-
Notifications
You must be signed in to change notification settings - Fork 47
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
Can't convert BigInt to Decimal without setting its value to 0 #142
Comments
Woah, I haven't seen this '2n' thing before. Is it a new Javascript feature? |
The syntax used describes something called For more information on BigInts, see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/BigInt |
Cutting edge! I'll take a look at supporting BigInts if I find the time and mood. |
You can convert a BigInt to a String with Number("1".repeat(309))
1.1111111111111112e+308
Number("1".repeat(310))
Infinity |
I guess it'd be sufficient to detect the string is longer than 300 digits, grab the first 18 of them, and turn it into mantissa and exponent. |
Now, lambert-w has 200 iterations to get more accurate results. Also, converting BigInts to Decimals is now possible! (new Decimal(12345n**12345n).toString() outputs 2.867865225007882e50509)
#145 will fix it |
Couldn't you |
but that's what #145 does. |
Currently (latest
break_eternity.js
version as of 2023-01-07), attempting to convert a BigInt value to Decimal will return 0. Furthermore, a string that represents a number (generated byBigInt.toString()
) will also return 0 if the number the string represents is at least 21024.Console output with test cases:
Discovered whilst writing migration code for an incremental game to convert various save data from BigInt values to their proper Decimals.
The text was updated successfully, but these errors were encountered: