diff -r 94d9e97f3ee1 Doc/c-api/typeobj.rst --- a/Doc/c-api/typeobj.rst Mon Nov 21 11:38:37 2016 +0200 +++ b/Doc/c-api/typeobj.rst Mon Nov 21 11:39:18 2016 +0200 @@ -725,11 +725,11 @@ type objects) *must* have the :attr:`ob_ typedef int (*setter)(PyObject *, PyObject *, void *); typedef struct PyGetSetDef { - char *name; /* attribute name */ - getter get; /* C function to get the attribute */ - setter set; /* C function to set or delete the attribute */ - char *doc; /* optional doc string */ - void *closure; /* optional additional data for getter and setter */ + const char *name; /* attribute name */ + getter get; /* C function to get the attribute */ + setter set; /* C function to set or delete the attribute */ + const char *doc; /* optional doc string */ + void *closure; /* optional additional data for getter and setter */ } PyGetSetDef; diff -r 94d9e97f3ee1 Doc/extending/newtypes.rst --- a/Doc/extending/newtypes.rst Mon Nov 21 11:38:37 2016 +0200 +++ b/Doc/extending/newtypes.rst Mon Nov 21 11:39:18 2016 +0200 @@ -1138,11 +1138,11 @@ in the instance. A variety of primitive be read-only or read-write. The structures in the table are defined as:: typedef struct PyMemberDef { - char *name; - int type; - int offset; - int flags; - char *doc; + const char *name; + int type; + int offset; + int flags; + const char *doc; } PyMemberDef; For each entry in the table, a :term:`descriptor` will be constructed and added to the diff -r 94d9e97f3ee1 Doc/whatsnew/3.7.rst --- a/Doc/whatsnew/3.7.rst Mon Nov 21 11:38:37 2016 +0200 +++ b/Doc/whatsnew/3.7.rst Mon Nov 21 11:39:18 2016 +0200 @@ -99,6 +99,12 @@ Build and C API Changes of libffi is now required when building ``_ctypes`` on such platforms. Contributed by Zachary Ware in :issue:`27979`. +* Fields :c:member:`name` and :c:member:`doc` of structures + :c:type:`PyMemberDef`, :c:type:`PyGetSetDef`, + :c:type:`PyStructSequence_Field`, :c:type:`PyStructSequence_Desc`, + and :c:type:`wrapperbase` are now of type ``const char *`` rather of + ``char *``. (Contributed by Serhiy Storchaka in :issue:`XXXXX`.) + Deprecated ========== diff -r 94d9e97f3ee1 Include/descrobject.h --- a/Include/descrobject.h Mon Nov 21 11:38:37 2016 +0200 +++ b/Include/descrobject.h Mon Nov 21 11:39:18 2016 +0200 @@ -9,10 +9,10 @@ typedef PyObject *(*getter)(PyObject *, typedef int (*setter)(PyObject *, PyObject *, void *); typedef struct PyGetSetDef { - char *name; + const char *name; getter get; setter set; - char *doc; + const char *doc; void *closure; } PyGetSetDef; @@ -24,11 +24,11 @@ typedef PyObject *(*wrapperfunc_kwds)(Py void *wrapped, PyObject *kwds); struct wrapperbase { - char *name; + const char *name; int offset; void *function; wrapperfunc wrapper; - char *doc; + const char *doc; int flags; PyObject *name_strobj; }; diff -r 94d9e97f3ee1 Include/structmember.h --- a/Include/structmember.h Mon Nov 21 11:38:37 2016 +0200 +++ b/Include/structmember.h Mon Nov 21 11:39:18 2016 +0200 @@ -16,11 +16,11 @@ extern "C" { pointer is NULL. */ typedef struct PyMemberDef { - char *name; + const char *name; int type; Py_ssize_t offset; int flags; - char *doc; + const char *doc; } PyMemberDef; /* Types */ diff -r 94d9e97f3ee1 Include/structseq.h --- a/Include/structseq.h Mon Nov 21 11:38:37 2016 +0200 +++ b/Include/structseq.h Mon Nov 21 11:39:18 2016 +0200 @@ -8,13 +8,13 @@ extern "C" { #endif typedef struct PyStructSequence_Field { - char *name; - char *doc; + const char *name; + const char *doc; } PyStructSequence_Field; typedef struct PyStructSequence_Desc { - char *name; - char *doc; + const char *name; + const char *doc; struct PyStructSequence_Field *fields; int n_in_sequence; } PyStructSequence_Desc; diff -r 94d9e97f3ee1 Objects/structseq.c --- a/Objects/structseq.c Mon Nov 21 11:38:37 2016 +0200 +++ b/Objects/structseq.c Mon Nov 21 11:39:18 2016 +0200 @@ -256,7 +256,7 @@ structseq_reduce(PyStructSequence* self) } for (; i < n_fields; i++) { - char *n = Py_TYPE(self)->tp_members[i-n_unnamed_fields].name; + const char *n = Py_TYPE(self)->tp_members[i-n_unnamed_fields].name; if (PyDict_SetItemString(dict, n, self->ob_item[i]) < 0) goto error; }