Beefy Boxes and Bandwidth Generously Provided by pair Networks
Keep It Simple, Stupid
 
PerlMonks  

(simple|short|script) logging

by hiseldl (Priest)
on Dec 04, 2006 at 19:53 UTC ( [id://587726]=CUFP: print w/replies, xml ) Need Help??

Have you ever written a script and needed a quick way to log-to-a-file. I've done this over and over, in the last several years that I've been writing perl. It's a simple and short way to log things to a file. For example:

# start the logfile slog "$logfile"; slog "=======================================START="; slog "= ".(scalar localtime); # do some stuff noslog; # send to another logfile slog "$another_logfile"; slog "=======================================START="; slog "= ".(scalar localtime); # do some stuff noslog;

It has limitations, such as, only one log file can be written at a time. It uses IO::File, but that shouldn't be too much of a limitation, anymore. It also puts $_slogfh in the main:: namespace. Since I mostly use this for quick testing-type scripts, I don't run into any naming collisions.

My typical usage is that I remove newlines from each sub to get them both on their own lines, then, i just add them to any scripts where I need a quick log-to-a-file solution.

sub slog(@) { $::_slogfh||=new IO::File $_[0],">>"; print $::_slogfh @_,$/ }; sub noslog() { undef $::_slogfh };

Log In?
Username:
Password:

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

How do I use this?Last hourOther CB clients
Other Users?
Others surveying the Monastery: (7)
As of 2024-04-16 06:50 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found