1
0
Fork 0
mirror of https://github.com/pry/pry.git synced 2022-11-09 12:35:05 -05:00
pry--pry/lib/pry/commands/cd.rb
Kyrylo Silin 4956376f13 rubocop: fix offences of the Metrics/LineLength cop
I realise that some code might be less readable now, but now that we set a good
default limit, we protect the codebase from further mess. It's important to do
this to prevent adding more mess to already messy code that we have. :doctor:
2019-03-03 17:37:58 +02:00

43 lines
1.1 KiB
Ruby

class Pry
class Command
class Cd < Pry::ClassCommand
match 'cd'
group 'Context'
description 'Move into a new context (object or scope).'
banner <<-'BANNER'
Usage: cd [OPTIONS] [--help]
Move into new context (object or scope). As in UNIX shells use `cd ..` to go
back, `cd /` to return to Pry top-level and `cd -` to toggle between last two
scopes. Complex syntax (e.g `cd ../@x/@y`) also supported.
cd @x
cd ..
cd /
cd -
https://github.com/pry/pry/wiki/State-navigation#wiki-Changing_scope
BANNER
def process
state.old_stack ||= []
if arg_string.strip == "-"
unless state.old_stack.empty?
_pry_.binding_stack, state.old_stack = state.old_stack, _pry_.binding_stack
end
else
stack = ObjectPath.new(arg_string, _pry_.binding_stack).resolve
if stack && stack != _pry_.binding_stack
state.old_stack = _pry_.binding_stack
_pry_.binding_stack = stack
end
end
end
end
Pry::Commands.add_command(Pry::Command::Cd)
end
end