From 7967d23ea4be369adeb1ef3ee2faa24595c4d3f0 Mon Sep 17 00:00:00 2001 From: Kun Zhou Date: Mon, 13 Nov 2023 19:25:07 -0800 Subject: [PATCH] Fix big number accuracy --- lib/packets/packet.js | 20 ++++++++------------ 1 file changed, 8 insertions(+), 12 deletions(-) diff --git a/lib/packets/packet.js b/lib/packets/packet.js index ccf3a8458cf..f5989b892d8 100644 --- a/lib/packets/packet.js +++ b/lib/packets/packet.js @@ -222,9 +222,8 @@ class Packet { return word1 * 0x100000000 + word0; } res = new Long(word0, word1, !signed); // Long need unsigned - const resNumber = res.toNumber(); const resString = res.toString(); - res = resNumber.toString() === resString ? resNumber : resString; + res = res.greaterThan(Number.MAX_SAFE_INTEGER) ? res.toNumber() : resString; return bigNumberStrings ? resString : res; } // eslint-disable-next-line no-console @@ -425,7 +424,7 @@ class Packet { return StringParser.decode( this.buffer, encoding, - this.offset - len, + this.offset - len, this.offset ); } @@ -456,15 +455,12 @@ class Packet { if (supportBigNumbers) { if (numDigits >= 15) { str = this.readString(end - this.offset, 'binary'); - result = parseInt(str, 10); - if (result.toString() === str) { - return sign * result; - } - return sign === -1 ? `-${str}` : str; - } - if (numDigits > 16) { - str = this.readString(end - this.offset); - return sign === -1 ? `-${str}` : str; + str = sign === -1 ? `-${str}` : str; + result = Long.fromString(str, false, 10); + if (result.greaterThan(Long.MAX_SAFE_INTEGER) || result.lessThan(Long.MIN_SAFE_INTEGER)) { + return result; + } + return result.toNumber(); } } if (this.buffer[this.offset] === plus) {