2011-04-12 20:48:50 -04:00
|
|
|
class Pry
|
2011-04-25 16:58:06 -04:00
|
|
|
module Helpers
|
2011-04-12 20:48:50 -04:00
|
|
|
|
2011-04-25 16:58:06 -04:00
|
|
|
module BaseHelpers
|
2011-08-08 08:35:22 -04:00
|
|
|
|
2011-05-04 08:53:04 -04:00
|
|
|
module_function
|
|
|
|
|
|
|
|
def silence_warnings
|
|
|
|
old_verbose = $VERBOSE
|
|
|
|
$VERBOSE = nil
|
|
|
|
begin
|
|
|
|
yield
|
|
|
|
ensure
|
|
|
|
$VERBOSE = old_verbose
|
|
|
|
end
|
|
|
|
end
|
2011-04-18 17:31:39 -04:00
|
|
|
|
2012-11-02 09:26:01 -04:00
|
|
|
# Acts like send but ignores any methods defined below Object or Class in the
|
|
|
|
# inheritance hierarchy.
|
|
|
|
# This is required to introspect methods on objects like Net::HTTP::Get that
|
|
|
|
# have overridden the `method` method.
|
|
|
|
def safe_send(obj, method, *args, &block)
|
|
|
|
(Module === obj ? Module : Object).instance_method(method).bind(obj).call(*args, &block)
|
|
|
|
end
|
|
|
|
public :safe_send
|
|
|
|
|
2012-12-25 13:42:47 -05:00
|
|
|
def find_command(name, set = Pry::Commands)
|
|
|
|
command_match = set.find do |_, command|
|
2012-12-25 14:24:02 -05:00
|
|
|
(listing = command.options[:listing]) == name && listing != nil
|
2012-12-25 13:24:18 -05:00
|
|
|
end
|
|
|
|
command_match.last if command_match
|
2011-05-27 12:11:06 -04:00
|
|
|
end
|
2011-04-18 17:31:39 -04:00
|
|
|
|
2012-02-08 21:55:51 -05:00
|
|
|
def not_a_real_file?(file)
|
|
|
|
file =~ /(\(.*\))|<.*>/ || file =~ /__unknown__/ || file == "" || file == "-e"
|
|
|
|
end
|
|
|
|
|
2011-04-12 20:48:50 -04:00
|
|
|
def command_dependencies_met?(options)
|
|
|
|
return true if !options[:requires_gem]
|
|
|
|
Array(options[:requires_gem]).all? do |g|
|
2013-01-08 17:24:53 -05:00
|
|
|
Rubygem.installed?(g)
|
2011-04-12 20:48:50 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-01-06 15:43:41 -05:00
|
|
|
def set_file_and_dir_locals(file_name, _pry_=_pry_(), target=target())
|
2011-09-25 02:53:08 -04:00
|
|
|
return if !target or !file_name
|
2011-08-31 13:05:21 -04:00
|
|
|
_pry_.last_file = File.expand_path(file_name)
|
|
|
|
_pry_.inject_local("_file_", _pry_.last_file, target)
|
|
|
|
|
|
|
|
_pry_.last_dir = File.dirname(_pry_.last_file)
|
|
|
|
_pry_.inject_local("_dir_", _pry_.last_dir, target)
|
2011-05-04 09:45:29 -04:00
|
|
|
end
|
|
|
|
|
2011-10-09 15:03:24 -04:00
|
|
|
def use_ansi_codes?
|
2012-08-12 00:38:32 -04:00
|
|
|
windows_ansi? || ENV['TERM'] && ENV['TERM'] != "dumb"
|
2011-10-09 15:03:24 -04:00
|
|
|
end
|
|
|
|
|
2011-06-11 06:44:30 -04:00
|
|
|
def colorize_code(code)
|
|
|
|
if Pry.color
|
|
|
|
CodeRay.scan(code, :ruby).term
|
|
|
|
else
|
|
|
|
code
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-04-22 01:12:32 -04:00
|
|
|
def highlight(string, regexp, highlight_color=:bright_yellow)
|
2011-08-16 01:00:18 -04:00
|
|
|
string.gsub(regexp) { |match| "<#{highlight_color}>#{match}</#{highlight_color}>" }
|
2011-04-22 01:12:32 -04:00
|
|
|
end
|
|
|
|
|
2011-04-13 01:16:12 -04:00
|
|
|
# formatting
|
|
|
|
def heading(text)
|
|
|
|
text = "#{text}\n--"
|
|
|
|
Pry.color ? "\e[1m#{text}\e[0m": text
|
|
|
|
end
|
|
|
|
|
2011-12-26 19:48:59 -05:00
|
|
|
# have fun on the Windows platform.
|
|
|
|
def windows?
|
|
|
|
RbConfig::CONFIG['host_os'] =~ /mswin|mingw/
|
|
|
|
end
|
|
|
|
|
2012-06-23 18:06:32 -04:00
|
|
|
# are we able to use ansi on windows?
|
|
|
|
def windows_ansi?
|
|
|
|
defined?(Win32::Console) || ENV['ANSICON']
|
|
|
|
end
|
|
|
|
|
2011-08-22 21:41:27 -04:00
|
|
|
# are we on Jruby platform?
|
|
|
|
def jruby?
|
2011-12-27 18:04:30 -05:00
|
|
|
RbConfig::CONFIG['ruby_install_name'] == 'jruby'
|
2011-08-31 23:47:29 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
# are we on rbx platform?
|
|
|
|
def rbx?
|
2011-12-27 18:04:30 -05:00
|
|
|
RbConfig::CONFIG['ruby_install_name'] == 'rbx'
|
2011-08-22 21:41:27 -04:00
|
|
|
end
|
|
|
|
|
2012-04-12 22:55:30 -04:00
|
|
|
def mri_18?
|
|
|
|
RUBY_VERSION =~ /1.8/ && RbConfig::CONFIG['ruby_install_name'] == 'ruby'
|
|
|
|
end
|
|
|
|
|
|
|
|
def mri_19?
|
|
|
|
RUBY_VERSION =~ /1.9/ && RbConfig::CONFIG['ruby_install_name'] == 'ruby'
|
|
|
|
end
|
|
|
|
|
2011-04-18 10:11:00 -04:00
|
|
|
# Try to use `less` for paging, if it fails then use
|
|
|
|
# simple_pager. Also do not page if Pry.pager is falsey
|
2012-02-11 02:53:13 -05:00
|
|
|
def stagger_output(text, out = nil)
|
2012-02-11 03:00:38 -05:00
|
|
|
out ||= case
|
2012-08-12 00:38:32 -04:00
|
|
|
when respond_to?(:output)
|
|
|
|
# Mixin.
|
|
|
|
output
|
|
|
|
when Pry.respond_to?(:output)
|
|
|
|
# Parent.
|
|
|
|
Pry.output
|
|
|
|
else
|
|
|
|
# Sys.
|
|
|
|
$stdout
|
|
|
|
end
|
2012-04-12 22:55:30 -04:00
|
|
|
|
2012-08-08 18:00:04 -04:00
|
|
|
if text.lines.count < Pry::Pager.page_size || !Pry.pager
|
|
|
|
out.puts text
|
|
|
|
else
|
2012-08-09 10:58:49 -04:00
|
|
|
Pry::Pager.page(text)
|
2012-08-08 18:00:04 -04:00
|
|
|
end
|
2011-04-19 06:37:10 -04:00
|
|
|
rescue Errno::ENOENT
|
2012-08-09 11:43:46 -04:00
|
|
|
Pry::Pager.page(text, :simple)
|
2011-04-19 06:37:10 -04:00
|
|
|
rescue Errno::EPIPE
|
2011-04-13 01:16:12 -04:00
|
|
|
end
|
2012-08-12 00:38:32 -04:00
|
|
|
|
|
|
|
# @param [String] arg_string The object path expressed as a string.
|
|
|
|
# @param [Pry] _pry_ The relevant Pry instance.
|
|
|
|
# @param [Array<Binding>] old_stack The state of the old binding stack
|
|
|
|
# @return [Array<Array<Binding>, Array<Binding>>] An array
|
|
|
|
# containing two elements: The new `binding_stack` and the old `binding_stack`.
|
|
|
|
def context_from_object_path(arg_string, _pry_=nil, old_stack=[])
|
|
|
|
|
|
|
|
# Extract command arguments. Delete blank arguments like " ", but
|
|
|
|
# don't delete empty strings like "".
|
|
|
|
path = arg_string.split(/\//).delete_if { |a| a =~ /\A\s+\z/ }
|
|
|
|
stack = _pry_.binding_stack.dup
|
|
|
|
state_old_stack = old_stack
|
|
|
|
|
|
|
|
# Special case when we only get a single "/", return to root.
|
|
|
|
if path.empty?
|
|
|
|
state_old_stack = stack.dup unless old_stack.empty?
|
|
|
|
stack = [stack.first]
|
|
|
|
end
|
|
|
|
|
|
|
|
path.each_with_index do |context, i|
|
|
|
|
begin
|
|
|
|
case context.chomp
|
|
|
|
when ""
|
|
|
|
state_old_stack = stack.dup
|
|
|
|
stack = [stack.first]
|
|
|
|
when "::"
|
|
|
|
state_old_stack = stack.dup
|
|
|
|
stack.push(TOPLEVEL_BINDING)
|
|
|
|
when "."
|
|
|
|
next
|
|
|
|
when ".."
|
|
|
|
unless stack.size == 1
|
|
|
|
# Don't rewrite old_stack if we're in complex expression
|
|
|
|
# (e.g.: `cd 1/2/3/../4).
|
|
|
|
state_old_stack = stack.dup if path.first == ".."
|
|
|
|
stack.pop
|
|
|
|
end
|
|
|
|
when "-"
|
|
|
|
unless old_stack.empty?
|
|
|
|
# Interchange current stack and old stack with each other.
|
|
|
|
stack, state_old_stack = state_old_stack, stack
|
|
|
|
end
|
|
|
|
else
|
|
|
|
state_old_stack = stack.dup if i == 0
|
|
|
|
stack.push(Pry.binding_for(stack.last.eval(context)))
|
|
|
|
end
|
|
|
|
|
|
|
|
rescue RescuableException => e
|
|
|
|
# Restore old stack to its initial values.
|
|
|
|
state_old_stack = old_stack
|
|
|
|
|
2012-08-17 02:26:52 -04:00
|
|
|
msg = [
|
|
|
|
"Bad object path: #{arg_string}.",
|
|
|
|
"Failed trying to resolve: #{context}.",
|
|
|
|
e.inspect
|
|
|
|
].join(' ')
|
|
|
|
|
|
|
|
CommandError.new(msg).tap do |err|
|
|
|
|
err.set_backtrace e.backtrace
|
|
|
|
raise err
|
|
|
|
end
|
2012-08-12 00:38:32 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
return stack, state_old_stack
|
|
|
|
end
|
|
|
|
|
2011-04-12 20:48:50 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|