X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FController%2FWrapCGI.pm;h=06cc3d346f71cdae95bb64927091b51a354a6142;hb=59492b79aebaad73b50335a99d6f9533b175f6af;hp=7236da24f6e8fe83670c3fd4d7cd6a87b94bb5bd;hpb=7a3e5a11ca57aebc997d0902119ffaab1080c9ea;p=catagits%2FCatalyst-Controller-WrapCGI.git diff --git a/lib/Catalyst/Controller/WrapCGI.pm b/lib/Catalyst/Controller/WrapCGI.pm index 7236da2..06cc3d3 100644 --- a/lib/Catalyst/Controller/WrapCGI.pm +++ b/lib/Catalyst/Controller/WrapCGI.pm @@ -6,10 +6,10 @@ use mro 'c3'; extends 'Catalyst::Controller'; +use Catalyst::Exception (); use HTTP::Request::AsCGI (); use HTTP::Request (); use URI (); -use Catalyst::Exception (); use URI::Escape; use HTTP::Request::Common; @@ -19,13 +19,9 @@ use namespace::clean -except => 'meta'; Catalyst::Controller::WrapCGI - Run CGIs in Catalyst -=head1 VERSION - -Version 0.024 - =cut -our $VERSION = '0.024'; +our $VERSION = '0.034'; =head1 SYNOPSIS @@ -197,8 +193,6 @@ sub wrap_cgi { } } - my $filtered_env = $self->_filtered_env(\%ENV); - $req->content($body_content); $req->content_length(length($body_content)); @@ -217,7 +211,6 @@ sub wrap_cgi { my $env = HTTP::Request::AsCGI->new( $req, ($username ? (REMOTE_USER => $username) : ()), - %$filtered_env, PATH_INFO => $path_info, # eww, this is likely broken: FILEPATH_INFO => '/'.$c->action.$path_info, @@ -232,6 +225,8 @@ sub wrap_cgi { my $saved_error; + local %ENV = %{ $self->_filtered_env(\%ENV) }; + $env->setup; eval { $call->() }; $saved_error = $@; @@ -239,9 +234,12 @@ sub wrap_cgi { select($old); - Catalyst::Exception->throw( - message => "CGI invocation failed: $saved_error" - ) if $saved_error; + if( $saved_error ) { + die $saved_error if ref $saved_error; + Catalyst::Exception->throw( + message => "CGI invocation failed: $saved_error" + ); + } } return $env->response; @@ -394,6 +392,8 @@ Rafael Kitover C<< >> Hans Dieter Pearcey C<< >> +Some code stolen from Tatsuhiko Miyagawa's L. + =head1 COPYRIGHT & LICENSE Copyright (c) 2008-2009 L and