use vars qw{ $VERSION @EXPORT };
-$VERSION = '0.77';
+$VERSION = '0.78';
use Filter::Util::Call;
use Carp;
sub FILTER (&;$) {
my $caller = caller;
my ($filter, $terminator) = @_;
- no warnings 'redefine';
+ local $SIG{__WARN__} = sub{};
*{"${caller}::import"} = gen_filter_import($caller,$filter,$terminator);
*{"${caller}::unimport"} = gen_filter_unimport($caller);
}
sub gen_std_filter_for {
my ($type, $transform) = @_;
return sub { my (@pieces, $instr);
+ $DB::single=1;
for (extract_multiple($_,$extractor_for{$type})) {
if (ref()) { push @pieces, $_; $instr=0 }
elsif ($instr) { $pieces[-1] .= $_ }
1 ;
+Note that the source code is passed as a single string, so any regex that
+uses C<^> or C<$> to detect line boundaries will need the C</m> flag.
=head2 Disabling or changing <no> behaviour
}
{ terminator => "" };
-B<Note that, no matter what you set the terminator pattern too,
+B<Note that, no matter what you set the terminator pattern to,
the actual terminator itself I<must> be contained on a single source line.>
FILTER_ONLY
code => sub { s/BANG\s+BANG/die 'BANG' if \$BANG/g },
- quotelike => sub { s/BANG\s+BANG/CHITTY CHITYY/g };
+ quotelike => sub { s/BANG\s+BANG/CHITTY CHITTY/g };
The C<"code"> subroutine will only be used to filter parts of the source
code that are not quotelikes, POD, or C<__DATA__>. The C<quotelike>
Note that you can also apply two or more of the same type of filter in
a single C<FILTER_ONLY>. For example, here's a simple
macro-preprocessor that is only applied within regexes,
-with a final debugging pass that printd the resulting source code:
+with a final debugging pass that prints the resulting source code:
use Regexp::Common;
FILTER_ONLY
However, Filter::Simple is smart enough to notice your existing
C<import> and Do The Right Thing with it.
-That is, if you explcitly define an C<import> subroutine in a package
+That is, if you explicitly define an C<import> subroutine in a package
that's using Filter::Simple, that C<import> subroutine will still
be invoked immediately after any filter you install.
==============================================================================
- Release of version 0.77 of Filter::Simple
+ Release of version 0.78 of Filter::Simple
==============================================================================
==============================================================================
-CHANGES IN VERSION 0.77
+CHANGES IN VERSION 0.78
- - Re-allowed user-defined terminators to be regexes
+ - Re-corified test modules in line with Jarkko's new scheme
+
+ - Various POD nits unknitted (thanks Autrijus)
+
+ - Added the missing DotsForArrows.pm demo file (thanks Autrijus)
+
+ - Added support for Perl 5.005
+
+ - added prereq for Text::Balanced in Makefile.PL
+
+ - Added note about use of /m flag when using ^ or $ in filter regexes
==============================================================================