X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=src%2Flib%2Fgraph%2Fcomponent-sink.c;h=7a24fed9b39c1fb515c2142cb85da7998b63948c;hb=43c59509042845f8d42c3e99ec74d45fa2dc0908;hp=598392454b12c093cc35045880e71bd4fae3ac6c;hpb=578e048b5debf169e286e5b5cc747b5d6c16886d;p=babeltrace.git diff --git a/src/lib/graph/component-sink.c b/src/lib/graph/component-sink.c index 59839245..7a24fed9 100644 --- a/src/lib/graph/component-sink.c +++ b/src/lib/graph/component-sink.c @@ -21,19 +21,22 @@ * SOFTWARE. */ -#define BT_LOG_TAG "COMP-SINK" -#include "lib/lib-logging.h" +#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 "compat/compiler.h" #include -#include -#include +#include +#include #include #include "component-sink.h" #include "component.h" +#include "graph.h" +#include "lib/func-status.h" BT_HIDDEN void bt_component_sink_destroy(struct bt_component *component) @@ -46,9 +49,12 @@ struct bt_component *bt_component_sink_create( { struct bt_component_sink *sink = NULL; + BT_ASSERT_PRE_NO_ERROR(); + sink = g_new0(struct bt_component_sink, 1); if (!sink) { - BT_LOGE_STR("Failed to allocate one sink component."); + BT_LIB_LOGE_APPEND_CAUSE( + "Failed to allocate one sink component."); goto end; } @@ -62,12 +68,12 @@ bt_component_sink_borrow_class_const( { struct bt_component_class *cls; - BT_ASSERT_PRE_NON_NULL(component, "Component"); + BT_ASSERT_PRE_DEV_NON_NULL(component, "Component"); cls = component->parent.class; - BT_ASSERT(cls); - BT_ASSERT(cls->type == BT_COMPONENT_CLASS_TYPE_SINK); + BT_ASSERT_DBG(cls); + BT_ASSERT_DBG(cls->type == BT_COMPONENT_CLASS_TYPE_SINK); return (bt_component_class_sink *) cls; } @@ -113,25 +119,26 @@ bt_self_component_sink_borrow_input_port_by_index( (void *) component, index); } -enum bt_self_component_status bt_self_component_sink_add_input_port( +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, struct bt_self_component_port_input **self_port) { - enum bt_self_component_status status; + enum bt_self_component_add_port_status status; struct bt_port *port = NULL; struct bt_component *comp = (void *) self_comp; + BT_ASSERT_PRE_NO_ERROR(); + /* bt_component_add_input_port() logs details/errors */ status = bt_component_add_input_port(comp, name, user_data, &port); - if (status != BT_SELF_COMPONENT_STATUS_OK) { + if (status != BT_FUNC_STATUS_OK) { goto end; } if (self_port) { /* Move reference to user */ *self_port = (void *) port; - port = NULL; } end: @@ -139,6 +146,16 @@ end: return status; } +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"); + return (bt_bool) bt_graph_is_interrupted( + bt_component_borrow_graph(comp)); +} + void bt_component_sink_get_ref( const struct bt_component_sink *component_sink) {