mirror of
https://github.com/python/cpython.git
synced 2025-11-02 03:01:58 +00:00
Merged revisions 77916 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r77916 | antoine.pitrou | 2010-02-02 23:36:17 +0100 (mar., 02 févr. 2010) | 4 lines Issue #7385: Fix a crash in `MemoryView_FromObject` when `PyObject_GetBuffer` fails. Patch by Florent Xicluna. ........
This commit is contained in:
parent
b1f7b7bef5
commit
05b7c5644c
3 changed files with 98 additions and 7 deletions
|
|
@ -76,6 +76,7 @@ PyObject *
|
|||
PyMemoryView_FromObject(PyObject *base)
|
||||
{
|
||||
PyMemoryViewObject *mview;
|
||||
Py_buffer view;
|
||||
|
||||
if (!PyObject_CheckBuffer(base)) {
|
||||
PyErr_SetString(PyExc_TypeError,
|
||||
|
|
@ -84,20 +85,17 @@ PyMemoryView_FromObject(PyObject *base)
|
|||
return NULL;
|
||||
}
|
||||
|
||||
mview = (PyMemoryViewObject *)
|
||||
PyObject_GC_New(PyMemoryViewObject, &PyMemoryView_Type);
|
||||
if (mview == NULL)
|
||||
if (PyObject_GetBuffer(base, &view, PyBUF_FULL_RO) < 0)
|
||||
return NULL;
|
||||
|
||||
mview->base = NULL;
|
||||
if (PyObject_GetBuffer(base, &(mview->view), PyBUF_FULL_RO) < 0) {
|
||||
Py_DECREF(mview);
|
||||
mview = (PyMemoryViewObject *)PyMemoryView_FromBuffer(&view);
|
||||
if (mview == NULL) {
|
||||
PyBuffer_Release(&view);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
mview->base = base;
|
||||
Py_INCREF(base);
|
||||
_PyObject_GC_TRACK(mview);
|
||||
return (PyObject *)mview;
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue