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
|
package Log::Dispatch::Base;
use strict;
use vars qw($VERSION @EXPORT_OK);
$VERSION = sprintf "%d.%02d", q$Revision: 1.9 $ =~ /: (\d+)\.(\d+)/;
1;
sub _get_callbacks
{
shift;
my %p = @_;
return unless exists $p{callbacks};
return @{ $p{callbacks} }
if UNIVERSAL::isa( $p{callbacks}, 'ARRAY' );
return $p{callbacks}
if UNIVERSAL::isa( $p{callbacks}, 'CODE' );
return;
}
sub _apply_callbacks
{
my $self = shift;
my %p = @_;
my $msg = delete $p{message};
foreach my $cb ( @{ $self->{callbacks} } )
{
$msg = $cb->( message => $msg, %p );
}
return $msg;
}
__END__
=head1 NAME
Log::Dispatch::Base - Code shared by dispatch and output objects.
=head1 SYNOPSIS
use Log::Dispatch::Base;
...
@ISA = qw(Log::Dispatch::Base);
=head1 DESCRIPTION
Unless you are me, you probably don't need to know what this class
does.
=head1 AUTHOR
Dave Rolsky, <autarch@urth.org>
=cut
|