lib: simplify the public notification iterator interfaces
[babeltrace.git] / include / babeltrace / graph / notification-iterator-internal.h
1 #ifndef BABELTRACE_GRAPH_NOTIFICATION_ITERATOR_INTERNAL_H
2 #define BABELTRACE_GRAPH_NOTIFICATION_ITERATOR_INTERNAL_H
3
4 /*
5 * BabelTrace - Notification Iterator Internal
6 *
7 * Copyright 2015 Jérémie Galarneau <jeremie.galarneau@efficios.com>
8 * Copyright 2017 Philippe Proulx <pproulx@efficios.com>
9 *
10 * Permission is hereby granted, free of charge, to any person obtaining a copy
11 * of this software and associated documentation files (the "Software"), to deal
12 * in the Software without restriction, including without limitation the rights
13 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
14 * copies of the Software, and to permit persons to whom the Software is
15 * furnished to do so, subject to the following conditions:
16 *
17 * The above copyright notice and this permission notice shall be included in
18 * all copies or substantial portions of the Software.
19 *
20 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
21 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
22 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
23 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
24 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
25 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
26 * SOFTWARE.
27 */
28
29 #include <babeltrace/babeltrace-internal.h>
30 #include <babeltrace/object-internal.h>
31 #include <babeltrace/ref-internal.h>
32 #include <babeltrace/graph/connection.h>
33 #include <babeltrace/graph/notification.h>
34 #include <babeltrace/graph/notification-iterator.h>
35 #include <babeltrace/graph/private-connection-private-notification-iterator.h>
36 #include <babeltrace/types.h>
37 #include <babeltrace/assert-internal.h>
38 #include <stdbool.h>
39
40 struct bt_port;
41 struct bt_graph;
42
43 enum bt_notification_iterator_type {
44 BT_NOTIFICATION_ITERATOR_TYPE_PRIVATE_CONNECTION,
45 BT_NOTIFICATION_ITERATOR_TYPE_OUTPUT_PORT,
46 };
47
48 enum bt_private_connection_notification_iterator_notif_type {
49 BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_NOTIF_TYPE_EVENT = (1U << 0),
50 BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_NOTIF_TYPE_INACTIVITY = (1U << 1),
51 BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_NOTIF_TYPE_STREAM_BEGIN = (1U << 2),
52 BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_NOTIF_TYPE_STREAM_END = (1U << 3),
53 BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_NOTIF_TYPE_PACKET_BEGIN = (1U << 4),
54 BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_NOTIF_TYPE_PACKET_END = (1U << 5),
55 BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_NOTIF_TYPE_DISCARDED_EVENTS = (1U << 6),
56 BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_NOTIF_TYPE_DISCARDED_PACKETS = (1U << 7),
57 };
58
59 enum bt_private_connection_notification_iterator_state {
60 /* Iterator is not initialized. */
61 BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_STATE_NON_INITIALIZED,
62
63 /* Iterator is active, not at the end yet, and not finalized. */
64 BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_STATE_ACTIVE,
65
66 /*
67 * Iterator is ended, not finalized yet: the "next" method
68 * returns BT_NOTIFICATION_ITERATOR_STATUS_END.
69 */
70 BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_STATE_ENDED,
71
72 /*
73 * Iterator is finalized, but not at the end yet. This means
74 * that the "next" method can still return queued notifications
75 * before returning the BT_NOTIFICATION_ITERATOR_STATUS_CANCELED
76 * status.
77 */
78 BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_STATE_FINALIZED,
79
80 /*
81 * Iterator is finalized and ended: the "next" method always
82 * returns BT_NOTIFICATION_ITERATOR_STATUS_CANCELED.
83 */
84 BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_STATE_FINALIZED_AND_ENDED,
85 };
86
87 struct bt_notification_iterator {
88 struct bt_object base;
89 enum bt_notification_iterator_type type;
90 };
91
92 struct bt_notification_iterator_private_connection {
93 struct bt_notification_iterator base;
94 struct bt_component *upstream_component; /* Weak */
95 struct bt_port *upstream_port; /* Weak */
96 struct bt_connection *connection; /* Weak */
97 struct bt_graph *graph; /* Weak */
98
99 /*
100 * This hash table keeps the state of a stream as viewed by
101 * this notification iterator. This is used to, in developer
102 * mode:
103 *
104 * * Automatically enqueue "stream begin", "packet begin",
105 * "packet end", and "stream end" notifications depending
106 * on the stream's state and on the next notification returned
107 * by the upstream component.
108 *
109 * * Make sure that, once the notification iterator has seen a
110 * "stream end" notification for a given stream, no other
111 * notifications which refer to this stream can be delivered
112 * by this iterator.
113 *
114 * The key (struct bt_stream *) is not owned by this. The
115 * value is an allocated state structure.
116 */
117 GHashTable *stream_states;
118
119 enum bt_private_connection_notification_iterator_state state;
120 void *user_data;
121 };
122
123 struct bt_notification_iterator_output_port {
124 struct bt_notification_iterator base;
125 struct bt_graph *graph; /* Owned by this */
126 struct bt_component *colander; /* Owned by this */
127
128 /* Only used temporarily: should always be NULL */
129 struct bt_notification *notif;
130 };
131
132 static inline
133 struct bt_private_connection_private_notification_iterator *
134 bt_private_connection_private_notification_iterator_from_notification_iterator(
135 struct bt_notification_iterator_private_connection *iterator)
136 {
137 return (void *) iterator;
138 }
139
140 BT_HIDDEN
141 enum bt_connection_status bt_private_connection_notification_iterator_create(
142 struct bt_component *upstream_comp,
143 struct bt_port *upstream_port,
144 struct bt_connection *connection,
145 struct bt_notification_iterator_private_connection **iterator);
146
147 BT_HIDDEN
148 void bt_private_connection_notification_iterator_finalize(
149 struct bt_notification_iterator_private_connection *iterator);
150
151 BT_HIDDEN
152 void bt_private_connection_notification_iterator_set_connection(
153 struct bt_notification_iterator_private_connection *iterator,
154 struct bt_connection *connection);
155
156 static inline
157 const char *bt_notification_iterator_status_string(
158 enum bt_notification_iterator_status status)
159 {
160 switch (status) {
161 case BT_NOTIFICATION_ITERATOR_STATUS_CANCELED:
162 return "BT_NOTIFICATION_ITERATOR_STATUS_CANCELED";
163 case BT_NOTIFICATION_ITERATOR_STATUS_AGAIN:
164 return "BT_NOTIFICATION_ITERATOR_STATUS_AGAIN";
165 case BT_NOTIFICATION_ITERATOR_STATUS_END:
166 return "BT_NOTIFICATION_ITERATOR_STATUS_END";
167 case BT_NOTIFICATION_ITERATOR_STATUS_OK:
168 return "BT_NOTIFICATION_ITERATOR_STATUS_OK";
169 case BT_NOTIFICATION_ITERATOR_STATUS_INVALID:
170 return "BT_NOTIFICATION_ITERATOR_STATUS_INVALID";
171 case BT_NOTIFICATION_ITERATOR_STATUS_ERROR:
172 return "BT_NOTIFICATION_ITERATOR_STATUS_ERROR";
173 case BT_NOTIFICATION_ITERATOR_STATUS_NOMEM:
174 return "BT_NOTIFICATION_ITERATOR_STATUS_NOMEM";
175 case BT_NOTIFICATION_ITERATOR_STATUS_UNSUPPORTED:
176 return "BT_NOTIFICATION_ITERATOR_STATUS_UNSUPPORTED";
177 default:
178 return "(unknown)";
179 }
180 };
181
182 static inline
183 const char *bt_private_connection_notification_iterator_state_string(
184 enum bt_private_connection_notification_iterator_state state)
185 {
186 switch (state) {
187 case BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_STATE_ACTIVE:
188 return "BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_STATE_ACTIVE";
189 case BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_STATE_ENDED:
190 return "BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_STATE_ENDED";
191 case BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_STATE_FINALIZED:
192 return "BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_STATE_FINALIZED";
193 case BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_STATE_FINALIZED_AND_ENDED:
194 return "BT_PRIVATE_CONNECTION_NOTIFICATION_ITERATOR_STATE_FINALIZED_AND_ENDED";
195 default:
196 return "(unknown)";
197 }
198 };
199
200 #endif /* BABELTRACE_GRAPH_NOTIFICATION_ITERATOR_INTERNAL_H */
This page took 0.034114 seconds and 4 git commands to generate.