package Catalyst;
use strict;
-use base 'Class::Data::Inheritable';
+use base 'Catalyst::Base';
use UNIVERSAL::require;
use Catalyst::Log;
-__PACKAGE__->mk_classdata($_) for qw/_config engine log/;
+__PACKAGE__->mk_classdata($_) for qw/engine log/;
our $VERSION = '5.00';
our @ISA;
=cut
-sub config {
- my $self = shift;
- $self->_config( {} ) unless $self->_config;
- if ( $_[0] ) {
- my $config = $_[1] ? {@_} : $_[0];
- while ( my ( $key, $val ) = each %$config ) {
- $self->_config->{$key} = $val;
- }
- }
- return $self->_config;
-}
-
sub import {
my ( $self, @options ) = @_;
my $caller = caller(0);
push @{"$caller\::ISA"}, $self;
}
+ if ( $caller->engine ) {
+ return; # Catalyst is allready initialized
+ }
+
unless ( $caller->log ) {
$caller->log( Catalyst::Log->new );
}
}
# Options
- my $engine = $ENV{MOD_PERL}
+ my $engine =
+ $ENV{MOD_PERL}
? 'Catalyst::Engine::Apache'
: 'Catalyst::Engine::CGI';
# Engine
$engine = "Catalyst::Engine::$ENV{CATALYST_ENGINE}"
if $ENV{CATALYST_ENGINE};
+
+ if ( $engine eq 'Catalyst::Engine::Server' ) {
+ $engine = 'Catalyst::Engine::HTTP::Daemon';
+ $caller->log->warn( "Catalyst::Engine::Server is deprecated, "
+ . "using Catalyst::Engine::HTTP::Daemon." );
+ }
+
$engine->require;
die qq/Couldn't load engine "$engine", "$@"/ if $@;
{