|  |  |  | Mission Control Plugins Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | ||||
| Plugin loader and global functionsPlugin loader and global functions — Writing a plugin, or loading plugins | 
#include <mission-control-plugins/mission-control-plugins.h> GObject * mcp_plugin_ref_nth_object (guint n); #define MCP_PLUGIN_REF_NTH_OBJECT_SYMBOL void mcp_set_debug (gboolean debug); void mcp_add_object (gpointer object); void mcp_read_dir (const gchar *path); const GList * mcp_list_objects (void);
To write plugins for Mission Control, build a GModule whose name starts
with "mcp-" and ends with G_MODULE_SUFFIX, for instance mcp-testplugin.so
on Linux or mcp-testplugin.dll on Windows. It must be installed in the
directory given by the ${plugindir} variable in the mission-control-plugins
pkg-config file.
Each plugin must contain an extern (public) function called
mcp_plugin_ref_nth_object() which behaves as documented here. Mission
Control will call that function to load the plugin.
Mission Control also uses functions from this part of the library, to load the plugins.
GObject *           mcp_plugin_ref_nth_object           (guint n);
Implemented by each plugin (not implemented in this library!) as a hook
point; it will be called repeatedly with an increasing argument, and must
return a GObject reference each time, until it returns NULL.
Mission Control will query each object for the GInterfaces it implements, and behave accordingly; for instance, the objects might implement McpRequestPolicy and/or McpDispatchOperationPolicy.
As currently implemented, these objects are never unreferenced.
#define MCP_PLUGIN_REF_NTH_OBJECT_SYMBOL "mcp_plugin_ref_nth_object"
A string constant whose value is the name mcp_plugin_ref_nth_object().
void                mcp_set_debug                       (gboolean debug);
Set whether debug output will be produced via g_debug() for the plugin
loader. Plugins shouldn't normally need to call this function.
| 
 | whether to log debug output | 
void                mcp_add_object                      (gpointer object);
Add an object to the list of "plugin objects". Mission Control does this
automatically for the objects returned by mcp_plugin_ref_nth_object(),
so you should only need to use this if you're embedding part of Mission
Control in a larger process.
As currently implemented, these objects are never unreferenced.
Mission Control uses this function to load its plugins; plugins shouldn't call it.
| 
 | an object implementing one or more plugin interfaces | 
void                mcp_read_dir                        (const gchar *path);
Read plugins from the given path. Any file with prefix "mcp-" and suffix
G_MODULE_SUFFIX is considered as a potential plugin, and loaded; if it
contains the symbol mcp_plugin_ref_nth_object(), the plugin is made
resident, then that symbol is called as a function until it returns NULL.
Mission Control uses this function to load its plugins; plugins shouldn't call it.
| 
 | full path to a plugins directory | 
const GList *       mcp_list_objects                    (void);
Return a list of objects that might implement plugin interfaces.
Mission Control uses this function to iterate through the loaded plugin objects; plugins shouldn't need to call it.
| Returns : | a constant list of plugin objects |