1#!/bin/bash 2 3CHECKPATCH="${CHECKPATCH:-checkpatch.pl}" 4# checkpatch.pl will ignore the following paths 5CHECKPATCH_IGNORE=$(echo \ 6 core/include/gen-asm-defines.h \ 7 core/lib/lib{fdt,tomcrypt} core/lib/zlib \ 8 lib/libutils lib/libmbedtls \ 9 core/arch/arm/include/arm{32,64}.h \ 10 core/arch/arm/plat-ti/api_monitor_index_a{9,15}.h \ 11 core/arch/arm/dts) 12_CP_EXCL=$(for p in $CHECKPATCH_IGNORE; do echo ":(exclude)$p" ; done) 13 14function _checkpatch() { 15 # Use --typedefsfile if supported by the checkpatch tool 16 typedefs_opt="--typedefsfile typedefs.checkpatch" 17 $CHECKPATCH --help 2>&1 | grep -q -- --typedefsfile || \ 18 typedefs_opt=""; 19 # Ignore NOT_UNIFIED_DIFF in case patch has no diff 20 # (e.g., all paths filtered out) 21 $CHECKPATCH --quiet --ignore FILE_PATH_CHANGES \ 22 --ignore GERRIT_CHANGE_ID \ 23 --ignore NOT_UNIFIED_DIFF \ 24 --ignore CAMELCASE \ 25 --ignore PREFER_KERNEL_TYPES \ 26 --ignore CONCATENATED_STRING \ 27 --no-tree \ 28 --strict \ 29 $typedefs_opt \ 30 - 31} 32 33function checkpatch() { 34 git show --oneline --no-patch $1 35 # The first git 'format-patch' shows the commit message 36 # The second one produces the diff (might be empty if _CP_EXCL 37 # filters out all diffs) 38 (git format-patch $1^..$1 --stdout | sed -n '/^diff --git/q;p'; \ 39 git format-patch $1^..$1 --stdout -- $_CP_EXCL . | \ 40 sed -n '/^diff --git/,$p') | _checkpatch 41} 42 43function checkstaging() { 44 git diff --cached -- . $_CP_EXCL | _checkpatch 45} 46 47function checkworking() { 48 git diff -- . $_CP_EXCL | _checkpatch 49} 50 51function checkdiff() { 52 git diff $1...$2 -- . $_CP_EXCL | _checkpatch 53} 54 55