mirror of
https://github.com/python/cpython.git
synced 2024-12-13 20:05:53 +08:00
af68c874a6
In C++, it's an error to pass a string literal to a char* function without a const_cast(). Rather than require every C++ extension module to put a cast around string literals, fix the API to state the const-ness. I focused on parts of the API where people usually pass literals: PyArg_ParseTuple() and friends, Py_BuildValue(), PyMethodDef, the type slots, etc. Predictably, there were a large set of functions that needed to be fixed as a result of these changes. The most pervasive change was to make the keyword args list passed to PyArg_ParseTupleAndKewords() to be a const char *kwlist[]. One cast was required as a result of the changes: A type object mallocs the memory for its tp_doc slot and later frees it. PyTypeObject says that tp_doc is const char *; but if the type was created by type_new(), we know it is safe to cast to char *.
25 lines
611 B
C
25 lines
611 B
C
|
|
/* Module object interface */
|
|
|
|
#ifndef Py_MODULEOBJECT_H
|
|
#define Py_MODULEOBJECT_H
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
PyAPI_DATA(PyTypeObject) PyModule_Type;
|
|
|
|
#define PyModule_Check(op) PyObject_TypeCheck(op, &PyModule_Type)
|
|
#define PyModule_CheckExact(op) ((op)->ob_type == &PyModule_Type)
|
|
|
|
PyAPI_FUNC(PyObject *) PyModule_New(const char *);
|
|
PyAPI_FUNC(PyObject *) PyModule_GetDict(PyObject *);
|
|
PyAPI_FUNC(char *) PyModule_GetName(PyObject *);
|
|
PyAPI_FUNC(char *) PyModule_GetFilename(PyObject *);
|
|
PyAPI_FUNC(void) _PyModule_Clear(PyObject *);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
#endif /* !Py_MODULEOBJECT_H */
|