X-Git-Url: http://git.shiar.net/perl/plp/.git/blobdiff_plain/5d1c2193a6c3c98cf426e03eb783eace183e5a0c..4565100c67dd7b0344e9eb332296d5fa64e7611b:/PLP/Apache.pm diff --git a/PLP/Apache.pm b/PLP/Apache.pm index a18ed25..bc78881 100644 --- a/PLP/Apache.pm +++ b/PLP/Apache.pm @@ -5,21 +5,36 @@ use strict; our $VERSION = '1.00'; use PLP; -require Apache::Constants; + +use constant MP2 => ( + defined $ENV{MOD_PERL_API_VERSION} and $ENV{MOD_PERL_API_VERSION} >= 2 +); + +BEGIN { + if (MP2) { + require Apache2::Const; + require Apache2::RequestRec; + require Apache2::RequestUtil; + require Apache2::RequestIO; + } else { + require Apache::Constants; + } +} # mod_perl initializer: returns 0 on success, Apache error code on failure sub init { our $r = shift; $PLP::print = 'PLP::Apache::print'; + $PLP::read = \&read; $ENV{PLP_FILENAME} = my $filename = $r->filename; unless (-f $filename) { - return Apache::Constants::NOT_FOUND(); + return MP2 ? Apache2::Const::HTTP_NOT_FOUND() : Apache::Constants::NOT_FOUND(); } unless (-r _) { - return Apache::Constants::FORBIDDEN(); + return MP2 ? Apache2::Const::HTTP_FORBIDDEN() : Apache::Constants::FORBIDDEN(); } $ENV{PLP_NAME} = $r->uri; @@ -35,6 +50,12 @@ sub init { return 0; # OK } +sub read ($) { + my ($bytes) = @_; + $r->read(my $data, $bytes); + return $data; +} + # FAST printing under mod_perl sub print { return unless grep length, @_; @@ -51,7 +72,7 @@ sub handler { #S PLP::start($_[0]); PLP::start(); no strict 'subs'; - return Apache::Constants::OK(); + return MP2 ? Apache2::Const::OK() : Apache::Constants::OK(); } 1;