Beefy Boxes and Bandwidth Generously Provided by pair Networks
No such thing as a small change

(simple|short|script) logging

by hiseldl (Priest)
on Dec 04, 2006 at 19:53 UTC ( #587726=snippet: 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?

What's my password?
Create A New User
Node Status?
node history
Node Type: snippet [id://587726]
[shmem]: hmm module takeover... any hints? I'm being lazy wrt searches
[choroba]: Contact the author, ask other to help contacting the author, write to pause admins
[shmem]: ah perlfaq7
[shmem]: thanks choroba, found it. 'Tis about MJD Devel::Trace

How do I use this? | Other CB clients
Other Users?
Others browsing the Monastery: (10)
As of 2018-02-23 14:47 GMT
Find Nodes?
    Voting Booth?
    When it is dark outside I am happiest to see ...

    Results (302 votes). Check out past polls.