forked from mozilla/moz-git-tools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
pre-commit
executable file
·44 lines (41 loc) · 1.22 KB
/
pre-commit
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
#!/bin/bash
#
# Check that we're not adding any .orig files, and check for trailing
# whitespace.
#
if git rev-parse --verify HEAD >/dev/null 2>&1
then
against=HEAD
else
# Initial commit: diff against an empty tree object
against=4b825dc642cb6eb9a060e54bf8d69288fbee4904
fi
# Check for .orig files added in this commit.
orig_files=$(git diff --cached --name-only --diff-filter=A $against | grep '\.orig$')
if [[ "$orig_files" != "" ]]; then
num_orig_files=$(echo "$orig_files" | wc -l)
if [[ "$num_orig_files" == "1" ]]; then
echo "Error: Attempting to commit .orig file $orig_files."
else
echo "Error: Attempting to commit $num_orig_files .orig files:"
echo
echo "$(echo "$orig_files" | sed -e 's/^/ /')"
fi
echo
echo "If you really want to proceed, commit with --no-verify."
exit 1
fi
# Check for trailing whitespace
if ! git diff-index --check --cached $against --; then
echo
echo "Error: Trailing whitespace in commit."
echo
echo "You can automagically fix trailing whitespace with: "
echo
echo " git commit -a --no-verify -m TEMP"
echo " git rebase --whitespace=fix HEAD^"
echo " git reset HEAD^"
echo
echo "If you really want to proceed, commit with --no-verify."
exit 2
fi