X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2Fblib.pm;h=f755e29b0de7f818a27e03cd631bd7c858256b6a;hb=eb60b0e7b57f22da325f4de3b9eed4515e564eef;hp=1d56a58174e3777dd4f74a85840e591a304b5928;hpb=fc1ce8cc0aa3c1d2926edfb2f302ea8c60b40168;p=p5sagit%2Fp5-mst-13.2.git diff --git a/lib/blib.pm b/lib/blib.pm index 1d56a58..f755e29 100644 --- a/lib/blib.pm +++ b/lib/blib.pm @@ -16,7 +16,7 @@ Looks for MakeMaker-like I<'blib'> directory structure starting in I (or current directory) and working back up to five levels of '..'. Intended for use on command line with B<-M> option as a way of testing -arbitary scripts against an uninstalled version of a package. +arbitrary scripts against an uninstalled version of a package. However it is possible to : @@ -34,37 +34,62 @@ Pollutes global name space for development only task. Nick Ing-Simmons nik@tiuk.ti.com -=cut +=cut use Cwd; +use File::Spec; -use vars qw($VERSION); -$VERSION = '1.00'; +use vars qw($VERSION $Verbose); +$VERSION = '1.04'; +$Verbose = 0; sub import { my $package = shift; - my $dir = getcwd; - if ($^O eq 'VMS') { ($dir = VMS::Filespec::unixify($dir)) =~ s-/$--; } + my $dir; + if ($^O eq "MSWin32" && -f "Win32.xs") { + # We don't use getcwd() on Windows because it will internally + # call Win32::GetCwd(), which will get the Win32 module loaded. + # That means that it would not be possible to run `make test` + # for the Win32 module because blib.pm would always load the + # installed version before @INC gets updated with the blib path. + chomp($dir = `cd`); + } + else { + $dir = getcwd; + } + if ($^O eq 'VMS') { ($dir = VMS::Filespec::unixify($dir)) =~ s-/\z--; } if (@_) { $dir = shift; - $dir =~ s/blib$//; - $dir =~ s,/+$,,; - $dir = '.' unless ($dir); + $dir =~ s/blib\z//; + $dir =~ s,/+\z,,; + $dir = File::Spec->curdir unless ($dir); die "$dir is not a directory\n" unless (-d $dir); } - my $i = 5; + my $i = 5; + my($blib, $blib_lib, $blib_arch); while ($i--) { - my $blib = "${dir}/blib"; - if (-d $blib && -d "$blib/arch" && -d "$blib/lib") + $blib = File::Spec->catdir($dir, "blib"); + $blib_lib = File::Spec->catdir($blib, "lib"); + + if ($^O eq 'MacOS') + { + $blib_arch = File::Spec->catdir($blib_lib, $MacPerl::Architecture); + } + else + { + $blib_arch = File::Spec->catdir($blib, "arch"); + } + + if (-d $blib && -d $blib_arch && -d $blib_lib) { - unshift(@INC,"$blib/arch","$blib/lib"); - warn "Using $blib\n"; + unshift(@INC,$blib_arch,$blib_lib); + warn "Using $blib\n" if $Verbose; return; } - $dir .= "/.."; + $dir = File::Spec->catdir($dir, File::Spec->updir); } die "Cannot find blib even in $dir\n"; }