in reply to (tye)Re: How do I get warnings to work properly?
in thread How do I get warnings to work properly?
I did a bit of hacking with warnings.pm. What's throwing the module off is its use of the caller function.
Here is an illustration:
package MyAbc;
warnings::register;
sub foo
{
warnings::warn "foo", if (warnings::enabled);
bar;
}
sub bar
{
warnings::warn "bar", if (warnings::enabled);
}
Warnings will work in foo because it is "top-level", but they do not work in bar because it's a function within a function.
That is, they don't work if I use warnings 'MyAbc', but they will work if I run Perl with the -w switch.
Correction ... if I run foo from a calling module, we don't see the warning from foo but we do see it from bar. However, when we run bar directly we don't see it.
Even stranger, a module that I'm working on has the opposite effect of my correction. This is strange indeed.
|
|---|