NAME
    Catalyst::Action::RenderView - Sensible default end action.

SYNOPSIS
        sub end : ActionClass('RenderView') {}

DESCRIPTION
    This action implements a sensible default end action, which will forward
    to the first available view, unless "$c->res->status" is a 3xx code
    (redirection, not modified, etc.), 204 (no content), or "$c->res->body"
    has already been set. It also allows you to pass "dump_info=1" to the
    url in order to force a debug screen, while in debug mode.

    If you have more than one view, you can specify which one to use with
    the "default_view" config setting and the "current_view" and
    "current_view_instance" stash keys (see Catalyst's "$c->view($name)"
    method -- this module simply calls "$c->view" with no argument).

METHODS
  end
    The default "end" action. You can override this as required in your
    application class; normal inheritance applies.

INTERNAL METHODS
  execute
    Dispatches control to superclasses, then forwards to the default View.

    See "METHODS/action" in Catalyst::Action.

SCRUBBING OUTPUT
    When you force debug with dump_info=1, RenderView is capable of removing
    classes from the objects in your stash. By default it will replace any
    DBIx::Class ResultSource objects with the class name, which cleans up
    the debug output considerably, but you can change what gets scrubbed by
    setting a list of classes in
    $c->config->{'Action::RenderView'}->{ignore_classes}. For instance:

        $c->config->{'Action::RenderView'}->{ignore_classes} = [];

    To disable the functionality. You can also set
    config->{'Action::RenderView'}->{scrubber_func} to change what it does
    with the classes. For instance, this will undef it instead of putting in
    the class name:

        $c->config->{'Action::RenderView'}->{scrubber_func} = sub { undef $_ };

  Deprecation notice
    This plugin used to be configured by setting "$c->config->{debug}". That
    configuration key is still supported in this release, but is deprecated,
    please use the 'Action::RenderView' namespace as shown above for
    configuration in new code.

EXTENDING
    To add something to an "end" action that is called before rendering,
    simply place it in the "end" method:

        sub end : ActionClass('RenderView') {
            my ( $self, $c ) = @_;
            # do stuff here; the RenderView action is called afterwards
        }

    To add things to an "end" action that are called *after* rendering, you
    can set it up like this:

        sub render : ActionClass('RenderView') { }

        sub end : Private {
            my ( $self, $c ) = @_;
            $c->forward('render');
            # do stuff here
        }

AUTHORS
    *   Marcus Ramberg <marcus@thefeed.no>

    *   Florian Ragwitz <rafl@debian.org>

CONTRIBUTOR
    Graham Knop <haarg@haarg.org>

COPYRIGHT AND LICENSE
    This software is copyright (c) 2006 - 2009 by Marcus Ramberg and Florian
    Ragwitz.

    This is free software; you can redistribute it and/or modify it under
    the same terms as the Perl 5 programming language system itself.