fix array in if_false
This commit is contained in:
parent
dab32bc307
commit
8e07a7568f
@ -40,7 +40,7 @@ module Parser
|
||||
rule(:if => simple(:if), :conditional => simple(:conditional),
|
||||
:if_true => {:expressions => sequence(:if_true) , :else => simple(:else) },
|
||||
:if_false => {:expressions => sequence(:if_false) , :end => simple(:e) }) do
|
||||
s(:if , s(:condition, conditional), s(:if_true, *if_true), s(:if_false , if_false))
|
||||
s(:if , s(:condition, conditional), s(:if_true, *if_true), s(:if_false , *if_false))
|
||||
end
|
||||
|
||||
rule(:if => simple(:if), :conditional => simple(:conditional),
|
||||
|
@ -8,21 +8,22 @@ class Ifi
|
||||
end
|
||||
end
|
||||
-- -- --
|
||||
s(:expressions,
|
||||
s(:class, :Ifi,
|
||||
s(:derives, nil),
|
||||
s(:function, :int,
|
||||
s(:name, :ofthen),
|
||||
s(:parameters,
|
||||
s(:field, :int, :n)),
|
||||
s(:expressions,
|
||||
s(:if,
|
||||
s(:condition,
|
||||
s(:int, 0)),
|
||||
s(:if_true,
|
||||
s(:assign,
|
||||
s(:name, :isit),
|
||||
s(:int, 42))),
|
||||
s(:if_false, [s(:assign,
|
||||
s(:name, :maybenot),
|
||||
s(:int, 667))]))))))
|
||||
s(:expressions,
|
||||
s(:class, :Ifi,
|
||||
s(:derives, nil),
|
||||
s(:function, :int,
|
||||
s(:name, :ofthen),
|
||||
s(:parameters,
|
||||
s(:field, :int, :n)),
|
||||
s(:expressions,
|
||||
s(:if,
|
||||
s(:condition,
|
||||
s(:int, 0)),
|
||||
s(:if_true,
|
||||
s(:assign,
|
||||
s(:name, :isit),
|
||||
s(:int, 42))),
|
||||
s(:if_false,
|
||||
s(:assign,
|
||||
s(:name, :maybenot),
|
||||
s(:int, 667))))))))
|
||||
|
@ -4,10 +4,11 @@ else
|
||||
667
|
||||
end
|
||||
-- -- --
|
||||
s(:expressions,
|
||||
s(:if,
|
||||
s(:condition,
|
||||
s(:int, 0)),
|
||||
s(:if_true,
|
||||
s(:int, 42)),
|
||||
s(:if_false, [s(:int, 667)])))
|
||||
s(:expressions,
|
||||
s(:if,
|
||||
s(:condition,
|
||||
s(:int, 0)),
|
||||
s(:if_true,
|
||||
s(:int, 42)),
|
||||
s(:if_false,
|
||||
s(:int, 667))))
|
||||
|
@ -4,22 +4,22 @@ else
|
||||
var.new(33)
|
||||
end
|
||||
-- -- --
|
||||
s(:expressions,
|
||||
s(:if,
|
||||
s(:condition,
|
||||
s(:operator, ">",
|
||||
s(:int, 3),
|
||||
s(:name, :var))),
|
||||
s(:if_true,
|
||||
s(:call,
|
||||
s(:name, :initialize),
|
||||
s(:arguments,
|
||||
s(:int, 3)),
|
||||
s(:receiver,
|
||||
s(:module, "Object")))),
|
||||
s(:if_false, [s(:call,
|
||||
s(:name, :new),
|
||||
s(:arguments,
|
||||
s(:int, 33)),
|
||||
s(:receiver,
|
||||
s(:name, :var)))])))
|
||||
s(:expressions,
|
||||
s(:if,
|
||||
s(:condition,
|
||||
s(:operator, ">",
|
||||
s(:int, 3),
|
||||
s(:name, :var))),
|
||||
s(:if_true,
|
||||
s(:call,
|
||||
s(:name, :initialize),
|
||||
s(:arguments,
|
||||
s(:int, 3)),
|
||||
s(:receiver,
|
||||
s(:module, "Object")))),
|
||||
s(:if_false, s(:call,
|
||||
s(:name, :new),
|
||||
s(:arguments,
|
||||
s(:int, 33)),
|
||||
s(:receiver,
|
||||
s(:name, :var))))))
|
||||
|
@ -6,19 +6,20 @@ ref ofthen(int n)
|
||||
end
|
||||
end
|
||||
-- -- --
|
||||
s(:expressions,
|
||||
s(:function, :ref,
|
||||
s(:name, :ofthen),
|
||||
s(:parameters,
|
||||
s(:field, :int, :n)),
|
||||
s(:expressions,
|
||||
s(:if,
|
||||
s(:condition,
|
||||
s(:int, 0)),
|
||||
s(:if_true,
|
||||
s(:assign,
|
||||
s(:name, :isit),
|
||||
s(:int, 42))),
|
||||
s(:if_false, [s(:assign,
|
||||
s(:name, :maybenot),
|
||||
s(:int, 667))])))))
|
||||
s(:expressions,
|
||||
s(:function, :ref,
|
||||
s(:name, :ofthen),
|
||||
s(:parameters,
|
||||
s(:field, :int, :n)),
|
||||
s(:expressions,
|
||||
s(:if,
|
||||
s(:condition,
|
||||
s(:int, 0)),
|
||||
s(:if_true,
|
||||
s(:assign,
|
||||
s(:name, :isit),
|
||||
s(:int, 42))),
|
||||
s(:if_false,
|
||||
s(:assign,
|
||||
s(:name, :maybenot),
|
||||
s(:int, 667)))))))
|
||||
|
@ -6,19 +6,20 @@ int retvar(int n)
|
||||
end
|
||||
end
|
||||
-- -- --
|
||||
s(:expressions,
|
||||
s(:function, :int,
|
||||
s(:name, :retvar),
|
||||
s(:parameters,
|
||||
s(:field, :int, :n)),
|
||||
s(:expressions,
|
||||
s(:if,
|
||||
s(:condition,
|
||||
s(:operator, ">",
|
||||
s(:name, :n),
|
||||
s(:int, 5))),
|
||||
s(:if_true,
|
||||
s(:return,
|
||||
s(:int, 10))),
|
||||
s(:if_false, [s(:return,
|
||||
s(:int, 20))])))))
|
||||
s(:expressions,
|
||||
s(:function, :int,
|
||||
s(:name, :retvar),
|
||||
s(:parameters,
|
||||
s(:field, :int, :n)),
|
||||
s(:expressions,
|
||||
s(:if,
|
||||
s(:condition,
|
||||
s(:operator, ">",
|
||||
s(:name, :n),
|
||||
s(:int, 5))),
|
||||
s(:if_true,
|
||||
s(:return,
|
||||
s(:int, 10))),
|
||||
s(:if_false,
|
||||
s(:return,
|
||||
s(:int, 20)))))))
|
||||
|
@ -8,20 +8,21 @@ module Foo
|
||||
end
|
||||
end
|
||||
-- -- --
|
||||
s(:expressions,
|
||||
s(:module, :Foo,
|
||||
s(:function, :ref,
|
||||
s(:name, :ofthen),
|
||||
s(:parameters,
|
||||
s(:field, :int, :n)),
|
||||
s(:expressions,
|
||||
s(:if,
|
||||
s(:condition,
|
||||
s(:int, 0)),
|
||||
s(:if_true,
|
||||
s(:assign,
|
||||
s(:name, :isit),
|
||||
s(:int, 42))),
|
||||
s(:if_false, [s(:assign,
|
||||
s(:name, :maybenot),
|
||||
s(:int, 667))]))))))
|
||||
s(:expressions,
|
||||
s(:module, :Foo,
|
||||
s(:function, :ref,
|
||||
s(:name, :ofthen),
|
||||
s(:parameters,
|
||||
s(:field, :int, :n)),
|
||||
s(:expressions,
|
||||
s(:if,
|
||||
s(:condition,
|
||||
s(:int, 0)),
|
||||
s(:if_true,
|
||||
s(:assign,
|
||||
s(:name, :isit),
|
||||
s(:int, 42))),
|
||||
s(:if_false,
|
||||
s(:assign,
|
||||
s(:name, :maybenot),
|
||||
s(:int, 667))))))))
|
||||
|
Loading…
x
Reference in New Issue
Block a user