NAME
Importer::Zim::Unit - Import functions with compilation unit scope
VERSION
version 0.4.0
SYNOPSIS
use Importer::Zim::Unit 'Scalar::Util' => 'blessed';
use Importer::Zim::Unit 'Scalar::Util' =>
( 'blessed' => { -as => 'typeof' } );
use Importer::Zim::Unit 'Mango::BSON' => ':bson';
use Importer::Zim::Unit 'Foo' => { -version => '3.0' } => 'foo';
use Importer::Zim::Unit 'SpaceTime::Machine' => [qw(robot rubber_pig)];
DESCRIPTION
"I'm gonna roll around on the floor for a while. KAY?"
– GIR
This is a backend for Importer::Zim which makes imported symbols available during compilation.
Unlike Importer::Zim::Lexical, it works for perls before 5.18. Unlike Importer::Zim::Lexical which plays with lexical subs, this meddles with the symbol tables for a (hopefully short) time interval.
HOW IT WORKS
The statement
use Importer::Zim::Unit 'Foo' => 'foo';
works sort of
use Sub::Replace;
my $_OLD_SUBS;
BEGIN {
require Foo;
$_OLD_SUBS = Sub::Replace::sub_replace('foo' => \&Foo::foo);
}
UNITCHECK {
Sub::Replace::sub_replace($_OLD_SUBS);
}
That means:
Imported subroutines are installed into the caller namespace at compile time.
Imported subroutines are cleaned up just after the unit which defined them has been compiled.
See "BEGIN, UNITCHECK, CHECK, INIT and END" in perlsub for the concept of "compilation unit" which is relevant here.
See Sub::Replace for a few gotchas about why this is not simply done with Perl statements such as
*foo = \&Foo::foo;
DEBUGGING
You can set the IMPORTER_ZIM_DEBUG
environment variable for get some diagnostics information printed to STDERR
.
IMPORTER_ZIM_DEBUG=1
SEE ALSO
"BEGIN, UNITCHECK, CHECK, INIT and END" in perlsub
AUTHOR
Adriano Ferreira <ferreira@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2017 by Adriano Ferreira.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.