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 105 106 107 108 109 110 111
|
use strict;
use warnings;
package App::Cmd::Subdispatch;
use App::Cmd;
use App::Cmd::Command;
BEGIN { our @ISA = qw(App::Cmd::Command App::Cmd) }
=head1 NAME
App::Cmd::Subdispatch - an App::Cmd::Command that is also an App::Cmd
=head1 VERSION
version 0.307
=cut
our $VERSION = '0.307';
=head1 METHODS
=head2 new
A hackish new that allows us to have an Command instance before they normally
exist.
=cut
sub new {
my ($inv, $fields, @args) = @_;
if (ref $inv) {
@{ $inv }{ keys %$fields } = values %$fields;
return $inv;
} else {
$inv->SUPER::new($fields, @args);
}
}
=head2 prepare
my $subcmd = $subdispatch->prepare($app, @args);
An overridden version of L<App::Cmd::Command/prepare> that performs a new
dispatch cycle.
=cut
sub prepare {
my ($class, $app, @args) = @_;
my $self = $class->new({ app => $app });
my ($subcommand, $opt, @sub_args) = $self->get_command(@args);
$self->set_global_options($opt);
if (defined $subcommand) {
return $self->_prepare_command($subcommand, $opt, @sub_args);
} else {
if (@args) {
return $self->_bad_command(undef, $opt, @sub_args);
} else {
return $self->prepare_default_command($opt, @sub_args);
}
}
}
sub _plugin_prepare {
my ($self, $plugin, @args) = @_;
return $plugin->prepare($self->choose_parent_app($self->app, $plugin), @args);
}
=head2 app
$subdispatch->app;
This method returns the application that this subdispatch is a command of.
=cut
sub app { $_[0]{app} }
=head2 choose_parent_app
$subcmd->prepare(
$subdispatch->choose_parent_app($app, $opt, $plugin),
@$args
);
A method that chooses whether the parent app or the subdispatch is going to be
C<< $cmd->app >>.
=cut
sub choose_parent_app {
my ( $self, $app, $plugin ) = @_;
if (
$plugin->isa("App::Cmd::Command::commands")
or $plugin->isa("App::Cmd::Command::help")
or scalar keys %{ $self->global_options }
) {
return $self;
} else {
return $app;
}
}
1;
|