summaryrefslogtreecommitdiff
path: root/misc/travis/clang-format.sh
blob: c917744ece48273f2aac6c02df86543a6d6c7a40 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#!/bin/sh

CLANG_FORMAT=clang-format-8

if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then
    # Travis only clones the PR branch and uses its HEAD commit as detached HEAD,
    # so it's problematic when we want an exact commit range for format checks.
    # We fetch upstream to ensure that we have the proper references to resolve.
    # Ideally we would use $TRAVIS_COMMIT_RANGE but it doesn't play well with PR
    # updates, as it only includes changes since the previous state of the PR.
    if [ -z "$(git remote | grep upstream)" ]; then
      git remote add upstream https://github.com/godotengine/godot \
          --no-tags -f -t $TRAVIS_BRANCH
    fi
    RANGE="upstream/$TRAVIS_BRANCH HEAD"
else
    # Test only the last commit, since $TRAVIS_COMMIT_RANGE wouldn't support
    # force pushes.
    RANGE=HEAD
fi

FILES=$(git diff-tree --no-commit-id --name-only -r $RANGE | grep -v thirdparty/ | grep -v platform/android/java/lib/src/com/ | grep -E "\.(c|h|cpp|hpp|cc|hh|cxx|m|mm|inc|java|glsl)$")
echo "Checking files:\n$FILES"

# create a random filename to store our generated patch
prefix="static-check-clang-format"
suffix="$(date +%s)"
patch="/tmp/$prefix-$suffix.patch"

for file in $FILES; do
    "$CLANG_FORMAT" -style=file "$file" | \
        diff -u "$file" - | \
        sed -e "1s|--- |--- a/|" -e "2s|+++ -|+++ b/$file|" >> "$patch"
done

# if no patch has been generated all is ok, clean up the file stub and exit
if [ ! -s "$patch" ] ; then
    printf "Files in this commit comply with the clang-format rules.\n"
    rm -f "$patch"
    exit 0
fi

# a patch has been created, notify the user and exit
printf "\n*** The following differences were found between the code to commit "
printf "and the clang-format rules:\n\n"
pygmentize -l diff "$patch"
printf "\n*** Aborting, please fix your commit(s) with 'git commit --amend' or 'git rebase -i <hash>'\n"
exit 1