1 package Catalyst::Script::Create;
4 use MooseX::Types::Moose qw/Bool/;
5 use namespace::autoclean;
7 with 'Catalyst::ScriptRole';
10 traits => [qw(Getopt)],
11 cmd_aliases => 'nonew',
14 documentation => 'Force new scripts',
18 traits => [qw(Getopt)],
22 documentation => 'Force debug mode',
26 traits => [qw(Getopt)],
27 cmd_aliases => 'mech',
30 documentation => 'use WWW::Mechanize',
36 $self->_exit_with_usage if !$ARGV[0];
38 my $helper = Catalyst::Helper->new( { '.newfiles' => !$self->force, mech => $self->mech } );
40 $self->_display_help unless $helper->mk_component( $self->app, @ARGV );
44 __PACKAGE__->meta->make_immutable;
48 Catalyst::Script::Create - Create a new Catalyst Component
52 myapp_create.pl [options] model|view|controller name [helper] [options]
55 -force don't create a .new file where a file to be created exists
56 -mechanize use Test::WWW::Mechanize::Catalyst for tests if available
57 -help display this help and exits
60 myapp_create.pl controller My::Controller
61 myapp_create.pl controller My::Controller BindLex
62 myapp_create.pl -mechanize controller My::Controller
63 myapp_create.pl view My::View
64 myapp_create.pl view MyView TT
65 myapp_create.pl view TT TT
66 myapp_create.pl model My::Model
67 myapp_create.pl model SomeDB DBIC::Schema MyApp::Schema create=dynamic\
69 myapp_create.pl model AnotherDB DBIC::Schema MyApp::Schema create=static\
70 dbi:Pg:dbname=foo root 4321
73 perldoc Catalyst::Manual
74 perldoc Catalyst::Manual::Intro
78 Create a new Catalyst Component.
80 Existing component files are not overwritten. If any of the component files
81 to be created already exist the file will be written with a '.new' suffix.
82 This behavior can be suppressed with the C<-force> option.
86 Catalyst Contributors, see Catalyst.pm
90 This library is free software, you can redistribute it and/or modify
91 it under the same terms as Perl itself.