Here are the results of testing Anon and jellisii2's suggestions:
(Sample code used for testing available if needed)

  1. Log4perl qw/:easy/;

    PROS:

    • Easy to implement.

    CONS:

    • (minor) Manual work needed to find and replace all die() calls with LOGDIE
    • Does not catch and log errors in external modules that do not use Log4perl
  2. Export custom die() in Logger.pm

    PROS:

    • Easy to implement.

    CONS:

    • (minor) Extra file to be distributed with script.
    • Does not catch and log errors in external modules that do not use Log4perl
    • Catches die() in an eval
  3. Wrap logging in custom $SIG{__DIE__} handler

    PROS:

    CONS:

Any further suggestions on how I should proceed? I am leaning towards using $SIG{__DIE__} and then testing to see if anything breaks unexpectedly. If things do break, I plan on either installing the missing modules, or if ActiveState does not have them, localising $SIG{__DIE__} and wrapping the offending call in an eval.


In reply to Re: YAML, $SIG{__DIE__}, Log4perl, $^S, and eval{} by ateague
in thread [SOLVED] YAML, $SIG{__DIE__}, Log4perl, $^S, and eval{} by ateague

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.