summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/Filter/Simple.pm15
-rw-r--r--lib/Filter/Simple/README16
-rw-r--r--lib/Filter/Simple/t/data.t2
-rw-r--r--lib/Filter/Simple/t/export.t2
-rw-r--r--lib/Filter/Simple/t/filter.t2
-rw-r--r--lib/Filter/Simple/t/filter_only.t2
-rw-r--r--lib/Filter/Simple/t/import.t2
7 files changed, 27 insertions, 14 deletions
diff --git a/lib/Filter/Simple.pm b/lib/Filter/Simple.pm
index e68fca123b..1ab5b98e3d 100644
--- a/lib/Filter/Simple.pm
+++ b/lib/Filter/Simple.pm
@@ -4,7 +4,7 @@ use Text::Balanced ':ALL';
use vars qw{ $VERSION @EXPORT };
-$VERSION = '0.77';
+$VERSION = '0.78';
use Filter::Util::Call;
use Carp;
@@ -20,7 +20,7 @@ sub import {
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);
}
@@ -98,6 +98,7 @@ my %selector_for = (
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] .= $_ }
@@ -388,6 +389,8 @@ In other words, the previous example, would become:
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
@@ -453,7 +456,7 @@ or:
}
{ 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.>
@@ -525,7 +528,7 @@ For example:
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>
@@ -573,7 +576,7 @@ found in the source code.
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
@@ -651,7 +654,7 @@ C<import> subroutine you might have explicitly declared.
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.
diff --git a/lib/Filter/Simple/README b/lib/Filter/Simple/README
index 832643df64..5ec13de99d 100644
--- a/lib/Filter/Simple/README
+++ b/lib/Filter/Simple/README
@@ -1,5 +1,5 @@
==============================================================================
- Release of version 0.77 of Filter::Simple
+ Release of version 0.78 of Filter::Simple
==============================================================================
@@ -46,10 +46,20 @@ COPYRIGHT
==============================================================================
-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
==============================================================================
diff --git a/lib/Filter/Simple/t/data.t b/lib/Filter/Simple/t/data.t
index c90702bfce..8d58046c0a 100644
--- a/lib/Filter/Simple/t/data.t
+++ b/lib/Filter/Simple/t/data.t
@@ -1,7 +1,7 @@
BEGIN {
if ($ENV{PERL_CORE}) {
chdir('t') if -d 't';
- @INC = qw(lib/Filter/Simple ../lib);
+ @INC = qw(lib/Filter/Simple ../lib);
}
}
diff --git a/lib/Filter/Simple/t/export.t b/lib/Filter/Simple/t/export.t
index 805a67a35a..40c62da96a 100644
--- a/lib/Filter/Simple/t/export.t
+++ b/lib/Filter/Simple/t/export.t
@@ -1,7 +1,7 @@
BEGIN {
if ($ENV{PERL_CORE}) {
chdir('t') if -d 't';
- @INC = qw(lib/Filter/Simple ../lib);
+ @INC = qw(lib/Filter/Simple ../lib);
}
}
diff --git a/lib/Filter/Simple/t/filter.t b/lib/Filter/Simple/t/filter.t
index d971b81522..f1d71d9279 100644
--- a/lib/Filter/Simple/t/filter.t
+++ b/lib/Filter/Simple/t/filter.t
@@ -1,7 +1,7 @@
BEGIN {
if ($ENV{PERL_CORE}) {
chdir('t') if -d 't';
- @INC = qw(lib/Filter/Simple ../lib);
+ @INC = qw(lib/Filter/Simple ../lib);
}
}
diff --git a/lib/Filter/Simple/t/filter_only.t b/lib/Filter/Simple/t/filter_only.t
index 9f81a3cc19..e537609f4b 100644
--- a/lib/Filter/Simple/t/filter_only.t
+++ b/lib/Filter/Simple/t/filter_only.t
@@ -1,7 +1,7 @@
BEGIN {
if ($ENV{PERL_CORE}) {
chdir('t') if -d 't';
- @INC = qw(lib/Filter/Simple ../lib);
+ @INC = qw(lib/Filter/Simple ../lib);
}
}
diff --git a/lib/Filter/Simple/t/import.t b/lib/Filter/Simple/t/import.t
index 99306de4f4..d087692b78 100644
--- a/lib/Filter/Simple/t/import.t
+++ b/lib/Filter/Simple/t/import.t
@@ -1,7 +1,7 @@
BEGIN {
if ($ENV{PERL_CORE}) {
chdir('t') if -d 't';
- @INC = qw(lib/Filter/Simple ../lib);
+ @INC = qw(lib/Filter/Simple ../lib);
}
}