mirror of https://github.com/python/cpython.git
Merged revisions 78435 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k ........ r78435 | larry.hastings | 2010-02-24 17:49:58 -0500 (Wed, 24 Feb 2010) | 4 lines Issue #5939: Add additional runtime checking to ensure a valid capsule in Modules/_ctypes/callproc.c. Reviewed by Benjamin P. My first commit! ........
This commit is contained in:
parent
73ad434945
commit
e5fd21f11f
|
@ -12,7 +12,9 @@ What's New in Python 3.1.2?
|
||||||
Core and Builtins
|
Core and Builtins
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
=======
|
- Issue #5939: Add additional runtime checking to ensure a valid capsule
|
||||||
|
in Modules/_ctypes/callproc.c.
|
||||||
|
|
||||||
- Issue #7309: Fix unchecked attribute access when converting
|
- Issue #7309: Fix unchecked attribute access when converting
|
||||||
UnicodeEncodeError, UnicodeDecodeError, and UnicodeTranslateError to
|
UnicodeEncodeError, UnicodeDecodeError, and UnicodeTranslateError to
|
||||||
strings.
|
strings.
|
||||||
|
|
|
@ -139,8 +139,14 @@ _ctypes_get_errobj(int **pspace)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
errobj = PyDict_GetItem(dict, error_object_name);
|
errobj = PyDict_GetItem(dict, error_object_name);
|
||||||
if (errobj)
|
if (errobj) {
|
||||||
|
if (!PyCapsule_IsValid(errobj, CTYPES_CAPSULE_NAME_PYMEM)) {
|
||||||
|
PyErr_SetString(PyExc_RuntimeError,
|
||||||
|
"ctypes.error_object is an invalid capsule");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
Py_INCREF(errobj);
|
Py_INCREF(errobj);
|
||||||
|
}
|
||||||
else {
|
else {
|
||||||
void *space = PyMem_Malloc(sizeof(int) * 2);
|
void *space = PyMem_Malloc(sizeof(int) * 2);
|
||||||
if (space == NULL)
|
if (space == NULL)
|
||||||
|
|
Loading…
Reference in New Issue