Fix: allow NULL (unnamed) in bt_ctf_stream_class_{get,set}_name()
[babeltrace.git] / include / babeltrace / ctf-ir / stream-internal.h
index daaa430b36572d3680b437a73d046800c2eaea5e..41fe247d21afbe152a9b7dc80447781b47b64e0a 100644 (file)
  * SOFTWARE.
  */
 
-#include <babeltrace/ctf-writer/ref-internal.h>
+#include <babeltrace/ctf-ir/stream.h>
+#include <babeltrace/object-internal.h>
 #include <babeltrace/ctf-writer/clock.h>
 #include <babeltrace/ctf-writer/event-fields.h>
 #include <babeltrace/ctf-writer/event-types.h>
+#include <babeltrace/ctf-writer/serialize-internal.h>
 #include <babeltrace/babeltrace-internal.h>
-#include <babeltrace/ctf/types.h>
 #include <glib.h>
 
-typedef void(*flush_func)(struct bt_ctf_stream *, void *);
+struct bt_port;
+struct bt_component;
 
-struct flush_callback {
-       flush_func func;
+typedef void (*bt_ctf_stream_destroy_listener_func)(
+               struct bt_ctf_stream *stream, void *data);
+
+struct bt_ctf_stream_destroy_listener {
+       bt_ctf_stream_destroy_listener_func func;
        void *data;
 };
 
 struct bt_ctf_stream {
-       struct bt_ctf_ref ref_count;
-       uint32_t id;
+       struct bt_object base;
+       int64_t id;
        struct bt_ctf_stream_class *stream_class;
-       struct flush_callback flush;
+       GString *name;
+       struct bt_ctf_field *packet_header;
+       struct bt_ctf_field *packet_context;
+
+       /*
+        * When a notification which contains a reference to a stream
+        * object (event notification, for example) is returned by the
+        * "next" method of a sink or filter component's notification
+        * iterator, it must NOT be returned by the "next" method of a
+        * notification iterator which iterates on the notifications of
+        * another output port of the same component.
+        *
+        * To ensure this, the stream object keeps a hash table which
+        * indicates which port, for a given component, is currently
+        * allowed to emit notifications which contain a reference to
+        * this stream.
+        *
+        * This is a `struct bt_component *` to `struct bt_port *` hash
+        * table. Both pointers are weak references because there's no
+        * need to keep one or the other alive as far as this stream is
+        * concerned.
+        */
+       GHashTable *comp_cur_port;
+
+       /* Writer-specific members. */
        /* Array of pointers to bt_ctf_event for the current packet */
        GPtrArray *events;
-       struct ctf_stream_pos pos;
+       struct bt_ctf_stream_pos pos;
        unsigned int flushed_packet_count;
-       uint64_t events_discarded;
+       uint64_t discarded_events;
+       uint64_t size;
+
+       /* Array of struct bt_ctf_stream_destroy_listener */
+       GArray *destroy_listeners;
 };
 
 BT_HIDDEN
-struct bt_ctf_stream *bt_ctf_stream_create(
-               struct bt_ctf_stream_class *stream_class);
+int bt_ctf_stream_set_fd(struct bt_ctf_stream *stream, int fd);
 
 BT_HIDDEN
-int bt_ctf_stream_set_flush_callback(struct bt_ctf_stream *stream,
-               flush_func callback, void *data);
+void bt_ctf_stream_map_component_to_port(struct bt_ctf_stream *stream,
+               struct bt_component *comp,
+               struct bt_port *port);
 
 BT_HIDDEN
-int bt_ctf_stream_set_fd(struct bt_ctf_stream *stream, int fd);
+struct bt_port *bt_ctf_stream_port_for_component(struct bt_ctf_stream *stream,
+               struct bt_component *comp);
+
+BT_HIDDEN
+void bt_ctf_stream_add_destroy_listener(struct bt_ctf_stream *stream,
+               bt_ctf_stream_destroy_listener_func func, void *data);
+
+BT_HIDDEN
+void bt_ctf_stream_remove_destroy_listener(struct bt_ctf_stream *stream,
+               bt_ctf_stream_destroy_listener_func func, void *data);
+
+static inline
+struct bt_ctf_stream_class *bt_ctf_stream_borrow_stream_class(
+               struct bt_ctf_stream *stream)
+{
+       assert(stream);
+       return stream->stream_class;
+}
 
 #endif /* BABELTRACE_CTF_WRITER_STREAM_INTERNAL_H */
This page took 0.023822 seconds and 4 git commands to generate.