This is a live mirror of the Perl 5 development currently hosted at
https://github.com/perl/perl5
https://perl5.git.perl.org
/
perl5.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Update CPAN-Meta-YAML to CPAN version 0.010
[perl5.git]
/
win32
/
config_h.PL
diff --git
a/win32/config_h.PL
b/win32/config_h.PL
index
679ba99
..
6b7fbda
100644
(file)
--- a/
win32/config_h.PL
+++ b/
win32/config_h.PL
@@
-1,15
+1,39
@@
-#
-use Config;
+#!perl -w
+use strict;
+
+BEGIN { warn "Running ".__FILE__."\n" };
+BEGIN
+ {
+ require "Config.pm";
+ die "Config.pm:$@" if $@;
+ Config->import;
+ }
use File::Compare qw(compare);
use File::Copy qw(copy);
use File::Compare qw(compare);
use File::Copy qw(copy);
-my $name = $0;
+use File::Basename qw(fileparse);
+
+my ($name, $dir) = fileparse($0);
$name =~ s#^(.*)\.PL$#../$1.SH#;
$name =~ s#^(.*)\.PL$#../$1.SH#;
+my %opt;
+while (@ARGV && $ARGV[0] =~ /^([\w_]+)=(.*)$/)
+ {
+ $opt{$1}=$2;
+ shift(@ARGV);
+ }
+
+$opt{CONFIG_H} ||= 'config.h';
+$opt{CORE_DIR} ||= '../lib/CORE';
+
+warn "Writing $opt{CONFIG_H}\n";
+
open(SH,"<$name") || die "Cannot open $name:$!";
while (<SH>)
{
open(SH,"<$name") || die "Cannot open $name:$!";
while (<SH>)
{
- last if /^sed/;
+ last if /^
\s*
sed/;
}
}
-($term,$file,$pat) = /^sed\s+<<(\S+)\s+>(\S+)\s+(.*)$/;
+my($term,$file,$pat) = /^\s*sed\s+<<(\S+)\s+>(\S+)\s+(.*)$/;
+
+$file =~ s/^\$(\w+)$/$opt{$1}/g;
my $str = "sub munge\n{\n";
my $str = "sub munge\n{\n";
@@
-27,6
+51,7
@@
eval $str;
die "$str:$@" if $@;
open(H,">$file.new") || die "Cannot open $file.new:$!";
die "$str:$@" if $@;
open(H,">$file.new") || die "Cannot open $file.new:$!";
+binmode(H);
while (<SH>)
{
last if /^$term$/o;
while (<SH>)
{
last if /^$term$/o;
@@
-35,36
+60,29
@@
while (<SH>)
munge();
s/\\\$/\$/g;
s#/[ *\*]*\*/#/**/#;
munge();
s/\\\$/\$/g;
s#/[ *\*]*\*/#/**/#;
- if (/^\s*#define\s+ARCHLIB_EXP/)
+ s#(.)/\*\*/#$1/ **/# if(/^\/\*/); #avoid "/*" inside comments
+ if (/^\s*#define\s+(PRIVLIB|SITELIB|VENDORLIB)_EXP/)
{
{
- $_ = "#define
ARCHLIB_EXP (win32PerlLibPath(ARCHNAME,
NULL))\t/**/\n";
+ $_ = "#define
". $1 . "_EXP (win32_get_". lc($1) . "(PERL_VERSION_STRING,
NULL))\t/**/\n";
}
}
- if (/^\s*#define\s+PRIVLIB_EXP/)
+ # incpush() handles archlibs, so disable them
+ elsif (/^\s*#define\s+(ARCHLIB|SITEARCH|VENDORARCH)_EXP/)
{
{
- $_ = "
#define PRIVLIB_EXP (win32PerlLibPath(NULL))\t/**/\n"
+ $_ = "
/*#define ". $1 . "_EXP \"\"\t/ **/\n";
}
}
-
if (/^\s*#define\s+SITEARCH_EXP
/)
+
elsif (/^\s*#define\s+CPP(STDIN|RUN)\s+"gcc(.*)"\s*$
/)
{
{
- $_ = "#define SITEARCH_EXP (win32PerlLibPath(\"site\",ARCHNAME,NULL))\t/**/\n";
- }
- if (/^\s*#define\s+SITELIB_EXP/)
- {
- $_ = "#define SITELIB_EXP (win32PerlLibPath(\"site\",NULL))\t/**/\n";
+ $_ = "#define CPP" . $1 . " \"" . $opt{ARCHPREFIX} . "gcc" . $2 . "\"\n";
}
print H;
}
}
print H;
}
-print H "#include <win32.h>
-#ifndef DEBUGGING
-#define DEBUGGING
-#endif
-";
close(H);
close(SH);
close(H);
close(SH);
-chmod(0666,"
../lib/CORE/config.h
");
-copy("$file.new","
../lib/CORE/config.h
") || die "Cannot copy:$!";
-chmod(0444,"
../lib/CORE/config.h
");
+chmod(0666,"
$opt{CORE_DIR}/$opt{CONFIG_H}
");
+copy("$file.new","
$opt{CORE_DIR}/$opt{CONFIG_H}
") || die "Cannot copy:$!";
+chmod(0444,"
$opt{CORE_DIR}/$opt{CONFIG_H}
");
if (compare("$file.new",$file))
{
if (compare("$file.new",$file))
{
@@
-72,9
+90,13
@@
if (compare("$file.new",$file))
chmod(0666,$file);
unlink($file);
rename("$file.new",$file);
chmod(0666,$file);
unlink($file);
rename("$file.new",$file);
- chmod(0444,$file);
exit(1);
}
exit(1);
}
+else
+ {
+ unlink ("$file.new");
+ exit(0);
+ }
sub Config
{
sub Config
{
@@
-90,7
+112,7
@@
sub BackTick
my $cmd = shift;
if ($cmd =~ /^echo\s+(.*?)\s*\|\s+sed\s+'(.*)'\s*$/)
{
my $cmd = shift;
if ($cmd =~ /^echo\s+(.*?)\s*\|\s+sed\s+'(.*)'\s*$/)
{
-
local
($data,$pat) = ($1,$2);
+
my
($data,$pat) = ($1,$2);
$data =~ s/\s+/ /g;
eval "\$data =~ $pat";
return $data;
$data =~ s/\s+/ /g;
eval "\$data =~ $pat";
return $data;