sub run {
my ($self) = @_;
- $self->_display_help if ( !$ARGV[0] );
+ $self->_exit_with_usage if !$ARGV[0];
my $helper = Catalyst::Helper->new( { '.newfiles' => !$self->force, mech => $self->mech } );
}
__PACKAGE__->meta->make_immutable;
-1;
=head1 NAME
it under the same terms as Perl itself.
=cut
+
documentation => q{Display this help and exit},
);
-sub _display_help {
+sub _exit_with_usage {
my $self = shift;
pod2usage();
exit 0;
before run => sub {
my $self = shift;
- $self->_display_help if $self->help;
+ $self->_exit_with_usage if $self->help;
};
sub run {
$app->run($self->_application_args);
}
+# GROSS HACK, temporary until MX::Getopt gets some proper refactoring and unfucking..
+around '_parse_argv' => sub {
+ my ($orig, $self, @args) = @_;
+ my %data = eval { $self->$orig(@args) };
+ $self->_exit_with_usage($@) if $@;
+ $data{usage} = Catalyst::ScriptRole::Useage->new(code => sub { shift; $self->_exit_with_usage(@_) });
+ return %data;
+};
+
+# This package is going away.
+package # Hide from PAUSE
+ Catalyst::ScriptRole::Useage;
+use Moose;
+use namespace::autoclean;
+
+has code => ( is => 'ro', required => 1 );
+
+sub die { shift->code->(@_) }
+
1;
=head1 NAME
it under the same terms as Perl itself.
=cut
-
\ No newline at end of file
+
--- /dev/null
+#!/usr/bin/env perl
+use strict;
+use warnings;
+
+use FindBin qw/$Bin/;
+use lib "$Bin/../lib";
+
+use Test::More;
+use Test::Exception;
+
+use Catalyst::Script::CGI;
+
+local @ARGV;
+lives_ok {
+ Catalyst::Script::CGI->new_with_options(application_name => 'TestAppToTestScripts')->run;
+} "new_with_options";
+shift @TestAppToTestScripts::RUN_ARGS;
+is_deeply \@TestAppToTestScripts::RUN_ARGS, [], "no args";
+
+done_testing;
--- /dev/null
+#!/usr/bin/env perl
+use strict;
+use warnings;
+use Test::More;
+
+use FindBin qw/$Bin/;
+use lib "$Bin/../lib";
+
+{
+ package TestHelpScript;
+ use Moose;
+ with 'Catalyst::ScriptRole';
+ our $help;
+ sub _exit_with_usage { $help++ }
+}
+{
+ local $TestHelpScript::help;
+ local @ARGV = ('-h');
+ TestHelpFromScriptCGI->new_with_options(application_name => 'TestAppToTestScripts')->run;
+ ok $TestHelpFromScriptCGI::help, 1;
+}
+{
+ local $TestHelpScript::help;
+ local @ARGV = ('--help');
+ TestHelpFromScriptCGI->new_with_options(application_name => 'TestAppToTestScripts')->run;
+ is $TestHelpFromScriptCGI::help, 2;
+}
+
+done_testing;