diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2011-02-24 20:50:49 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2011-02-24 20:50:49 (GMT) |
commit | 5bffa79c227236a8bfde6bf174a1f3f0a43fd2ea (patch) | |
tree | c755754b167f2c992e610dab9a6dfe7c6ff59511 | |
parent | 1ce92dc20d698ce46c3459da7801c76bb8518550 (diff) | |
download | cpython-5bffa79c227236a8bfde6bf174a1f3f0a43fd2ea.zip cpython-5bffa79c227236a8bfde6bf174a1f3f0a43fd2ea.tar.gz cpython-5bffa79c227236a8bfde6bf174a1f3f0a43fd2ea.tar.bz2 |
Issue #11286: Raise a ValueError from calling PyMemoryView_FromBuffer with
a buffer struct having a NULL data pointer.
-rw-r--r-- | Lib/test/test_capi.py | 2 | ||||
-rw-r--r-- | Misc/NEWS | 3 | ||||
-rw-r--r-- | Modules/_testcapimodule.c | 11 | ||||
-rw-r--r-- | Objects/memoryobject.c | 5 |
4 files changed, 21 insertions, 0 deletions
diff --git a/Lib/test/test_capi.py b/Lib/test/test_capi.py index 32f8fae..529a2a5 100644 --- a/Lib/test/test_capi.py +++ b/Lib/test/test_capi.py @@ -50,6 +50,8 @@ class CAPITest(unittest.TestCase): b'Fatal Python error:' b' PyThreadState_Get: no current thread') + def test_memoryview_from_NULL_pointer(self): + self.assertRaises(ValueError, _testcapi.make_memoryview_from_NULL_pointer) @unittest.skipUnless(threading, 'Threading required for this test.') class TestPendingCalls(unittest.TestCase): @@ -10,6 +10,9 @@ What's New in Python 3.3 Alpha 1? Core and Builtins ----------------- +- Issue #11286: Raise a ValueError from calling PyMemoryView_FromBuffer with + a buffer struct having a NULL data pointer. + - Issue #11272: On Windows, input() strips '\r' (and not only '\n'), and sys.stdin uses universal newline (replace '\r\n' by '\n'). diff --git a/Modules/_testcapimodule.c b/Modules/_testcapimodule.c index f326568..f19d0df 100644 --- a/Modules/_testcapimodule.c +++ b/Modules/_testcapimodule.c @@ -2231,6 +2231,15 @@ make_exception_with_doc(PyObject *self, PyObject *args, PyObject *kwargs) return PyErr_NewExceptionWithDoc(name, doc, base, dict); } +static PyObject * +make_memoryview_from_NULL_pointer(PyObject *self) +{ + Py_buffer info; + if (PyBuffer_FillInfo(&info, NULL, NULL, 1, 1, PyBUF_FULL_RO) < 0) + return NULL; + return PyMemoryView_FromBuffer(&info); +} + /* Test that the fatal error from not having a current thread doesn't cause an infinite loop. Run via Lib/test/test_capi.py */ static PyObject * @@ -2326,6 +2335,8 @@ static PyMethodDef TestMethods[] = { {"code_newempty", code_newempty, METH_VARARGS}, {"make_exception_with_doc", (PyCFunction)make_exception_with_doc, METH_VARARGS | METH_KEYWORDS}, + {"make_memoryview_from_NULL_pointer", (PyCFunction)make_memoryview_from_NULL_pointer, + METH_NOARGS}, {"crash_no_current_thread", (PyCFunction)crash_no_current_thread, METH_NOARGS}, {NULL, NULL} /* sentinel */ }; diff --git a/Objects/memoryobject.c b/Objects/memoryobject.c index 7782076..2e32b2a 100644 --- a/Objects/memoryobject.c +++ b/Objects/memoryobject.c @@ -75,6 +75,11 @@ PyMemoryView_FromBuffer(Py_buffer *info) { PyMemoryViewObject *mview; + if (info->buf == NULL) { + PyErr_SetString(PyExc_ValueError, + "cannot make memory view from a buffer with a NULL data pointer"); + return NULL; + } mview = (PyMemoryViewObject *) PyObject_GC_New(PyMemoryViewObject, &PyMemoryView_Type); if (mview == NULL) |