X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=lib%2FMaypole%2FApplication.pm;h=c10221a8784bbf36be6cae136b523cd1f81ec23f;hb=022b9e6b3f519f7e4041112b407b6769dedd7799;hp=fcbb13cadbae123204652dbb24b3a22770ff1e63;hpb=b062970a7574aff3972cba599967979d7613bfc5;p=maypole.git diff --git a/lib/Maypole/Application.pm b/lib/Maypole/Application.pm index fcbb13c..c10221a 100644 --- a/lib/Maypole/Application.pm +++ b/lib/Maypole/Application.pm @@ -4,23 +4,25 @@ use strict; use warnings; use UNIVERSAL::require; use Maypole; +use Maypole::Config; our @ISA; +our $VERSION = '2.05'; 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: $@) } @@ -30,6 +32,9 @@ sub import { } } } + + $caller->config(Maypole::Config->new); + $caller->setup() if $autosetup; } if ( $ENV{MOD_PERL} ) {