From e0023883c6d2e6745a19e4b48e186ed156c1fca8 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 17:19:27 +0200 Subject: Adding upstream version 2.11.2. Signed-off-by: Daniel Baumann --- man/check-man | 46 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100755 man/check-man (limited to 'man/check-man') diff --git a/man/check-man b/man/check-man new file mode 100755 index 0000000..a58b7f9 --- /dev/null +++ b/man/check-man @@ -0,0 +1,46 @@ +#! /bin/sh +set -e + +# Check that a manual page formats without errors. Lintian does something +# similar for Debian packages. Relies on top_builddir, LINGUA, and EGREP +# variables exported from 'make check', or you can set them manually. + +if [ -z "$top_builddir" ]; then + echo "top_builddir unset; try 'make check' instead?" + exit 77 +elif [ -z "$LINGUA" ]; then + echo "LINGUA unset; try 'make check' instead?" + exit 77 +elif [ -z "$EGREP" ]; then + echo "EGREP unset; try 'make check' instead?" + exit 77 +fi + +[ -x "$top_builddir/src/man" ] || exit 77 + +code=0 +errors="$(LC_ALL=C MANWIDTH=80 MAN_KEEP_FORMATTING=1 "$top_builddir/libtool" \ + --mode=execute \ + -dlopen "$top_builddir/lib/.libs/libman.la" \ + -dlopen "$top_builddir/libdb/.libs/libmandb.la" \ + "$top_builddir/src/man" --warnings -E UTF-8 -l "$1" \ + 2>&1 >/dev/null)" || code=$? + +# Ignore wrapping failures for CJK manual pages; this should go away once +# groff supports these natively. +# Indeed, even for other languages we're going to get "cannot adjust line" +# if %manpath_config_file% expands to something long. Hmm. We'll just ignore +# this across the board for now. +errors="$(echo "$errors" | $EGREP -v "(cannot adjust line|can't break line)")" || true + +if [ "$code" != 0 ]; then + echo "man -E UTF-8 -l $1 failed with exit status $code and error output:" + echo "$errors" + exit $code +elif [ "$errors" ]; then + echo "man -E UTF-8 -l $1 produced error output:" + echo "$errors" + exit 1 +else + exit 0 +fi -- cgit v1.2.3