2

当 ruby​​ 应用程序遇到异常时,无论框架如何,堆栈跟踪都会首先显示最重要的信息。通常很长,我发现自己向上滚动命令行以查找它的开始位置,而实际上我只需要阅读前一两行。

我想重新排列输出以反转堆栈跟踪的显示顺序。也许我的措辞不正确,但我无法通过快速搜索找到如何做到这一点。

有没有人有任何处理异常输出的经验,可以为我指明正确的方向?

例如:

$ rackup
/Users/Ascended/Ruby/sinatra/genye/app.rb:19:in `include': wrong argument type String (expected Module) (TypeError)
    from /Users/Ascended/Ruby/sinatra/genye/app.rb:19:in `block in <class:Application>'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/lib/ruby/gems/2.0.0/gems/sinatra-1.4.3/lib/sinatra/base.rb:1385:in `configure'
    from /Users/Ascended/Ruby/sinatra/genye/app.rb:17:in `<class:Application>'
    from /Users/Ascended/Ruby/sinatra/genye/app.rb:11:in `<top (required)>'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/lib/ruby/gems/2.0.0/gems/backports-3.3.3/lib/backports/tools.rb:328:in `require'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/lib/ruby/gems/2.0.0/gems/backports-3.3.3/lib/backports/tools.rb:328:in `require_with_backports'
    from /Users/Ascended/Ruby/sinatra/genye/config.ru:7:in `block in <main>'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/lib/ruby/gems/2.0.0/gems/rack-1.5.2/lib/rack/builder.rb:55:in `instance_eval'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/lib/ruby/gems/2.0.0/gems/rack-1.5.2/lib/rack/builder.rb:55:in `initialize'
    from /Users/Ascended/Ruby/sinatra/genye/config.ru:in `new'
    from /Users/Ascended/Ruby/sinatra/genye/config.ru:in `<main>'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/lib/ruby/gems/2.0.0/gems/rack-1.5.2/lib/rack/builder.rb:49:in `eval'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/lib/ruby/gems/2.0.0/gems/rack-1.5.2/lib/rack/builder.rb:49:in `new_from_string'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/lib/ruby/gems/2.0.0/gems/rack-1.5.2/lib/rack/builder.rb:40:in `parse_file'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/lib/ruby/gems/2.0.0/gems/rack-1.5.2/lib/rack/server.rb:277:in `build_app_and_options_from_config'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/lib/ruby/gems/2.0.0/gems/rack-1.5.2/lib/rack/server.rb:199:in `app'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/lib/ruby/gems/2.0.0/gems/rack-1.5.2/lib/rack/server.rb:314:in `wrapped_app'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/lib/ruby/gems/2.0.0/gems/rack-1.5.2/lib/rack/server.rb:250:in `start'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/lib/ruby/gems/2.0.0/gems/rack-1.5.2/lib/rack/server.rb:141:in `start'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/lib/ruby/gems/2.0.0/gems/rack-1.5.2/bin/rackup:4:in `<top (required)>'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/bin/rackup:23:in `load'
    from /Users/Ascended/.rbenv/versions/2.0.0-p0/bin/rackup:23:in `<main>'
$

我想看看这条线:

/Users/Ascended/Ruby/sinatra/genye/app.rb:19:in `include': wrong argument type String (expected Module) (TypeError)

在输出的末尾而不是开头,有效地颠倒了输出的顺序。

4

1 回答 1

-1

如果你发现异常,你可以尝试这样的事情:

begin
  bad_code
rescue Exception => e 
  puts e.backtrace.reverse
end
于 2013-07-30T21:38:17.950 回答