-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpre-commit.sh
executable file
·93 lines (70 loc) · 2.08 KB
/
pre-commit.sh
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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#!/bin/bash
# SPDX-License-Identifier: GPL-3.0-or-later
INPUT_SEVERITY="style"
for opt
do
case "$opt" in
-S=*|--severity=*)
INPUT_SEVERITY="${opt#*=}"
shift
;;
-S|--severity)
# shellcheck disable=SC2034
INPUT_SEVERITY="$2"
# shellcheck disable=SC2016
shift 2 || { echo 'option `--severity` requires an argument SEVERITY' >&2; exit 1; }
;;
-x|--external-sources)
# shellcheck disable=SC2034
INPUT_EXTERNAL_SOURCES=y
shift
;;
--sarif)
INPUT_WRITE_SARIF=y
shift
;;
esac
done
export SHELLCHECK_OPTS=("$@")
SCRIPT_DIR="$(dirname "$(readlink -f "$0")")/"
export SCRIPT_DIR
. "${SCRIPT_DIR-}functions.sh"
WORK_DIR="$(mktemp -d)/"
export WORK_DIR
# get changed files
git diff --name-only -z --diff-filter=db --cached > "${WORK_DIR}changed-files.txt"
only_changed_scripts=()
get_scripts_for_scanning "${WORK_DIR}changed-files.txt" "only_changed_scripts"
echo -e "${VERSIONS_HEADING}"
show_versions
echo -e "${MAIN_HEADING}"
echo -e "::group::📜 ${WHITE}List of shell scripts for scanning${NOCOLOR}"
echo "${only_changed_scripts[@]}"
echo "::endgroup::"
echo
# ------------ #
# SHELLCHECK #
# ------------ #
exit_status=0
execute_shellcheck "${SHELLCHECK_OPTS[@]}" "${only_changed_scripts[@]}" > "${WORK_DIR}head-shellcheck.err"
git stash >/dev/null
execute_shellcheck "${SHELLCHECK_OPTS[@]}" "${only_changed_scripts[@]}" > "${WORK_DIR}base-shellcheck.err"
git stash apply --index >/dev/null
get_fixes "${WORK_DIR}base-shellcheck.err" "${WORK_DIR}head-shellcheck.err"
evaluate_and_print_fixes
get_defects "${WORK_DIR}head-shellcheck.err" "${WORK_DIR}base-shellcheck.err"
echo
evaluate_and_print_defects
exit_status=$?
if is_true "${INPUT_WRITE_SARIF}"; then
shellcheck_version=$(get_shellcheck_version)
csgrep \
--strip-path-prefix './' \
--mode=sarif \
--set-scan-prop='tool:ShellCheck' \
--set-scan-prop="tool-version:${shellcheck_version}" \
--set-scan-prop='tool-url:https://www.shellcheck.net/wiki/' \
"${WORK_DIR}defects.log" > output.sarif
fi
summary
exit ${exit_status}