Strip babeltrace.c
[babeltrace.git] / plugins / component-class.c
index 191efdcb1ef8869e809b97d3e77462b5f7a9d7b1..e0e2e0bf2e4e9cd8c42ae8297909277279b85a6f 100644 (file)
 
 #include <babeltrace/compiler.h>
 #include <babeltrace/plugin/component-class-internal.h>
+#include <babeltrace/ref.h>
 #include <glib.h>
 
 static
-void bt_component_class_destroy(struct bt_ref *ref)
+void bt_component_class_destroy(struct bt_object *obj)
 {
        struct bt_component_class *class;
 
-       assert(ref);
-       class = container_of(ref, struct bt_component_class, ref);
+       assert(obj);
+       class = container_of(obj, struct bt_component_class, base);
        if (class->name) {
                g_string_free(class->name, TRUE);
        }
-       bt_plugin_put(class->plugin);
+       if (class->description) {
+               g_string_free(class->description, TRUE);
+       }
+
+       bt_put(class->plugin);
        g_free(class);
 }
 
 BT_HIDDEN
 struct bt_component_class *bt_component_class_create(
                enum bt_component_type type, const char *name,
-               struct bt_plugin *plugin)
+               const char *description, struct bt_plugin *plugin)
 {
        struct bt_component_class *class;
 
@@ -56,36 +61,43 @@ struct bt_component_class *bt_component_class_create(
                goto end;
        }
 
-       bt_ref_init(&class->ref, bt_component_class_destroy);
+       bt_object_init(class, bt_component_class_destroy);
        class->type = type;
        class->name = g_string_new(name);
-       if (!class->name) {
-               bt_component_class_put(class);
-               class = NULL;
+       class->description = g_string_new(description);
+       if (!class->name || !class->description) {
+               BT_PUT(class);
                goto end;
        }
-       bt_plugin_get(plugin);
-       class->plugin = plugin;
+
+       class->plugin = bt_get(plugin);
 end:
        return class;
 }
 
-BT_HIDDEN
-void bt_component_class_get(struct bt_component_class *class)
+const char *bt_component_class_get_name(
+               struct bt_component_class *component_class)
 {
-       if (!class) {
-               return;
-       }
+       return component_class ? component_class->name->str : NULL;
+}
 
-       bt_ref_get(&class->ref);
+enum bt_component_type bt_component_class_get_type(
+               struct bt_component_class *component_class)
+{
+       return component_class ? component_class->type :
+                       BT_COMPONENT_TYPE_UNKNOWN;
 }
 
-BT_HIDDEN
-void bt_component_class_put(struct bt_component_class *class)
+struct bt_plugin *bt_component_class_get_plugin(
+               struct bt_component_class *component_class)
 {
-       if (!class) {
-               return;
-       }
+       return component_class ? bt_get(component_class->plugin) :
+                       NULL;
+}
 
-       bt_ref_put(&class->ref);
+const char *bt_component_class_get_description(
+               struct bt_component_class *component_class)
+{
+       return component_class ? component_class->description->str : NULL;
 }
+
This page took 0.026681 seconds and 4 git commands to generate.