Skip to content

Commit

Permalink
Merge pull request #203 from k0kubun/ls
Browse files Browse the repository at this point in the history
Implement pry-like ls command
  • Loading branch information
aycabta authored Mar 21, 2021
2 parents 209f53c + 19b6c20 commit dc6cbb6
Show file tree
Hide file tree
Showing 4 changed files with 84 additions and 7 deletions.
48 changes: 48 additions & 0 deletions lib/irb/cmd/ls.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
# frozen_string_literal: true

require_relative "nop"
require_relative "../color"

# :stopdoc:
module IRB
module ExtendCommand
class Ls < Nop
def execute(*arg, grep: nil)
o = Output.new(grep: grep)

obj = arg.empty? ? irb_context.workspace.main : arg.first
locals = arg.empty? ? irb_context.workspace.binding.local_variables : []
klass = (obj.class == Class || obj.class == Module ? obj : obj.class)

o.dump("constants", obj.constants) if obj.respond_to?(:constants)
o.dump("#{klass}.methods", obj.singleton_methods(false))
o.dump("#{klass}#methods", klass.public_instance_methods(false))
o.dump("instance variables", obj.instance_variables)
o.dump("class variables", klass.class_variables)
o.dump("locals", locals)
end

class Output
def initialize(grep: nil)
@grep = grep
end

def dump(name, strs)
strs = strs.grep(@grep) if @grep
strs = strs.sort
return if strs.empty?

print "#{Color.colorize(name, [:BOLD, :BLUE])}: "
if strs.size > 7
len = [strs.map(&:length).max, 16].min
puts; strs.each_slice(7) { |ss| puts " #{ss.map { |s| "%-#{len}s" % s }.join(" ")}" }
else
puts strs.join(" ")
end
end
end
private_constant :Output
end
end
end
# :startdoc:
14 changes: 10 additions & 4 deletions lib/irb/cmd/nop.rb
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,16 @@ module IRB
module ExtendCommand
class Nop


def self.execute(conf, *opts, &block)
command = new(conf)
command.execute(*opts, &block)
if RUBY_ENGINE == "ruby" && RUBY_VERSION >= "2.7.0"
def self.execute(conf, *opts, **kwargs, &block)
command = new(conf)
command.execute(*opts, **kwargs, &block)
end
else
def self.execute(conf, *opts, &block)
command = new(conf)
command.execute(*opts, &block)
end
end

def initialize(conf)
Expand Down
12 changes: 9 additions & 3 deletions lib/irb/extend-command.rb
Original file line number Diff line number Diff line change
Expand Up @@ -125,6 +125,11 @@ def irb_context
:irb_info, :Info, "irb/cmd/info"
],

[
:irb_ls, :Ls, "irb/cmd/ls",
[:ls, NO_OVERRIDE],
],

[
:irb_measure, :Measure, "irb/cmd/measure",
[:measure, NO_OVERRIDE],
Expand Down Expand Up @@ -169,12 +174,13 @@ def self.def_extend_command(cmd_name, cmd_class, load_file = nil, *aliases)
end

if load_file
kwargs = ", **kwargs" if RUBY_ENGINE == "ruby" && RUBY_VERSION >= "2.7.0"
line = __LINE__; eval %[
def #{cmd_name}(*opts, &b)
def #{cmd_name}(*opts#{kwargs}, &b)
require "#{load_file}"
arity = ExtendCommand::#{cmd_class}.instance_method(:execute).arity
args = (1..(arity < 0 ? ~arity : arity)).map {|i| "arg" + i.to_s }
args << "*opts" if arity < 0
args << "*opts#{kwargs}" if arity < 0
args << "&block"
args = args.join(", ")
line = __LINE__; eval %[
Expand All @@ -185,7 +191,7 @@ def self.#{cmd_name}_(\#{args})
end
end
], nil, __FILE__, line
__send__ :#{cmd_name}_, *opts, &b
__send__ :#{cmd_name}_, *opts#{kwargs}, &b
end
], nil, __FILE__, line
else
Expand Down
17 changes: 17 additions & 0 deletions test/irb/test_cmd.rb
Original file line number Diff line number Diff line change
Expand Up @@ -372,5 +372,22 @@ def test_irb_load
/=> "bug17564"\n/,
], out)
end

def test_ls
IRB.init_config(nil)
workspace = IRB::WorkSpace.new(self)
irb = IRB::Irb.new(workspace)
IRB.conf[:MAIN_CONTEXT] = irb.context
input = TestInputMethod.new([
"ls Object.new.tap { |o| o.instance_variable_set(:@a, 1) }\n",
])
irb = IRB::Irb.new(IRB::WorkSpace.new(Object.new), input)
irb.context.return_format = "=> %s\n"
out, err = capture_output do
irb.eval_input
end
assert_empty err
assert_match(/^instance variables: @a\n/, out)
end
end
end

0 comments on commit dc6cbb6

Please sign in to comment.