From 13f5b9972742636cb88e6fe4441eb4740adfd648 Mon Sep 17 00:00:00 2001 From: "mark.dickinson" Date: Thu, 3 Dec 2009 12:08:56 +0000 Subject: [PATCH] Issue #6985: number of range() items should be constrained to lie in a Py_ssize_t, not an int. git-svn-id: http://svn.python.org/projects/python/trunk@76648 6015fed2-1504-0410-9fe1-9d1591cc4771 --- Python/bltinmodule.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/Python/bltinmodule.c b/Python/bltinmodule.c index 80fc9b4244..b201aaf787 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"); -- 2.11.4.GIT