2019-06-11 21:33:29 +08:00
|
|
|
#!/usr/bin/env perl
|
|
|
|
#***************************************************************************
|
|
|
|
# _ _ ____ _
|
|
|
|
# Project ___| | | | _ \| |
|
|
|
|
# / __| | | | |_) | |
|
|
|
|
# | (__| |_| | _ <| |___
|
|
|
|
# \___|\___/|_| \_\_____|
|
|
|
|
#
|
2022-02-04 21:46:29 +08:00
|
|
|
# Copyright (C) 2010 - 2022, Daniel Stenberg, <daniel@haxx.se>, et al.
|
2019-06-11 21:33:29 +08:00
|
|
|
#
|
|
|
|
# This software is licensed as described in the file COPYING, which
|
|
|
|
# you should have received as part of this distribution. The terms
|
2020-11-04 21:02:01 +08:00
|
|
|
# are also available at https://curl.se/docs/copyright.html.
|
2019-06-11 21:33:29 +08:00
|
|
|
#
|
|
|
|
# You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
|
|
|
# copies of the Software, and permit persons to whom the Software is
|
|
|
|
# furnished to do so, under the terms of the COPYING file.
|
|
|
|
#
|
|
|
|
# This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
# KIND, either express or implied.
|
|
|
|
#
|
|
|
|
# SPDX-License-Identifier: curl
|
2022-05-17 17:16:50 +08:00
|
|
|
#
|
2019-06-11 21:33:29 +08:00
|
|
|
###########################################################################
|
|
|
|
#
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
|
|
|
|
# the DISABLE options that can be set by configure
|
|
|
|
my %disable;
|
|
|
|
# the DISABLE options that are used in C files
|
|
|
|
my %file;
|
2019-11-12 00:16:04 +08:00
|
|
|
# the DISABLE options that are documented
|
|
|
|
my %docs;
|
2019-06-11 21:33:29 +08:00
|
|
|
|
|
|
|
# we may get the dir root pointed out
|
|
|
|
my $root=$ARGV[0] || ".";
|
2019-11-12 00:16:04 +08:00
|
|
|
my $DOCS="CURL-DISABLE.md";
|
2019-06-11 21:33:29 +08:00
|
|
|
|
2021-04-15 18:11:41 +08:00
|
|
|
sub scanconf {
|
|
|
|
my ($f)=@_;
|
|
|
|
open S, "<$f";
|
2019-06-11 21:33:29 +08:00
|
|
|
while(<S>) {
|
|
|
|
if(/(CURL_DISABLE_[A-Z_]+)/g) {
|
|
|
|
my ($sym)=($1);
|
|
|
|
$disable{$sym} = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
close S;
|
|
|
|
}
|
|
|
|
|
2021-04-15 18:11:41 +08:00
|
|
|
sub scan_configure {
|
|
|
|
opendir(my $m, "$root/m4") || die "Can't opendir $root/m4: $!";
|
|
|
|
my @m4 = grep { /\.m4$/ } readdir($m);
|
|
|
|
closedir $m;
|
|
|
|
scanconf("$root/configure.ac");
|
|
|
|
# scan all m4 files too
|
|
|
|
for my $e (@m4) {
|
|
|
|
scanconf("$root/m4/$e");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-06-11 21:33:29 +08:00
|
|
|
sub scan_file {
|
|
|
|
my ($source)=@_;
|
|
|
|
open F, "<$source";
|
|
|
|
while(<F>) {
|
2022-02-04 21:46:29 +08:00
|
|
|
while(s/(CURL_DISABLE_[A-Z_]+)//) {
|
2019-06-11 21:33:29 +08:00
|
|
|
my ($sym)=($1);
|
|
|
|
$file{$sym} = $source;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
close F;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub scan_dir {
|
|
|
|
my ($dir)=@_;
|
|
|
|
opendir(my $dh, $dir) || die "Can't opendir $dir: $!";
|
2021-03-29 05:12:23 +08:00
|
|
|
my @cfiles = grep { /\.[ch]\z/ && -f "$dir/$_" } readdir($dh);
|
2019-06-11 21:33:29 +08:00
|
|
|
closedir $dh;
|
|
|
|
for my $f (sort @cfiles) {
|
|
|
|
scan_file("$dir/$f");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sub scan_sources {
|
|
|
|
scan_dir("$root/src");
|
|
|
|
scan_dir("$root/lib");
|
|
|
|
scan_dir("$root/lib/vtls");
|
|
|
|
scan_dir("$root/lib/vauth");
|
|
|
|
}
|
|
|
|
|
2019-11-12 00:16:04 +08:00
|
|
|
sub scan_docs {
|
|
|
|
open F, "<$root/docs/$DOCS";
|
|
|
|
my $line = 0;
|
|
|
|
while(<F>) {
|
|
|
|
$line++;
|
2022-09-21 05:30:19 +08:00
|
|
|
if(/^## `(CURL_DISABLE_[A-Z_]+)/g) {
|
2019-11-12 00:16:04 +08:00
|
|
|
my ($sym)=($1);
|
|
|
|
$docs{$sym} = $line;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
close F;
|
|
|
|
}
|
|
|
|
|
2019-06-11 21:33:29 +08:00
|
|
|
scan_configure();
|
|
|
|
scan_sources();
|
2019-11-12 00:16:04 +08:00
|
|
|
scan_docs();
|
2019-06-11 21:33:29 +08:00
|
|
|
|
|
|
|
|
|
|
|
my $error = 0;
|
|
|
|
# Check the configure symbols for use in code
|
|
|
|
for my $s (sort keys %disable) {
|
|
|
|
if(!$file{$s}) {
|
|
|
|
printf "Present in configure.ac, not used by code: %s\n", $s;
|
|
|
|
$error++;
|
|
|
|
}
|
2019-11-12 00:16:04 +08:00
|
|
|
if(!$docs{$s}) {
|
|
|
|
printf "Present in configure.ac, not documented in $DOCS: %s\n", $s;
|
|
|
|
$error++;
|
|
|
|
}
|
2019-06-11 21:33:29 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
# Check the code symbols for use in configure
|
|
|
|
for my $s (sort keys %file) {
|
|
|
|
if(!$disable{$s}) {
|
|
|
|
printf "Not set by configure: %s (%s)\n", $s, $file{$s};
|
|
|
|
$error++;
|
|
|
|
}
|
2019-11-12 00:16:04 +08:00
|
|
|
if(!$docs{$s}) {
|
|
|
|
printf "Used in code, not documented in $DOCS: %s\n", $s;
|
|
|
|
$error++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# Check the documented symbols
|
|
|
|
for my $s (sort keys %docs) {
|
|
|
|
if(!$disable{$s}) {
|
|
|
|
printf "Documented but not in configure: %s\n", $s;
|
|
|
|
$error++;
|
|
|
|
}
|
|
|
|
if(!$file{$s}) {
|
|
|
|
printf "Documented, but not used by code: %s\n", $s;
|
|
|
|
$error++;
|
|
|
|
}
|
2019-06-11 21:33:29 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
exit $error;
|