core icon indicating copy to clipboard operation
core copied to clipboard

Overflow issue when converting integers near maxint

Open richcarl opened this issue 1 year ago • 1 comments

10 * total + code - 0x30 needs to be 10 * total + (code - 0x30), otherwise this overflows the integer range when converting values close to maxint (2^53 - 1 = 9007199254740991 with a JS backend). For example:

    > String.toInt "9007199254740945"
    Just 9007199254740944 : Maybe Int
    > String.toInt "9007199254740991"
    Just 9007199254740992 : Maybe Int

https://github.com/elm/core/blob/84f38891468e8e153fc85a9b63bdafd81b24664e/src/Elm/Kernel/String.js#L291C24-L291C35

I would expect this function to always give an exact result whenever the integer literal fits into the available range for integers, but this is currently not true.

richcarl avatar Oct 06 '23 17:10 richcarl

Thanks for reporting this! To set expectations:

  • Issues are reviewed in batches, so it can take some time to get a response.
  • Ask questions a community forum. You will get an answer quicker that way!
  • If you experience something similar, open a new issue. We like duplicates.

Finally, please be patient with the core team. They are trying their best with limited resources.

github-actions[bot] avatar Oct 06 '23 17:10 github-actions[bot]