1Log::Dispatchouli(3) User Contributed Perl Documentation Log::Dispatchouli(3)
2
3
4
6 Log::Dispatchouli - a simple wrapper around Log::Dispatch
7
9 version 2.019
10
12 my $logger = Log::Dispatchouli->new({
13 ident => 'stuff-purger',
14 facility => 'daemon',
15 to_stdout => $opt->{print},
16 debug => $opt->{verbose}
17 });
18
19 $logger->log([ "There are %s items left to purge...", $stuff_left ]);
20
21 $logger->log_debug("this is extra often-ignored debugging log");
22
23 $logger->log_fatal("Now we will die!!");
24
26 Log::Dispatchouli is a thin layer above Log::Dispatch and meant to make
27 it dead simple to add logging to a program without having to think much
28 about categories, facilities, levels, or things like that. It is meant
29 to make logging just configurable enough that you can find the logs you
30 want and just easy enough that you will actually log things.
31
32 Log::Dispatchouli can log to syslog (if you specify a facility),
33 standard error or standard output, to a file, or to an array in memory.
34 That last one is mostly useful for testing.
35
36 In addition to providing as simple a way to get a handle for logging
37 operations, Log::Dispatchouli uses String::Flogger to process the
38 things to be logged, meaning you can easily log data structures.
39 Basically: strings are logged as is, arrayrefs are taken as (sprintf
40 format, args), and subroutines are called only if needed. For more
41 information read the String::Flogger docs.
42
44 new
45 my $logger = Log::Dispatchouli->new(\%arg);
46
47 This returns a new logger, a Log::Dispatchouli object.
48
49 Valid arguments are:
50
51 ident - the name of the thing logging (mandatory)
52 to_self - log to the logger object for testing; default: false
53 to_stdout - log to STDOUT; default: false
54 to_stderr - log to STDERR; default: false
55 facility - to which syslog facility to send logs; default: none
56
57 to_file - log to PROGRAM_NAME.YYYYMMDD in the log path; default: false
58 log_file - a leaf name for the file to log to with to_file
59 log_path - path in which to log to file; defaults to DISPATCHOULI_PATH
60 environment variable or, failing that, to your system's tmpdir
61
62 file_format - this optional coderef is passed the message to be logged
63 and returns the text to write out
64
65 log_pid - if true, prefix all log entries with the pid; default: true
66 fail_fatal - a boolean; if true, failure to log is fatal; default: true
67 muted - a boolean; if true, only fatals are logged; default: false
68 debug - a boolean; if true, log_debug method is not a no-op
69 defaults to the truth of the DISPATCHOULI_DEBUG env var
70 quiet_fatal - 'stderr' or 'stdout' or an arrayref of zero, one, or both
71 fatal log messages will not be logged to these
72 (default: stderr)
73 config_id - a name for this logger's config; rarely needed!
74 syslog_socket - a value for Sys::Syslog's "socket" arg; default: "native"
75
76 The log path is either /tmp or the value of the DISPATCHOULI_PATH env
77 var.
78
79 If the DISPATCHOULI_NOSYSLOG env var is true, we don't log to syslog.
80
81 log
82 $logger->log(@messages);
83
84 $logger->log(\%arg, @messages);
85
86 This method uses String::Flogger on the input, then unconditionally
87 logs the result. Each message is flogged individually, then joined
88 with spaces.
89
90 If the first argument is a hashref, it will be used as extra arguments
91 to logging. It may include a "prefix" entry to preprocess the message
92 by prepending a string (if the prefix is a string) or calling a
93 subroutine to generate a new message (if the prefix is a coderef).
94
95 log_fatal
96 This behaves like the "log" method, but will throw the logged string as
97 an exception after logging.
98
99 This method can also be called as "fatal", to match other popular
100 logging interfaces. If you want to override this method, you must
101 override "log_fatal" and not "fatal".
102
103 log_debug
104 This behaves like the "log" method, but will only log (at the debug
105 level) if the logger object has its debug property set to true.
106
107 This method can also be called as "debug", to match other popular
108 logging interfaces. If you want to override this method, you must
109 override "log_debug" and not "debug".
110
111 set_debug
112 $logger->set_debug($bool);
113
114 This sets the logger's debug property, which affects the behavior of
115 "log_debug".
116
117 get_debug
118 This gets the logger's debug property, which affects the behavior of
119 "log_debug".
120
121 clear_debug
122 This method does nothing, and is only useful for
123 Log::Dispatchouli::Proxy objects. See Methods for Proxy Loggers,
124 below.
125
126 set_muted
127 $logger->set_muted($bool);
128
129 This sets the logger's muted property, which affects the behavior of
130 "log".
131
132 get_muted
133 This gets the logger's muted property, which affects the behavior of
134 "log".
135
136 clear_muted
137 This method does nothing, and is only useful for
138 Log::Dispatchouli::Proxy objects. See Methods for Proxy Loggers,
139 below.
140
141 get_prefix
142 my $prefix = $logger->get_prefix;
143
144 This method returns the currently-set prefix for the logger, which may
145 be a string or code reference or undef. See Logger Prefix.
146
147 set_prefix
148 $logger->set_prefix( $new_prefix );
149
150 This method changes the prefix. See Logger Prefix.
151
152 clear_prefix
153 This method clears any set logger prefix. (It can also be called as
154 "unset_prefix", but this is deprecated. See Logger Prefix.
155
156 ident
157 This method returns the logger's ident.
158
159 config_id
160 This method returns the logger's configuration id, which defaults to
161 its ident. This can be used to make two loggers equivalent in
162 Log::Dispatchouli::Global so that trying to reinitialize with a new
163 logger with the same "config_id" as the current logger will not throw
164 an exception, and will simply do no thing.
165
166 dispatcher
167 This returns the underlying Log::Dispatch object. This is not the
168 method you're looking for. Move along.
169
171 Log messages may be prepended with information to set context. This
172 can be set at a logger level or per log item. The simplest example is:
173
174 my $logger = Log::Dispatchouli->new( ... );
175
176 $logger->set_prefix("Batch 123: ");
177
178 $logger->log("begun processing");
179
180 # ...
181
182 $logger->log("finished processing");
183
184 The above will log something like:
185
186 Batch 123: begun processing
187 Batch 123: finished processing
188
189 To pass a prefix per-message:
190
191 $logger->log({ prefix => 'Sub-Item 234: ' }, 'error!')
192
193 # Logs: Batch 123: Sub-Item 234: error!
194
195 If the prefix is a string, it is prepended to each line of the message.
196 If it is a coderef, it is called and passed the message to be logged.
197 The return value is logged instead.
198
199 Proxy loggers also have their own prefix settings, which accumulate.
200 So:
201
202 my $proxy = $logger->proxy({ proxy_prefix => 'Subsystem 12: ' });
203
204 $proxy->set_prefix('Page 9: ');
205
206 $proxy->log({ prefix => 'Paragraph 6: ' }, 'Done.');
207
208 ...will log...
209
210 Batch 123: Subsystem 12: Page 9: Paragraph 6: Done.
211
213 string_flogger
214 This method returns the thing on which flog will be called to format
215 log messages. By default, it just returns "String::Flogger"
216
217 env_prefix
218 This method should return a string used as a prefix to find environment
219 variables that affect the logger's behavior. For example, if this
220 method returns "XYZZY" then when checking the environment for a default
221 value for the "debug" parameter, Log::Dispatchouli will first check
222 "XYZZY_DEBUG", then "DISPATCHOULI_DEBUG".
223
224 By default, this method returns "()", which means no extra environment
225 variable is checked.
226
227 env_value
228 my $value = $logger->env_value('DEBUG');
229
230 This method returns the value for the environment variable suffix
231 given. For example, the example given, calling with "DEBUG" will check
232 "DISPATCHOULI_DEBUG".
233
235 new_tester
236 my $logger = Log::Dispatchouli->new_tester( \%arg );
237
238 This returns a new logger that logs only "to_self". It's useful in
239 testing. If no "ident" arg is provided, one will be generated.
240 "log_pid" is off by default, but can be overridden.
241
242 "\%arg" is optional.
243
244 events
245 This method returns the arrayref of events logged to an array in memory
246 (in the logger). If the logger is not logging "to_self" this raises an
247 exception.
248
249 clear_events
250 This method empties the current sequence of events logged into an array
251 in memory. If the logger is not logging "to_self" this raises an
252 exception.
253
255 proxy
256 my $proxy_logger = $logger->proxy( \%arg );
257
258 This method returns a new proxy logger -- an instance of
259 Log::Dispatchouli::Proxy -- which will log through the given logger,
260 but which may have some settings localized.
261
262 %arg is optional. It may contain the following entries:
263
264 proxy_prefix
265 This is a prefix that will be applied to anything the proxy logger
266 logs, and cannot be changed.
267
268 debug
269 This can be set to true or false to change the proxy's "am I in
270 debug mode?" setting. It can be changed or cleared later on the
271 proxy.
272
273 parent
274 logger
275 These methods return the logger itself. (They're more useful when
276 called on proxy loggers.)
277
279 To provide compatibility with some other loggers, most specifically
280 Log::Contextual, the following methods are provided. You should not
281 use these methods without a good reason, and you should never subclass
282 them. Instead, subclass the methods they call.
283
284 is_debug
285 This method calls "get_debug".
286
287 is_info
288 is_fatal
289 These methods return true.
290
291 info
292 fatal
293 debug
294 These methods redispatch to "log", "log_fatal", and "log_debug"
295 respectively.
296
298 · Log::Dispatch
299
300 · String::Flogger
301
303 Ricardo SIGNES <rjbs@cpan.org>
304
306 · Christopher J. Madsen <perl@cjmweb.net>
307
308 · Dagfinn Ilmari Mannsåker <ilmari@ilmari.org>
309
310 · Dan Book <grinnz@gmail.com>
311
312 · George Hartzell <hartzell@alerce.com>
313
314 · Jon Stuart <jon@fastmailteam.com>
315
316 · Matt Phillips <mattp@cpan.org>
317
318 · Olivier Mengué <dolmen@cpan.org>
319
320 · Randy Stauner <randy@magnificent-tears.com>
321
322 · Sawyer X <xsawyerx@cpan.org>
323
325 This software is copyright (c) 2019 by Ricardo SIGNES.
326
327 This is free software; you can redistribute it and/or modify it under
328 the same terms as the Perl 5 programming language system itself.
329
330
331
332perl v5.30.0 2019-08-05 Log::Dispatchouli(3)