Fix: src.text.dmesg: put leaking trace class on component destruction
[babeltrace.git] / include / babeltrace / graph / component-class-sink-const.h
index 613b91635e7cd2c664d27e670037753109343dd9..ecd0059c31ac01b2f782532091d7b49e90977f79 100644 (file)
  * SOFTWARE.
  */
 
+/* For bt_component_class, bt_component_class_sink */
+#include <babeltrace/types.h>
+
 #ifdef __cplusplus
 extern "C" {
 #endif
 
-struct bt_component_class;
-struct bt_component_class_sink;
-
 static inline
-const struct bt_component_class *
+const bt_component_class *
 bt_component_class_sink_as_component_class_const(
-               const struct bt_component_class_sink *comp_cls_sink)
+               const bt_component_class_sink *comp_cls_sink)
 {
        return (const void *) comp_cls_sink;
 }
 
+extern void bt_component_class_sink_get_ref(
+               const bt_component_class_sink *component_class_sink);
+
+extern void bt_component_class_sink_put_ref(
+               const bt_component_class_sink *component_class_sink);
+
+#define BT_COMPONENT_CLASS_SINK_PUT_REF_AND_RESET(_var)                \
+       do {                                                    \
+               bt_component_class_sink_put_ref(_var);          \
+               (_var) = NULL;                                  \
+       } while (0)
+
+#define BT_COMPONENT_CLASS_SINK_MOVE_REF(_var_dst, _var_src)   \
+       do {                                                    \
+               bt_component_class_sink_put_ref(_var_dst);      \
+               (_var_dst) = (_var_src);                        \
+               (_var_src) = NULL;                              \
+       } while (0)
+
 #ifdef __cplusplus
 }
 #endif
This page took 0.041251 seconds and 4 git commands to generate.