Module Objects¶
- PyTypeObjectPyModule_Type¶
- Part of theStable ABI.
This instance of
PyTypeObjectrepresents the Python module type. Thisis exposed to Python programs astypes.ModuleType.
- intPyModule_Check(PyObject*p)¶
Return true ifp is a module object, or a subtype of a module object.This function always succeeds.
- intPyModule_CheckExact(PyObject*p)¶
Return true ifp is a module object, but not a subtype of
PyModule_Type. This function always succeeds.
- PyObject*PyModule_NewObject(PyObject*name)¶
- Return value: New reference. Part of theStable ABI since version 3.7.
Return a new module object with
module.__name__set toname.The module’s__name__,__doc__,__package__and__loader__attributes arefilled in (all but__name__are set toNone). The caller isresponsible for setting a__file__attribute.Return
NULLwith an exception set on error.Added in version 3.3.
Changed in version 3.4:
__package__and__loader__are now set toNone.
- PyObject*PyModule_New(constchar*name)¶
- Return value: New reference. Part of theStable ABI.
Similar to
PyModule_NewObject(), but the name is a UTF-8 encodedstring instead of a Unicode object.
- PyObject*PyModule_GetDict(PyObject*module)¶
- Return value: Borrowed reference. Part of theStable ABI.
Return the dictionary object that implementsmodule’s namespace; this objectis the same as the
__dict__attribute of the module object.Ifmodule is not a module object (or a subtype of a module object),SystemErroris raised andNULLis returned.It is recommended extensions use other
PyModule_*andPyObject_*functions rather than directly manipulate a module’s__dict__.The returned reference is borrowed from the module; it is valid untilthe module is destroyed.
- PyObject*PyModule_GetNameObject(PyObject*module)¶
- Return value: New reference. Part of theStable ABI since version 3.7.
Returnmodule’s
__name__value. If the module does notprovide one, or if it is not a string,SystemErroris raised andNULLis returned.Added in version 3.3.
- constchar*PyModule_GetName(PyObject*module)¶
- Part of theStable ABI.
Similar to
PyModule_GetNameObject()but return the name encoded to'utf-8'.The returned buffer is only valid until the module is renamed or destroyed.Note that Python code may rename a module by setting its
__name__attribute.
- PyModuleDef*PyModule_GetDef(PyObject*module)¶
- Part of theStable ABI.
Return a pointer to the
PyModuleDefstruct from which the module wascreated, orNULLif the module wasn’t created from a definition.On error, return
NULLwith an exception set.UsePyErr_Occurred()to tell this case apart from a missingPyModuleDef.
- PyObject*PyModule_GetFilenameObject(PyObject*module)¶
- Return value: New reference. Part of theStable ABI.
Return the name of the file from whichmodule was loaded usingmodule’s
__file__attribute. If this is not defined, or if it is not astring, raiseSystemErrorand returnNULL; otherwise returna reference to a Unicode object.Added in version 3.2.
- constchar*PyModule_GetFilename(PyObject*module)¶
- Part of theStable ABI.
Similar to
PyModule_GetFilenameObject()but return the filenameencoded to ‘utf-8’.The returned buffer is only valid until the module’s
__file__attributeis reassigned or the module is destroyed.Deprecated since version 3.2:
PyModule_GetFilename()raisesUnicodeEncodeErroronunencodable filenames, usePyModule_GetFilenameObject()instead.
Module definition¶
Modules created using the C API are typically defined using anarray ofslots.The slots provide a “description” of how a module should be created.
Changed in version 3.15.0a2 (unreleased):Previously, aPyModuleDef struct was necessary to define modules.The older way of defining modules is still available: consult either theModule definition struct section or earlier versions of this documentationif you plan to support earlier Python versions.
The slots array is usually used to define an extension module’s “main”module object (seeDefining extension modules for details).It can also be used tocreate extension modules dynamically.
Unless specified otherwise, the same slot ID may not be repeatedin an array of slots.
- typePyModuleDef_Slot¶
- Part of theStable ABI (including all members) since version 3.5.
- intslot¶
A slot ID, chosen from the available
Py_mod_*values explained below.An ID of 0 marks the end of a
PyModuleDef_Slotarray.
- void*value¶
Value of the slot, whose meaning depends on the slot ID.
The value may not be NULL.To leave a slot out, omit the
PyModuleDef_Slotentry entirely.
Added in version 3.5.
- intslot¶
Metadata slots¶
- Py_mod_name¶
- Part of theStable ABI since version 3.15.
SlotIDfor the name of the new module,as a NUL-terminated UTF8-encodedconstchar*.Note that modules are typically created using a
ModuleSpec, and when they are, thename from the spec will be used instead ofPy_mod_name.However, it is still recommended to include this slot for introspectionand debugging purposes.Added in version 3.15.0a2 (unreleased):Use
PyModuleDef.m_nameinstead to support previous versions.
- Py_mod_doc¶
- Part of theStable ABI since version 3.15.
SlotIDfor the docstring of the newmodule, as a NUL-terminated UTF8-encodedconstchar*.Usually it is set to a variable created with
PyDoc_STRVAR.Added in version 3.15.0a2 (unreleased):Use
PyModuleDef.m_docinstead to support previous versions.
Feature slots¶
- Py_mod_abi¶
- Part of theStable ABI since version 3.15.
SlotIDwhose value points toaPyABIInfostructure describing the ABI thatthe extension is using.A suitable
PyABIInfovariable can be defined using thePyABIInfo_VARmacro, as in:PyABIInfo_VAR(abi_info);staticPyModuleDef_Slotmymodule_slots[]={{Py_mod_abi,&abi_info},...};
When creating a module, Python checks the value of this slotusing
PyABIInfo_Check().Added in version 3.15.
- Py_mod_multiple_interpreters¶
- Part of theStable ABI since version 3.12.
SlotIDwhose value is one of:- Py_MOD_MULTIPLE_INTERPRETERS_NOT_SUPPORTED¶
The module does not support being imported in subinterpreters.
- Py_MOD_MULTIPLE_INTERPRETERS_SUPPORTED¶
The module supports being imported in subinterpreters,but only when they share the main interpreter’s GIL.(SeeIsolating Extension Modules.)
- Py_MOD_PER_INTERPRETER_GIL_SUPPORTED¶
The module supports being imported in subinterpreters,even when they have their own GIL.(SeeIsolating Extension Modules.)
This slot determines whether or not importing this modulein a subinterpreter will fail.
If
Py_mod_multiple_interpretersis not specified, the importmachinery defaults toPy_MOD_MULTIPLE_INTERPRETERS_SUPPORTED.Added in version 3.12.
- Py_MOD_MULTIPLE_INTERPRETERS_NOT_SUPPORTED¶
- Py_mod_gil¶
- Part of theStable ABI since version 3.13.
SlotIDwhose value is one of:- Py_MOD_GIL_USED¶
The module depends on the presence of the global interpreter lock (GIL),and may access global state without synchronization.
- Py_MOD_GIL_NOT_USED¶
The module is safe to run without an active GIL.
This slot is ignored by Python builds not configured with
--disable-gil. Otherwise, it determines whether or not importingthis module will cause the GIL to be automatically enabled. SeeFree-threaded CPython for more detail.If
Py_mod_gilis not specified, the import machinery defaults toPy_MOD_GIL_USED.Added in version 3.13.
- Py_MOD_GIL_USED¶
Creation and initialization slots¶
- Py_mod_create¶
- Part of theStable ABI since version 3.5.
SlotIDfor a function that createsthe module object itself.The function must have the signature:- PyObject*create_module(PyObject*spec,PyModuleDef*def)¶
The function will be called with:
spec: a
ModuleSpec-like object, meaning that any attributes definedforimportlib.machinery.ModuleSpechave matching semantics.However, any of the attributes may be missing.def:
NULL, or the module definition if the module is created from one.
The function should return a new module object, or set an errorand return
NULL.This function should be kept minimal. In particular, it should notcall arbitrary Python code, as trying to import the same module again mayresult in an infinite loop.
If
Py_mod_createis not specified, the import machinery will createa normal module object usingPyModule_New(). The name is taken fromspec, not the definition, to allow extension modules to dynamically adjustto their place in the module hierarchy and be imported under differentnames through symlinks, all while sharing a single module definition.There is no requirement for the returned object to be an instance of
PyModule_Type.However, some slots may only be used withPyModule_Typeinstances; in particular:module state slots (
Py_mod_state_*),
Added in version 3.5.
Changed in version 3.15.0a2 (unreleased):Theslots argument may be a
ModuleSpec-like object, rather thana trueModuleSpecinstance.Note that previous versions of CPython did not enforce this.Thedef argument may now be
NULL, since modules are not necessarilymade from definitions. - PyObject*create_module(PyObject*spec,PyModuleDef*def)¶
- Py_mod_exec¶
- Part of theStable ABI since version 3.5.
SlotIDfor a function that willexecute, or initialize, the module.This function does the equivalent to executing the code of a Python module:typically, it adds classes and constants to the module.The signature of the function is:See theSupport functions section for some usefulfunctions to call.
For backwards compatibility, the
PyModuleDef.m_slotsarray maycontain multiplePy_mod_execslots; these are processed in theorder they appear in the array.Elsewhere (that is, in arguments toPyModule_FromSlotsAndSpec()and in return values ofPyModExport_<name>), repeating the slotis not allowed.Added in version 3.5.
Changed in version 3.15.0a2 (unreleased):Repeated
Py_mod_execslots are disallowed, except inPyModuleDef.m_slots.
- Py_mod_methods¶
- Part of theStable ABI since version 3.15.
SlotIDfor a table of module-levelfunctions, as an array ofPyMethodDefvalues suitable as thefunctions argument toPyModule_AddFunctions().Like other slot IDs, a slots array may only contain one
Py_mod_methodsentry.To add functions from multiplePyMethodDefarrays, callPyModule_AddFunctions()in thePy_mod_execfunction.The table must be statically allocated (or otherwise guaranteed to outlivethe module object).
Added in version 3.15.0a2 (unreleased):Use
PyModuleDef.m_methodsinstead to support previous versions.
Module state¶
Extension modules can havemodule state – apiece of memory that is allocated on module creation,and freed when the module object is deallocated.The module state is specified usingdedicated slots.
A typical use of module state is storing an exception type – or indeedanytype object defined by the module –
Unlike the module’s Python attributes, Python code cannot replace or deletedata stored in module state.
Keeping per-module information in attributes and module state, rather than instatic globals, makes module objectsisolated and safer for use inmultiple sub-interpreters.It also helps Python do an orderly clean-up when it shuts down.
Extensions that keep references to Python objects as part of module state mustimplementPy_mod_state_traverse andPy_mod_state_clearfunctions to avoid reference leaks.
To retrieve the state from a given module, use the following functions:
- void*PyModule_GetState(PyObject*module)¶
- Part of theStable ABI.
Return the “state” of the module, that is, a pointer to the block of memoryallocated at module creation time, or
NULL. SeePy_mod_state_size.On error, return
NULLwith an exception set.UsePyErr_Occurred()to tell this case apart from missingmodule state.
- intPyModule_GetStateSize(PyObject*,Py_ssize_t*result)¶
- Part of theStable ABI since version 3.15.
Set*result to the size of the module’s state, as specified using
Py_mod_state_size(orPyModuleDef.m_size),and return 0.On error, set*result to -1, and return -1 with an exception set.
Added in version 3.15.0a2 (unreleased).
Slots for defining module state¶
The followingPyModuleDef_Slot.slot IDs are available fordefining the module state.
- Py_mod_state_size¶
- Part of theStable ABI since version 3.15.
SlotIDfor the size of the module state,in bytes.Setting the value to a non-negative value means that the module can bere-initialized and specifies the additional amount of memory it requiresfor its state.
SeePEP 3121 for more details.
Use
PyModule_GetStateSize()to retrieve the size of a given module.Added in version 3.15.0a2 (unreleased):Use
PyModuleDef.m_sizeinstead to support previous versions.
- Py_mod_state_traverse¶
- Part of theStable ABI since version 3.15.
SlotIDfor a traversal function to callduring GC traversal of the module object.The signature of the function, and meanings of the arguments,is similar as for
PyTypeObject.tp_traverse:This function is not called if the module state was requested but is notallocated yet. This is the case immediately after the module is createdand before the module is executed (
Py_mod_execfunction). Moreprecisely, this function is not called if the state size(Py_mod_state_size) is greater than 0 and the module state(as returned byPyModule_GetState()) isNULL.Added in version 3.15.0a2 (unreleased):Use
PyModuleDef.m_sizeinstead to support previous versions.
- Py_mod_state_clear¶
- Part of theStable ABI since version 3.15.
SlotIDfor a clear function to callduring GC clearing of the module object.The signature of the function is:
This function is not called if the module state was requested but is notallocated yet. This is the case immediately after the module is createdand before the module is executed (
Py_mod_execfunction). Moreprecisely, this function is not called if the state size(Py_mod_state_size) is greater than 0 and the module state(as returned byPyModule_GetState()) isNULL.Like
PyTypeObject.tp_clear, this function is notalwayscalled before a module is deallocated. For example, when referencecounting is enough to determine that an object is no longer used,the cyclic garbage collector is not involved andthePy_mod_state_freefunction is called directly.Added in version 3.15.0a2 (unreleased):Use
PyModuleDef.m_clearinstead to support previous versions.
- Py_mod_state_free¶
- Part of theStable ABI since version 3.15.
SlotIDfor a function to call duringdeallocation of the module object.The signature of the function is:
This function is not called if the module state was requested but is notallocated yet. This is the case immediately after the module is createdand before the module is executed (
Py_mod_execfunction). Moreprecisely, this function is not called if the state size(Py_mod_state_size) is greater than 0 and the module state(as returned byPyModule_GetState()) isNULL.Added in version 3.15.0a2 (unreleased):Use
PyModuleDef.m_freeinstead to support previous versions.
Module token¶
Each module may have an associatedtoken: a pointer-sized value intended toidentify of the module state’s memory layout.This means that if you have a module object, but you are not sure if it“belongs” to your extension, you can check using code like this:
PyObject*module=<themoduleinquestion>void*module_token;if(PyModule_GetToken(module,&module_token)<0){returnNULL;}if(module_token!=your_token){PyErr_SetString(PyExc_ValueError,"unexpected module")returnNULL;}// This module's state has the expected memory layout; it's safe to caststructmy_statestate=(structmy_state*)PyModule_GetState(module)
A module’s token – and theyour_token value to use in the above code – is:
For modules created with
PyModuleDef: the address of thatPyModuleDef;For modules defined with the
Py_mod_tokenslot: the valueof that slot;For modules created from an
PyModExport_*export hook: the slots array that the exporthook returned (unless overriden withPy_mod_token).
- Py_mod_token¶
- Part of theStable ABI since version 3.15.
SlotIDfor the module token.If you use this slot to set the module token (rather than rely on thedefault), you must ensure that:
The pointer outlives the class, so it’s not reused for something elsewhile the class exists.
It “belongs” to the extension module where the class lives, so it will notclash with other extensions.
If the token points to a
PyModuleDefstruct, the module shouldbehave as if it was created from thatPyModuleDef.In particular, the module state must have matching layout and semantics.
Modules created from
PyModuleDefallways use the address ofthePyModuleDefas the token.This means thatPy_mod_tokencannot be used inPyModuleDef.m_slots.Added in version 3.15.0a2 (unreleased).
- intPyModule_GetToken(PyObject*module,void**result)¶
- Part of theStable ABI since version 3.15.
Set*result to the module’s token and return 0.
On error, set*result to NULL, and return -1 with an exception set.
Added in version 3.15.0a2 (unreleased).
See alsoPyType_GetModuleByToken().
Creating extension modules dynamically¶
The following functions may be used to create an extension module dynamically,rather than from an extension’sexport hook.
- PyObject*PyModule_FromSlotsAndSpec(constPyModuleDef_Slot*slots,PyObject*spec)¶
- Return value: New reference. Part of theStable ABI since version 3.15.
Create a new module object, given an array ofslotsand the
ModuleSpecspec.Theslots argument must point to an array of
PyModuleDef_Slotstructures, terminated by an entry slot with slot ID of 0(typically written as{0}or{0,NULL}in C).Theslots argument may not beNULL.Thespec argument may be any
ModuleSpec-like object, as describedinPy_mod_createdocumentation.Currently, thespec must have anameattribute.On success, return the new module.On error, return
NULLwith an exception set.Note that this does not process the module’s execution slot(
Py_mod_exec).BothPyModule_FromSlotsAndSpec()andPyModule_Exec()must be called to fully initialize a module.(See alsoMulti-phase initialization.)Theslots array only needs to be valid for the duration of the
PyModule_FromSlotsAndSpec()call.In particular, it may be heap-allocated.Added in version 3.15.0a2 (unreleased).
- intPyModule_Exec(PyObject*module)¶
- Part of theStable ABI since version 3.15.
Execute the
Py_mod_execslot(s) of the givenmodule.On success, return 0.On error, return -1 with an exception set.
For clarity: Ifmodule has no slots, for example if it useslegacy single-phase initialization,this function does nothing and returns 0.
Added in version 3.15.0a2 (unreleased).
Module definition struct¶
Traditionally, extension modules were defined using amodule definitionas the “description” of how a module should be created.Rather than using an array ofslots directly,the definition has dedicated members for most common functionality,and allows additional slots as an extension mechanism.
This way of defining modules is still available and there are no plans toremove it.
- typePyModuleDef¶
- Part of theStable ABI (including all members).
The module definition struct, which holds information needed to createa module object.
This structure must be statically allocated (or be otherwise guaranteedto be valid while any modules created from it exist).Usually, there is only one variable of this type for each extension moduledefined this way.
- PyModuleDef_Basem_base¶
Always initialize this member to
PyModuleDef_HEAD_INIT:- typePyModuleDef_Base¶
- Part of theStable ABI (including all members).
The type of
PyModuleDef.m_base.
- PyModuleDef_HEAD_INIT¶
The required initial value for
PyModuleDef.m_base.
- typePyModuleDef_Base¶
- constchar*m_name¶
Corresponds to the
Py_mod_nameslot.
- constchar*m_doc¶
These members correspond to the
Py_mod_docslot.Setting this to NULL is equivalent to omitting the slot.
- Py_ssize_tm_size¶
Corresponds to the
Py_mod_state_sizeslot.Setting this to zero is equivalent to omitting the slot.When usinglegacy single-phase initializationor when creating modules dynamically using
PyModule_Create()orPyModule_Create2(),m_sizemay be set to -1.This indicates that the module does not support sub-interpreters,because it has global state.
- PyMethodDef*m_methods¶
Corresponds to the
Py_mod_methodsslot.Setting this to NULL is equivalent to omitting the slot.
- PyModuleDef_Slot*m_slots¶
An array of additional slots, terminated by a
{0,NULL}entry.This array may not contain slots corresponding to
PyModuleDefmembers.For example, you cannot usePy_mod_nameinm_slots;the module name must be given asPyModuleDef.m_name.
- traverseprocm_traverse¶
- inquirym_clear¶
- freefuncm_free¶
These members correspond to the
Py_mod_state_traverse,Py_mod_state_clear, andPy_mod_state_freeslots,respectively.Setting these members to NULL is equivalent to omitting thecorresponding slots.
Changed in version 3.9:
m_traverse,m_clearandm_freefunctions are longer called before the module state is allocated.
- PyModuleDef_Basem_base¶
The following API can be used to create modules from aPyModuleDefstruct:
- PyObject*PyModule_Create(PyModuleDef*def)¶
- Return value: New reference.
Create a new module object, given the definition indef.This is a macro that calls
PyModule_Create2()withmodule_api_version set toPYTHON_API_VERSION, ortoPYTHON_ABI_VERSIONif using thelimited API.
- PyObject*PyModule_Create2(PyModuleDef*def,intmodule_api_version)¶
- Return value: New reference. Part of theStable ABI.
Create a new module object, given the definition indef, assuming theAPI versionmodule_api_version. If that version does not match the versionof the running interpreter, a
RuntimeWarningis emitted.Return
NULLwith an exception set on error.This function does not support slots.The
m_slotsmember ofdef must beNULL.Note
Most uses of this function should be using
PyModule_Create()instead; only use this if you are sure you need it.
- PyObject*PyModule_FromDefAndSpec(PyModuleDef*def,PyObject*spec)¶
- Return value: New reference.
This macro calls
PyModule_FromDefAndSpec2()withmodule_api_version set toPYTHON_API_VERSION, ortoPYTHON_ABI_VERSIONif using thelimited API.Added in version 3.5.
- PyObject*PyModule_FromDefAndSpec2(PyModuleDef*def,PyObject*spec,intmodule_api_version)¶
- Return value: New reference. Part of theStable ABI since version 3.7.
Create a new module object, given the definition indef and theModuleSpecspec, assuming the API versionmodule_api_version.If that version does not match the version of the running interpreter,a
RuntimeWarningis emitted.Return
NULLwith an exception set on error.Note that this does not process execution slots (
Py_mod_exec).BothPyModule_FromDefAndSpecandPyModule_ExecDefmust be calledto fully initialize a module.Note
Most uses of this function should be using
PyModule_FromDefAndSpec()instead; only use this if you are sure you need it.Added in version 3.5.
- intPyModule_ExecDef(PyObject*module,PyModuleDef*def)¶
- Part of theStable ABI since version 3.7.
Process any execution slots (
Py_mod_exec) given indef.Added in version 3.5.
- PYTHON_API_VERSION¶
The C API version. Defined for backwards compatibility.
Currently, this constant is not updated in new Python versions, and is notuseful for versioning. This may change in the future.
- PYTHON_ABI_VERSION¶
Defined as
3for backwards compatibility.Currently, this constant is not updated in new Python versions, and is notuseful for versioning. This may change in the future.
Support functions¶
The following functions are provided to help initialize a module object.They are intended for a module’s execution slot (Py_mod_exec),the initialization function for legacysingle-phase initialization,or code that creates modules dynamically.
- intPyModule_AddObjectRef(PyObject*module,constchar*name,PyObject*value)¶
- Part of theStable ABI since version 3.10.
Add an object tomodule asname. This is a convenience function whichcan be used from the module’s initialization function.
On success, return
0. On error, raise an exception and return-1.Example usage:
staticintadd_spam(PyObject*module,intvalue){PyObject*obj=PyLong_FromLong(value);if(obj==NULL){return-1;}intres=PyModule_AddObjectRef(module,"spam",obj);Py_DECREF(obj);returnres;}
To be convenient, the function accepts
NULLvalue with an exceptionset. In this case, return-1and just leave the raised exceptionunchanged.The example can also be written without checking explicitly ifobj is
NULL:staticintadd_spam(PyObject*module,intvalue){PyObject*obj=PyLong_FromLong(value);intres=PyModule_AddObjectRef(module,"spam",obj);Py_XDECREF(obj);returnres;}
Note that
Py_XDECREF()should be used instead ofPy_DECREF()inthis case, sinceobj can beNULL.The number of differentname strings passed to this functionshould be kept small, usually by only using statically allocated stringsasname.For names that aren’t known at compile time, prefer calling
PyUnicode_FromString()andPyObject_SetAttr()directly.For more details, seePyUnicode_InternFromString(), which may beused internally to create a key object.Added in version 3.10.
- intPyModule_Add(PyObject*module,constchar*name,PyObject*value)¶
- Part of theStable ABI since version 3.13.
Similar to
PyModule_AddObjectRef(), but “steals” a referencetovalue.It can be called with a result of function that returns a new referencewithout bothering to check its result or even saving it to a variable.Example usage:
if(PyModule_Add(module,"spam",PyBytes_FromString(value))<0){gotoerror;}
Added in version 3.13.
- intPyModule_AddObject(PyObject*module,constchar*name,PyObject*value)¶
- Part of theStable ABI.
Similar to
PyModule_AddObjectRef(), but steals a reference tovalue on success (if it returns0).The new
PyModule_Add()orPyModule_AddObjectRef()functions are recommended, since it iseasy to introduce reference leaks by misusing thePyModule_AddObject()function.Note
Unlike other functions that steal references,
PyModule_AddObject()only releases the reference tovalueon success.This means that its return value must be checked, and calling code must
Py_XDECREF()value manually on error.Example usage:
PyObject*obj=PyBytes_FromString(value);if(PyModule_AddObject(module,"spam",obj)<0){// If 'obj' is not NULL and PyModule_AddObject() failed,// 'obj' strong reference must be deleted with Py_XDECREF().// If 'obj' is NULL, Py_XDECREF() does nothing.Py_XDECREF(obj);gotoerror;}// PyModule_AddObject() stole a reference to obj:// Py_XDECREF(obj) is not needed here.
Deprecated since version 3.13:
PyModule_AddObject()issoft deprecated.
- intPyModule_AddIntConstant(PyObject*module,constchar*name,longvalue)¶
- Part of theStable ABI.
Add an integer constant tomodule asname. This convenience function can beused from the module’s initialization function.Return
-1with an exception set on error,0on success.This is a convenience function that calls
PyLong_FromLong()andPyModule_AddObjectRef(); see their documentation for details.
- intPyModule_AddStringConstant(PyObject*module,constchar*name,constchar*value)¶
- Part of theStable ABI.
Add a string constant tomodule asname. This convenience function can beused from the module’s initialization function. The stringvalue must be
NULL-terminated.Return-1with an exception set on error,0on success.This is a convenience function that calls
PyUnicode_InternFromString()andPyModule_AddObjectRef();see their documentation for details.
- PyModule_AddIntMacro(module,macro)¶
Add an int constant tomodule. The name and the value are taken frommacro. For example
PyModule_AddIntMacro(module,AF_INET)adds the intconstantAF_INET with the value ofAF_INET tomodule.Return-1with an exception set on error,0on success.
- PyModule_AddStringMacro(module,macro)¶
Add a string constant tomodule.
- intPyModule_AddType(PyObject*module,PyTypeObject*type)¶
- Part of theStable ABI since version 3.10.
Add a type object tomodule.The type object is finalized by calling internally
PyType_Ready().The name of the type object is taken from the last component oftp_nameafter dot.Return-1with an exception set on error,0on success.Added in version 3.9.
- intPyModule_AddFunctions(PyObject*module,PyMethodDef*functions)¶
- Part of theStable ABI since version 3.7.
Add the functions from the
NULLterminatedfunctions array tomodule.Refer to thePyMethodDefdocumentation for details on individualentries (due to the lack of a shared module namespace, module level“functions” implemented in C typically receive the module as their firstparameter, making them similar to instance methods on Python classes).This function is called automatically when creating a module from
PyModuleDef(such as when usingMulti-phase initialization,PyModule_Create, orPyModule_FromDefAndSpec).Some module authors may prefer defining functions in multiplePyMethodDefarrays; in that case they should call this functiondirectly.Thefunctions array must be statically allocated (or otherwise guaranteedto outlive the module object).
Added in version 3.5.
- intPyModule_SetDocString(PyObject*module,constchar*docstring)¶
- Part of theStable ABI since version 3.7.
Set the docstring formodule todocstring.This function is called automatically when creating a module from
PyModuleDef(such as when usingMulti-phase initialization,PyModule_Create, orPyModule_FromDefAndSpec).Added in version 3.5.
- intPyUnstable_Module_SetGIL(PyObject*module,void*gil)¶
- This isUnstable API. It may change without warning in minor releases.
Indicate thatmodule does or does not support running without the globalinterpreter lock (GIL), using one of the values from
Py_mod_gil. It must be called duringmodule’s initializationfunction when usingLegacy single-phase initialization.If this function is not called during module initialization, theimport machinery assumes the module does not support running without theGIL. This function is only available in Python builds configured with--disable-gil.Return-1with an exception set on error,0on success.Added in version 3.13.
Module lookup (single-phase initialization)¶
The legacysingle-phase initializationinitialization scheme creates singleton modules that can be looked upin the context of the current interpreter. This allows the module object to beretrieved later with only a reference to the module definition.
These functions will not work on modules created using multi-phase initialization,since multiple such modules can be created from a single definition.
- PyObject*PyState_FindModule(PyModuleDef*def)¶
- Return value: Borrowed reference. Part of theStable ABI.
Returns the module object that was created fromdef for the current interpreter.This method requires that the module object has been attached to the interpreter state with
PyState_AddModule()beforehand. In case the corresponding module object is notfound or has not been attached to the interpreter state yet, it returnsNULL.
- intPyState_AddModule(PyObject*module,PyModuleDef*def)¶
- Part of theStable ABI since version 3.3.
Attaches the module object passed to the function to the interpreter state. This allowsthe module object to be accessible via
PyState_FindModule().Only effective on modules created using single-phase initialization.
Python calls
PyState_AddModuleautomatically after importing a modulethat usessingle-phase initialization,so it is unnecessary (but harmless) to call it from module initializationcode. An explicit call is needed only if the module’s own init codesubsequently callsPyState_FindModule.The function is mainly intended for implementing alternative importmechanisms (either by calling it directly, or by referring to itsimplementation for details of the required state updates).If a module was attached previously using the samedef, it is replacedby the newmodule.
The caller must have anattached thread state.
Return
-1with an exception set on error,0on success.Added in version 3.3.
- intPyState_RemoveModule(PyModuleDef*def)¶
- Part of theStable ABI since version 3.3.
Removes the module object created fromdef from the interpreter state.Return
-1with an exception set on error,0on success.The caller must have anattached thread state.
Added in version 3.3.