56549a0195
Follow-up to #55785. In `black_format.sh`, the `--exclude` switch was wrongly used. It's a misnomer that only excludes _untracked_ files, arcane pathspec patterns should instead be used to exclude _tracked_ files. Using this newfound knowledge, we can also simplify the other scripts.
39 lines
1.4 KiB
Bash
Executable file
39 lines
1.4 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
|
|
# This script runs clang-format and fixes copyright headers on all relevant files in the repo.
|
|
# This is the primary script responsible for fixing style violations.
|
|
|
|
set -uo pipefail
|
|
|
|
# Loops through all code files tracked by Git.
|
|
git ls-files -- '*.c' '*.h' '*.cpp' '*.hpp' '*.cc' '*.hh' '*.cxx' '*.m' '*.mm' '*.inc' '*.java' '*.glsl' \
|
|
':!:.git/*' ':!:thirdparty/*' ':!:platform/android/java/lib/src/com/google/*' ':!:*-so_wrap.*' |
|
|
while read -r f; do
|
|
# Run clang-format.
|
|
clang-format --Wno-error=unknown -i "$f"
|
|
|
|
# Fix copyright headers, but not all files get them.
|
|
if [[ "$f" == *"inc" ]]; then
|
|
continue
|
|
elif [[ "$f" == *"glsl" ]]; then
|
|
continue
|
|
elif [[ "$f" == "platform/android/java/lib/src/org/godotengine/godot/input/InputManager"* ]]; then
|
|
continue
|
|
fi
|
|
|
|
python misc/scripts/copyright_headers.py "$f"
|
|
done
|
|
|
|
diff=$(git diff --color)
|
|
|
|
# If no patch has been generated all is OK, clean up, and exit.
|
|
if [ -z "$diff" ] ; then
|
|
printf "Files in this commit comply with the clang-tidy style rules.\n"
|
|
exit 0
|
|
fi
|
|
|
|
# A patch has been created, notify the user, clean up, and exit.
|
|
printf "\n*** The following changes have been made to comply with the formatting rules:\n\n"
|
|
echo "$diff"
|
|
printf "\n*** Please fix your commit(s) with 'git commit --amend' or 'git rebase -i <hash>'\n"
|
|
exit 1
|