mirror of
https://github.com/python/cpython.git
synced 2025-08-31 05:58:33 +00:00
Merge 3.1
This commit is contained in:
commit
fa3edbed25
2 changed files with 11 additions and 3 deletions
|
@ -3050,6 +3050,7 @@ count_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
|
|||
Py_ssize_t cnt = 0;
|
||||
PyObject *long_cnt = NULL;
|
||||
PyObject *long_step = NULL;
|
||||
long step;
|
||||
static char *kwlist[] = {"start", "step", 0};
|
||||
|
||||
if (!PyArg_ParseTupleAndKeywords(args, kwds, "|OO:count",
|
||||
|
@ -3087,9 +3088,11 @@ count_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
|
|||
assert(long_cnt != NULL && long_step != NULL);
|
||||
|
||||
/* Fast mode only works when the step is 1 */
|
||||
if (!PyLong_Check(long_step) ||
|
||||
PyLong_AS_LONG(long_step) != 1) {
|
||||
slow_mode = 1;
|
||||
step = PyLong_AsLong(long_step);
|
||||
if (step != 1) {
|
||||
slow_mode = 1;
|
||||
if (step == -1 && PyErr_Occurred())
|
||||
PyErr_Clear();
|
||||
}
|
||||
|
||||
if (slow_mode)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue