NAME Dist::Zilla::Util::CurrentCmd - Attempt to determine the current command Dist::Zilla is running under. VERSION version 0.002001 SYNOPSIS use Dist::Zilla::Util::CurrentCmd qw(current_cmd); ... if ( is_install() ) { die "This plugin hates installing things for some reason!" } if ( is_build() ) { print "I Love you man\n"; } if ( current_cmd() eq 'run' ) { die "RUN THE OTHER WAY" } DESCRIPTION This module exists in case you are absolutely certain you want to have different behaviors for either a plugin, or a bundle, to trigger on ( or off ) a specific phase. Usually, this is a bad idea, and the need to do this suggests a poor choice of work-flow to begin with. That said, this utility is *probably* more useful in a bundle than in a plugin, in that it will be slightly more optimal than say, having an "ENV" flag to control this difference. FUNCTIONS "current_cmd" Returns the name of the of the first "command" entry in the "caller" stack that matches /\ADist::Zilla::App::Command::(.*)::([^:\s]+)\z/msx For instance: Dist::Zilla::App::Command::build::execute -> build "is_build" Convenience shorthand for "current_cmd() eq 'build'" "is_install" Convenience shorthand for "current_cmd() eq 'install'" "as_cmd" Internals wrapper to lie to code operating in the callback that the "current_cmd" is. as_cmd('install' => sub { is_install(); # true }); CAVEATS User beware, this code is both hackish and new, and relies on using "caller" to determine which "Dist::Zilla::App::Command::" we are running under. There may be conditions that there are no "Command"s in the "caller" stack which meet this definition, or the *first* such thing may be a misleading representation of what is actually running. And there's a degree of uncertainty of reliability, because I haven't yet devised reliable ways of testing it that don't involve invoking "dzil" ( which is problematic on testers where "Dist::Zilla" is in @INC but "dzil" is not in "ENV{PATH}" ) To that extent, I don't even know for sure if this module works yet, or if it works in a bundle, or if it works in all commands, or if it works under "Dist::Zilla::App::Tester" as expected. AUTHOR Kent Fredric <kentfredric@gmail.com> COPYRIGHT AND LICENSE This software is copyright (c) 2014 by Kent Fredric <kentfredric@gmail.com>. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.