doc: Clarify the release process for a first stable
[tor.git] / scripts / maint / checkOptionDocs.pl.in
blob2d4a7884f54dcbb2ee82cb4786af004f955ec7d1
1 #!/usr/bin/perl -w
2 use strict;
4 my %options = ();
5 my %descOptions = ();
6 my %torrcSampleOptions = ();
7 my %manPageOptions = ();
9 # Load the canonical list as actually accepted by Tor.
10 open(F, "@abs_top_builddir@/src/app/tor --list-torrc-options |") or die;
11 while (<F>) {
12 next if m!\[notice\] Tor v0\.!;
13 if (m!^([A-Za-z0-9_]+)!) {
14 $options{$1} = 1;
15 } else {
16 print "Unrecognized output> ";
17 print;
20 close F;
22 # Load the contents of torrc.sample
23 sub loadTorrc {
24 my ($fname, $options) = @_;
25 local *F;
26 open(F, "$fname") or die;
27 while (<F>) {
28 next if (m!##+!);
29 if (m!#([A-Za-z0-9_]+)!) {
30 $options->{$1} = 1;
33 close F;
37 loadTorrc("@abs_top_srcdir@/src/config/torrc.sample.in", \%torrcSampleOptions);
39 # Try to figure out what's in the man page.
41 my $considerNextLine = 0;
42 open(F, "@abs_top_srcdir@/doc/man/tor.1.txt") or die;
43 while (<F>) {
44 if (m!^(?:\[\[([A-za-z0-9_]+)\]\] *)?\*\*([A-Za-z0-9_]+)\*\*!) {
45 $manPageOptions{$2} = 1;
46 print "Missing an anchor: $2\n" unless (defined $1 or $2 eq 'tor');
49 close F;
51 # Now, display differences:
53 sub subtractHashes {
54 my ($s, $a, $b) = @_;
55 my @lst = ();
56 for my $k (keys %$a) {
57 push @lst, $k unless (exists $b->{$k});
59 print "$s: ", join(' ', sort @lst), "\n\n";
63 # subtractHashes("No online docs", \%options, \%descOptions);
64 # subtractHashes("Orphaned online docs", \%descOptions, \%options);
66 subtractHashes("Orphaned in torrc.sample.in", \%torrcSampleOptions, \%options);
68 subtractHashes("Not in man page", \%options, \%manPageOptions);
69 subtractHashes("Orphaned in man page", \%manPageOptions, \%options);