1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/dist/tools/cppcheck
Neil Jones 65911f3499 cppcheck: Don't Run cppcheck on ASM files.
cppcheck doesn't understand ASM style comments beginning with '#' and tries to
parse them:

I get this error:
 cpu/mips_pic32_common/reset_mod.S:84: error (syntaxError): syntax error
from this line:
 beqz s1, init_resources # Branch if this is NOT an NMI exception.

If I place the comment inside C-style comments cppcheck passes, ie

 beqz s1, init_resources # /*Branch if this is NOT an NMI exception.*/

Note current in-tree ASM files fail cppcheck (they must have been added before
this check) for example:

cpu/lpc2387/asmfunc.s
2017-03-29 15:14:43 +01:00
..
check.sh cppcheck: Don't Run cppcheck on ASM files. 2017-03-29 15:14:43 +01:00
README.md all: remove extra blank lines at the end 2015-05-09 09:10:08 +02:00

About

This is a cppcheck wrapper script with appropriate parameters for checking RIOT. It accepts a branch name as an argument which is used to limit the scope of the check. Other parameters will be passed to cppcheck, so you can further modify its behavior.

Example usage

Check all files changed in the current branch against the branch named 'master':

./dist/tools/cppcheck/check.sh master

Check all files but ignore warnings about unused struct members:

./dist/tools/cppcheck/check.sh --suppress=unassignedVariable

Check all files changed in the current branch against the branch named 'master', ignoring warnings about unassigned variables:

./dist/tools/cppcheck/check.sh master  --suppress=unassignedVariable

Default options

This script suppresses warnings of the type "unusedStructMember" by default. If you want to get warnings about "unusedStructMembers" run the script with the --show-unused-struct option: ./dist/tools/cppcheck/check.sh --show-unused-struct [BRANCH] [options to be passed]

What to do about the findings

You should read the code carefully. While cppcheck certainly produces valuable information, it can also warn about code that is actually OK. If this happens, you can add an "inline suppression" like this:

/* cppcheck-suppress passedByValue */
timex_t timex_add(const timex_t a, const timex_t b);