mirror of
https://github.com/mirror/wget.git
synced 2025-01-28 05:10:35 +08:00
build_info.pl improvements, advertise large-file support.
This commit is contained in:
parent
3648b91197
commit
186ee6d0ff
@ -1,3 +1,11 @@
|
||||
2009-10-09 Micah Cowan <micah@cowan.name>
|
||||
|
||||
* build_aux/build_info.pl: Reworked the input format. Eliminated
|
||||
support, and need, for arbitrary #if blocks. Introduced
|
||||
"choices", and explicitly open the .c file rather than print to
|
||||
STDOUT, so we avoid creating the file if we find problems with
|
||||
the input. Options are advertised in alphabetical order.
|
||||
|
||||
2009-09-24 Micah Cowan <micah@cowan.name>
|
||||
|
||||
* vms/vms.c: Moved to src/src.c.
|
||||
|
@ -20,8 +20,7 @@
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use FindBin qw($Bin);
|
||||
use File::Spec ();
|
||||
use Carp qw(croak);
|
||||
|
||||
my $file = shift @ARGV;
|
||||
|
||||
@ -32,59 +31,92 @@ my $file = shift @ARGV;
|
||||
|
||||
sub parse_config
|
||||
{
|
||||
my (%block, @defines, %feature);
|
||||
my $features = [];
|
||||
my $choice_key;
|
||||
my $choice = [];
|
||||
my $list = $features;
|
||||
|
||||
open(my $fh, '<', "$file.in") or die "Cannot open $file.in: $!";
|
||||
|
||||
while (<$fh>) {
|
||||
next if /^\s*$/;
|
||||
|
||||
if ($list eq $choice) {
|
||||
unless (s/^\s+//) {
|
||||
$list = $features;
|
||||
push @$features, [$choice_key, $choice];
|
||||
$choice = [];
|
||||
undef $choice_key;
|
||||
}
|
||||
} elsif (/^([A-Za-z0-9_-]+) \s+ choice:\s*$/x) {
|
||||
$choice_key = $1;
|
||||
$list = $choice;
|
||||
next;
|
||||
}
|
||||
|
||||
if (/^([A-Za-z0-9_-]+) \s+ (.*)$/x) {
|
||||
push @$list, [$1, $2];
|
||||
} else {
|
||||
croak "Can't parse line: $_";
|
||||
}
|
||||
}
|
||||
|
||||
if ($list eq $choice) {
|
||||
push @$features, [$choice_key, $choice];
|
||||
}
|
||||
|
||||
open(my $fh, '<', $file) or die "Cannot open $file: $!";
|
||||
my $cfg = do { local $/; <$fh> };
|
||||
close($fh);
|
||||
|
||||
while ($cfg =~ /^\ *? (\w+) (?:\s+?)? (\w+?)? \s*$/gmx) {
|
||||
$feature{$1} = $2 || '_MISSING';
|
||||
push @defines, $1;
|
||||
}
|
||||
while ($cfg =~ /^(\ *? \#\w+? \s+? (\w+) .+ \#\w+)/gmsx) {
|
||||
$block{$2} = $1;
|
||||
}
|
||||
|
||||
my %data = (
|
||||
block => \%block,
|
||||
defines => \@defines,
|
||||
feature => \%feature,
|
||||
);
|
||||
|
||||
return \%data;
|
||||
return $features;
|
||||
}
|
||||
|
||||
sub output_code
|
||||
{
|
||||
my ($block, $defines, $feature) =
|
||||
map $_[0]->{$_}, qw(block defines feature);
|
||||
my $features = shift;
|
||||
|
||||
print do { local $/; <DATA> }, "\n";
|
||||
print <<EOC;
|
||||
open(my $fh, '>', "$file") or die "Cannot open $file: $!";
|
||||
|
||||
print $fh do { local $/; <DATA> }, "\n";
|
||||
print $fh <<EOC;
|
||||
const char* (compiled_features[]) =
|
||||
{
|
||||
|
||||
EOC
|
||||
my @output;
|
||||
foreach my $define (@$defines) {
|
||||
if (!exists $block->{$define}) {
|
||||
push @output, <<EOC;
|
||||
#ifdef $define
|
||||
"+$feature->{$define}",
|
||||
#else
|
||||
"-$feature->{$define}",
|
||||
#endif
|
||||
foreach my $feature (sort { $a->[0] cmp $b->[0] } @$features) {
|
||||
my ($name, $check) = @$feature;
|
||||
|
||||
if (ref $check eq 'ARRAY') {
|
||||
my ($ch_name, $ch_check) = @{ shift @$check };
|
||||
print $fh <<EOC;
|
||||
#if $ch_check
|
||||
"+$name/$ch_name",
|
||||
EOC
|
||||
}
|
||||
else {
|
||||
push @output, <<EOC;
|
||||
$block->{$define}
|
||||
foreach my $choice (@$check) {
|
||||
($ch_name, $ch_check) = @$choice;
|
||||
|
||||
print $fh <<EOC;
|
||||
#elif $ch_check
|
||||
"+$name/$ch_name",
|
||||
EOC
|
||||
}
|
||||
print $fh <<EOC;
|
||||
#else
|
||||
"-$name",
|
||||
#endif
|
||||
|
||||
EOC
|
||||
} else {
|
||||
print $fh <<EOC;
|
||||
#if $check
|
||||
"+$name",
|
||||
#else
|
||||
"-$name",
|
||||
#endif
|
||||
|
||||
EOC
|
||||
}
|
||||
}
|
||||
print join "\n", @output;
|
||||
print <<EOC;
|
||||
print $fh <<EOC;
|
||||
|
||||
/* sentinel value */
|
||||
NULL
|
||||
|
@ -1,3 +1,9 @@
|
||||
2009-10-09 Micah Cowan <micah@cowan.name>
|
||||
|
||||
* build_info.c.in: Adapt to new input format. Added a check for
|
||||
large-file support. Replaced the "openssl" and "gnutls"
|
||||
advertisements with a single "ssl/foo" advertisement.
|
||||
|
||||
2009-09-30 Micah Cowan <micah@cowan.name>
|
||||
|
||||
* sysdep.h: Unconditionally include stdbool.h (gnulib has it for
|
||||
|
@ -65,7 +65,7 @@ MD5_LDADD = @MD5_LDADD@
|
||||
|
||||
build_info.c: $(srcdir)/Makefile.am $(srcdir)/build_info.c.in
|
||||
$(PERL) $(top_srcdir)/build-aux/build_info.pl \
|
||||
$(srcdir)/build_info.c.in > $@
|
||||
$(srcdir)/build_info.c
|
||||
|
||||
ESCAPEQUOTE = sed -e 's/[\\"]/\\&/g' -e 's/\\"/"/' -e 's/\\";$$/";/'
|
||||
version.c: $(wget_SOURCES) ../lib/libgnu.a $(MD5_LDADD) \
|
||||
|
@ -1,24 +1,18 @@
|
||||
ENABLE_DIGEST digest
|
||||
ENABLE_IPV6 ipv6
|
||||
ENABLE_NLS nls
|
||||
ENABLE_NTLM ntlm
|
||||
ENABLE_OPIE opie
|
||||
HAVE_MD5
|
||||
HAVE_SSL https
|
||||
HAVE_LIBGNUTLS gnutls
|
||||
HAVE_LIBSSL openssl
|
||||
ENABLE_IRI iri
|
||||
digest defined ENABLE_DIGEST
|
||||
https defined HAVE_SSL
|
||||
ipv6 defined ENABLE_IPV6
|
||||
iri defined ENABLE_IRI
|
||||
large-file SIZEOF_OFF_T >= 8
|
||||
|
||||
#ifdef HAVE_MD5
|
||||
#ifdef HAVE_BUILTIN_MD5
|
||||
"+md5/builtin",
|
||||
#elif HAVE_OPENSSL_MD5
|
||||
"+md5/openssl",
|
||||
#elif HAVE_SOLARIS_MD5
|
||||
"+md5/solaris",
|
||||
#else
|
||||
#error "md5 set, but no library found!",
|
||||
#endif
|
||||
#else
|
||||
"-md5",
|
||||
#endif
|
||||
md5 choice:
|
||||
builtin defined HAVE_BUILTIN_MD5
|
||||
openssl defined HAVE_OPENSSL_MD5
|
||||
solaris defined HAVE_SOLARIS_MD5
|
||||
|
||||
nls defined ENABLE_NLS
|
||||
ntlm defined ENABLE_NTLM
|
||||
opie defined ENABLE_OPIE
|
||||
|
||||
ssl choice:
|
||||
openssl defined HAVE_LIBSSL
|
||||
gnutls defined HAVE_LIBGNUTLS
|
||||
|
Loading…
Reference in New Issue
Block a user