2019-06-11 06:29:10 +02:00
|
|
|
#!/usr/bin/env bash
|
2019-01-21 12:01:52 +01:00
|
|
|
#
|
|
|
|
# To install this script, copy it to .git/hooks/pre-commit in local copy of
|
|
|
|
# tor git repo and make sure it has permission to execute.
|
|
|
|
#
|
|
|
|
# This is pre-commit git hook script that prevents commiting your changeset if
|
2019-08-20 04:21:02 +02:00
|
|
|
# it fails our code formatting, changelog entry formatting, module include
|
2020-07-02 19:54:19 +02:00
|
|
|
# rules, etc...
|
2019-01-21 12:01:52 +01:00
|
|
|
|
2020-07-02 19:47:12 +02:00
|
|
|
# Run only if this environment variable is set.
|
|
|
|
if [ -z "$TOR_EXTRA_PRE_COMMIT_CHECKS" ]; then
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
2019-01-21 12:01:52 +01:00
|
|
|
workdir=$(git rev-parse --show-toplevel)
|
|
|
|
|
|
|
|
cd "$workdir" || exit 1
|
|
|
|
|
2019-02-21 19:35:33 +01:00
|
|
|
set -e
|
2019-01-21 12:01:52 +01:00
|
|
|
|
2019-10-24 05:59:02 +02:00
|
|
|
if [ $# -eq 0 ]; then
|
|
|
|
# When called in pre-commit, check the files modified in this commit
|
|
|
|
CHECK_FILTER="git diff --cached --name-only --diff-filter=ACMR"
|
|
|
|
# Use the appropriate owned tor source list to filter the changed files
|
2020-01-23 16:26:09 +01:00
|
|
|
|
|
|
|
# This is the layout in 0.3.5 and later.
|
|
|
|
|
|
|
|
# Keep these lists consistent:
|
|
|
|
# - OWNED_TOR_C_FILES in Makefile.am
|
|
|
|
# - CHECK_FILES in pre-commit.git-hook and pre-push.git-hook
|
|
|
|
# - try_parse in check_cocci_parse.sh
|
|
|
|
CHECK_FILES="$($CHECK_FILTER \
|
2019-10-24 05:59:02 +02:00
|
|
|
src/lib/*/*.[ch] \
|
|
|
|
src/core/*/*.[ch] \
|
|
|
|
src/feature/*/*.[ch] \
|
|
|
|
src/app/*/*.[ch] \
|
|
|
|
src/test/*.[ch] \
|
|
|
|
src/test/*/*.[ch] \
|
|
|
|
src/tools/*.[ch] \
|
2020-01-23 16:26:09 +01:00
|
|
|
)"
|
2019-10-24 05:59:02 +02:00
|
|
|
else
|
|
|
|
# When called in pre-push, concatenate the argument array
|
|
|
|
# Fails on special characters in file names
|
|
|
|
CHECK_FILES="$*"
|
|
|
|
fi
|
|
|
|
|
|
|
|
## General File Checks
|
|
|
|
|
2019-04-10 17:49:23 +02:00
|
|
|
if [ -n "$(ls ./changes/)" ]; then
|
2019-02-21 19:35:33 +01:00
|
|
|
python scripts/maint/lintChanges.py ./changes/*
|
|
|
|
fi
|
|
|
|
|
2019-10-24 05:59:02 +02:00
|
|
|
if [ -e scripts/maint/checkShellScripts.sh ]; then
|
|
|
|
scripts/maint/checkShellScripts.sh
|
|
|
|
fi
|
|
|
|
|
2019-12-03 04:06:30 +01:00
|
|
|
if [ -e scripts/maint/checkSpaceTest.sh ]; then
|
|
|
|
scripts/maint/checkSpaceTest.sh
|
|
|
|
fi
|
|
|
|
|
2019-10-24 05:59:02 +02:00
|
|
|
if [ ! "$CHECK_FILES" ]; then
|
|
|
|
echo "No modified tor-owned source files, skipping further checks"
|
|
|
|
exit 0
|
2019-02-21 19:35:33 +01:00
|
|
|
fi
|
2019-01-21 12:01:52 +01:00
|
|
|
|
2019-10-24 05:59:02 +02:00
|
|
|
## Owned Source File Checks
|
|
|
|
|
2019-10-28 04:04:29 +01:00
|
|
|
printf "Modified tor-owned source files:\\n%s\\n" "$CHECK_FILES"
|
2019-10-24 05:59:02 +02:00
|
|
|
|
|
|
|
# We want word splitting here, because file names are space separated
|
|
|
|
# shellcheck disable=SC2086
|
|
|
|
perl scripts/maint/checkSpace.pl -C \
|
|
|
|
$CHECK_FILES
|
|
|
|
|
2020-07-02 19:54:19 +02:00
|
|
|
# This makes sure that we are only including things we're allowed to include.
|
2019-08-05 20:11:51 +02:00
|
|
|
if test -e scripts/maint/practracker/includes.py; then
|
|
|
|
python scripts/maint/practracker/includes.py
|
2019-01-24 14:06:09 +01:00
|
|
|
fi
|
2019-04-19 08:46:36 +02:00
|
|
|
|
2019-10-23 07:43:27 +02:00
|
|
|
if [ -e scripts/coccinelle/check_cocci_parse.sh ]; then
|
|
|
|
|
2019-10-24 05:59:02 +02:00
|
|
|
# Run a verbose cocci parse check on the changed files
|
|
|
|
# (spatch is slow, so we don't want to check all the files.)
|
|
|
|
#
|
|
|
|
# We want word splitting here, because file names are space separated
|
|
|
|
# shellcheck disable=SC2086
|
|
|
|
VERBOSE=1 scripts/coccinelle/check_cocci_parse.sh \
|
|
|
|
$CHECK_FILES
|
2019-10-23 07:43:27 +02:00
|
|
|
fi
|