X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FImport%2FInto.pm;h=59c861bdd848b9391fe0ccd466ce7fce455084b1;hb=ac6d2081e8a5f1e5dbe0f95685080edaf40ca48b;hp=b1daa5475b257ea3083351e0a16f086d41b70fa3;hpb=100742112f9d3aada7ea4be3053a99b09a7ef745;p=p5sagit%2FImport-Into.git diff --git a/lib/Import/Into.pm b/lib/Import/Into.pm index b1daa54..59c861b 100644 --- a/lib/Import/Into.pm +++ b/lib/Import/Into.pm @@ -3,18 +3,22 @@ package Import::Into; use strict; use warnings FATAL => 'all'; -our $VERSION = '1.000003'; # 1.0.3 +our $VERSION = '1.001001'; # 1.1.1 my %importers; sub _importer { my $target = shift; - \($importers{$target} ||= eval qq{ - package $target; - sub { my \$m = splice \@_, 1, 1; shift->\$m(\@_) }; - } or die "Couldn't build importer for $target: $@") + my ($package, $file, $line) = $target =~ /[^0-9]/ ? ($target) : caller($target + 1); + my $code = qq{package $package;\n} + . ($file ? "#line $line \"$file\"\n" : '') + . 'sub { my $m = splice @_, 1, 1; shift->$m(@_) };'."\n"; + my $sub = \(eval $code + or die "Couldn't build importer for $package: $@"); + $importers{$target} = $sub + unless $file; + $sub; } - sub import::into { my ($class, $target, @args) = @_; @@ -73,6 +77,7 @@ want to do that). Finally, we also provide an C to allow the exporting of the effect of C: + # unimport::out_of was added in 1.1.0 (1.001000) sub unimport { Moose->unimport::out_of(scalar caller); # no MyThing == no Moose } @@ -180,6 +185,12 @@ you're receiving this from a parameter, I recommend using L: And that's it. +=head1 ACKNOWLEDGEMENTS + +Thanks to Getty for asking "how can I get C<< use strict; use warnings; >> +turned on for all consumers of my code?" and then "why is this not a +module?!". + =head1 AUTHOR mst - Matt S. Trout (cpan:MSTROUT)