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