-
Notifications
You must be signed in to change notification settings - Fork 8
/
ApacheStdErr.pm
50 lines (43 loc) · 988 Bytes
/
ApacheStdErr.pm
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
##################################################
package Log::Log4perl::ApacheStdErr;
##################################################
#use 5.006;
use strict;
#use warnings;
use Log::Log4perl qw(:easy);
sub TIEHANDLE {
my $class = shift;
bless [], $class;
}
sub PRINT {
my $self = shift;
no warnings;
my ($str) = @_;
if ($str =~ /^\[.+\]/) {
untie *STDERR;
print STDERR @_;
tie *STDERR, 'Log::Log4perl::ApacheStdErr';
}
eval {$str = join(" ", @_)};
if ($@) {
untie *STDERR;
print STDERR @_;
print STDERR $@;
tie *STDERR, 'Log::Log4perl::ApacheStdErr';
}
if ($str =~ /uninitialized/ ) {
$Log::Log4perl::caller_depth++;
TRACE @_;
$Log::Log4perl::caller_depth--;
} elsif ($str =~ /redefined/ ) {
$Log::Log4perl::caller_depth++;
TRACE @_;
$Log::Log4perl::caller_depth--;
} else {
$Log::Log4perl::caller_depth++;
DEBUG @_;
WARN $str;
$Log::Log4perl::caller_depth--;
}
}
1;