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';
our $ENGINE = 'CGI';
our $CORE = 0;
our $MULTIARCH = 0;
-our $SCRIPT = '';
+our $SCRIPT;
+our $USAGE;
=head1 NAME
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 );
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)
$SCRIPT = $script;
}
+=head2 catalyst_par_usage($usage)
+
+=cut
+
+sub catalyst_par_usage {
+ my ( $self, $usage ) = @_;
+ $USAGE = $usage;
+}
+
package Catalyst::Module::Install;
use strict;
$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 ()";
my $version = $Catalyst::VERSION;
my $class = $self->name;
- my $script_file = IO::File->new("< $script");
- my $script_content = do { local $/; <$script_file> };
-
my $classes = '';
$classes .= " require $_;\n" for @Catalyst::Module::Install::CLASSES;
+
+ unlink $par_pl;
+
+ my $usage = $Module::Install::Catalyst::USAGE || <<"EOF";
+Usage:
+ [parl] $name\[.par] [script] [arguments]
+
+ Examples:
+ parl $name.par $name\_server.pl -r
+ myapp $name\_cgi.pl
+EOF
+
+ my $script = $Module::Install::Catalyst::SCRIPT;
my $tmp_file = IO::File->new("> $par_pl ");
print $tmp_file <<"EOF";
-require lib;
-if (\$0 !~ /par.pl\.\\w+\$/) {
-$script_content
+if ( \$ENV{PAR_PROGNAME} ) {
+ my \$zip = \$PAR::LibCache{\$ENV{PAR_PROGNAME}}
+ || Archive::Zip->new(__FILE__);
+ 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 ) {
+ my \$name = \$member->fileName;
+ \$name =~ /(\\w+\\.pl)\$/;
+ \$name = \$1;
+ next if \$name =~ /^main\.pl\$/;
+ next if \$name =~ /^par\.pl\$/;
+ \$list .= " \$name\\n";
+ }
+ die <<"END";
+$usage
+\$list
+END
+ }
+ my \$file = shift \@ARGV;
+ \$file =~ s/^.*[\\/\\\\]//;
+ \$file =~ s/\\.[^.]*\$//i;
+ my \$member = eval { \$zip->memberNamed("./script/\$file.pl") };
+ die qq/Can't open perl script "\$file"\n/ unless \$member;
+ PAR::_run_member( \$member, 1 );
}
else {
+ require lib;
import lib 'lib';
\$ENV{CATALYST_ENGINE} = '$engine';
require $class;
require Catalyst::Controller;
require Catalyst::Model;
require Catalyst::View;
+ require Getopt::Long;
+ require Pod::Usage;
+ require Pod::Text;
$classes
}
EOF