Module Objects

PyTypeObjectPyModule_Type
Part of theStable ABI.

This instance ofPyTypeObject represents 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 ofPyModule_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 withmodule.__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.

ReturnNULL with 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 toPyModule_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),SystemError is raised andNULL is returned.

It is recommended extensions use otherPyModule_* 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,SystemError is raised andNULL is returned.

Added in version 3.3.

constchar*PyModule_GetName(PyObject*module)
Part of theStable ABI.

Similar toPyModule_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 thePyModuleDef struct from which the module wascreated, orNULL if the module wasn’t created from a definition.

On error, returnNULL with 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, raiseSystemError and returnNULL; otherwise returna reference to a Unicode object.

Added in version 3.2.

constchar*PyModule_GetFilename(PyObject*module)
Part of theStable ABI.

Similar toPyModule_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() raisesUnicodeEncodeError onunencodable 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 availablePy_mod_* values explained below.

An ID of 0 marks the end of aPyModuleDef_Slot array.

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 thePyModuleDef_Slot entry entirely.

Added in version 3.5.

Metadata slots

Py_mod_name
Part of theStable ABI since version 3.15.

SlotID for the name of the new module,as a NUL-terminated UTF8-encodedconstchar*.

Note that modules are typically created using aModuleSpec, 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):UsePyModuleDef.m_name instead to support previous versions.

Py_mod_doc
Part of theStable ABI since version 3.15.

SlotID for the docstring of the newmodule, as a NUL-terminated UTF8-encodedconstchar*.

Usually it is set to a variable created withPyDoc_STRVAR.

Added in version 3.15.0a2 (unreleased):UsePyModuleDef.m_doc instead to support previous versions.

Feature slots

Py_mod_abi
Part of theStable ABI since version 3.15.

SlotID whose value points toaPyABIInfo structure describing the ABI thatthe extension is using.

A suitablePyABIInfo variable can be defined using thePyABIInfo_VAR macro, as in:

PyABIInfo_VAR(abi_info);staticPyModuleDef_Slotmymodule_slots[]={{Py_mod_abi,&abi_info},...};

When creating a module, Python checks the value of this slotusingPyABIInfo_Check().

Added in version 3.15.

Py_mod_multiple_interpreters
Part of theStable ABI since version 3.12.

SlotID whose 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.

IfPy_mod_multiple_interpreters is not specified, the importmachinery defaults toPy_MOD_MULTIPLE_INTERPRETERS_SUPPORTED.

Added in version 3.12.

Py_mod_gil
Part of theStable ABI since version 3.13.

SlotID whose 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.

IfPy_mod_gil is not specified, the import machinery defaults toPy_MOD_GIL_USED.

Added in version 3.13.

Creation and initialization slots

Py_mod_create
Part of theStable ABI since version 3.5.

SlotID for 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: aModuleSpec-like object, meaning that any attributes definedforimportlib.machinery.ModuleSpec have 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 returnNULL.

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.

IfPy_mod_create is 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 ofPyModule_Type.However, some slots may only be used withPyModule_Type instances; in particular:

Added in version 3.5.

Changed in version 3.15.0a2 (unreleased):Theslots argument may be aModuleSpec-like object, rather thana trueModuleSpec instance.Note that previous versions of CPython did not enforce this.

Thedef argument may now beNULL, since modules are not necessarilymade from definitions.

Py_mod_exec
Part of theStable ABI since version 3.5.

SlotID for 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:

intexec_module(PyObject*module)

See theSupport functions section for some usefulfunctions to call.

For backwards compatibility, thePyModuleDef.m_slots array maycontain multiplePy_mod_exec slots; 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):RepeatedPy_mod_exec slots are disallowed, except inPyModuleDef.m_slots.

Py_mod_methods
Part of theStable ABI since version 3.15.

SlotID for a table of module-levelfunctions, as an array ofPyMethodDef values suitable as thefunctions argument toPyModule_AddFunctions().

Like other slot IDs, a slots array may only contain onePy_mod_methods entry.To add functions from multiplePyMethodDef arrays, callPyModule_AddFunctions() in thePy_mod_exec function.

The table must be statically allocated (or otherwise guaranteed to outlivethe module object).

Added in version 3.15.0a2 (unreleased):UsePyModuleDef.m_methods instead 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, orNULL. SeePy_mod_state_size.

On error, returnNULL with 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 usingPy_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.

SlotID for 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.

UsePyModule_GetStateSize() to retrieve the size of a given module.

Added in version 3.15.0a2 (unreleased):UsePyModuleDef.m_size instead to support previous versions.

Py_mod_state_traverse
Part of theStable ABI since version 3.15.

SlotID for a traversal function to callduring GC traversal of the module object.

The signature of the function, and meanings of the arguments,is similar as forPyTypeObject.tp_traverse:

inttraverse_module_state(PyObject*module,visitprocvisit,void*arg)

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_exec function). 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):UsePyModuleDef.m_size instead to support previous versions.

Py_mod_state_clear
Part of theStable ABI since version 3.15.

SlotID for a clear function to callduring GC clearing of the module object.

The signature of the function is:

intclear_module_state(PyObject*module)

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_exec function). 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.

