summaryrefslogtreecommitdiffstats
path: root/Objects/bytearrayobject.c
diff options
context:
space:
mode:
authorGeorg Brandl <georg@python.org>2009-07-22 12:06:11 (GMT)
committerGeorg Brandl <georg@python.org>2009-07-22 12:06:11 (GMT)
commit069bcc3dd99be9d4a0ea2202377066c0a77de651 (patch)
treee72e0ee70a669ce9fd29441a752ce3ad2b8e0efb /Objects/bytearrayobject.c
parent3cc12f69421f14c4d919cc015b71259056b3bc60 (diff)
downloadcpython-069bcc3dd99be9d4a0ea2202377066c0a77de651.zip
cpython-069bcc3dd99be9d4a0ea2202377066c0a77de651.tar.gz
cpython-069bcc3dd99be9d4a0ea2202377066c0a77de651.tar.bz2
Merged revisions 74169 via svnmerge from
svn+ssh://svn.python.org/python/branches/py3k ................ r74169 | georg.brandl | 2009-07-22 14:03:59 +0200 (Mi, 22 Jul 2009) | 9 lines Merged revisions 74167 via svnmerge from svn+ssh://pythondev@svn.python.org/python/trunk ........ r74167 | georg.brandl | 2009-07-22 13:57:15 +0200 (Mi, 22 Jul 2009) | 1 line Issue #6540: Fixed crash for bytearray.translate() with invalid parameters. ........ ................
Diffstat (limited to 'Objects/bytearrayobject.c')
-rw-r--r--Objects/bytearrayobject.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/Objects/bytearrayobject.c b/Objects/bytearrayobject.c
index 165fd10..f3d5697 100644
--- a/Objects/bytearrayobject.c
+++ b/Objects/bytearrayobject.c
@@ -1389,15 +1389,17 @@ bytearray_translate(PyByteArrayObject *self, PyObject *args)
if (vtable.len != 256) {
PyErr_SetString(PyExc_ValueError,
"translation table must be 256 characters long");
- goto done;
+ PyBuffer_Release(&vtable);
+ return NULL;
}
table = (const char*)vtable.buf;
}
if (delobj != NULL) {
if (_getbuffer(delobj, &vdel) < 0) {
- delobj = NULL; /* don't try to release vdel buffer on exit */
- goto done;
+ if (tableobj != NULL)
+ PyBuffer_Release(&vtable);
+ return NULL;
}
}
else {