|Perl Monk, Perl Meditation|
Filter::Simple bug with here documentsby Ovid (Cardinal)
|on Dec 02, 2005 at 04:51 UTC||Need Help??|
Ovid has asked for the
wisdom of the Perl Monks concerning the following question:
Though I've already reported this bug, along with a fix, I have no idea how the fix works. I'm completely mystified. Here's a small test case:
In other words, it filters nothing.
Here's my test code:
This generates the error:substr outside of string at /usr/local/lib/perl5/5.8.7/Text/Balanced.pm line 70.
At first blush it looks like Text::Balanced has a problem with the HERE docs (and historically it has had problems with HERE docs). However, there's a relatively easy fix for this. Opening up Filter::Simple and adding [$_] as the first line of the anonymous subroutine which Filter::Simple::gen_std_filter_for returns:
And the problem mysteriously goes away. I have no frickin' idea why. Any clues? I've emailed thedamian about this but frankly, that's one heck of an embarrassing bug fix since it's "voodoo". Is there something bizarelly simple that I'm overlooking?
Side note: you can also have fun by deleting the "/" line in the first here doc. That generates other fun error messages.
This is perl, v5.8.7 built for darwin-2level. I'm using the latest Text::Balanced and Filter::Simple. I can replicate this problem on OS X and Fedora Core 2. A friend of mine can't replicate this on Perl 5.8.5 Redhat 4.0.