NAME

Catalyst::Plugin::StackTrace - Display a stack trace on the debug screen

SYNOPSIS

    use Catalyst qw/-Debug StackTrace/;

DESCRIPTION

This plugin will enhance the standard Catalyst debug screen by including a stack trace of your appliation up to the point where the error occurred. Each stack frame is displayed along with the package name, line number, file name, and code context surrounding the line number.

This plugin is only active in -Debug mode by default, but can be enabled by setting the enable config option.

CONFIGURATION

Configuration is optional and is specified in MyApp->config->{stacktrace}.

enable

Allows you forcibly enable or disalbe this plugin, ignoring the current debug setting. If this option is defined, its value will be used.

context

The number of context lines of code to display on either side of the stack frame line. Defaults to 3.

reverse

By default, the stack frames are shown in from "top" to "bottom" (newest to oldest). Enabling this option reverses the stack frames so they will be displayed "bottom" to "top", or from the callers perspective.

verbose

This option sets the amount of stack frames you want to see in the stack trace. It defaults to 0, meaning only frames from your application's namespace are shown. You can use levels 1 and 2 for deeper debugging.

If set to 1, the stack trace will include frames from packages outside of your application's namespace, but not from most of the Catalyst internals. Packages ignored at this level include:

    Catalyst
    Catalyst::Action
    Catalyst::Base
    Catalyst::Dispatcher
    Catalyst::Engine::*
    Catalyst::Plugin::StackTrace
    Catalyst::Plugin::Static::Simple
    NEXT
    main

If set to 2, the stack trace will include frames from everything except this module.

INTERNAL METHODS

The following methods are extended by this plugin.

execute

In execute, we create a local die handler to generate the stack trace.

finalize_error

In finalize_error, we inject the stack trace HTML into the debug screen below the error message.

setup

SEE ALSO

Catalyst

AUTHORS

Andy Grundman, <andy@hybridized.org>

Matt S. Trout, <mst@shadowcatsystems.co.uk>

THANKS

The authors of CGI::Application::Plugin::DebugScreen, from which a lot of code was used.

COPYRIGHT

Copyright (c) 2005 - 2009 the Catalyst::Plugin::StackTrace "AUTHORS" as listed above.

LICENSE

This program is free software, you can redistribute it and/or modify it under the same terms as Perl itself.