Is not having it fatal for core operation or can you work around not having it? If not having it is fatal, then you might as well use it so your module fails immediately. If you can work around it then eval the require so you can manage the case where it's missing.
Also, I would tend to think that almost anything that imports subroutines or other symbols really needs to happen at compile time. There are some exceptions, but those tend to be the special cases.
I think newer versions of Carp are lightweight and require the heavy stuff only if invoked. Generally, that pattern may make sense -- require modules at runtime that you only need in a fatal exception (e.g. a dumper). Once the exception is triggered, the loading time of the module at at that point is pretty irrelevant.
I see it kind of like this (not a complete set of permutations, but a set of guidelines):
- Always used in any execution of the program -- use
- Sometimes used, but has import side effects (e.g. importing functions) -- use
- Sometimes used, import not required, but fatal if not present when needed -- use
- Sometimes used, import not required, can work around it not being available -- require (in an eval)
- Sometimes used, specified at runtime (e.g. by a config file) -- require
- Rarely used, fatal if not present, but module is "big" relative to rest of the code -- require or use (personal preference)
- Rarely used, only in fatal error handling -- require
-xdg
Code written by xdg and posted on PerlMonks is public domain. It is provided as is with no warranties, express or implied, of any kind. Posted code may not have been tested. Use of posted code is at your own risk.
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: |
| & | | & |
| < | | < |
| > | | > |
| [ | | [ |
| ] | | ] |
Link using PerlMonks shortcuts! What shortcuts can I use for linking?
See Writeup Formatting Tips and other pages linked from there for more info.