/*
* BabelTrace - Babeltrace Plug-in Interface
*
- * Copyright 2015 Jérémie Galarneau <jeremie.galarneau@efficios.com>
+ * Copyright 2016 Jérémie Galarneau <jeremie.galarneau@efficios.com>
*
* Author: Jérémie Galarneau <jeremie.galarneau@efficios.com>
*
* SOFTWARE.
*/
-#include <errno.h>
-
#ifdef __cplusplus
extern "C" {
#endif
-/**
- * Plug-in type.
- */
-enum bt_plugin_type {
- BT_PLUGIN_TYPE_UNKNOWN = -1,
-
- /** A source plug-in is a notification generator. */
- BT_PLUGIN_TYPE_SOURCE = 0,
-
- /** A sink plug-in handles incoming notifications. */
- BT_PLUGIN_TYPE_SINK = 1,
-
- /** A filter plug-in implements both Source and Sink interfaces. */
- BT_PLUGIN_TYPE_FILTER = 2,
-};
-
-/**
- * Status code. Errors are always negative.
- */
-enum bt_plugin_status {
- /** Memory allocation failure. */
- /* -12 for compatibility with -ENOMEM */
- BT_PLUGIN_STATUS_NOMEM = -12,
-
- /** Invalid arguments. */
- /* -22 for compatibility with -EINVAL */
- BT_PLUGIN_STATUS_INVAL = -22,
-
- /** Unsupported plug-in feature. */
- BT_PLUGIN_STATUS_UNSUPPORTED = -2,
-
- /** General error. */
- BT_PLUGIN_STATUS_ERROR = -1,
-
- /** No error, okay. */
- BT_PLUGIN_STATUS_OK = 0,
-}
+struct bt_plugin;
/**
- * Get plug-in instance name
+ * Get the name of a plug-in.
*
- * @param plugin Plug-in instance of which to get the name
- * @returns Returns a pointer to the plug-in's name
+ * @param plugin An instance of a plug-in
+ * @returns Plug-in name or NULL on error
*/
extern const char *bt_plugin_get_name(struct bt_plugin *plugin);
/**
- * Set plug-in instance name
+ * Get the name of a plug-in's author.
*
- * @param plugin Plug-in instance of which to set the name
- * @param name New plug-in name (will be copied)
- * @returns One of #bt_plugin_status values
+ * @param plugin An instance of a plug-in
+ * @returns Plug-in author or NULL on error
*/
-extern enum bt_plugin_status bt_plugin_set_name(
- struct bt_plugin *plugin, const char *name);
+extern const char *bt_plugin_get_author(struct bt_plugin *plugin);
/**
- * Get plug-in instance type
- *
- * @param plugin Plug-in instance of which to get the type
- * @returns One of #bt_plugin_type values
- */
-extern enum bt_plugin_type bt_plugin_get_type(struct bt_plugin *plugin);
-
-/**
- * Set a plug-in instance's error stream
- *
- * @param plugin Plug-in instance
- * @param error_stream Error stream
- * @returns One of #bt_plugin_status values
- */
-extern enum bt_plugin_status bt_plugin_set_error_stream(
- struct bt_plugin *plugin, FILE *error_stream);
-
-/**
- * Increments the reference count of \p plugin.
- *
- * @param plugin Plug-in of which to increment the reference count
- *
- * @see bt_plugin_put()
- */
-extern void bt_plugin_get(struct bt_plugin *plugin);
-
-/**
- * Decrements the reference count of \p plugin, destroying it when this
- * count reaches 0.
- *
- * @param plugin Plug-in of which to decrement the reference count
+ * Get the license of a plug-in.
*
- * @see bt_plugin_get()
+ * @param plugin An instance of a plug-in
+ * @returns Plug-in license or NULL on error
*/
-extern void bt_plugin_put(struct bt_plugin *plugin);
+extern const char *bt_plugin_get_license(struct bt_plugin *plugin);
#ifdef __cplusplus
}