| Top |  |  |  |  | 
| gpointer | construct-properties | Write / Construct Only | 
| PeasEngine * | engine | Read / Write / Construct Only | 
| GType * | extension-type | Read / Write / Construct Only | 
A PeasExtensionSet is an object which proxies method calls to a set of actual extensions. The application writer will use these objects in order to call methods on several instances of an actual extension exported by all the currently loaded plugins.
PeasExtensionSet will automatically track loading and unloading of the plugins, and signal appearance and disappearance of new extension instances. You should connect to those signals if you wish to call specific methods on loading or unloading time.
Here is the code for a typical setup of PeasExtensionSet with PeasActivatable as the watched extension point, and GtkWindow instances as the target objects:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 | static void on_extension_added (PeasExtensionSet *set, PeasPluginInfo *info, PeasActivatable *activatable) { peas_activatable_activate (activatable); } static void on_extension_removed (PeasExtensionSet *set, PeasPluginInfo *info, PeasActivatable *activatable) { peas_activatable_deactivate (activatable); } PeasExtensionSet * setup_extension_set (PeasEngine *engine, GtkWindow *window) { PeasExtensionSet *set; set = peas_extension_set_new (engine, PEAS_TYPE_ACTIVATABLE, "object", window, NULL); peas_extension_set_foreach (set, (PeasExtensionSetForeachFunc) on_extension_added, NULL); g_signal_connect (set, "extension-added", G_CALLBACK (on_extension_added), NULL); g_signal_connect (set, "extension-removed", G_CALLBACK (on_extension_removed), NULL); return set; } | 
void (*PeasExtensionSetForeachFunc) (PeasExtensionSet *set,PeasPluginInfo *info,PeasExtension *exten,gpointer data);
This function is passed to peas_extension_set_foreach() and
will be called for each extension in set
.
Since: 1.2
gboolean peas_extension_set_call (PeasExtensionSet *set,const gchar *method_name,...);
peas_extension_set_call has been deprecated since version 1.2 and should not be used in newly-written code.
Use peas_extension_set_foreach() instead.
Call a method on all the PeasExtension instances contained in set
.
See peas_extension_call() for more information.
gboolean peas_extension_set_call_valist (PeasExtensionSet *set,const gchar *method_name,va_list va_args);
peas_extension_set_call_valist has been deprecated since version 1.2 and should not be used in newly-written code.
Use peas_extension_set_foreach() instead.
Call a method on all the PeasExtension instances contained in set
.
See peas_extension_call_valist() for more information.
gboolean peas_extension_set_callv (PeasExtensionSet *set,const gchar *method_name,GIArgument *args);
peas_extension_set_callv has been deprecated since version 1.2 and should not be used in newly-written code.
Use peas_extension_set_foreach() instead.
Call a method on all the PeasExtension instances contained in set
.
See peas_extension_callv() for more information.
void peas_extension_set_foreach (PeasExtensionSet *set,PeasExtensionSetForeachFunc func,gpointer data);
Calls func
 for each PeasExtension.
| set | ||
| func | A function call for each extension. | [scope call] | 
| data | Optional data to be passed to the function or  | 
Since: 1.2
PeasExtension * peas_extension_set_get_extension (PeasExtensionSet *set,PeasPluginInfo *info);
Returns the PeasExtension object corresponding to info
, or NULL
if the plugin doesn't provide such an extension.
PeasExtensionSet * peas_extension_set_new (PeasEngine *engine,GType exten_type,const gchar *first_property,...);
Create a new PeasExtensionSet for the exten_type
 extension type.
At any moment, the PeasExtensionSet will contain an extension instance for
each loaded plugin which implements the exten_type
 extension type. It does
so by connecting to the relevant signals from PeasEngine.
The property values passed to peas_extension_set_new() will be used for the
construction of new extension instances.
If engine
 is NULL, then the default engine will be used.
See peas_engine_create_extension() for more information.
[skip]
| engine |  A PeasEngine, or  | [allow-none] | 
| exten_type | the extension GType. | |
| first_property | the name of the first property. | |
| ... | the value of the first property, followed optionally by more
name/value pairs, followed by  | 
PeasExtensionSet * peas_extension_set_newv (PeasEngine *engine,GType exten_type,guint n_parameters,GParameter *parameters);
Create a new PeasExtensionSet for the exten_type
 extension type.
If engine
 is NULL, then the default engine will be used.
See peas_extension_set_new() for more information.
[rename-to peas_extension_set_new]
| engine |  A PeasEngine, or  | [allow-none] | 
| exten_type | the extension GType. | |
| n_parameters | the length of the  | |
| parameters | an array of GParameter. | [array length=n_parameters] | 
PeasExtensionSet * peas_extension_set_new_valist (PeasEngine *engine,GType exten_type,const gchar *first_property,va_list var_args);
Create a new PeasExtensionSet for the exten_type
 extension type.
If engine
 is NULL, then the default engine will be used.
See peas_extension_set_new() for more information.
[skip]
| engine |  A PeasEngine, or  | [allow-none] | 
| exten_type | the extension GType. | |
| first_property | the name of the first property. | |
| var_args | the value of the first property, followed optionally by more
name/value pairs, followed by  | 
struct PeasExtensionSet;
The PeasExtensionSet structure contains only private data and should only be accessed using the provided API.
struct PeasExtensionSetClass {
  GObjectClass parent_class;
  /* Virtual public methods */
#ifndef PEAS_DISABLE_DEPRECATED
  gboolean   (*call)                      (PeasExtensionSet *set,
                                           const gchar      *method_name,
                                           GIArgument       *args);
#else
  /* Signals */
  void       (*extension_added)           (PeasExtensionSet *set,
                                           PeasPluginInfo   *info,
                                           PeasExtension    *exten);
  void       (*extension_removed)         (PeasExtensionSet *set,
                                           PeasPluginInfo   *info,
                                           PeasExtension    *exten);
};
The class structure for PeasExtensionSet.
| GObjectClass  | The parent class. | |
| The VFunc for  | ||
| Signal class handler for the “extension-added” signal. | ||
| Signal class handler for the “extension-removed” signal. | 
“construct-properties” property“construct-properties” gpointer
The properties to pass the extensions when creating them.
Flags: Write / Construct Only
“engine” property“engine” PeasEngine *
The PeasEngine this set is attached to.
Flags: Read / Write / Construct Only
“extension-type” property“extension-type” GType *
The extension GType managed by this set.
Flags: Read / Write / Construct Only
Allowed values: void
“extension-added” signalvoid user_function (PeasExtensionSet *set, PeasPluginInfo *info, GObject *exten, gpointer user_data)
The extension-added signal is emitted when a new extension has been added to the PeasExtensionSet. It happens when a new plugin implementing the extension set's extension type is loaded.
You should connect to this signal in order to set up the extensions when they are loaded. Note that this signal is not fired for extensions coming from plugins that were already loaded when the PeasExtensionSet instance was created. You should set those up by yourself.
Flags: Run Last
“extension-removed” signalvoid user_function (PeasExtensionSet *set, PeasPluginInfo *info, GObject *exten, gpointer user_data)
The extension-removed signal is emitted when a new extension is about to be removed from the PeasExtensionSet. It happens when a plugin implementing the extension set's extension type is unloaded, or when the PeasExtensionSet itself is destroyed.
You should connect to this signal in order to clean up the extensions when their plugin is unload. Note that this signal is not fired for the PeasExtension instances still available when the PeasExtensionSet instance is destroyed. You should clean those up by yourself.
Flags: Run Last