mirror of
https://github.com/nlohmann/json
synced 2024-11-27 22:30:09 +00:00
Merge branch 'develop' into feature/issue698
This commit is contained in:
commit
54bd1b5124
23
src/json.hpp
23
src/json.hpp
@ -6659,17 +6659,16 @@ class serializer
|
||||
const bool is_negative = std::is_same<NumberType, number_integer_t>::value and (x < 0);
|
||||
std::size_t i = 0;
|
||||
|
||||
// spare 1 byte for '\0'
|
||||
while (x != 0 and i < number_buffer.size() - 1)
|
||||
while (x != 0)
|
||||
{
|
||||
// spare 1 byte for '\0'
|
||||
assert(i < number_buffer.size() - 1);
|
||||
|
||||
const auto digit = std::labs(static_cast<long>(x % 10));
|
||||
number_buffer[i++] = static_cast<char>('0' + digit);
|
||||
x /= 10;
|
||||
}
|
||||
|
||||
// make sure the number has been processed completely
|
||||
assert(x == 0);
|
||||
|
||||
if (is_negative)
|
||||
{
|
||||
// make sure there is capacity for the '-'
|
||||
@ -6698,20 +6697,6 @@ class serializer
|
||||
return;
|
||||
}
|
||||
|
||||
// special case for 0.0 and -0.0
|
||||
if (x == 0)
|
||||
{
|
||||
if (std::signbit(x))
|
||||
{
|
||||
o->write_characters("-0.0", 4);
|
||||
}
|
||||
else
|
||||
{
|
||||
o->write_characters("0.0", 3);
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
// get number of digits for a text -> float -> text round-trip
|
||||
static constexpr auto d = std::numeric_limits<number_float_t>::digits10;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user