package Catalyst::Script::Create;
use Moose;
-use strict;
-use warnings;
-use Getopt::Long;
-use Pod::Usage;
-use Catalyst::Helper;
+use MooseX::Types::Moose qw/Bool Str/;
+use namespace::autoclean;
-my $force = 0;
-my $mech = 0;
-my $help = 0;
+with 'Catalyst::ScriptRole';
-GetOptions(
- 'nonew|force' => \$force,
- 'mech|mechanize' => \$mech,
- 'help|?' => \$help
- );
+has force => (
+ traits => [qw(Getopt)],
+ cmd_aliases => 'nonew',
+ isa => Bool,
+ is => 'ro',
+ documentation => 'Force new scripts',
+);
-pod2usage(1) if ( $help || !$ARGV[0] );
+has debug => (
+ traits => [qw(Getopt)],
+ cmd_aliases => 'd',
+ isa => Bool,
+ is => 'ro',
+ documentation => 'Force debug mode',
+);
-my $helper = Catalyst::Helper->new( { '.newfiles' => !$force, mech => $mech } );
+has mechanize => (
+ traits => [qw(Getopt)],
+ cmd_aliases => 'mech',
+ isa => Bool,
+ is => 'ro',
+ documentation => 'use WWW::Mechanize',
+);
-pod2usage(1) unless $helper->mk_component( 'BoyosPlace', @ARGV );
+has helper_class => (
+ isa => Str,
+ is => 'ro',
+ builder => '_build_helper_class',
+);
-1;
+sub _build_helper_class { 'Catalyst::Helper' }
+
+sub run {
+ my ($self) = @_;
+
+ $self->_getopt_full_usage if !$self->ARGV->[0];
+
+ my $helper_class = $self->helper_class;
+ Class::MOP::load_class($helper_class);
+ my $helper = $helper_class->new( { '.newfiles' => !$self->force, mech => $self->mechanize } );
+
+ $self->_getopt_full_usage unless $helper->mk_component( $self->application_name, @{$self->extra_argv} );
+
+}
+
+__PACKAGE__->meta->make_immutable;
=head1 NAME
-boyosplace_create.pl - Create a new Catalyst Component
+Catalyst::Script::Create - Create a new Catalyst Component
=head1 SYNOPSIS
-boyosplace_create.pl [options] model|view|controller name [helper] [options]
+ myapp_create.pl [options] model|view|controller name [helper] [options]
Options:
- -force don't create a .new file where a file to be created exists
- -mechanize use Test::WWW::Mechanize::Catalyst for tests if available
- -help display this help and exits
+ --force don't create a .new file where a file to be created exists
+ --mechanize use Test::WWW::Mechanize::Catalyst for tests if available
+ --help display this help and exits
Examples:
- boyosplace_create.pl controller My::Controller
- boyosplace_create.pl controller My::Controller BindLex
- boyosplace_create.pl -mechanize controller My::Controller
- boyosplace_create.pl view My::View
- boyosplace_create.pl view MyView TT
- boyosplace_create.pl view TT TT
- boyosplace_create.pl model My::Model
- boyosplace_create.pl model SomeDB DBIC::Schema MyApp::Schema create=dynamic\
+ myapp_create.pl controller My::Controller
+ myapp_create.pl controller My::Controller BindLex
+ myapp_create.pl --mechanize controller My::Controller
+ myapp_create.pl view My::View
+ myapp_create.pl view MyView TT
+ myapp_create.pl view TT TT
+ myapp_create.pl model My::Model
+ myapp_create.pl model SomeDB DBIC::Schema MyApp::Schema create=dynamic\
dbi:SQLite:/tmp/my.db
- boyosplace_create.pl model AnotherDB DBIC::Schema MyApp::Schema create=static\
+ myapp_create.pl model AnotherDB DBIC::Schema MyApp::Schema create=static\
dbi:Pg:dbname=foo root 4321
See also:
Existing component files are not overwritten. If any of the component files
to be created already exist the file will be written with a '.new' suffix.
-This behavior can be suppressed with the C<-force> option.
+This behavior can be suppressed with the C<--force> option.
=head1 AUTHORS
it under the same terms as Perl itself.
=cut
+