class Opal::Nodes::BaseYieldNode
def compile_call(children, level)
def compile_call(children, level) yielding_scope = find_yielding_scope yielding_scope.uses_block! block_name = yielding_scope.block_name || '$yield' if yields_single_arg?(children) push expr(children.first) wrap "Opal.yield1(#{block_name}, ", ')' else push expr(s(:arglist, *children)) if uses_splat?(children) wrap "Opal.yieldX(#{block_name}, ", ')' else wrap "Opal.yieldX(#{block_name}, [", '])' end end end
def find_yielding_scope
def find_yielding_scope working = scope while working if working.block_name or working.def? break end working = working.parent end working end
def uses_splat?(children)
def uses_splat?(children) children.any? { |child| child.type == :splat } end
def yields_single_arg?(children)
def yields_single_arg?(children) !uses_splat?(children) and children.size == 1 end