diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2012-04-01 14:05:46 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2012-04-01 14:05:46 (GMT) |
commit | 58bb82e7b4b50fa5efaefc1196bd927992fbe783 (patch) | |
tree | 297fc8ec19a5e746c40b6b140dba83f90b9e3c0c | |
parent | 165a2c2e27c07ac0c1ab5092a79f7f30c6c2a0d6 (diff) | |
download | cpython-58bb82e7b4b50fa5efaefc1196bd927992fbe783.zip cpython-58bb82e7b4b50fa5efaefc1196bd927992fbe783.tar.gz cpython-58bb82e7b4b50fa5efaefc1196bd927992fbe783.tar.bz2 |
Issue #13019: Fix potential reference leaks in bytearray.extend().
Patch by Suman Saha.
-rw-r--r-- | Misc/NEWS | 3 | ||||
-rw-r--r-- | Objects/bytearrayobject.c | 8 |
2 files changed, 9 insertions, 2 deletions
@@ -10,6 +10,9 @@ What's New in Python 3.2.4 Core and Builtins ----------------- +- Issue #13019: Fix potential reference leaks in bytearray.extend(). Patch + by Suman Saha. + - Issue #14378: Fix compiling ast.ImportFrom nodes with a "__future__" string as the module name that was not interned. diff --git a/Objects/bytearrayobject.c b/Objects/bytearrayobject.c index 4202ff2..55b4df6 100644 --- a/Objects/bytearrayobject.c +++ b/Objects/bytearrayobject.c @@ -2234,8 +2234,10 @@ bytearray_extend(PyByteArrayObject *self, PyObject *arg) } bytearray_obj = PyByteArray_FromStringAndSize(NULL, buf_size); - if (bytearray_obj == NULL) + if (bytearray_obj == NULL) { + Py_DECREF(it); return NULL; + } buf = PyByteArray_AS_STRING(bytearray_obj); while ((item = PyIter_Next(it)) != NULL) { @@ -2268,8 +2270,10 @@ bytearray_extend(PyByteArrayObject *self, PyObject *arg) return NULL; } - if (bytearray_setslice(self, Py_SIZE(self), Py_SIZE(self), bytearray_obj) == -1) + if (bytearray_setslice(self, Py_SIZE(self), Py_SIZE(self), bytearray_obj) == -1) { + Py_DECREF(bytearray_obj); return NULL; + } Py_DECREF(bytearray_obj); Py_RETURN_NONE; |