mirror of
https://github.com/nlohmann/json
synced 2024-11-23 20:40:08 +00:00
🚨 fixed a compiler warning #527
The result of snprintf is later used in situations where a long may overflow.
This commit is contained in:
parent
67a06834b0
commit
d60851168e
11
src/json.hpp
11
src/json.hpp
@ -6929,8 +6929,8 @@ class basic_json
|
||||
static constexpr auto d = std::numeric_limits<number_float_t>::digits10;
|
||||
|
||||
// the actual conversion
|
||||
long len = snprintf(number_buffer.data(), number_buffer.size(),
|
||||
"%.*g", d, x);
|
||||
std::ptrdiff_t len = snprintf(number_buffer.data(), number_buffer.size(),
|
||||
"%.*g", d, x);
|
||||
|
||||
// negative value indicates an error
|
||||
assert(len > 0);
|
||||
@ -10429,10 +10429,9 @@ class basic_json
|
||||
|
||||
Proof (by contradiction): Assume a finite input. To loop forever, the
|
||||
loop must never hit code with a `break` statement. The only code
|
||||
snippets without a `break` statement are the continue statements for
|
||||
whitespace and byte-order-marks. To loop forever, the input must be an
|
||||
infinite sequence of whitespace or byte-order-marks. This contradicts
|
||||
the assumption of finite input, q.e.d.
|
||||
snippets without a `break` statement is the continue statement for
|
||||
whitespace. To loop forever, the input must be an infinite sequence
|
||||
whitespace. This contradicts the assumption of finite input, q.e.d.
|
||||
*/
|
||||
token_type scan()
|
||||
{
|
||||
|
@ -6929,8 +6929,8 @@ class basic_json
|
||||
static constexpr auto d = std::numeric_limits<number_float_t>::digits10;
|
||||
|
||||
// the actual conversion
|
||||
long len = snprintf(number_buffer.data(), number_buffer.size(),
|
||||
"%.*g", d, x);
|
||||
std::ptrdiff_t len = snprintf(number_buffer.data(), number_buffer.size(),
|
||||
"%.*g", d, x);
|
||||
|
||||
// negative value indicates an error
|
||||
assert(len > 0);
|
||||
@ -10429,10 +10429,9 @@ class basic_json
|
||||
|
||||
Proof (by contradiction): Assume a finite input. To loop forever, the
|
||||
loop must never hit code with a `break` statement. The only code
|
||||
snippets without a `break` statement are the continue statements for
|
||||
whitespace and byte-order-marks. To loop forever, the input must be an
|
||||
infinite sequence of whitespace or byte-order-marks. This contradicts
|
||||
the assumption of finite input, q.e.d.
|
||||
snippets without a `break` statement is the continue statement for
|
||||
whitespace. To loop forever, the input must be an infinite sequence
|
||||
whitespace. This contradicts the assumption of finite input, q.e.d.
|
||||
*/
|
||||
token_type scan()
|
||||
{
|
||||
|
Loading…
Reference in New Issue
Block a user