| #!/usr/bin/env 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} |