diff options
author | Michele Calgaro <michele.calgaro@yahoo.it> | 2024-01-03 22:42:04 +0900 |
---|---|---|
committer | Michele Calgaro <michele.calgaro@yahoo.it> | 2024-02-09 11:23:03 +0900 |
commit | 5467861028c350bf50be5c0e657785ecce158c5d (patch) | |
tree | 96ec320da82f8d02273c51cb7a8cca8d0eaf4689 /code_format/uncrustify_file | |
parent | 0e60f5c6834eb89dec4c62ab67d0a08a87a2ba77 (diff) | |
download | scripts-5467861028c350bf50be5c0e657785ecce158c5d.tar.gz scripts-5467861028c350bf50be5c0e657785ecce158c5d.zip |
Code format: add client side core scriptsfeat/code-formatting
Signed-off-by: Michele Calgaro <michele.calgaro@yahoo.it>
Diffstat (limited to 'code_format/uncrustify_file')
-rwxr-xr-x | code_format/uncrustify_file | 117 |
1 files changed, 117 insertions, 0 deletions
diff --git a/code_format/uncrustify_file b/code_format/uncrustify_file new file mode 100755 index 0000000..0f2204a --- /dev/null +++ b/code_format/uncrustify_file @@ -0,0 +1,117 @@ +#!/bin/bash + +# +# This script tries to format a single file with uncrustify-trinity +# using the specified configuration file and until there are no +# further changes, up to the maximum number of times specified. +# +# Parameters: +# $1: config file to use +# $2: source file to format +# $3: maximum number of formatting attempts (optional integer - default is 5) +# Use 0 to just validate whether a file adhere to the required code format +# + +# Check uncrustify-trinity location +UNCRUSTIFY_BIN="" +if [ -x "/opt/trinity/bin/uncrustify-trinity" ]; then + UNCRUSTIFY_BIN="/opt/trinity/bin/uncrustify-trinity" +elif [ -x "/usr/bin/uncrustify-trinity" ]; then + UNCRUSTIFY_BIN="/usr/bin/uncrustify-trinity" +elif [ -x "/usr/local/bin/uncrustify-trinity" ]; then + UNCRUSTIFY_BIN="/usr/local/bin/uncrustify-trinity" +fi +if [ "${UNCRUSTIFY_BIN}" = "" ]; then + echo "[UF] --- Unable to find uncrustify-trinity executable. Aborting." + exit 1 +fi + + +# Check config file exists +CFG_FILE=$1 +if [ ! -e "$1" ]; then + echo "[UF] --- Unable to find the specified configuration file [${CFG_FILE}]. Aborting." + exit 2 +fi + +# Check source file exists +SRC_FILE=$2 +if [ ! -e "$2" ]; then + echo "[UF] --- Unable to find the specified source file [${SRC_FILE}]. Aborting." + exit 3 +fi + +# Setup intermediate file names +FMT_SRC_FILE="${SRC_FILE%.*}_uncrusted_src.${SRC_FILE##*.}" +FMT_DST_FILE="${SRC_FILE%.*}_uncrusted_dst.${SRC_FILE##*.}" + +# Validate the number of retries, if specified +NUM_ATTEMPTS=5 # default, if not specified +if [ "$3" != "" ]; then + NUM_ATTEMPTS=$(($3)) + if [ ${NUM_ATTEMPTS} -lt 0 ]; then + echo "[UF] --- The number of attempts [${NUM_ATTEMPTS}] must be zero or more. Aborting." + exit 4 + fi +fi +REAL_NUM_ATTEMPTS=$((${NUM_ATTEMPTS} + 1)) + +# Format file and check for errors +# Each pass formats FMT_SRC_FILE into FMT_DST_FILE. +# If there are no errors, a check for changes is done and +# if there are no changes since the previous pass, the process stops. +# If changes are detected, the process continue with a new pass +# until either there are no more changes of the maximum number of +# attempts has been reached. +# At each new pass, the last FMT_DST_FILE becomes the new FMT_SRC_FILE. +echo "[UF] Processing file ${SRC_FILE}" +cp "${SRC_FILE}" "${FMT_SRC_FILE}" +FINISHED="n" +COUNTER=0 +while [ "${FINISHED}" != "y" -a ${COUNTER} -lt ${REAL_NUM_ATTEMPTS} ]; do + COUNTER=$((${COUNTER} + 1)) + echo "[UF] Pass ${COUNTER}" + ${UNCRUSTIFY_BIN} -c "${CFG_FILE}" -f "$FMT_SRC_FILE" -o "${FMT_DST_FILE}" + RESULT=$? + if [ ! ${RESULT} -eq 0 ]; then + echo "[UF] --- Processing error reported by uncrustify-trinity [error code ${RESULT}]" + rm "${FMT_SRC_FILE}" 2>/dev/null + rm "${FMT_DST_FILE}" 2>/dev/null + exit 5 + fi + # Check for changes + if cmp -s "${FMT_SRC_FILE}" "${FMT_DST_FILE}"; then + # No changes detected + FINISHED="y" + else + # Changes detected, prepare for next pass + mv "${FMT_DST_FILE}" "${FMT_SRC_FILE}" + fi +done + +# If a stable formatted output is achieved within the maximum number +# of attempts allowed, update the source file and exit successfully. +# Otherwise remove all the temporary files and exit with error. +if [ "${FINISHED}" != "y" ]; then + if [ ${NUM_ATTEMPTS} -eq 0 ]; then + echo "[UF] --- Code format verification FAILED." + else + echo "[UF] --- Unable to reach stable formatted code in ${NUM_ATTEMPTS} attempts." + fi + rm "${FMT_SRC_FILE}" 2>/dev/null + rm "${FMT_DST_FILE}" 2>/dev/null + exit 6 +fi + +if [ $COUNTER -gt 1 ]; then + # Only update the file if there were actual changes (COUNTER > 1) + # to avoid updating the modified time unnecessarily + mv "${FMT_DST_FILE}" "${SRC_FILE}" +else + rm "${FMT_DST_FILE}" +fi +rm "${FMT_SRC_FILE}" 2>/dev/null + +if [ ${NUM_ATTEMPTS} -eq 0 ]; then + echo "[UF] Code format verification OK." +fi |