C::C::CGIBin: add support for __DATA__ sections in CGIs
Rafael Kitover [Fri, 24 Apr 2009 04:44:13 +0000 (04:44 +0000)]
Changes
Makefile.PL
lib/Catalyst/Controller/CGIBin.pm
lib/Catalyst/Controller/WrapCGI.pm

diff --git a/Changes b/Changes
index 0037c6c..d3497c8 100644 (file)
--- a/Changes
+++ b/Changes
@@ -22,3 +22,6 @@ Revision history for Catalyst-Controller-WrapCGI
 
 0.0027  2009-04-03 14:55:34
     Add 'kill_env' and default to killing 'MOD_PERL' from environment.
+
+0.0028  2009-04-24 04:40:39
+    Add support for __DATA__ sections in cgis for C::CGIBin
index 09df012..2d8a215 100644 (file)
@@ -6,7 +6,6 @@ author   'Matt S. Trout <mst@shadowcat.co.uk>';
 include  'Module::AutoInstall';
 
 requires 'Catalyst' => '5.7007';
-requires 'Class::C3' => '0.20';
 requires 'parent';
 requires 'Task::Weaken';
 requires 'HTTP::Request::AsCGI';
@@ -16,6 +15,13 @@ requires 'List::MoreUtils';
 requires 'File::Slurp';
 requires 'namespace::clean';
 
+requires 'MRO::Compat';
+
+if($] < 5.009_005) {
+    requires 'Class::C3::XS' => '0.08';
+    requires 'Class::C3' => '0.20';
+}
+
 test_requires 'Catalyst::Plugin::Static::Simple';
 
 build_requires 'Test::More' => '0.86';
index 562cae5..3ffc19b 100644 (file)
@@ -3,7 +3,8 @@ package Catalyst::Controller::CGIBin;
 use strict;
 use warnings;
 
-use Class::C3;
+use MRO::Compat;
+use mro 'c3';
 use File::Slurp 'slurp';
 use File::Find::Rule ();
 use Catalyst::Exception ();
@@ -12,6 +13,7 @@ use IPC::Open3;
 use Symbol 'gensym';
 use List::MoreUtils 'any';
 use IO::File ();
+use Carp;
 use namespace::clean -except => 'meta';
 
 use parent 'Catalyst::Controller::WrapCGI';
@@ -22,11 +24,11 @@ Catalyst::Controller::CGIBin - Serve CGIs from root/cgi-bin
 
 =head1 VERSION
 
-Version 0.005
+Version 0.006
 
 =cut
 
-our $VERSION = '0.005';
+our $VERSION = '0.006';
 
 =head1 SYNOPSIS
 
@@ -194,12 +196,25 @@ something more involved (see L<ModPerl::PerlRun>.)
 sub wrap_perl_cgi {
     my ($self, $cgi, $action_name) = @_;
 
-    do {
+    my $code = slurp $cgi;
+
+    $code =~ s/^__DATA__\r?\n(.*)//ms;
+    my $data = $1;
+
+    my $coderef = do {
         no warnings;
         eval ' 
             package Catalyst::Controller::CGIBin::_CGIs_::'.$action_name.';
-            sub {' . slurp($cgi) . '}'
-    }
+            sub {'
+                . 'local *DATA;'
+                . q{open DATA, '<', \$data;}
+                . $code
+         . '}';
+    };
+
+    croak __PACKAGE__ . ": Could not compile $cgi to coderef: $@" if $@;
+
+    $coderef
 }
 
 =head2 $self->wrap_nonperl_cgi($path, $action_name)
index d740721..c2d4cdb 100644 (file)
@@ -15,11 +15,11 @@ Catalyst::Controller::WrapCGI - Run CGIs in Catalyst
 
 =head1 VERSION
 
-Version 0.0027
+Version 0.0028
 
 =cut
 
-our $VERSION = '0.0027';
+our $VERSION = '0.0028';
 
 =head1 SYNOPSIS