2021-08-01 21:28:25 +02:00
#!/usr/bin/env bash
#
# Copyright (c) 2019 The Bitcoin Core developers
# Distributed under the MIT software license, see the accompanying
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
#
export LC_ALL = C
ENABLED_CHECKS = (
"Class '.*' has a constructor with 1 argument that is not explicit."
"Struct '.*' has a constructor with 1 argument that is not explicit."
"Function parameter '.*' should be passed by const reference."
"Comparison of modulo result is predetermined"
"Local variable '.*' shadows outer argument"
"Redundant initialization for '.*'. The initialized value is overwritten before it is read."
"Dereferencing '.*' after it is deallocated / released"
"The scope of the variable '.*' can be reduced."
"Parameter '.*' can be declared with const"
"Variable '.*' can be declared with const"
"Variable '.*' is assigned a value that is never used."
"Unused variable"
"The function '.*' overrides a function in a base class but is not marked with a 'override' specifier."
# Enabale to catch all warnings
2021-12-28 22:54:50 +01:00
".*"
2021-08-01 21:28:25 +02:00
)
IGNORED_WARNINGS = (
"src/bls/bls.h:.* Struct 'CBLSIdImplicit' has a constructor with 1 argument that is not explicit."
2021-12-28 22:54:50 +01:00
"src/llmq/dkgsessionmgr.h:.* warning: struct member 'ContributionsCacheEntry::entryTime' is never used."
"src/llmq/instantsend.h:.* warning: struct member 'NonLockedTxInfo::pindexMined' is never used."
"src/rpc/masternode.cpp:.*:21: warning: Consider using std::copy algorithm instead of a raw loop." # UniValue doesn't support std::copy
"src/spork.h:.* warning: struct member 'CSporkDef::defaultValue' is never used."
"src/test/dip0020opcodes_tests.cpp:.* warning: There is an unknown macro here somewhere. Configuration is required. If BOOST_FIXTURE_TEST_SUITE is a macro then please configure it."
"src/ctpl_stl.h:.*22: warning: Dereferencing '_f' after it is deallocated / released"
2022-04-16 16:46:04 +02:00
"src/llmq/snapshot.cpp:.*:17: warning: Consider using std::copy algorithm instead of a raw loop."
"src/llmq/snapshot.cpp:.*:18: warning: Consider using std::copy algorithm instead of a raw loop."
2021-08-01 21:28:25 +02:00
# General catchall, for some reason any value named 'hash' is viewed as never used.
"Variable 'hash' is assigned a value that is never used."
# The following can be useful to ignore when the catch all is used
# "Consider performing initialization in initialization list."
2021-12-28 22:54:50 +01:00
"Consider using std::transform algorithm instead of a raw loop."
"Consider using std::accumulate algorithm instead of a raw loop."
2021-08-01 21:28:25 +02:00
# "Consider using std::any_of algorithm instead of a raw loop."
# "Consider using std::count_if algorithm instead of a raw loop."
# "Consider using std::find_if algorithm instead of a raw loop."
2021-12-28 22:54:50 +01:00
# "Member variable '.*' is not initialized in the constructor."
2021-08-01 21:28:25 +02:00
)
# We should attempt to update this with all dash specific code
2021-12-28 22:54:50 +01:00
FILES = $( git ls-files -- "src/batchedlogger.*" \
"src/bench/bls*.cpp" \
"src/bls/*.cpp" \
"src/bls/*.h" \
"src/cachemap.h" \
"src/cachemultimap.h" \
"src/coinjoin/*.cpp" \
"src/coinjoin/*.h" \
"src/ctpl_stl.h" \
"src/cxxtimer.hpp" \
"src/dsnotificationinterface.*" \
"src/evo/*.cpp" \
"src/evo/*.h" \
"src/governance/*.cpp" \
"src/governance/*.h" \
"src/hdchain.*" \
"src/keepass.*" \
"src/llmq/*.cpp" \
"src/llmq/*.h" \
"src/masternode/*.cpp" \
"src/masternode/*.h" \
"src/messagesigner.*" \
"src/netfulfilledman.*" \
"src/qt/governancelist.*" \
"src/qt/masternodelist.*" \
"src/rpc/coinjoin.cpp" \
"src/rpc/governance.cpp" \
"src/rpc/masternode.cpp" \
"src/rpc/rpcevo.cpp" \
"src/rpc/rpcquorums.cpp" \
"src/spork.*" \
"src/saltedhasher.*" \
"src/stacktraces.*" \
"src/statsd_client.*" \
"src/test/block_reward_reallocation_tests.cpp" \
"src/test/bls_tests.cpp" \
"src/test/dip0020opcodes_tests.cpp" \
"src/test/dynamic_activation*.cpp" \
"src/test/evo*.cpp" \
"src/test/governance*.cpp" \
"src/unordered_lru_cache.h" )
2021-08-01 21:28:25 +02:00
if ! command -v cppcheck > /dev/null; then
echo "Skipping cppcheck linting since cppcheck is not installed."
exit 0
fi
function join_array {
local IFS = " $1 "
shift
echo " $* "
}
ENABLED_CHECKS_REGEXP = $( join_array "|" " ${ ENABLED_CHECKS [@] } " )
IGNORED_WARNINGS_REGEXP = $( join_array "|" " ${ IGNORED_WARNINGS [@] } " )
FILES_REGEXP = $( join_array "|" " ${ FILES [@] } " )
WARNINGS = $( echo " ${ FILES } " | \
2021-10-01 13:44:40 +02:00
xargs cppcheck --enable= all -j " $( getconf _NPROCESSORS_ONLN) " --language= c++ --std= c++17 --template= gcc -D__cplusplus -DENABLE_WALLET -DCLIENT_VERSION_BUILD -DCLIENT_VERSION_IS_RELEASE -DCLIENT_VERSION_MAJOR -DCLIENT_VERSION_MINOR -DCLIENT_VERSION_REVISION -DCOPYRIGHT_YEAR -DDEBUG -DHAVE_WORKING_BOOST_SLEEP_FOR -DCHAR_BIT= 8 -I src/ -q 2>& 1 | sort -u | \
2021-08-01 21:28:25 +02:00
grep -E " ${ ENABLED_CHECKS_REGEXP } " | \
grep -vE " ${ IGNORED_WARNINGS_REGEXP } " | \
grep -E " ${ FILES_REGEXP } " )
if [ [ ${ WARNINGS } != "" ] ] ; then
echo " ${ WARNINGS } "
echo
echo "Advice not applicable in this specific case? Add an exception by updating"
echo " IGNORED_WARNINGS in $0 "
# Uncomment to enforce the linter / comment to run locally
exit 1
fi
exit 0