Fix: libctfcopytrace: replace clock classes in copies
[babeltrace.git] / include / babeltrace / ctf-ir / stream-class-internal.h
index 1bd1ea18c26bfb63c9711c38fa95aefaa5ea8208..3bde4ed9c132dd5944cdae5fb1ea71b00fb05bfe 100644 (file)
 #include <babeltrace/ctf-ir/trace.h>
 #include <babeltrace/object-internal.h>
 #include <babeltrace/babeltrace-internal.h>
-#include <babeltrace/ctf/types.h>
 #include <babeltrace/ctf-ir/trace-internal.h>
+#include <assert.h>
 #include <glib.h>
 
-struct bt_ctf_stream_class {
+struct bt_stream_class {
        struct bt_object base;
        GString *name;
        struct bt_ctf_clock *clock;
-       GPtrArray *event_classes; /* Array of pointers to bt_ctf_event_class */
+       GPtrArray *event_classes; /* Array of pointers to bt_event_class */
+       /* event class id (int64_t) to event class */
+       GHashTable *event_classes_ht;
        int id_set;
-       uint32_t id;
-       uint32_t next_event_id;
-       uint32_t next_stream_id;
-       struct bt_ctf_field_type *packet_context_type;
-       struct bt_ctf_field_type *event_header_type;
-       struct bt_ctf_field_type *event_context_type;
+       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;
        int frozen;
        int byte_order;
 
@@ -60,23 +62,37 @@ struct bt_ctf_stream_class {
 };
 
 BT_HIDDEN
-void bt_ctf_stream_class_freeze(struct bt_ctf_stream_class *stream_class);
+void bt_stream_class_freeze(struct bt_stream_class *stream_class);
 
 BT_HIDDEN
-int bt_ctf_stream_class_serialize(struct bt_ctf_stream_class *stream_class,
+int bt_stream_class_serialize(struct bt_stream_class *stream_class,
                struct metadata_context *context);
 
 BT_HIDDEN
-void bt_ctf_stream_class_set_byte_order(
-               struct bt_ctf_stream_class *stream_class, int byte_order);
+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
-int _bt_ctf_stream_class_set_id(struct bt_ctf_stream_class *stream_class,
-               uint32_t id);
+void _bt_stream_class_set_id(struct bt_stream_class *stream_class,
+               int64_t id);
 
 BT_HIDDEN
-int bt_ctf_stream_class_set_id_no_check(
-               struct bt_ctf_stream_class *stream_class, uint32_t id);
+int bt_stream_class_set_id_no_check(
+               struct bt_stream_class *stream_class, int64_t id);
+
+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);
+
+static inline
+struct bt_trace *bt_stream_class_borrow_trace(
+               struct bt_stream_class *stream_class)
+{
+       assert(stream_class);
+       return (void *) bt_object_borrow_parent(stream_class);
+}
 
 #endif /* BABELTRACE_CTF_IR_STREAM_CLASS_INTERNAL_H */
This page took 0.025517 seconds and 4 git commands to generate.