forked from OP-TEE/optee_os
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcheckpatch_inc.sh
50 lines (43 loc) · 1.52 KB
/
checkpatch_inc.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
#!/bin/bash
CHECKPATCH="${CHECKPATCH:-checkpatch.pl}"
CHECKPATCH_OPT="${CHECKPATCH_OPT:-}"
# checkpatch.pl will ignore the following paths
CHECKPATCH_IGNORE=$(echo \
core/include/gen-asm-defines.h \
core/lib/lib{fdt,tomcrypt} core/lib/zlib \
lib/libutils lib/libmbedtls \
lib/libutee/include/elf.h \
lib/libutee/include/elf_common.h \
core/arch/arm/include/arm{32,64}.h \
core/arch/arm/plat-ti/api_monitor_index_a{9,15}.h \
core/arch/arm/dts \
ta/pkcs11/scripts/verify-helpers.sh \
core/arch/riscv/include/encoding.h )
_CP_EXCL=$(for p in $CHECKPATCH_IGNORE; do echo ":(exclude)$p" ; done)
function _checkpatch() {
# Use --typedefsfile if supported by the checkpatch tool
typedefs_opt="--typedefsfile typedefs.checkpatch"
$CHECKPATCH --help 2>&1 | grep -q -- --typedefsfile || \
typedefs_opt="";
# Ignore NOT_UNIFIED_DIFF in case patch has no diff
# (e.g., all paths filtered out)
$CHECKPATCH $CHECKPATCH_OPT $typedefs_opt -
}
function checkpatch() {
git show --oneline --no-patch $1
# The first git 'format-patch' shows the commit message
# The second one produces the diff (might be empty if _CP_EXCL
# filters out all diffs)
(git format-patch $1^..$1 --stdout | sed -n '/^diff --git/q;p'; \
git format-patch $1^..$1 --stdout -- $_CP_EXCL . | \
sed -n '/^diff --git/,$p') | _checkpatch
}
function checkstaging() {
git diff --cached -- . $_CP_EXCL | _checkpatch
}
function checkworking() {
git diff -- . $_CP_EXCL | _checkpatch
}
function checkdiff() {
git diff $1...$2 -- . $_CP_EXCL | _checkpatch
}