Commit 07e14766 authored by Walter Dörwald's avatar Walter Dörwald

Make int("...") return a long if an int would overflow.

Also remove the 512 character limitation for int(u"...") and long(u"...").

This closes SF bug #629989.
parent aca49b06
...@@ -435,10 +435,8 @@ if int(s)+1 != -sys.maxint: ...@@ -435,10 +435,8 @@ if int(s)+1 != -sys.maxint:
raise TestFailed, "int(%s)" % `s` raise TestFailed, "int(%s)" % `s`
try: try:
int(s[1:]) int(s[1:])
except ValueError: except:
pass raise TestFailed, "int(%s)" % `s[1:]` + " should return long"
else:
raise TestFailed, "int(%s)" % `s[1:]` + " should raise ValueError"
try: try:
int(1e100) int(1e100)
except OverflowError: except OverflowError:
...@@ -468,9 +466,12 @@ try: int('53', 40) ...@@ -468,9 +466,12 @@ try: int('53', 40)
except ValueError: pass except ValueError: pass
else: raise TestFailed("int('53', 40) didn't raise ValueError") else: raise TestFailed("int('53', 40) didn't raise ValueError")
try: int('1' * 512) try: int('1' * 600)
except ValueError: pass except: raise TestFailed("int('1' * 600) didn't return long")
else: raise TestFailed("int('1' * 512) didn't raise ValueError")
if have_unicode:
try: int(unichr(0x661) * 600)
except: raise TestFailed("int('\\u0661' * 600) didn't return long")
try: int(1, 12) try: int(1, 12)
except TypeError: pass except TypeError: pass
......
...@@ -208,10 +208,9 @@ PyInt_FromString(char *s, char **pend, int base) ...@@ -208,10 +208,9 @@ PyInt_FromString(char *s, char **pend, int base)
return NULL; return NULL;
} }
else if (errno != 0) { else if (errno != 0) {
PyOS_snprintf(buffer, sizeof(buffer), if (err_ovf("string/unicode conversion"))
"int() literal too large: %.200s", s); return NULL;
PyErr_SetString(PyExc_ValueError, buffer); return PyLong_FromString(s, pend, base);
return NULL;
} }
if (pend) if (pend)
*pend = end; *pend = end;
...@@ -222,16 +221,19 @@ PyInt_FromString(char *s, char **pend, int base) ...@@ -222,16 +221,19 @@ PyInt_FromString(char *s, char **pend, int base)
PyObject * PyObject *
PyInt_FromUnicode(Py_UNICODE *s, int length, int base) PyInt_FromUnicode(Py_UNICODE *s, int length, int base)
{ {
char buffer[256]; PyObject *result;
char *buffer = PyMem_MALLOC(length+1);
if (length >= sizeof(buffer)) { if (buffer == NULL)
PyErr_SetString(PyExc_ValueError,
"int() literal too large to convert");
return NULL; return NULL;
}
if (PyUnicode_EncodeDecimal(s, length, buffer, NULL)) if (PyUnicode_EncodeDecimal(s, length, buffer, NULL)) {
PyMem_FREE(buffer);
return NULL; return NULL;
return PyInt_FromString(buffer, NULL, base); }
result = PyInt_FromString(buffer, NULL, base);
PyMem_FREE(buffer);
return result;
} }
#endif #endif
......
...@@ -1123,17 +1123,19 @@ PyLong_FromString(char *str, char **pend, int base) ...@@ -1123,17 +1123,19 @@ PyLong_FromString(char *str, char **pend, int base)
PyObject * PyObject *
PyLong_FromUnicode(Py_UNICODE *u, int length, int base) PyLong_FromUnicode(Py_UNICODE *u, int length, int base)
{ {
char buffer[256]; PyObject *result;
char *buffer = PyMem_MALLOC(length+1);
if (length >= sizeof(buffer)) { if (buffer == NULL)
PyErr_SetString(PyExc_ValueError,
"long() literal too large to convert");
return NULL;
}
if (PyUnicode_EncodeDecimal(u, length, buffer, NULL))
return NULL; return NULL;
return PyLong_FromString(buffer, NULL, base); if (PyUnicode_EncodeDecimal(u, length, buffer, NULL)) {
PyMem_FREE(buffer);
return NULL;
}
result = PyLong_FromString(buffer, NULL, base);
PyMem_FREE(buffer);
return result;
} }
#endif #endif
......
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