NAME
Log::Log4perl::Layout::PatternLayout::Stacktrace - implement %S
SYNOPSIS
use Log::Log4perl::Layout::PatternLayout::Stacktrace;
or
use Log::Log4perl::Layout::PatternLayout::Stacktrace -char => $letter;
or
use Log::Log4perl::Layout::PatternLayout::Stacktrace ();
Log::Log4perl::Layout::PatternLayout::Stacktrace::register_cspec $char
DESCRIPTION
This module is a subclass of Stacktrace::Configurable. It implements a slightly different default format and, mainly, registers the letter S
(or alternatively any letter you specify as value of the char
or -char
options to the import
method) as custom cspec with Log::Log4perl::Layout::PatternLayout.
If the module is require
d or use
d without calling import
, e.g. use Log::Log4perl::Layout::PatternLayout::Stacktrace ()
, no custom cspec is registered. You can do it later by calling
Log::Log4perl::Layout::PatternLayout::Stacktrace::register_cspec $char
How to generate a stack trace?
The simplest way is to include %S
(or whatever letter you registered) in your layout specification. This then uses the default stack trace format.
Alternatively, you can specify your own stack trace format putting it in curlies after the %S
like %S{[%*n] %f (%l)}
. Note, the curlies parser in Log::Log4perl::Layout::PatternLayout is not smart enough to match nesting pairs of braces. It simply matches up to the next closing brace character.
To overcome that you may put your actual format in an environment variable and use it in the curlies: %S{env=ENVVAR}
.
The default format
The default format is designed to be used in a layout pattern like this
%m%S%n
That is, first something is printed. In this case it is the actual message, %M
. Then comes the stack trace (%S
) followed by a newline.
The resulting output will then look like this:
The message
==== START STACK TRACE ===
[1] at t/100-l4p.t line 65
__ANON__ (Log::Log4perl::Logger=HASH(0x17c36e0), "The message")
[2] at t/100-l4p.t line 20
l1 ()
=== END STACK TRACE ===
You may notice there is a newline after the message. That's part of the default format.
The default format also allows you to silence a stack trace completely. It checks the environment variable L4P_STACKTRACE
. If set to off
, no
or 0
, %S
evaluates to the empty string.
There is another environment variable, L4P_STACKTRACE_A
. It controls what to do with complex data types like arrayrefs or objects.
For example, if you specify L4P_STACKTRACE_A=dump=CODE,dump=ARRAY,deparse,multiline=12
you might see this output:
The message
==== START STACK TRACE ===
[1] at t/100-l4p.t line 65
__ANON__ (
Log::Log4perl::Logger=HASH(0x17c36e0),
"The message"
)
[2] at t/100-l4p.t line 20
l1 (
sub { use warnings; use strict 'refs'; 2;},
[1,2,3]
)
=== END STACK TRACE ===
Look at frame #2. It does not say CODE(...)
as you might expect for a subroutine parameter. Instead it deparses the function. Also, if you look at the 2nd parameter which is an arrayref. It is dumped with Data::Dumper.
See StackTrace::Configurable for more information.
To be precise, the default format is this:
'env=L4P_STACKTRACE,'.
'%[nr=1,n]b%[nr=1,s= ==== START STACK TRACE ===]b%[nr=1,n]b'.
'%4b[%*n] at %f line %l%[n]b'.
'%12b%[skip_package]s %[env=L4P_STACKTRACE_A]a%[nr=$,n]b'.
'%[nr=$,s= === END STACK TRACE ===]b'
AUTHOR
Torsten Förtsch <torsten.foertsch@gmx.net>
COPYRIGHT
Copyright 2014- Torsten Förtsch
LICENSE
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.