/usr/share/perl5/Log/TraceMessages.pm is in liblog-tracemessages-perl 1.4-5.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 | package Log::TraceMessages;
use strict;
use vars qw($VERSION @ISA @EXPORT @EXPORT_OK);
require Exporter; require AutoLoader; @ISA = qw(Exporter AutoLoader);
@EXPORT = qw(); @EXPORT_OK = qw(t trace d dmp);
use vars '$VERSION';
$VERSION = '1.4';
use FileHandle;
=pod
=head1 NAME
Log::TraceMessages - Perl extension for trace messages used in debugging
=head1 SYNOPSIS
use Log::TraceMessages qw(t d);
$Log::TraceMessages::On = 1;
t 'got to here';
t 'value of $a is ' . d($a);
{
local $Log::TraceMessages::On = 0;
t 'this message will not be printed';
}
$Log::TraceMessages::Logfile = 'log.out';
t 'this message will go to the file log.out';
$Log::TraceMessages::Logfile = undef;
t 'and this message is on stderr as usual';
# For a CGI program producing HTML
$Log::TraceMessages::CGI = 1;
# Or to turn on trace if there's a command-line argument '--trace'
Log::TraceMessages::check_argv();
=head1 DESCRIPTION
This module is a slightly better way to put trace statements into your
code than just calling print(). It provides an easy way to turn trace
on and off for particular sections of code without having to comment
out bits of source.
=head1 USAGE
=over
=item $Log::TraceMessages::On
Flag controlling whether tracing is on or off. You can set it as you
wish, and of course it can be C<local>-ized. The default is off.
=cut
use vars '$On';
$On = 0;
=pod
=item $Log::TraceMessages::Logfile
The name of the file to which trace should be appended. If this is
undefined (which is the default), then trace will be written to
stderr, or to stdout if C<$CGI> is set.
=cut
use vars '$Logfile';
$Logfile = undef;
my $curr_Logfile = $Logfile;
my $fh = undef;
=pod
=item $Log::TraceMessages::CGI
Flag controlling whether the program printing trace messages is a CGI
program (default is no). This means that trace messages will be
printed as HTML. Unless C<$Logfile> is also set, messages will be
printed to stdout so they appear in the output page.
=cut
use vars '$CGI';
$CGI = 0;
=pod
=item t(messages)
Print the given strings, if tracing is enabled. Unless C<$CGI> is
true or C<$Logfile> is set, each message will be printed to stderr
with a newline appended.
=cut
sub t(@) {
return unless $On;
if (defined $Logfile) {
unless (defined $curr_Logfile and $curr_Logfile eq $Logfile) {
if (defined $fh) {
close $fh unless ($fh eq \*STDOUT or $fh eq \*STDERR);
}
undef $fh;
}
if (not defined $fh) {
$fh = new FileHandle(">>$Logfile")
or die "cannot append to $Logfile: $!";
# Autoflushing here is really just a kludge to let the
# test suite work. Although it could be useful for
# 'tail -f' etc.
#
$fh->autoflush(1);
$curr_Logfile = $Logfile;
}
}
else {
if (defined $fh) {
close $fh unless ($fh eq \*STDOUT or $fh eq \*STDERR);
}
$fh = $CGI ? \*STDOUT : \*STDERR;
undef $curr_Logfile;
}
die if not defined $fh;
my $s;
foreach $s (@_) {
if ($CGI) {
require HTML::FromText;
print $fh "\n<pre>", HTML::FromText::text2html($s), "</pre>\n"
or die "cannot print to filehandle: $!";
}
else {
print $fh "$s\n"
or die "cannot print to filehandle: $!";
}
}
}
=pod
=item trace(messages)
Synonym for C<t(messages)>.
=cut
sub trace(@) { &t }
=pod
=item d(scalar)
Return a string representation of a scalarE<39>s value suitable for
use in a trace statement. This is just a wrapper for Data::Dumper.
C<d()> will exit with '' if trace is not turned on. This is to
stop your program being slowed down by generating lots of strings for
trace statements that are never printed.
=cut
sub d($) {
return '' if not $On;
require Data::Dumper;
my $s = $_[0];
my $d = Data::Dumper::Dumper($s);
$d =~ s/^\$VAR1 =\s*//;
$d =~ s/;$//;
chomp $d;
return $d;
}
=pod
=item dmp(scalar)
Synonym for C<d(scalar)>.
=cut
sub dmp(@) { &d }
=pod
=item check_argv()
Looks at the global C<@ARGV> of command-line parameters to find one
called '--trace'. If this is found, it will be removed from C<@ARGV>
and tracing will be turned on. Since tracing is off by default,
calling C<check_argv()> is a way to make your program print trace only
when you ask for it from the command line.
=cut
sub check_argv() {
my @new_argv = ();
foreach (@ARGV) {
if ($_ eq '--trace') {
$On = 1;
}
else {
push @new_argv, $_;
}
}
@ARGV = @new_argv;
}
=pod
=head1 AUTHOR
Ed Avis, ed@membled.com
=head1 SEE ALSO
perl(1), Data::Dumper(3).
=cut
1;
__END__
|