1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
|
# Copyright (C) 2008-2010, Sebastian Riedel.
package Mojo::Command::Generate::Makefile;
use strict;
use warnings;
use base 'Mojo::Command';
__PACKAGE__->attr(description => <<'EOF');
Generate Makefile.PL.
EOF
__PACKAGE__->attr(usage => <<"EOF");
usage: $0 generate makefile
EOF
# You don’t like your job, you don’t strike.
# You go in every day and do it really half-assed. That’s the American way.
sub run {
my $self = shift;
my $class = $ENV{MOJO_APP} || 'MyApp';
my $path = $self->class_to_path($class);
my $name = $self->class_to_file($class);
$self->render_to_rel_file('makefile', 'Makefile.PL', $class, $path,
$name);
$self->chmod_file('Makefile.PL', 0744);
}
1;
__DATA__
@@ makefile
% my ($class, $path, $name) = @_;
#!/usr/bin/env perl
use 5.008001;
use strict;
use warnings;
# Son, when you participate in sporting events,
# it's not whether you win or lose, it's how drunk you get.
use ExtUtils::MakeMaker;
WriteMakefile(
NAME => '<%= $class %>',
VERSION_FROM => 'lib/<%= $path %>',
AUTHOR => 'A Good Programmer <nospam@cpan.org>',
EXE_FILES => ['script/<%= $name %>'],
PREREQ_PM => { 'Mojo' => '0.9003' },
test => {TESTS => 't/*.t t/*/*.t t/*/*/*.t'}
);
__END__
=head1 NAME
Mojo::Command::Generate::Makefile - Makefile Generator Command
=head1 SYNOPSIS
use Mojo::Command::Generate::Makefile;
my $makefile = Mojo::Command::Generate::Makefile->new;
$makefile->run(@ARGV);
=head1 DESCRIPTION
L<Mojo::Command::Generate::Makefile> is a makefile generator.
=head1 ATTRIBUTES
L<Mojo::Command::Generate::Makefile> inherits all attributes from
L<Mojo::Command> and implements the following new ones.
=head2 C<description>
my $description = $makefile->description;
$makefile = $makefile->description('Foo!');
Short description of this command, used for the command list.
=head2 C<usage>
my $usage = $makefile->usage;
$makefile = $makefile->usage('Foo!');
Usage information for this command, used for the help screen.
=head1 METHODS
L<Mojo::Command::Generate::Makefile> inherits all methods from
L<Mojo::Command> and implements the following new ones.
=head2 C<run>
$makefile = $makefile->run(@ARGV);
Run this command.
=head1 SEE ALSO
L<Mojolicious>, L<Mojolicious::Guides>, L<http://mojolicious.org>.
=cut
|