Skip to content

Commit

Permalink
Add case-insensitive atoms 't' and 'nil' to CommonList parser.
Browse files Browse the repository at this point in the history
Fixes #21
  • Loading branch information
gkellogg committed Oct 8, 2022
1 parent 7133e42 commit 17346ce
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 3 deletions.
2 changes: 1 addition & 1 deletion Gemfile
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ source 'https://rubygems.org'

gemspec

gem "rdf", git: "git://github.com/ruby-rdf/rdf.git", branch: "develop"
gem "rdf", git: "https://github.com/ruby-rdf/rdf", branch: "develop"

group :debug do
gem "byebug", platform: :mri
Expand Down
19 changes: 17 additions & 2 deletions lib/sxp/reader/common_lisp.rb
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ module SXP; class Reader
#
# @see https:/www.cs.cmu.edu/Groups/AI/html/cltl/clm/node14.html
class CommonLisp < Basic
OPTIONS = {nil: nil, t: true, quote: :quote, function: :function}
OPTIONS = {nil: false, t: true, quote: :quote, function: :function}

DECIMAL = /^[+-]?(\d*)?\.\d*$/
INTEGER_BASE_2 = /^[+-]?[01]+$/
Expand Down Expand Up @@ -35,7 +35,7 @@ class CommonLisp < Basic
#
# @param [IO, StringIO, String] input
# @param [Hash{Symbol => Object}] options
# @option options [Object] :nil (nil)
# @option options [Object] :nil (false)
# @option options [Object] :t (true)
# @option options [Object] :quote (:quote)
# @option options [Object] :function (:function)
Expand Down Expand Up @@ -69,6 +69,21 @@ def read_sharp
end
end

##
# Based on Basic#read_atom, but adds 't' and 'nil' atoms.
# @return [Object]
def read_atom
case buffer = read_literal
when '.' then buffer.to_sym
when RATIONAL then Rational($1.to_i, $2.to_i)
when DECIMAL then Float(buffer) # FIXME?
when INTEGER then Integer(buffer)
when /^t$/i then true
when /^nil$/i then false
else buffer.to_sym
end
end

##
# @return [Symbol]
def read_symbol(delimiter = nil)
Expand Down
15 changes: 15 additions & 0 deletions spec/common_lisp_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,21 @@
end
end

context "when reading booleans" do
{
't' => true,
'T' => true,
'nil' => false,
'NIL' => false,
'(or t nil)' => [:or, true, false],
'(or T NIL)' => [:or, true, false]
}.each_pair do |input, output|
it "reads #{input} as an integer" do
expect(read(input)).to eq output
end
end
end

context "when reading lists" do
it "reads `()` as an empty list" do
expect(read(%q(()))).to eq [] # FIXME
Expand Down

0 comments on commit 17346ce

Please sign in to comment.