diff options
author | Martin v. Löwis <martin@v.loewis.de> | 2008-08-13 15:53:07 (GMT) |
---|---|---|
committer | Martin v. Löwis <martin@v.loewis.de> | 2008-08-13 15:53:07 (GMT) |
commit | 423be95dcf55b0b8737207beb7b30eb549430dba (patch) | |
tree | b23453f2dc43d809aca931203a9580a81bd938fe /Modules/_hashopenssl.c | |
parent | 688356f59f3b0fe2412a5f66b79f0f9fdc4a98d2 (diff) | |
download | cpython-423be95dcf55b0b8737207beb7b30eb549430dba.zip cpython-423be95dcf55b0b8737207beb7b30eb549430dba.tar.gz cpython-423be95dcf55b0b8737207beb7b30eb549430dba.tar.bz2 |
Merged revisions 65654 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r65654 | martin.v.loewis | 2008-08-12 16:49:50 +0200 (Tue, 12 Aug 2008) | 6 lines
Issue #3139: Make buffer-interface thread-safe wrt. PyArg_ParseTuple,
by denying s# to parse objects that have a releasebuffer procedure,
and introducing s*.
More module might need to get converted to use s*.
........
Diffstat (limited to 'Modules/_hashopenssl.c')
-rw-r--r-- | Modules/_hashopenssl.c | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/Modules/_hashopenssl.c b/Modules/_hashopenssl.c index bd04411..c0f9a2c 100644 --- a/Modules/_hashopenssl.c +++ b/Modules/_hashopenssl.c @@ -164,7 +164,7 @@ EVP_hexdigest(EVPobject *self, PyObject *unused) if ((viewp)->ndim > 1) { \ PyErr_SetString(PyExc_BufferError, \ "Buffer must be single dimension"); \ - PyObject_ReleaseBuffer((obj), (viewp)); \ + PyBuffer_Release((viewp)); \ return NULL; \ } \ } while(0); @@ -186,7 +186,7 @@ EVP_update(EVPobject *self, PyObject *args) EVP_DigestUpdate(&self->ctx, (unsigned char*)view.buf, Py_SAFE_DOWNCAST(view.len, Py_ssize_t, unsigned int)); - PyObject_ReleaseBuffer(obj, &view); + PyBuffer_Release(&view); Py_INCREF(Py_None); return Py_None; @@ -267,7 +267,7 @@ EVP_tp_init(EVPobject *self, PyObject *args, PyObject *kwds) if (!PyArg_Parse(name_obj, "s", &nameStr)) { PyErr_SetString(PyExc_TypeError, "name must be a string"); if (data_obj) - PyObject_ReleaseBuffer(data_obj, &view); + PyBuffer_Release(&view); return -1; } @@ -275,7 +275,7 @@ EVP_tp_init(EVPobject *self, PyObject *args, PyObject *kwds) if (!digest) { PyErr_SetString(PyExc_ValueError, "unknown hash function"); if (data_obj) - PyObject_ReleaseBuffer(data_obj, &view); + PyBuffer_Release(&view); return -1; } EVP_DigestInit(&self->ctx, digest); @@ -286,7 +286,7 @@ EVP_tp_init(EVPobject *self, PyObject *args, PyObject *kwds) if (data_obj) { EVP_DigestUpdate(&self->ctx, (unsigned char*)view.buf, Py_SAFE_DOWNCAST(view.len, Py_ssize_t, unsigned int)); - PyObject_ReleaseBuffer(data_obj, &view); + PyBuffer_Release(&view); } return 0; @@ -421,7 +421,7 @@ EVP_new(PyObject *self, PyObject *args, PyObject *kwdict) Py_SAFE_DOWNCAST(view.len, Py_ssize_t, unsigned int)); if (data_obj) - PyObject_ReleaseBuffer(data_obj, &view); + PyBuffer_Release(&view); return ret_obj; } @@ -455,7 +455,7 @@ EVP_new(PyObject *self, PyObject *args, PyObject *kwdict) Py_SAFE_DOWNCAST(view.len, Py_ssize_t, unsigned int)); \ \ if (data_obj) \ - PyObject_ReleaseBuffer(data_obj, &view); \ + PyBuffer_Release(&view); \ return ret_obj; \ } |