summaryrefslogtreecommitdiff
path: root/win32
diff options
context:
space:
mode:
authorNicholas Clark <nick@ccl4.org>2009-02-03 23:07:36 +0000
committerNicholas Clark <nick@ccl4.org>2009-02-03 23:07:36 +0000
commitd57db09df25bb4fb2f5080ca37abbbfa49f1e8cf (patch)
tree2f1933d2c3adfc00b212ce53bc754561787b51f0 /win32
parent3ddd48aab497d12ecdb647e3011a07dc2cd3ed38 (diff)
downloadperl-d57db09df25bb4fb2f5080ca37abbbfa49f1e8cf.tar.gz
Refactor to avoid changing directory, and avoid needing getcwd().
Diffstat (limited to 'win32')
-rw-r--r--win32/FindExt.pm47
1 files changed, 17 insertions, 30 deletions
diff --git a/win32/FindExt.pm b/win32/FindExt.pm
index 4038017b51..69efa0adda 100644
--- a/win32/FindExt.pm
+++ b/win32/FindExt.pm
@@ -10,16 +10,8 @@ my $no = join('|',qw(GDBM_File ODBM_File NDBM_File DB_File
$no = qr/^(?:$no)$/i;
my %ext;
-my $ext;
my %static;
-sub getcwd {
- $_ = `cd`;
- chomp;
- s:\\:/:g ;
- return $ENV{'PWD'} = $_;
-}
-
sub set_static_extensions {
# adjust results of scan_ext, and also save
# statics in case scan_ext hasn't been called yet.
@@ -39,13 +31,9 @@ sub set_static_extensions {
sub scan_ext
{
- my $here = getcwd();
- my $dir = shift;
- chdir($dir) || die "Cannot cd to $dir\n";
- ($ext = getcwd()) =~ s,/,\\,g;
- find_ext('');
- chdir($here) || die "Cannot cd to $here\n";
- my @ext = extensions();
+ my $dir = shift;
+ find_ext("$dir/", '');
+ extensions();
}
sub dynamic_ext
@@ -83,23 +71,22 @@ sub is_static
# NOTE: recursion limit of 10 to prevent runaway in case of symlink madness
sub find_ext
{
- opendir my $dh, '.';
- my @items = grep { !/^\.\.?$/ } readdir $dh;
- closedir $dh;
- for my $xxx (@items) {
+ my $prefix = shift;
+ my $dir = shift;
+ opendir my $dh, "$prefix$dir";
+ while (defined (my $xxx = readdir $dh)) {
+ next if $xxx =~ /^\.\.?$/;
if ($xxx ne "DynaLoader") {
- if (-f "$xxx/$xxx.xs" || -f "$xxx/$xxx.c" ) {
- $ext{"$_[0]$xxx"} = $static{"$_[0]$xxx"} ? 'static' : 'dynamic';
- } elsif (-f "$xxx/Makefile.PL") {
- $ext{"$_[0]$xxx"} = 'nonxs';
+ if (-f "$prefix$dir$xxx/$xxx.xs" || -f "$prefix$dir$xxx/$xxx.c" ) {
+ $ext{"$dir$xxx"} = $static{"$dir$xxx"} ? 'static' : 'dynamic';
+ } elsif (-f "$prefix$dir$xxx/Makefile.PL") {
+ $ext{"$dir$xxx"} = 'nonxs';
} else {
- if (-d $xxx && @_ < 10) {
- chdir $xxx;
- find_ext("$_[0]$xxx/", @_);
- chdir "..";
+ if (-d "$prefix$dir$xxx" && $dir =~ tr#/## < 10) {
+ find_ext($prefix, "$dir$xxx/");
}
}
- $ext{"$_[0]$xxx"} = 'known' if $ext{"$_[0]$xxx"} && $xxx =~ $no;
+ $ext{"$dir$xxx"} = 'known' if $ext{"$dir$xxx"} && $xxx =~ $no;
}
}
@@ -109,10 +96,10 @@ sub find_ext
# recursive finding breaks SDBM_File/sdbm).
# A.D. 20011025 (SDBM), ajgough 20071008 (FieldHash)
- if (!$_[0] && -d "threads/shared") {
+ if (!$dir && -d "${prefix}threads/shared") {
$ext{"threads/shared"} = 'dynamic';
}
- if (!$_[0] && -d "Hash/Util/FieldHash") {
+ if (!$dir && -d "${prefix}Hash/Util/FieldHash") {
$ext{"Hash/Util/FieldHash"} = 'dynamic';
}
}