diff options
author | drh <> | 2023-03-22 16:24:17 +0000 |
---|---|---|
committer | drh <> | 2023-03-22 16:24:17 +0000 |
commit | c408c155d7d65f9d00e93d61449fce018d0f242b (patch) | |
tree | 7e8c49b9879eda4ef6e8f77fb8d5960c34abbabb /src | |
parent | 8854f30295cb35cb5d6185aed84d2fe6336dcf8a (diff) | |
parent | 667b5cc985d68f0f63e67a2888d0ec36c83a1688 (diff) | |
download | sqlite-c408c155d7d65f9d00e93d61449fce018d0f242b.tar.gz sqlite-c408c155d7d65f9d00e93d61449fce018d0f242b.zip |
The double-to-text conversion renders infinity as 9e999, so that JSON
output is compliant and so that values can be round-tripped.
FossilOrigin-Name: b52081d0acd07dc5bdb4951a3e8419866131965260c1e3a4c9b6e673bfe3dfea
Diffstat (limited to 'src')
-rw-r--r-- | src/json.c | 5 | ||||
-rw-r--r-- | src/printf.c | 15 |
2 files changed, 14 insertions, 6 deletions
diff --git a/src/json.c b/src/json.c index 67448421b..9783a3898 100644 --- a/src/json.c +++ b/src/json.c @@ -307,8 +307,11 @@ static void jsonAppendValue( jsonAppendRaw(p, "null", 4); break; } - case SQLITE_INTEGER: case SQLITE_FLOAT: { + jsonPrintf(100, p, "%!0.15g", sqlite3_value_double(pValue)); + break; + } + case SQLITE_INTEGER: { const char *z = (const char*)sqlite3_value_text(pValue); u32 n = (u32)sqlite3_value_bytes(pValue); jsonAppendRaw(p, z, n); diff --git a/src/printf.c b/src/printf.c index b222cb214..d59855917 100644 --- a/src/printf.c +++ b/src/printf.c @@ -601,11 +601,16 @@ void sqlite3_str_vappendf( while( realvalue<1e-8 ){ realvalue *= 1e8; exp-=8; } while( realvalue<1.0 ){ realvalue *= 10.0; exp--; } if( exp>350 ){ - bufpt = buf; - buf[0] = prefix; - memcpy(buf+(prefix!=0),"Inf",4); - length = 3+(prefix!=0); - break; + if( flag_zeropad ){ + realvalue = 9.0; + exp = 999; + }else{ + bufpt = buf; + buf[0] = prefix; + memcpy(buf+(prefix!=0),"Inf",4); + length = 3+(prefix!=0); + break; + } } if( xtype!=etFLOAT ){ realvalue += rounder; |