diff options
author | Thomas Haller <thaller@redhat.com> | 2018-10-25 08:55:08 +0200 |
---|---|---|
committer | Thomas Haller <thaller@redhat.com> | 2018-10-25 09:40:53 +0200 |
commit | 7a59cd274485e4c0345c563d48e516967630d7f0 (patch) | |
tree | ecc51130fa3215c8f02a48af1556a704f2786e95 /tools | |
parent | e11ee4582aad43d3bcc8a2ba9eaf9f14e976075a (diff) | |
download | NetworkManager-7a59cd274485e4c0345c563d48e516967630d7f0.tar.gz |
docs: rework check-docs test script
Try to make check-docs.sh script more readable.
Also, previously the script would check that one side was a subset
of the other side. Tighten this check up, now both sides of the
comparison must agree and yield the same lines.
Diffstat (limited to 'tools')
-rwxr-xr-x | tools/check-docs.sh | 54 |
1 files changed, 40 insertions, 14 deletions
diff --git a/tools/check-docs.sh b/tools/check-docs.sh index 1d49209757..b7623fed88 100755 --- a/tools/check-docs.sh +++ b/tools/check-docs.sh @@ -1,22 +1,48 @@ -#!/bin/sh +#!/bin/bash -SOURCEDIR=$1 +set -e + +die() { + printf '%s\n' "$@" >&2 + exit 1 +} + +word_regex() { + tr '\n|<>\\' ' ' \ + | sed -e 's, *$,\\>,' \ + -e 's,^ *,\\<,' \ + -e 's, \+,\\>\\|\\<,g' +} + +same_lines() { + diff <(printf "%s\n" "$1" | sed '/^$/d' | sort) \ + <(printf "%s\n%s\n" "$2" "$3" | sed '/^$/d' | sort) >&2 +} + +SOURCEDIR="$1" [ -n "$SOURCEDIR" ] && SOURCEDIR="$SOURCEDIR/" # Check that the D-Bus API docs contain all known interfaces -if (sed -n 's/.*<xi:include href="dbus-\(.*\.xml\)".*/\1\n\1/p' $SOURCEDIR''docs/api/network-manager-docs.xml; - cd $SOURCEDIR''introspection; ls *.xml) |sort |uniq -u| grep . >&2; then - echo "*** Error: D-Bus interfaces not included in docs/api/network-manager-docs.xml ***" >&2 - exit 1 +F1="$(sed -n 's,^ <xi:include href="dbus-\([^"]*\.xml\)"/>$,\1,p' "$SOURCEDIR"docs/api/network-manager-docs.xml)" +F2="$(cd "$SOURCEDIR"introspection; ls -1 *.xml)" +if ! same_lines "$F1" "$F2" ; then + die "*** Error: D-Bus interfaces not included in docs/api/network-manager-docs.xml ***" fi # Check that files that define types that are in public libnm API are included in libnm documentation. -# Don't complain about readability or I'll rewrite this in Perl. -if (sed -n 's/.*<xi:include href="\(xml\/.*\.xml\)".*/\1\n\1/p' $SOURCEDIR''docs/libnm/libnm-docs.xml; - grep -lE "$(sed -n 's/^[\t ]*\(.*_get_type\);/\1/p' $SOURCEDIR''libnm/libnm.ver |xargs echo |sed 's/ /|/g')" $SOURCEDIR''libnm/*.h $SOURCEDIR''libnm-core/*.h | - sed 's,.*/,xml/,;s/\.h$/.xml/') |sort |uniq -u| grep . >&2; then - echo "*** Error: libnm classes not included in docs/libnm/libnm-docs.xml ***" >&2 - exit 1 +F1="$(sed -n 's/.*<xi:include href="xml\/\([^"]*\)\.xml".*/\1/p' "$SOURCEDIR"docs/libnm/libnm-docs.xml)" +F2="$(grep -l "$(sed -n 's/^[\t ]*\(.*_get_type\);/\1/p' "$SOURCEDIR"libnm/libnm.ver | word_regex)" \ + "$SOURCEDIR"libnm/*.h \ + "$SOURCEDIR"libnm-core/*.h \ + | sed 's,.*/\([^/]\+\)\.h$,\1,')" +F2_EXTRA=" +annotation-glossary +api-index-full +nm-dbus-interface +nm-errors +nm-utils +nm-version +" +if ! same_lines "$F1" "$F2" "$F2_EXTRA"; then + die "*** Error: libnm classes not included in docs/libnm/libnm-docs.xml ***" fi - -exit 0 |