X-Git-Url: https://perl5.git.perl.org/perl5.git/blobdiff_plain/f711619fd1eeb97e4fd8ecb19fb934b351190e86..2c6c1df5c2ddebe97be50ffbfbe1f5a2cf113eb1:/configpm diff --git a/configpm b/configpm index ec81bfc..fbc4710 100755 --- a/configpm +++ b/configpm @@ -75,14 +75,13 @@ my %Extensions = map {($_,$_)} # This is the list from MM_VMS, plus pad.h, parser.h, perlsfio.h utf8.h # which it installs. It *doesn't* install perliol.h - FIXME. my @header_files = qw(EXTERN.h INTERN.h XSUB.h av.h config.h cop.h cv.h - embed.h embedvar.h form.h gv.h handy.h hv.h intrpvar.h + embed.h embedvar.h form.h gv.h handy.h hv.h hv_func.h intrpvar.h iperlsys.h keywords.h mg.h nostdio.h op.h opcode.h pad.h parser.h patchlevel.h perl.h perlio.h perlsdio.h perlsfio.h perlvars.h perly.h pp.h pp_proto.h proto.h regcomp.h regexp.h regnodes.h scope.h sv.h thread.h utf8.h util.h); -# No point in adding fakethr.h, as it no longer works push @header_files, $^O eq 'VMS' ? 'vmsish.h' : qw(dosish.h perliol.h time64.h unixish.h); @@ -149,7 +148,10 @@ die "Can't automatically determine name for Config_heavy.pl from '$Config_PM'" my $config_txt; my $heavy_txt; -$heavy_txt .= sprintf <<'ENDOFBEG'; +my $from = $^O eq 'VMS' ? 'PERLSHR image' : 'binary (from libperl)'; +my $env_cygwin = $^O eq 'cygwin' + ? 'push @env, "CYGWIN=\"$ENV{CYGWIN}\"" if $ENV{CYGWIN};' . "\n" : ""; +$heavy_txt .= sprintf <<'ENDOFBEG', $^O, $^O, $from, $^O, $env_cygwin; # This file was created by configpm when Perl was built. Any changes # made to this file will be lost the next time perl is built. @@ -176,6 +178,9 @@ sub local_patches { } sub _V { + die "Perl lib was built for '%s' but is being run on '$^O'" + unless "%s" eq $^O; + my ($bincompat, $non_bincompat, $date, @patches) = Internals::V(); my $opts = join ' ', sort split ' ', "$bincompat $non_bincompat"; @@ -185,11 +190,7 @@ sub _V { $opts =~ s/(?=.{53})(.{1,53}) /$1\n /mg; print Config::myconfig(); - if ($^O eq 'VMS') { - print "\nCharacteristics of this PERLSHR image: \n"; - } else { - print "\nCharacteristics of this binary (from libperl): \n"; - } + print "\nCharacteristics of this %s: \n"; print " Compile-time options: $opts\n"; @@ -198,13 +199,12 @@ sub _V { print "\t$_\n" foreach @patches; } - print " Built under $^O\n"; + print " Built under %s\n"; print " $date\n" if defined $date; my @env = map { "$_=\"$ENV{$_}\"" } sort grep {/^PERL/} keys %%ENV; - push @env, "CYGWIN=\"$ENV{CYGWIN}\"" if $^O eq 'cygwin' and $ENV{CYGWIN}; - +%s if (@env) { print " \%%ENV:\n"; print " $_\n" foreach @env; @@ -227,7 +227,7 @@ EOT my %export_ok = eval $export_funcs or die; -$config_txt .= sprintf << 'EOT', $export_funcs; +$config_txt .= sprintf << 'EOT', $], $export_funcs; # This file was created by configpm when Perl was built. Any changes # made to this file will be lost the next time perl is built. @@ -238,7 +238,9 @@ $config_txt .= sprintf << 'EOT', $export_funcs; package Config; use strict; use warnings; -use vars '%%Config'; +use vars '%%Config', '$VERSION'; + +$VERSION = "%s"; # Skip @Config::EXPORT because it only contains %%Config, which we special # case below as it's not a function. @Config::EXPORT won't change in the @@ -278,12 +280,11 @@ sub import { return; } -die "Perl lib version (%s) doesn't match executable '$0' version ($])" +die "$0: Perl lib version (%s) doesn't match executable '$^X' version ($])" unless $^V; $^V eq %s - or die "Perl lib version (%s) doesn't match executable '$0' version (" . - sprintf("v%%vd",$^V) . ")"; + or die sprintf "%%s: Perl lib version (%s) doesn't match executable '$^X' version (%%vd)", $0, $^V; ENDOFBEG @@ -382,7 +383,7 @@ $fetch_string .= <<'EOT'; EOT } else { - # We only have ' delimted. + # We only have ' delimited. $fetch_string .= <<'EOT'; return undef unless $Config_SH_expanded =~ /\n$key=\'(.*?)\'\n/s; @@ -1017,7 +1018,7 @@ EOF s{([\'\"])([^\'\"\s]+)\1}(C<$2>)g; # "date" command s{\'([A-Za-z_\- *=/]+)\'}(C<$1>)g; # 'ln -s' s{ - (?