line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
# BEGIN BPS TAGGED BLOCK {{{ |
2
|
|
|
|
|
|
|
# COPYRIGHT: |
3
|
|
|
|
|
|
|
# |
4
|
|
|
|
|
|
|
# This software is Copyright (c) 2003-2008 Best Practical Solutions, LLC |
5
|
|
|
|
|
|
|
# |
6
|
|
|
|
|
|
|
# |
7
|
|
|
|
|
|
|
# (Except where explicitly superseded by other copyright notices) |
8
|
|
|
|
|
|
|
# |
9
|
|
|
|
|
|
|
# |
10
|
|
|
|
|
|
|
# LICENSE: |
11
|
|
|
|
|
|
|
# |
12
|
|
|
|
|
|
|
# |
13
|
|
|
|
|
|
|
# This program is free software; you can redistribute it and/or |
14
|
|
|
|
|
|
|
# modify it under the terms of either: |
15
|
|
|
|
|
|
|
# |
16
|
|
|
|
|
|
|
# a) Version 2 of the GNU General Public License. You should have |
17
|
|
|
|
|
|
|
# received a copy of the GNU General Public License along with this |
18
|
|
|
|
|
|
|
# program. If not, write to the Free Software Foundation, Inc., 51 |
19
|
|
|
|
|
|
|
# Franklin Street, Fifth Floor, Boston, MA 02110-1301 or visit |
20
|
|
|
|
|
|
|
# their web page on the internet at |
21
|
|
|
|
|
|
|
# http://www.gnu.org/copyleft/gpl.html. |
22
|
|
|
|
|
|
|
# |
23
|
|
|
|
|
|
|
# b) Version 1 of Perl's "Artistic License". You should have received |
24
|
|
|
|
|
|
|
# a copy of the Artistic License with this package, in the file |
25
|
|
|
|
|
|
|
# named "ARTISTIC". The license is also available at |
26
|
|
|
|
|
|
|
# http://opensource.org/licenses/artistic-license.php. |
27
|
|
|
|
|
|
|
# |
28
|
|
|
|
|
|
|
# This work is distributed in the hope that it will be useful, but |
29
|
|
|
|
|
|
|
# WITHOUT ANY WARRANTY; without even the implied warranty of |
30
|
|
|
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
31
|
|
|
|
|
|
|
# General Public License for more details. |
32
|
|
|
|
|
|
|
# |
33
|
|
|
|
|
|
|
# CONTRIBUTION SUBMISSION POLICY: |
34
|
|
|
|
|
|
|
# |
35
|
|
|
|
|
|
|
# (The following paragraph is not intended to limit the rights granted |
36
|
|
|
|
|
|
|
# to you to modify and distribute this software under the terms of the |
37
|
|
|
|
|
|
|
# GNU General Public License and is only of importance to you if you |
38
|
|
|
|
|
|
|
# choose to contribute your changes and enhancements to the community |
39
|
|
|
|
|
|
|
# by submitting them to Best Practical Solutions, LLC.) |
40
|
|
|
|
|
|
|
# |
41
|
|
|
|
|
|
|
# By intentionally submitting any modifications, corrections or |
42
|
|
|
|
|
|
|
# derivatives to this work, or any other work intended for use with SVK, |
43
|
|
|
|
|
|
|
# to Best Practical Solutions, LLC, you confirm that you are the |
44
|
|
|
|
|
|
|
# copyright holder for those contributions and you grant Best Practical |
45
|
|
|
|
|
|
|
# Solutions, LLC a nonexclusive, worldwide, irrevocable, royalty-free, |
46
|
|
|
|
|
|
|
# perpetual, license to use, copy, create derivative works based on |
47
|
|
|
|
|
|
|
# those contributions, and sublicense and distribute those contributions |
48
|
|
|
|
|
|
|
# and any derivatives thereof. |
49
|
|
|
|
|
|
|
# |
50
|
|
|
|
|
|
|
# END BPS TAGGED BLOCK }}} |
51
|
|
|
|
|
|
|
package SVK::Logger; |
52
|
188
|
|
|
188
|
|
2194
|
use strict; |
|
188
|
|
|
|
|
363
|
|
|
188
|
|
|
|
|
8659
|
|
53
|
188
|
|
|
188
|
|
1204
|
use warnings; |
|
188
|
|
|
|
|
383
|
|
|
188
|
|
|
|
|
18376
|
|
54
|
|
|
|
|
|
|
|
55
|
188
|
|
|
188
|
|
1081
|
use SVK::Version; our $VERSION = $SVK::VERSION; |
|
188
|
|
|
|
|
337
|
|
|
188
|
|
|
|
|
89985
|
|
56
|
|
|
|
|
|
|
|
57
|
|
|
|
|
|
|
if (eval { |
58
|
|
|
|
|
|
|
require Log::Log4perl; |
59
|
|
|
|
|
|
|
Log::Log4perl->import(':levels'); |
60
|
|
|
|
|
|
|
1; |
61
|
|
|
|
|
|
|
} ) { |
62
|
|
|
|
|
|
|
my $level = lc($ENV{SVKLOGLEVEL} || "info"); |
63
|
|
|
|
|
|
|
$level = { map { $_ => uc $_ } qw( debug info warn error fatal ) } |
64
|
|
|
|
|
|
|
->{ $level } || 'INFO'; |
65
|
|
|
|
|
|
|
|
66
|
|
|
|
|
|
|
my $conf_file = $ENV{SVKLOGCONFFILE}; |
67
|
|
|
|
|
|
|
my $conf; |
68
|
|
|
|
|
|
|
if ( defined($conf_file) and -e $conf_file ) { |
69
|
|
|
|
|
|
|
my $fh; |
70
|
|
|
|
|
|
|
open $fh, $conf_file or die $!; |
71
|
|
|
|
|
|
|
local $/; |
72
|
|
|
|
|
|
|
$conf = <$fh>; |
73
|
|
|
|
|
|
|
close $fh; |
74
|
|
|
|
|
|
|
} |
75
|
|
|
|
|
|
|
#warn $conf unless $Log::Log4perl::Logger::INITIALIZED; |
76
|
|
|
|
|
|
|
$conf ||= qq{ |
77
|
|
|
|
|
|
|
log4perl.rootLogger=$level, Screen |
78
|
|
|
|
|
|
|
log4perl.appender.Screen = Log::Log4perl::Appender::Screen |
79
|
|
|
|
|
|
|
log4perl.appender.Screen.stderr = 0 |
80
|
|
|
|
|
|
|
log4perl.appender.Screen.layout = PatternLayout |
81
|
|
|
|
|
|
|
log4perl.appender.Screen.layout.ConversionPattern = %m%n |
82
|
|
|
|
|
|
|
}; |
83
|
|
|
|
|
|
|
|
84
|
|
|
|
|
|
|
# ... passed as a reference to init() |
85
|
|
|
|
|
|
|
Log::Log4perl::init( \$conf ) unless Log::Log4perl->initialized; |
86
|
|
|
|
|
|
|
*get_logger = sub { Log::Log4perl->get_logger(@_) }; |
87
|
|
|
|
|
|
|
} |
88
|
|
|
|
|
|
|
else { |
89
|
188
|
|
|
188
|
|
457
|
*get_logger = sub { 'SVK::Logger::Compat' }; |
90
|
|
|
|
|
|
|
} |
91
|
|
|
|
|
|
|
|
92
|
|
|
|
|
|
|
sub import { |
93
|
188
|
|
|
188
|
|
440
|
my $class = shift; |
94
|
188
|
|
50
|
|
|
1610
|
my $var = shift || 'logger'; |
95
|
|
|
|
|
|
|
|
96
|
|
|
|
|
|
|
# it's ok if people add a sigil; we can get rid of that. |
97
|
188
|
|
|
|
|
1246
|
$var =~ s/^\$*//; |
98
|
|
|
|
|
|
|
|
99
|
|
|
|
|
|
|
# Find out which package we'll export into. |
100
|
188
|
|
|
|
|
720
|
my $caller = caller() . ''; |
101
|
|
|
|
|
|
|
|
102
|
188
|
|
|
|
|
745
|
(my $name = $caller) =~ s/::/./g; |
103
|
188
|
|
|
|
|
865
|
my $logger = get_logger(lc($name)); |
104
|
|
|
|
|
|
|
{ |
105
|
|
|
|
|
|
|
# As long as we don't use a package variable, each module we export |
106
|
|
|
|
|
|
|
# into will get their own object. Also, this allows us to decide on |
107
|
|
|
|
|
|
|
# the exported variable name. Hope it isn't too bad form... |
108
|
188
|
|
|
188
|
|
1398
|
no strict 'refs'; |
|
188
|
|
|
|
|
630
|
|
|
188
|
|
|
|
|
117318
|
|
|
188
|
|
|
|
|
685
|
|
109
|
188
|
|
|
|
|
378
|
*{ $caller . "::$var" } = \$logger; |
|
188
|
|
|
|
|
31397
|
|
110
|
|
|
|
|
|
|
} |
111
|
|
|
|
|
|
|
} |
112
|
|
|
|
|
|
|
|
113
|
|
|
|
|
|
|
package SVK::Logger::Compat; |
114
|
|
|
|
|
|
|
require Carp; |
115
|
|
|
|
|
|
|
|
116
|
|
|
|
|
|
|
my $current_level; |
117
|
|
|
|
|
|
|
my $level; |
118
|
|
|
|
|
|
|
|
119
|
|
|
|
|
|
|
BEGIN { |
120
|
188
|
|
|
188
|
|
4149
|
my $i; |
121
|
188
|
|
|
|
|
499
|
$level = { map { $_ => ++$i } reverse qw( debug info warn error fatal ) }; |
|
940
|
|
|
|
|
3132
|
|
122
|
188
|
|
33
|
|
|
3377
|
$current_level = $level->{lc($ENV{SVKLOGLEVEL} || "info")} || $level->{info}; |
123
|
|
|
|
|
|
|
|
124
|
188
|
|
|
0
|
|
1078
|
my $ignore = sub { return }; |
|
0
|
|
|
|
|
0
|
|
125
|
|
|
|
|
|
|
my $warn = sub { |
126
|
0
|
|
|
0
|
|
0
|
shift; |
127
|
0
|
|
|
|
|
0
|
my $s = join "", @_; |
128
|
0
|
|
|
|
|
0
|
chomp $s; |
129
|
0
|
|
|
|
|
0
|
print "$s\n"; |
130
|
188
|
|
|
|
|
1108
|
}; |
131
|
188
|
|
|
0
|
|
879
|
my $die = sub { shift; die $_[0]."\n"; }; |
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
132
|
188
|
|
|
0
|
|
711
|
my $carp = sub { shift; goto \&Carp::carp }; |
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
133
|
188
|
|
|
0
|
|
1468
|
my $confess = sub { shift; goto \&Carp::confess }; |
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
134
|
188
|
|
|
0
|
|
875
|
my $croak = sub { shift; goto \&Carp::croak }; |
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
135
|
|
|
|
|
|
|
|
136
|
188
|
50
|
|
|
|
1259
|
*debug = $current_level >= $level->{debug} ? $warn : $ignore; |
137
|
188
|
50
|
|
|
|
783
|
*info = $current_level >= $level->{info} ? $warn : $ignore; |
138
|
188
|
50
|
|
|
|
2084
|
*warn = $current_level >= $level->{warn} ? $warn : $ignore; |
139
|
188
|
50
|
|
|
|
833
|
*error = $current_level >= $level->{warn} ? $warn : $ignore; |
140
|
188
|
|
|
|
|
464
|
*fatal = $die; |
141
|
188
|
|
|
|
|
375
|
*logconfess = $confess; |
142
|
188
|
|
|
|
|
418
|
*logdie = $die; |
143
|
188
|
|
|
|
|
368
|
*logcarp = $carp; |
144
|
188
|
|
|
|
|
20584
|
*logcroak = $croak; |
145
|
|
|
|
|
|
|
|
146
|
|
|
|
|
|
|
} |
147
|
|
|
|
|
|
|
|
148
|
0
|
|
|
0
|
|
|
sub is_debug { $current_level >= $level->{debug} } |
149
|
|
|
|
|
|
|
|
150
|
|
|
|
|
|
|
1; |
151
|
|
|
|
|
|
|
|
152
|
|
|
|
|
|
|
__END__ |