From 78e17a0db3a9d113a6957482245926373dc50f9b Mon Sep 17 00:00:00 2001 From: Robin Jarry Date: Sun, 17 Sep 2023 21:20:55 +0200 Subject: contrib: add script to check man pages consistency Add a new shell script to check that all commands are documented in man pages and that the man pages do not contain non-existent commands. Also check that all explicitly parsed options with ini reflection are documented as well. It is not possible to check if the man pages do reference non-existent options since some of the options are parsed lazily in workers and some of them are also declared with placeholders (e.g. *column-*). Run the script in the lint target. Signed-off-by: Robin Jarry Tested-by: Bence Ferdinandy --- contrib/check-docs | 59 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100755 contrib/check-docs (limited to 'contrib/check-docs') diff --git a/contrib/check-docs b/contrib/check-docs new file mode 100755 index 00000000..b92ca3c0 --- /dev/null +++ b/contrib/check-docs @@ -0,0 +1,59 @@ +#!/bin/sh + +tmp=$(mktemp) +trap "rm -f $tmp" EXIT + +global_fail=0 + +cmd_scd_sed='s/^\*:([a-z][a-z-]*)\*.*/\1/p' +cmd_go_sed='/^func ([[:alnum:]]\+) Aliases() \[\]string {$/{n; s/", "/ /g; s/.*return \[\]string{"\(.*\)"}/\1/p}' + +fail=0 +sed -nre "$cmd_scd_sed" doc/*.scd > "$tmp" +for f in $(find commands -type f -name '*.go'); do + for cmd in $(sed -ne "$cmd_go_sed" "$f"); do + if ! grep -qFx "$cmd" "$tmp"; then + grep -HnF --color "\"$cmd\"" "$f" + fail=$((fail+1)) + fi + done +done + +if [ "$fail" -gt 0 ]; then + echo "error: $fail command(s) not documented in man pages" >&2 + global_fail=1 +fi + +fail=0 +sed -ne "$cmd_go_sed" $(find commands -type f -name '*.go') | tr ' ' '\n' > "$tmp" +for f in doc/*.scd; do + for cmd in $(sed -nre "$cmd_scd_sed" "$f"); do + if ! grep -qFx "$cmd" "$tmp"; then + grep -Hn --color "^\\*:$cmd\\*" "$f" + fail=$((fail+1)) + fi + done +done + +if [ "$fail" -gt 0 ]; then + echo "error: $fail non-existent command(s) documented in man pages" >&2 + global_fail=1 +fi + +fail=0 +sed -nre 's/^\*([a-z][a-z-]*)\* = .*/\1/p' doc/*.scd > "$tmp" +for f in $(find config -type f -name '*.go'); do + for opt in $(sed -nre 's/.*`ini:"([a-z][a-z-]*)".*/\1/p' $f); do + if ! grep -qFx "$opt" "$tmp"; then + grep -HnF --color "\"$opt\"" "$f" + fail=$((fail+1)) + fi + done +done + +if [ "$fail" -gt 0 ]; then + echo "error: $fail option(s) not documented in man pages" >&2 + global_fail=1 +fi + +exit $global_fail -- cgit