logo
Free, unlimited AI code reviews that run on commit
git-lrc git-lrc GitHub Install Now We'd appreciate a star git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt

Devel::ArgNames - Figure out the names of variables passed into subroutines.

Authors

       Ran Eilam

       Yuval Kogman <nothingmuch@woobling.org>

Description

       When print-debugging code, you will often ind yourself going:

               print "\$foo is $foo, \$bar is $bar"

       With this module, you can write a reusable subroutine easily:

               sub my_print_vars {
                       my %vars;

                       @vars{arg_names()} = @_;

                       foreach my $var ( keys %vars ) {
                               warn "$var is $vars{$var}\n";
                       }
               }

               my_print_vars($foo, $bar);

       This module doesn't provide dumping facilities because there are too many to choose from. This is a DIY
       kit ;-)

Exports

       arg_names [ $level ]
           This  function  will return the names associated with the variables found on @_, at the level $level.
           If $level is not provided "arg_names"'s caller's caller will be used ("$level == 2" in that case).

Name

       Devel::ArgNames - Figure out the names of variables passed into subroutines.

See Also

       Data::Dumper::Simple, DB, Devel::Caller, Devel::Caller::Perl, PadWalker.

Synopsis

               use Devel::ArgNames;

               sub foo {
                       warn "foo() called with arguments: "
                               . join(", ", map { defined() ? $_ : "<unknown>" } arg_names(@_) );
               }

               foo($bar, $gorch, $blah[4]);

Version Control

       This   module   is   maintained   using   Darcs.    You    can    get    the    latest    version    from
       <http://nothingmuch.woobling.org/Devel-ArgNames/>, and use "darcs send" to commit changes.

See Also