Kaydet (Commit) 85c0b894 authored tarafından Serhiy Storchaka's avatar Serhiy Storchaka Kaydeden (comit) GitHub

bpo-31619: Fixed a ValueError when convert a string with large number of underscores (#3827)

to integer with binary base.
üst 1a87de7f
...@@ -508,5 +508,13 @@ class IntTestCases(unittest.TestCase): ...@@ -508,5 +508,13 @@ class IntTestCases(unittest.TestCase):
check('123\ud800') check('123\ud800')
check('123\ud800', 10) check('123\ud800', 10)
def test_issue31619(self):
self.assertEqual(int('1_0_1_0_1_0_1_0_1_0_1_0_1_0_1_0_1_0_1_0_1_0_1_0_1_0_1_0_1_0_1', 2),
0b1010101010101010101010101010101)
self.assertEqual(int('1_2_3_4_5_6_7_0_1_2_3', 8), 0o12345670123)
self.assertEqual(int('1_2_3_4_5_6_7_8_9', 16), 0x123456789)
self.assertEqual(int('1_2_3_4_5_6_7', 32), 1144132807)
if __name__ == "__main__": if __name__ == "__main__":
unittest.main() unittest.main()
Fixed a ValueError when convert a string with large number of underscores
to integer with binary base.
...@@ -2057,15 +2057,15 @@ long_from_binary_base(const char **str, int base, PyLongObject **res) ...@@ -2057,15 +2057,15 @@ long_from_binary_base(const char **str, int base, PyLongObject **res)
} }
*str = p; *str = p;
/* n <- # of Python digits needed, = ceiling(n/PyLong_SHIFT). */ /* n <- the number of Python digits needed,
n = digits * bits_per_char + PyLong_SHIFT - 1; = ceiling((digits * bits_per_char) / PyLong_SHIFT). */
if (n / bits_per_char < p - start) { if (digits > (PY_SSIZE_T_MAX - (PyLong_SHIFT - 1)) / bits_per_char) {
PyErr_SetString(PyExc_ValueError, PyErr_SetString(PyExc_ValueError,
"int string too large to convert"); "int string too large to convert");
*res = NULL; *res = NULL;
return 0; return 0;
} }
n = n / PyLong_SHIFT; n = (digits * bits_per_char + PyLong_SHIFT - 1) / PyLong_SHIFT;
z = _PyLong_New(n); z = _PyLong_New(n);
if (z == NULL) { if (z == NULL) {
*res = NULL; *res = NULL;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment