X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FEngine.pm;h=650a142a8fb1503e846857821fab9d402d7a8c0f;hb=ccb13b15884c34b801d716a19ffcf52ecdfeab94;hp=16895f3ea9628c4c62ef2228e0b5a2a841e29b81;hpb=1e5dad0099d51c919670c0e765615937b0fd4dae;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Engine.pm b/lib/Catalyst/Engine.pm index 16895f3..650a142 100644 --- a/lib/Catalyst/Engine.pm +++ b/lib/Catalyst/Engine.pm @@ -12,9 +12,7 @@ use HTTP::Headers; use URI::QueryParam; use Moose::Util::TypeConstraints; use Plack::Loader; -use Plack::Middleware::Conditional; -use Plack::Middleware::ReverseProxy; -use Catalyst::Engine::Loader; +use Catalyst::EngineLoader; use Encode (); use utf8; @@ -793,13 +791,17 @@ sub run { # like Gitalist's --git_dir are possible to get from the app without stupid tricks. my $server = pop @args if (scalar @args && blessed $args[-1]); my $options = pop @args if (scalar @args && ref($args[-1]) eq 'HASH'); + # Back compat hack for applications with old (non Catalyst::Script) scripts to work in FCGI. + if (scalar @args && !ref($args[0])) { + if (my $listen = shift @args) { + $options->{listen} ||= [$listen]; + } + } if (! $server ) { - $server = Catalyst::Engine::Loader->new(application_name => ref($self))->auto(); - # We're not being called from a script, - # so auto detect what backend to run on. - # This should never happen, as mod_perl - # never calls ->run, instead the $app->handle - # method is called per request. + $server = Catalyst::EngineLoader->new(application_name => ref($self))->auto(); + # We're not being called from a script, so auto detect what backend to + # run on. This should never happen, as mod_perl never calls ->run, + # instead the $app->handle method is called per request. $app->log->warn("Not supplied a Plack engine, falling back to engine auto-loader (are your scripts ancient?)") } $server->run($psgi, $options);