2023-09-01 19:03:20 +00:00
|
|
|
// Module support interface
|
1991-02-19 12:39:46 +00:00
|
|
|
|
2000-07-08 17:25:55 +00:00
|
|
|
#ifndef Py_MODSUPPORT_H
|
|
|
|
#define Py_MODSUPPORT_H
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2005-12-10 18:50:16 +00:00
|
|
|
PyAPI_FUNC(int) PyArg_Parse(PyObject *, const char *, ...);
|
2013-05-13 04:08:28 +00:00
|
|
|
PyAPI_FUNC(int) PyArg_ParseTuple(PyObject *, const char *, ...);
|
2002-08-12 07:21:58 +00:00
|
|
|
PyAPI_FUNC(int) PyArg_ParseTupleAndKeywords(PyObject *, PyObject *,
|
2023-12-04 11:14:56 +00:00
|
|
|
const char *, PY_CXX_CONST char * const *, ...);
|
2017-01-24 19:27:12 +00:00
|
|
|
PyAPI_FUNC(int) PyArg_VaParse(PyObject *, const char *, va_list);
|
|
|
|
PyAPI_FUNC(int) PyArg_VaParseTupleAndKeywords(PyObject *, PyObject *,
|
2023-12-04 11:14:56 +00:00
|
|
|
const char *, PY_CXX_CONST char * const *, va_list);
|
2023-05-31 09:38:55 +00:00
|
|
|
|
2010-04-24 18:21:17 +00:00
|
|
|
PyAPI_FUNC(int) PyArg_ValidateKeywordArguments(PyObject *);
|
2006-03-01 04:06:10 +00:00
|
|
|
PyAPI_FUNC(int) PyArg_UnpackTuple(PyObject *, const char *, Py_ssize_t, Py_ssize_t, ...);
|
2005-12-10 18:50:16 +00:00
|
|
|
PyAPI_FUNC(PyObject *) Py_BuildValue(const char *, ...);
|
|
|
|
PyAPI_FUNC(PyObject *) Py_VaBuildValue(const char *, va_list);
|
2016-08-14 07:52:18 +00:00
|
|
|
|
2023-07-25 19:01:45 +00:00
|
|
|
#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x030a0000
|
2020-11-04 12:59:15 +00:00
|
|
|
// Add an attribute with name 'name' and value 'obj' to the module 'mod.
|
2023-07-18 06:42:05 +00:00
|
|
|
// On success, return 0.
|
2020-11-04 12:59:15 +00:00
|
|
|
// On error, raise an exception and return -1.
|
|
|
|
PyAPI_FUNC(int) PyModule_AddObjectRef(PyObject *mod, const char *name, PyObject *value);
|
2023-07-25 19:01:45 +00:00
|
|
|
#endif /* Py_LIMITED_API */
|
2020-11-04 12:59:15 +00:00
|
|
|
|
2023-07-18 06:42:05 +00:00
|
|
|
#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x030d0000
|
|
|
|
// Similar to PyModule_AddObjectRef() but steal a reference to 'value'.
|
|
|
|
PyAPI_FUNC(int) PyModule_Add(PyObject *mod, const char *name, PyObject *value);
|
|
|
|
#endif /* Py_LIMITED_API */
|
|
|
|
|
|
|
|
// Similar to PyModule_AddObjectRef() and PyModule_Add() but steal
|
|
|
|
// a reference to 'value' on success and only on success.
|
|
|
|
// Errorprone. Should not be used in new code.
|
2020-11-04 12:59:15 +00:00
|
|
|
PyAPI_FUNC(int) PyModule_AddObject(PyObject *mod, const char *, PyObject *value);
|
|
|
|
|
2005-12-10 18:50:16 +00:00
|
|
|
PyAPI_FUNC(int) PyModule_AddIntConstant(PyObject *, const char *, long);
|
|
|
|
PyAPI_FUNC(int) PyModule_AddStringConstant(PyObject *, const char *, const char *);
|
2022-04-21 21:00:26 +00:00
|
|
|
|
2020-03-22 16:17:34 +00:00
|
|
|
#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03090000
|
|
|
|
/* New in 3.9 */
|
|
|
|
PyAPI_FUNC(int) PyModule_AddType(PyObject *module, PyTypeObject *type);
|
|
|
|
#endif /* Py_LIMITED_API */
|
2022-04-21 21:00:26 +00:00
|
|
|
|
2022-06-20 14:04:52 +00:00
|
|
|
#define PyModule_AddIntMacro(m, c) PyModule_AddIntConstant((m), #c, (c))
|
|
|
|
#define PyModule_AddStringMacro(m, c) PyModule_AddStringConstant((m), #c, (c))
|
2015-06-02 23:06:47 +00:00
|
|
|
|
|
|
|
#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03050000
|
|
|
|
/* New in 3.5 */
|
2015-05-23 12:24:10 +00:00
|
|
|
PyAPI_FUNC(int) PyModule_SetDocString(PyObject *, const char *);
|
|
|
|
PyAPI_FUNC(int) PyModule_AddFunctions(PyObject *, PyMethodDef *);
|
|
|
|
PyAPI_FUNC(int) PyModule_ExecDef(PyObject *module, PyModuleDef *def);
|
2015-06-02 23:06:47 +00:00
|
|
|
#endif
|
2006-02-15 17:27:45 +00:00
|
|
|
|
2009-05-29 14:47:46 +00:00
|
|
|
#define Py_CLEANUP_SUPPORTED 0x20000
|
|
|
|
|
2006-02-28 19:02:24 +00:00
|
|
|
#define PYTHON_API_VERSION 1013
|
|
|
|
#define PYTHON_API_STRING "1013"
|
1995-01-09 17:47:20 +00:00
|
|
|
/* The API version is maintained (independently from the Python version)
|
|
|
|
so we can detect mismatches between the interpreter and dynamically
|
2000-07-16 12:04:32 +00:00
|
|
|
loaded modules. These are diagnosed by an error message but
|
1996-07-30 16:41:02 +00:00
|
|
|
the module is still loaded (because the mismatch can only be tested
|
|
|
|
after loading the module). The error message is intended to
|
|
|
|
explain the core dump a few seconds later.
|
1995-01-09 17:47:20 +00:00
|
|
|
|
1996-08-22 22:55:47 +00:00
|
|
|
The symbol PYTHON_API_STRING defines the same value as a string
|
|
|
|
literal. *** PLEASE MAKE SURE THE DEFINITIONS MATCH. ***
|
|
|
|
|
1995-01-09 17:47:20 +00:00
|
|
|
Please add a line or two to the top of this log for each API
|
|
|
|
version change:
|
|
|
|
|
2015-05-23 12:24:10 +00:00
|
|
|
22-Feb-2006 MvL 1013 PEP 353 - long indices for sequence lengths
|
2006-02-28 19:02:24 +00:00
|
|
|
|
2015-05-23 12:24:10 +00:00
|
|
|
19-Aug-2002 GvR 1012 Changes to string object struct for
|
|
|
|
interning changes, saving 3 bytes.
|
2002-08-19 21:43:18 +00:00
|
|
|
|
2015-05-23 12:24:10 +00:00
|
|
|
17-Jul-2001 GvR 1011 Descr-branch, just to be on the safe side
|
2001-08-02 04:15:00 +00:00
|
|
|
|
2001-01-25 22:13:34 +00:00
|
|
|
25-Jan-2001 FLD 1010 Parameters added to PyCode_New() and
|
|
|
|
PyFrame_New(); Python 2.1a2
|
|
|
|
|
2000-03-29 01:46:45 +00:00
|
|
|
14-Mar-2000 GvR 1009 Unicode API added
|
|
|
|
|
2015-05-23 12:24:10 +00:00
|
|
|
3-Jan-1999 GvR 1007 Decided to change back! (Don't reuse 1008!)
|
1999-01-03 12:40:24 +00:00
|
|
|
|
2015-05-23 12:24:10 +00:00
|
|
|
3-Dec-1998 GvR 1008 Python 1.5.2b1
|
1998-12-03 18:18:12 +00:00
|
|
|
|
2015-05-23 12:24:10 +00:00
|
|
|
18-Jan-1997 GvR 1007 string interning and other speedups
|
1997-01-18 07:54:03 +00:00
|
|
|
|
2015-05-23 12:24:10 +00:00
|
|
|
11-Oct-1996 GvR renamed Py_Ellipses to Py_Ellipsis :-(
|
1996-10-11 16:25:41 +00:00
|
|
|
|
2015-05-23 12:24:10 +00:00
|
|
|
30-Jul-1996 GvR Slice and ellipses syntax added
|
1996-07-30 16:41:02 +00:00
|
|
|
|
2015-05-23 12:24:10 +00:00
|
|
|
23-Jul-1996 GvR For 1.4 -- better safe than sorry this time :-)
|
1996-07-30 16:41:02 +00:00
|
|
|
|
2015-05-23 12:24:10 +00:00
|
|
|
7-Nov-1995 GvR Keyword arguments (should've been done at 1.3 :-( )
|
1996-01-12 00:49:39 +00:00
|
|
|
|
2015-05-23 12:24:10 +00:00
|
|
|
10-Jan-1995 GvR Renamed globals to new naming scheme
|
1995-01-12 11:45:45 +00:00
|
|
|
|
2015-05-23 12:24:10 +00:00
|
|
|
9-Jan-1995 GvR Initial version (incompatible with older API)
|
1995-01-09 17:47:20 +00:00
|
|
|
*/
|
|
|
|
|
2010-12-03 20:14:31 +00:00
|
|
|
/* The PYTHON_ABI_VERSION is introduced in PEP 384. For the lifetime of
|
|
|
|
Python 3, it will stay at the value of 3; changes to the limited API
|
|
|
|
must be performed in a strictly backwards-compatible manner. */
|
|
|
|
#define PYTHON_ABI_VERSION 3
|
|
|
|
#define PYTHON_ABI_STRING "3"
|
|
|
|
|
2022-02-24 16:51:59 +00:00
|
|
|
PyAPI_FUNC(PyObject *) PyModule_Create2(PyModuleDef*, int apiver);
|
1993-07-28 09:05:47 +00:00
|
|
|
|
2010-12-03 20:14:31 +00:00
|
|
|
#ifdef Py_LIMITED_API
|
|
|
|
#define PyModule_Create(module) \
|
2022-06-20 14:04:52 +00:00
|
|
|
PyModule_Create2((module), PYTHON_ABI_VERSION)
|
2010-12-03 20:14:31 +00:00
|
|
|
#else
|
2008-06-11 05:26:20 +00:00
|
|
|
#define PyModule_Create(module) \
|
2022-06-20 14:04:52 +00:00
|
|
|
PyModule_Create2((module), PYTHON_API_VERSION)
|
2015-05-23 12:24:10 +00:00
|
|
|
#endif
|
|
|
|
|
2015-06-02 23:06:47 +00:00
|
|
|
#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03050000
|
|
|
|
/* New in 3.5 */
|
2015-05-23 12:24:10 +00:00
|
|
|
PyAPI_FUNC(PyObject *) PyModule_FromDefAndSpec2(PyModuleDef *def,
|
|
|
|
PyObject *spec,
|
|
|
|
int module_api_version);
|
|
|
|
|
|
|
|
#ifdef Py_LIMITED_API
|
|
|
|
#define PyModule_FromDefAndSpec(module, spec) \
|
2022-06-20 14:04:52 +00:00
|
|
|
PyModule_FromDefAndSpec2((module), (spec), PYTHON_ABI_VERSION)
|
2015-05-23 12:24:10 +00:00
|
|
|
#else
|
|
|
|
#define PyModule_FromDefAndSpec(module, spec) \
|
2022-06-20 14:04:52 +00:00
|
|
|
PyModule_FromDefAndSpec2((module), (spec), PYTHON_API_VERSION)
|
2015-06-02 23:06:47 +00:00
|
|
|
#endif /* Py_LIMITED_API */
|
2022-04-21 21:00:26 +00:00
|
|
|
|
2015-06-02 23:06:47 +00:00
|
|
|
#endif /* New in 3.5 */
|
1998-06-27 18:21:59 +00:00
|
|
|
|
2024-07-03 16:36:57 +00:00
|
|
|
#ifndef Py_LIMITED_API
|
|
|
|
# define Py_CPYTHON_MODSUPPORT_H
|
|
|
|
# include "cpython/modsupport.h"
|
|
|
|
# undef Py_CPYTHON_MODSUPPORT_H
|
|
|
|
#endif
|
|
|
|
|
1993-07-28 09:05:47 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif /* !Py_MODSUPPORT_H */
|