NAME
Log::Fine::Formatter - Log message formatting and sanitization
SYNOPSIS
Provides a formatting facility for log messages
use Log::Fine::Handle;
use Log::Fine::Formatter;
my $handle = Log::Fine::Handle::Console->new();
my $formatter = Log::Fine::Formatter::Detailed->new(
timestamp_format => "%Y-%m-%d %H:%M:%S"
);
# by default, the handle will set its formatter to
# Log::Fine::Formatter::Basic. If that's not what you want, set
# it to preference.
$handle->formatter($formatter);
# set the time-stamp to "YYYY-MM-DD HH:MM:SS"
$formatter->timeStamp("%Y-%m-%d %H:%M:%S");
# high resolution timestamps with milliseconds are
# supported thus:
my $hires_formatter =
Log::Fine::Formatter::Basic->new(
hires => 1,
timestamp_format => "%H:%M:%S.%%millis%%",
);
DESCRIPTION
Base ancestral class for all formatters. All customized formatters must inherit from this class. The formatter class allows developers to adjust the time-stamp in a log message to a customizable strftime-compatible string without the tedious mucking about writing a formatter sub-class. By default, the time-stamp format is "%c". See "timeStamp" and the strftime(3) man page on your system for further details.
High Resolution Timestamps
High Resolution time stamps are generated using the Time::HiRes module. Depending on your distribution of perl, this may or may not be installed. Add the string "%%millis%%" (without the quotes) where you would like milliseconds displayed within your format. For example:
$formatter->timeStamp("%H:%M:%S.%%millis%%");
Please note you must enable high resolution mode during Formatter construction as so:
my $formatter = Log::Fine::Formatter::Basic->new( hires => 1 );
By default, the time-stamp format for high resolution mode is "%H:%M:%S.%%millis%%". This can be changed via the "timeStamp" method or set during formatter construction.
METHODS
format
Returns the formatted message. Must be sub-classed!
Returns
The formatted string
testFormat
Special method used for unit tests only. Not for use in production environments!
Parameters
level
Level at which to log
message
Message to log
Returns
The formatted string
timeStamp
Getter/Setter for a strftime(3)-compatible format string. If passed with an argument, sets the objects strftime compatible string. Otherwise, returns the object's format string.
Parameters
string
[optional] strftime(3) compatible string to set
Returns
strftime(3) compatible string
SEE ALSO
perl, strftime, Log::Fine, Time::HiRes
AUTHOR
Christopher M. Fuhrman, <cfuhrman at panix.com>
BUGS
Please report any bugs or feature requests to bug-log-fine-record at rt.cpan.org
, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Log-Fine. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
SUPPORT
You can find documentation for this module with the perldoc command.
perldoc Log::Fine
You can also look for information at:
AnnoCPAN: Annotated CPAN documentation
CPAN Ratings
RT: CPAN's request tracker
Search CPAN
REVISION INFORMATION
$Id: Formatter.pm 205 2010-01-03 21:06:25Z cfuhrman $
COPYRIGHT & LICENSE
Copyright (c) 2008, 2009, 2010 Christopher M. Fuhrman, All rights reserved.
This program is free software licensed under the...
The BSD License
The full text of the license can be found in the LICENSE file included with this module.