diff options
author | J William Piggott | 2015-01-12 20:26:06 +0100 |
---|---|---|
committer | J William Piggott | 2015-01-13 17:43:45 +0100 |
commit | d1fd99e8e0d874c3059d085d8d5871f763a40939 (patch) | |
tree | fcf397035422bf74ac8af2c96abfe4784ee4b2af /tools | |
parent | build-sys: add sfdisk.static (diff) | |
download | kernel-qcow2-util-linux-d1fd99e8e0d874c3059d085d8d5871f763a40939.tar.gz kernel-qcow2-util-linux-d1fd99e8e0d874c3059d085d8d5871f763a40939.tar.xz kernel-qcow2-util-linux-d1fd99e8e0d874c3059d085d8d5871f763a40939.zip |
tools: checkman.sh portability
checkman.sh fails if 'git' or 'lib' are
anywhere in the tested file's path:
Change to using relative paths.
Improve the 'find' command call.
checkman.sh depends upon the man-db package:
Remove all instants of the man command and
use troff directly to improve portability.
Signed-off-by: J William Piggott <elseifthen@gmx.com>
Diffstat (limited to 'tools')
-rwxr-xr-x | tools/checkmans.sh | 26 |
1 files changed, 12 insertions, 14 deletions
diff --git a/tools/checkmans.sh b/tools/checkmans.sh index bc3ba8ff8..6b80853cc 100755 --- a/tools/checkmans.sh +++ b/tools/checkmans.sh @@ -39,10 +39,6 @@ while getopts vVh OPTIONS; do esac done -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 @@ -68,9 +64,10 @@ remove_repeats() set -u } +cd $(git rev-parse --show-toplevel) + for I in $( - find $(git rev-parse --show-toplevel) -name '*.[1-8]' | - egrep -v '(Documentation|.git|/.libs/|autom4te.cache)' + find -path './autom4te.cache' -prune -o -name '*[[:alpha:]].[1-8]' -print ); do MAN_FILE=${I##*/} MAN_LIST[${MAN_FILE%%.[0-9]}]=1 @@ -78,7 +75,7 @@ for I in $( # Some manuals, such as x86_64, call inclusion and they # should not be tested any further. if ${VERBOSE}; then - printf "skipping: ${I##*util-linux/}: includes " + printf "skipping: ${I}: includes " awk '{print $2}' ${I} fi continue @@ -87,16 +84,17 @@ for I in $( if ${VERBOSE}; then echo "testing: ${I}" fi - MANWIDTH=80 man --warnings=all ${I} >/dev/null 2>| ${ERROR_FILE} - if [ -s ${ERROR_FILE} ]; then - echo "error: run: man --warnings=all ${I##*util-linux/} >/dev/null" >&2 - I_ERR=1 + RET=1 + cat ${I} | troff -mandoc -ww -z |& grep "<" && RET=$? + if [ $RET = 0 ]; then + echo "From: cat ${I} | troff -mandoc -ww -z" + echo "==================================================" fi if ! lexgrog ${I} >/dev/null; then - echo "error: run: lexgrog ${I##*util-linux/}" >&2 + echo "error: run: lexgrog ${I}" >&2 I_ERR=1 fi - REPEATS=( $(MANWIDTH=2000 man -l ${I} | + REPEATS=( $(cat ${I} | troff -mandoc -ww -Tascii | grotty | col -b | sed -e 's/\s\+/\n/g; /^$/d' | awk 'BEGIN { p="" } { if (0 < length($0)) { if (p == $0) { print } } p = $0 }') ) @@ -109,7 +107,7 @@ for I in $( let ITER=${ITER}-1 || true done if [ 0 -lt "${#REPEATS[@]}" ]; then - echo "warning: ${I##*util-linux/} has repeating words: ${REPEATS[@]}" + echo "warning: ${I} has repeating words: ${REPEATS[@]}" fi fi # The 'let' may cause exit on error. |