adjusted code and tests to use renamed and rearranged parser bits

This commit is contained in:
Torsten Ruger 2014-04-27 18:13:34 +03:00
parent 032758db8b
commit 28410ab22a
5 changed files with 28 additions and 28 deletions

View File

@ -3,7 +3,7 @@ require 'vm/nodes'
module Parser
class Transform < Parslet::Transform
rule(:number => simple(:value)) { Vm::NumberExpression.new(value.to_i) }
rule(:integer => simple(:value)) { Vm::IntegerExpression.new(value.to_i) }
rule(:name => simple(:name)) { Vm::NameExpression.new(name.to_s) }
rule(:arg => simple(:arg)) { arg }

View File

@ -7,7 +7,7 @@ module Vm
end
end
class NumberExpression < Expression
class IntegerExpression < Expression
attr_reader :value
def initialize val
@value = val

View File

@ -19,13 +19,13 @@ class TestNodes < MiniTest::Test
def test_number
tree = parse "42"
assert_kind_of Vm::NumberExpression , tree
assert_kind_of Vm::IntegerExpression , tree
assert_equal 42 , tree.value
end
def test_args
tree = parse "( 42 )"
assert_kind_of Hash , tree
assert_kind_of Vm::NumberExpression , tree[:args]
assert_kind_of Vm::IntegerExpression , tree[:args]
assert_equal 42 , tree[:args].value
end
def test_arg_list

View File

@ -13,8 +13,8 @@ class ParserTest < MiniTest::Test
end
def test_number
@input = '42 '
@expected = {:number => '42'}
@parser = @parser.number
@expected = {:integer => '42'}
@parser = @parser.integer
end
def test_name
@ -25,7 +25,7 @@ class ParserTest < MiniTest::Test
def test_argument_list
@input = '(42, foo)'
@expected = {:args => [{:arg => {:number => '42'}},
@expected = {:args => [{:arg => {:integer => '42'}},
{:arg => {:name => 'foo'}}]}
@parser = @parser.args
end
@ -33,7 +33,7 @@ class ParserTest < MiniTest::Test
def test_function_call
@input = 'baz(42, foo)'
@expected = {:funcall => {:name => 'baz' },
:args => [{:arg => {:number => '42'}},
:args => [{:arg => {:integer => '42'}},
{:arg => {:name => 'foo'}}]}
@parser = @parser.funcall
@ -47,9 +47,9 @@ if (0) {
667
}
HERE
@expected = {:cond => {:number => '0'},
:if_true => {:body => {:number => '42'}},
:if_false => {:body => {:number => '667'}}}
@expected = {:cond => {:integer => '0'},
:if_true => {:body => {:integer => '42'}},
:if_false => {:body => {:integer => '667'}}}
@parser = @parser.cond
end
@ -61,7 +61,7 @@ function foo(x) {
HERE
@expected = {:func => {:name => 'foo'},
:params => {:param => {:name => 'x'}},
:body => {:number => '5'}}
:body => {:integer => '5'}}
@parser = @parser.func
end
end

View File

@ -13,8 +13,8 @@ class TransformTest < MiniTest::Test
assert_equal @expected.class , is.class
end
def test_number
@input = {:number => '42'}
@expected = Vm::NumberExpression.new(42)
@input = {:integer => '42'}
@expected = Vm::IntegerExpression.new(42)
check_equals
assert_equal 42 , @expected.value
end
@ -26,39 +26,39 @@ class TransformTest < MiniTest::Test
end
def test_argument_list
@input = {:args => [{:arg => {:number => '42'}},
@input = {:args => [{:arg => {:integer => '42'}},
{:arg => {:name => 'foo'}}]}
@expected = [Vm::NumberExpression.new(42),
@expected = [Vm::IntegerExpression.new(42),
Vm::NameExpression.new('foo')]
check_equals
end
def test_single_argument
@input = {:funcall => {:name => 'foo'},
:args => [{:arg => {:number => '42'}}]}
@expected = Vm::FuncallExpression.new 'foo', [Vm::NumberExpression.new(42)]
:args => [{:arg => {:integer => '42'}}]}
@expected = Vm::FuncallExpression.new 'foo', [Vm::IntegerExpression.new(42)]
check_equals
end
def test_multi_argument
@input = {:funcall => {:name => 'baz'},
:args => [{:arg => {:number => '42'}},
:args => [{:arg => {:integer => '42'}},
{:arg => {:name => 'foo'}}]}
@expected = Vm::FuncallExpression.new 'baz', [Vm::NumberExpression.new(42),
@expected = Vm::FuncallExpression.new 'baz', [Vm::IntegerExpression.new(42),
Vm::NameExpression.new('foo')]
check_equals
end
def test_conditional
@input = {:cond => {:number => '0'},
:if_true => {:body => {:number => '42'}},
:if_false => {:body => {:number => '667'}}}
@input = {:cond => {:integer => '0'},
:if_true => {:body => {:integer => '42'}},
:if_false => {:body => {:integer => '667'}}}
@expected = Vm::ConditionalExpression.new \
Vm::NumberExpression.new(0),
Vm::NumberExpression.new(42),
Vm::NumberExpression.new(667)
Vm::IntegerExpression.new(0),
Vm::IntegerExpression.new(42),
Vm::IntegerExpression.new(667)
check_equals
end
@ -66,11 +66,11 @@ class TransformTest < MiniTest::Test
def test__function_definition
@input = {:func => {:name => 'foo'},
:params => {:param => {:name => 'x'}},
:body => {:number => '5'}}
:body => {:integer => '5'}}
@expected = Vm::FunctionExpression.new \
'foo',
[Vm::NameExpression.new('x')],
Vm::NumberExpression.new(5)
Vm::IntegerExpression.new(5)
check_equals
end