From: Mark Dickinson Date: Thu, 3 Dec 2009 12:08:56 +0000 (+0000) Subject: Issue #6985: number of range() items should be constrained to lie X-Git-Tag: v2.7a1~8 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=3dc254181abe0297b917eefb591af92a4a90598e;p=thirdparty%2FPython%2Fcpython.git Issue #6985: number of range() items should be constrained to lie in a Py_ssize_t, not an int. --- diff --git a/Python/bltinmodule.c b/Python/bltinmodule.c index 80fc9b42448b..b201aaf78775 100644 --- a/Python/bltinmodule.c +++ b/Python/bltinmodule.c @@ -1754,7 +1754,7 @@ handle_range_longs(PyObject *self, PyObject *args) PyObject *curnum = NULL; PyObject *v = NULL; long bign; - int i, n; + Py_ssize_t i, n; int cmp_result; PyObject *zero = PyLong_FromLong(0); @@ -1834,7 +1834,7 @@ handle_range_longs(PyObject *self, PyObject *args) Py_DECREF(neg_istep); } - n = (int)bign; + n = (Py_ssize_t)bign; if (bign < 0 || (long)n != bign) { PyErr_SetString(PyExc_OverflowError, "range() result has too many items"); @@ -1914,7 +1914,7 @@ builtin_range(PyObject *self, PyObject *args) { long ilow = 0, ihigh = 0, istep = 1; long bign; - int i, n; + Py_ssize_t i, n; PyObject *v; @@ -1943,7 +1943,7 @@ builtin_range(PyObject *self, PyObject *args) bign = get_len_of_range(ilow, ihigh, istep); else bign = get_len_of_range(ihigh, ilow, -istep); - n = (int)bign; + n = (Py_ssize_t)bign; if (bign < 0 || (long)n != bign) { PyErr_SetString(PyExc_OverflowError, "range() result has too many items");