1 /* 2 * This file is part of gtkD. 3 * 4 * gtkD is free software; you can redistribute it and/or modify 5 * it under the terms of the GNU Lesser General Public License 6 * as published by the Free Software Foundation; either version 3 7 * of the License, or (at your option) any later version, with 8 * some exceptions, please read the COPYING file. 9 * 10 * gtkD is distributed in the hope that it will be useful, 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 * GNU Lesser General Public License for more details. 14 * 15 * You should have received a copy of the GNU Lesser General Public License 16 * along with gtkD; if not, write to the Free Software 17 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110, USA 18 */ 19 20 // generated automatically - do not change 21 // find conversion definition on APILookup.txt 22 // implement new conversion functionalities on the wrap.utils pakage 23 24 25 module gobject.TypePluginT; 26 27 public import gobject.c.functions; 28 public import gobject.c.types; 29 public import gtkc.gobjecttypes; 30 31 32 /** 33 * The GObject type system supports dynamic loading of types. 34 * The #GTypePlugin interface is used to handle the lifecycle 35 * of dynamically loaded types. It goes as follows: 36 * 37 * 1. The type is initially introduced (usually upon loading the module 38 * the first time, or by your main application that knows what modules 39 * introduces what types), like this: 40 * |[<!-- language="C" --> 41 * new_type_id = g_type_register_dynamic (parent_type_id, 42 * "TypeName", 43 * new_type_plugin, 44 * type_flags); 45 * ]| 46 * where @new_type_plugin is an implementation of the 47 * #GTypePlugin interface. 48 * 49 * 2. The type's implementation is referenced, e.g. through 50 * g_type_class_ref() or through g_type_create_instance() (this is 51 * being called by g_object_new()) or through one of the above done on 52 * a type derived from @new_type_id. 53 * 54 * 3. This causes the type system to load the type's implementation by 55 * calling g_type_plugin_use() and g_type_plugin_complete_type_info() 56 * on @new_type_plugin. 57 * 58 * 4. At some point the type's implementation isn't required anymore, 59 * e.g. after g_type_class_unref() or g_type_free_instance() (called 60 * when the reference count of an instance drops to zero). 61 * 62 * 5. This causes the type system to throw away the information retrieved 63 * from g_type_plugin_complete_type_info() and then it calls 64 * g_type_plugin_unuse() on @new_type_plugin. 65 * 66 * 6. Things may repeat from the second step. 67 * 68 * So basically, you need to implement a #GTypePlugin type that 69 * carries a use_count, once use_count goes from zero to one, you need 70 * to load the implementation to successfully handle the upcoming 71 * g_type_plugin_complete_type_info() call. Later, maybe after 72 * succeeding use/unuse calls, once use_count drops to zero, you can 73 * unload the implementation again. The type system makes sure to call 74 * g_type_plugin_use() and g_type_plugin_complete_type_info() again 75 * when the type is needed again. 76 * 77 * #GTypeModule is an implementation of #GTypePlugin that already 78 * implements most of this except for the actual module loading and 79 * unloading. It even handles multiple registered types per module. 80 */ 81 public template TypePluginT(TStruct) 82 { 83 /** Get the main Gtk struct */ 84 public GTypePlugin* getTypePluginStruct(bool transferOwnership = false) 85 { 86 if (transferOwnership) 87 ownedRef = false; 88 return cast(GTypePlugin*)getStruct(); 89 } 90 91 92 /** 93 * Calls the @complete_interface_info function from the 94 * #GTypePluginClass of @plugin. There should be no need to use this 95 * function outside of the GObject type system itself. 96 * 97 * Params: 98 * instanceType = the #GType of an instantiable type to which the interface 99 * is added 100 * interfaceType = the #GType of the interface whose info is completed 101 * info = the #GInterfaceInfo to fill in 102 */ 103 public void completeInterfaceInfo(GType instanceType, GType interfaceType, GInterfaceInfo* info) 104 { 105 g_type_plugin_complete_interface_info(getTypePluginStruct(), instanceType, interfaceType, info); 106 } 107 108 /** 109 * Calls the @complete_type_info function from the #GTypePluginClass of @plugin. 110 * There should be no need to use this function outside of the GObject 111 * type system itself. 112 * 113 * Params: 114 * gType = the #GType whose info is completed 115 * info = the #GTypeInfo struct to fill in 116 * valueTable = the #GTypeValueTable to fill in 117 */ 118 public void completeTypeInfo(GType gType, GTypeInfo* info, GTypeValueTable* valueTable) 119 { 120 g_type_plugin_complete_type_info(getTypePluginStruct(), gType, info, valueTable); 121 } 122 123 /** 124 * Calls the @unuse_plugin function from the #GTypePluginClass of 125 * @plugin. There should be no need to use this function outside of 126 * the GObject type system itself. 127 */ 128 public void unuse() 129 { 130 g_type_plugin_unuse(getTypePluginStruct()); 131 } 132 133 /** 134 * Calls the @use_plugin function from the #GTypePluginClass of 135 * @plugin. There should be no need to use this function outside of 136 * the GObject type system itself. 137 */ 138 public void use() 139 { 140 g_type_plugin_use(getTypePluginStruct()); 141 } 142 }