line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
package HTTP::OAI::Debug; |
2
|
|
|
|
|
|
|
|
3
|
|
|
|
|
|
|
=pod |
4
|
|
|
|
|
|
|
|
5
|
|
|
|
|
|
|
=head1 NAME |
6
|
|
|
|
|
|
|
|
7
|
|
|
|
|
|
|
B - debug the HTTP::OAI libraries |
8
|
|
|
|
|
|
|
|
9
|
|
|
|
|
|
|
=head1 DESCRIPTION |
10
|
|
|
|
|
|
|
|
11
|
|
|
|
|
|
|
This package is a copy of L and exposes the same API. In addition to "trace", "debug" and "conns" this exposes a "sax" level for debugging SAX events. |
12
|
|
|
|
|
|
|
|
13
|
|
|
|
|
|
|
=cut |
14
|
|
|
|
|
|
|
|
15
|
|
|
|
|
|
|
require Exporter; |
16
|
|
|
|
|
|
|
@ISA = qw(Exporter); |
17
|
|
|
|
|
|
|
@EXPORT_OK = qw(level trace debug conns); |
18
|
|
|
|
|
|
|
|
19
|
|
|
|
|
|
|
our $VERSION = '4.12'; |
20
|
|
|
|
|
|
|
|
21
|
11
|
|
|
11
|
|
68
|
use Carp (); |
|
11
|
|
|
|
|
16
|
|
|
11
|
|
|
|
|
4926
|
|
22
|
|
|
|
|
|
|
|
23
|
|
|
|
|
|
|
my @levels = qw(trace debug conns sax); |
24
|
|
|
|
|
|
|
%current_level = (); |
25
|
|
|
|
|
|
|
|
26
|
|
|
|
|
|
|
|
27
|
|
|
|
|
|
|
sub import |
28
|
|
|
|
|
|
|
{ |
29
|
11
|
|
|
11
|
|
22
|
my $pack = shift; |
30
|
11
|
|
|
|
|
20
|
my $callpkg = caller(0); |
31
|
11
|
|
|
|
|
18
|
my @symbols = (); |
32
|
11
|
|
|
|
|
18
|
my @levels = (); |
33
|
11
|
|
|
|
|
25
|
for (@_) { |
34
|
0
|
0
|
|
|
|
0
|
if (/^[-+]/) { |
35
|
0
|
|
|
|
|
0
|
push(@levels, $_); |
36
|
|
|
|
|
|
|
} |
37
|
|
|
|
|
|
|
else { |
38
|
0
|
|
|
|
|
0
|
push(@symbols, $_); |
39
|
|
|
|
|
|
|
} |
40
|
|
|
|
|
|
|
} |
41
|
11
|
|
|
|
|
507
|
Exporter::export($pack, $callpkg, @symbols); |
42
|
11
|
|
|
|
|
35
|
level(@levels); |
43
|
|
|
|
|
|
|
} |
44
|
|
|
|
|
|
|
|
45
|
|
|
|
|
|
|
|
46
|
|
|
|
|
|
|
sub level |
47
|
|
|
|
|
|
|
{ |
48
|
11
|
|
|
11
|
0
|
253
|
for (@_) { |
49
|
0
|
0
|
|
|
|
0
|
if ($_ eq '+') { # all on |
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
50
|
|
|
|
|
|
|
# switch on all levels |
51
|
0
|
|
|
|
|
0
|
%current_level = map { $_ => 1 } @levels; |
|
0
|
|
|
|
|
0
|
|
52
|
|
|
|
|
|
|
} |
53
|
|
|
|
|
|
|
elsif ($_ eq '-') { # all off |
54
|
0
|
|
|
|
|
0
|
%current_level = (); |
55
|
|
|
|
|
|
|
} |
56
|
|
|
|
|
|
|
elsif (/^([-+])(\w+)$/) { |
57
|
0
|
|
|
|
|
0
|
$current_level{$2} = $1 eq '+'; |
58
|
|
|
|
|
|
|
} |
59
|
|
|
|
|
|
|
else { |
60
|
0
|
|
|
|
|
0
|
Carp::croak("Illegal level format $_"); |
61
|
|
|
|
|
|
|
} |
62
|
|
|
|
|
|
|
} |
63
|
|
|
|
|
|
|
} |
64
|
|
|
|
|
|
|
|
65
|
|
|
|
|
|
|
|
66
|
22
|
50
|
|
22
|
0
|
150
|
sub trace { _log(@_) if $current_level{'trace'}; } |
67
|
0
|
0
|
|
0
|
0
|
0
|
sub debug { _log(@_) if $current_level{'debug'}; } |
68
|
0
|
0
|
|
0
|
0
|
0
|
sub conns { _log(@_) if $current_level{'conns'}; } |
69
|
1289
|
50
|
|
1289
|
0
|
49989
|
sub sax { _log(@_) if $current_level{'sax'}; } |
70
|
|
|
|
|
|
|
|
71
|
|
|
|
|
|
|
|
72
|
|
|
|
|
|
|
sub _log |
73
|
|
|
|
|
|
|
{ |
74
|
0
|
|
|
0
|
|
|
my $msg = shift; |
75
|
0
|
|
|
|
|
|
$msg =~ s/\n$//; |
76
|
0
|
|
|
|
|
|
$msg =~ s/\n/\\n/g; |
77
|
|
|
|
|
|
|
|
78
|
0
|
|
|
|
|
|
my($package,$filename,$line,$sub) = caller(2); |
79
|
0
|
|
|
|
|
|
print STDERR "$sub: $msg\n"; |
80
|
|
|
|
|
|
|
} |
81
|
|
|
|
|
|
|
|
82
|
|
|
|
|
|
|
1; |