File: Log4perl.pm

package info (click to toggle)
liblog-report-perl 1.41-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 572 kB
  • sloc: perl: 2,819; makefile: 8
file content (114 lines) | stat: -rw-r--r-- 2,894 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
# This code is part of Perl distribution Log-Report version 1.41.
# The POD got stripped from this file by OODoc version 3.04.
# For contributors see file ChangeLog.

# This software is copyright (c) 2007-2025 by Mark Overmeer.

# This is free software; you can redistribute it and/or modify it under
# the same terms as the Perl 5 programming language system itself.
# SPDX-License-Identifier: Artistic-1.0-Perl OR GPL-1.0-or-later

#oodist: *** DO NOT USE THIS VERSION FOR PRODUCTION ***
#oodist: This file contains OODoc-style documentation which will get stripped
#oodist: during its release in the distribution.  You can use this file for
#oodist: testing, however the code of this development version may be broken!

package Log::Report::Dispatcher::Log4perl;{
our $VERSION = '1.41';
}

use base 'Log::Report::Dispatcher';

use warnings;
use strict;

use Log::Report 'log-report';

use Log::Report::Util qw/@reasons expand_reasons/;
use Log::Log4perl     qw/:levels/;

my %default_reasonToLevel = (
	TRACE   => $DEBUG,
	ASSERT  => $DEBUG,
	INFO    => $INFO,
	NOTICE  => $INFO,
	WARNING => $WARN,
	MISTAKE => $WARN,
	ERROR   => $ERROR,
	FAULT   => $ERROR,
	ALERT   => $FATAL,
	FAILURE => $FATAL,
	PANIC   => $FATAL,
);

@reasons==keys %default_reasonToLevel
	or panic __"Not all reasons have a default translation";

# Do not show these as source of the error: one or more caller frames up
Log::Log4perl->wrapper_register($_) for qw/
	Log::Report
	Log::Report::Dispatcher
	Log::Report::Dispatcher::Try
/;

#--------------------


sub init($)
{	my ($self, $args) = @_;
	$args->{accept} ||= 'ALL';
	$self->SUPER::init($args);

	my $name   = $self->name;

	$self->{LRDL_levels}  = { %default_reasonToLevel };
	if(my $to_level = delete $args->{to_level})
	{	my @to = @$to_level;
		while(@to)
		{	my ($reasons, $level) = splice @to, 0, 2;
			my @reasons = expand_reasons $reasons;

			$level =~ m/^[0-5]$/
				or error __x"Log4perl level '{level}' must be in 0-5", level => $level;

			$self->{LRDL_levels}{$_} = $level for @reasons;
		}
	}

	if(my $config = delete $args->{config}) {
		Log::Log4perl->init($config) or return;
	}

	$self;
}

#--------------------

sub logger(;$)
{	my ($self, $domain) = @_;
	defined $domain
		or return Log::Log4perl->get_logger($self->name);

	# get_logger() creates a logger if that does not exist.  But we
	# want to route it to default
	$Log::Log4perl::LOGGERS_BY_NAME->{$domain} ||= Log::Log4perl->get_logger($self->name);
}

#--------------------

sub log($$$$)
{	my ($self, $opts, $reason, $msg, $domain) = @_;
	my $text   = $self->translate($opts, $reason, $msg) or return;
	my $level  = $self->reasonToLevel($reason);

	local $Log::Log4perl::caller_depth = $Log::Log4perl::caller_depth + 3;

	$text =~ s/\s+$//s;  # log4perl adds own \n
	$self->logger($domain)->log($level, $text);
	$self;
}


sub reasonToLevel($) { $_[0]->{LRDL_levels}{$_[1]} }

1;