summaryrefslogtreecommitdiff
path: root/lib/lib.pm
diff options
context:
space:
mode:
authorLarry Wall <lwall@scalpel.netlabs.com>1995-11-21 10:01:00 +1200
committerLarry <lwall@scalpel.netlabs.com>1995-11-21 10:01:00 +1200
commit4633a7c4bad06b471d9310620b7fe8ddd158cccd (patch)
tree37ebeb26a64f123784fd8fac6243b124767243b0 /lib/lib.pm
parent8e07c86ebc651fe92eb7e3b25f801f57cfb8dd6f (diff)
downloadperl-4633a7c4bad06b471d9310620b7fe8ddd158cccd.tar.gz
5.002 beta 1
If you're adventurous, have a look at ftp://ftp.sems.com/pub/outgoing/perl5.0/perl5.002beta1.tar.gz Many thanks to Andy for doing the integration. Obviously, if you consult the bugs database, you'll note there are still plenty of buglets that need fixing, and several enhancements that I've intended to put in still haven't made it in (Hi, Tim and Ilya). But I think it'll be pretty stable. And you can start to fiddle around with prototypes (which are, of course, still totally undocumented). Packrats, don't worry too much about readvertising this widely. Nowadays we're on a T1 here, so our bandwidth is okay. Have the appropriate amount of jollity. Larry
Diffstat (limited to 'lib/lib.pm')
-rw-r--r--lib/lib.pm41
1 files changed, 33 insertions, 8 deletions
diff --git a/lib/lib.pm b/lib/lib.pm
index a0fe89b13d..ab19426b04 100644
--- a/lib/lib.pm
+++ b/lib/lib.pm
@@ -1,12 +1,21 @@
package lib;
+use Config;
+
+my $archname = $Config{'archname'};
+
@ORIG_INC = (); # (avoid typo warning)
@ORIG_INC = @INC; # take a handy copy of 'original' value
sub import {
shift;
- unshift(@INC, @_);
+ foreach (@_) {
+ unshift(@INC, $_);
+ # Put a corresponding archlib directory infront of $_ if it
+ # looks like $_ has an archlib directory below it.
+ unshift(@INC, "$_/$archname") if -d "$_/$archname/auto";
+ }
}
@@ -15,7 +24,10 @@ sub unimport {
my $mode = shift if $_[0] =~ m/^:[A-Z]+/;
my %names;
- foreach(@_) { ++$names{$_} };
+ foreach(@_) {
+ ++$names{$_};
+ ++$names{"$_/$archname"} if -d "$_/$archname/auto";
+ }
if ($mode and $mode eq ':ALL') {
# Remove ALL instances of each named directory.
@@ -26,6 +38,7 @@ sub unimport {
}
}
+1;
__END__
=head1 NAME
@@ -55,10 +68,18 @@ path. Saying
use lib LIST;
-is the same as saying
+is I<almost> the same as saying
BEGIN { unshift(@INC, LIST) }
+For each directory in LIST (called $dir here) the lib module also
+checks to see if a directory called $dir/$archname/auto exists.
+If so the $dir/$archname directory is assumed to be a corresponding
+architecture specific directory and is added to @INC in front of $dir.
+
+If LIST includes both $dir and $dir/$archname then $dir/$archname will
+be added to @INC twice (if $dir/$archname/auto exists).
+
=head2 DELETING DIRECTORIES FROM @INC
@@ -77,19 +98,23 @@ specify ':ALL' as the first parameter of C<no lib>. For example:
no lib qw(:ALL .);
+For each directory in LIST (called $dir here) the lib module also
+checks to see if a directory called $dir/$archname/auto exists.
+If so the $dir/$archname directory is assumed to be a corresponding
+architecture specific directory and is also deleted from @INC.
+
+If LIST includes both $dir and $dir/$archname then $dir/$archname will
+be deleted from @INC twice (if $dir/$archname/auto exists).
+
=head2 RESTORING ORIGINAL @INC
When the lib module is first loaded it records the current value of @INC
in an array C<@lib::ORIG_INC>. To restore @INC to that value you
-can say either
+can say
@INC = @lib::ORIG_INC;
-or
-
- no lib @INC;
- use lib @lib::ORIG_INC;
=head1 SEE ALSO