X-Git-Url: https://git.efficios.com/?p=babeltrace.git;a=blobdiff_plain;f=src%2Flib%2Fgraph%2Fcomponent-sink.c;h=37eda35a6b680119160b3b2c9ee51b452609300f;hp=b848a019acba3932a7d054efdb326f5a4aedf1a1;hb=805e57b014d3763c86568a0b966f4d5093a53e03;hpb=98b15851a941e7342b8bb19e265cdc3a40fabfb8 diff --git a/src/lib/graph/component-sink.c b/src/lib/graph/component-sink.c index b848a019..37eda35a 100644 --- a/src/lib/graph/component-sink.c +++ b/src/lib/graph/component-sink.c @@ -1,36 +1,19 @@ /* + * SPDX-License-Identifier: MIT + * * Copyright 2017-2018 Philippe Proulx * Copyright 2015 Jérémie Galarneau - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE - * SOFTWARE. */ #define BT_LOG_TAG "LIB/COMPONENT-SINK" #include "lib/logging.h" #include "common/assert.h" -#include "lib/assert-pre.h" -#include "lib/assert-post.h" +#include "lib/assert-cond.h" #include "compat/compiler.h" #include -#include -#include +#include +#include #include #include "component-sink.h" @@ -38,12 +21,10 @@ #include "graph.h" #include "lib/func-status.h" -BT_HIDDEN void bt_component_sink_destroy(struct bt_component *component) { } -BT_HIDDEN struct bt_component *bt_component_sink_create( const struct bt_component_class *class) { @@ -60,13 +41,14 @@ end: return (void *) sink; } +BT_EXPORT const bt_component_class_sink * bt_component_sink_borrow_class_const( const bt_component_sink *component) { struct bt_component_class *cls; - BT_ASSERT_PRE_DEV_NON_NULL(component, "Component"); + BT_ASSERT_PRE_DEV_COMP_NON_NULL(component); cls = component->parent.class; @@ -76,47 +58,66 @@ bt_component_sink_borrow_class_const( return (bt_component_class_sink *) cls; } +BT_EXPORT uint64_t bt_component_sink_get_input_port_count( const struct bt_component_sink *component) { - /* bt_component_get_input_port_count() logs details/errors */ - return bt_component_get_input_port_count((void *) component); + /* bt_component_get_input_port_count() checks preconditions */ + return bt_component_get_input_port_count((void *) component, __func__); } +BT_EXPORT const struct bt_port_input * bt_component_sink_borrow_input_port_by_name_const( const struct bt_component_sink *component, const char *name) { - /* bt_component_borrow_input_port_by_name() logs details/errors */ - return bt_component_borrow_input_port_by_name((void *) component, name); + /* + * bt_component_borrow_input_port_by_name() logs details/errors + * and checks preconditions. + */ + return bt_component_borrow_input_port_by_name((void *) component, name, + __func__); } +BT_EXPORT struct bt_self_component_port_input * bt_self_component_sink_borrow_input_port_by_name( struct bt_self_component_sink *component, const char *name) { - /* bt_component_borrow_input_port_by_name() logs details/errors */ + /* + * bt_component_borrow_input_port_by_name() logs details/errors + * and checks preconditions. + */ return (void *) bt_component_borrow_input_port_by_name( - (void *) component, name); + (void *) component, name, __func__); } +BT_EXPORT const struct bt_port_input *bt_component_sink_borrow_input_port_by_index_const( const struct bt_component_sink *component, uint64_t index) { - /* bt_component_borrow_input_port_by_index() logs details/errors */ + /* + * bt_component_borrow_input_port_by_index() logs details/errors + * and checks preconditions. + */ return bt_component_borrow_input_port_by_index( - (void *) component, index); + (void *) component, index, __func__); } +BT_EXPORT struct bt_self_component_port_input * bt_self_component_sink_borrow_input_port_by_index( struct bt_self_component_sink *component, uint64_t index) { - /* bt_component_borrow_input_port_by_index() logs details/errors */ + /* + * bt_component_borrow_input_port_by_index() logs details/errors + * and checks preconditions. + */ return (void *) bt_component_borrow_input_port_by_index( - (void *) component, index); + (void *) component, index, __func__); } +BT_EXPORT enum bt_self_component_add_port_status bt_self_component_sink_add_input_port( struct bt_self_component_sink *self_comp, const char *name, void *user_data, @@ -126,8 +127,12 @@ enum bt_self_component_add_port_status bt_self_component_sink_add_input_port( struct bt_port *port = NULL; struct bt_component *comp = (void *) self_comp; - /* bt_component_add_input_port() logs details/errors */ - status = bt_component_add_input_port(comp, name, user_data, &port); + /* + * bt_component_add_input_port() logs details/errors and checks + * preconditions. + */ + status = bt_component_add_input_port(comp, name, user_data, &port, + __func__); if (status != BT_FUNC_STATUS_OK) { goto end; } @@ -135,7 +140,6 @@ enum bt_self_component_add_port_status bt_self_component_sink_add_input_port( if (self_port) { /* Move reference to user */ *self_port = (void *) port; - port = NULL; } end: @@ -143,22 +147,25 @@ end: return status; } +BT_EXPORT bt_bool bt_self_component_sink_is_interrupted( const struct bt_self_component_sink *self_comp) { struct bt_component *comp = (void *) self_comp; - BT_ASSERT_PRE_NON_NULL(comp, "Component"); + BT_ASSERT_PRE_COMP_NON_NULL(comp); return (bt_bool) bt_graph_is_interrupted( bt_component_borrow_graph(comp)); } +BT_EXPORT void bt_component_sink_get_ref( const struct bt_component_sink *component_sink) { bt_object_get_ref(component_sink); } +BT_EXPORT void bt_component_sink_put_ref( const struct bt_component_sink *component_sink) {