[Development] JSON 64 bit int
Thiago Macieira
thiago.macieira at intel.com
Wed Feb 11 22:11:09 CET 2015
On Wednesday 11 February 2015 21:26:40 Marc Mutz wrote:
> The interesting part is what Qt should do about it. Postel's Law clearly
> asks
> for accepting (even invalid) input as long as its meaning is clear. Clearly,
> that is the case for larger-than-double numbers. So, by Postel's Law, Qt
> should strive to support them. If you apply the law to the API side of
> QtJSON, then it should do so even for writing. So Bo has a valid point.
Accepting is one thing. But if we do this, we need to be able to generate 64-
bit integers. Think of this: what happens if you do a pass-through
QJsonDocument of data outside of JSON documents? Should QJsonDocument:
1) output invalid data because it arrived in such a way?
2) silently lose up to 11 bits of precision?
If we chose #1, then the follow-up question is what happens if you extract the
data to your structure and want to re-create the JSON document -- you wouldn't
be able to.
> If long double was any useful (apparently it's no larger than double on
> Windows), we could use that, but as it stands, that would be pointless.
There are very few architectures that support 80- or 128-bit precision floating
point in hardware. x86 is one of them, but unlike single- and double-precision
modes, the extended-precision support did not make the transition to the SSE
world. That means x86-64 does support the type natively, but requires use of
the expensive x87 unit and 32-bit style calling conventions.
--
Thiago Macieira - thiago.macieira (AT) intel.com
Software Architect - Intel Open Source Technology Center
More information about the Development
mailing list