File Coverage

blib/lib/Log/ger/Plugin/WithDie.pm
Criterion Covered Total %
statement 30 30 100.0
branch 6 8 75.0
condition 6 6 100.0
subroutine 8 8 100.0
pod 0 1 0.0
total 50 53 94.3


line stmt bran cond sub pod time code
1             package Log::ger::Plugin::WithDie;
2              
3             our $DATE = '2017-08-04'; # DATE
4             our $VERSION = '0.002'; # VERSION
5              
6 1     1   57349 use strict;
  1         2  
  1         27  
7 1     1   4 use warnings;
  1         2  
  1         22  
8              
9 1     1   4 use Log::ger ();
  1         1  
  1         337  
10              
11             sub get_hooks {
12 1     1 0 11 my %conf = @_;
13              
14             return {
15             create_routine_names => [
16             __PACKAGE__, 50,
17             sub {
18 3     3   1140 my %args = @_;
19              
20 3         6 my $levels = \%Log::ger::Levels;
21              
22             return [{
23             log_subs => [
24 6         23 (map { ["log_${_}_die", $_, "default"] }
25 18 50       57 grep {$levels->{$_} > 0 && $levels->{$_} <= 20} keys %$levels),
26             ],
27             is_subs => [],
28             log_methods => [
29 6         25 (map { ["${_}_die", $_, "default"] }
30 3 50       11 grep {$levels->{$_} > 0 && $levels->{$_} <= 20} keys %$levels),
  18         48  
31             ],
32             logml_methods => [
33             ],
34             is_methods => [
35             ],
36             }, 0];
37             }],
38             before_install_routines => [
39             __PACKAGE__, 50,
40             sub {
41 3     3   3051 my %args = @_;
42              
43             # wrap the logger
44 3         30 for my $r (@{ $args{routines} }) {
  3         7  
45 42         63 my ($code, $name, $numlevel, $type) = @$r;
46 42 100 100     150 if ($type eq 'log_sub' && $name =~ /\Alog_\w+_die\z/) {
    100 100        
47             $r->[0] = sub {
48 2     2   562 $code->(@_);
49 2         10 die $args{formatters}{default}(@_)."\n";
50 2         8 };
51             } elsif ($type eq 'log_method' && $name =~ /\A\w+_die\z/) {
52             $r->[0] = sub {
53 2     2   301 $code->(@_);
54 2         5 shift;
55 2         6 die $args{formatters}{default}(@_)."\n";
56 4         15 };
57             }
58             }
59             },
60 1         8 ],
61             };
62             }
63              
64             1;
65             # ABSTRACT: Add *_die logging routines
66              
67             __END__