GObject.TypePlugin¶
interface
An interface that handles the lifecycle of dynamically loaded types.
The GObject type system supports dynamic loading of types. It goes as follows:
-
The type is initially introduced (usually upon loading the module the first time, or by your main application that knows what modules introduces what types), like this:
wherenew_type_pluginis an implementation of theGTypePlugininterface. -
The type's implementation is referenced, e.g. through
TypeClass.refor throughGObject.type_create_instance(this is being called byObject.new) or through one of the above done on a type derived fromnew_type_id. -
This causes the type system to load the type's implementation by calling
TypePlugin.useandTypePlugin.complete_type_infoonnew_type_plugin. -
At some point the type's implementation isn't required anymore, e.g. after
TypeClass.unrefortype_free_instance(called when the reference count of an instance drops to zero). -
This causes the type system to throw away the information retrieved from
TypePlugin.complete_type_infoand then it callsTypePlugin.unuseonnew_type_plugin. -
Things may repeat from the second step.
So basically, you need to implement a GTypePlugin type that
carries a use_count, once use_count goes from zero to one, you need
to load the implementation to successfully handle the upcoming
TypePlugin.complete_type_info call. Later, maybe after
succeeding use/unuse calls, once use_count drops to zero, you can
unload the implementation again. The type system makes sure to call
TypePlugin.use and TypePlugin.complete_type_info
again when the type is needed again.
TypeModule is an implementation of GTypePlugin that
already implements most of this except for the actual module loading and
unloading. It even handles multiple registered types per module.
Methods¶
complete_interface_info¶
def complete_interface_info(self, instance_type: type | Type, interface_type: type | Type, info: InterfaceInfo) -> None
Calls the complete_interface_info function from the
TypePluginClass of plugin. There should be no need to use this
function outside of the GObject type system itself.
Parameters:
instance_type— theGTypeof an instantiatable type to which the interface is addedinterface_type— theGTypeof the interface whose info is completedinfo— theInterfaceInfoto fill in
complete_type_info¶
def complete_type_info(self, g_type: type | Type, info: TypeInfo, value_table: TypeValueTable) -> None
Calls the complete_type_info function from the TypePluginClass of plugin.
There should be no need to use this function outside of the GObject
type system itself.
Parameters:
g_type— theGTypewhose info is completedinfo— theTypeInfostruct to fill invalue_table— theTypeValueTableto fill in
unuse¶
Calls the unuse_plugin function from the TypePluginClass of
plugin. There should be no need to use this function outside of
the GObject type system itself.
use¶
Calls the use_plugin function from the TypePluginClass of
plugin. There should be no need to use this function outside of
the GObject type system itself.