]> granicus.if.org Git - python/commitdiff
Issue #25659: Change assert to TypeError in from_buffer/_copy()
authorMartin Panter <vadmium+py@gmail.com>
Sun, 20 Nov 2016 09:35:06 +0000 (09:35 +0000)
committerMartin Panter <vadmium+py@gmail.com>
Sun, 20 Nov 2016 09:35:06 +0000 (09:35 +0000)
Based on suggestion by Eryk Sun.

Lib/ctypes/test/test_frombuffer.py
Misc/NEWS
Modules/_ctypes/_ctypes.c

index 9f4bb28d6a7750c27fd176a33f0f92b3918750c3..d708ed6906fe435b7690fc53a254af8e8f513ddd 100644 (file)
@@ -77,5 +77,13 @@ class Test(unittest.TestCase):
         self.assertRaises(ValueError,
                           (c_int * 1).from_buffer_copy, a, 16 * sizeof(c_int))
 
+    def test_abstract(self):
+        self.assertRaises(TypeError, Array.from_buffer, bytearray(10))
+        self.assertRaises(TypeError, Structure.from_buffer, bytearray(10))
+        self.assertRaises(TypeError, Union.from_buffer, bytearray(10))
+        self.assertRaises(TypeError, Array.from_buffer_copy, b"123")
+        self.assertRaises(TypeError, Structure.from_buffer_copy, b"123")
+        self.assertRaises(TypeError, Union.from_buffer_copy, b"123")
+
 if __name__ == '__main__':
     unittest.main()
index c89fe7896e6a7ef5cf2d693f940f835ec428369f..7d877a9a95bdbb75cef65bffa849d7055eab479f 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -63,6 +63,9 @@ Core and Builtins
 Library
 -------
 
+- Issue #25659: In ctypes, prevent a crash calling the from_buffer() and
+  from_buffer_copy() methods on abstract classes like Array.
+
 - Issue #28563: Fixed possible DoS and arbitrary code execution when handle
   plural form selections in the gettext module.  The expression parser now
   supports exact syntax supported by GNU gettext.
index 5b4ac47a3ba28e323afcfee908de032eb4f96737..f301b138585a781a004463e1aa998c9d2b5f957d 100644 (file)
@@ -501,7 +501,10 @@ CDataType_from_buffer(PyObject *type, PyObject *args)
     Py_ssize_t offset = 0;
     PyObject *obj, *result;
     StgDictObject *dict = PyType_stgdict(type);
-    assert (dict);
+    if (!dict) {
+        PyErr_SetString(PyExc_TypeError, "abstract class");
+        return NULL;
+    }
 
     if (!PyArg_ParseTuple(args,
 #if (PY_VERSION_HEX < 0x02050000)
@@ -557,13 +560,16 @@ CDataType_from_buffer_copy(PyObject *type, PyObject *args)
     Py_ssize_t offset = 0;
     PyObject *obj, *result;
     StgDictObject *dict = PyType_stgdict(type);
-    assert (dict);
+    if (!dict) {
+        PyErr_SetString(PyExc_TypeError, "abstract class");
+        return NULL;
+    }
 
     if (!PyArg_ParseTuple(args,
 #if (PY_VERSION_HEX < 0x02050000)
-                          "O|i:from_buffer",
+                          "O|i:from_buffer_copy",
 #else
-                          "O|n:from_buffer",
+                          "O|n:from_buffer_copy",
 #endif
                           &obj, &offset))
         return NULL;