ZAP: Add by_dnode variants to lookup/prefetch_uint64
[zfs.git] / scripts / mancheck.sh
blob364ad1b7628658ac4aba2e8b4254de58cb2aee44
1 #!/bin/sh
3 # Permission to use, copy, modify, and/or distribute this software for
4 # any purpose with or without fee is hereby granted.
6 # THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
7 # WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
8 # MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
9 # ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
10 # WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN
11 # AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
12 # OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
14 # shellcheck disable=SC2086
16 trap 'rm -f "$stdout_file" "$stderr_file" "$result_file"' EXIT
18 if [ "$#" -eq 0 ]; then
19 echo "Usage: $0 manpage-directory..."
20 exit 1
23 if ! command -v mandoc > /dev/null; then
24 echo "skipping mancheck because mandoc is not installed"
25 exit 0
28 IFS="
30 files="$(find "$@" -type f -name '*[1-9]*' -not -name '.*')" || exit 1
32 add_excl="$(awk '
33 /^.\\" lint-ok:/ {
34 print "-e"
35 $1 = "mandoc:"
36 $2 = FILENAME ":[[:digit:]]+:[[:digit:]]+:"
37 print
38 }' $files)"
40 # Redirect to file instead of 2>&1ing because mandoc flushes inconsistently(?) which tears lines
41 # https://github.com/openzfs/zfs/pull/12129/checks?check_run_id=2701608671#step:5:3
42 stdout_file="$(mktemp)"
43 stderr_file="$(mktemp)"
44 mandoc -Tlint $files 1>"$stdout_file" 2>"$stderr_file"
45 result_file="$(mktemp)"
46 grep -vhE -e 'mandoc: outdated mandoc.db' -e 'STYLE: referenced manual not found' $add_excl "$stdout_file" "$stderr_file" > "$result_file"
48 if [ -s "$result_file" ]; then
49 cat "$result_file"
50 exit 1
51 else
52 echo "no errors found"