X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=p5sagit%2FImport-Into.git;a=blobdiff_plain;f=lib%2FImport%2FInto.pm;h=59c861bdd848b9391fe0ccd466ce7fce455084b1;hp=a3c56528e427032b595010f8662f8a6b3310eafb;hb=ac6d2081e8a5f1e5dbe0f95685080edaf40ca48b;hpb=95ecfed2dfe247f1cb4cba0edd6cb2f706fdc930 diff --git a/lib/Import/Into.pm b/lib/Import/Into.pm index a3c5652..59c861b 100644 --- a/lib/Import/Into.pm +++ b/lib/Import/Into.pm @@ -9,12 +9,16 @@ 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) = @_;