1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
|
module Treetop
module Compiler
class Choice < ParsingExpression
def compile(address, builder, parent_expression = nil)
super
begin_comment(self)
use_vars :result, :start_index
compile_alternatives(alternatives, parent_expression)
end_comment(self)
end
def compile_alternatives(alternatives, parent_expression)
obtain_new_subexpression_address
alternatives.first.compile(subexpression_address, builder)
builder.if__ subexpression_success? do
# Undo lazy instantiation:
builder << "#{subexpression_result_var} = SyntaxNode.new(input, (index-1)...index) if #{subexpression_result_var} == true"
assign_result subexpression_result_var
extend_result_with_declared_module
extend_result_with_inline_module parent_expression
end
builder.else_ do
if alternatives.size == 1
reset_index
assign_failure start_index_var
else
compile_alternatives(alternatives[1..-1], parent_expression)
end
end
end
def expected
'"(any alternative)"'
end
end
end
end
|