File Coverage

blib/lib/Log/ger/Plugin/MultilevelLog.pm
Criterion Covered Total %
statement 12 38 31.5
branch 1 10 10.0
condition 0 4 0.0
subroutine 4 9 44.4
pod 0 2 0.0
total 17 63 26.9


line stmt bran cond sub pod time code
1             package Log::ger::Plugin::MultilevelLog;
2              
3 1     1   403689 use strict;
  1         3  
  1         67  
4 1     1   7 use warnings;
  1         3  
  1         78  
5              
6 1     1   504 use Log::ger::Util;
  1         2  
  1         466  
7              
8             our $AUTHORITY = 'cpan:PERLANCAR'; # AUTHORITY
9             our $DATE = '2023-12-29'; # DATE
10             our $DIST = 'Log-ger'; # DIST
11             our $VERSION = '0.042'; # VERSION
12              
13             sub meta { +{
14 0     0 0   v => 2,
15             } }
16              
17             sub get_hooks {
18 0     0 0   my %conf = @_;
19              
20 0   0       my $sub_name = $conf{sub_name} || 'log';
21 0   0       my $method_name = $conf{method_name} || 'log';
22              
23             return {
24             create_filter => [
25             __PACKAGE__, # key
26             50, # priority
27             sub { # hook
28 0     0     my %hook_args = @_; # see Log::ger::Manual::Internals/"Arguments passed to hook"
29              
30             my $filter = sub {
31 0           my $level = Log::ger::Util::numeric_level(shift);
32 0 0         return 0 unless $level <= $Log::ger::Current_Level;
33 0           {level=>$level};
34 0           };
35              
36 0           [$filter, 0, 'ml'];
37             },
38             ],
39              
40             create_formatter => [
41             __PACKAGE__, # key
42             50, # priority
43             sub { # hook
44 0     0     my %hook_args = @_; # see Log::ger::Manual::Internals/"Arguments passed to hook"
45              
46             my $formatter =
47              
48             # just like the default formatter, except it accepts first
49             # argument (level)
50             sub {
51 0           shift; # level
52 0 0         return $_[0] if @_ < 2;
53 0           my $fmt = shift;
54 0           my @args;
55 0           for (@_) {
56 0 0         if (!defined($_)) {
    0          
57 0           push @args, '';
58             } elsif (ref $_) {
59 0           push @args, Log::ger::Util::_dump($_);
60             } else {
61 0           push @args, $_;
62             }
63             }
64             # redefine is just a dummy category for perls < 5.22
65             # which don't have 'redundant' yet
66 1 50   1   8 no warnings ($warnings::Bits{'redundant'} ? 'redundant' : 'redefine');
  1         3  
  1         266  
67 0           sprintf $fmt, @args;
68 0           };
69              
70 0           [$formatter, 0, 'ml'];
71             },
72             ],
73              
74             create_routine_names => [
75             __PACKAGE__, # key
76             50, # priority
77             sub { # hook
78 0     0     my %hook_args = @_; # see Log::ger::Manual::Internals/"Arguments passed to hook"
79             return [{
80             logger_subs => [[$sub_name , undef, 'ml', undef, 'ml']],
81             logger_methods => [[$method_name, undef, 'ml', undef, 'ml']],
82 0           }, $conf{exclusive}];
83             },
84 0           ],
85             };
86             }
87              
88             1;
89             # ABSTRACT: (DEPRECATED) Old name for Log::ger::Format::MultilevelLog
90              
91             __END__