package Module::Install::Catalyst;
use strict;
-use base 'Module::Install::Base';
+
+our @ISA;
+require Module::Install::Base;
+@ISA = qw/Module::Install::Base/;
+
use File::Find;
use FindBin;
use File::Copy::Recursive 'rcopy';
use File::Spec ();
+my $SAFETY = 0;
+
our @IGNORE =
qw/Build Build.PL Changes MANIFEST META.yml Makefile.PL Makefile README
_build blib lib script t inc/;
our $ENGINE = 'CGI';
our $CORE = 0;
our $MULTIARCH = 0;
+our $SCRIPT;
our $USAGE;
=head1 NAME
=head1 METHODS
+=head2 catalyst
+
+=cut
+
+sub catalyst {
+ my $self = shift;
+ print <<EOF;
+*** Module::Install::Catalyst
+EOF
+ $self->catalyst_files;
+ $self->catalyst_par;
+ print <<EOF;
+*** Module::Install::Catalyst finished.
+EOF
+}
+
=head2 catalyst_files
=cut
push @files, $name;
}
closedir CATDIR;
- my @path = split '::', $self->name;
+ my @path = split '-', $self->name;
for my $orig (@files) {
my $path = File::Spec->catdir( 'blib', 'lib', @path, $orig );
rcopy( $orig, $path );
=cut
# Workaround for a namespace conflict
-sub catalyst_par { Catalyst::Module::Install::_catalyst_par(@_) }
+sub catalyst_par {
+ my ( $self, $par ) = @_;
+ return if $SAFETY;
+ $SAFETY++;
+ my $name = $self->name;
+ my $usage = $USAGE;
+ $usage =~ s/"/\\"/g;
+ my $class_string = join "', '", @CLASSES;
+ $class_string = "'$class_string'" if $class_string;
+ $self->postamble(<<EOF);
+catalyst_par :: all
+\t\$(NOECHO) \$(PERL) -Ilib -Minc::Module::Install -MModule::Install::Catalyst -e"Catalyst::Module::Install::_catalyst_par( '$par', '$name', { CLASSES => [$class_string], CORE => $CORE, ENGINE => '$ENGINE', MULTIARCH => $MULTIARCH, SCRIPT => '$SCRIPT', USAGE => q#$usage# } )"
+EOF
+ print <<EOF;
+Please run "make catalyst_par" to create the PAR package!
+EOF
+}
=head2 catalyst_par_core($core)
sub catalyst_par_core {
my ( $self, $core ) = @_;
- $core ? ( $CORE = $core ) : $core++;
+ $core ? ( $CORE = $core ) : $CORE++;
}
=head2 catalyst_par_classes(@clases)
sub catalyst_par_multiarch {
my ( $self, $multiarch ) = @_;
- $multiarch ? ( $MULTIARCH = $multiarch ) : $multiarch++;
+ $multiarch ? ( $MULTIARCH = $multiarch ) : $MULTIARCH++;
+}
+
+=head2 catalyst_par_script($script)
+
+=cut
+
+sub catalyst_par_script {
+ my ( $self, $script ) = @_;
+ $SCRIPT = $script;
}
=head2 catalyst_par_usage($usage)
use File::Spec ();
sub _catalyst_par {
- my ( $self, $par ) = @_;
+ my ( $par, $class_name, $opts ) = @_;
- my $name = $self->name;
+ my $ENGINE = $opts->{ENGINE};
+ my $CLASSES = $opts->{CLASSES} || [];
+ my $USAGE = $opts->{USAGE};
+ my $SCRIPT = $opts->{SCRIPT};
+ my $MULTIARCH = $opts->{MULTIARCH};
+ my $CORE = $opts->{CORE};
+
+ my $name = $class_name;
$name =~ s/::/_/g;
$name = lc $name;
$par ||= "$name.par";
- my $engine = $Module::Install::Catalyst::ENGINE || 'CGI';
+ my $engine = $ENGINE || 'CGI';
# Check for PAR
eval "use PAR ()";
die "Please install Module::ScanDeps\n" if $@;
my $root = $FindBin::Bin;
- my $path = File::Spec->catfile( 'blib', 'lib', split( '::', $self->name ) );
+ $class_name =~ s/-/::/g;
+ my $path = File::Spec->catfile( 'blib', 'lib', split( '::', $class_name ) );
$path .= '.pm';
unless ( -f $path ) {
print qq/Not writing PAR, "$path" doesn't exist\n/;
unlink $par_pl;
my $version = $Catalyst::VERSION;
- my $class = $self->name;
+ my $class = $class_name;
my $classes = '';
- $classes .= " require $_;\n" for @Catalyst::Module::Install::CLASSES;
+ $classes .= " require $_;\n" for @$CLASSES;
unlink $par_pl;
- my $usage = $Module::Install::Catalyst::USAGE || <<"EOF";
+ my $usage = $USAGE || <<"EOF";
Usage:
[parl] $name\[.par] [script] [arguments]
myapp $name\_cgi.pl
EOF
+ my $script = $SCRIPT;
my $tmp_file = IO::File->new("> $par_pl ");
print $tmp_file <<"EOF";
if ( \$ENV{PAR_PROGNAME} ) {
my \$zip = \$PAR::LibCache{\$ENV{PAR_PROGNAME}}
|| Archive::Zip->new(__FILE__);
- if (\@ARGV == 0 ) {
+ my \$script = '$script';
+ \$ARGV[0] ||= \$script if \$script;
+ if ( ( \@ARGV == 0 ) || ( \$ARGV[0] eq '-h' ) || ( \$ARGV[0] eq '-help' )) {
my \@members = \$zip->membersMatching('.*script/.*\.pl');
my \$list = " Available scripts:\\n";
for my \$member ( \@members ) {
$tmp_file->close;
# Create package
- # local $SIG{__WARN__} = sub { };
- # open my $olderr, '>&STDERR';
- # open STDERR, '>', File::Spec->devnull;
+ local $SIG{__WARN__} = sub { };
+ open my $olderr, '>&STDERR';
+ open STDERR, '>', File::Spec->devnull;
my %opt = (
'x' => 1,
'n' => 0,
'o' => $par,
'a' => [ grep( !/par.pl/, glob '.' ) ],
'p' => 1,
- 'B' => $Module::Install::Catalyst::CORE,
- 'm' => $Module::Install::Catalyst::MULTIARCH
+ 'B' => $CORE,
+ 'm' => $MULTIARCH
);
App::Packer::PAR->new(
frontend => 'Module::ScanDeps',
args => ['par.pl'],
)->go;
- # open STDERR, '>&', $olderr;
+ open STDERR, '>&', $olderr;
- # unlink $par_pl;
+ unlink $par_pl;
chdir $root;
rmove( File::Spec->catfile( 'blib', $par ), $par );
return 1;