our @IGNORE =
qw/Build Build.PL Changes MANIFEST META.yml Makefile.PL Makefile README
_build blib lib script t inc/;
+our @CLASSES = ();
our $ENGINE = 'CGI';
our $CORE = 0;
our $MULTIARCH = 0;
+our $SCRIPT = '';
=head1 NAME
=cut
-sub catalyst_par {
+# Workaround for a namespace conflict
+sub catalyst_par { Catalyst::Module::Install::_catalyst_par(@_) }
+
+=head2 catalyst_par_core($core)
+
+=cut
+
+sub catalyst_par_core {
+ my ( $self, $core ) = @_;
+ $core ? ( $CORE = $core ) : $core++;
+}
+
+=head2 catalyst_par_classes(@clases)
+
+=cut
+
+sub catalyst_par_classes {
+ my ( $self, @classes ) = @_;
+ push @CLASSES, @classes;
+}
+
+=head2 catalyst_par_engine($engine)
+
+=cut
+
+sub catalyst_par_engine {
+ my ( $self, $engine ) = @_;
+ $ENGINE = $engine;
+}
+
+=head2 catalyst_par_multiarch($multiarch)
+
+=cut
+
+sub catalyst_par_multiarch {
+ my ( $self, $multiarch ) = @_;
+ $multiarch ? ( $MULTIARCH = $multiarch ) : $multiarch++;
+}
+
+=head2 catalyst_par_script($script)
+
+=cut
+
+sub catalyst_par_script {
+ my ( $self, $script ) = @_;
+ $SCRIPT = $script;
+}
+
+package Catalyst::Module::Install;
+
+use strict;
+use FindBin;
+use File::Copy::Recursive 'rmove';
+use File::Spec ();
+
+sub _catalyst_par {
my ( $self, $par ) = @_;
- $par ||= 'application.par';
- my $engine = $ENGINE || 'CGI';
+ my $name = $self->name;
+ $name =~ s/::/_/g;
+ $name = lc $name;
+ $par ||= "$name.par";
+ my $engine = $Module::Install::Catalyst::ENGINE || 'CGI';
+ my $script = $Module::Install::Catalyst::SCRIPT || "$name\_cgi.pl";
# Check for PAR
eval "use PAR ()";
die "Please install Module::ScanDeps" if $@;
my $root = $FindBin::Bin;
+ my $path = File::Spec->catfile( 'blib', 'lib', split( '::', $self->name ) );
+ $path .= '.pm';
+ unless ( -f $path ) {
+ print qq/Not writing PAR, "$path" doesn't exist\n/;
+ return 0;
+ }
+ print qq/Writing PAR "$par"\n/;
chdir File::Spec->catdir( $root, 'blib' );
my $par_pl = 'par.pl';
my $version = $Catalyst::VERSION;
my $class = $self->name;
- my $tmp_file = IO::File->new("> $par_pl");
+ my $classes = '';
+ $classes .= " require $_;\n" for @Catalyst::Module::Install::CLASSES;
+ my $tmp_file = IO::File->new(" > $par_pl ");
print $tmp_file <<"EOF";
-die "$class on Catalyst $version\n" if \$0 !~ /par.pl\.\\w+\$/;
-BEGIN { \$ENV{CATALYST_ENGINE} = '$engine' };
-use lib 'lib';
-require $class;
-import $class;
-require Catalyst::Helper;
-require Catalyst::PAR;
-require Catalyst::Build;
-require Catalyst::Test;
-require Catalyst::Engine::HTTP;
-require Catalyst::Engine::CGI;
-require Catalyst::Controller;
-require Catalyst::Model;
-require Catalyst::View;
+require lib;
+if (\$0 !~ /par.pl\.\\w+\$/) {
+ import lib '../lib';
+ require FindBin;
+ require "\$FindBin::Bin/script/$script";
+}
+else {
+ import lib 'lib';
+ \$ENV{CATALYST_ENGINE} = '$engine';
+ require $class;
+ import $class;
+ require Catalyst::Helper;
+ require Catalyst::Test;
+ require Catalyst::Engine::HTTP;
+ require Catalyst::Engine::CGI;
+ require Catalyst::Controller;
+ require Catalyst::Model;
+ require Catalyst::View;
+ $classes
+}
EOF
$tmp_file->close;
'o' => $par,
'a' => [ grep( !/par.pl/, glob '.' ) ],
'p' => 1,
- 'B' => $CORE,
- 'm' => $MULTIARCH
+ 'B' => $Module::Install::Catalyst::CORE,
+ 'm' => $Module::Install::Catalyst::MULTIARCH
);
App::Packer::PAR->new(
frontend => 'Module::ScanDeps',
backopts => \%opt,
args => ['par.pl'],
)->go;
+
open STDERR, '>&', $olderr;
unlink $par_pl;
chdir $root;
- rmove File::Spec->catfile( 'blib', $par ), $par;
-}
-
-=head2 catalyst_par_core($core)
-
-=cut
-
-sub catalyst_par_core {
- my ( $self, $core ) = @_;
- $CORE = $core;
-}
-
-=head2 catalyst_par_engine($engine)
-
-=cut
-
-sub catalyst_par_engine {
- my ( $self, $engine ) = @_;
- $ENGINE = $engine;
-}
-
-=head2 catalyst_par_multiarch($multiarch)
-
-=cut
-
-sub catalyst_par_multiarch {
- my ( $self, $multiarch ) = @_;
- $MULTIARCH = $multiarch;
+ rmove( File::Spec->catfile( 'blib', $par ), $par );
+ return 1;
}
=head1 AUTHOR