mirror of https://github.com/python/cpython.git
gh-99284: [ctypes] remove `_use_broken_old_ctypes_structure_semantics_` (GH-99285)
It was untested and undocumented. No code has been found in the wild that ever used it.
This commit is contained in:
parent
27d8dc2c9d
commit
a3360facba
|
@ -873,3 +873,7 @@ Removed
|
|||
* Remove the ``PyUnicode_InternImmortal()`` function and the
|
||||
``SSTATE_INTERNED_IMMORTAL`` macro.
|
||||
(Contributed by Victor Stinner in :gh:`85858`.)
|
||||
|
||||
* Remove ``_use_broken_old_ctypes_structure_semantics_`` flag
|
||||
from :mod:`ctypes` module.
|
||||
(Contributed by Nikita Sobolev in :gh:`99285`.)
|
||||
|
|
|
@ -765,7 +765,6 @@ _PyStaticObjects_CheckRefcnt(PyInterpreterState *interp) {
|
|||
_PyStaticObject_CheckRefcnt((PyObject *)&_Py_ID(_swappedbytes_));
|
||||
_PyStaticObject_CheckRefcnt((PyObject *)&_Py_ID(_type_));
|
||||
_PyStaticObject_CheckRefcnt((PyObject *)&_Py_ID(_uninitialized_submodules));
|
||||
_PyStaticObject_CheckRefcnt((PyObject *)&_Py_ID(_use_broken_old_ctypes_structure_semantics_));
|
||||
_PyStaticObject_CheckRefcnt((PyObject *)&_Py_ID(_warn_unawaited_coroutine));
|
||||
_PyStaticObject_CheckRefcnt((PyObject *)&_Py_ID(_xoptions));
|
||||
_PyStaticObject_CheckRefcnt((PyObject *)&_Py_ID(a));
|
||||
|
|
|
@ -251,7 +251,6 @@ struct _Py_global_strings {
|
|||
STRUCT_FOR_ID(_swappedbytes_)
|
||||
STRUCT_FOR_ID(_type_)
|
||||
STRUCT_FOR_ID(_uninitialized_submodules)
|
||||
STRUCT_FOR_ID(_use_broken_old_ctypes_structure_semantics_)
|
||||
STRUCT_FOR_ID(_warn_unawaited_coroutine)
|
||||
STRUCT_FOR_ID(_xoptions)
|
||||
STRUCT_FOR_ID(a)
|
||||
|
|
|
@ -757,7 +757,6 @@ extern "C" {
|
|||
INIT_ID(_swappedbytes_), \
|
||||
INIT_ID(_type_), \
|
||||
INIT_ID(_uninitialized_submodules), \
|
||||
INIT_ID(_use_broken_old_ctypes_structure_semantics_), \
|
||||
INIT_ID(_warn_unawaited_coroutine), \
|
||||
INIT_ID(_xoptions), \
|
||||
INIT_ID(a), \
|
||||
|
|
|
@ -408,8 +408,6 @@ _PyUnicode_InitStaticStrings(void) {
|
|||
PyUnicode_InternInPlace(&string);
|
||||
string = &_Py_ID(_uninitialized_submodules);
|
||||
PyUnicode_InternInPlace(&string);
|
||||
string = &_Py_ID(_use_broken_old_ctypes_structure_semantics_);
|
||||
PyUnicode_InternInPlace(&string);
|
||||
string = &_Py_ID(_warn_unawaited_coroutine);
|
||||
PyUnicode_InternInPlace(&string);
|
||||
string = &_Py_ID(_xoptions);
|
||||
|
|
|
@ -0,0 +1,2 @@
|
|||
Remove ``_use_broken_old_ctypes_structure_semantics_``
|
||||
old untested and undocumented hack from :mod:`ctypes`.
|
|
@ -356,14 +356,6 @@ PyCStructUnionType_update_stgdict(PyObject *type, PyObject *fields, int isStruct
|
|||
int big_endian;
|
||||
int arrays_seen = 0;
|
||||
|
||||
/* HACK Alert: I cannot be bothered to fix ctypes.com, so there has to
|
||||
be a way to use the old, broken semantics: _fields_ are not extended
|
||||
but replaced in subclasses.
|
||||
|
||||
XXX Remove this in ctypes 1.0!
|
||||
*/
|
||||
int use_broken_old_ctypes_semantics;
|
||||
|
||||
if (fields == NULL)
|
||||
return 0;
|
||||
|
||||
|
@ -378,19 +370,6 @@ PyCStructUnionType_update_stgdict(PyObject *type, PyObject *fields, int isStruct
|
|||
big_endian = PY_BIG_ENDIAN;
|
||||
}
|
||||
|
||||
if (_PyObject_LookupAttr(type,
|
||||
&_Py_ID(_use_broken_old_ctypes_structure_semantics_), &tmp) < 0)
|
||||
{
|
||||
return -1;
|
||||
}
|
||||
if (tmp) {
|
||||
Py_DECREF(tmp);
|
||||
use_broken_old_ctypes_semantics = 1;
|
||||
}
|
||||
else {
|
||||
use_broken_old_ctypes_semantics = 0;
|
||||
}
|
||||
|
||||
if (_PyObject_LookupAttr(type, &_Py_ID(_pack_), &tmp) < 0) {
|
||||
return -1;
|
||||
}
|
||||
|
@ -454,7 +433,7 @@ PyCStructUnionType_update_stgdict(PyObject *type, PyObject *fields, int isStruct
|
|||
if (!isStruct) {
|
||||
stgdict->flags |= TYPEFLAG_HASUNION;
|
||||
}
|
||||
if (basedict && !use_broken_old_ctypes_semantics) {
|
||||
if (basedict) {
|
||||
size = offset = basedict->size;
|
||||
align = basedict->align;
|
||||
union_size = 0;
|
||||
|
|
Loading…
Reference in New Issue