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