Issue #12764: Fix a crash in ctypes when the name of a Structure field is not

a string.
This commit is contained in:
Amaury Forgeot d'Arc 2011-09-02 20:32:23 +02:00
parent a95d19efa6
commit cf316a171e
3 changed files with 26 additions and 2 deletions

View File

@ -239,6 +239,14 @@ class StructureTestCase(unittest.TestCase):
pass
self.assertRaises(TypeError, setattr, POINT, "_fields_", [("x", 1), ("y", 2)])
def test_invalid_name(self):
# field name must be string
def declare_with_name(name):
class S(Structure):
_fields_ = [(name, c_int)]
self.assertRaises(TypeError, declare_with_name, u"x\xe9")
def test_intarray_fields(self):
class SomeInts(Structure):
_fields_ = [("a", c_int * 4)]

View File

@ -180,6 +180,9 @@ Library
Extension Modules
-----------------
- Issue #12764: Fix a crash in ctypes when the name of a Structure field is not
a string.
- Issue #9651: Fix a crash when ctypes.create_string_buffer(0) was passed to
some functions like file.write().

View File

@ -494,8 +494,21 @@ PyCStructUnionType_update_stgdict(PyObject *type, PyObject *fields, int isStruct
char *fieldfmt = dict->format ? dict->format : "B";
char *fieldname = PyString_AsString(name);
char *ptr;
Py_ssize_t len = strlen(fieldname) + strlen(fieldfmt);
char *buf = alloca(len + 2 + 1);
Py_ssize_t len;
char *buf;
if (fieldname == NULL)
{
PyErr_Format(PyExc_TypeError,
"structure field name must be string not %s",
name->ob_type->tp_name);
Py_DECREF(pair);
return -1;
}
len = strlen(fieldname) + strlen(fieldfmt);
buf = alloca(len + 2 + 1);
sprintf(buf, "%s:%s:", fieldfmt, fieldname);