X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FEngine.pm;h=a2cc178bb8361935fe6a833611346b14a8fd4a04;hb=f7a3f8fd0a1df1dc3f5811747cfa377a020b9dcc;hp=16895f3ea9628c4c62ef2228e0b5a2a841e29b81;hpb=1e5dad0099d51c919670c0e765615937b0fd4dae;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Engine.pm b/lib/Catalyst/Engine.pm index 16895f3..a2cc178 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(%$options); + # 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);