mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-10 20:03:34 -03:00
scripted-diff: Use [[nodiscard]] (C++17) instead of NODISCARD
-BEGIN VERIFY SCRIPT- sed -i "s/NODISCARD/[[nodiscard]]/g" $(git grep -l "NODISCARD" ":(exclude)src/bench/nanobench.h" ":(exclude)src/attributes.h") -END VERIFY SCRIPT-
This commit is contained in:
parent
50091592dd
commit
4848e71107
17 changed files with 54 additions and 54 deletions
|
@ -35,7 +35,7 @@ static const int8_t mapBase58[256] = {
|
||||||
-1,-1,-1,-1,-1,-1,-1,-1, -1,-1,-1,-1,-1,-1,-1,-1,
|
-1,-1,-1,-1,-1,-1,-1,-1, -1,-1,-1,-1,-1,-1,-1,-1,
|
||||||
};
|
};
|
||||||
|
|
||||||
NODISCARD static bool DecodeBase58(const char* psz, std::vector<unsigned char>& vch, int max_ret_len)
|
[[nodiscard]] static bool DecodeBase58(const char* psz, std::vector<unsigned char>& vch, int max_ret_len)
|
||||||
{
|
{
|
||||||
// Skip leading spaces.
|
// Skip leading spaces.
|
||||||
while (*psz && IsSpace(*psz))
|
while (*psz && IsSpace(*psz))
|
||||||
|
@ -141,7 +141,7 @@ std::string EncodeBase58Check(Span<const unsigned char> input)
|
||||||
return EncodeBase58(vch);
|
return EncodeBase58(vch);
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD static bool DecodeBase58Check(const char* psz, std::vector<unsigned char>& vchRet, int max_ret_len)
|
[[nodiscard]] static bool DecodeBase58Check(const char* psz, std::vector<unsigned char>& vchRet, int max_ret_len)
|
||||||
{
|
{
|
||||||
if (!DecodeBase58(psz, vchRet, max_ret_len > std::numeric_limits<int>::max() - 4 ? std::numeric_limits<int>::max() : max_ret_len + 4) ||
|
if (!DecodeBase58(psz, vchRet, max_ret_len > std::numeric_limits<int>::max() - 4 ? std::numeric_limits<int>::max() : max_ret_len + 4) ||
|
||||||
(vchRet.size() < 4)) {
|
(vchRet.size() < 4)) {
|
||||||
|
|
|
@ -29,7 +29,7 @@ std::string EncodeBase58(Span<const unsigned char> input);
|
||||||
* Decode a base58-encoded string (str) into a byte vector (vchRet).
|
* Decode a base58-encoded string (str) into a byte vector (vchRet).
|
||||||
* return true if decoding is successful.
|
* return true if decoding is successful.
|
||||||
*/
|
*/
|
||||||
NODISCARD bool DecodeBase58(const std::string& str, std::vector<unsigned char>& vchRet, int max_ret_len);
|
[[nodiscard]] bool DecodeBase58(const std::string& str, std::vector<unsigned char>& vchRet, int max_ret_len);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Encode a byte span into a base58-encoded string, including checksum
|
* Encode a byte span into a base58-encoded string, including checksum
|
||||||
|
@ -40,6 +40,6 @@ std::string EncodeBase58Check(Span<const unsigned char> input);
|
||||||
* Decode a base58-encoded string (str) that includes a checksum into a byte
|
* Decode a base58-encoded string (str) that includes a checksum into a byte
|
||||||
* vector (vchRet), return true if decoding is successful
|
* vector (vchRet), return true if decoding is successful
|
||||||
*/
|
*/
|
||||||
NODISCARD bool DecodeBase58Check(const std::string& str, std::vector<unsigned char>& vchRet, int max_ret_len);
|
[[nodiscard]] bool DecodeBase58Check(const std::string& str, std::vector<unsigned char>& vchRet, int max_ret_len);
|
||||||
|
|
||||||
#endif // BITCOIN_BASE58_H
|
#endif // BITCOIN_BASE58_H
|
||||||
|
|
|
@ -22,8 +22,8 @@ class UniValue;
|
||||||
// core_read.cpp
|
// core_read.cpp
|
||||||
CScript ParseScript(const std::string& s);
|
CScript ParseScript(const std::string& s);
|
||||||
std::string ScriptToAsmStr(const CScript& script, const bool fAttemptSighashDecode = false);
|
std::string ScriptToAsmStr(const CScript& script, const bool fAttemptSighashDecode = false);
|
||||||
NODISCARD bool DecodeHexTx(CMutableTransaction& tx, const std::string& hex_tx, bool try_no_witness = false, bool try_witness = true);
|
[[nodiscard]] bool DecodeHexTx(CMutableTransaction& tx, const std::string& hex_tx, bool try_no_witness = false, bool try_witness = true);
|
||||||
NODISCARD bool DecodeHexBlk(CBlock&, const std::string& strHexBlk);
|
[[nodiscard]] bool DecodeHexBlk(CBlock&, const std::string& strHexBlk);
|
||||||
bool DecodeHexBlockHeader(CBlockHeader&, const std::string& hex_header);
|
bool DecodeHexBlockHeader(CBlockHeader&, const std::string& hex_header);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -197,7 +197,7 @@ uint256 SerializeHash(const T& obj, int nType=SER_GETHASH, int nVersion=PROTOCOL
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Single-SHA256 a 32-byte input (represented as uint256). */
|
/** Single-SHA256 a 32-byte input (represented as uint256). */
|
||||||
NODISCARD uint256 SHA256Uint256(const uint256& input);
|
[[nodiscard]] uint256 SHA256Uint256(const uint256& input);
|
||||||
|
|
||||||
unsigned int MurmurHash3(unsigned int nHashSeed, Span<const unsigned char> vDataToHash);
|
unsigned int MurmurHash3(unsigned int nHashSeed, Span<const unsigned char> vDataToHash);
|
||||||
|
|
||||||
|
|
|
@ -113,7 +113,7 @@ static fs::path GetPidFile(const ArgsManager& args)
|
||||||
return AbsPathForConfigVal(fs::path(args.GetArg("-pid", BITCOIN_PID_FILENAME)));
|
return AbsPathForConfigVal(fs::path(args.GetArg("-pid", BITCOIN_PID_FILENAME)));
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD static bool CreatePidFile(const ArgsManager& args)
|
[[nodiscard]] static bool CreatePidFile(const ArgsManager& args)
|
||||||
{
|
{
|
||||||
fsbridge::ofstream file{GetPidFile(args)};
|
fsbridge::ofstream file{GetPidFile(args)};
|
||||||
if (file) {
|
if (file) {
|
||||||
|
|
|
@ -36,6 +36,6 @@ static const CFeeRate DEFAULT_MAX_RAW_TX_FEE_RATE{COIN / 10};
|
||||||
* @param[in] wait_callback wait until callbacks have been processed to avoid stale result due to a sequentially RPC.
|
* @param[in] wait_callback wait until callbacks have been processed to avoid stale result due to a sequentially RPC.
|
||||||
* return error
|
* return error
|
||||||
*/
|
*/
|
||||||
NODISCARD TransactionError BroadcastTransaction(NodeContext& node, CTransactionRef tx, std::string& err_string, const CAmount& max_tx_fee, bool relay, bool wait_callback);
|
[[nodiscard]] TransactionError BroadcastTransaction(NodeContext& node, CTransactionRef tx, std::string& err_string, const CAmount& max_tx_fee, bool relay, bool wait_callback);
|
||||||
|
|
||||||
#endif // BITCOIN_NODE_TRANSACTION_H
|
#endif // BITCOIN_NODE_TRANSACTION_H
|
||||||
|
|
|
@ -22,7 +22,7 @@ enum class OutputType {
|
||||||
|
|
||||||
extern const std::array<OutputType, 3> OUTPUT_TYPES;
|
extern const std::array<OutputType, 3> OUTPUT_TYPES;
|
||||||
|
|
||||||
NODISCARD bool ParseOutputType(const std::string& str, OutputType& output_type);
|
[[nodiscard]] bool ParseOutputType(const std::string& str, OutputType& output_type);
|
||||||
const std::string& FormatOutputType(OutputType type);
|
const std::string& FormatOutputType(OutputType type);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -398,7 +398,7 @@ struct PartiallySignedTransaction
|
||||||
|
|
||||||
/** Merge psbt into this. The two psbts must have the same underlying CTransaction (i.e. the
|
/** Merge psbt into this. The two psbts must have the same underlying CTransaction (i.e. the
|
||||||
* same actual Bitcoin transaction.) Returns true if the merge succeeded, false otherwise. */
|
* same actual Bitcoin transaction.) Returns true if the merge succeeded, false otherwise. */
|
||||||
NODISCARD bool Merge(const PartiallySignedTransaction& psbt);
|
[[nodiscard]] bool Merge(const PartiallySignedTransaction& psbt);
|
||||||
bool AddInput(const CTxIn& txin, PSBTInput& psbtin);
|
bool AddInput(const CTxIn& txin, PSBTInput& psbtin);
|
||||||
bool AddOutput(const CTxOut& txout, const PSBTOutput& psbtout);
|
bool AddOutput(const CTxOut& txout, const PSBTOutput& psbtout);
|
||||||
PartiallySignedTransaction() {}
|
PartiallySignedTransaction() {}
|
||||||
|
@ -605,11 +605,11 @@ bool FinalizeAndExtractPSBT(PartiallySignedTransaction& psbtx, CMutableTransacti
|
||||||
* @param[in] psbtxs the PSBTs to combine
|
* @param[in] psbtxs the PSBTs to combine
|
||||||
* @return error (OK if we successfully combined the transactions, other error if they were not compatible)
|
* @return error (OK if we successfully combined the transactions, other error if they were not compatible)
|
||||||
*/
|
*/
|
||||||
NODISCARD TransactionError CombinePSBTs(PartiallySignedTransaction& out, const std::vector<PartiallySignedTransaction>& psbtxs);
|
[[nodiscard]] TransactionError CombinePSBTs(PartiallySignedTransaction& out, const std::vector<PartiallySignedTransaction>& psbtxs);
|
||||||
|
|
||||||
//! Decode a base64ed PSBT into a PartiallySignedTransaction
|
//! Decode a base64ed PSBT into a PartiallySignedTransaction
|
||||||
NODISCARD bool DecodeBase64PSBT(PartiallySignedTransaction& decoded_psbt, const std::string& base64_psbt, std::string& error);
|
[[nodiscard]] bool DecodeBase64PSBT(PartiallySignedTransaction& decoded_psbt, const std::string& base64_psbt, std::string& error);
|
||||||
//! Decode a raw (binary blob) PSBT into a PartiallySignedTransaction
|
//! Decode a raw (binary blob) PSBT into a PartiallySignedTransaction
|
||||||
NODISCARD bool DecodeRawPSBT(PartiallySignedTransaction& decoded_psbt, const std::string& raw_psbt, std::string& error);
|
[[nodiscard]] bool DecodeRawPSBT(PartiallySignedTransaction& decoded_psbt, const std::string& raw_psbt, std::string& error);
|
||||||
|
|
||||||
#endif // BITCOIN_PSBT_H
|
#endif // BITCOIN_PSBT_H
|
||||||
|
|
|
@ -731,7 +731,7 @@ enum class ParseScriptContext {
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Parse a key path, being passed a split list of elements (the first element is ignored). */
|
/** Parse a key path, being passed a split list of elements (the first element is ignored). */
|
||||||
NODISCARD bool ParseKeyPath(const std::vector<Span<const char>>& split, KeyPath& out, std::string& error)
|
[[nodiscard]] bool ParseKeyPath(const std::vector<Span<const char>>& split, KeyPath& out, std::string& error)
|
||||||
{
|
{
|
||||||
for (size_t i = 1; i < split.size(); ++i) {
|
for (size_t i = 1; i < split.size(); ++i) {
|
||||||
Span<const char> elem = split[i];
|
Span<const char> elem = split[i];
|
||||||
|
|
|
@ -38,7 +38,7 @@ class CCoinsViewTest : public CCoinsView
|
||||||
std::map<COutPoint, Coin> map_;
|
std::map<COutPoint, Coin> map_;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
NODISCARD bool GetCoin(const COutPoint& outpoint, Coin& coin) const override
|
[[nodiscard]] bool GetCoin(const COutPoint& outpoint, Coin& coin) const override
|
||||||
{
|
{
|
||||||
std::map<COutPoint, Coin>::const_iterator it = map_.find(outpoint);
|
std::map<COutPoint, Coin>::const_iterator it = map_.find(outpoint);
|
||||||
if (it == map_.end()) {
|
if (it == map_.end()) {
|
||||||
|
|
|
@ -35,23 +35,23 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
NODISCARD inline std::vector<uint8_t> ConsumeRandomLengthByteVector(FuzzedDataProvider& fuzzed_data_provider, const size_t max_length = 4096) noexcept
|
[[nodiscard]] inline std::vector<uint8_t> ConsumeRandomLengthByteVector(FuzzedDataProvider& fuzzed_data_provider, const size_t max_length = 4096) noexcept
|
||||||
{
|
{
|
||||||
const std::string s = fuzzed_data_provider.ConsumeRandomLengthString(max_length);
|
const std::string s = fuzzed_data_provider.ConsumeRandomLengthString(max_length);
|
||||||
return {s.begin(), s.end()};
|
return {s.begin(), s.end()};
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD inline std::vector<bool> ConsumeRandomLengthBitVector(FuzzedDataProvider& fuzzed_data_provider, const size_t max_length = 4096) noexcept
|
[[nodiscard]] inline std::vector<bool> ConsumeRandomLengthBitVector(FuzzedDataProvider& fuzzed_data_provider, const size_t max_length = 4096) noexcept
|
||||||
{
|
{
|
||||||
return BytesToBits(ConsumeRandomLengthByteVector(fuzzed_data_provider, max_length));
|
return BytesToBits(ConsumeRandomLengthByteVector(fuzzed_data_provider, max_length));
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD inline CDataStream ConsumeDataStream(FuzzedDataProvider& fuzzed_data_provider, const size_t max_length = 4096) noexcept
|
[[nodiscard]] inline CDataStream ConsumeDataStream(FuzzedDataProvider& fuzzed_data_provider, const size_t max_length = 4096) noexcept
|
||||||
{
|
{
|
||||||
return {ConsumeRandomLengthByteVector(fuzzed_data_provider, max_length), SER_NETWORK, INIT_PROTO_VERSION};
|
return {ConsumeRandomLengthByteVector(fuzzed_data_provider, max_length), SER_NETWORK, INIT_PROTO_VERSION};
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD inline std::vector<std::string> ConsumeRandomLengthStringVector(FuzzedDataProvider& fuzzed_data_provider, const size_t max_vector_size = 16, const size_t max_string_length = 16) noexcept
|
[[nodiscard]] inline std::vector<std::string> ConsumeRandomLengthStringVector(FuzzedDataProvider& fuzzed_data_provider, const size_t max_vector_size = 16, const size_t max_string_length = 16) noexcept
|
||||||
{
|
{
|
||||||
const size_t n_elements = fuzzed_data_provider.ConsumeIntegralInRange<size_t>(0, max_vector_size);
|
const size_t n_elements = fuzzed_data_provider.ConsumeIntegralInRange<size_t>(0, max_vector_size);
|
||||||
std::vector<std::string> r;
|
std::vector<std::string> r;
|
||||||
|
@ -62,7 +62,7 @@ NODISCARD inline std::vector<std::string> ConsumeRandomLengthStringVector(Fuzzed
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
NODISCARD inline std::vector<T> ConsumeRandomLengthIntegralVector(FuzzedDataProvider& fuzzed_data_provider, const size_t max_vector_size = 16) noexcept
|
[[nodiscard]] inline std::vector<T> ConsumeRandomLengthIntegralVector(FuzzedDataProvider& fuzzed_data_provider, const size_t max_vector_size = 16) noexcept
|
||||||
{
|
{
|
||||||
const size_t n_elements = fuzzed_data_provider.ConsumeIntegralInRange<size_t>(0, max_vector_size);
|
const size_t n_elements = fuzzed_data_provider.ConsumeIntegralInRange<size_t>(0, max_vector_size);
|
||||||
std::vector<T> r;
|
std::vector<T> r;
|
||||||
|
@ -73,7 +73,7 @@ NODISCARD inline std::vector<T> ConsumeRandomLengthIntegralVector(FuzzedDataProv
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
NODISCARD inline std::optional<T> ConsumeDeserializable(FuzzedDataProvider& fuzzed_data_provider, const size_t max_length = 4096) noexcept
|
[[nodiscard]] inline std::optional<T> ConsumeDeserializable(FuzzedDataProvider& fuzzed_data_provider, const size_t max_length = 4096) noexcept
|
||||||
{
|
{
|
||||||
const std::vector<uint8_t> buffer = ConsumeRandomLengthByteVector(fuzzed_data_provider, max_length);
|
const std::vector<uint8_t> buffer = ConsumeRandomLengthByteVector(fuzzed_data_provider, max_length);
|
||||||
CDataStream ds{buffer, SER_NETWORK, INIT_PROTO_VERSION};
|
CDataStream ds{buffer, SER_NETWORK, INIT_PROTO_VERSION};
|
||||||
|
@ -86,35 +86,35 @@ NODISCARD inline std::optional<T> ConsumeDeserializable(FuzzedDataProvider& fuzz
|
||||||
return obj;
|
return obj;
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD inline opcodetype ConsumeOpcodeType(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
[[nodiscard]] inline opcodetype ConsumeOpcodeType(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
||||||
{
|
{
|
||||||
return static_cast<opcodetype>(fuzzed_data_provider.ConsumeIntegralInRange<uint32_t>(0, MAX_OPCODE));
|
return static_cast<opcodetype>(fuzzed_data_provider.ConsumeIntegralInRange<uint32_t>(0, MAX_OPCODE));
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD inline CAmount ConsumeMoney(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
[[nodiscard]] inline CAmount ConsumeMoney(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
||||||
{
|
{
|
||||||
return fuzzed_data_provider.ConsumeIntegralInRange<CAmount>(0, MAX_MONEY);
|
return fuzzed_data_provider.ConsumeIntegralInRange<CAmount>(0, MAX_MONEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD inline int64_t ConsumeTime(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
[[nodiscard]] inline int64_t ConsumeTime(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
||||||
{
|
{
|
||||||
static const int64_t time_min = ParseISO8601DateTime("1970-01-01T00:00:00Z");
|
static const int64_t time_min = ParseISO8601DateTime("1970-01-01T00:00:00Z");
|
||||||
static const int64_t time_max = ParseISO8601DateTime("9999-12-31T23:59:59Z");
|
static const int64_t time_max = ParseISO8601DateTime("9999-12-31T23:59:59Z");
|
||||||
return fuzzed_data_provider.ConsumeIntegralInRange<int64_t>(time_min, time_max);
|
return fuzzed_data_provider.ConsumeIntegralInRange<int64_t>(time_min, time_max);
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD inline CScript ConsumeScript(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
[[nodiscard]] inline CScript ConsumeScript(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
||||||
{
|
{
|
||||||
const std::vector<uint8_t> b = ConsumeRandomLengthByteVector(fuzzed_data_provider);
|
const std::vector<uint8_t> b = ConsumeRandomLengthByteVector(fuzzed_data_provider);
|
||||||
return {b.begin(), b.end()};
|
return {b.begin(), b.end()};
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD inline CScriptNum ConsumeScriptNum(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
[[nodiscard]] inline CScriptNum ConsumeScriptNum(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
||||||
{
|
{
|
||||||
return CScriptNum{fuzzed_data_provider.ConsumeIntegral<int64_t>()};
|
return CScriptNum{fuzzed_data_provider.ConsumeIntegral<int64_t>()};
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD inline uint160 ConsumeUInt160(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
[[nodiscard]] inline uint160 ConsumeUInt160(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
||||||
{
|
{
|
||||||
const std::vector<uint8_t> v160 = fuzzed_data_provider.ConsumeBytes<uint8_t>(160 / 8);
|
const std::vector<uint8_t> v160 = fuzzed_data_provider.ConsumeBytes<uint8_t>(160 / 8);
|
||||||
if (v160.size() != 160 / 8) {
|
if (v160.size() != 160 / 8) {
|
||||||
|
@ -123,7 +123,7 @@ NODISCARD inline uint160 ConsumeUInt160(FuzzedDataProvider& fuzzed_data_provider
|
||||||
return uint160{v160};
|
return uint160{v160};
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD inline uint256 ConsumeUInt256(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
[[nodiscard]] inline uint256 ConsumeUInt256(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
||||||
{
|
{
|
||||||
const std::vector<uint8_t> v256 = fuzzed_data_provider.ConsumeBytes<uint8_t>(256 / 8);
|
const std::vector<uint8_t> v256 = fuzzed_data_provider.ConsumeBytes<uint8_t>(256 / 8);
|
||||||
if (v256.size() != 256 / 8) {
|
if (v256.size() != 256 / 8) {
|
||||||
|
@ -132,12 +132,12 @@ NODISCARD inline uint256 ConsumeUInt256(FuzzedDataProvider& fuzzed_data_provider
|
||||||
return uint256{v256};
|
return uint256{v256};
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD inline arith_uint256 ConsumeArithUInt256(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
[[nodiscard]] inline arith_uint256 ConsumeArithUInt256(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
||||||
{
|
{
|
||||||
return UintToArith256(ConsumeUInt256(fuzzed_data_provider));
|
return UintToArith256(ConsumeUInt256(fuzzed_data_provider));
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD inline CTxMemPoolEntry ConsumeTxMemPoolEntry(FuzzedDataProvider& fuzzed_data_provider, const CTransaction& tx) noexcept
|
[[nodiscard]] inline CTxMemPoolEntry ConsumeTxMemPoolEntry(FuzzedDataProvider& fuzzed_data_provider, const CTransaction& tx) noexcept
|
||||||
{
|
{
|
||||||
// Avoid:
|
// Avoid:
|
||||||
// policy/feerate.cpp:28:34: runtime error: signed integer overflow: 34873208148477500 * 1000 cannot be represented in type 'long'
|
// policy/feerate.cpp:28:34: runtime error: signed integer overflow: 34873208148477500 * 1000 cannot be represented in type 'long'
|
||||||
|
@ -152,7 +152,7 @@ NODISCARD inline CTxMemPoolEntry ConsumeTxMemPoolEntry(FuzzedDataProvider& fuzze
|
||||||
return CTxMemPoolEntry{MakeTransactionRef(tx), fee, time, entry_height, spends_coinbase, sig_op_cost, {}};
|
return CTxMemPoolEntry{MakeTransactionRef(tx), fee, time, entry_height, spends_coinbase, sig_op_cost, {}};
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD inline CTxDestination ConsumeTxDestination(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
[[nodiscard]] inline CTxDestination ConsumeTxDestination(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
||||||
{
|
{
|
||||||
CTxDestination tx_destination;
|
CTxDestination tx_destination;
|
||||||
switch (fuzzed_data_provider.ConsumeIntegralInRange<int>(0, 5)) {
|
switch (fuzzed_data_provider.ConsumeIntegralInRange<int>(0, 5)) {
|
||||||
|
@ -190,7 +190,7 @@ NODISCARD inline CTxDestination ConsumeTxDestination(FuzzedDataProvider& fuzzed_
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
NODISCARD bool MultiplicationOverflow(const T i, const T j) noexcept
|
[[nodiscard]] bool MultiplicationOverflow(const T i, const T j) noexcept
|
||||||
{
|
{
|
||||||
static_assert(std::is_integral<T>::value, "Integral required.");
|
static_assert(std::is_integral<T>::value, "Integral required.");
|
||||||
if (std::numeric_limits<T>::is_signed) {
|
if (std::numeric_limits<T>::is_signed) {
|
||||||
|
@ -213,7 +213,7 @@ NODISCARD bool MultiplicationOverflow(const T i, const T j) noexcept
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
NODISCARD bool AdditionOverflow(const T i, const T j) noexcept
|
[[nodiscard]] bool AdditionOverflow(const T i, const T j) noexcept
|
||||||
{
|
{
|
||||||
static_assert(std::is_integral<T>::value, "Integral required.");
|
static_assert(std::is_integral<T>::value, "Integral required.");
|
||||||
if (std::numeric_limits<T>::is_signed) {
|
if (std::numeric_limits<T>::is_signed) {
|
||||||
|
@ -223,7 +223,7 @@ NODISCARD bool AdditionOverflow(const T i, const T j) noexcept
|
||||||
return std::numeric_limits<T>::max() - i < j;
|
return std::numeric_limits<T>::max() - i < j;
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD inline bool ContainsSpentInput(const CTransaction& tx, const CCoinsViewCache& inputs) noexcept
|
[[nodiscard]] inline bool ContainsSpentInput(const CTransaction& tx, const CCoinsViewCache& inputs) noexcept
|
||||||
{
|
{
|
||||||
for (const CTxIn& tx_in : tx.vin) {
|
for (const CTxIn& tx_in : tx.vin) {
|
||||||
const Coin& coin = inputs.AccessCoin(tx_in.prevout);
|
const Coin& coin = inputs.AccessCoin(tx_in.prevout);
|
||||||
|
@ -238,7 +238,7 @@ NODISCARD inline bool ContainsSpentInput(const CTransaction& tx, const CCoinsVie
|
||||||
* Returns a byte vector of specified size regardless of the number of remaining bytes available
|
* Returns a byte vector of specified size regardless of the number of remaining bytes available
|
||||||
* from the fuzzer. Pads with zero value bytes if needed to achieve the specified size.
|
* from the fuzzer. Pads with zero value bytes if needed to achieve the specified size.
|
||||||
*/
|
*/
|
||||||
NODISCARD inline std::vector<uint8_t> ConsumeFixedLengthByteVector(FuzzedDataProvider& fuzzed_data_provider, const size_t length) noexcept
|
[[nodiscard]] inline std::vector<uint8_t> ConsumeFixedLengthByteVector(FuzzedDataProvider& fuzzed_data_provider, const size_t length) noexcept
|
||||||
{
|
{
|
||||||
std::vector<uint8_t> result(length);
|
std::vector<uint8_t> result(length);
|
||||||
const std::vector<uint8_t> random_bytes = fuzzed_data_provider.ConsumeBytes<uint8_t>(length);
|
const std::vector<uint8_t> random_bytes = fuzzed_data_provider.ConsumeBytes<uint8_t>(length);
|
||||||
|
@ -419,7 +419,7 @@ public:
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
NODISCARD inline FuzzedFileProvider ConsumeFile(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
[[nodiscard]] inline FuzzedFileProvider ConsumeFile(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
||||||
{
|
{
|
||||||
return {fuzzed_data_provider};
|
return {fuzzed_data_provider};
|
||||||
}
|
}
|
||||||
|
@ -440,7 +440,7 @@ public:
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
NODISCARD inline FuzzedAutoFileProvider ConsumeAutoFile(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
[[nodiscard]] inline FuzzedAutoFileProvider ConsumeAutoFile(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
||||||
{
|
{
|
||||||
return {fuzzed_data_provider};
|
return {fuzzed_data_provider};
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
/** Parse an HD keypaths like "m/7/0'/2000". */
|
/** Parse an HD keypaths like "m/7/0'/2000". */
|
||||||
NODISCARD bool ParseHDKeypath(const std::string& keypath_str, std::vector<uint32_t>& keypath);
|
[[nodiscard]] bool ParseHDKeypath(const std::string& keypath_str, std::vector<uint32_t>& keypath);
|
||||||
|
|
||||||
/** Write HD keypaths as strings */
|
/** Write HD keypaths as strings */
|
||||||
std::string WriteHDKeypath(const std::vector<uint32_t>& keypath);
|
std::string WriteHDKeypath(const std::vector<uint32_t>& keypath);
|
||||||
|
|
|
@ -19,6 +19,6 @@
|
||||||
*/
|
*/
|
||||||
std::string FormatMoney(const CAmount& n);
|
std::string FormatMoney(const CAmount& n);
|
||||||
/** Parse an amount denoted in full coins. E.g. "0.0034" supplied on the command line. **/
|
/** Parse an amount denoted in full coins. E.g. "0.0034" supplied on the command line. **/
|
||||||
NODISCARD bool ParseMoney(const std::string& str, CAmount& nRet);
|
[[nodiscard]] bool ParseMoney(const std::string& str, CAmount& nRet);
|
||||||
|
|
||||||
#endif // BITCOIN_UTIL_MONEYSTR_H
|
#endif // BITCOIN_UTIL_MONEYSTR_H
|
||||||
|
|
|
@ -280,7 +280,7 @@ std::string DecodeBase32(const std::string& str, bool* pf_invalid)
|
||||||
return std::string((const char*)vchRet.data(), vchRet.size());
|
return std::string((const char*)vchRet.data(), vchRet.size());
|
||||||
}
|
}
|
||||||
|
|
||||||
NODISCARD static bool ParsePrechecks(const std::string& str)
|
[[nodiscard]] static bool ParsePrechecks(const std::string& str)
|
||||||
{
|
{
|
||||||
if (str.empty()) // No empty string allowed
|
if (str.empty()) // No empty string allowed
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -101,42 +101,42 @@ constexpr inline bool IsSpace(char c) noexcept {
|
||||||
* @returns true if the entire string could be parsed as valid integer,
|
* @returns true if the entire string could be parsed as valid integer,
|
||||||
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
||||||
*/
|
*/
|
||||||
NODISCARD bool ParseInt32(const std::string& str, int32_t *out);
|
[[nodiscard]] bool ParseInt32(const std::string& str, int32_t *out);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert string to signed 64-bit integer with strict parse error feedback.
|
* Convert string to signed 64-bit integer with strict parse error feedback.
|
||||||
* @returns true if the entire string could be parsed as valid integer,
|
* @returns true if the entire string could be parsed as valid integer,
|
||||||
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
||||||
*/
|
*/
|
||||||
NODISCARD bool ParseInt64(const std::string& str, int64_t *out);
|
[[nodiscard]] bool ParseInt64(const std::string& str, int64_t *out);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert decimal string to unsigned 8-bit integer with strict parse error feedback.
|
* Convert decimal string to unsigned 8-bit integer with strict parse error feedback.
|
||||||
* @returns true if the entire string could be parsed as valid integer,
|
* @returns true if the entire string could be parsed as valid integer,
|
||||||
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
||||||
*/
|
*/
|
||||||
NODISCARD bool ParseUInt8(const std::string& str, uint8_t *out);
|
[[nodiscard]] bool ParseUInt8(const std::string& str, uint8_t *out);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert decimal string to unsigned 32-bit integer with strict parse error feedback.
|
* Convert decimal string to unsigned 32-bit integer with strict parse error feedback.
|
||||||
* @returns true if the entire string could be parsed as valid integer,
|
* @returns true if the entire string could be parsed as valid integer,
|
||||||
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
||||||
*/
|
*/
|
||||||
NODISCARD bool ParseUInt32(const std::string& str, uint32_t *out);
|
[[nodiscard]] bool ParseUInt32(const std::string& str, uint32_t *out);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert decimal string to unsigned 64-bit integer with strict parse error feedback.
|
* Convert decimal string to unsigned 64-bit integer with strict parse error feedback.
|
||||||
* @returns true if the entire string could be parsed as valid integer,
|
* @returns true if the entire string could be parsed as valid integer,
|
||||||
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
||||||
*/
|
*/
|
||||||
NODISCARD bool ParseUInt64(const std::string& str, uint64_t *out);
|
[[nodiscard]] bool ParseUInt64(const std::string& str, uint64_t *out);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert string to double with strict parse error feedback.
|
* Convert string to double with strict parse error feedback.
|
||||||
* @returns true if the entire string could be parsed as valid double,
|
* @returns true if the entire string could be parsed as valid double,
|
||||||
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
* false if not the entire string could be parsed or when overflow or underflow occurred.
|
||||||
*/
|
*/
|
||||||
NODISCARD bool ParseDouble(const std::string& str, double *out);
|
[[nodiscard]] bool ParseDouble(const std::string& str, double *out);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert a span of bytes to a lower-case hexadecimal string.
|
* Convert a span of bytes to a lower-case hexadecimal string.
|
||||||
|
@ -170,7 +170,7 @@ bool TimingResistantEqual(const T& a, const T& b)
|
||||||
* @returns true on success, false on error.
|
* @returns true on success, false on error.
|
||||||
* @note The result must be in the range (-10^18,10^18), otherwise an overflow error will trigger.
|
* @note The result must be in the range (-10^18,10^18), otherwise an overflow error will trigger.
|
||||||
*/
|
*/
|
||||||
NODISCARD bool ParseFixedPoint(const std::string &val, int decimals, int64_t *amount_out);
|
[[nodiscard]] bool ParseFixedPoint(const std::string &val, int decimals, int64_t *amount_out);
|
||||||
|
|
||||||
/** Convert from one power-of-2 number base to another. */
|
/** Convert from one power-of-2 number base to another. */
|
||||||
template<int frombits, int tobits, bool pad, typename O, typename I>
|
template<int frombits, int tobits, bool pad, typename O, typename I>
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
NODISCARD inline std::string TrimString(const std::string& str, const std::string& pattern = " \f\n\r\t\v")
|
[[nodiscard]] inline std::string TrimString(const std::string& str, const std::string& pattern = " \f\n\r\t\v")
|
||||||
{
|
{
|
||||||
std::string::size_type front = str.find_first_not_of(pattern);
|
std::string::size_type front = str.find_first_not_of(pattern);
|
||||||
if (front == std::string::npos) {
|
if (front == std::string::npos) {
|
||||||
|
@ -59,7 +59,7 @@ inline std::string Join(const std::vector<std::string>& list, const std::string&
|
||||||
/**
|
/**
|
||||||
* Check if a string does not contain any embedded NUL (\0) characters
|
* Check if a string does not contain any embedded NUL (\0) characters
|
||||||
*/
|
*/
|
||||||
NODISCARD inline bool ValidAsCString(const std::string& str) noexcept
|
[[nodiscard]] inline bool ValidAsCString(const std::string& str) noexcept
|
||||||
{
|
{
|
||||||
return str.size() == strlen(str.c_str());
|
return str.size() == strlen(str.c_str());
|
||||||
}
|
}
|
||||||
|
@ -80,7 +80,7 @@ std::string ToString(const T& t)
|
||||||
* Check whether a container begins with the given prefix.
|
* Check whether a container begins with the given prefix.
|
||||||
*/
|
*/
|
||||||
template <typename T1, size_t PREFIX_LEN>
|
template <typename T1, size_t PREFIX_LEN>
|
||||||
NODISCARD inline bool HasPrefix(const T1& obj,
|
[[nodiscard]] inline bool HasPrefix(const T1& obj,
|
||||||
const std::array<uint8_t, PREFIX_LEN>& prefix)
|
const std::array<uint8_t, PREFIX_LEN>& prefix)
|
||||||
{
|
{
|
||||||
return obj.size() >= PREFIX_LEN &&
|
return obj.size() >= PREFIX_LEN &&
|
||||||
|
|
|
@ -188,7 +188,7 @@ protected:
|
||||||
std::map<OptionsCategory, std::map<std::string, Arg>> m_available_args GUARDED_BY(cs_args);
|
std::map<OptionsCategory, std::map<std::string, Arg>> m_available_args GUARDED_BY(cs_args);
|
||||||
std::list<SectionInfo> m_config_sections GUARDED_BY(cs_args);
|
std::list<SectionInfo> m_config_sections GUARDED_BY(cs_args);
|
||||||
|
|
||||||
NODISCARD bool ReadConfigStream(std::istream& stream, const std::string& filepath, std::string& error, bool ignore_invalid_keys = false);
|
[[nodiscard]] bool ReadConfigStream(std::istream& stream, const std::string& filepath, std::string& error, bool ignore_invalid_keys = false);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns true if settings values from the default section should be used,
|
* Returns true if settings values from the default section should be used,
|
||||||
|
@ -220,8 +220,8 @@ public:
|
||||||
*/
|
*/
|
||||||
void SelectConfigNetwork(const std::string& network);
|
void SelectConfigNetwork(const std::string& network);
|
||||||
|
|
||||||
NODISCARD bool ParseParameters(int argc, const char* const argv[], std::string& error);
|
[[nodiscard]] bool ParseParameters(int argc, const char* const argv[], std::string& error);
|
||||||
NODISCARD bool ReadConfigFiles(std::string& error, bool ignore_invalid_keys = false);
|
[[nodiscard]] bool ReadConfigFiles(std::string& error, bool ignore_invalid_keys = false);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Log warnings for options in m_section_only_args when
|
* Log warnings for options in m_section_only_args when
|
||||||
|
|
Loading…
Reference in a new issue