class Opal::Nodes::BaseYieldNode
def compile_call
def compile_call yielding_scope = find_yielding_scope yielding_scope.uses_block! yielding_scope.block_name ||= '$yield' block_name = yielding_scope.block_name 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 || 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) && children.size == 1 end