From: Martin v. Löwis Date: Mon, 3 Apr 2006 11:38:08 +0000 (+0000) Subject: Allow long integers in PySlice_GetIndices. X-Git-Tag: v2.5a1~53 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=54b42f185ea64dc06649d07bb1592d94bb379935;p=python Allow long integers in PySlice_GetIndices. --- diff --git a/Objects/sliceobject.c b/Objects/sliceobject.c index e33261b814..271a9ad62d 100644 --- a/Objects/sliceobject.c +++ b/Objects/sliceobject.c @@ -106,20 +106,20 @@ PySlice_GetIndices(PySliceObject *r, Py_ssize_t length, if (r->step == Py_None) { *step = 1; } else { - if (!PyInt_Check(r->step)) return -1; + if (!PyInt_Check(r->step) && !PyLong_Check(r->step)) return -1; *step = PyInt_AsSsize_t(r->step); } if (r->start == Py_None) { *start = *step < 0 ? length-1 : 0; } else { - if (!PyInt_Check(r->start)) return -1; + if (!PyInt_Check(r->start) && !PyLong_Check(r->step)) return -1; *start = PyInt_AsSsize_t(r->start); if (*start < 0) *start += length; } if (r->stop == Py_None) { *stop = *step < 0 ? -1 : length; } else { - if (!PyInt_Check(r->stop)) return -1; + if (!PyInt_Check(r->stop) && !PyLong_Check(r->step)) return -1; *stop = PyInt_AsSsize_t(r->stop); if (*stop < 0) *stop += length; }