X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=include%2Fbabeltrace%2Fplugin%2Fplugin-system.h;h=0de0676818390f7bb1bdd3972a9df6a08af294db;hb=38b48196e2b127cceb022056bb22a15086644e10;hp=fea024fdd87f33d04ccc865ed0da7f991305f662;hpb=2bd8a567becb9934d52fe95aa8a722322ab660f8;p=babeltrace.git diff --git a/include/babeltrace/plugin/plugin-system.h b/include/babeltrace/plugin/plugin-system.h index fea024fd..0de06768 100644 --- a/include/babeltrace/plugin/plugin-system.h +++ b/include/babeltrace/plugin/plugin-system.h @@ -30,99 +30,194 @@ * SOFTWARE. */ -#include -#include - #ifdef __cplusplus extern "C" { #endif struct bt_notification; +struct bt_notification_iterator; +struct bt_component; +struct bt_component_factory; + +typedef enum bt_component_status (*bt_plugin_init_func)( + struct bt_component_factory *factory); +typedef void (*bt_plugin_exit_func)(void); + +/** + * Component private data deallocation function type. + * + * @param component Component instance + */ +typedef void (*bt_component_destroy_cb)(struct bt_component *component); + +/** + * Component initialization function type. + * + * A component's private data and required callbacks must be set by this + * function. + * + * @param component Component instance + * @returns One of #bt_component_status values + */ +typedef enum bt_component_status (*bt_component_init_cb)( + struct bt_component *component); + +/** + * Get a component's private data. + * + * @param component Component of which to get the private data + * @returns Component's private data + */ +extern void *bt_component_get_private_data(struct bt_component *component); /** - * Plug-in private data deallocation function type. + * Set a component's private data. * - * @param plugin Plug-in instance + * @param component Component of which to set the private data + * @param data Component private data + * @returns One of #bt_component_status values */ -typedef void (*bt_plugin_destroy_cb)(struct bt_plugin *plugin); +extern enum bt_component_status bt_component_set_private_data( + struct bt_component *component, void *data); /** - * Iterator creation function type. + * Set a component's private data cleanup function. + * + * @param component Component of which to set the private data destruction + * function + * @param data Component private data clean-up function + * @returns One of #bt_component_status values + */ +extern enum bt_component_status bt_component_set_destroy_cb( + struct bt_component *component, + bt_component_destroy_cb destroy); + +/** bt_component_souce */ +/** + * Iterator initialization function type. + * + * A notification iterator's private data, deinitialization, next, and get + * callbacks must be set by this function. * - * @param plugin Plug-in instance + * @param component Component instance + * @param iterator Notification iterator instance */ -typedef struct bt_notification_iterator *( - *bt_plugin_source_iterator_create_cb)( - struct bt_plugin *plugin); +typedef enum bt_component_status (*bt_component_source_init_iterator_cb)( + struct bt_component *component, + struct bt_notification_iterator *iterator); +/** + * Set a source component's iterator initialization function. + * + * @param component Component instance + * @param init_iterator Notification iterator initialization callback + */ +extern enum bt_component_status +bt_component_source_set_iterator_init_cb(struct bt_component *component, + bt_component_source_init_iterator_cb init_iterator); + +/** bt_component_sink */ /** * Notification handling function type. * - * @param plugin Plug-in instance + * @param component Component instance * @param notificattion Notification to handle + * @returns One of #bt_component_status values */ -typedef int (*bt_plugin_sink_handle_notification_cb)(struct bt_plugin *, - struct bt_notification *); +typedef enum bt_component_status (*bt_component_sink_handle_notification_cb)( + struct bt_component *, struct bt_notification *); -typedef struct bt_notification *(bt_notification_iterator_get_notification_cb)( - struct bt_notification_iterator *); +/** + * Set a sink component's notification handling callback. + * + * @param component Component instance + * @param handle_notification Notification handling callback + * @returns One of #bt_component_status values + */ +extern enum bt_component_status +bt_component_sink_set_handle_notification_cb(struct bt_component *component, + bt_component_sink_handle_notification_cb handle_notification); -typedef struct bt_notification *(bt_notification_iterator_get_notification_cb)( - struct bt_notification_iterator *); +/** bt_component_notification_iterator */ +/** + * Function returning an iterator's current notification. + * + * @param iterator Notification iterator instance + * @returns A notification instance + */ +typedef struct bt_notification *(*bt_notification_iterator_get_cb)( + struct bt_notification_iterator *iterator); -typedef enum bt_notification_iterator_status (bt_notification_iterator_next_cb)( - struct bt_notification_iterator *); +/** + * Function advancing an iterator's position of one element. + * + * @param iterator Notification iterator instance + * @returns One of #bt_notification_iterator_status values + */ +typedef enum bt_notification_iterator_status (*bt_notification_iterator_next_cb)( + struct bt_notification_iterator *iterator); /** - * Get a plug-in's private (implementation) data. + * Function cleaning-up an iterator's private data on destruction. * - * @param plugin Plug-in of which to get the private data - * @returns Plug-in private data + * @param iterator Notification iterator instance */ -extern void *bt_plugin_get_private_data(struct bt_plugin *plugin); +typedef void (*bt_notification_iterator_destroy_cb)( + struct bt_notification_iterator *iterator); +/** + * Set an iterator's "get" callback which return the current notification. + * + * @param iterator Notification iterator instance + * @param get Notification return callback + * @returns One of #bt_notification_iterator_status values + */ +extern enum bt_notification_iterator_status +bt_notification_iterator_set_get_cb(struct bt_notification_iterator *iterator, + bt_notification_iterator_get_cb get); -/** Plug-in initialization functions */ /** - * Allocate a source plug-in. + * Set an iterator's "next" callback which advances the iterator's position. * - * @param name Plug-in instance name (will be copied) - * @param private_data Private plug-in implementation data - * @param destroy_cb Plug-in private data clean-up callback - * @param iterator_create_cb Iterator creation callback - * @returns A source plug-in instance + * @param iterator Notification iterator instance + * @param next Iterator "next" callback + * @returns One of #bt_notification_iterator_status values */ -extern struct bt_plugin *bt_plugin_source_create(const char *name, - void *private_data, bt_plugin_destroy_cb destroy_func, - bt_plugin_source_iterator_create_cb iterator_create_cb); +extern enum bt_notification_iterator_status +bt_notification_iterator_set_next_cb(struct bt_notification_iterator *iterator, + bt_notification_iterator_next_cb next); /** - * Allocate a sink plug-in. + * Set an iterator's "destroy" callback. * - * @param name Plug-in instance name (will be copied) - * @param private_data Private plug-in implementation data - * @param destroy_cb Plug-in private data clean-up callback - * @param notification_cb Notification handling callback - * @returns A sink plug-in instance + * @param iterator Notification iterator instance + * @param next Iterator destruction callback + * @returns One of #bt_notification_iterator_status values */ -extern struct bt_plugin *bt_plugin_sink_create(const char *name, - void *private_data, bt_plugin_destroy_cb destroy_func, - bt_plugin_sink_handle_notification_cb notification_cb); +extern enum bt_notification_iterator_status +bt_notification_iterator_set_destroy_cb( + struct bt_notification_iterator *iterator, + bt_notification_iterator_destroy_cb destroy); +/** + * Set an iterator's private data. + * + * @param iterator Notification iterator instance + * @param data Iterator private data + * @returns One of #bt_notification_iterator_status values + */ +extern enum bt_notification_iterator_status +bt_notification_iterator_set_private_data( + struct bt_notification_iterator *iterator, void *data); -/** Notification iterator functions */ /** - * Allocate a notification iterator. + * Get an iterator's private data. * - * @param plugin Plug-in instance - * @param next_cb Callback advancing to the next notification - * @param notification_cb Callback providing the current notification - * @returns A notification iterator instance + * @param iterator Notification iterator instance + * @returns Iterator instance private data */ -extern struct bt_notification_iterator *bt_notification_iterator_create( - struct bt_plugin *plugin, - bt_notification_iterator_next_cb next_cb, - bt_notification_iterator_get_notification_cb notification_cb); +extern void *bt_notification_iterator_get_private_data( + struct bt_notification_iterator *iterator); #ifdef __cplusplus }