lib/byebug/commands/method.rb



module Byebug

  begin
    require 'methodsig'
    have_methodsig = true
  rescue LoadError
    have_methodsig = false
  end

  # Implements byebug's 'method sig' command.
  class MethodSigCommand < Command
    def regexp
      /^\s* m(?:ethod)? \s+ sig(?:nature)? \s+ (\S+) \s*$/x
    end

    def execute
      obj = bb_eval('method(:%s)' % @match[1])
      if obj.is_a?(Method)
        begin
          print "%s\n", obj.signature.to_s
        rescue
          errmsg("Can't get signature for '#{@match[1]}'\n")
        end
      else
        errmsg("Can't make method out of '#{@match[1]}'\n")
      end
    end

    class << self
      def names
        %w(method)
      end

      def description
        %{m[ethod] sig[nature] <obj>\tshow the signature of a method}
      end
    end
  end if have_methodsig

  # Implements byebug's 'method' command.
  class MethodCommand < Command
    include Columnize

    def regexp
      /^\s* m(?:ethod)? \s+ ((iv)|(i(:?nstance)?)\s+)?/x
    end

    def execute
      obj = bb_eval(@match.post_match)
      if @match[1] == "iv"
        obj.instance_variables.sort.each do |v|
          print "#{v} = #{obj.instance_variable_get(v).inspect}\n"
        end
      elsif @match[1]
        print "#{columnize(obj.methods.sort(), Command.settings[:width])}\n"
      else
        return print "Should be Class/Module: #{@match.post_match}\n" unless
          obj.kind_of? Module
        print "#{columnize(obj.instance_methods(false).sort(),
                           Command.settings[:width])}\n"
      end
    end

    class << self
      def names
        %w(method)
      end

      def description
        %{m[ethod] i[nstance] <obj>\tshow methods of object
          m[ethod] iv <obj>\t\tshow instance variables of object
          m[ethod] <class|module>\t\tshow instance methods of class or module}
      end
    end
  end

end