Tweaked check for preserved sign; added LCOV_EXCL_LINE
This commit is contained in:
parent
1c029b97c0
commit
cd0b651d43
1 changed files with 4 additions and 4 deletions
|
@ -9103,7 +9103,7 @@ basic_json_parser_66:
|
||||||
|
|
||||||
if (!p)
|
if (!p)
|
||||||
{
|
{
|
||||||
return false;
|
return false; // LCOV_EXCL_LINE
|
||||||
}
|
}
|
||||||
|
|
||||||
if (*p == '-' or *p == '+')
|
if (*p == '-' or *p == '+')
|
||||||
|
@ -9113,7 +9113,7 @@ basic_json_parser_66:
|
||||||
|
|
||||||
if (p == m_end)
|
if (p == m_end)
|
||||||
{
|
{
|
||||||
return false;
|
return false; // LCOV_EXCL_LINE
|
||||||
}
|
}
|
||||||
|
|
||||||
while (p < m_end and *p >= '0'
|
while (p < m_end and *p >= '0'
|
||||||
|
@ -9252,11 +9252,11 @@ basic_json_parser_66:
|
||||||
value = static_cast<T>(x);
|
value = static_cast<T>(x);
|
||||||
|
|
||||||
return x == static_cast<decltype(x)>(value) // x fits into destination T
|
return x == static_cast<decltype(x)>(value) // x fits into destination T
|
||||||
|
and (x < 0) == (value < 0) // preserved sign
|
||||||
and (x != 0 or is_integral()) // strto[u]ll did nto fail
|
and (x != 0 or is_integral()) // strto[u]ll did nto fail
|
||||||
and errno == 0 // strto[u]ll did not overflow
|
and errno == 0 // strto[u]ll did not overflow
|
||||||
and m_start < m_end // token was not empty
|
and m_start < m_end // token was not empty
|
||||||
and endptr == m_end // parsed entire token exactly
|
and endptr == m_end; // parsed entire token exactly
|
||||||
and (x < 0) == (*m_start == '-'); // input was sign-compatible
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#else // parsing integral types manually
|
#else // parsing integral types manually
|
||||||
|
|
Loading…
Reference in a new issue