LikePyTypeObject.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_free function is called directly.

Added in version 3.15.0a2 (unreleased):UsePyModuleDef.m_clear instead to support previous versions.

Py_mod_state_free
Part of theStable ABI since version 3.15.

SlotID for a function to call duringdeallocation of the module object.

The signature of the function is:

intfree_module_state(PyObject*module)

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_exec function). 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):UsePyModuleDef.m_free instead 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:

Py_mod_token
Part of theStable ABI since version 3.15.

SlotID for 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 aPyModuleDef struct, the module shouldbehave as if it was created from thatPyModuleDef.In particular, the module state must have matching layout and semantics.

Modules created fromPyModuleDef allways use the address ofthePyModuleDef as the token.This means thatPy_mod_token cannot 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 theModuleSpecspec.

Theslots argument must point to an array ofPyModuleDef_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 anyModuleSpec-like object, as describedinPy_mod_create documentation.Currently, thespec must have aname attribute.

On success, return the new module.On error, returnNULL with 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 thePyModule_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 thePy_mod_exec slot(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 toPyModuleDef_HEAD_INIT:

typePyModuleDef_Base
Part of theStable ABI (including all members).

The type ofPyModuleDef.m_base.

PyModuleDef_HEAD_INIT

The required initial value forPyModuleDef.m_base.

constchar*m_name

Corresponds to thePy_mod_name slot.

constchar*m_doc

These members correspond to thePy_mod_doc slot.Setting this to NULL is equivalent to omitting the slot.

Py_ssize_tm_size

Corresponds to thePy_mod_state_size slot.Setting this to zero is equivalent to omitting the slot.

When usinglegacy single-phase initializationor when creating modules dynamically usingPyModule_Create()orPyModule_Create2(),m_size may be set to -1.This indicates that the module does not support sub-interpreters,because it has global state.

PyMethodDef*m_methods

Corresponds to thePy_mod_methods slot.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 toPyModuleDefmembers.For example, you cannot usePy_mod_name inm_slots;the module name must be given asPyModuleDef.m_name.

Changed in version 3.5:Prior to version 3.5, this member was always set toNULL,and was defined as:

inquirym_reload
traverseprocm_traverse
inquirym_clear
freefuncm_free

These members correspond to thePy_mod_state_traverse,Py_mod_state_clear, andPy_mod_state_free slots,respectively.

Setting these members to NULL is equivalent to omitting thecorresponding slots.

Changed in version 3.9:m_traverse,m_clear andm_freefunctions are longer called before the module state is allocated.

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 callsPyModule_Create2() withmodule_api_version set toPYTHON_API_VERSION, ortoPYTHON_ABI_VERSION if 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, aRuntimeWarning is emitted.

ReturnNULL with an exception set on error.

This function does not support slots.Them_slots member ofdef must beNULL.

Note

Most uses of this function should be usingPyModule_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 callsPyModule_FromDefAndSpec2() withmodule_api_version set toPYTHON_API_VERSION, ortoPYTHON_ABI_VERSION if 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,aRuntimeWarning is emitted.

ReturnNULL with an exception set on error.

Note that this does not process execution slots (Py_mod_exec).BothPyModule_FromDefAndSpec andPyModule_ExecDef must be calledto fully initialize a module.

Note

Most uses of this function should be usingPyModule_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 as3 for 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, return0. 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 acceptsNULLvalue with an exceptionset. In this case, return-1 and just leave the raised exceptionunchanged.

The example can also be written without checking explicitly ifobj isNULL:

staticintadd_spam(PyObject*module,intvalue){PyObject*obj=PyLong_FromLong(value);intres=PyModule_AddObjectRef(module,"spam",obj);Py_XDECREF(obj);returnres;}

Note thatPy_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 callingPyUnicode_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 toPyModule_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 toPyModule_AddObjectRef(), but steals a reference tovalue on success (if it returns0).

The newPyModule_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 mustPy_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-1 with an exception set on error,0 on success.

This is a convenience function that callsPyLong_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 beNULL-terminated.Return-1 with an exception set on error,0 on success.

This is a convenience function that callsPyUnicode_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 examplePyModule_AddIntMacro(module,AF_INET) adds the intconstantAF_INET with the value ofAF_INET tomodule.Return-1 with an exception set on error,0 on 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 internallyPyType_Ready().The name of the type object is taken from the last component oftp_name after dot.Return-1 with an exception set on error,0 on success.

Added in version 3.9.

intPyModule_AddFunctions(PyObject*module,PyMethodDef*functions)
Part of theStable ABI since version 3.7.

Add the functions from theNULL terminatedfunctions array tomodule.Refer to thePyMethodDef documentation 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 fromPyModuleDef (such as when usingMulti-phase initialization,PyModule_Create, orPyModule_FromDefAndSpec).Some module authors may prefer defining functions in multiplePyMethodDef arrays; 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 fromPyModuleDef (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 fromPy_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-1 with an exception set on error,0 on 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 withPyState_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 viaPyState_FindModule().

Only effective on modules created using single-phase initialization.

Python callsPyState_AddModule automatically 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-1 with an exception set on error,0 on 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-1 with an exception set on error,0 on success.

The caller must have anattached thread state.

Added in version 3.3.