X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;ds=sidebyside;f=lib%2FMaypole%2FApplication.pm;h=3336c1f73cd7d1da68d9fbbb1c6677856e41b302;hb=75e8e464477b6476876f0d43e41677446fe34b89;hp=fcbb13cadbae123204652dbb24b3a22770ff1e63;hpb=b062970a7574aff3972cba599967979d7613bfc5;p=maypole.git diff --git a/lib/Maypole/Application.pm b/lib/Maypole/Application.pm index fcbb13c..3336c1f 100644 --- a/lib/Maypole/Application.pm +++ b/lib/Maypole/Application.pm @@ -4,32 +4,37 @@ use strict; use warnings; use UNIVERSAL::require; use Maypole; +use Maypole::Config; our @ISA; +our $VERSION = '2.08'; sub import { my ( $self, @plugins ) = @_; my $caller = caller(0); no strict 'refs'; push @{"${caller}::ISA"}, $self; - foreach (@plugins) { - if (/^\-Setup$/) { $caller->setup } + my $autosetup=0; + foreach (sort @plugins) { + if (/^\-Setup$/) { $autosetup++; } elsif (/^\-Debug$/) { *{"$caller\::debug"} = sub { 1 }; warn "Debugging enabled"; } elsif (/^-.*$/) { warn "Unknown flag: $_" } else { - # The plugin caller should be our application class eval "package $caller; require Maypole::Plugin::$_"; if ($@) { warn qq(Loading plugin "Maypole::Plugin::$_" failed: $@) } else { warn "Loaded plugin: Maypole::Plugin::$_" if $caller->debug; - unshift @ISA, "Maypole::Plugin::$_"; + push @{"${caller}::ISA"}, "Maypole::Plugin::$_"; } } } + + $caller->config(Maypole::Config->new); + $caller->setup() if $autosetup; } if ( $ENV{MOD_PERL} ) { @@ -45,7 +50,7 @@ else { =head1 NAME -Maypole::Application - Maypole Universal Frontend +Maypole::Application - Universal Maypole Frontend =head1 SYNOPSIS @@ -82,6 +87,10 @@ is equivalent to use Maypole::Application; MyApp->setup; +Note that no options are passed to C. You must ensure that the +required model config parameters are set in Cconfig>. See +L for more information. + =head2 -Debug use Maypole::Application qw(-Debug); @@ -99,3 +108,5 @@ Idea by Marcus Ramberg, C =head1 LICENSE You may distribute this code under the same terms as Perl itself. + +=cut