File Coverage

blib/lib/Perl/Lint/Policy/ClassHierarchies/ProhibitOneArgBless.pm
Criterion Covered Total %
statement 43 44 97.7
branch 21 22 95.4
condition 15 24 62.5
subroutine 6 6 100.0
pod 0 1 0.0
total 85 97 87.6


line stmt bran cond sub pod time code
1             package Perl::Lint::Policy::ClassHierarchies::ProhibitOneArgBless;
2 133     133   70276 use strict;
  133         188  
  133         3031  
3 133     133   412 use warnings;
  133         166  
  133         2442  
4 133     133   770 use Perl::Lint::Constants::Type;
  133         149  
  133         59922  
5 133     133   557 use parent "Perl::Lint::Policy";
  133         162  
  133         574  
6              
7             use constant {
8 133         36778 DESC => 'One-argument "bless" used',
9             EXPL => [365],
10 133     133   6704 };
  133         177  
11              
12             sub evaluate {
13 3     3 0 7 my ($class, $file, $tokens, $args) = @_;
14              
15 3         4 my @violations;
16 3         3 my $token_num = scalar @$tokens;
17 3         7 for (my $i = 0; $i < $token_num; $i++) {
18 70         53 my $token = $tokens->[$i];
19 70         58 my $token_type = $token->{type};
20 70         46 my $token_data = $token->{data};
21              
22 70 100 66     154 if ($token_type == BUILTIN_FUNC && $token_data eq 'bless') {
23 14         10 my $left_paren_num = 0;
24 14         11 my $left_brace_num = 0;
25 14         8 my $left_bracket_num = 0;
26 14         9 my $comma_num = 0;
27              
28 14 100       26 $i++ if $tokens->[$i+1]->{type} == LEFT_PAREN;
29              
30 14         23 for ($i++; $i < $token_num; $i++) {
31 66         51 my $token = $tokens->[$i];
32 66         51 my $token_type = $token->{type};
33 66         49 my $token_data = $token->{data};
34              
35 66 50 100     329 if ($token_type == LEFT_PAREN) {
    100 66        
    100 66        
    100 33        
    100 66        
    100 66        
    100 33        
    100          
36 0         0 $left_paren_num++;
37             }
38             elsif ($token_type == LEFT_BRACE) {
39 7         11 $left_brace_num++;
40             }
41             elsif ($token_type == LEFT_BRACKET) {
42 8         13 $left_bracket_num++;
43             }
44             elsif ($token_type == RIGHT_PAREN) {
45 7         9 $left_paren_num--;
46             }
47             elsif ($token_type == RIGHT_BRACE) {
48 7         9 $left_brace_num--;
49             }
50             elsif ($token_type == RIGHT_BRACKET) {
51 8         13 $left_bracket_num--;
52             }
53             elsif (
54             ($token_type == COMMA || $token_type == ARROW) &&
55             $left_paren_num <= 0 &&
56             $left_brace_num <= 0 &&
57             $left_bracket_num <= 0
58             ) {
59 6         9 $comma_num++;
60             }
61             elsif (
62             $token_type == SEMI_COLON &&
63             $left_paren_num <= 0 &&
64             $left_brace_num <= 0 &&
65             $left_bracket_num <= 0
66             ) {
67 14 100       21 if ($comma_num == 0) {
68             push @violations, {
69             filename => $file,
70             line => $token->{line},
71 8         25 description => DESC,
72             explanation => EXPL,
73             policy => __PACKAGE__,
74             };
75             }
76 14         27 last;
77             }
78             }
79             }
80             }
81              
82 3         13 return \@violations;
83             }
84              
85             1;
86