lib/byebug/commands/method.rb in byebug-3.5.1 vs lib/byebug/commands/method.rb in byebug-4.0.0
- old
+ new
@@ -1,5 +1,7 @@
+require 'byebug/command'
+
module Byebug
#
# Show methods of specific classes/modules/objects.
#
class MethodCommand < Command
@@ -9,31 +11,37 @@
/^\s* m(?:ethod)? \s+ (i(:?nstance)?\s+)?/x
end
def execute
obj = bb_eval(@match.post_match)
- if @match[1]
- puts "#{columnize(obj.methods.sort, Setting[:width])}"
- elsif !obj.is_a?(Module)
- puts "Should be Class/Module: #{@match.post_match}"
- else
- puts "#{columnize(obj.instance_methods(false).sort, Setting[:width])}"
- end
+ result =
+ if @match[1]
+ prc('method.methods', obj.methods.sort) { |item, _| { name: item } }
+ elsif !obj.is_a?(Module)
+ pr('variable.errors.not_module', object: @match.post_match)
+ else
+ prc('method.methods', obj.instance_methods(false).sort) do |item, _|
+ { name: item }
+ end
+ end
+ puts result
end
class << self
def names
%w(method)
end
def description
- %{m[ethod] (i[nstance][ <obj>]|<class|module>)
+ prettify <<-EOD
+ m[ethod] (i[nstance][ <obj>]|<class|module>)
When invoked with "instance", shows instance methods of the object
specified as argument or of self no object was specified.
When invoked only with a class or module, shows class methods of the
- class or module specified as argument.}
+ class or module specified as argument.
+ EOD
end
end
end
end