Beefy Boxes and Bandwidth Generously Provided by pair Networks
Pathologically Eclectic Rubbish Lister
 
PerlMonks  

Re: Logging the results of 'die'

by Abigail (Deacon)
on Jun 09, 2001 at 00:15 UTC ( [id://87052]=note: print w/replies, xml ) Need Help??


in reply to Logging the results of 'die'

Yes, provided everything in your program (and its modules) use die instead of printing to STDERR. (Well, even then there are ways, but I won't go into them now).

What you need to do is use a die handler. Here's a complete program that logs errors to a file:

#!/opt/perl/bin/perl use warnings 'all'; use strict; { my ($fh, $logfile); INIT { $logfile = "/var/log/whatever/errors"; open $fh => ">> $logfile" or die "Failed to open $logfile: $!\ +n"; $SIG {__DIE__} = sub { print $fh @_; print $fh "\n" unless $_ [-1] =~ /\n\z/; }; } END { $fh and (close $fh or warn "Failed to close $logfile: $!\n"); } } print "Hello, world\n"; die "Meep, meep!"; print "I should be dead....\n"; __END__

-- Abigail

Log In?
Username:
Password:

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://87052]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this?Last hourOther CB clients
Other Users?
Others sharing their wisdom with the Monastery: (5)
As of 2024-04-20 00:23 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found