NAME

Mojolicious::Plugin::DOCRenderer - Doc Renderer Plugin

SYNOPSIS

# Mojolicious::Lite
plugin 'DOCRenderer';
plugin DOCRenderer => {module => 'MyApp'};
plugin DOCRenderer => {name => 'foo'};
plugin DOCRenderer => {url => '/mydoc'};
plugin DOCRenderer => {preprocess => 'epl'};

# Mojolicious
$self->plugin('DOCRenderer');
$self->plugin(DOCRenderer => {module => 'MyApp'});
$self->plugin(DOCRenderer => {name => 'foo'});
$self->plugin(DOCRenderer => {url => '/mydoc'});
$self->plugin(DOCRenderer => {preprocess => 'epl'});

#############################
# Mojolicious::Lite example #
#############################
use Mojolicious::Lite;
use File::Basename;

plugin 'DOCRenderer' => {
    # use this script base name as a default module to show for "/doc"
    module => fileparse( __FILE__, qr/\.[^.]*/ );
};

app->start;

__END__

=head1 NAME

MyApp - My Mojolicious::Lite Application

=head1 DESCRIPTION

This documentation will be available online, for example from L<http://localhost:3000/doc>.

=cut

#######################
# Mojolicious example #
#######################
package MyApp;
use Mojo::Base 'Mojolicious';

sub development_mode {
  # Enable browsing of "/doc" only in development mode
  shift->plugin( 'DOCRenderer' );
}

sub startup {
  my $self = shift;
  # some code
}

__END__

=head1 NAME

MyApp - My Mojolicious Application

=head1 DESCRIPTION

This documentation will be available online, for example from L<http://localhost:3000/doc>.

=cut

DESCRIPTION

Mojolicious::Plugin::DOCRenderer generates on-the-fly and browses online POD documentation directly from your Mojolicious application source codes and makes it available under /doc (customizable).

The plugin expects that you use POD to document your codes of course.

The plugin is simple modification of Mojolicious::Plugin::PODRenderer.

OPTIONS

module

# Mojolicious::Lite
plugin DOCRenderer => {module => 'MyApp'};

Name of the module to initially display. Default is $ENV{MOJO_APP}. Mojolicious::Lite application may have undefined $ENV{MOJO_APP}; in such case you should set module, see Mojolicious::Lite example.

name

# Mojolicious::Lite
plugin DOCRenderer => {name => 'foo'};

Handler name.

preprocess

# Mojolicious::Lite
plugin DOCRenderer => {preprocess => 'epl'};

Handler name of preprocessor.

url

# Mojolicious::Lite
plugin DOCRenderer => {url => '/mydoc'};

URL from which the documentation of your project is available. Default is /doc.

METHODS

Mojolicious::Plugin::DOCRenderer inherits all methods from Mojolicious::Plugin and implements the following new ones.

register

my $route = $plugin->register(Mojolicious->new);
my $route = $plugin->register(Mojolicious->new, {name => 'foo'});

Register renderer in Mojolicious application.

SEE ALSO

Mojolicious::Plugin::PODRenderer, Mojolicious, Mojolicious::Guides, http://mojolicio.us.