Refactor the plugin registration and loading machinery
[babeltrace.git] / include / babeltrace / plugin / plugin-internal.h
index fbb91de6dbabd44d7ded5816d801510c2e531fed..ac0217207bcfca61f068df44cc083d43f151afbc 100644 (file)
@@ -1,5 +1,5 @@
-#ifndef BABELTRACE_PLUGIN_INTERNAL_H
-#define BABELTRACE_PLUGIN_INTERNAL_H
+#ifndef BABELTRACE_PLUGIN_PLUGIN_INTERNAL_H
+#define BABELTRACE_PLUGIN_PLUGIN_INTERNAL_H
 
 /*
  * BabelTrace - Plug-in Internal
  */
 
 #include <babeltrace/babeltrace-internal.h>
-#include <babeltrace/ref-internal.h>
-#include <babeltrace/plugin/component.h>
-#include <babeltrace/plugin/plugin.h>
+#include <babeltrace/plugin/plugin-dev.h>
 #include <babeltrace/object-internal.h>
+#include <stdbool.h>
 #include <gmodule.h>
 
-/**
- * Plug-ins are owned by bt_component_factory and the bt_component_class-es
- * it provides. This means that its lifetime bound by either the component
- * factory's, or the concrete components' lifetime which may be in use and which
- * have hold a reference to their bt_component_class which, in turn, have a
- * reference to their plugin.
- *
- * This ensures that a plugin's library is not closed while it is being used
- * even if the bt_component_factory, which created its components, is destroyed.
- */
+struct bt_plugin_shared_lib_handle {
+       struct bt_object base;
+       GString *path;
+       GModule *module;
+
+       /* True if initialization function was called */
+       bool init_called;
+       bt_plugin_exit_func exit;
+};
+
 struct bt_plugin {
        struct bt_object base;
+       bool frozen;
+
+       /* Owned by this */
+       struct bt_plugin_shared_lib_handle *shared_lib_handle;
+
+       /* Array of pointers to bt_component_class (owned by this) */
+       GPtrArray *comp_classes;
+
+       /* Pointers to plugin's memory: do NOT free */
+       const struct __bt_plugin_descriptor *descriptor;
        const char *name;
        const char *author;
        const char *license;
-        bt_plugin_init_func init;
-       bt_plugin_exit_func exit;
-       GModule *module;
+       const char *description;
+       bt_plugin_init_func init;
 };
 
-BT_HIDDEN
-struct bt_plugin *bt_plugin_create(GModule *module);
-
-BT_HIDDEN
-enum bt_component_status bt_plugin_register_component_classes(
-               struct bt_plugin *plugin, struct bt_component_factory *factory);
-
-#endif /* BABELTRACE_PLUGIN_INTERNAL_H */
+#endif /* BABELTRACE_PLUGIN_PLUGIN_INTERNAL_H */
This page took 0.024005 seconds and 4 git commands to generate.