blob: af688c4b0ddfd8dbb9454ddb4e1e12deadf531fa [file] [log] [blame]
Yegor Timoshenkoc2e49412018-10-07 01:58:27 +00001#!/usr/bin/env bash
Tom Hillered6d1e62018-07-21 00:23:17 -04002
3# Creates `./util/README.md` and `./Documentation/Util.md` of description files
4# in `./util` subdirectories
5#
6# Execute from root of project. Example:
Jonathan Neuschäfer05400b72018-12-11 15:49:04 +01007# `util/util_readme/util_readme.sh`
Tom Hillered6d1e62018-07-21 00:23:17 -04008
9UTIL_README_DIR="$(cd "$(dirname "$0")" || exit; pwd -P)"
10UTIL_DIR=$(dirname "$UTIL_README_DIR")
11COREBOOT_ROOT_DIR=$(dirname "$UTIL_DIR")
12DOCMENTATION_DIR="$COREBOOT_ROOT_DIR/Documentation"
Tom Hiller785dee02018-07-26 21:33:35 -040013SUMMARY="_Scripts and programs found in the \`./util\` directory_"
Tom Hillered6d1e62018-07-21 00:23:17 -040014
15DESCRIPTION_FILES=$(find "$UTIL_DIR" -name "description.md" | sort)
16
17echo -n "" > "$UTIL_DIR/README.md"
18echo "# Utilities" > "$DOCMENTATION_DIR/util.md"
Tom Hiller785dee02018-07-26 21:33:35 -040019echo "$SUMMARY" >> "$DOCMENTATION_DIR/util.md"
Tom Hillered6d1e62018-07-21 00:23:17 -040020
21for DESC_FILE in $DESCRIPTION_FILES; do
22 UTIL_NAME=$(echo "$DESC_FILE" | rev | cut -d '/' -f2 | rev)
23 DESC=$(cat "$DESC_FILE")
24
25 if [[ $DESC == "__"${UTIL_NAME}* || $DESC == "__["${UTIL_NAME}* ]]; then
26 DESC="* $DESC"
27 else
28 DESC="* __${UTIL_NAME}__ - $DESC"
29 fi
30
31 # format description to under 72 characters per line and only
32 # breaking on whitespace
33 DESC=$(echo "$DESC" \
34 | tr '\r\n' ' ' \
35 | sed 's/ [*]\+/\n\t\*/g' \
36 | sed 's/ \+/ /g' \
37 | fold -s -w72 \
38 | sed 's/\s*$//')
39
40 echo "$DESC" >> "$UTIL_DIR/README.md"
41 echo "$DESC" >> "$DOCMENTATION_DIR/util.md"
42done