Is there a way to use Log::Log4perl to make a smart self-logging module that logs its operations to a file even in the absence of the calling script not initializing Log4perl? As far as I can tell from the documentation, the only way to use Log4perl is to initialize it in the running script from a configuration, then modules implementing Log4perl calls log themselves based on the caller’s Log4perl config.
Instead, I’d like the modules to provide a default initialization config for Log4perl. This would provide the default file appender for the module’s category. Then, I could override this behavior by initing Log4perl in the caller with a different config if needed, and everything would hopefully just work.
Is this sort of defensive logging behavior possible or am I going to need to rely on initing Log4perl in every .pl script that calls the module I want logged?
I do this in a custom Log role in Moose (irrelevant complicated code removed):
As you can see, the log object is self-initializing — if
Log::Log4perl->inithas not been called, theneasy_initis called. You could easily modify this to allow each module to customize its logger — I do so with optional role parameters, withref($this)as the default fallback.PS. You may also want to look at MooseX::Log::Log4perl, which is where I started before I used the logger role above. Someday when I get around to it I will submit some much-needed patches to that MX module to incorporate some features I have added.