File Coverage

blib/lib/Log/ger/Format/Hashref.pm
Criterion Covered Total %
statement 18 18 100.0
branch 6 6 100.0
condition n/a
subroutine 5 5 100.0
pod 0 2 0.0
total 29 31 93.5


line stmt bran cond sub pod time code
1             package Log::ger::Format::Hashref;
2              
3             our $AUTHORITY = 'cpan:PERLANCAR'; # AUTHORITY
4             our $DATE = '2020-03-11'; # DATE
5             our $DIST = 'Log-ger-Format-Hashref'; # DIST
6             our $VERSION = '0.003'; # VERSION
7              
8 1     1   69056 use strict;
  1         10  
  1         25  
9 1     1   4 use warnings;
  1         2  
  1         163  
10              
11             sub meta { +{
12 1     1 0 12 v => 2,
13             } }
14              
15             sub get_hooks {
16 1     1 0 11 my %plugin_conf = @_;
17              
18             return {
19             create_formatter => [
20             __PACKAGE__, # key
21             50, # priority
22             sub { # hook
23 2     2   2133 my %hook_args = @_; # see Log::ger::Manual::Internals/"Arguments passed to hook"
24              
25             my $formatter = sub {
26 5 100       578 if (@_ == 1) {
    100          
27 2 100       6 if (ref $_[0] eq 'HASH') {
28 1         2 return $_[0];
29             } else {
30 1         7 return {message=>$_[0]};
31             }
32             } elsif (@_ % 2) {
33 1         9 die "Please log an even number of arguments";
34             } else {
35 2         8 return {@_};
36             }
37 2         5 };
38 2         6 [$formatter];
39              
40 1         7 }],
41             };
42             }
43              
44             1;
45             # ABSTRACT: Format arguments as hashref
46              
47             __END__