diff options
author | cypherpunks <cypherpunks@torproject.org> | 2015-03-11 10:47:13 +0100 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2015-03-14 13:00:06 -0400 |
commit | eeb753e87115a7b19cc7de83c061fa5e599acb81 (patch) | |
tree | d60fc747cbfe9684163092ec9d042e2dca13990a /scripts/maint/checkOptionDocs.pl.in | |
parent | e656a88fad97a813f29f48a92ea9f972122bc3af (diff) | |
download | tor-eeb753e87115a7b19cc7de83c061fa5e599acb81.tar.gz tor-eeb753e87115a7b19cc7de83c061fa5e599acb81.zip |
Make `check-docs` work from out-of-tree builds.
Diffstat (limited to 'scripts/maint/checkOptionDocs.pl.in')
-rw-r--r-- | scripts/maint/checkOptionDocs.pl.in | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/scripts/maint/checkOptionDocs.pl.in b/scripts/maint/checkOptionDocs.pl.in new file mode 100644 index 0000000000..1f53adf099 --- /dev/null +++ b/scripts/maint/checkOptionDocs.pl.in @@ -0,0 +1,69 @@ +#!/usr/bin/perl -w +use strict; + +my %options = (); +my %descOptions = (); +my %torrcSampleOptions = (); +my %manPageOptions = (); + +# Load the canonical list as actually accepted by Tor. +open(F, "@abs_top_builddir@/src/or/tor --list-torrc-options |") or die; +while (<F>) { + next if m!\[notice\] Tor v0\.!; + if (m!^([A-Za-z0-9_]+)!) { + $options{$1} = 1; + } else { + print "Unrecognized output> "; + print; + } +} +close F; + +# Load the contents of torrc.sample +sub loadTorrc { + my ($fname, $options) = @_; + local *F; + open(F, "$fname") or die; + while (<F>) { + next if (m!##+!); + if (m!#([A-Za-z0-9_]+)!) { + $options->{$1} = 1; + } + } + close F; + 0; +} + +loadTorrc("@abs_top_srcdir@/src/config/torrc.sample.in", \%torrcSampleOptions); + +# Try to figure out what's in the man page. + +my $considerNextLine = 0; +open(F, "@abs_top_srcdir@/doc/tor.1.txt") or die; +while (<F>) { + if (m!^(?:\[\[([A-za-z0-9_]+)\]\] *)?\*\*([A-Za-z0-9_]+)\*\*!) { + $manPageOptions{$2} = 1; + print "Missing an anchor: $2\n" unless (defined $1 or $2 eq 'tor'); + } +} +close F; + +# Now, display differences: + +sub subtractHashes { + my ($s, $a, $b) = @_; + my @lst = (); + for my $k (keys %$a) { + push @lst, $k unless (exists $b->{$k}); + } + print "$s: ", join(' ', sort @lst), "\n\n"; + 0; +} + +# subtractHashes("No online docs", \%options, \%descOptions); +# subtractHashes("Orphaned online docs", \%descOptions, \%options); + +subtractHashes("Orphaned in torrc.sample.in", \%torrcSampleOptions, \%options); + +subtractHashes("Not in man page", \%options, \%manPageOptions); +subtractHashes("Orphaned in man page", \%manPageOptions, \%options); |