require File.dirname(__FILE__) + '/../helper' class ShakeLexerTest < Test::Unit::TestCase P = File.dirname(__FILE__) + "/samples/shake_tracker_nodes.shk" L = Tracksperanto::ShakeGrammar::Lexer def test_parse_single_cmt cmt = " // Mary had a little lamb" s = parse(cmt) assert_equal [[:comment, " Mary had a little lamb"]], s end def test_parse_two_line_cmt cmt = [" // Mary had a little lamb", " // Old McDonald had a farm"].join("\n\n\n\n\n\n") s = parse(cmt) assert_equal [[:comment, " Mary had a little lamb"], [:comment, " Old McDonald had a farm"]], s end def test_parse_cmt_and_unknown cmt = " // Mary had a little lamb\nFooBar" s = parse(cmt) assert_equal [[:comment, " Mary had a little lamb"], [:atom, "FooBar"]], s end def test_parse_funcall s = parse ' DoFoo(1, 2, 3, "Welcome!\"\""); ' assert_equal [[:funcall, "DoFoo", [:atom_i, 1], [:atom_i, 2], [:atom_i, 3], [:atom_c, 'Welcome!""']]], s end def test_parse_nested_funcall s = parse ' DoFoo(1, Foo(4));' assert_equal [[:funcall, "DoFoo", [:atom_i, 1], [:funcall, "Foo", [:atom_i, 4]]]], s end def test_parse_single_nested_funcall s = parse("OuterFunc(InnerFunc(15)") assert_equal [[:funcall, "OuterFunc", [:funcall, "InnerFunc", [:atom_i, 15]]]], s end def test_parse_single_funcall s = parse('SomeFunc(1,2,3)') assert_equal [[:funcall, "SomeFunc", [:atom_i, 1], [:atom_i, 2], [:atom_i, 3]]], s end def test_parse_funcall_with_valueats s = parse 'Linear(0,716.08@1,715.846@2,715.518@3,715.034@4,714.377@5)' assert_equal( [ [:funcall, "Linear", [:atom_i, 0], [[:atom_f, 716.08], [:atom_at_i, 1]], [[:atom_f, 715.846], [:atom_at_i, 2]], [[:atom_f, 715.518], [:atom_at_i, 3]], [[:atom_f, 715.034], [:atom_at_i, 4]], [[:atom_f, 714.377], [:atom_at_i, 5]] ] ], s) end def test_parse_hermite_valuats_containing_arrays # Hermite curves use array args s = parse 'Hermite(0,[-64,98.33,98.33]@1,[50,97.29,97.29]@4)' ref = [[:funcall, "Hermite", [:atom_i, 0], [:arr, [:atom_f, -64.0], [:atom_f, 98.33], [:atom_f, 98.33]], [:atom_at_i, 1], [:arr, [:atom_i, 50], [:atom_f, 97.29], [:atom_f, 97.29]], [:atom_at_i, 4] ]] assert_equal ref, s end def test_parse_from_start_injects_comment p = File.open(P){|f| f.read(1600) } tree = parse(p) assert_equal :comment, tree[0][0] assert_equal :comment, tree[1][0] assert_equal :funcall, tree[2][0] end def test_parse_varassign s = parse 'Foo = Blur(Foo, 1, 2, 3);' assert_equal [[:var, "Foo"], [:eq], [:funcall, "Blur", [:atom, "Foo"], [:atom_i, 1], [:atom_i, 2], [:atom_i, 3]]], s end def test_parse_whole_file_does_not_raise assert_nothing_raised do parse(File.open(P), L) end end def parse(s, klass = L) s = StringIO.new(s) unless s.respond_to?(:read) klass.new(s).stack end end