|  |  |  | Peas Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | ||||
typedef PeasExtension; GType peas_extension_get_extension_type (PeasExtension *exten); gboolean peas_extension_call (PeasExtension *exten,const gchar *method_name,...); gboolean peas_extension_call_valist (PeasExtension *exten,const gchar *method_name,va_list args); gboolean peas_extension_callv (PeasExtension *exten,const gchar *method_name,GIArgument *args,GIArgument *return_value);
PeasExtension is a proxy class used to access actual extensions implemented using various languages. As such, the application writer will use PeasExtension instances to call methods on extension provided by loaded plugins.
To properly use the proxy instances, you will need GObject-introspection data for the GInterface or GObjectClass you want to use as an extension point. For instance, if you wish to use PeasActivatable, you will need to put the following code excerpt in the engine initialization code, in order to load the required "Peas" typelib:
| 1 | 
You should proceed the same way for any namespace which provides interfaces you want to use as extension points. GObject-introspection data is required for all the supported languages, even for C.
PeasExtension does not provide any way to access the underlying object. The main reason is that some loaders may not rely on proper GObject inheritance for the definition of extensions, and hence it would not be possible for libpeas to provide a functional GObject instance at all. Another reason is that it makes reference counting issues easier to deal with.
See peas_extension_call() for more information.
GType               peas_extension_get_extension_type   (PeasExtension *exten);
Get the type of the extension interface of the object proxied by exten.
| 
 | A PeasExtension. | 
| Returns : | The GType proxied by exten. | 
gboolean peas_extension_call (PeasExtension *exten,const gchar *method_name,...);
peas_extension_call is deprecated and should not be used in newly-written code. 1.2. Use the dynamically implemented interface instead.
Call a method of the object behind extension.
The arguments provided to this functions should be of the same type as those defined in the GInterface or GObjectClass used as a base for the proxied extension. They should be provided in the same order, and if its return type is not void, then a pointer to a variable of that type should be passed as the last argument.
For instance, if the method prototype is:
| 1 | 
you should call peas_extension_call() this way:
| 1 | 
This function will not do anything if the introspection data for the proxied
object's class has not been loaded previously through g_irepository_require().
| 
 | A PeasExtension. | 
| 
 | the name of the method that should be called. | 
| 
 | arguments for the method. | 
| Returns : | TRUEon successful call. | 
gboolean peas_extension_call_valist (PeasExtension *exten,const gchar *method_name,va_list args);
peas_extension_call_valist is deprecated and should not be used in newly-written code. 1.2. Use the dynamically implemented interface instead.
Call a method of the object behind extension, using args as arguments.
See peas_extension_call() for more information.
| 
 | A PeasExtension. | 
| 
 | the name of the method that should be called. | 
| 
 | the arguments for the method. | 
| Returns : | TRUEon successful call. | 
gboolean peas_extension_callv (PeasExtension *exten,const gchar *method_name,GIArgument *args,GIArgument *return_value);
peas_extension_callv is deprecated and should not be used in newly-written code. 1.2. Use the dynamically implemented interface instead.
Rename to: peas_extension_call
Call a method of the object behind extension, using args as arguments.
See peas_extension_call() for more information.
| 
 | A PeasExtension. | 
| 
 | the name of the method that should be called. | 
| 
 | the arguments for the method. | 
| 
 | the return falue for the method. | 
| Returns : | TRUEon successful call. [transfer full] |