NAME

AnyEvent::Multilog - event-driven interface to a multilog process

VERSION

version 1.102860

SYNOPSIS

my $log = AnyEvent::Multilog->new(
    script => [qw{t +* ./log}],
);

$log->start;
$log->push_write('log message');
$log->push_write('another log message');
$log->rotate;
$log->push_write('another log message in a new log file');
$log->shutdown;

DESCRIPTION

This module makes it easy to log via a multilog process. It handles spawning the multilog process and handling its errors.

ATTRIBUTES

script

Required.

This is an ArrayRef representing the multilog script that describes how to log. See the multilog for more information on what this script is and how to write one.

Note that the shell is never invoked, so you don't need to escape anything from the shell.

To select all lines, add a tai64n timestamp, and log to a directory called "log", your script should be ['t', '+*', './log'].

multilog

Optional.

The path to the multilog binary. By default, checks $PATH and uses the one in there.

on_exit

Optional.

Coderef that is called when the multilog process exists, successfully or otherwise.

Your coderef is passed three arguments, a boolean indicating successful exit, a message indicating why multilog exited, and the AnyEvent::Subprocess::Done object representing the exited subprocess.

on_error

Optional.

Coderef to be called when multilog writes something to stderr. It's assumed that logging can't proceed after something is read from stderr, so all methods will die regardless of whether or not you handle this callback. Handling this event lets you proactively spawn a new logger and kill this one without losing any messages.

Patch welcome to make this automatic. I can't get multilog to die on my machine.

METHODS

start

Call this when you are ready to fork off the multilog and start logging. If you call another method before calling this, the results are undefined.

push_write

Send a line to multilog. If you don't provide a newline, one will be provided for you.

rotate

Ask multilog to rotate the log right now.

push_shutdown

Ask multilog to shut down after writing the current line to disk. Any pending data is made available via $self->leftover_data, which can be checked for with $self->has_leftover_data.

When multilog is done writing, your on_exit callback will be called.

shutdown

Shutdown immediately by closing the file descriptor that multilog is reading from.

When multilog is done writing, your on_exit callback will be called.

is_shutdown

Returns true if multilog is done.

has_leftover_data

Returns true if multilog exited without reading some data we asked it to log.

leftover_data

Returns any data that multilog did not write before exiting.

has_errors

Returns true if errors were encourntered.

errors

Returns a list of errors that were encountered.

AUTHOR

Jonathan Rockway <jrockway@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2010 by Jonathan Rockway <jrockway@cpan.org>.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.