File Coverage

blib/lib/Perl/Lint/Policy/ValuesAndExpressions/ProhibitLongChainsOfMethodCalls.pm
Criterion Covered Total %
statement 35 35 100.0
branch 10 10 100.0
condition 7 9 77.7
subroutine 7 7 100.0
pod 0 1 0.0
total 59 62 95.1


line stmt bran cond sub pod time code
1             package Perl::Lint::Policy::ValuesAndExpressions::ProhibitLongChainsOfMethodCalls;
2 134     134   69139 use strict;
  134         221  
  134         3122  
3 134     134   423 use warnings;
  134         157  
  134         2499  
4 134     134   800 use Perl::Lint::Constants::Type;
  134         168  
  134         60343  
5 134     134   905 use Perl::Lint::Constants::Kind;
  134         183  
  134         6732  
6 134     134   468 use parent "Perl::Lint::Policy";
  134         153  
  134         599  
7              
8             use constant {
9 134         27233 DESC => 'The number of chained calls to allow',
10             EXPL => 'Long chains of method calls indicate code that is too tightly coupled',
11 134     134   6793 };
  134         185  
12              
13             sub evaluate {
14 9     9 0 16 my ($class, $file, $tokens, $src, $args) = @_;
15              
16 9         13 my $max_chain_length = 3;
17 9 100       23 if (my $this_policies_arg = $args->{prohibit_long_chains_of_method_calls}) {
18 2   33     8 $max_chain_length = $this_policies_arg->{max_chain_length} || $max_chain_length;
19             }
20              
21 9         11 my @violations;
22 9         27 for (my $i = 0, my $token_type, my $num_of_chain = 0; my $token = $tokens->[$i]; $i++) {
23 599         362 $token_type = $token->{type};
24              
25 599 100 100     1604 if ($token_type == POINTER) {
    100          
26 104         75 my $next_token = $tokens->[$i+1];
27 104         71 my $next_token_type = $next_token->{type};
28 104 100 100     259 if ($next_token_type == LEFT_BRACE || $next_token_type == LEFT_BRACKET) {
29             # array and hash ref chains. They should be ignored.
30 16         20 next;
31             }
32              
33 88         125 $num_of_chain++;
34             }
35             elsif ($token_type == SEMI_COLON || $token->{kind} == KIND_STMT) {
36 46 100       53 if ($num_of_chain > $max_chain_length) {
37             push @violations, {
38             filename => $file,
39             line => $token->{line},
40 12         32 description => DESC,
41             explanation => EXPL,
42             policy => __PACKAGE__,
43             };
44             }
45 46         70 $num_of_chain = 0;
46             }
47             }
48              
49 9         32 return \@violations;
50             }
51              
52             1;
53