This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
=for apidoc wrong api
[perl5.git] / configpm
CommitLineData
a0d0e21e 1#!./miniperl -w
962e59f3
DM
2#
3# configpm
4#
8ed6d636
VK
5# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001,
6# 2002, 2003, 2004, 2005, 2006, 2007 Larry Wall and others.
962e59f3
DM
7#
8#
9# Regenerate the files
10#
11# lib/Config.pm
12# lib/Config_heavy.pl
13# lib/Config.pod
962e59f3 14#
8ed6d636 15#
962e59f3
DM
16# from the contents of the static files
17#
18# Porting/Glossary
19# myconfig.SH
20#
21# and from the contents of the Configure-generated file
22#
23# config.sh
24#
8ed6d636 25#
962e59f3
DM
26# It will only update Config.pm and Config_heavy.pl if the contents of
27# either file would be different. Note that *both* files are updated in
28# this case, since for example an extension makefile that has a dependency
29# on Config.pm should trigger even if only Config_heavy.pl has changed.
30
31sub usage { die <<EOF }
d2d98f31 32usage: $0 [ options ]
962e59f3 33 --no-glossary don't include Porting/Glossary in lib/Config.pod
4e73d6a4 34 --chdir=dir change directory before writing files
962e59f3
DM
35EOF
36
2f4f46ad
NC
37use strict;
38use vars qw(%Config $Config_SH_expanded);
8990e307 39
a8e1d30b
NC
40my $how_many_common = 22;
41
42# commonly used names to precache (and hence lookup fastest)
43my %Common;
44
45while ($how_many_common--) {
46 $_ = <DATA>;
47 chomp;
48 /^(\S+):\s*(\d+)$/ or die "Malformed line '$_'";
49 $Common{$1} = $1;
50}
5435c704 51
d50f1408
NC
52# Post 37589e1eefb1bd62 DynaLoader defaults to reading these at runtime.
53# Ideally we're redo the data below, but Fotango's build system made it
54# wonderfully easy to instrument, and no longer exists.
55$Common{$_} = $_ foreach qw(dlext so);
56
5435c704
NC
57# names of things which may need to have slashes changed to double-colons
58my %Extensions = map {($_,$_)}
59 qw(dynamic_ext static_ext extensions known_extensions);
60
1f0fc1c9
NC
61# The plan is that this information is used by ExtUtils::MakeMaker to generate
62# Makefile dependencies, rather than hardcoding a list, which has become out
63# of date. However, currently, MM_Unix.pm and MM_VMS.pm have *different* lists,
64# *and* descrip_mms.template doesn't actually install all the headers.
65# The "Unix" list seems to (attempt to) avoid the generated headers, which I'm
66# not sure is the right thing to do. Also, not certain whether it would be
67# easier to parse MANIFEST to get these (adding config.h, and potentially
68# removing others), but for now, stick to a hard coded list.
69
70# Could use a map to add ".h", but I suspect that it's easier to use literals,
71# so that anyone using grep will find them
97cb92d6 72# This is the list from MM_VMS, plus pad.h, parser.h, utf8.h
1f0fc1c9
NC
73# which it installs. It *doesn't* install perliol.h - FIXME.
74my @header_files = qw(EXTERN.h INTERN.h XSUB.h av.h config.h cop.h cv.h
4d3a042d 75 embed.h embedvar.h form.h gv.h handy.h hv.h hv_func.h intrpvar.h
1f0fc1c9
NC
76 iperlsys.h keywords.h mg.h nostdio.h op.h opcode.h
77 pad.h parser.h patchlevel.h perl.h perlio.h perlsdio.h
97cb92d6 78 perlvars.h perly.h pp.h pp_proto.h proto.h
1f0fc1c9
NC
79 regcomp.h regexp.h regnodes.h scope.h sv.h thread.h utf8.h
80 util.h);
81
1f0fc1c9
NC
82push @header_files,
83 $^O eq 'VMS' ? 'vmsish.h' : qw(dosish.h perliol.h time64.h unixish.h);
84
85my $header_files = ' return qw(' . join(' ', sort @header_files) . ');';
86$header_files =~ s/(?=.{64}) # If line is still overlength
87 (.{1,64})\ # Split at the last convenient space
88 /$1\n /gx;
89
5435c704
NC
90# allowed opts as well as specifies default and initial values
91my %Allowed_Opts = (
2d9d8159 92 'glossary' => 1, # --no-glossary - no glossary file inclusion,
5435c704 93 # for compactness
4e73d6a4 94 'chdir' => '', # --chdir=dir - change directory before writing files
18f68570 95);
18f68570 96
5435c704
NC
97sub opts {
98 # user specified options
99 my %given_opts = (
100 # --opt=smth
101 (map {/^--([\-_\w]+)=(.*)$/} @ARGV),
102 # --opt --no-opt --noopt
103 (map {/^no-?(.*)$/i?($1=>0):($_=>1)} map {/^--([\-_\w]+)$/} @ARGV),
104 );
105
106 my %opts = (%Allowed_Opts, %given_opts);
107
108 for my $opt (grep {!exists $Allowed_Opts{$_}} keys %given_opts) {
962e59f3
DM
109 warn "option '$opt' is not recognized";
110 usage;
5435c704
NC
111 }
112 @ARGV = grep {!/^--/} @ARGV;
113
114 return %opts;
115}
18f68570 116
5435c704
NC
117
118my %Opts = opts();
119
4e73d6a4
NC
120if ($Opts{chdir}) {
121 chdir $Opts{chdir} or die "$0: could not chdir $Opts{chdir}: $!"
122}
123
8ed6d636 124my ($Config_SH, $Config_PM, $Config_heavy, $Config_POD);
d2d98f31 125my $Glossary = 'Porting/Glossary';
5435c704 126
8aaffb9f
BF
127$Config_PM = "lib/Config.pm";
128$Config_POD = "lib/Config.pod";
129$Config_SH = "config.sh";
130
d2d98f31
VK
131($Config_heavy = $Config_PM) =~ s/\.pm$/_heavy.pl/;
132die "Can't automatically determine name for Config_heavy.pl from '$Config_PM'"
133 if $Config_heavy eq $Config_PM;
8990e307 134
962e59f3
DM
135my $config_txt;
136my $heavy_txt;
2d9d8159 137
c6b7b56c 138my $export_funcs = <<'EOT';
9fe67fcb
NC
139my %Export_Cache = (myconfig => 1, config_sh => 1, config_vars => 1,
140 config_re => 1, compile_date => 1, local_patches => 1,
3acb769b 141 bincompat_options => 1, non_bincompat_options => 1,
1f0fc1c9 142 header_files => 1);
c6b7b56c 143EOT
a0d0e21e 144
c6b7b56c
NC
145my %export_ok = eval $export_funcs or die;
146
c7a7bc4d 147$config_txt .= sprintf << 'EOT', $], $export_funcs;
5435c704
NC
148# This file was created by configpm when Perl was built. Any changes
149# made to this file will be lost the next time perl is built.
3c81428c 150
3acf89b2
MB
151# for a description of the variables, please have a look at the
152# Glossary file, as written in the Porting folder, or use the url:
153# http://perl5.git.perl.org/perl.git/blob/HEAD:/Porting/Glossary
154
8990e307 155package Config;
2f4f46ad 156use strict;
9fe67fcb 157use warnings;
c7a7bc4d
DG
158use vars '%%Config', '$VERSION';
159
160$VERSION = "%s";
c6b7b56c
NC
161
162# Skip @Config::EXPORT because it only contains %%Config, which we special
163# case below as it's not a function. @Config::EXPORT won't change in the
164# lifetime of Perl 5.
165%s
2f4f46ad 166@Config::EXPORT = qw(%%Config);
c6b7b56c 167@Config::EXPORT_OK = keys %%Export_Cache;
a48f8c77 168
43d06990
NC
169# Need to stub all the functions to make code such as print Config::config_sh
170# keep working
171
c6b7b56c 172EOT
43d06990 173
c6b7b56c 174$config_txt .= "sub $_;\n" foreach sort keys %export_ok;
2f4f46ad 175
c6b7b56c
NC
176my $myver = sprintf "%vd", $^V;
177
178$config_txt .= sprintf <<'ENDOFBEG', ($myver) x 3;
e3d0cac0
IZ
179
180# Define our own import method to avoid pulling in the full Exporter:
181sub import {
a5094cb0 182 shift;
2f4f46ad 183 @_ = @Config::EXPORT unless @_;
5435c704 184
a48f8c77
MS
185 my @funcs = grep $_ ne '%%Config', @_;
186 my $export_Config = @funcs < @_ ? 1 : 0;
5435c704 187
2f4f46ad 188 no strict 'refs';
a48f8c77
MS
189 my $callpkg = caller(0);
190 foreach my $func (@funcs) {
a5094cb0
NC
191 die qq{"$func" is not exported by the Config module\n}
192 unless $Export_Cache{$func};
a48f8c77
MS
193 *{$callpkg.'::'.$func} = \&{$func};
194 }
5435c704 195
a48f8c77
MS
196 *{"$callpkg\::Config"} = \%%Config if $export_Config;
197 return;
e3d0cac0
IZ
198}
199
69667126 200die "$0: Perl lib version (%s) doesn't match executable '$^X' version ($])"
5435c704 201 unless $^V;
de98c553 202
5435c704 203$^V eq %s
69667126 204 or die sprintf "%%s: Perl lib version (%s) doesn't match executable '$^X' version (%%vd)", $0, $^V;
a0d0e21e 205
8990e307
LW
206ENDOFBEG
207
16d20bd9 208
5435c704 209my @non_v = ();
5435c704
NC
210my @v_others = ();
211my $in_v = 0;
212my %Data = ();
ebf3760c 213my $quote;
5435c704 214
a0d0e21e 215
1a9ca827 216my %seen_quotes;
2f4f46ad
NC
217{
218 my ($name, $val);
8ed6d636 219 open(CONFIG_SH, $Config_SH) || die "Can't open $Config_SH: $!";
2f4f46ad 220 while (<CONFIG_SH>) {
a0d0e21e 221 next if m:^#!/bin/sh:;
5435c704 222
a02608de 223 # Catch PERL_CONFIG_SH=true and PERL_VERSION=n line from Configure.
d4de4258 224 s/^(\w+)=(true|\d+)\s*$/$1='$2'\n/ or m/^(\w+)='(.*)'$/;
3905a40f 225 my($k, $v) = ($1, $2);
5435c704 226
2000072c 227 # grandfather PATCHLEVEL and SUBVERSION and CONFIG
cceca5ed
GS
228 if ($k) {
229 if ($k eq 'PERL_VERSION') {
230 push @v_others, "PATCHLEVEL='$v'\n";
231 }
232 elsif ($k eq 'PERL_SUBVERSION') {
233 push @v_others, "SUBVERSION='$v'\n";
234 }
a02608de 235 elsif ($k eq 'PERL_CONFIG_SH') {
2000072c
JH
236 push @v_others, "CONFIG='$v'\n";
237 }
cceca5ed 238 }
5435c704 239
435ec615
HM
240 # We can delimit things in config.sh with either ' or ".
241 unless ($in_v or m/^(\w+)=(['"])(.*\n)/){
a0d0e21e
LW
242 push(@non_v, "#$_"); # not a name='value' line
243 next;
244 }
5435c704
NC
245 if ($in_v) {
246 $val .= $_;
247 }
248 else {
ebf3760c 249 $quote = $2;
5435c704
NC
250 ($name,$val) = ($1,$3);
251 }
435ec615 252 $in_v = $val !~ /$quote\n/;
44a8e56a 253 next if $in_v;
a0d0e21e 254
5435c704 255 s,/,::,g if $Extensions{$name};
a0d0e21e 256
5435c704 257 $val =~ s/$quote\n?\z//;
3c81428c 258
5435c704 259 my $line = "$name=$quote$val$quote\n";
deeea481 260 push(@v_others, $line);
1a9ca827 261 $seen_quotes{$quote}++;
2f4f46ad
NC
262 }
263 close CONFIG_SH;
5435c704 264}
2f4f46ad 265
1a9ca827
NC
266# This is somewhat grim, but I want the code for parsing config.sh here and
267# now so that I can expand $Config{ivsize} and $Config{ivtype}
268
269my $fetch_string = <<'EOT';
270
271# Search for it in the big string
272sub fetch_string {
273 my($self, $key) = @_;
274
275EOT
276
277if ($seen_quotes{'"'}) {
278 # We need the full ' and " code
1a9ca827 279
b46acf92
NC
280$fetch_string .= <<'EOT';
281 return undef unless my ($quote_type, $value) = $Config_SH_expanded =~ /\n$key=(['"])(.*?)\1\n/s;
1a9ca827
NC
282
283 # If we had a double-quote, we'd better eval it so escape
284 # sequences and such can be interpolated. Since the incoming
285 # value is supposed to follow shell rules and not perl rules,
286 # we escape any perl variable markers
b46acf92
NC
287
288 # Historically, since " 'support' was added in change 1409, the
289 # interpolation was done before the undef. Stick to this arguably buggy
290 # behaviour as we're refactoring.
1a9ca827
NC
291 if ($quote_type eq '"') {
292 $value =~ s/\$/\\\$/g;
293 $value =~ s/\@/\\\@/g;
294 eval "\$value = \"$value\"";
295 }
b46acf92
NC
296
297 # So we can say "if $Config{'foo'}".
298 $self->{$key} = $value eq 'undef' ? undef : $value; # cache it
1a9ca827 299}
b46acf92
NC
300EOT
301
302} else {
2effe01f 303 # We only have ' delimited.
b46acf92 304
1a9ca827 305$fetch_string .= <<'EOT';
b46acf92 306 return undef unless $Config_SH_expanded =~ /\n$key=\'(.*?)\'\n/s;
1a9ca827 307 # So we can say "if $Config{'foo'}".
b46acf92 308 $self->{$key} = $1 eq 'undef' ? undef : $1;
1a9ca827
NC
309}
310EOT
311
b46acf92
NC
312}
313
1a9ca827
NC
314eval $fetch_string;
315die if $@;
3c81428c 316
8468119f
NC
317# Calculation for the keys for byteorder
318# This is somewhat grim, but I need to run fetch_string here.
deeea481 319our $Config_SH_expanded = join "\n", '', @v_others;
8468119f
NC
320
321my $t = fetch_string ({}, 'ivtype');
322my $s = fetch_string ({}, 'ivsize');
323
324# byteorder does exist on its own but we overlay a virtual
325# dynamically recomputed value.
326
327# However, ivtype and ivsize will not vary for sane fat binaries
328
329my $f = $t eq 'long' ? 'L!' : $s == 8 ? 'Q': 'I';
330
331my $byteorder_code;
332if ($s == 4 || $s == 8) {
4efc19b7 333 my $list = join ',', reverse(1..$s-1);
8468119f
NC
334 my $format = 'a'x$s;
335 $byteorder_code = <<"EOT";
2855b621 336
4efc19b7
NC
337my \$i = ord($s);
338foreach my \$c ($list) { \$i <<= 8; \$i |= ord(\$c); }
2d9d8159 339our \$byteorder = join('', unpack('$format', pack('$f', \$i)));
8468119f
NC
340EOT
341} else {
2d9d8159 342 $byteorder_code = "our \$byteorder = '?'x$s;\n";
8468119f
NC
343}
344
88fe16b2
NC
345my @need_relocation;
346
347if (fetch_string({},'userelocatableinc')) {
4d20abad
NC
348 foreach my $what (qw(prefixexp
349
350 archlibexp
351 html1direxp
352 html3direxp
353 man1direxp
354 man3direxp
91f668c3 355 privlibexp
4d20abad 356 scriptdirexp
91f668c3 357 sitearchexp
4d20abad
NC
358 sitebinexp
359 sitehtml1direxp
360 sitehtml3direxp
91f668c3 361 sitelibexp
4d20abad
NC
362 siteman1direxp
363 siteman3direxp
364 sitescriptexp
91f668c3 365 vendorarchexp
4d20abad
NC
366 vendorbinexp
367 vendorhtml1direxp
368 vendorhtml3direxp
91f668c3 369 vendorlibexp
4d20abad
NC
370 vendorman1direxp
371 vendorman3direxp
372 vendorscriptexp
373
374 siteprefixexp
375 sitelib_stem
1d230ada
NC
376 vendorlib_stem
377
378 installarchlib
379 installhtml1dir
380 installhtml3dir
381 installman1dir
382 installman3dir
383 installprefix
384 installprefixexp
385 installprivlib
386 installscript
387 installsitearch
388 installsitebin
389 installsitehtml1dir
390 installsitehtml3dir
391 installsitelib
392 installsiteman1dir
393 installsiteman3dir
394 installsitescript
395 installvendorarch
396 installvendorbin
397 installvendorhtml1dir
398 installvendorhtml3dir
399 installvendorlib
400 installvendorman1dir
401 installvendorman3dir
402 installvendorscript
403 )) {
88fe16b2
NC
404 push @need_relocation, $what if fetch_string({}, $what) =~ m!^\.\.\./!;
405 }
88fe16b2
NC
406}
407
408my %need_relocation;
409@need_relocation{@need_relocation} = @need_relocation;
410
91f668c3
NC
411# This can have .../ anywhere:
412if (fetch_string({}, 'otherlibdirs') =~ m!\.\.\./!) {
413 $need_relocation{otherlibdirs} = 'otherlibdirs';
414}
415
88fe16b2
NC
416my $relocation_code = <<'EOT';
417
418sub relocate_inc {
419 my $libdir = shift;
420 return $libdir unless $libdir =~ s!^\.\.\./!!;
421 my $prefix = $^X;
422 if ($prefix =~ s!/[^/]*$!!) {
423 while ($libdir =~ m!^\.\./!) {
424 # Loop while $libdir starts "../" and $prefix still has a trailing
425 # directory
426 last unless $prefix =~ s!/([^/]+)$!!;
427 # but bail out if the directory we picked off the end of $prefix is .
428 # or ..
429 if ($1 eq '.' or $1 eq '..') {
430 # Undo! This should be rare, hence code it this way rather than a
431 # check each time before the s!!! above.
432 $prefix = "$prefix/$1";
433 last;
434 }
435 # Remove that leading ../ and loop again
436 substr ($libdir, 0, 3, '');
437 }
438 $libdir = "$prefix/$libdir";
439 }
440 $libdir;
441}
442EOT
443
ed9ba3bb
JR
444my $osname = fetch_string({}, 'osname');
445my $from = $osname eq 'VMS' ? 'PERLSHR image' : 'binary (from libperl)';
446my $env_cygwin = $osname eq 'cygwin'
447 ? 'push @env, "CYGWIN=\"$ENV{CYGWIN}\"" if $ENV{CYGWIN};' . "\n" : "";
448
449$heavy_txt .= sprintf <<'ENDOFBEG', $osname, $osname, $from, $osname, $env_cygwin;
450# This file was created by configpm when Perl was built. Any changes
451# made to this file will be lost the next time perl is built.
452
453package Config;
454use strict;
455use warnings;
456use vars '%%Config';
457
458sub bincompat_options {
459 return split ' ', (Internals::V())[0];
460}
461
462sub non_bincompat_options {
463 return split ' ', (Internals::V())[1];
464}
465
466sub compile_date {
467 return (Internals::V())[2]
468}
469
470sub local_patches {
471 my (undef, undef, undef, @patches) = Internals::V();
472 return @patches;
473}
474
475sub _V {
476 die "Perl lib was built for '%s' but is being run on '$^O'"
477 unless "%s" eq $^O;
478
479 my ($bincompat, $non_bincompat, $date, @patches) = Internals::V();
480
481 my $opts = join ' ', sort split ' ', "$bincompat $non_bincompat";
482
483 # wrap at 76 columns.
484
485 $opts =~ s/(?=.{53})(.{1,53}) /$1\n /mg;
486
487 print Config::myconfig();
488 print "\nCharacteristics of this %s: \n";
489
490 print " Compile-time options: $opts\n";
491
492 if (@patches) {
493 print " Locally applied patches:\n";
494 print "\t$_\n" foreach @patches;
495 }
496
497 print " Built under %s\n";
498
499 print " $date\n" if defined $date;
500
501 my @env = map { "$_=\"$ENV{$_}\"" } sort grep {/^PERL/} keys %%ENV;
502%s
503 if (@env) {
504 print " \%%ENV:\n";
505 print " $_\n" foreach @env;
506 }
507 print " \@INC:\n";
508 print " $_\n" foreach @INC;
509}
510
511sub header_files {
512ENDOFBEG
513
514$heavy_txt .= $header_files . "\n}\n\n";
515
91f668c3 516if (%need_relocation) {
88fe16b2 517 my $relocations_in_common;
91f668c3
NC
518 # otherlibdirs only features in the hash
519 foreach (keys %need_relocation) {
88fe16b2
NC
520 $relocations_in_common++ if $Common{$_};
521 }
522 if ($relocations_in_common) {
962e59f3 523 $config_txt .= $relocation_code;
88fe16b2 524 } else {
962e59f3 525 $heavy_txt .= $relocation_code;
88fe16b2
NC
526 }
527}
528
962e59f3 529$heavy_txt .= join('', @non_v) . "\n";
3c81428c 530
5435c704 531# copy config summary format from the myconfig.SH script
962e59f3 532$heavy_txt .= "our \$summary = <<'!END!';\n";
3b5ca523 533open(MYCONFIG,"<myconfig.SH") || die "open myconfig.SH failed: $!";
54310121 5341 while defined($_ = <MYCONFIG>) && !/^Summary of/;
962e59f3 535do { $heavy_txt .= $_ } until !defined($_ = <MYCONFIG>) || /^\s*$/;
3c81428c 536close(MYCONFIG);
a0d0e21e 537
962e59f3 538$heavy_txt .= "\n!END!\n" . <<'EOT';
90ec21fb 539my $summary_expanded;
3c81428c 540
541sub myconfig {
90ec21fb
EM
542 return $summary_expanded if $summary_expanded;
543 ($summary_expanded = $summary) =~ s{\$(\w+)}
46807d8e
YO
544 {
545 my $c;
546 if ($1 eq 'git_ancestor_line') {
547 if ($Config::Config{git_ancestor}) {
548 $c= "\n Ancestor: $Config::Config{git_ancestor}";
549 } else {
550 $c= "";
551 }
552 } else {
553 $c = $Config::Config{$1};
554 }
555 defined($c) ? $c : 'undef'
556 }ge;
90ec21fb 557 $summary_expanded;
3c81428c 558}
5435c704 559
8468119f
NC
560local *_ = \my $a;
561$_ = <<'!END!';
3c81428c 562EOT
563
962e59f3 564$heavy_txt .= join('', sort @v_others) . "!END!\n";
2855b621
NC
565
566# Only need the dynamic byteorder code in Config.pm if 'byteorder' is one of
567# the precached keys
568if ($Common{byteorder}) {
962e59f3 569 $config_txt .= $byteorder_code;
2855b621 570} else {
962e59f3 571 $heavy_txt .= $byteorder_code;
2855b621 572}
5435c704 573
88fe16b2 574if (@need_relocation) {
962e59f3
DM
575$heavy_txt .= 'foreach my $what (qw(' . join (' ', @need_relocation) .
576 ")) {\n" . <<'EOT';
8d962fa1 577 s/^($what=)(['"])(.*?)\2/$1 . $2 . relocate_inc($3) . $2/me;
88fe16b2
NC
578}
579EOT
91f668c3
NC
580# Currently it only makes sense to do the ... relocation on Unix, so there's
581# no need to emulate the "which separator for this platform" logic in perl.c -
582# ':' will always be applicable
583if ($need_relocation{otherlibdirs}) {
962e59f3 584$heavy_txt .= << 'EOT';
91f668c3
NC
585s{^(otherlibdirs=)(['"])(.*?)\2}
586 {$1 . $2 . join ':', map {relocate_inc($_)} split ':', $3 . $2}me;
587EOT
588}
88fe16b2
NC
589}
590
962e59f3 591$heavy_txt .= <<'EOT';
2d9d8159 592s/(byteorder=)(['"]).*?\2/$1$2$Config::byteorder$2/m;
43d06990
NC
593
594my $config_sh_len = length $_;
3be00128 595
e935c5a4 596our $Config_SH_expanded = "\n$_" . << 'EOVIRTUAL';
8468119f
NC
597EOT
598
06482b90
NC
599foreach my $prefix (qw(ccflags ldflags)) {
600 my $value = fetch_string ({}, $prefix);
601 my $withlargefiles = fetch_string ({}, $prefix . "_uselargefiles");
27da23d5
JH
602 if (defined $withlargefiles) {
603 $value =~ s/\Q$withlargefiles\E\b//;
962e59f3 604 $heavy_txt .= "${prefix}_nolargefiles='$value'\n";
27da23d5 605 }
06482b90 606}
5435c704 607
06482b90
NC
608foreach my $prefix (qw(libs libswanted)) {
609 my $value = fetch_string ({}, $prefix);
27da23d5
JH
610 my $withlf = fetch_string ({}, 'libswanted_uselargefiles');
611 next unless defined $withlf;
06482b90
NC
612 my @lflibswanted
613 = split(' ', fetch_string ({}, 'libswanted_uselargefiles'));
614 if (@lflibswanted) {
615 my %lflibswanted;
616 @lflibswanted{@lflibswanted} = ();
617 if ($prefix eq 'libs') {
618 my @libs = grep { /^-l(.+)/ &&
619 not exists $lflibswanted{$1} }
620 split(' ', fetch_string ({}, 'libs'));
621 $value = join(' ', @libs);
622 } else {
623 my @libswanted = grep { not exists $lflibswanted{$_} }
624 split(' ', fetch_string ({}, 'libswanted'));
625 $value = join(' ', @libswanted);
4b2ec495 626 }
435ec615 627 }
962e59f3 628 $heavy_txt .= "${prefix}_nolargefiles='$value'\n";
5435c704
NC
629}
630
962e59f3 631$heavy_txt .= "EOVIRTUAL\n";
06482b90 632
46807d8e 633$heavy_txt .= <<'ENDOFGIT';
505afc73 634eval {
12d7e04d
YO
635 # do not have hairy conniptions if this isnt available
636 require 'Config_git.pl';
637 $Config_SH_expanded .= $Config::Git_Data;
505afc73
YO
638 1;
639} or warn "Warning: failed to load Config_git.pl, something strange about this perl...\n";
46807d8e
YO
640ENDOFGIT
641
962e59f3 642$heavy_txt .= $fetch_string;
06482b90 643
962e59f3 644$config_txt .= <<'ENDOFEND';
06482b90 645
2d9d8159 646sub FETCH {
5435c704
NC
647 my($self, $key) = @_;
648
649 # check for cached value (which may be undef so we use exists not defined)
9fe67fcb 650 return exists $self->{$key} ? $self->{$key} : $self->fetch_string($key);
a0d0e21e 651}
9fe67fcb 652
2d9d8159
NC
653ENDOFEND
654
962e59f3 655$heavy_txt .= <<'ENDOFEND';
1a9ca827 656
3c81428c 657my $prevpos = 0;
658
a0d0e21e
LW
659sub FIRSTKEY {
660 $prevpos = 0;
2ddb7828 661 substr($Config_SH_expanded, 1, index($Config_SH_expanded, '=') - 1 );
a0d0e21e
LW
662}
663
664sub NEXTKEY {
1a9ca827
NC
665ENDOFEND
666if ($seen_quotes{'"'}) {
962e59f3 667$heavy_txt .= <<'ENDOFEND';
435ec615 668 # Find out how the current key's quoted so we can skip to its end.
3be00128
NC
669 my $quote = substr($Config_SH_expanded,
670 index($Config_SH_expanded, "=", $prevpos)+1, 1);
671 my $pos = index($Config_SH_expanded, qq($quote\n), $prevpos) + 2;
1a9ca827
NC
672ENDOFEND
673} else {
674 # Just ' quotes, so it's much easier.
962e59f3 675$heavy_txt .= <<'ENDOFEND';
1a9ca827
NC
676 my $pos = index($Config_SH_expanded, qq('\n), $prevpos) + 2;
677ENDOFEND
678}
962e59f3 679$heavy_txt .= <<'ENDOFEND';
3be00128 680 my $len = index($Config_SH_expanded, "=", $pos) - $pos;
a0d0e21e 681 $prevpos = $pos;
3be00128 682 $len > 0 ? substr($Config_SH_expanded, $pos, $len) : undef;
85e6fe83 683}
a0d0e21e 684
2ddb7828 685sub EXISTS {
5435c704
NC
686 return 1 if exists($_[0]->{$_[1]});
687
1a9ca827
NC
688 return(index($Config_SH_expanded, "\n$_[1]='") != -1
689ENDOFEND
690if ($seen_quotes{'"'}) {
962e59f3 691$heavy_txt .= <<'ENDOFEND';
1a9ca827
NC
692 or index($Config_SH_expanded, "\n$_[1]=\"") != -1
693ENDOFEND
694}
962e59f3 695$heavy_txt .= <<'ENDOFEND';
5435c704 696 );
a0d0e21e
LW
697}
698
3c81428c 699sub STORE { die "\%Config::Config is read-only\n" }
e736dcee 700*DELETE = *CLEAR = \*STORE; # Typeglob aliasing uses less space
3c81428c 701
702sub config_sh {
43d06990 703 substr $Config_SH_expanded, 1, $config_sh_len;
748a9306 704}
9193ea20 705
706sub config_re {
707 my $re = shift;
3be00128
NC
708 return map { chomp; $_ } grep eval{ /^(?:$re)=/ }, split /^/,
709 $Config_SH_expanded;
9193ea20 710}
711
3c81428c 712sub config_vars {
307dc113 713 # implements -V:cfgvar option (see perlrun -V:)
a48f8c77 714 foreach (@_) {
307dc113 715 # find optional leading, trailing colons; and query-spec
4a305f6a 716 my ($notag,$qry,$lncont) = m/^(:)?(.*?)(:)?$/; # flags fore and aft,
307dc113
JC
717 # map colon-flags to print decorations
718 my $prfx = $notag ? '': "$qry="; # tag-prefix for print
719 my $lnend = $lncont ? ' ' : ";\n"; # line ending for print
4a305f6a 720
307dc113 721 # all config-vars are by definition \w only, any \W means regex
4a305f6a
JC
722 if ($qry =~ /\W/) {
723 my @matches = config_re($qry);
724 print map "$_$lnend", @matches ? @matches : "$qry: not found" if !$notag;
725 print map { s/\w+=//; "$_$lnend" } @matches ? @matches : "$qry: not found" if $notag;
a48f8c77 726 } else {
2d9d8159
NC
727 my $v = (exists $Config::Config{$qry}) ? $Config::Config{$qry}
728 : 'UNKNOWN';
a48f8c77 729 $v = 'undef' unless defined $v;
4a305f6a 730 print "${prfx}'${v}'$lnend";
a48f8c77 731 }
3c81428c 732 }
733}
734
2d9d8159
NC
735# Called by the real AUTOLOAD
736sub launcher {
737 undef &AUTOLOAD;
738 goto \&$Config::AUTOLOAD;
739}
740
7411;
9193ea20 742ENDOFEND
743
744if ($^O eq 'os2') {
962e59f3 745 $config_txt .= <<'ENDOFSET';
9193ea20 746my %preconfig;
747if ($OS2::is_aout) {
3be00128 748 my ($value, $v) = $Config_SH_expanded =~ m/^used_aout='(.*)'\s*$/m;
9193ea20 749 for (split ' ', $value) {
3be00128 750 ($v) = $Config_SH_expanded =~ m/^aout_$_='(.*)'\s*$/m;
9193ea20 751 $preconfig{$_} = $v eq 'undef' ? undef : $v;
752 }
753}
764df951 754$preconfig{d_fork} = undef unless $OS2::can_fork; # Some funny cases can't
9193ea20 755sub TIEHASH { bless {%preconfig} }
756ENDOFSET
a48f8c77
MS
757 # Extract the name of the DLL from the makefile to avoid duplication
758 my ($f) = grep -r, qw(GNUMakefile Makefile);
759 my $dll;
760 if (open my $fh, '<', $f) {
761 while (<$fh>) {
762 $dll = $1, last if /^PERL_DLL_BASE\s*=\s*(\S*)\s*$/;
763 }
30500b05 764 }
962e59f3 765 $config_txt .= <<ENDOFSET if $dll;
30500b05
IZ
766\$preconfig{dll_name} = '$dll';
767ENDOFSET
9193ea20 768} else {
962e59f3 769 $config_txt .= <<'ENDOFSET';
5435c704
NC
770sub TIEHASH {
771 bless $_[1], $_[0];
772}
9193ea20 773ENDOFSET
774}
775
a8e1d30b
NC
776foreach my $key (keys %Common) {
777 my $value = fetch_string ({}, $key);
778 # Is it safe on the LHS of => ?
779 my $qkey = $key =~ /^[A-Za-z_][A-Za-z0-9_]*$/ ? $key : "'$key'";
780 if (defined $value) {
781 # Quote things for a '' string
782 $value =~ s!\\!\\\\!g;
783 $value =~ s!'!\\'!g;
784 $value = "'$value'";
91f668c3
NC
785 if ($key eq 'otherlibdirs') {
786 $value = "join (':', map {relocate_inc(\$_)} split (':', $value))";
787 } elsif ($need_relocation{$key}) {
88fe16b2
NC
788 $value = "relocate_inc($value)";
789 }
a8e1d30b
NC
790 } else {
791 $value = "undef";
792 }
793 $Common{$key} = "$qkey => $value";
794}
2855b621
NC
795
796if ($Common{byteorder}) {
797 $Common{byteorder} = 'byteorder => $byteorder';
798}
799my $fast_config = join '', map { " $_,\n" } sort values %Common;
5435c704 800
e4d9df75
FC
801# Sanity check needed to stop an infinite loop if Config_heavy.pl fails to
802# define &launcher for some reason (eg it got truncated)
962e59f3 803$config_txt .= sprintf <<'ENDOFTIE', $fast_config;
9193ea20 804
fb73857a 805sub DESTROY { }
806
2d9d8159 807sub AUTOLOAD {
c1b2b415 808 require 'Config_heavy.pl';
938af39e 809 goto \&launcher unless $Config::AUTOLOAD =~ /launcher$/;
2d9d8159
NC
810 die "&Config::AUTOLOAD failed on $Config::AUTOLOAD";
811}
812
2c165900 813# tie returns the object, so the value returned to require will be true.
5435c704 814tie %%Config, 'Config', {
a8e1d30b 815%s};
5435c704
NC
816ENDOFTIE
817
748a9306 818
8ed6d636 819open(CONFIG_POD, ">$Config_POD") or die "Can't open $Config_POD: $!";
5435c704 820print CONFIG_POD <<'ENDOFTAIL';
3c81428c 821=head1 NAME
a0d0e21e 822
3c81428c 823Config - access Perl configuration information
824
825=head1 SYNOPSIS
826
827 use Config;
63f18be6
NC
828 if ($Config{usethreads}) {
829 print "has thread support\n"
3c81428c 830 }
831
a48f8c77 832 use Config qw(myconfig config_sh config_vars config_re);
3c81428c 833
834 print myconfig();
835
836 print config_sh();
837
a48f8c77
MS
838 print config_re();
839
3c81428c 840 config_vars(qw(osname archname));
841
842
843=head1 DESCRIPTION
844
845The Config module contains all the information that was available to
846the C<Configure> program at Perl build time (over 900 values).
847
848Shell variables from the F<config.sh> file (written by Configure) are
849stored in the readonly-variable C<%Config>, indexed by their names.
850
851Values stored in config.sh as 'undef' are returned as undefined
1fef88e7 852values. The perl C<exists> function can be used to check if a
3c81428c 853named variable exists.
854
3acf89b2
MB
855For a description of the variables, please have a look at the
856Glossary file, as written in the Porting folder, or use the url:
857http://perl5.git.perl.org/perl.git/blob/HEAD:/Porting/Glossary
858
3c81428c 859=over 4
860
861=item myconfig()
862
863Returns a textual summary of the major perl configuration values.
2788353a 864See also C<-V> in L<perlrun/Command Switches>.
3c81428c 865
866=item config_sh()
867
868Returns the entire perl configuration information in the form of the
869original config.sh shell variable assignment script.
870
a48f8c77
MS
871=item config_re($regex)
872
873Like config_sh() but returns, as a list, only the config entries who's
874names match the $regex.
875
3c81428c 876=item config_vars(@names)
877
878Prints to STDOUT the values of the named configuration variable. Each is
879printed on a separate line in the form:
880
881 name='value';
882
883Names which are unknown are output as C<name='UNKNOWN';>.
2788353a 884See also C<-V:name> in L<perlrun/Command Switches>.
3c81428c 885
3acb769b
NC
886=item bincompat_options()
887
888Returns a list of C pre-processor options used when compiling this F<perl>
889binary, which affect its binary compatibility with extensions.
890C<bincompat_options()> and C<non_bincompat_options()> are shown together in
891the output of C<perl -V> as I<Compile-time options>.
892
893=item non_bincompat_options()
894
895Returns a list of C pre-processor options used when compiling this F<perl>
896binary, which do not affect binary compatibility with extensions.
897
898=item compile_date()
899
900Returns the compile date (as a string), equivalent to what is shown by
901C<perl -V>
902
903=item local_patches()
904
905Returns a list of the names of locally applied patches, equivalent to what
906is shown by C<perl -V>.
907
1f0fc1c9
NC
908=item header_files()
909
910Returns a list of the header files that should be used as dependencies for
911XS code, for this version of Perl on this platform.
912
3c81428c 913=back
914
915=head1 EXAMPLE
916
917Here's a more sophisticated example of using %Config:
918
919 use Config;
743c51bc
W
920 use strict;
921
922 my %sig_num;
923 my @sig_name;
924 unless($Config{sig_name} && $Config{sig_num}) {
925 die "No sigs?";
926 } else {
927 my @names = split ' ', $Config{sig_name};
928 @sig_num{@names} = split ' ', $Config{sig_num};
929 foreach (@names) {
930 $sig_name[$sig_num{$_}] ||= $_;
931 }
932 }
3c81428c 933
743c51bc
W
934 print "signal #17 = $sig_name[17]\n";
935 if ($sig_num{ALRM}) {
936 print "SIGALRM is $sig_num{ALRM}\n";
3c81428c 937 }
938
939=head1 WARNING
940
941Because this information is not stored within the perl executable
942itself it is possible (but unlikely) that the information does not
943relate to the actual perl binary which is being used to access it.
944
945The Config module is installed into the architecture and version
946specific library directory ($Config{installarchlib}) and it checks the
947perl version number when loaded.
948
435ec615
HM
949The values stored in config.sh may be either single-quoted or
950double-quoted. Double-quoted strings are handy for those cases where you
951need to include escape sequences in the strings. To avoid runtime variable
952interpolation, any C<$> and C<@> characters are replaced by C<\$> and
953C<\@>, respectively. This isn't foolproof, of course, so don't embed C<\$>
954or C<\@> in double-quoted strings unless you're willing to deal with the
955consequences. (The slashes will end up escaped and the C<$> or C<@> will
956trigger variable interpolation)
957
ebc74a4b
GS
958=head1 GLOSSARY
959
960Most C<Config> variables are determined by the C<Configure> script
961on platforms supported by it (which is most UNIX platforms). Some
962platforms have custom-made C<Config> variables, and may thus not have
963some of the variables described below, or may have extraneous variables
964specific to that particular port. See the port specific documentation
965in such cases.
966
c90cd22b
RGS
967=cut
968
ebc74a4b
GS
969ENDOFTAIL
970
5435c704
NC
971if ($Opts{glossary}) {
972 open(GLOS, "<$Glossary") or die "Can't open $Glossary: $!";
18f68570 973}
2f4f46ad
NC
974my %seen = ();
975my $text = 0;
fb87c415 976$/ = '';
8b4a1c96 977my $errors= 0;
fb87c415
IZ
978
979sub process {
aade5aff
YST
980 if (s/\A(\w*)\s+\(([\w.]+)\):\s*\n(\t?)/=item C<$1>\n\nFrom F<$2>:\n\n/m) {
981 my $c = substr $1, 0, 1;
982 unless ($seen{$c}++) {
5435c704 983 print CONFIG_POD <<EOF if $text;
fb87c415 984=back
ebc74a4b 985
c90cd22b
RGS
986=cut
987
fb87c415 988EOF
5435c704 989 print CONFIG_POD <<EOF;
fb87c415
IZ
990=head2 $c
991
bbc7dcd2 992=over 4
fb87c415 993
c90cd22b
RGS
994=cut
995
fb87c415 996EOF
aade5aff
YST
997 $text = 1;
998 }
999 }
1000 elsif (!$text || !/\A\t/) {
1001 warn "Expected a Configure variable header",
8b4a1c96
YO
1002 ($text ? " or another paragraph of description" : () ),
1003 ", instead we got:\n$_";
1004 $errors++;
fb87c415
IZ
1005 }
1006 s/n't/n\00t/g; # leave can't, won't etc untouched
9b22980b 1007 s/^\t\s+(.*)/\n$1/gm; # Indented lines ===> new paragraph
fb87c415
IZ
1008 s/^(?<!\n\n)\t(.*)/$1/gm; # Not indented lines ===> text
1009 s{([\'\"])(?=[^\'\"\s]*[./][^\'\"\s]*\1)([^\'\"\s]+)\1}(F<$2>)g; # '.o'
1010 s{([\'\"])([^\'\"\s]+)\1}(C<$2>)g; # "date" command
1011 s{\'([A-Za-z_\- *=/]+)\'}(C<$1>)g; # 'ln -s'
1012 s{
24665371 1013 (?<! [\w./<\'\"\$] ) # Only standalone file names
fb87c415
IZ
1014 (?! e \. g \. ) # Not e.g.
1015 (?! \. \. \. ) # Not ...
1016 (?! \d ) # Not 5.004
a1151a3c
RGS
1017 (?! read/ ) # Not read/write
1018 (?! etc\. ) # Not etc.
1019 (?! I/O ) # Not I/O
1020 (
1021 \$ ? # Allow leading $
1022 [\w./]* [./] [\w./]* # Require . or / inside
1023 )
1024 (?<! \. (?= [\s)] ) ) # Do not include trailing dot
fb87c415
IZ
1025 (?! [\w/] ) # Include all of it
1026 }
1027 (F<$1>)xg; # /usr/local
1028 s/((?<=\s)~\w*)/F<$1>/g; # ~name
1029 s/(?<![.<\'\"])\b([A-Z_]{2,})\b(?![\'\"])/C<$1>/g; # UNISTD
1030 s/(?<![.<\'\"])\b(?!the\b)(\w+)\s+macro\b/C<$1> macro/g; # FILE_cnt macro
1031 s/n[\0]t/n't/g; # undo can't, won't damage
ebc74a4b
GS
1032}
1033
5435c704 1034if ($Opts{glossary}) {
7701ffb5
JH
1035 <GLOS>; # Skip the "DO NOT EDIT"
1036 <GLOS>; # Skip the preamble
18f68570
VK
1037 while (<GLOS>) {
1038 process;
5435c704 1039 print CONFIG_POD;
18f68570 1040 }
8b4a1c96
YO
1041 if ($errors) {
1042 die "Errors encountered while processing $Glossary. ",
1043 "Header lines are expected to be of the form:\n",
1044 "NAME (CLASS):\n",
1045 "Maybe there is a malformed header?\n",
1046 ;
1047 }
fb87c415 1048}
ebc74a4b 1049
5435c704 1050print CONFIG_POD <<'ENDOFTAIL';
ebc74a4b
GS
1051
1052=back
1053
58ab6743
RS
1054=head1 GIT DATA
1055
1056Information on the git commit from which the current perl binary was compiled
1057can be found in the variable C<$Config::Git_Data>. The variable is a
1058structured string that looks something like this:
1059
1060 git_commit_id='ea0c2dbd5f5ac6845ecc7ec6696415bf8e27bd52'
1061 git_describe='GitLive-blead-1076-gea0c2db'
1062 git_branch='smartmatch'
1063 git_uncommitted_changes=''
1064 git_commit_id_title='Commit id:'
1065 git_commit_date='2009-05-09 17:47:31 +0200'
1066
1067Its format is not guaranteed not to change over time.
1068
3c81428c 1069=head1 NOTE
1070
1071This module contains a good example of how to use tie to implement a
1072cache and an example of how to make a tied variable readonly to those
1073outside of it.
1074
1075=cut
a0d0e21e 1076
9193ea20 1077ENDOFTAIL
a0d0e21e 1078
962e59f3 1079close(GLOS) if $Opts{glossary};
5435c704 1080close(CONFIG_POD);
8ed6d636 1081print "written $Config_POD\n";
962e59f3
DM
1082
1083my $orig_config_txt = "";
1084my $orig_heavy_txt = "";
1085{
1086 local $/;
1087 my $fh;
1088 $orig_config_txt = <$fh> if open $fh, "<", $Config_PM;
1089 $orig_heavy_txt = <$fh> if open $fh, "<", $Config_heavy;
1090}
1091
1092if ($orig_config_txt ne $config_txt or $orig_heavy_txt ne $heavy_txt) {
1093 open CONFIG, ">", $Config_PM or die "Can't open $Config_PM: $!\n";
1094 open CONFIG_HEAVY, ">", $Config_heavy or die "Can't open $Config_heavy: $!\n";
1095 print CONFIG $config_txt;
1096 print CONFIG_HEAVY $heavy_txt;
1097 close(CONFIG_HEAVY);
1098 close(CONFIG);
1099 print "updated $Config_PM\n";
1100 print "updated $Config_heavy\n";
1101}
1102
a0d0e21e
LW
1103# Now do some simple tests on the Config.pm file we have created
1104unshift(@INC,'lib');
5435c704 1105require $Config_PM;
13bce055 1106require $Config_heavy;
a0d0e21e
LW
1107import Config;
1108
5435c704 1109die "$0: $Config_PM not valid"
a02608de 1110 unless $Config{'PERL_CONFIG_SH'} eq 'true';
a0d0e21e 1111
5435c704 1112die "$0: error processing $Config_PM"
a0d0e21e 1113 if defined($Config{'an impossible name'})
a02608de 1114 or $Config{'PERL_CONFIG_SH'} ne 'true' # test cache
a0d0e21e
LW
1115 ;
1116
5435c704 1117die "$0: error processing $Config_PM"
a0d0e21e
LW
1118 if eval '$Config{"cc"} = 1'
1119 or eval 'delete $Config{"cc"}'
1120 ;
1121
1122
85e6fe83 1123exit 0;
a8e1d30b
NC
1124# Popularity of various entries in %Config, based on a large build and test
1125# run of code in the Fotango build system:
1126__DATA__
1127path_sep: 8490
1128d_readlink: 7101
1129d_symlink: 7101
1130archlibexp: 4318
1131sitearchexp: 4305
1132sitelibexp: 4305
1133privlibexp: 4163
1134ldlibpthname: 4041
1135libpth: 2134
1136archname: 1591
1137exe_ext: 1256
1138scriptdir: 1155
1139version: 1116
1140useithreads: 1002
1141osvers: 982
1142osname: 851
1143inc_version_list: 783
1144dont_use_nlink: 779
1145intsize: 759
1146usevendorprefix: 642
1147dlsrc: 624
1148cc: 541
1149lib_ext: 520
1150so: 512
1151ld: 501
1152ccdlflags: 500
1153ldflags: 495
1154obj_ext: 495
1155cccdlflags: 493
1156lddlflags: 493
1157ar: 492
1158dlext: 492
1159libc: 492
1160ranlib: 492
1161full_ar: 491
1162vendorarchexp: 491
1163vendorlibexp: 491
1164installman1dir: 489
1165installman3dir: 489
1166installsitebin: 489
1167installsiteman1dir: 489
1168installsiteman3dir: 489
1169installvendorman1dir: 489
1170installvendorman3dir: 489
1171d_flexfnam: 474
1172eunicefix: 360
1173d_link: 347
1174installsitearch: 344
1175installscript: 341
1176installprivlib: 337
1177binexp: 336
1178installarchlib: 336
1179installprefixexp: 336
1180installsitelib: 336
1181installstyle: 336
1182installvendorarch: 336
1183installvendorbin: 336
1184installvendorlib: 336
1185man1ext: 336
1186man3ext: 336
1187sh: 336
1188siteprefixexp: 336
1189installbin: 335
1190usedl: 332
1191ccflags: 285
1192startperl: 232
1193optimize: 231
1194usemymalloc: 229
1195cpprun: 228
1196sharpbang: 228
1197perllibs: 225
1198usesfio: 224
1199usethreads: 220
1200perlpath: 218
1201extensions: 217
1202usesocks: 208
1203shellflags: 198
1204make: 191
1205d_pwage: 189
1206d_pwchange: 189
1207d_pwclass: 189
1208d_pwcomment: 189
1209d_pwexpire: 189
1210d_pwgecos: 189
1211d_pwpasswd: 189
1212d_pwquota: 189
1213gccversion: 189
1214libs: 186
1215useshrplib: 186
1216cppflags: 185
1217ptrsize: 185
1218shrpenv: 185
1219static_ext: 185
1220use5005threads: 185
1221uselargefiles: 185
1222alignbytes: 184
1223byteorder: 184
1224ccversion: 184
1225config_args: 184
1226cppminus: 184