🚨 fixed a compiler warning #527

The result of snprintf is later used in situations where a long may
overflow.
This commit is contained in:
Niels Lohmann 2017-03-22 08:10:02 +01:00
parent 67a06834b0
commit d60851168e
No known key found for this signature in database
GPG key ID: 7F3CEA63AE251B69
2 changed files with 10 additions and 12 deletions

View file

@ -6929,7 +6929,7 @@ 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(),
std::ptrdiff_t len = snprintf(number_buffer.data(), number_buffer.size(),
"%.*g", d, x);
// negative value indicates an error
@ -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()
{

View file

@ -6929,7 +6929,7 @@ 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(),
std::ptrdiff_t len = snprintf(number_buffer.data(), number_buffer.size(),
"%.*g", d, x);
// negative value indicates an error
@ -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()
{