1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-12 09:18:10 +03:00
samba-mirror/docs-xml/scripts/find_missing_doc.pl

63 lines
1.3 KiB
Perl
Executable File

#!/usr/bin/perl
my %doc;
$topdir = (shift @ARGV) or $topdir = ".";
##################################################
# Reading links from manpage
$curdir = $ENV{PWD};
chdir("smbdotconf");
open(IN,"xsltproc --xinclude --param smb.context ALL generate-context.xsl parameters.all.xml|");
while(<IN>) {
if( /<samba:parameter .*?name="([^"]*?)"/g ){
my $name = $1;
$name =~ s/ //g;
$doc{$name} = "NOTFOUND";
}
}
close(IN);
chdir($curdir);
#################################################
# Reading entries from source code
open(SOURCE,"$topdir/param/loadparm.c") or die("Can't open $topdir/param/loadparm.c: $!");
while ($ln = <SOURCE>) {
last if $ln =~ m/^static\ struct\ parm_struct\ parm_table.*/;
} #burn through the preceding lines
while ($ln = <SOURCE>) {
last if $ln =~ m/^\s*\}\;\s*$/;
#pull in the param names only
next if $ln =~ m/.*P_SEPARATOR.*/;
next unless $ln =~ /\s*\.label\s*=\s*\"(.*)\".*/;
my $name = $1;
$name =~ s/ //g;
if($doc{lc($name)}) {
$doc{lc($name)} = "FOUND";
} else {
print "'$name' is not documented\n";
}
}
close SOURCE;
##################################################
# Trying to find missing references
foreach (keys %doc) {
if($doc{$_} cmp "FOUND") {
print "'$_' is documented but is not a configuration option\n";
}
}