-
-
Notifications
You must be signed in to change notification settings - Fork 271
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Implementation-defined encoding of NaN
values in JS engines
#895
Comments
I don't think there's a solution here. The only potential solution is to use WebAssembly. Though this would complicate the whole thing for users: instead of having single self-sufficient file, they'll end up with some non-trivial setup, including some HTTP server (WebAssembly does not work from local file system) and which is different for browser, Node.js, etc. Also, I have a use-case where I run TeaVM-generated JS in Rhino and it works just fine. Having So I suggest to leave this as is, until there's an update in JS standard which allows to convert without loss of data. Perhaps, add a note to the contributor's documentation that in Firefox some tests may fail. @tryone144 are you agree? Do you have another solution in mind? |
I personally think we are in a bad position to require anything. This is more of an issue with how the JavaScript engines are designed and how the specification does not enforce either behavior. We can't really do anything about this other than to roll our own
Yes, I totally agree. I don't have a practical workaround. This issue itself was meant to at least document this behavior for the future. Adding a comment to the relevant functions/tests is a good idea. I can't think of legitimate reasons to convert non-canonical |
Most JavaScript engines perform NaN-canonicalization. This results in information loss when converting a long to a double and back, iff the bits encode a non-canonical NaN value. V8 in chrome seems to be an exception that keeps the bits intact. See: konsoletyper#895 Related: 8277671
Most JavaScript engines perform NaN-canonicalization. This results in information loss when converting a long to a double and back, iff the bits encode a non-canonical NaN value. V8 in chrome seems to be an exception that keeps the bits intact. See: konsoletyper#895 Related: 8277671
Related to the changes in 8277671 (#749), assertions that test for bit specific values of
OTHER_NAN
(either Double or Float) depend on potentially implementation specific handling ofNaN
values in the underlying JS engine (and fail in firefox).Notably, V8 (in chrome) appears to keep the bit-pattern of different NaN values intact when writing to and reading from
DataView
s (and typed arrays), while SpiderMonkey (in firefox) does not and canonicalizes NaN values when reading from aDataView
(and typed arrays)1.The ECMAScript specification is not worded explicitly enough for either behaviour to be against the spec (while reading). The write case explicitly mentions that an implementation must keep the encoding of distinguishable NaN values in a way that they stay distinguishable. It appears there is no consensus on what the correct behaviour is (from a performance and security perspective).
Given the current state, I don't think we can rely on the internal bit-encoding of NaN values to survive the
long -> double -> long
orint -> float -> int
conversion which is required by thedoubleToRawLongBits()
andfloatToRawIntBits()
methods.Edit: JavaScriptCore in Webkit (or Nitro as it is called in Safari) seem to follow SpiderMonkey in canonicalizing
NaN
values.Potentially related discussions in the spidermonkey case:
Their stance on normalizing doubles (and
NaN
s) is linked to internal double-boxing which usesNaN
doubles as object pointers.Footnotes
See TypedArrayObject.cpp and DataViewObject.cpp in SpiderMonkey. ↩
The text was updated successfully, but these errors were encountered: