File Coverage

blib/lib/Perl/Lint/Policy/TestingAndDebugging/ProhibitNoWarnings.pm
Criterion Covered Total %
statement 45 45 100.0
branch 17 18 94.4
condition 14 18 77.7
subroutine 6 6 100.0
pod 0 1 0.0
total 82 88 93.1


line stmt bran cond sub pod time code
1             package Perl::Lint::Policy::TestingAndDebugging::ProhibitNoWarnings;
2 133     133   68559 use strict;
  133         158  
  133         2936  
3 133     133   411 use warnings;
  133         131  
  133         2329  
4 133     133   848 use Perl::Lint::Constants::Type;
  133         124  
  133         58775  
5 133     133   557 use parent "Perl::Lint::Policy";
  133         140  
  133         539  
6              
7             use constant {
8 133         45303 DESC => 'Warnings disabled',
9             EXPL => [431],
10 133     133   6598 };
  133         147  
11              
12             sub evaluate {
13 13     13 0 29 my ($class, $file, $tokens, $src, $args) = @_;
14              
15 13         18 my @arg_allows;
16             my $allow_with_category_restriction;
17 13 100       45 if (my $this_policies_arg = $args->{prohibit_no_warnings}) {
18 10 100       50 if (my $allow = $this_policies_arg->{allow}) {
19 4         23 @arg_allows = map { lc $_ } split(/[\s,]/, $allow);
  9         20  
20             }
21 10         17 $allow_with_category_restriction = $this_policies_arg->{allow_with_category_restriction};
22             }
23              
24 13         16 my @violations;
25 13         21 my $token_num = scalar @$tokens;
26 13         39 for (my $i = 0; $i < $token_num; $i++) {
27 50         44 my $token = $tokens->[$i];
28 50         56 my $token_type = $token->{type};
29              
30 50 100 66     150 if ($token_type == BUILTIN_FUNC and $token->{data} eq 'no') {
31 14         28 $token = $tokens->[++$i];
32              
33 14         13 my @allows;
34 14 50 33     66 if ($token->{type} == KEY && $token->{data} eq 'warnings') {
35 14         42 for ($i++; $i < $token_num; $i++) {
36 53         41 $token = $tokens->[$i];
37 53         41 $token_type = $token->{type};
38              
39 53 100 100     286 if ($token_type == STRING || $token_type == RAW_STRING) {
    100 66        
    100          
40 13         28 push @allows, $token->{data};
41             }
42             elsif ($token_type == REG_EXP) {
43 4         20 push @allows, split(/ /, $token->{data});
44             }
45             elsif ($token_type == SEMI_COLON || !$tokens->[$i+1]) {
46 14 100 100     64 last if @allows && $allow_with_category_restriction;
47              
48 9         17 for my $arg_allow (@arg_allows) {
49 9         11 @allows = grep { $_ ne $arg_allow } @allows;
  19         30  
50             }
51 9 100 100     43 if (!@arg_allows || @allows) {
52             push @violations, {
53             filename => $file,
54             line => $token->{line},
55 7         39 description => DESC,
56             explanation => EXPL,
57             policy => __PACKAGE__,
58             };
59 7         23 last;
60             }
61             }
62             }
63             }
64             }
65             }
66              
67 13         53 return \@violations;
68             }
69              
70             1;
71