module DissociatedIntrospection class MethodInLiner attr_reader :defs, :ruby_code # @param [Array] defs # @param [DissociatedIntrospection::RubyCode] ruby_code def initialize(ruby_code, defs:) @defs = defs @ruby_code = ruby_code end # @return [DissociatedIntrospection::RubyCode] def in_line rewriter = InLiner.new rewriter.defs = defs result = rewriter.process(ruby_code.ast) RubyCode.build_from_ast(result) end class InLiner < Parser::TreeRewriter attr_accessor :defs def on_send(node) if (result = in_line_calls(node)) result else super end end def in_line_calls(node) called_on, method_name, *args = *node # TODO: Deal with args by replacing lvar with passed objects return unless args.empty? && called_on_self?(called_on) called_method = called_method(method_name) return unless called_method processed_called_method = process(called_method.body.ast) node.updated(processed_called_method.type, processed_called_method.children) end def called_on_self?(called_on) called_on.nil? || called_on.type == :self end def called_method(method_name) defs.detect { |_def| _def.name == method_name } end end end end