module RipperRubyParser module SexpHandlers module HelperMethods def handle_potentially_typeless_sexp exp if exp.nil? s() elsif exp.first.is_a? Symbol process(exp) else exp.map! { |sub_exp| handle_potentially_typeless_sexp(sub_exp) } end end def handle_potentially_typeless_sexp_with_fallback_type type, exp if exp.nil? s() elsif exp.first.is_a? Symbol process(exp) else exp.map! { |sub_exp| process(sub_exp) } exp.unshift type exp end end def convert_block_args(args) if args names = args[1][1..-1] if names.length > 1 or names.first =~ /^\*/ s(:masgn, s(:array, *names.map { |name| arg_name_to_lasgn(name) })) else s(:lasgn, names.first) end end end def arg_name_to_lasgn(name) if name =~ /^\*(.*)/ s(:splat, s(:lasgn, $1.to_sym)) else s(:lasgn, name) end end def handle_statement_list exp statements = map_body exp wrap_in_block(statements) end def extract_node_symbol_with_position exp return nil if exp.nil? _, ident, pos = exp.shift 3 return ident.to_sym, pos end def extract_node_symbol exp return nil if exp.nil? _, ident, _ = exp.shift 3 ident.to_sym end def with_position pos, exp (line, _) = pos with_line_number line, exp end def with_line_number line, exp exp.line = line exp end def with_position_from_node_symbol exp sym, pos = extract_node_symbol_with_position exp with_position(pos, yield(sym)) end def generic_add_star exp _, args, splatarg = exp.shift 3 items = args.map { |sub| process(sub) } items << s(:splat, process(splatarg)) s(*items) end def is_literal? exp exp.sexp_type == :lit end def map_body body body. map { |sub_exp| process(sub_exp) }. reject { |sub_exp| sub_exp.sexp_type == :void_stmt } end def wrap_in_block statements case statements.length when 0 nil when 1 statements.first else s(:block, *statements) end end def handle_return_argument_list arglist arglist = process(arglist) args = arglist[1..-1] if args.length == 1 arg = args[0] if arg.sexp_type == :splat s(:svalue, arg) else arg end else s(:array, *args) end end end end end