Tizen 2.1 base
[platform/upstream/glib2.0.git] / gobject / gtypemodule.h
1 /* GObject - GLib Type, Object, Parameter and Signal Library
2  * Copyright (C) 2000 Red Hat, Inc.
3  *
4  * This library is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2 of the License, or (at your option) any later version.
8  *
9  * This library is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public
15  * License along with this library; if not, write to the
16  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17  * Boston, MA 02111-1307, USA.
18  */
19 #if !defined (__GLIB_GOBJECT_H_INSIDE__) && !defined (GOBJECT_COMPILATION)
20 #error "Only <glib-object.h> can be included directly."
21 #endif
22
23 #ifndef __G_TYPE_MODULE_H__
24 #define __G_TYPE_MODULE_H__
25
26 #include <gobject/gobject.h>
27 #include <gobject/genums.h>
28
29 G_BEGIN_DECLS
30
31 typedef struct _GTypeModule      GTypeModule;
32 typedef struct _GTypeModuleClass GTypeModuleClass;
33
34 #define G_TYPE_TYPE_MODULE              (g_type_module_get_type ())
35 #define G_TYPE_MODULE(module)           (G_TYPE_CHECK_INSTANCE_CAST ((module), G_TYPE_TYPE_MODULE, GTypeModule))
36 #define G_TYPE_MODULE_CLASS(class)      (G_TYPE_CHECK_CLASS_CAST ((class), G_TYPE_TYPE_MODULE, GTypeModuleClass))
37 #define G_IS_TYPE_MODULE(module)        (G_TYPE_CHECK_INSTANCE_TYPE ((module), G_TYPE_TYPE_MODULE))
38 #define G_IS_TYPE_MODULE_CLASS(class)   (G_TYPE_CHECK_CLASS_TYPE ((class), G_TYPE_TYPE_MODULE))
39 #define G_TYPE_MODULE_GET_CLASS(module) (G_TYPE_INSTANCE_GET_CLASS ((module), G_TYPE_TYPE_MODULE, GTypeModuleClass))
40
41 /**
42  * GTypeModule:
43  * @name: the name of the module
44  * 
45  * The members of the <structname>GTypeModule</structname> structure should not 
46  * be accessed directly, except for the @name field.
47  */
48 struct _GTypeModule 
49 {
50   GObject parent_instance;
51
52   guint use_count;
53   GSList *type_infos;
54   GSList *interface_infos;
55
56   /*< public >*/
57   gchar *name;
58 };
59
60 /**
61  * GTypeModuleClass:
62  * @parent_class: the parent class
63  * @load: loads the module and registers one or more types using
64  *  g_type_module_register_type().
65  * @unload: unloads the module
66  * 
67  * In order to implement dynamic loading of types based on #GTypeModule, 
68  * the @load and @unload functions in #GTypeModuleClass must be implemented.
69  */
70 struct _GTypeModuleClass
71 {
72   GObjectClass parent_class;
73
74   /*< public >*/
75   gboolean (* load)   (GTypeModule *module);
76   void     (* unload) (GTypeModule *module);
77
78   /*< private >*/
79   /* Padding for future expansion */
80   void (*reserved1) (void);
81   void (*reserved2) (void);
82   void (*reserved3) (void);
83   void (*reserved4) (void);
84 };
85
86 /**
87  * G_DEFINE_DYNAMIC_TYPE:
88  * @TN: The name of the new type, in Camel case.
89  * @t_n: The name of the new type, in lowercase, with words
90  *  separated by '_'.
91  * @T_P: The #GType of the parent type.
92  * 
93  * A convenience macro for dynamic type implementations, which declares a
94  * class initialization function, an instance initialization function (see 
95  * #GTypeInfo for information about these) and a static variable named 
96  * @t_n<!-- -->_parent_class pointing to the parent class. Furthermore, 
97  * it defines a <function>*_get_type()</function> and a static 
98  * <function>*_register_type()</function> function for use in your
99  * <function>module_init()</function>.
100  * See G_DEFINE_DYNAMIC_TYPE_EXTENDED() for an example.
101  * 
102  * Since: 2.14
103  */
104 #define G_DEFINE_DYNAMIC_TYPE(TN, t_n, T_P)          G_DEFINE_DYNAMIC_TYPE_EXTENDED (TN, t_n, T_P, 0, {})
105 /**
106  * G_DEFINE_DYNAMIC_TYPE_EXTENDED:
107  * @TypeName: The name of the new type, in Camel case.
108  * @type_name: The name of the new type, in lowercase, with words
109  *  separated by '_'.
110  * @TYPE_PARENT: The #GType of the parent type.
111  * @flags: #GTypeFlags to pass to g_type_module_register_type()
112  * @CODE: Custom code that gets inserted in the *_get_type() function.
113  * 
114  * A more general version of G_DEFINE_DYNAMIC_TYPE() which
115  * allows to specify #GTypeFlags and custom code.
116  * 
117  * |[
118  * G_DEFINE_DYNAMIC_TYPE_EXTENDED (GtkGadget,
119  *                                 gtk_gadget,
120  *                                 GTK_TYPE_THING,
121  *                                 0,
122  *                                 G_IMPLEMENT_INTERFACE_DYNAMIC (TYPE_GIZMO,
123  *                                                                gtk_gadget_gizmo_init));
124  * ]|
125  * expands to
126  * |[
127  * static void     gtk_gadget_init              (GtkGadget      *self);
128  * static void     gtk_gadget_class_init        (GtkGadgetClass *klass);
129  * static void     gtk_gadget_class_finalize    (GtkGadgetClass *klass);
130  * 
131  * static gpointer gtk_gadget_parent_class = NULL;
132  * static GType    gtk_gadget_type_id = 0;
133  * 
134  * static void     gtk_gadget_class_intern_init (gpointer klass)
135  * {
136  *   gtk_gadget_parent_class = g_type_class_peek_parent (klass); 
137  *   gtk_gadget_class_init ((GtkGadgetClass*) klass); 
138  * }
139  * 
140  * GType
141  * gtk_gadget_get_type (void)
142  * {
143  *   return gtk_gadget_type_id;
144  * }
145  * 
146  * static void
147  * gtk_gadget_register_type (GTypeModule *type_module)
148  * {
149  *   const GTypeInfo g_define_type_info = {
150  *     sizeof (GtkGadgetClass),
151  *     (GBaseInitFunc) NULL,
152  *     (GBaseFinalizeFunc) NULL,
153  *     (GClassInitFunc) gtk_gadget_class_intern_init,
154  *     (GClassFinalizeFunc) gtk_gadget_class_finalize,
155  *     NULL,   // class_data
156  *     sizeof (GtkGadget),
157  *     0,      // n_preallocs
158  *     (GInstanceInitFunc) gtk_gadget_init, 
159  *     NULL    // value_table
160  *   };
161  *   gtk_gadget_type_id = g_type_module_register_type (type_module,
162  *                                                     GTK_TYPE_THING,
163  *                                                     GtkGadget,
164  *                                                     &g_define_type_info,
165  *                                                     (GTypeFlags) flags);
166  *   {
167  *     const GInterfaceInfo g_implement_interface_info = {
168  *       (GInterfaceInitFunc) gtk_gadget_gizmo_init
169  *     };
170  *     g_type_module_add_interface (type_module, g_define_type_id, TYPE_GIZMO, &g_implement_interface_info);
171  *   }
172  * }
173  * ]|
174  * 
175  * Since: 2.14
176  */
177 #define G_DEFINE_DYNAMIC_TYPE_EXTENDED(TypeName, type_name, TYPE_PARENT, flags, CODE) \
178 static void     type_name##_init              (TypeName        *self); \
179 static void     type_name##_class_init        (TypeName##Class *klass); \
180 static void     type_name##_class_finalize    (TypeName##Class *klass); \
181 static gpointer type_name##_parent_class = NULL; \
182 static GType    type_name##_type_id = 0; \
183 static void     type_name##_class_intern_init (gpointer klass) \
184 { \
185   type_name##_parent_class = g_type_class_peek_parent (klass); \
186   type_name##_class_init ((TypeName##Class*) klass); \
187 } \
188 GType \
189 type_name##_get_type (void) \
190 { \
191   return type_name##_type_id; \
192 } \
193 static void \
194 type_name##_register_type (GTypeModule *type_module) \
195 { \
196   GType g_define_type_id G_GNUC_UNUSED; \
197   const GTypeInfo g_define_type_info = { \
198     sizeof (TypeName##Class), \
199     (GBaseInitFunc) NULL, \
200     (GBaseFinalizeFunc) NULL, \
201     (GClassInitFunc) type_name##_class_intern_init, \
202     (GClassFinalizeFunc) type_name##_class_finalize, \
203     NULL,   /* class_data */ \
204     sizeof (TypeName), \
205     0,      /* n_preallocs */ \
206     (GInstanceInitFunc) type_name##_init, \
207     NULL    /* value_table */ \
208   }; \
209   type_name##_type_id = g_type_module_register_type (type_module, \
210                                                      TYPE_PARENT, \
211                                                      #TypeName, \
212                                                      &g_define_type_info, \
213                                                      (GTypeFlags) flags); \
214   g_define_type_id = type_name##_type_id; \
215   { CODE ; } \
216 }
217
218 /**
219  * G_IMPLEMENT_INTERFACE_DYNAMIC:
220  * @TYPE_IFACE: The #GType of the interface to add
221  * @iface_init: The interface init function
222  *
223  * A convenience macro to ease interface addition in the @_C_ section
224  * of G_DEFINE_DYNAMIC_TYPE_EXTENDED(). See G_DEFINE_DYNAMIC_TYPE_EXTENDED()
225  * for an example.
226  *
227  * Note that this macro can only be used together with the
228  * G_DEFINE_DYNAMIC_TYPE_EXTENDED macros, since it depends on variable
229  * names from that macro.
230  *
231  * Since: 2.24
232  */
233 #define G_IMPLEMENT_INTERFACE_DYNAMIC(TYPE_IFACE, iface_init)       { \
234   const GInterfaceInfo g_implement_interface_info = { \
235     (GInterfaceInitFunc) iface_init, NULL, NULL      \
236   }; \
237   g_type_module_add_interface (type_module, g_define_type_id, TYPE_IFACE, &g_implement_interface_info); \
238 }
239
240 GType    g_type_module_get_type       (void) G_GNUC_CONST;
241 gboolean g_type_module_use            (GTypeModule          *module);
242 void     g_type_module_unuse          (GTypeModule          *module);
243 void     g_type_module_set_name       (GTypeModule          *module,
244                                        const gchar          *name);
245 GType    g_type_module_register_type  (GTypeModule          *module,
246                                        GType                 parent_type,
247                                        const gchar          *type_name,
248                                        const GTypeInfo      *type_info,
249                                        GTypeFlags            flags);
250 void     g_type_module_add_interface  (GTypeModule          *module,
251                                        GType                 instance_type,
252                                        GType                 interface_type,
253                                        const GInterfaceInfo *interface_info);
254 GType    g_type_module_register_enum  (GTypeModule          *module,
255                                        const gchar          *name,
256                                        const GEnumValue     *const_static_values);
257 GType    g_type_module_register_flags (GTypeModule          *module,
258                                        const gchar          *name,
259                                        const GFlagsValue    *const_static_values);
260
261 G_END_DECLS
262
263 #endif /* __G_TYPE_MODULE_H__ */