manpagez: man pages & more
man Perl::Critic::Policy::Subroutines::ProhibitUnusedPrivateSubroutines(3)
Home | html | info | man
Perl::Critic::Policy::Subroutines::ProhibitUnusedPrivateSubroutines(3)



NAME

       Perl::Critic::Policy::Subroutines::ProhibitUnusedPrivateSubroutines -
       Prevent unused private subroutines.


AFFILIATION

       This Policy is part of the core Perl::Critic distribution.


DESCRIPTION

       By convention Perl authors (like authors in many other languages)
       indicate private methods and variables by inserting a leading
       underscore before the identifier.  This policy catches such subroutines
       which are not used in the file which declares them.

       This module defines a 'use' of a subroutine as a subroutine or method
       call to it (other than from inside the subroutine itself), a reference
       to it (i.e.  "my $foo = \&_foo"), a "goto" to it outside the subroutine
       itself (i.e.  "goto &_foo"), or the use of the subroutine's name as an
       even-numbered argument to "use overload".


CONFIGURATION

       You can define what a private subroutine name looks like by specifying
       a regular expression for the "private_name_regex" option in your
       .perlcriticrc:

           [Subroutines::ProhibitUnusedPrivateSubroutines]
           private_name_regex = _(?!_)\w+

       The above example is a way of saying that subroutines that start with a
       double underscore are not considered to be private.  (Perl::Critic, in
       its implementation, uses leading double underscores to indicate a
       distribution-private subroutine -- one that is allowed to be invoked by
       other Perl::Critic modules, but not by anything outside of
       Perl::Critic.)

       You can configure additional subroutines to accept by specifying them
       in a space-delimited list to the "allow" option:

           [Subroutines::ProhibitUnusedPrivateSubroutines]
           allow = _bar _baz

       These are added to the default list of exemptions from this policy. So
       the above allows "sub _bar {}" and "sub _baz {}", even if they are not
       referred to in the module that defines them.

       You can allow a whole class or subroutine names by defining a a regular
       expression that matches allowed names.

           [Subroutines::ProhibitUnusedPrivateSubroutines]
           allow_name_regex = _build_\w+

       You can configure this policy not to check private subroutines declared
       in a file that uses one or more particular named modules.  This allows
       you to, for example, exclude unused private subroutine checking in
       classes that are roles.

           [Subroutines::ProhibitUnusedPrivateSubroutines]
           skip_when_using = Moose::Role Moo::Role Role::Tiny


HISTORY

       This policy is derived from
       Perl::Critic::Policy::Subroutines::ProtectPrivateSubs, which looks at
       the other side of the problem.


BUGS

       Does not forbid "sub Foo::_foo{}" because it does not know (and can not
       assume) what is in the "Foo" package.

       Does not respect the scope caused by multiple packages in the same
       file.  For example a file:

           package Foo;
           sub _is_private { print "A private sub!"; }

           package Bar;
           _is_private();

       Will not trigger a violation even though "Foo::_is_private" is not
       called.  Similarly, "skip_when_using" currently works on a file level,
       not on a package scope level.


SEE ALSO

       Perl::Critic::Policy::Subroutines::ProtectPrivateSubs(3).


AUTHOR

       Chris Dolan <cdolan@cpan.org>


COPYRIGHT

       Copyright (c) 2009-2011 Thomas R. Wyant, III.

       This program is free software; you can redistribute it and/or modify it
       under the same terms as Perl itself.  The full text of this license can
       be found in the LICENSE file included with this module.




perl v5.Perl::Critic::Policy::Subroutines::ProhibitUnusedPrivateSubroutines(3)

perl-critic 1.134.0 - Generated Tue Jun 4 15:16:06 CDT 2019
© manpagez.com 2000-2024
Individual documents may contain additional copyright information.