assert-pre-internal.h: add BT_ASSERT_PRE_VALID_INDEX()
[babeltrace.git] / include / babeltrace / ctf-ir / stream-class-internal.h
index 24c75848370e8c95dce52f3a77f6c66c69bb5694..6a167c9371267cf2302844cf46ca6de1f5b7ad3a 100644 (file)
  * SOFTWARE.
  */
 
-#include <babeltrace/ctf-writer/clock.h>
-#include <babeltrace/ctf-writer/event-fields.h>
-#include <babeltrace/ctf-writer/event-types.h>
-#include <babeltrace/ctf-ir/trace.h>
+#include <babeltrace/assert-internal.h>
+#include <babeltrace/common-internal.h>
+#include <babeltrace/ctf-ir/validation-internal.h>
+#include <babeltrace/ctf-ir/field-types-internal.h>
+#include <babeltrace/ctf-ir/utils-internal.h>
+#include <babeltrace/ctf-ir/visitor.h>
+#include <babeltrace/ctf-ir/stream-class.h>
 #include <babeltrace/object-internal.h>
+#include <babeltrace/object-pool-internal.h>
 #include <babeltrace/babeltrace-internal.h>
-#include <babeltrace/ctf-ir/trace-internal.h>
-#include <assert.h>
 #include <glib.h>
+#include <inttypes.h>
 
 struct bt_stream_class {
        struct bt_object base;
        GString *name;
-       struct bt_ctf_clock *clock;
-       GPtrArray *event_classes; /* Array of pointers to bt_event_class */
-       /* event class id (int64_t) to event class */
+
+       /* Array of pointers to event class addresses */
+       GPtrArray *event_classes;
+
+       /* event class id (int64_t) to event class address */
        GHashTable *event_classes_ht;
        int id_set;
        int64_t id;
        int64_t next_event_id;
-       int64_t next_stream_id;
-       struct bt_field_type *packet_context_type;
-       struct bt_field_type *event_header_type;
-       struct bt_field_type *event_context_type;
+       struct bt_field_type *packet_context_field_type;
+       struct bt_field_type *event_header_field_type;
+       struct bt_field_type *event_context_field_type;
        int frozen;
        int byte_order;
 
@@ -78,45 +82,47 @@ struct bt_stream_class {
         * backing clock class of the `clock` member above.
         */
        struct bt_clock_class *clock_class;
-};
 
-BT_HIDDEN
-void bt_stream_class_freeze(struct bt_stream_class *stream_class);
+       /* Pool of `struct bt_field_wrapper *` */
+       struct bt_object_pool event_header_field_pool;
 
-BT_HIDDEN
-int bt_stream_class_serialize(struct bt_stream_class *stream_class,
-               struct metadata_context *context);
-
-BT_HIDDEN
-void bt_stream_class_set_byte_order(
-               struct bt_stream_class *stream_class, int byte_order);
-
-/* Set stream_class id without checking if the stream class is frozen */
-BT_HIDDEN
-void _bt_stream_class_set_id(struct bt_stream_class *stream_class,
-               int64_t id);
+       /* Pool of `struct bt_field_wrapper *` */
+       struct bt_object_pool packet_context_field_pool;
+};
 
-BT_HIDDEN
-int bt_stream_class_set_id_no_check(
-               struct bt_stream_class *stream_class, int64_t id);
+struct bt_event_class;
 
 BT_HIDDEN
-int bt_stream_class_map_clock_class(
-               struct bt_stream_class *stream_class,
-               struct bt_field_type *packet_context_type,
-               struct bt_field_type *event_header_type);
+void bt_stream_class_freeze(struct bt_stream_class *stream_class);
 
 BT_HIDDEN
 int bt_stream_class_validate_single_clock_class(
                struct bt_stream_class *stream_class,
                struct bt_clock_class **expected_clock_class);
 
+BT_HIDDEN
+int bt_stream_class_visit(struct bt_stream_class *stream_class,
+               bt_visitor visitor, void *data);
+
 static inline
-struct bt_trace *bt_stream_class_borrow_trace(
-               struct bt_stream_class *stream_class)
+void _bt_stream_class_set_id(
+               struct bt_stream_class *stream_class, int64_t id)
+{
+       BT_ASSERT(stream_class);
+       stream_class->id = id;
+       stream_class->id_set = 1;
+       BT_LOGV("Set stream class's ID (internal): "
+               "addr=%p, name=\"%s\", id=%" PRId64,
+               stream_class, bt_stream_class_get_name(stream_class),
+               bt_stream_class_get_id(stream_class));
+}
+
+static inline
+int bt_stream_class_set_id_no_check(
+               struct bt_stream_class *stream_class, int64_t id)
 {
-       assert(stream_class);
-       return (void *) bt_object_borrow_parent(stream_class);
+       _bt_stream_class_set_id(stream_class, id);
+       return 0;
 }
 
 #endif /* BABELTRACE_CTF_IR_STREAM_CLASS_INTERNAL_H */
This page took 0.026956 seconds and 4 git commands to generate.