class Opal::Nodes::ZsuperNode

super with implicit args

def block_name

def block_name
  case def_scope
  when Opal::Nodes::IterNode
    def_scope.block_name
  when Opal::Nodes::DefNode
    def_scope.block_name
  else
    raise "Don't know what to do with super in the scope #{def_scope}"
  end
end

def compile

def compile
  if def_scope
    implicit_args = implicit_arglist
    # If the method we're in has a block and we're using a default super call with no args, we need to grab the block
    # If an iter (block via braces) is provided, that takes precedence
    if block_name && !iter
      block_pass = s(:block_pass, s(:lvar, block_name))
      implicit_args << block_pass
    end
    @arglist = s(:arglist, *implicit_args)
  end
  compile_using_send
end

def implicit_arglist

def implicit_arglist
  args = []
  kwargs = []
  def_scope.original_args.children.each do |sexp|
    lvar_name = sexp.children[0]
    case sexp.type
    when :arg, :optarg
      arg_node = s(:lvar, lvar_name)
      args << arg_node
    when :restarg
      arg_node = lvar_name ? s(:lvar, lvar_name) : s(:js_tmp, '$rest_arg')
      args << s(:splat, arg_node)
    when :kwarg, :kwoptarg
      key_name = sexp.meta[:arg_name]
      kwargs << s(:pair, s(:sym, key_name), s(:lvar, lvar_name))
    when :kwrestarg
      arg_node = lvar_name ? s(:lvar, lvar_name) : s(:js_tmp, '$kw_rest_arg')
      kwargs << s(:kwsplat, arg_node)
    end
  end
  args << s(:hash, *kwargs) unless kwargs.empty?
  args
end

def implicit_arguments_param

def implicit_arguments_param
  'true'
end

def initialize(*)

def initialize(*)
  super
  # preserve a block if we have one already but otherwise, assume a block is coming from higher
  # up the chain
  unless iter.type == :iter
    # Need to support passing block up even if it's not referenced in this method at all
    scope.uses_block!
    @iter = s(:js_tmp, scope.block_name || '$yield')
  end
end