lib: strictly type function return status enumerations
[babeltrace.git] / src / lib / graph / component-class-sink-colander.c
CommitLineData
706a18f9 1/*
e2f7325d 2 * Copyright 2017-2018 Philippe Proulx <pproulx@efficios.com>
706a18f9
PP
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining a copy
5 * of this software and associated documentation files (the "Software"), to deal
6 * in the Software without restriction, including without limitation the rights
7 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8 * copies of the Software, and to permit persons to whom the Software is
9 * furnished to do so, subject to the following conditions:
10 *
11 * The above copyright notice and this permission notice shall be included in
12 * all copies or substantial portions of the Software.
13 *
14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
20 * SOFTWARE.
21 */
22
350ad6c1 23#define BT_LOG_TAG "LIB/COLANDER"
c2d9d9cf 24#include "lib/logging.h"
706a18f9 25
578e048b
MJ
26#include "common/assert.h"
27#include "lib/assert-pre.h"
28#include "lib/object.h"
3fadfbc0
MJ
29#include <babeltrace2/graph/component-class-sink.h>
30#include <babeltrace2/graph/self-component-sink.h>
31#include <babeltrace2/graph/self-component-port.h>
32#include <babeltrace2/graph/self-component-port-input-message-iterator.h>
33#include <babeltrace2/graph/self-component.h>
706a18f9 34#include <glib.h>
706a18f9 35
578e048b 36#include "component-class-sink-colander.h"
d24d5663 37#include "lib/func-status.h"
578e048b 38
706a18f9 39static
0d72b8c3 40struct bt_component_class_sink *colander_comp_cls;
706a18f9 41
706a18f9 42static
d24d5663 43enum bt_component_class_init_method_status colander_init(
d94d92ac 44 struct bt_self_component_sink *self_comp,
05e21286 45 const struct bt_value *params, void *init_method_data)
706a18f9 46{
d24d5663
PP
47 enum bt_component_class_init_method_status status =
48 BT_FUNC_STATUS_OK;
7474e7d3 49 struct bt_component_class_sink_colander_priv_data *colander_data = NULL;
8ed535b5
PP
50 struct bt_component_class_sink_colander_data *user_provided_data =
51 init_method_data;
706a18f9 52
3f7d4d90 53 BT_ASSERT(init_method_data);
7474e7d3
PP
54 colander_data = g_new0(
55 struct bt_component_class_sink_colander_priv_data, 1);
706a18f9
PP
56 if (!colander_data) {
57 BT_LOGE_STR("Failed to allocate colander data.");
d24d5663 58 status = BT_FUNC_STATUS_MEMORY_ERROR;
706a18f9
PP
59 goto end;
60 }
61
d6e69534 62 colander_data->msgs = user_provided_data->msgs;
d4393e08 63 colander_data->count_addr = user_provided_data->count_addr;
d94d92ac
PP
64 status = bt_self_component_sink_add_input_port(self_comp, "in",
65 NULL, NULL);
d24d5663 66 if (status != BT_FUNC_STATUS_OK) {
706a18f9
PP
67 BT_LOGE_STR("Cannot add input port.");
68 goto end;
69 }
70
d94d92ac 71 bt_self_component_set_data(
707b7d35 72 bt_self_component_sink_as_self_component(self_comp),
d94d92ac 73 colander_data);
706a18f9
PP
74
75end:
76 return status;
77}
78
79static
d94d92ac 80void colander_finalize(struct bt_self_component_sink *self_comp)
706a18f9 81{
7474e7d3 82 struct bt_component_class_sink_colander_priv_data *colander_data =
d94d92ac 83 bt_self_component_get_data(
707b7d35 84 bt_self_component_sink_as_self_component(self_comp));
706a18f9
PP
85
86 if (!colander_data) {
87 return;
88 }
89
d6e69534 90 BT_OBJECT_PUT_REF_AND_RESET(colander_data->msg_iter);
706a18f9
PP
91 g_free(colander_data);
92}
93
94static
d24d5663
PP
95enum bt_component_class_sink_graph_is_configured_method_status
96colander_graph_is_configured(
36d1acad 97 bt_self_component_sink *self_comp)
706a18f9 98{
d24d5663
PP
99 enum bt_component_class_sink_graph_is_configured_method_status status =
100 BT_FUNC_STATUS_OK;
7474e7d3 101 struct bt_component_class_sink_colander_priv_data *colander_data =
d94d92ac 102 bt_self_component_get_data(
707b7d35 103 bt_self_component_sink_as_self_component(self_comp));
706a18f9 104
36d1acad
SM
105 struct bt_self_component_port_input *self_port =
106 bt_self_component_sink_borrow_input_port_by_name(self_comp, "in");
107 BT_ASSERT(self_port);
108
f6ccaed9 109 BT_ASSERT(colander_data);
d6e69534
PP
110 BT_OBJECT_PUT_REF_AND_RESET(colander_data->msg_iter);
111 colander_data->msg_iter =
112 bt_self_component_port_input_message_iterator_create(
d94d92ac 113 self_port);
d6e69534
PP
114 if (!colander_data->msg_iter) {
115 BT_LIB_LOGE("Cannot create message iterator on "
d94d92ac
PP
116 "self component input port: %![port-]+p",
117 self_port);
d24d5663 118 status = BT_FUNC_STATUS_MEMORY_ERROR;
706a18f9
PP
119 goto end;
120 }
121
122end:
bf55043c 123 return status;
706a18f9
PP
124}
125
126static
d24d5663 127enum bt_component_class_sink_consume_method_status colander_consume(
d94d92ac 128 struct bt_self_component_sink *self_comp)
706a18f9 129{
d24d5663
PP
130 enum bt_component_class_sink_consume_method_status status =
131 BT_FUNC_STATUS_OK;
132 enum bt_message_iterator_next_status next_status;
7474e7d3 133 struct bt_component_class_sink_colander_priv_data *colander_data =
d94d92ac 134 bt_self_component_get_data(
707b7d35 135 bt_self_component_sink_as_self_component(self_comp));
d6e69534 136 bt_message_array_const msgs;
706a18f9 137
f6ccaed9 138 BT_ASSERT(colander_data);
3f7d4d90 139 BT_ASSERT(colander_data->msg_iter);
d24d5663
PP
140 next_status = bt_self_component_port_input_message_iterator_next(
141 colander_data->msg_iter, &msgs,
142 colander_data->count_addr);
143 switch (next_status) {
144 case BT_FUNC_STATUS_AGAIN:
145 status = BT_FUNC_STATUS_AGAIN;
706a18f9 146 goto end;
d24d5663
PP
147 case BT_FUNC_STATUS_END:
148 status = BT_FUNC_STATUS_END;
706a18f9 149 goto end;
d24d5663 150 case BT_FUNC_STATUS_OK:
d6e69534
PP
151 /* Move messages to user (count already set) */
152 memcpy(colander_data->msgs, msgs,
153 sizeof(*msgs) * *colander_data->count_addr);
706a18f9
PP
154 break;
155 default:
d24d5663 156 status = BT_FUNC_STATUS_ERROR;
706a18f9
PP
157 goto end;
158 }
159
706a18f9 160end:
706a18f9
PP
161 return status;
162}
163
d94d92ac 164struct bt_component_class_sink *bt_component_class_sink_colander_get(void)
706a18f9
PP
165{
166 if (colander_comp_cls) {
167 goto end;
168 }
169
0d72b8c3
PP
170 colander_comp_cls = bt_component_class_sink_create("colander",
171 colander_consume);
706a18f9
PP
172 if (!colander_comp_cls) {
173 BT_LOGE_STR("Cannot create sink colander component class.");
174 goto end;
175 }
176
0d72b8c3 177 (void) bt_component_class_sink_set_init_method(
d94d92ac 178 colander_comp_cls, colander_init);
0d72b8c3 179 (void) bt_component_class_sink_set_finalize_method(
d94d92ac 180 colander_comp_cls, colander_finalize);
36d1acad
SM
181 (void) bt_component_class_sink_set_graph_is_configured_method(
182 colander_comp_cls, colander_graph_is_configured);
706a18f9
PP
183
184end:
398454ed 185 bt_object_get_ref(colander_comp_cls);
5a2b6475 186 return colander_comp_cls;
706a18f9
PP
187}
188
189__attribute__((destructor)) static
190void put_colander(void) {
65300d60 191 BT_OBJECT_PUT_REF_AND_RESET(colander_comp_cls);
706a18f9 192}
This page took 0.046022 seconds and 4 git commands to generate.