X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=win32%2Fconfig_h.PL;h=957966c59fa9d8a25cd533419685353ae741374b;hb=ff019190b10d1548efb9adf56145a5feb1d2cfef;hp=d266f6557f909c340a4a329927b2abc45369a75f;hpb=137443ea0a858c43f5a720730cac6209a7d41948;p=p5sagit%2Fp5-mst-13.2.git diff --git a/win32/config_h.PL b/win32/config_h.PL index d266f65..957966c 100644 --- a/win32/config_h.PL +++ b/win32/config_h.PL @@ -1,9 +1,32 @@ # -use Config; +BEGIN { warn "Running ".__FILE__."\n" }; +BEGIN + { + require "../lib/Config.pm"; + die "../Config.pm:$@" if $@; + Config::->import; + } use File::Compare qw(compare); use File::Copy qw(copy); my $name = $0; $name =~ s#^(.*)\.PL$#../$1.SH#; +my %opt; +while (@ARGV && $ARGV[0] =~ /^([\w_]+)=(.*)$/) + { + $opt{$1}=$2; + shift(@ARGV); + } + +$opt{CONFIG_H} ||= 'config.h'; + +warn "Writing $opt{CONFIG_H}\n"; + +my $patchlevel = $opt{INST_VER}; +$patchlevel =~ s|^[\\/]||; +$patchlevel =~ s|~VERSION~|$Config{version}|g; +$patchlevel ||= $Config{version}; +$patchlevel = qq["$patchlevel"]; + open(SH,"<$name") || die "Cannot open $name:$!"; while () { @@ -11,6 +34,8 @@ while () } ($term,$file,$pat) = /^sed\s+<<(\S+)\s+>(\S+)\s+(.*)$/; +$file =~ s/^\$(\w+)$/$opt{$1}/g; + my $str = "sub munge\n{\n"; while ($pat =~ s/-e\s+'([^']*)'\s*//) @@ -27,6 +52,7 @@ eval $str; die "$str:$@" if $@; open(H,">$file.new") || die "Cannot open $file.new:$!"; +#binmode H; # no CRs (which cause a spurious rebuild) while () { last if /^$term$/o; @@ -35,15 +61,17 @@ while () munge(); s/\\\$/\$/g; s#/[ *\*]*\*/#/**/#; - if (/#define\s+ARCHLIBEXP/) + if (/^\s*#define\s+(PRIVLIB|SITELIB|VENDORLIB)_EXP/) + { + $_ = "#define ". $1 . "_EXP (win32_get_". lc($1) . "($patchlevel))\t/**/\n"; + } + # incpush() handles archlibs, so disable them + elsif (/^\s*#define\s+(ARCHLIB|SITEARCH|VENDORARCH)_EXP/) { + $_ = "/*#define ". $1 . "_EXP \"\"\t/**/\n"; } print H; } -print H "#include -#define ARCHLIBEXP (win32PerlLibPath()) -#define DEBUGGING -"; close(H); close(SH); @@ -58,9 +86,14 @@ if (compare("$file.new",$file)) chmod(0666,$file); unlink($file); rename("$file.new",$file); - chmod(0444,$file); + #chmod(0444,$file); exit(1); } +else + { + unlink ("$file.new"); + exit(0); + } sub Config {