summaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authorSami Kerola2013-04-08 21:32:57 +0200
committerKarel Zak2013-04-09 12:26:48 +0200
commiteb7069693e39301a337c7a720b8f657385a10add (patch)
tree285e8a02cc3595fa2ba40f568bf5f30435b6c398 /tools
parentdocs: remove repeated words [checkmans.sh] (diff)
downloadkernel-qcow2-util-linux-eb7069693e39301a337c7a720b8f657385a10add.tar.gz
kernel-qcow2-util-linux-eb7069693e39301a337c7a720b8f657385a10add.tar.xz
kernel-qcow2-util-linux-eb7069693e39301a337c7a720b8f657385a10add.zip
tools: make checkmans.sh to find missing manuals
Finding missing manuals is loosely based on ideas in man-page-day-1.sh, wrote by Peter Schiffer. CC: Peter Schiffer <pschiffe@redhat.com> Signed-off-by: Sami Kerola <kerolasa@iki.fi>
Diffstat (limited to 'tools')
-rwxr-xr-xtools/checkmans.sh44
1 files changed, 40 insertions, 4 deletions
diff --git a/tools/checkmans.sh b/tools/checkmans.sh
index a987f4122..bc3ba8ff8 100755
--- a/tools/checkmans.sh
+++ b/tools/checkmans.sh
@@ -43,6 +43,9 @@ ERROR_FILE=$(mktemp ${SCRIPT_INVOCATION_SHORT_NAME}.XXXXXXXXXX)
# remove tmp file at exit
trap "rm -f ${ERROR_FILE}" 0
+# Try to find missing manuals matching build targets with manual files.
+declare -A MAN_LIST BIN_LIST
+
COUNT_ERRORS=0
declare -a REPEATS
declare -A KNOWN_REPEATS
@@ -69,11 +72,13 @@ for I in $(
find $(git rev-parse --show-toplevel) -name '*.[1-8]' |
egrep -v '(Documentation|.git|/.libs/|autom4te.cache)'
); do
+ MAN_FILE=${I##*/}
+ MAN_LIST[${MAN_FILE%%.[0-9]}]=1
if awk '{if (1 < NR) {exit 1}; if ($1 ~ /^.so$/) {exit 0}}' ${I}; then
# Some manuals, such as x86_64, call inclusion and they
# should not be tested any further.
if ${VERBOSE}; then
- printf "skipping: ${I}: includes "
+ printf "skipping: ${I##*util-linux/}: includes "
awk '{print $2}' ${I}
fi
continue
@@ -84,11 +89,11 @@ for I in $(
fi
MANWIDTH=80 man --warnings=all ${I} >/dev/null 2>| ${ERROR_FILE}
if [ -s ${ERROR_FILE} ]; then
- echo "error: run: man --warnings=all ${I} >/dev/null" >&2
+ echo "error: run: man --warnings=all ${I##*util-linux/} >/dev/null" >&2
I_ERR=1
fi
if ! lexgrog ${I} >/dev/null; then
- echo "error: run: lexgrog ${I}" >&2
+ echo "error: run: lexgrog ${I##*util-linux/}" >&2
I_ERR=1
fi
REPEATS=( $(MANWIDTH=2000 man -l ${I} |
@@ -104,7 +109,7 @@ for I in $(
let ITER=${ITER}-1 || true
done
if [ 0 -lt "${#REPEATS[@]}" ]; then
- echo "warning: ${I} has repeating words: ${REPEATS[@]}"
+ echo "warning: ${I##*util-linux/} has repeating words: ${REPEATS[@]}"
fi
fi
# The 'let' may cause exit on error.
@@ -113,6 +118,37 @@ for I in $(
let COUNT_ERRORS=$COUNT_ERRORS+$I_ERR || true
done
+# Create a list of build targets.
+for I in $(find $(git rev-parse --show-toplevel) -name 'Make*.am' | xargs awk '
+$1 ~ /_SOURCES/ {
+ if ($1 ~ /^test/ ||
+ $1 ~ /^no(inst|dist)/ ||
+ $1 ~ /^sample/ ||
+ $1 ~ /^BUILT/) {
+ next
+ }
+ sub(/_SOURCES/, "")
+ if ($1 ~ /^lib.*_la/) {
+ next
+ }
+ sub(/_static/, "")
+ gsub(/_/, ".")
+ sub(/switch.root/, "switch_root")
+ sub(/pivot.root/, "pivot_root")
+ print $1
+}'); do
+ BIN_LIST[$I]=1
+done
+
+# Find if build target does not have manual.
+set +u
+for I in ${!BIN_LIST[@]}; do
+ if [ -v ${MAN_LIST[$I]} ]; then
+ echo "warning: ${I} does not have man page"
+ fi
+done
+set -u
+
if [ ${COUNT_ERRORS} -ne 0 ]; then
echo "error: ${SCRIPT_INVOCATION_SHORT_NAME}: ${COUNT_ERRORS} manuals failed" >&2
exit 1