4 * Babeltrace Filter Component
6 * Copyright 2016 Jérémie Galarneau <jeremie.galarneau@efficios.com>
8 * Author: Jérémie Galarneau <jeremie.galarneau@efficios.com>
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:
17 * The above copyright notice and this permission notice shall be included in
18 * all copies or substantial portions of the Software.
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
29 #include <babeltrace/compiler.h>
30 #include <babeltrace/values.h>
31 #include <babeltrace/component/component-filter-internal.h>
32 #include <babeltrace/component/component-internal.h>
33 #include <babeltrace/component/component-class-internal.h>
34 #include <babeltrace/component/notification/notification.h>
35 #include <babeltrace/component/notification/iterator-internal.h>
38 struct bt_notification_iterator
*bt_component_filter_create_notification_iterator(
39 struct bt_component
*component
)
41 return bt_component_create_iterator(component
, NULL
);
45 struct bt_notification_iterator
*bt_component_filter_create_notification_iterator_with_init_method_data(
46 struct bt_component
*component
, void *init_method_data
)
48 return bt_component_create_iterator(component
, init_method_data
);
52 void bt_component_filter_destroy(struct bt_component
*component
)
54 struct bt_component_filter
*filter
= container_of(component
,
55 struct bt_component_filter
, parent
);
57 if (filter
->input_ports
) {
58 g_ptr_array_free(filter
->input_ports
, TRUE
);
61 if (filter
->output_ports
) {
62 g_ptr_array_free(filter
->output_ports
, TRUE
);
67 struct bt_component
*bt_component_filter_create(
68 struct bt_component_class
*class, struct bt_value
*params
)
71 struct bt_component_filter
*filter
= NULL
;
72 enum bt_component_status status
;
74 filter
= g_new0(struct bt_component_filter
, 1);
79 filter
->parent
.class = bt_get(class);
80 status
= bt_component_init(&filter
->parent
, bt_component_filter_destroy
);
81 if (status
!= BT_COMPONENT_STATUS_OK
) {
85 ret
= bt_component_init_input_ports(&filter
->parent
,
86 &filter
->input_ports
);
91 ret
= bt_component_init_output_ports(&filter
->parent
,
92 &filter
->output_ports
);
98 return filter
? &filter
->parent
: NULL
;
105 enum bt_component_status
bt_component_filter_validate(
106 struct bt_component
*component
)
108 enum bt_component_status ret
= BT_COMPONENT_STATUS_OK
;
111 ret
= BT_COMPONENT_STATUS_INVALID
;
115 if (!component
->class) {
116 ret
= BT_COMPONENT_STATUS_INVALID
;
120 if (component
->class->type
!= BT_COMPONENT_CLASS_TYPE_FILTER
) {
121 ret
= BT_COMPONENT_STATUS_INVALID
;
125 /* Enforce iterator limits. */
130 int bt_component_filter_get_input_port_count(struct bt_component
*component
)
133 struct bt_component_filter
*filter
;
140 if (component
->class->type
!= BT_COMPONENT_CLASS_TYPE_FILTER
) {
145 filter
= container_of(component
, struct bt_component_filter
, parent
);
146 ret
= filter
->input_ports
->len
;
151 struct bt_port
*bt_component_filter_get_input_port(
152 struct bt_component
*component
, const char *name
)
154 struct bt_component_filter
*filter
;
155 struct bt_port
*ret_port
= NULL
;
157 if (!component
|| !name
||
158 component
->class->type
!= BT_COMPONENT_CLASS_TYPE_FILTER
) {
162 filter
= container_of(component
, struct bt_component_filter
, parent
);
163 ret_port
= bt_component_get_port(filter
->input_ports
, name
);
168 struct bt_port
*bt_component_filter_get_input_port_at_index(
169 struct bt_component
*component
, int index
)
171 struct bt_port
*port
= NULL
;
172 struct bt_component_filter
*filter
;
175 component
->class->type
!= BT_COMPONENT_CLASS_TYPE_FILTER
) {
179 filter
= container_of(component
, struct bt_component_filter
, parent
);
180 port
= bt_component_get_port_at_index(filter
->input_ports
, index
);
185 struct bt_port
*bt_component_filter_get_default_input_port(
186 struct bt_component
*component
)
188 return bt_component_filter_get_input_port(component
,
189 DEFAULT_INPUT_PORT_NAME
);
192 struct bt_port
*bt_component_filter_add_input_port(
193 struct bt_component
*component
, const char *name
)
195 struct bt_port
*port
;
196 struct bt_component_filter
*filter
;
199 component
->class->type
!= BT_COMPONENT_CLASS_TYPE_FILTER
) {
204 filter
= container_of(component
, struct bt_component_filter
, parent
);
205 port
= bt_component_add_port(component
, filter
->input_ports
,
206 BT_PORT_TYPE_INPUT
, name
);
211 enum bt_component_status
bt_component_filter_remove_input_port(
212 struct bt_component
*component
, const char *name
)
214 enum bt_component_status status
;
215 struct bt_component_filter
*filter
;
218 component
->class->type
!= BT_COMPONENT_CLASS_TYPE_FILTER
) {
219 status
= BT_COMPONENT_STATUS_INVALID
;
223 filter
= container_of(component
, struct bt_component_filter
, parent
);
224 status
= bt_component_remove_port(component
, filter
->input_ports
,
230 int bt_component_filter_get_output_port_count(struct bt_component
*component
)
233 struct bt_component_filter
*filter
;
240 if (component
->class->type
!= BT_COMPONENT_CLASS_TYPE_FILTER
) {
245 filter
= container_of(component
, struct bt_component_filter
, parent
);
246 ret
= filter
->output_ports
->len
;
251 struct bt_port
*bt_component_filter_get_output_port(
252 struct bt_component
*component
, const char *name
)
254 struct bt_component_filter
*filter
;
255 struct bt_port
*ret_port
= NULL
;
257 if (!component
|| !name
||
258 component
->class->type
!= BT_COMPONENT_CLASS_TYPE_FILTER
) {
262 filter
= container_of(component
, struct bt_component_filter
, parent
);
263 ret_port
= bt_component_get_port(filter
->output_ports
, name
);
268 struct bt_port
*bt_component_filter_get_output_port_at_index(
269 struct bt_component
*component
, int index
)
271 struct bt_port
*port
= NULL
;
272 struct bt_component_filter
*filter
;
275 component
->class->type
!= BT_COMPONENT_CLASS_TYPE_FILTER
) {
279 filter
= container_of(component
, struct bt_component_filter
, parent
);
280 port
= bt_component_get_port_at_index(filter
->output_ports
, index
);
285 struct bt_port
*bt_component_filter_get_default_output_port(
286 struct bt_component
*component
)
288 return bt_component_filter_get_output_port(component
,
289 DEFAULT_OUTPUT_PORT_NAME
);
292 struct bt_port
*bt_component_filter_add_output_port(
293 struct bt_component
*component
, const char *name
)
295 struct bt_port
*port
;
296 struct bt_component_filter
*filter
;
299 component
->class->type
!= BT_COMPONENT_CLASS_TYPE_FILTER
) {
304 filter
= container_of(component
, struct bt_component_filter
, parent
);
305 port
= bt_component_add_port(component
, filter
->output_ports
,
306 BT_PORT_TYPE_OUTPUT
, name
);
311 enum bt_component_status
bt_component_filter_remove_output_port(
312 struct bt_component
*component
, const char *name
)
314 enum bt_component_status status
;
315 struct bt_component_filter
*filter
;
318 component
->class->type
!= BT_COMPONENT_CLASS_TYPE_FILTER
) {
319 status
= BT_COMPONENT_STATUS_INVALID
;
323 filter
= container_of(component
, struct bt_component_filter
, parent
);
324 status
= bt_component_remove_port(component
, filter
->output_ports
,