in reply to Use and Require - making an informed choice.

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):

-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.