[Bast-commits] r5308 - local-lib/1.000/trunk/lib/local
apeiron at dev.catalyst.perl.org
apeiron at dev.catalyst.perl.org
Wed Jan 14 02:38:54 GMT 2009
Author: apeiron
Date: 2009-01-14 02:38:54 +0000 (Wed, 14 Jan 2009)
New Revision: 5308
Modified:
local-lib/1.000/trunk/lib/local/lib.pm
Log:
Add the --self-contained patch from Mark Stosberg (with corrected CPAN.pm
command-line usage). Thanks, Mark!
Modified: local-lib/1.000/trunk/lib/local/lib.pm
===================================================================
--- local-lib/1.000/trunk/lib/local/lib.pm 2009-01-14 01:25:28 UTC (rev 5307)
+++ local-lib/1.000/trunk/lib/local/lib.pm 2009-01-14 02:38:54 UTC (rev 5308)
@@ -14,9 +14,24 @@
our $VERSION = '1.002000'; # 1.2.0
sub import {
- my ($class, $path) = @_;
+ my ($class, @args) = @_;
+
+ # The path is required, but last in the list, so we pop, not shift here.
+ my $path = pop @args;
$path = $class->resolve_path($path);
$class->setup_local_lib_for($path);
+
+ # Handle the '--self-contained' option
+ my $flag = shift @args;
+ no warnings 'uninitialized'; # the flag is optional
+ if ($flag eq '--self-contained') {
+ # The only directories that remain are those that we just defined and those where core modules are stored.
+ @INC = ($Config::Config{privlibexp}, $Config::Config{archlibexp}, split ':', $ENV{PERL5LIB});
+ }
+ elsif (defined $flag) {
+ die "unrecognized import argument: $flag";
+ }
+
}
sub pipeline;
@@ -306,6 +321,13 @@
From the shell -
+ # Install LWP and it's missing dependencies to the 'my_lwp' directory
+ perl -MCPAN -Mlocal::lib=my_lwp -e 'CPAN::install(LWP)'
+
+ # Install LWP and *all non-core* dependencies to the 'my_lwp' directory
+ perl -MCPAN -Mlocal::lib=--self-contained,my_lwp -e 'CPAN::install(LWP)'
+
+ # Just print out useful shell commands
$ perl -Mlocal::lib
export MODULEBUILDRC=/home/username/perl/.modulebuildrc
export PERL_MM_OPT='INSTALL_BASE=/home/username/perl'
@@ -365,6 +387,16 @@
These values are then available for reference by any code after import.
+=head1 A WARNING ABOUT UNINST=1
+
+Be careful about using local::lib in combination with "make install UNINST=1".
+The idea of this feature is that will uninstall an old version of a module
+before installing a new one. However it lacks a safety check that the old
+version and the new version will go in the same directory. Used in combination
+with local::lib, you can potentially delete a globally accessible version of a
+module while installing the new version in a local place. Only combine if "make
+install UNINST=1" and local::lib if you understand these possible consequences.
+
=head1 LIMITATIONS
Rather basic shell detection. Right now anything with csh in its name is
@@ -403,6 +435,8 @@
Patches to correctly output commands for csh style shells, as well as some
documentation additions, contributed by Christopher Nehren <apeiron at cpan.org>.
+'--self-contained' feature contributed by Mark Stosberg <mark at summersault.com>.
+
=head1 LICENSE
This library is free software under the same license as perl itself
More information about the Bast-commits
mailing list