mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-10 11:57:28 -03:00
Merge bitcoin/bitcoin#28237: refactor: Enforce C-str fmt strings in WalletLogPrintf()
fa60fa3b0c
bitcoin-tidy: Apply bitcoin-unterminated-logprintf to spkm as well (MarcoFalke)faa11434fe
refactor: Enable all clang-tidy plugin bitcoin tests (MarcoFalke)fa6dc57760
refactor: Enforce C-str fmt strings in WalletLogPrintf() (MarcoFalke)fa244f3321
doc: Fix bitcoin-unterminated-logprintf tidy comments (MarcoFalke) Pull request description: All fmt functions only accept a raw C-string as argument. There should never be a need to pass a format string that is not a compile-time string literal, so disallow it in `WalletLogPrintf()` to avoid accidentally introducing it. Apart from consistency, this also fixes the clang-tidy plugin bug https://github.com/bitcoin/bitcoin/pull/26296#discussion_r1286821141. ACKs for top commit: theuni: ACKfa60fa3b0c
Tree-SHA512: fa6f4984c50f9b34e850bdfee7236706af586e512d866cc869cf0cdfaf9aa707029c210ca72d91f85e75fcbd8efe0d77084701de8c3d2004abfd7e46b6fa9072
This commit is contained in:
commit
7bf078f2b7
8 changed files with 37 additions and 19 deletions
|
@ -2,9 +2,10 @@
|
||||||
// Distributed under the MIT software license, see the accompanying
|
// Distributed under the MIT software license, see the accompanying
|
||||||
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||||
|
|
||||||
// Warn about any use of LogPrintf that does not end with a newline.
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
// Test for bitcoin-unterminated-logprintf
|
||||||
|
|
||||||
enum LogFlags {
|
enum LogFlags {
|
||||||
NONE
|
NONE
|
||||||
};
|
};
|
||||||
|
@ -21,8 +22,6 @@ static inline void LogPrintf_(const std::string& logging_function, const std::st
|
||||||
#define LogPrintLevel_(category, level, ...) LogPrintf_(__func__, __FILE__, __LINE__, category, level, __VA_ARGS__)
|
#define LogPrintLevel_(category, level, ...) LogPrintf_(__func__, __FILE__, __LINE__, category, level, __VA_ARGS__)
|
||||||
#define LogPrintf(...) LogPrintLevel_(LogFlags::NONE, Level::None, __VA_ARGS__)
|
#define LogPrintf(...) LogPrintLevel_(LogFlags::NONE, Level::None, __VA_ARGS__)
|
||||||
|
|
||||||
// Use a macro instead of a function for conditional logging to prevent
|
|
||||||
// evaluating arguments when logging for the category is not enabled.
|
|
||||||
#define LogPrint(category, ...) \
|
#define LogPrint(category, ...) \
|
||||||
do { \
|
do { \
|
||||||
LogPrintf(__VA_ARGS__); \
|
LogPrintf(__VA_ARGS__); \
|
||||||
|
@ -38,9 +37,23 @@ class CWallet
|
||||||
|
|
||||||
public:
|
public:
|
||||||
template <typename... Params>
|
template <typename... Params>
|
||||||
void WalletLogPrintf(std::string fmt, Params... parameters) const
|
void WalletLogPrintf(const char* fmt, Params... parameters) const
|
||||||
{
|
{
|
||||||
LogPrintf(("%s " + fmt).c_str(), GetDisplayName(), parameters...);
|
LogPrintf(("%s " + std::string{fmt}).c_str(), GetDisplayName(), parameters...);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
struct ScriptPubKeyMan
|
||||||
|
{
|
||||||
|
std::string GetDisplayName() const
|
||||||
|
{
|
||||||
|
return "default wallet";
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename... Params>
|
||||||
|
void WalletLogPrintf(const char* fmt, Params... parameters) const
|
||||||
|
{
|
||||||
|
LogPrintf(("%s " + std::string{fmt}).c_str(), GetDisplayName(), parameters...);
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -52,6 +65,8 @@ void good_func2()
|
||||||
{
|
{
|
||||||
CWallet wallet;
|
CWallet wallet;
|
||||||
wallet.WalletLogPrintf("hi\n");
|
wallet.WalletLogPrintf("hi\n");
|
||||||
|
ScriptPubKeyMan spkm;
|
||||||
|
spkm.WalletLogPrintf("hi\n");
|
||||||
|
|
||||||
const CWallet& walletref = wallet;
|
const CWallet& walletref = wallet;
|
||||||
walletref.WalletLogPrintf("hi\n");
|
walletref.WalletLogPrintf("hi\n");
|
||||||
|
@ -81,6 +96,8 @@ void bad_func5()
|
||||||
{
|
{
|
||||||
CWallet wallet;
|
CWallet wallet;
|
||||||
wallet.WalletLogPrintf("hi");
|
wallet.WalletLogPrintf("hi");
|
||||||
|
ScriptPubKeyMan spkm;
|
||||||
|
spkm.WalletLogPrintf("hi");
|
||||||
|
|
||||||
const CWallet& walletref = wallet;
|
const CWallet& walletref = wallet;
|
||||||
walletref.WalletLogPrintf("hi");
|
walletref.WalletLogPrintf("hi");
|
||||||
|
|
|
@ -36,14 +36,12 @@ void LogPrintfCheck::registerMatchers(clang::ast_matchers::MatchFinder* finder)
|
||||||
this);
|
this);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
CWallet wallet;
|
|
||||||
auto walletptr = &wallet;
|
auto walletptr = &wallet;
|
||||||
wallet.WalletLogPrintf("foo");
|
wallet.WalletLogPrintf("foo");
|
||||||
wallet->WalletLogPrintf("foo");
|
wallet->WalletLogPrintf("foo");
|
||||||
*/
|
*/
|
||||||
finder->addMatcher(
|
finder->addMatcher(
|
||||||
cxxMemberCallExpr(
|
cxxMemberCallExpr(
|
||||||
thisPointerType(qualType(hasDeclaration(cxxRecordDecl(hasName("CWallet"))))),
|
|
||||||
callee(cxxMethodDecl(hasName("WalletLogPrintf"))),
|
callee(cxxMethodDecl(hasName("WalletLogPrintf"))),
|
||||||
hasArgument(0, stringLiteral(unterminated()).bind("logstring"))),
|
hasArgument(0, stringLiteral(unterminated()).bind("logstring"))),
|
||||||
this);
|
this);
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
|
|
||||||
namespace bitcoin {
|
namespace bitcoin {
|
||||||
|
|
||||||
|
// Warn about any use of LogPrintf that does not end with a newline.
|
||||||
class LogPrintfCheck final : public clang::tidy::ClangTidyCheck
|
class LogPrintfCheck final : public clang::tidy::ClangTidyCheck
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
Checks: '
|
Checks: '
|
||||||
-*,
|
-*,
|
||||||
bitcoin-unterminated-logprintf,
|
bitcoin-*,
|
||||||
bugprone-argument-comment,
|
bugprone-argument-comment,
|
||||||
bugprone-use-after-move,
|
bugprone-use-after-move,
|
||||||
misc-unused-using-decls,
|
misc-unused-using-decls,
|
||||||
|
|
|
@ -250,9 +250,10 @@ public:
|
||||||
virtual std::unordered_set<CScript, SaltedSipHasher> GetScriptPubKeys() const { return {}; };
|
virtual std::unordered_set<CScript, SaltedSipHasher> GetScriptPubKeys() const { return {}; };
|
||||||
|
|
||||||
/** Prepends the wallet name in logging output to ease debugging in multi-wallet use cases */
|
/** Prepends the wallet name in logging output to ease debugging in multi-wallet use cases */
|
||||||
template<typename... Params>
|
template <typename... Params>
|
||||||
void WalletLogPrintf(std::string fmt, Params... parameters) const {
|
void WalletLogPrintf(const char* fmt, Params... parameters) const
|
||||||
LogPrintf(("%s " + fmt).c_str(), m_storage.GetDisplayName(), parameters...);
|
{
|
||||||
|
LogPrintf(("%s " + std::string{fmt}).c_str(), m_storage.GetDisplayName(), parameters...);
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Watch-only address added */
|
/** Watch-only address added */
|
||||||
|
|
|
@ -2320,7 +2320,7 @@ OutputType CWallet::TransactionChangeType(const std::optional<OutputType>& chang
|
||||||
void CWallet::CommitTransaction(CTransactionRef tx, mapValue_t mapValue, std::vector<std::pair<std::string, std::string>> orderForm)
|
void CWallet::CommitTransaction(CTransactionRef tx, mapValue_t mapValue, std::vector<std::pair<std::string, std::string>> orderForm)
|
||||||
{
|
{
|
||||||
LOCK(cs_wallet);
|
LOCK(cs_wallet);
|
||||||
WalletLogPrintf("CommitTransaction:\n%s", tx->ToString());
|
WalletLogPrintf("CommitTransaction:\n%s", tx->ToString()); // NOLINT(bitcoin-unterminated-logprintf)
|
||||||
|
|
||||||
// Add tx to wallet, because if it has change it's also ours,
|
// Add tx to wallet, because if it has change it's also ours,
|
||||||
// otherwise just for transaction history.
|
// otherwise just for transaction history.
|
||||||
|
|
|
@ -891,9 +891,10 @@ public:
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Prepends the wallet name in logging output to ease debugging in multi-wallet use cases */
|
/** Prepends the wallet name in logging output to ease debugging in multi-wallet use cases */
|
||||||
template<typename... Params>
|
template <typename... Params>
|
||||||
void WalletLogPrintf(std::string fmt, Params... parameters) const {
|
void WalletLogPrintf(const char* fmt, Params... parameters) const
|
||||||
LogPrintf(("%s " + fmt).c_str(), GetDisplayName(), parameters...);
|
{
|
||||||
|
LogPrintf(("%s " + std::string{fmt}).c_str(), GetDisplayName(), parameters...);
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Upgrade the wallet */
|
/** Upgrade the wallet */
|
||||||
|
|
|
@ -20,10 +20,10 @@ FALSE_POSITIVES = [
|
||||||
("src/clientversion.cpp", "strprintf(_(COPYRIGHT_HOLDERS).translated, COPYRIGHT_HOLDERS_SUBSTITUTION)"),
|
("src/clientversion.cpp", "strprintf(_(COPYRIGHT_HOLDERS).translated, COPYRIGHT_HOLDERS_SUBSTITUTION)"),
|
||||||
("src/test/translation_tests.cpp", "strprintf(format, arg)"),
|
("src/test/translation_tests.cpp", "strprintf(format, arg)"),
|
||||||
("src/validationinterface.cpp", "LogPrint(BCLog::VALIDATION, fmt \"\\n\", __VA_ARGS__)"),
|
("src/validationinterface.cpp", "LogPrint(BCLog::VALIDATION, fmt \"\\n\", __VA_ARGS__)"),
|
||||||
("src/wallet/wallet.h", "WalletLogPrintf(std::string fmt, Params... parameters)"),
|
("src/wallet/wallet.h", "WalletLogPrintf(const char* fmt, Params... parameters)"),
|
||||||
("src/wallet/wallet.h", "LogPrintf((\"%s \" + fmt).c_str(), GetDisplayName(), parameters...)"),
|
("src/wallet/wallet.h", "LogPrintf((\"%s \" + std::string{fmt}).c_str(), GetDisplayName(), parameters...)"),
|
||||||
("src/wallet/scriptpubkeyman.h", "WalletLogPrintf(std::string fmt, Params... parameters)"),
|
("src/wallet/scriptpubkeyman.h", "WalletLogPrintf(const char* fmt, Params... parameters)"),
|
||||||
("src/wallet/scriptpubkeyman.h", "LogPrintf((\"%s \" + fmt).c_str(), m_storage.GetDisplayName(), parameters...)"),
|
("src/wallet/scriptpubkeyman.h", "LogPrintf((\"%s \" + std::string{fmt}).c_str(), m_storage.GetDisplayName(), parameters...)"),
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue