mirror of
https://github.com/dashpay/dash.git
synced 2024-12-25 20:12:57 +01:00
f503a7edc1
* src/evo/evodb.cpp:57:29: warning: Assert statement calls a function which may have desired side effects: 'IsClean'. [assertWithSideEffect] * src/llmq/quorums.cpp:635:37: note: Null pointer dereference src/llmq/quorums.cpp:635:37: warning: Either the condition 'pFrom==nullptr' is redundant or there is possible null pointer dereference: pFrom. [nullPointerRedundantCheck] src/llmq/quorums.cpp:636:81: note: Assuming that condition 'pFrom==nullptr' is not redundant * fix a bunch of cppcheck warnings * cppcheck: run on many more files. Enable all checks except a few ignored ones. ignored ``` "Consider using std::transform algorithm instead of a raw loop." "Consider using std::accumulate algorithm instead of a raw loop." ``` * ci: build specific version of cppcheck instead of install from apt * ci: use cppcheck 2.4, remove commented out line, fix symlink cppcheck 2.6 is latest, however causes issues ``` src/spork.cpp:135:51: warning: Analysis failed. If the code is valid then please report this failure. [cppcheckError] ``` cppcheck 2.5 appears to get into an infinite loop * no need to check presence before insertion * use if-init, remove redundant check * remove redundant check * don't remove cmake? fix macOs depends build? * cppcheck: one per line, alphabetize * remove duplicate cmake install
124 lines
5.7 KiB
Bash
Executable File
124 lines
5.7 KiB
Bash
Executable File
#!/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
|
|
".*"
|
|
)
|
|
|
|
IGNORED_WARNINGS=(
|
|
"src/bls/bls.h:.* Struct 'CBLSIdImplicit' has a constructor with 1 argument that is not explicit."
|
|
"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"
|
|
|
|
|
|
# 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."
|
|
"Consider using std::transform algorithm instead of a raw loop."
|
|
"Consider using std::accumulate algorithm instead of a raw loop."
|
|
# "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."
|
|
# "Member variable '.*' is not initialized in the constructor."
|
|
)
|
|
|
|
# We should attempt to update this with all dash specific code
|
|
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")
|
|
|
|
|
|
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}" | \
|
|
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 | \
|
|
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
|