2010-09-30 14:29:15 +00:00
|
|
|
#! @perl@ -w -I@nix@/libexec/nix
|
2008-10-28 10:19:31 +00:00
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
use Getopt::Long;
|
|
|
|
use Pod::Usage;
|
2009-02-12 16:38:08 +00:00
|
|
|
eval "use Catalyst::Helper;";
|
|
|
|
|
|
|
|
if ($@) {
|
|
|
|
die <<END;
|
|
|
|
To use the Catalyst development tools including catalyst.pl and the
|
|
|
|
generated script/myapp_create.pl you need Catalyst::Helper, which is
|
|
|
|
part of the Catalyst-Devel distribution. Please install this via a
|
|
|
|
vendor package or by running one of -
|
|
|
|
|
|
|
|
perl -MCPAN -e 'install Catalyst::Devel'
|
|
|
|
perl -MCPANPLUS -e 'install Catalyst::Devel'
|
|
|
|
END
|
|
|
|
}
|
2008-10-28 10:19:31 +00:00
|
|
|
|
|
|
|
my $force = 0;
|
|
|
|
my $mech = 0;
|
|
|
|
my $help = 0;
|
|
|
|
|
|
|
|
GetOptions(
|
|
|
|
'nonew|force' => \$force,
|
|
|
|
'mech|mechanize' => \$mech,
|
|
|
|
'help|?' => \$help
|
|
|
|
);
|
|
|
|
|
|
|
|
pod2usage(1) if ( $help || !$ARGV[0] );
|
|
|
|
|
|
|
|
my $helper = Catalyst::Helper->new( { '.newfiles' => !$force, mech => $mech } );
|
|
|
|
|
2008-11-25 11:01:42 +00:00
|
|
|
pod2usage(1) unless $helper->mk_component( 'Hydra', @ARGV );
|
2008-10-28 10:19:31 +00:00
|
|
|
|
|
|
|
1;
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
2008-11-25 11:01:42 +00:00
|
|
|
hydra_create.pl - Create a new Catalyst Component
|
2008-10-28 10:19:31 +00:00
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
2008-11-25 11:01:42 +00:00
|
|
|
hydra_create.pl [options] model|view|controller name [helper] [options]
|
2008-10-28 10:19:31 +00:00
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
Examples:
|
2008-11-25 11:01:42 +00:00
|
|
|
hydra_create.pl controller My::Controller
|
|
|
|
hydra_create.pl controller My::Controller BindLex
|
|
|
|
hydra_create.pl -mechanize controller My::Controller
|
|
|
|
hydra_create.pl view My::View
|
|
|
|
hydra_create.pl view MyView TT
|
|
|
|
hydra_create.pl view TT TT
|
|
|
|
hydra_create.pl model My::Model
|
|
|
|
hydra_create.pl model SomeDB DBIC::Schema MyApp::Schema create=dynamic\
|
2008-10-28 10:19:31 +00:00
|
|
|
dbi:SQLite:/tmp/my.db
|
2008-11-25 11:01:42 +00:00
|
|
|
hydra_create.pl model AnotherDB DBIC::Schema MyApp::Schema create=static\
|
2008-10-28 10:19:31 +00:00
|
|
|
dbi:Pg:dbname=foo root 4321
|
|
|
|
|
|
|
|
See also:
|
|
|
|
perldoc Catalyst::Manual
|
|
|
|
perldoc Catalyst::Manual::Intro
|
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
Create a new Catalyst Component.
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
=head1 AUTHORS
|
|
|
|
|
|
|
|
Catalyst Contributors, see Catalyst.pm
|
|
|
|
|
|
|
|
=head1 COPYRIGHT
|
|
|
|
|
|
|
|
This library is free software, you can redistribute it and/or modify
|
|
|
|
it under the same terms as Perl itself.
|
|
|
|
|
|
|
|
=cut
|