2000-11-05 06:07:26 +01:00
|
|
|
/* GObject - GLib Type, Object, Parameter and Signal Library
|
|
|
|
* Copyright (C) 2000 Red Hat, Inc.
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General
|
2014-01-23 12:58:29 +01:00
|
|
|
* Public License along with this library; if not, see <http://www.gnu.org/licenses/>.
|
2000-11-05 06:07:26 +01:00
|
|
|
*/
|
2012-12-28 05:43:14 +01:00
|
|
|
#ifndef __G_TYPE_PLUGIN_H__
|
|
|
|
#define __G_TYPE_PLUGIN_H__
|
|
|
|
|
2001-11-18 01:38:48 +01:00
|
|
|
#if !defined (__GLIB_GOBJECT_H_INSIDE__) && !defined (GOBJECT_COMPILATION)
|
|
|
|
#error "Only <glib-object.h> can be included directly."
|
|
|
|
#endif
|
2000-11-05 06:07:26 +01:00
|
|
|
|
|
|
|
#include <gobject/gtype.h>
|
|
|
|
|
2001-03-09 22:39:51 +01:00
|
|
|
G_BEGIN_DECLS
|
2000-11-05 06:07:26 +01:00
|
|
|
|
|
|
|
/* --- type macros --- */
|
|
|
|
#define G_TYPE_TYPE_PLUGIN (g_type_plugin_get_type ())
|
|
|
|
#define G_TYPE_PLUGIN(inst) (G_TYPE_CHECK_INSTANCE_CAST ((inst), G_TYPE_TYPE_PLUGIN, GTypePlugin))
|
|
|
|
#define G_TYPE_PLUGIN_CLASS(vtable) (G_TYPE_CHECK_CLASS_CAST ((vtable), G_TYPE_TYPE_PLUGIN, GTypePluginClass))
|
|
|
|
#define G_IS_TYPE_PLUGIN(inst) (G_TYPE_CHECK_INSTANCE_TYPE ((inst), G_TYPE_TYPE_PLUGIN))
|
|
|
|
#define G_IS_TYPE_PLUGIN_CLASS(vtable) (G_TYPE_CHECK_CLASS_TYPE ((vtable), G_TYPE_TYPE_PLUGIN))
|
|
|
|
#define G_TYPE_PLUGIN_GET_CLASS(inst) (G_TYPE_INSTANCE_GET_INTERFACE ((inst), G_TYPE_TYPE_PLUGIN, GTypePluginClass))
|
|
|
|
|
|
|
|
|
|
|
|
/* --- typedefs & structures --- */
|
|
|
|
typedef struct _GTypePluginClass GTypePluginClass;
|
2008-06-21 20:20:43 +02:00
|
|
|
/**
|
|
|
|
* GTypePluginUse:
|
|
|
|
* @plugin: the #GTypePlugin whose use count should be increased
|
|
|
|
*
|
|
|
|
* The type of the @use_plugin function of #GTypePluginClass, which gets called
|
|
|
|
* to increase the use count of @plugin.
|
|
|
|
*/
|
2000-11-05 06:07:26 +01:00
|
|
|
typedef void (*GTypePluginUse) (GTypePlugin *plugin);
|
2008-06-21 20:20:43 +02:00
|
|
|
/**
|
|
|
|
* GTypePluginUnuse:
|
|
|
|
* @plugin: the #GTypePlugin whose use count should be decreased
|
|
|
|
*
|
|
|
|
* The type of the @unuse_plugin function of #GTypePluginClass.
|
|
|
|
*/
|
2000-11-05 06:07:26 +01:00
|
|
|
typedef void (*GTypePluginUnuse) (GTypePlugin *plugin);
|
2008-06-21 20:20:43 +02:00
|
|
|
/**
|
|
|
|
* GTypePluginCompleteTypeInfo:
|
|
|
|
* @plugin: the #GTypePlugin
|
|
|
|
* @g_type: the #GType whose info is completed
|
|
|
|
* @info: the #GTypeInfo struct to fill in
|
|
|
|
* @value_table: the #GTypeValueTable to fill in
|
|
|
|
*
|
|
|
|
* The type of the @complete_type_info function of #GTypePluginClass.
|
|
|
|
*/
|
2000-11-05 06:07:26 +01:00
|
|
|
typedef void (*GTypePluginCompleteTypeInfo) (GTypePlugin *plugin,
|
|
|
|
GType g_type,
|
|
|
|
GTypeInfo *info,
|
|
|
|
GTypeValueTable *value_table);
|
2008-06-21 20:20:43 +02:00
|
|
|
/**
|
|
|
|
* GTypePluginCompleteInterfaceInfo:
|
|
|
|
* @plugin: the #GTypePlugin
|
|
|
|
* @instance_type: the #GType of an instantiable type to which the interface
|
|
|
|
* is added
|
|
|
|
* @interface_type: the #GType of the interface whose info is completed
|
|
|
|
* @info: the #GInterfaceInfo to fill in
|
|
|
|
*
|
|
|
|
* The type of the @complete_interface_info function of #GTypePluginClass.
|
|
|
|
*/
|
2000-11-05 06:07:26 +01:00
|
|
|
typedef void (*GTypePluginCompleteInterfaceInfo) (GTypePlugin *plugin,
|
|
|
|
GType instance_type,
|
2002-06-11 23:44:35 +02:00
|
|
|
GType interface_type,
|
2000-11-05 06:07:26 +01:00
|
|
|
GInterfaceInfo *info);
|
2008-06-21 20:20:43 +02:00
|
|
|
/**
|
|
|
|
* GTypePlugin:
|
|
|
|
*
|
2014-03-07 12:10:36 +01:00
|
|
|
* The GTypePlugin typedef is used as a placeholder
|
|
|
|
* for objects that implement the GTypePlugin interface.
|
2008-06-21 20:20:43 +02:00
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* GTypePluginClass:
|
|
|
|
* @use_plugin: Increases the use count of the plugin.
|
|
|
|
* @unuse_plugin: Decreases the use count of the plugin.
|
|
|
|
* @complete_type_info: Fills in the #GTypeInfo and
|
|
|
|
* #GTypeValueTable structs for the type. The structs are initialized
|
2014-03-03 00:20:37 +01:00
|
|
|
* with `memset(s, 0, sizeof (s))` before calling this function.
|
2008-06-21 20:20:43 +02:00
|
|
|
* @complete_interface_info: Fills in missing parts of the #GInterfaceInfo
|
2014-03-03 00:20:37 +01:00
|
|
|
* for the interface. The structs is initialized with
|
|
|
|
* `memset(s, 0, sizeof (s))` before calling this function.
|
2008-06-21 20:20:43 +02:00
|
|
|
*
|
|
|
|
* The #GTypePlugin interface is used by the type system in order to handle
|
|
|
|
* the lifecycle of dynamically loaded types.
|
|
|
|
*/
|
2000-11-05 06:07:26 +01:00
|
|
|
struct _GTypePluginClass
|
|
|
|
{
|
2003-10-18 01:33:03 +02:00
|
|
|
/*< private >*/
|
2000-11-05 06:07:26 +01:00
|
|
|
GTypeInterface base_iface;
|
|
|
|
|
2003-10-18 01:33:03 +02:00
|
|
|
/*< public >*/
|
2000-11-05 06:07:26 +01:00
|
|
|
GTypePluginUse use_plugin;
|
|
|
|
GTypePluginUnuse unuse_plugin;
|
|
|
|
GTypePluginCompleteTypeInfo complete_type_info;
|
|
|
|
GTypePluginCompleteInterfaceInfo complete_interface_info;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/* --- prototypes --- */
|
2012-12-06 20:04:59 +01:00
|
|
|
GLIB_AVAILABLE_IN_ALL
|
2000-11-05 06:07:26 +01:00
|
|
|
GType g_type_plugin_get_type (void) G_GNUC_CONST;
|
2012-12-06 20:04:59 +01:00
|
|
|
GLIB_AVAILABLE_IN_ALL
|
2000-11-05 06:07:26 +01:00
|
|
|
void g_type_plugin_use (GTypePlugin *plugin);
|
2012-12-06 20:04:59 +01:00
|
|
|
GLIB_AVAILABLE_IN_ALL
|
2000-11-05 06:07:26 +01:00
|
|
|
void g_type_plugin_unuse (GTypePlugin *plugin);
|
2012-12-06 20:04:59 +01:00
|
|
|
GLIB_AVAILABLE_IN_ALL
|
2000-11-05 06:07:26 +01:00
|
|
|
void g_type_plugin_complete_type_info (GTypePlugin *plugin,
|
|
|
|
GType g_type,
|
|
|
|
GTypeInfo *info,
|
|
|
|
GTypeValueTable *value_table);
|
2012-12-06 20:04:59 +01:00
|
|
|
GLIB_AVAILABLE_IN_ALL
|
2000-11-05 06:07:26 +01:00
|
|
|
void g_type_plugin_complete_interface_info (GTypePlugin *plugin,
|
|
|
|
GType instance_type,
|
2002-06-11 23:44:35 +02:00
|
|
|
GType interface_type,
|
2000-11-05 06:07:26 +01:00
|
|
|
GInterfaceInfo *info);
|
|
|
|
|
2001-03-09 22:39:51 +01:00
|
|
|
G_END_DECLS
|
2000-11-05 06:07:26 +01:00
|
|
|
|
|
|
|
#endif /* __G_TYPE_PLUGIN_H__ */
|