lib: split trace API into trace class and trace APIs
[babeltrace.git] / include / babeltrace / trace-ir / trace-internal.h
index fcf1bd29ebad6d5e83f93bb80dc009b2c7b1cee0..3b6eb1c7bdca4b36af48d21cac4b735daf399452 100644 (file)
@@ -26,6 +26,7 @@
  */
 
 #include <babeltrace/assert-pre-internal.h>
+#include <babeltrace/trace-ir/trace-class-internal.h>
 #include <babeltrace/trace-ir/trace.h>
 #include <babeltrace/trace-ir/stream-class-internal.h>
 #include <babeltrace/trace-ir/field-classes.h>
@@ -44,6 +45,9 @@
 struct bt_trace {
        struct bt_object base;
 
+       /* Owned by this */
+       struct bt_trace_class *class;
+
        struct {
                GString *str;
 
@@ -51,37 +55,20 @@ struct bt_trace {
                const char *value;
        } name;
 
-       struct {
-               uint8_t uuid[BABELTRACE_UUID_LEN];
-
-               /* NULL or `uuid` above */
-               bt_uuid value;
-       } uuid;
-
-       struct bt_value *environment;
-
-       /* Array of `struct bt_stream_class *` */
-       GPtrArray *stream_classes;
-
        /* Array of `struct bt_stream *` */
        GPtrArray *streams;
 
        /*
-        * Stream class (weak) to number of instantiated streams, used
-        * to automatically assign stream IDs per stream class.
+        * Stream class (weak, owned by owned trace class) to number of
+        * instantiated streams, used to automatically assign stream IDs
+        * per stream class within this trace.
         */
        GHashTable *stream_classes_stream_count;
 
        struct bt_field_class *packet_header_fc;
-       bool assigns_automatic_stream_class_id;
-
        GArray *is_static_listeners;
        bool is_static;
        bool in_remove_listener;
-
-       /* Pool of `struct bt_field_wrapper *` */
-       struct bt_object_pool packet_header_field_pool;
-
        bool frozen;
 };
 
This page took 0.02335 seconds and 4 git commands to generate.