Add pre-commit check for clang-format

This pre-commit script will deny commits that are not properly clang
formatted. This helps save cycles when dealing with kokoro's style
presubmit check.

Bug: b/187094215
Change-Id: I666de1cc861b31550eeb944c0736b5b82808daab
diff --git a/pre-commit b/pre-commit
new file mode 100755
index 0000000..b083f5b
--- /dev/null
+++ b/pre-commit
@@ -0,0 +1,48 @@
+if [ -x /usr/lib/git-core/google_hook ]; then
+  /usr/lib/git-core/google_hook pre-commit "$@"
+  echo 'warning: Cannot run /usr/lib/git-core/google_hook.' \
+    'If this is unexpected, please file a go/git-bug' >&2
+# Make a temporary directory
+TMPDIR=$(mktemp -d -t gcp-$(date +%Y-%m-%d-%H-%M-%S)-XXXXXXXXXX)
+diffFile=$(mktemp gpc-XXXXXXXXX --tmpdir=$TMPDIR)
+# Get every file that's been added, changed, or modified in the current index
+# except for shell scripts.
+FILES=$(git diff --cached --name-only --diff-filter=ACM | grep -v '\.sh')
+# Checkout a copy of current index into TMPDIR. This is necessary so that we
+# only read the versions of files that are being committed, and not any changes
+# to those files that haven't been added yet.
+git checkout-index --prefix=$TMPDIR/ -af
+# Everything else will now happen in TMPDIR
+# Go through each file and test if clang-format modifies the file
+for FILE in $FILES
+    tmpfile=$(mktemp gpc-XXXXXXXXX --tmpdir=$TMPDIR)
+    clang-format --style=file $FULLFILE > "$tmpfile"
+    diff "$FULLFILE" "$tmpfile" > "$diffFile"
+    if [ -s "$diffFile" ]
+    then
+        echo "$FILE"
+        pass=0
+    fi
+    rm "$tmpfile"
+rm "$diffFile"
+rm -rf "$TMPDIR"
+if [ "$pass" != 1 ]
+    echo "Please run src/ to correct the above files"
+    exit 1