From: Serhiy Storchaka Date: Tue, 26 Sep 2017 05:14:58 +0000 (+0300) Subject: bpo-31579: Fixed a possible leak in enumerate() with large indices. (#3753) X-Git-Tag: v3.7.0a2~109 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=0e950dd22b075b4809c84afda8aede02b76ac0fa;p=python bpo-31579: Fixed a possible leak in enumerate() with large indices. (#3753) --- diff --git a/Objects/enumobject.c b/Objects/enumobject.c index 154d901e86..4d0af14008 100644 --- a/Objects/enumobject.c +++ b/Objects/enumobject.c @@ -108,14 +108,18 @@ enum_next_long(enumobject *en, PyObject* next_item) if (en->en_longindex == NULL) { en->en_longindex = PyLong_FromSsize_t(PY_SSIZE_T_MAX); - if (en->en_longindex == NULL) + if (en->en_longindex == NULL) { + Py_DECREF(next_item); return NULL; + } } next_index = en->en_longindex; assert(next_index != NULL); stepped_up = PyNumber_Add(next_index, _PyLong_One); - if (stepped_up == NULL) + if (stepped_up == NULL) { + Py_DECREF(next_item); return NULL; + } en->en_longindex = stepped_up; if (result->ob_refcnt == 1) {