File Coverage

blib/lib/Perl/Lint/Policy/ValuesAndExpressions/RequireNumberSeparators.pm
Criterion Covered Total %
statement 39 39 100.0
branch 10 10 100.0
condition 5 9 55.5
subroutine 6 6 100.0
pod 0 1 0.0
total 60 65 92.3


line stmt bran cond sub pod time code
1             package Perl::Lint::Policy::ValuesAndExpressions::RequireNumberSeparators;
2 134     134   68285 use strict;
  134         190  
  134         5024  
3 134     134   457 use warnings;
  134         176  
  134         2542  
4 134     134   781 use Perl::Lint::Constants::Type;
  134         171  
  134         58031  
5 134     134   576 use parent "Perl::Lint::Policy";
  134         187  
  134         553  
6              
7             use constant {
8 134         36359 DESC => 'Long number not separated with underscores',
9             EXPL => [59],
10 134     134   6443 };
  134         184  
11              
12             sub evaluate {
13 7     7 0 16 my ($class, $file, $tokens, $src, $args) = @_;
14              
15 7         8 my $min_value = 100_000;
16 7 100       23 if (my $this_policies_arg = $args->{require_number_separators}) {
17 2   33     7 $min_value = $this_policies_arg->{min_value} || $min_value;
18             }
19              
20 7         8 my @violations;
21 7         27 for (my $i = 0; my $token = $tokens->[$i]; $i++) {
22 310         228 my $token_type = $token->{type};
23              
24 310 100 100     930 if ($token_type == INT || $token_type == DOUBLE) {
25 60         117 (my $num = $token->{data}) =~ s/\A[+-]//;
26              
27 60         105 my ($decimal_part, $fractional_part) = split /\./, $num;
28 60         85 my @decimals = split /_/, $decimal_part;
29 60         49 my @fractionals = ();
30              
31 60         38 my $joined;
32 60 100       77 if (defined $fractional_part) {
33 26         36 @fractionals = split /_/, $fractional_part;
34 26         49 $joined = join('', @decimals) . '.' . join('', @fractionals);
35             } else {
36 34         51 $joined = join '', @decimals;
37             }
38              
39 60 100 33     2218 if ((eval($joined) // -$min_value - 1) < $min_value) { ## no critic
40             # ~~~~~~~~~~~~~~~ If reach here, $joined is not a number
41 22         70 next;
42             }
43              
44 38         70 for my $part (@decimals, @fractionals) {
45 63 100       1956 if (eval($part) >= 1000) { ## no critic
46             push @violations, {
47             filename => $file,
48             line => $token->{line},
49 28         98 description => DESC,
50             explanation => EXPL,
51             policy => __PACKAGE__,
52             };
53 28         102 last;
54             }
55             }
56             }
57             }
58              
59 7         25 return \@violations;
60             }
61              
62             1;
63