NAME

Log::Log4perl::Layout::PatternLayout - Pattern Layout

SYNOPSIS

use Log::Log4perl::Layout::PatternLayout;

my $layout = Log::Log4perl::Layout::PatternLayout->new(
                                                 "%d (%F:%L)> %m");

DESCRIPTION

Creates a pattern layout according to http://jakarta.apache.org/log4j/docs/api/org/apache/log4j/PatternLayout.html.

The new() method creates a new PatternLayout, specifying its log format. The format string can contain a number of placeholders which will be replaced by the logging engine when it's time to log the message:

%c Category of the logging event.
%C Fully qualified package (or class) name of the caller
%d Current date in yyyy/mm/dd hh:mm:ss format
%F File where the logging event occurred
%l Fully qualified name of the calling method followed by the
   callers source the file name and line number between 
   parentheses.
%L Line number within the file where the log statement was issued
%m The message to be logged
%M Method or function where the logging request was issued
%n Newline (OS-independent)
%p Priority of the logging event
%r Number of milliseconds elapsed from program start to logging 
   event
%% A literal percent (%) sign

Quantify placeholders

All placeholders can be extended with formatting instructions, just like in printf:

%20c   Reserve 20 chars for the category, left-justify and fill
       with blanks if it is shorter
%-20c  Same as %20c, but right-justify and fill the left side 
       with blanks
%09r   Zero-pad the number of milliseconds to 9 digits

Fine-tuning with curlies

Some placeholders have special functions defined if you add curlies with content after them:

%c{1}  Just show the right-most category compontent, useful in large
       class hierarchies (Foo::Baz::Bar -> Bar)
%c{2}  Just show the two right most category components
       (Foo::Baz::Bar -> Baz::Bar)

%f     Display source file including full path
%f{1}  Just display filename
%f{2}  Display filename and last path component (dir/test.log)
%f{3}  Display filename and last two path components (d1/d2/test.log)

In this way, you're able to shrink the displayed category or limit file/path components to save space in your logs.

Fine-tune the date

If you're not happy with the default %d format for the date which looks like

YYYY/MM/DD HH:mm::ss

you're free to fine-tune it in order to display only certain characteristics of a date, according to the SimpleDateFormat in the Java World (http://java.sun.com/j2se/1.3/docs/api/java/text/SimpleDateFormat.html):

%d{HH:mm}     "23:45" -- Just display hours and minutes
%d{yy, EEEE}  "02, Monday" -- Just display two-digit year 
                              and spelled-out weekday
Here's the symbols and their meaning, according to the SimpleDateFormat
specification:

Symbol   Meaning                 Presentation     Example
------   -------                 ------------     -------
G        era designator          (Text)           AD
y        year                    (Number)         1996 
M        month in year           (Text & Number)  July & 07
d        day in month            (Number)         10
h        hour in am/pm (1-12)    (Number)         12
H        hour in day (0-23)      (Number)         0
m        minute in hour          (Number)         30
s        second in minute        (Number)         55
E        day in week             (Text)           Tuesday
D        day in year             (Number)         189
a        am/pm marker            (Text)           PM

(Text): 4 or more pattern letters--use full form, < 4--use short or 
        abbreviated form if one exists. 

(Number): the minimum number of digits. Shorter numbers are 
          zero-padded to this amount. Year is handled 
          specially; that is, if the count of 'y' is 2, the 
          Year will be truncated to 2 digits. 

(Text & Number): 3 or over, use text, otherwise use number. 

There's also a bunch of pre-defined formats:

%d{ABSOLUTE}   "HH:mm:ss,SSS"
%d{DATE}       "dd MMM YYYY HH:mm:ss,SSS"
%d{ISO8601}    "YYYY-mm-dd HH:mm:ss,SSS"

SEE ALSO

AUTHOR

Mike Schilli, <m@perlmeister.com>