mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-11-12 23:18:14 +01:00
util: Introduce ToIntegral<T>(const std::string&) for locale independent parsing using std::from_chars(…) (C++17)
util: Avoid locale dependent functions strtol/strtoll/strtoul/strtoull in ParseInt32/ParseInt64/ParseUInt32/ParseUInt64
fuzz: Assert equivalence between new and old Parse{Int,Uint}{8,32,64} functions
test: Add unit tests for ToIntegral<T>(const std::string&)
This commit is contained in:
@@ -1474,6 +1474,81 @@ BOOST_AUTO_TEST_CASE(test_ParseInt32)
|
||||
BOOST_CHECK(!ParseInt32("32482348723847471234", nullptr));
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(test_ToIntegral)
|
||||
{
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int32_t>("1234").value(), 1'234);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int32_t>("0").value(), 0);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int32_t>("01234").value(), 1'234);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int32_t>("00000000000000001234").value(), 1'234);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int32_t>("-00000000000000001234").value(), -1'234);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int32_t>("00000000000000000000").value(), 0);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int32_t>("-00000000000000000000").value(), 0);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int32_t>("-1234").value(), -1'234);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int32_t>("-1").value(), -1);
|
||||
|
||||
BOOST_CHECK(!ToIntegral<int32_t>(" 1"));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("1 "));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("1a"));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("1.1"));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("1.9"));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("+01.9"));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>(" -1"));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("-1 "));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>(" -1 "));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("+1"));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>(" +1"));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>(" +1 "));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("+-1"));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("-+1"));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("++1"));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("--1"));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>(""));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("aap"));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("0x1"));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("-32482348723847471234"));
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("32482348723847471234"));
|
||||
|
||||
BOOST_CHECK(!ToIntegral<int64_t>("-9223372036854775809"));
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int64_t>("-9223372036854775808").value(), -9'223'372'036'854'775'807LL - 1LL);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int64_t>("9223372036854775807").value(), 9'223'372'036'854'775'807);
|
||||
BOOST_CHECK(!ToIntegral<int64_t>("9223372036854775808"));
|
||||
|
||||
BOOST_CHECK(!ToIntegral<uint64_t>("-1"));
|
||||
BOOST_CHECK_EQUAL(ToIntegral<uint64_t>("0").value(), 0U);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<uint64_t>("18446744073709551615").value(), 18'446'744'073'709'551'615ULL);
|
||||
BOOST_CHECK(!ToIntegral<uint64_t>("18446744073709551616"));
|
||||
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("-2147483649"));
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int32_t>("-2147483648").value(), -2'147'483'648LL);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int32_t>("2147483647").value(), 2'147'483'647);
|
||||
BOOST_CHECK(!ToIntegral<int32_t>("2147483648"));
|
||||
|
||||
BOOST_CHECK(!ToIntegral<uint32_t>("-1"));
|
||||
BOOST_CHECK_EQUAL(ToIntegral<uint32_t>("0").value(), 0U);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<uint32_t>("4294967295").value(), 4'294'967'295U);
|
||||
BOOST_CHECK(!ToIntegral<uint32_t>("4294967296"));
|
||||
|
||||
BOOST_CHECK(!ToIntegral<int16_t>("-32769"));
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int16_t>("-32768").value(), -32'768);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int16_t>("32767").value(), 32'767);
|
||||
BOOST_CHECK(!ToIntegral<int16_t>("32768"));
|
||||
|
||||
BOOST_CHECK(!ToIntegral<uint16_t>("-1"));
|
||||
BOOST_CHECK_EQUAL(ToIntegral<uint16_t>("0").value(), 0U);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<uint16_t>("65535").value(), 65'535U);
|
||||
BOOST_CHECK(!ToIntegral<uint16_t>("65536"));
|
||||
|
||||
BOOST_CHECK(!ToIntegral<int8_t>("-129"));
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int8_t>("-128").value(), -128);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<int8_t>("127").value(), 127);
|
||||
BOOST_CHECK(!ToIntegral<int8_t>("128"));
|
||||
|
||||
BOOST_CHECK(!ToIntegral<uint8_t>("-1"));
|
||||
BOOST_CHECK_EQUAL(ToIntegral<uint8_t>("0").value(), 0U);
|
||||
BOOST_CHECK_EQUAL(ToIntegral<uint8_t>("255").value(), 255U);
|
||||
BOOST_CHECK(!ToIntegral<uint8_t>("256"));
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(test_ParseInt64)
|
||||
{
|
||||
int64_t n;
|
||||
|
||||
Reference in New Issue
Block a user