mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-26 11:13:23 -03:00
refactor: Enforce lowercase hex digits for consteval uint256
Also changes compile-time asserts with comments into throws.
This commit is contained in:
parent
4ee1940e84
commit
7e1d9a8468
3 changed files with 5 additions and 6 deletions
|
@ -177,7 +177,7 @@ void sanity_check_chainparams(const ArgsManager& args, ChainType chain_type)
|
||||||
|
|
||||||
// check max target * 4*nPowTargetTimespan doesn't overflow -- see pow.cpp:CalculateNextWorkRequired()
|
// check max target * 4*nPowTargetTimespan doesn't overflow -- see pow.cpp:CalculateNextWorkRequired()
|
||||||
if (!consensus.fPowNoRetargeting) {
|
if (!consensus.fPowNoRetargeting) {
|
||||||
arith_uint256 targ_max{UintToArith256(uint256{"FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF"})};
|
arith_uint256 targ_max{UintToArith256(uint256{"ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"})};
|
||||||
targ_max /= consensus.nPowTargetTimespan*4;
|
targ_max /= consensus.nPowTargetTimespan*4;
|
||||||
BOOST_CHECK(UintToArith256(consensus.powLimit) < targ_max);
|
BOOST_CHECK(UintToArith256(consensus.powLimit) < targ_max);
|
||||||
}
|
}
|
||||||
|
|
|
@ -431,7 +431,7 @@ BOOST_AUTO_TEST_CASE( check_ONE )
|
||||||
BOOST_AUTO_TEST_CASE(FromHex_vs_uint256)
|
BOOST_AUTO_TEST_CASE(FromHex_vs_uint256)
|
||||||
{
|
{
|
||||||
auto runtime_uint{uint256::FromHex("4A5E1E4BAAB89F3A32518A88C31BC87F618f76673e2cc77ab2127b7afdeda33b").value()};
|
auto runtime_uint{uint256::FromHex("4A5E1E4BAAB89F3A32518A88C31BC87F618f76673e2cc77ab2127b7afdeda33b").value()};
|
||||||
constexpr uint256 consteval_uint{ "4a5e1e4baab89f3a32518a88c31bc87f618F76673E2CC77AB2127B7AFDEDA33B"};
|
constexpr uint256 consteval_uint{ "4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab2127b7afdeda33b"};
|
||||||
BOOST_CHECK_EQUAL(consteval_uint, runtime_uint);
|
BOOST_CHECK_EQUAL(consteval_uint, runtime_uint);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -130,13 +130,12 @@ consteval base_blob<BITS>::base_blob(std::string_view hex_str)
|
||||||
// Non-lookup table version of HexDigit().
|
// Non-lookup table version of HexDigit().
|
||||||
auto from_hex = [](const char c) -> int8_t {
|
auto from_hex = [](const char c) -> int8_t {
|
||||||
if (c >= '0' && c <= '9') return c - '0';
|
if (c >= '0' && c <= '9') return c - '0';
|
||||||
if (c >= 'a' && c <= 'f') return c - 'a' + 0xA;
|
if (c >= 'a' && c <= 'f') return c - 'a' + 0xa;
|
||||||
if (c >= 'A' && c <= 'F') return c - 'A' + 0xA;
|
|
||||||
|
|
||||||
assert(false); // Reached if ctor is called with an invalid hex digit.
|
throw "Only lowercase hex digits are allowed, for consistency";
|
||||||
};
|
};
|
||||||
|
|
||||||
assert(hex_str.length() == m_data.size() * 2); // 2 hex digits per byte.
|
if (hex_str.length() != m_data.size() * 2) throw "Hex string must fit exactly";
|
||||||
auto str_it = hex_str.rbegin();
|
auto str_it = hex_str.rbegin();
|
||||||
for (auto& elem : m_data) {
|
for (auto& elem : m_data) {
|
||||||
auto lo = from_hex(*(str_it++));
|
auto lo = from_hex(*(str_it++));
|
||||||
|
|
Loading…
Add table
Reference in a new issue