Provided by: libperl-critic-perl_1.150-1_all
NAME
Perl::Critic::Policy::BuiltinFunctions::ProhibitUselessTopic - Don't pass $_ to built-in functions that assume it, or to most filetest operators.
AFFILIATION
This Policy is part of the Perl::Critic distribution.
DESCRIPTION
There are a number of places where $_, or "the topic" variable, is unnecessary. Topic unnecessary for certain Perl built-in functions Many Perl built-in functions will operate on $_ if no argument is passed. For example, the "length" function will operate on $_ by default. This snippet: for ( @list ) { if ( length( $_ ) == 4 ) { ... is more idiomatically written as: for ( @list ) { if ( length == 4 ) { ... In the case of the "split" function, the second argument is the one that defaults to $_. This snippet: for ( @list ) { my @args = split /\t/, $_; is better written as: for ( @list ) { my @args = split /\t/; There is one built-in that this policy does not check for: "reverse" called with $_. The "reverse" function only operates on $_ if called in scalar context. Therefore: for ( @list ) { my $backwards = reverse $_; is better written as: for ( @list ) { my $backwards = reverse; However, the distinction for scalar vs. list context on "reverse" is not yet working. See KNOWN BUGS below. Topic unnecessary for most filetest operators Another place that $_ is unnecessary is with a filetest operator. # These are identical. my $size = -s $_; my $size = -s; # These are identical. if ( -r $_ ) { ... if ( -r ) { ... The exception is after the "-t" filetest operator, which instead of defaulting to $_ defaults to "STDIN". # These are NOT identical. if ( -t $_ ) { ... if ( -t ) { ... # Checks STDIN, not $_
KNOWN BUGS
This policy flags a false positive on "reverse" called in list context, since "reverse" in list context does not assume $_. my $s = reverse( $_ ); # $_ is useless. my @a = reverse( $_ ); # $_ is not useless here.
CONFIGURATION
This Policy is not configurable except for the standard options.
AUTHOR
Andy Lester <andy@petdance.com>
COPYRIGHT
Copyright (c) 2013-2022 Andy Lester <andy@petdance.com> This library is free software; you can redistribute it and/or modify it under the terms of the Artistic License 2.0. perl v5.36.0 Perl::Critic::Policy::BuiltinFunctions::ProhibitUselessTopic(3pm)