* SOFTWARE.
*/
-#include <babeltrace/objects.h>
-
#ifdef __cplusplus
extern "C" {
#endif
+struct bt_notification;
+struct bt_notification_iterator;
+struct bt_component;
+
/**
- * Plug-in private data deallocation function type.
+ * Component private data deallocation function type.
*
- * @param plugin Plug-in instance
+ * @param component Component instance
*/
-typedef void (*bt_plugin_destroy_cb)(struct bt_plugin *plugin);
+typedef void (*bt_component_destroy_cb)(struct bt_component *component);
/**
- * Plug-in error stream registration function type.
+ * Source component initialization function type.
*
- * @param plugin Plug-in instance
- * @param error_stream Error stream, ownership is not transferred
- * @returns One of #bt_plugin_status values
+ * A source component's iterator initialization callback, private data and
+ * deinitialization callback must be set by this function.
+ *
+ * @param component Component instance
+ * @returns One of #bt_component_status values
*/
-typedef enum bt_plugin_status (*bt_plugin_set_error_stream_cb)(
- struct bt_plugin *plugin, FILE *error_stream);
+typedef enum bt_component_status (*bt_component_source_init_cb)(
+ struct bt_component *component);
/**
- * Get a plug-in's private (implementation) data.
+ * Sink component initialization function type.
+ *
+ * A sink component's notification handling callback, private data and
+ * deinitialization callback must be set by this function.
+ *
+ * @param component Component instance
+ * @returns One of #bt_component_status values
+ */
+typedef enum bt_component_status (*bt_component_sink_init_cb)(
+ struct bt_component *component);
+
+/**
+ * Iterator initialization function type.
+ *
+ * @param component Component instance
+ * @param iterator Iterator instance
+ */
+typedef enum bt_component_status (*bt_component_source_iterator_init_cb)(
+ struct bt_component *component,
+ struct bt_notification_iterator *iterator);
+
+/**
+ * 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);
+
+/**
+ * Set a component's private data.
+ *
+ * @param component Component of which to set the private data
+ * @param data Component private data
+ * @returns One of #bt_component_status values
+ */
+extern enum bt_component_status bt_component_set_private_data(
+ struct bt_component *component, void *data);
+
+/**
+ * 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 of which to get the private data
- * @returns Plug-in private data
+ * @param component Component instance
+ * @param iterator Notification iterator instance
*/
-extern void *bt_plugin_get_private_data(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 callback permiting the registration of an error stream.
+ * Set a source component's iterator initialization function.
*
- * @param plugin Plug-in to which the callback should be registered
- * @param cb Error stream registration callback
+ * @param component Component instance
+ * @param init_iterator Notification iterator initialization callback
*/
-extern int bt_plugin_set_error_stream_cb(struct bt_plugin *plugin,
- bt_plugin_set_error_stream_cb cb);
+extern enum bt_component_status
+bt_component_source_set_iterator_init_cb(struct bt_component *component,
+ bt_component_source_init_iterator_cb init_iterator);
-/* Plug-in initialization functions */
+/** bt_component_sink */
/**
- * Allocate a source plug-in.
+ * Notification handling function type.
*
- * @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 component Component instance
+ * @param notificattion Notification to handle
+ * @returns One of #bt_component_status values
*/
-extern struct bt_plugin *bt_plugin_source_create(const char *name,
- void *private_data, bt_plugin_destroy_func destroy_func,
- bt_plugin_source_iterator_create_cb iterator_create_cb);
+typedef enum bt_component_status (*bt_component_sink_handle_notification_cb)(
+ struct bt_component *, struct bt_notification *);
/**
- * Allocate a sink plug-in.
+ * Set a sink component's notification handling 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 component Component instance
+ * @param handle_notification Notification handling callback
+ * @returns One of #bt_component_status values
*/
-extern struct bt_plugin *bt_plugin_sink_create(const char *name,
- void *private_data, bt_plugin_destroy_func destroy_func,
- bt_plugin_sink_handle_notification_cb notification_cb);
+extern enum bt_component_status
+bt_component_sink_set_handle_notification_cb(struct bt_component *component,
+ bt_component_sink_handle_notification_cb handle_notification);
-/* Notification iterator functions */
+/** bt_component_notification_iterator */
/**
- * Allocate an notification iterator.
+ * Function returning an iterator's current notification.
*
- * @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 A notification instance
*/
-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);
+typedef struct bt_notification *(*bt_notification_iterator_get_cb)(
+ struct bt_notification_iterator *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);
+
+/**
+ * Function cleaning-up an iterator's private data on destruction.
+ *
+ * @param iterator Notification iterator instance
+ */
+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);
+
+/**
+ * Set an iterator's "next" callback which advances the iterator's position.
+ *
+ * @param iterator Notification iterator instance
+ * @param next Iterator "next" callback
+ * @returns One of #bt_notification_iterator_status values
+ */
+extern enum bt_notification_iterator_status
+bt_notification_iterator_set_next_cb(struct bt_notification_iterator *iterator,
+ bt_notification_iterator_next_cb next);
+
+/**
+ * Set an iterator's "destroy" callback.
+ *
+ * @param iterator Notification iterator instance
+ * @param next Iterator destruction callback
+ * @returns One of #bt_notification_iterator_status values
+ */
+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 plugin Plug-in instance on which to iterate
- * @param data Iterator private data
- * @returns One of #bt_notification_iterator_status values
+ * @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);
+
+/**
+ * Get an iterator's private data.
+ *
+ * @param iterator Notification iterator instance
+ * @returns Iterator instance private data
*/
-extern enum bt_notification_iterator_status *bt_notification_iterator_create(
- struct bt_plugin *plugin, void *data);
+extern void *bt_notification_iterator_get_private_data(
+ struct bt_notification_iterator *iterator);
#ifdef __cplusplus
}