From: Graham Knop Date: Fri, 6 Dec 2013 09:43:23 +0000 (-0500) Subject: refactor docs X-Git-Tag: v1.002000~7 X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=074eb8db7f15cce684ce9645cb1138d721ddd64e;p=p5sagit%2FImport-Into.git refactor docs --- diff --git a/lib/Import/Into.pm b/lib/Import/Into.pm index 11040cc..71f1507 100644 --- a/lib/Import/Into.pm +++ b/lib/Import/Into.pm @@ -43,7 +43,7 @@ sub unimport::out_of { =head1 NAME -Import::Into - import packages into other packages +Import::Into - import packages into other packages =head1 SYNOPSIS @@ -53,53 +53,44 @@ Import::Into - import packages into other packages use Thing1 (); use Thing2 (); - use Thing3 (); + # simple + sub import { + Thing1->import::into(scalar caller); + } + + # multiple sub import { my $target = caller; Thing1->import::into($target); Thing2->import::into($target, qw(import arguments)); - Thing3->import::into(1); # import to level } -Note: you don't need to do anything more clever than this provided you -document that people wanting to re-export your module should also be using -L. In fact, for a single module you can simply do: - + # by level sub import { - ... - Thing1->import::into(scalar caller); + Thing1->import::into(1); } -Notably, this works: - + # with exporter use base qw(Exporter); - sub import { shift->export_to_level(1); - Thing1->import::into(scalar caller); + Thing1->import::into(1); } -Note 2: You do B need to do anything to Thing1 to be able to call -C on it. This is a global method, and is callable on any -package (and in fact on any object as well, although it's rarer that you'd -want to do that). - -If you provide C with an integer instead of a package name, it -will be used as the number of stack frames to skip to find where to export to. -This has the advantage of preserving the apparent filename and line number -being exported to, which some modules (L, L) check. - -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) + # no My::MultiExporter == no Thing1 sub unimport { - Moose->unimport::out_of(scalar caller); # no MyThing == no Moose + Thing1->unimport::out_of(scalar caller); } -If how and why this all works is of interest to you, please read on to the -description immediately below. +You don't need to do anything more clever than this provided you +document that people wanting to re-export your module should also be using +L. + +Note: You do B need to make ayny changes to Thing1 to be able to call +C on it. This is a global method, and is callable on any +package (and in fact on any object as well, although it's rarer that you'd +want to do that). =head1 DESCRIPTION @@ -107,12 +98,56 @@ Writing exporters is a pain. Some use L, some use L, some use L, some use L ... and some things are pragmas. -If you want to re-export other things, you have to know which is which. -L subclasses provide export_to_level, but if they overrode their -import method all bets are off. L provides an into parameter -but figuring out something used it isn't trivial. Pragmas need to have -their C method called directly since they affect the current unit of -compilation. +Exporting on someone else's behalf is harder. The exporters don't provide a +consistent API for this, and pragmas need to have their import method called +directly, since they effect the current unit of compilation. + +C provides global methods to make this painless. + +=head1 METHODS + +=head2 $package->import::into( $target, @arguments ); + +A global method, callable on any package. Imports the given package into +C<$target>. C<@arguments> are passed along to the package's import method. + +C<$target> can be an package name to export to, an integer for the caller level to export to, or a hashref with the following options: + +=over 4 + +=item package + +The target package to export to. + +=item filename + +The apparent filename to export to. Some exporting modules, such as L or L, care about the filename they are being imported to. + +=item line + +The apparent line number to export to. To be combined with the C option. + +=item level + +The caller level to export to. This will automatically populate the C, C, and C options, making it the easiest most constent option. + +=item version + +A version number to check for the module. The equivalent of specifying the version number on a C line. + +=back + +=head2 $package->unimport::out_of( $target, @arguments ); + +Equivalent to C, but dispatches to C<$package>'s C method instead of C. + +=head1 WHY USE THIS MODULE + +The APIs for exporting modules aren't consistent. L subclasses +provide export_to_level, but if they overrode their import method all bets +are off. L provides an into parameter but figuring out +something used it isn't trivial. Pragmas need to have their C method +called directly since they affect the current unit of compilation. It's ... annoying.