123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145 |
- #!/bin/bash
- #
- # Copyright (c) 2015 Intel Corporation.
- #
- # SPDX-License-Identifier: Apache-2.0
- #
- # crawls the source tree to find out the amount of checkpatch issues
- # and optionally update scripts/known_checkpatch_issues
- # usage: check_known_checkpatch_issues.sh [-u]
- # where: -u updates the known_checkpatch_issues db and commits it
- # -q is the quiet mode (don't display the diff on stdout)
- exe_name=$(basename $0)
- do_checkpatch_bin=${ZEPHYR_BASE}/scripts/checkpatch/do_checkpatch.sh
- timestamp_bin=${ZEPHYR_BASE}/scripts/checkpatch/timestamp
- declare update=n
- declare quiet=n
- function usage {
- printf "usage: %s [-u][-q]\n" ${exe_name} >&2
- }
- function fail {
- usage
- exit -1
- }
- function verify_needed {
- needed="\
- ${do_checkpatch_bin} \
- ${timestamp_bin} \
- "
- for i in ${needed}; do
- type $i &>/dev/null
- if [ $? != 0 ]; then
- printf "need '%s' but not found in PATH\n" $i >&2
- exit -1
- fi
- done
- }
- function get_opts {
- declare -r optstr="quh"
- while getopts ${optstr} opt; do
- case ${opt} in
- u) update=y ;;
- q) quiet=y ;;
- h) usage; exit 0 ;;
- *) fail ;;
- esac
- done
- }
- verify_needed
- get_opts $@
- do_checkpatch=${do_checkpatch_bin}
- timestamp="${timestamp_bin} -u"
- ts=$(${timestamp})
- uid=$(id -u)
- pid=$$
- suffix=${uid}-${pid}-${ts}
- checkpatch_results=/tmp/checkpatch.results-${suffix}
- known_checkpatch_issues=${ZEPHYR_BASE}/scripts/known_checkpatch_issues
- checkpatch_issues=/tmp/checkpatch_issues-${suffix}
- git_log_params="\
- --abbrev=8 \
- --abbrev-commit \
- "
- commit_id_str=$(git log ${git_log_params} HEAD | head -n 1)
- echo ${commit_id_str} > ${checkpatch_issues}
- ${do_checkpatch} ${checkpatch_results} >> ${checkpatch_issues}
- diff_file=/tmp/checkpatch.results.diff-${suffix}
- diff -u ${known_checkpatch_issues} ${checkpatch_issues} > ${diff_file}
- if [ ${quiet} = n ]; then
- cat ${diff_file}
- fi
- # find all lines that starts with '+' but not '+commit' or '+++ diff'
- minuses_err_str=(\
- $(cat ${diff_file} | \
- grep -v -E "^\-\-\-" | grep -v -E "^\-commit " | grep -E "^\-" | \
- awk '{print $1}' | cut -d\- -f 2-) \
- )
- minuses_num_err=(\
- $(cat ${diff_file} | \
- grep -v -E "^\-\-\-" | grep -v -E "^\-commit " | grep -E "^\-" | \
- awk '{print $2}') \
- )
- plusses_err_str=(\
- $(cat ${diff_file} | \
- grep -v -E "^\+\+\+" | grep -v -E "^\+commit " | grep -E "^\+" | \
- awk '{print $1}' | cut -d\+ -f 2-) \
- )
- plusses_num_err=(\
- $(cat ${diff_file} | \
- grep -v -E "^\+\+\+" | grep -v -E "^\+commit " | grep -E "^\+" | \
- awk '{print $2}') \
- )
- exit_code=0
- declare -i num_plusses=${#plusses_num_err[@]}
- declare -i num_minuses=${#minuses_num_err[@]}
- declare -i test_num=${num_plusses}
- while [ ${test_num} -gt 0 ]; do
- test_num+=-1
- match=n
- declare -i i=${num_minuses}
- while [ $i -gt 0 ]; do
- i+=-1
- if [ ${plusses_err_str[${test_num}]} = ${minuses_err_str[$i]} ]; then
- n_minus=${minuses_num_err[$i]}
- n_plus=${plusses_num_err[${test_num}]}
- if [ ${n_plus} -gt ${n_minus} ]; then
- exit_code=1
- break 2
- fi
- match=y
- break 1
- fi
- done
- if [ ${match} = n ]; then
- # there was no match for the plus line, so that is a new error
- exit_code=1
- break 1
- fi
- done
- if [ ${update} = y ]; then
- msg="known_checkpatch_issues: updating to ${commit_id_str}"
- cp ${checkpatch_issues} ${known_checkpatch_issues}
- git add ${known_checkpatch_issues}
- git commit -m "${msg}"
- fi
- exit ${exit_code}
|