From 23726b8ea0fb1b2c6fa085cd7493f4d83cbef9f7 Mon Sep 17 00:00:00 2001 From: konsoletyper Date: Mon, 16 Jun 2014 16:11:38 +0400 Subject: [PATCH] Fixes incorrect long to double conversion --- .../main/resources/org/teavm/javascript/runtime.js | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/teavm-core/src/main/resources/org/teavm/javascript/runtime.js b/teavm-core/src/main/resources/org/teavm/javascript/runtime.js index 90151adde..595ff94fc 100644 --- a/teavm-core/src/main/resources/org/teavm/javascript/runtime.js +++ b/teavm-core/src/main/resources/org/teavm/javascript/runtime.js @@ -394,7 +394,12 @@ Long_fromNumber = function(val) { return new Long(val | 0, (val / 0x100000000) | 0); } Long_toNumber = function(val) { - return val.hi >= 0 ? val.lo + 0x100000000 * val.hi : -0x100000000 * (val.hi ^ 0xFFFFFFFF) + val.lo; + var lo = val.lo; + var hi = val.hi; + if (lo < 0) { + lo += 0x100000000; + } + return 0x100000000 * hi + lo; } Long_add = function(a, b) { var a_lolo = a.lo & 0xFFFF; @@ -410,8 +415,7 @@ Long_add = function(a, b) { var lohi = (a_lohi + b_lohi + (lolo >> 16)) | 0; var hilo = (a_hilo + b_hilo + (lohi >> 16)) | 0; var hihi = (a_hihi + b_hihi + (hilo >> 16)) | 0; - return new Long((lolo & 0xFFFF) | ((lohi & 0xFFFF) << 16), - (hilo & 0xFFFF) | ((hihi & 0xFFFF) << 16)); + return new Long((lolo & 0xFFFF) | ((lohi & 0xFFFF) << 16), (hilo & 0xFFFF) | ((hihi & 0xFFFF) << 16)); } Long_inc = function(a) { var lo = (a.lo + 1) | 0; @@ -446,8 +450,7 @@ Long_sub = function(a, b) { var lohi = (a_lohi - b_lohi + (lolo >> 16)) | 0; var hilo = (a_hilo - b_hilo + (lohi >> 16)) | 0; var hihi = (a_hihi - b_hihi + (hilo >> 16)) | 0; - return new Long((lolo & 0xFFFF) | ((lohi & 0xFFFF) << 16), - (hilo & 0xFFFF) | ((hihi & 0xFFFF) << 16)); + return new Long((lolo & 0xFFFF) | ((lohi & 0xFFFF) << 16), (hilo & 0xFFFF) | ((hihi & 0xFFFF) << 16)); } Long_compare = function(a, b) { var r = a.hi - b.hi;