MidLifeXis has asked for the wisdom of the Perl Monks concerning the following question:
Is this a reasonable approach to injecting a check into the "warn" call to remove certain warnings from your error stream? I would like to fix the warnings, but this is from 3rd party code, so the best I can do without rewriting their code (and introducing that mess) is to filter the errors out.
I don't want to filter all of these warnings out, just the ones from Foo::Bar.
#!perl -w ... use Foo::Bar; ... { my $lastwarn = $SIG{__WARN__}; # Filter out garbage warnings $SIG{__WARN__} = sub { return if ($_[0] =~ m/Use of uninitialized value in subroutine.*Foo +\/Bar.*/); (defined($lastwarn) && $lastwarn) ? &$lastwarn(@_) : warn(@_); }; }
Thanks all.
Update: Fixed error in regex.
Update 2: It appears (silly me) that the -w in the shebang line has implications (like making warnings global, for instance). I guess this is one of those "looking at the problem too long" type solutions (thanks tye).
--MidLifeXis
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re: Injecting a filter into warn()
by eyepopslikeamosquito (Archbishop) on Mar 10, 2005 at 21:10 UTC | |
by MidLifeXis (Monsignor) on Mar 10, 2005 at 21:14 UTC | |
by eyepopslikeamosquito (Archbishop) on Mar 10, 2005 at 21:41 UTC | |
by ikegami (Patriarch) on Mar 10, 2005 at 22:24 UTC | |
|
Re: Injecting a filter into warn()
by MidLifeXis (Monsignor) on Mar 14, 2005 at 18:05 UTC |