From fe9bc5abef3dcbe0f6395c3233f9d122579cd1f0 Mon Sep 17 00:00:00 2001 From: Hennadii Stepanov <32963518+hebasto@users.noreply.github.com> Date: Thu, 5 Dec 2024 14:37:47 +0000 Subject: [PATCH] ci: Update Clang in "tidy" job This change switches to the latest IWYU 0.23, which is compatible with Clang 19. Fixed new "modernize-use-starts-ends-with" warnings. The new "bugprone-use-after-move" warning in `result_tests.cpp` is a false positive caused by a bug in Boost.Test versions < 1.87. This has been addressed by introducing a local variable. See upstream references: - Issue: https://github.com/boostorg/test/issues/343 - Fix: https://github.com/boostorg/test/pull/348 Co-authored-by: MarcoFalke <*~=`'#}+{/-|&$^_@721217.xyz> --- ci/test/00_setup_env_native_tidy.sh | 3 ++- src/core_read.cpp | 2 +- src/test/result_tests.cpp | 3 ++- src/torcontrol.cpp | 4 ++-- src/wallet/walletdb.cpp | 2 +- 5 files changed, 8 insertions(+), 6 deletions(-) diff --git a/ci/test/00_setup_env_native_tidy.sh b/ci/test/00_setup_env_native_tidy.sh index 9068045f936..b85fae859c2 100755 --- a/ci/test/00_setup_env_native_tidy.sh +++ b/ci/test/00_setup_env_native_tidy.sh @@ -8,7 +8,8 @@ export LC_ALL=C.UTF-8 export CI_IMAGE_NAME_TAG="docker.io/ubuntu:24.04" export CONTAINER_NAME=ci_native_tidy -export TIDY_LLVM_V="18" +export TIDY_LLVM_V="19" +export APT_LLVM_V="${TIDY_LLVM_V}" export PACKAGES="clang-${TIDY_LLVM_V} libclang-${TIDY_LLVM_V}-dev llvm-${TIDY_LLVM_V}-dev libomp-${TIDY_LLVM_V}-dev clang-tidy-${TIDY_LLVM_V} jq libevent-dev libboost-dev libzmq3-dev systemtap-sdt-dev qtbase5-dev qttools5-dev qttools5-dev-tools libqrencode-dev libsqlite3-dev libdb++-dev" export NO_DEPENDS=1 export RUN_UNIT_TESTS=false diff --git a/src/core_read.cpp b/src/core_read.cpp index 23f341c2304..273dfb17e86 100644 --- a/src/core_read.cpp +++ b/src/core_read.cpp @@ -39,7 +39,7 @@ class OpCodeParser } mapOpNames[strName] = static_cast(op); // Convenience: OP_ADD and just ADD are both recognized: - if (strName.compare(0, 3, "OP_") == 0) { // strName starts with "OP_" + if (strName.starts_with("OP_")) { mapOpNames[strName.substr(3)] = static_cast(op); } } diff --git a/src/test/result_tests.cpp b/src/test/result_tests.cpp index 6a23a7b8950..2df756992b0 100644 --- a/src/test/result_tests.cpp +++ b/src/test/result_tests.cpp @@ -63,7 +63,8 @@ void ExpectSuccess(const util::Result& result, const bilingual_str& str, Args { ExpectResult(result, true, str); BOOST_CHECK_EQUAL(result.has_value(), true); - BOOST_CHECK_EQUAL(result.value(), T{std::forward(args)...}); + T expected{std::forward(args)...}; + BOOST_CHECK_EQUAL(result.value(), expected); BOOST_CHECK_EQUAL(&result.value(), &*result); } diff --git a/src/torcontrol.cpp b/src/torcontrol.cpp index 58fc1bdf2aa..8d14b6ce2e9 100644 --- a/src/torcontrol.cpp +++ b/src/torcontrol.cpp @@ -356,7 +356,7 @@ void TorController::get_socks_cb(TorControlConnection& _conn, const TorControlRe std::string socks_location; if (reply.code == 250) { for (const auto& line : reply.lines) { - if (0 == line.compare(0, 20, "net/listeners/socks=")) { + if (line.starts_with("net/listeners/socks=")) { const std::string port_list_str = line.substr(20); std::vector port_list = SplitString(port_list_str, ' '); @@ -367,7 +367,7 @@ void TorController::get_socks_cb(TorControlConnection& _conn, const TorControlRe if (portstr.empty()) continue; } socks_location = portstr; - if (0 == portstr.compare(0, 10, "127.0.0.1:")) { + if (portstr.starts_with("127.0.0.1:")) { // Prefer localhost - ignore other ports break; } diff --git a/src/wallet/walletdb.cpp b/src/wallet/walletdb.cpp index b09a0e40eb4..368415da129 100644 --- a/src/wallet/walletdb.cpp +++ b/src/wallet/walletdb.cpp @@ -1013,7 +1013,7 @@ static DBErrors LoadAddressBookRecords(CWallet* pwallet, DatabaseBatch& batch) E // "1" or "p" for present (which was written prior to // f5ba424cd44619d9b9be88b8593d69a7ba96db26). pwallet->LoadAddressPreviouslySpent(dest); - } else if (strKey.compare(0, 2, "rr") == 0) { + } else if (strKey.starts_with("rr")) { // Load "rr##" keys where ## is a decimal number, and strValue // is a serialized RecentRequestEntry object. pwallet->LoadAddressReceiveRequest(dest, strKey.substr(2), strValue);