diff options
Diffstat (limited to '')
-rw-r--r-- | t/cppcheck.t | 51 | ||||
-rw-r--r-- | t/cppcheck/cppcheck.supp | 46 |
2 files changed, 97 insertions, 0 deletions
diff --git a/t/cppcheck.t b/t/cppcheck.t new file mode 100644 index 0000000..b02661e --- /dev/null +++ b/t/cppcheck.t @@ -0,0 +1,51 @@ +#!/usr/bin/perl +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see <https://www.gnu.org/licenses/>. + +use strict; +use warnings; + +use Test::More; +use Test::Dpkg qw(:needs); + +test_needs_author(); +test_needs_command('cppcheck'); +test_needs_srcdir_switch(); + +plan tests => 1; + +# XXX: We should add the following to @cppcheck_opts, but then cppcheck emits +# tons of false positives due to not understanding non-returning functions. +# -DLIBDPKG_VOLATILE_API=1 +# -Ilib +my @cppcheck_opts = (qw( + --quiet --force --error-exitcode=2 + --inline-suppr + --std=c99 --std=c++03 + --suppressions-list=t/cppcheck/cppcheck.supp +), ( + '--enable=warning,performance,portability,style', + '--template=\'{file}:{line}: {severity} ({id}): {message}\'' +)); +my $tags = qx(cppcheck @cppcheck_opts . 2>&1); + +# Fixup the output: +chomp $tags; + +my $ok = length $tags == 0; + +ok($ok, 'cppcheck'); +if (not $ok) { + diag($tags); +} diff --git a/t/cppcheck/cppcheck.supp b/t/cppcheck/cppcheck.supp new file mode 100644 index 0000000..a62ae0a --- /dev/null +++ b/t/cppcheck/cppcheck.supp @@ -0,0 +1,46 @@ +// +// Suppression file for cppcheck. +/// + +// We assume that the system has a sane NULL definition. +varFuncNullUB + +// TODO: While perhaps valid there are many to handle right away. +variableScope + +// TODO: While perhaps valid there are many to handle right away. +constParameter + +// TODO: Will fix in 1.22.x. +badBitmaskCheck:lib/dpkg/fields.c +identicalInnerCondition:lib/dpkg/fsys-hash.c +knownConditionTrueFalse:lib/dpkg/tarfn.c + +// Ignore, this is an imported module. +unusedStructMember:lib/compat/obstack.c +nullPointerArithmetic:lib/compat/obstack.c + +// Ignore, the code is used only for its binary artifacts. +uninitMemberVar:*/Dpkg_Shlibs/patterns.cpp + +// BUG: False positive. +unusedStructMember:lib/dpkg/compress.c + +// BUG: False positive, it gets triggered even with -Ilib. +unknownMacro:lib/dpkg/string.h +unknownMacro:utils/*.c + +// BUG: False positive. +syntaxError:lib/dpkg/t/*.c + +// BUG: False positive, does not understand non-returning functors. +nullPointerArithmeticRedundantCheck:lib/dpkg/db-fsys-files.c +nullPointerArithmeticRedundantCheck:lib/dpkg/db-fsys-override.c +nullPointerRedundantCheck:lib/dpkg/db-fsys-override.c +nullPointerRedundantCheck:lib/dpkg/ehandle.c +nullPointerRedundantCheck:src/deb/build.c +nullPointerRedundantCheck:src/main/enquiry.c +nullPointerRedundantCheck:src/main/unpack.c + +// BUG: False positive, due to our local va_copy(). +va_list_usedBeforeStarted:lib/compat/vasprintf.c |