2012-08-11 20:22:29 -04:00
|
|
|
class Pry
|
2012-08-11 21:26:59 -04:00
|
|
|
Pry::Commands.create_command(/wtf([?!]*)/) do
|
|
|
|
group 'Context'
|
|
|
|
description "Show the backtrace of the most recent exception"
|
2012-08-11 20:22:29 -04:00
|
|
|
options :listing => 'wtf?'
|
|
|
|
|
|
|
|
banner <<-BANNER
|
|
|
|
Show's a few lines of the backtrace of the most recent exception (also available
|
|
|
|
as _ex_.backtrace).
|
|
|
|
|
|
|
|
If you want to see more lines, add more question marks or exclamation marks:
|
|
|
|
|
|
|
|
e.g.
|
|
|
|
pry(main)> wtf?
|
|
|
|
pry(main)> wtf?!???!?!?
|
|
|
|
|
|
|
|
To see the entire backtrace, pass the -v/--verbose flag:
|
|
|
|
|
|
|
|
e.g.
|
|
|
|
pry(main)> wtf -v
|
|
|
|
BANNER
|
|
|
|
|
|
|
|
def options(opt)
|
|
|
|
opt.on(:v, :verbose, "Show the full backtrace.")
|
|
|
|
end
|
|
|
|
|
|
|
|
def process
|
|
|
|
raise Pry::CommandError, "No most-recent exception" unless _pry_.last_exception
|
|
|
|
|
|
|
|
output.puts "#{text.bold('Exception:')} #{_pry_.last_exception.class}: #{_pry_.last_exception}\n--"
|
|
|
|
if opts.verbose?
|
|
|
|
output.puts Pry::Code.new(_pry_.last_exception.backtrace, 0, :text).with_line_numbers.to_s
|
|
|
|
else
|
|
|
|
output.puts Pry::Code.new(_pry_.last_exception.backtrace.first([captures[0].size, 0.5].max * 10), 0, :text).with_line_numbers.to_s
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|