X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=include%2Fbabeltrace2%2Ftrace-ir%2Ffield-class.h;h=9d2cf064901e33bd700a8196188110b335a7c6ca;hb=9b4f9b425f2efce9a6ccc25f7ae062ebc1116a7d;hp=d6997db5aabc1e8f8cbe2066712da98f9c8cd9bd;hpb=924dc299c8a893e92fcd985fa05c245b591ef314;p=babeltrace.git diff --git a/include/babeltrace2/trace-ir/field-class.h b/include/babeltrace2/trace-ir/field-class.h index d6997db5..9d2cf064 100644 --- a/include/babeltrace2/trace-ir/field-class.h +++ b/include/babeltrace2/trace-ir/field-class.h @@ -2,8 +2,7 @@ #define BABELTRACE2_TRACE_IR_FIELD_CLASS_H /* - * Copyright 2017-2018 Philippe Proulx - * Copyright 2013, 2014 Jérémie Galarneau + * Copyright (c) 2010-2019 EfficiOS Inc. and Linux Foundation * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -22,33 +21,26 @@ * 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. - * - * The Common Trace Format (CTF) Specification is available at - * http://www.efficios.com/ctf */ +#ifndef __BT_IN_BABELTRACE_H +# error "Please include instead." +#endif + #include #include -/* For bt_bool, bt_field_class, bt_trace_class */ #include - -/* For bt_field_class_integer_preferred_display_base */ #include -/* For __BT_FUNC_STATUS_* */ -#define __BT_FUNC_STATUS_ENABLE -#include -#undef __BT_FUNC_STATUS_ENABLE - #ifdef __cplusplus extern "C" { #endif -extern bt_field_class *bt_field_class_unsigned_integer_create( +extern bt_field_class *bt_field_class_integer_unsigned_create( bt_trace_class *trace_class); -extern bt_field_class *bt_field_class_signed_integer_create( +extern bt_field_class *bt_field_class_integer_signed_create( bt_trace_class *trace_class); extern void bt_field_class_integer_set_field_value_range( @@ -64,26 +56,26 @@ extern void bt_field_class_real_set_is_single_precision( bt_field_class *field_class, bt_bool is_single_precision); -extern bt_field_class *bt_field_class_unsigned_enumeration_create( +extern bt_field_class *bt_field_class_enumeration_unsigned_create( bt_trace_class *trace_class); -extern bt_field_class *bt_field_class_signed_enumeration_create( +extern bt_field_class *bt_field_class_enumeration_signed_create( bt_trace_class *trace_class); -typedef enum bt_field_class_enumeration_map_range_status { - BT_FIELD_CLASS_ENUMERATION_MAP_RANGE_STATUS_MEMORY_ERROR = __BT_FUNC_STATUS_MEMORY_ERROR, - BT_FIELD_CLASS_ENUMERATION_MAP_RANGE_STATUS_OK = __BT_FUNC_STATUS_OK, -} bt_field_class_enumeration_map_range_status; +typedef enum bt_field_class_enumeration_add_mapping_status { + BT_FIELD_CLASS_ENUMERATION_ADD_MAPPING_STATUS_MEMORY_ERROR = __BT_FUNC_STATUS_MEMORY_ERROR, + BT_FIELD_CLASS_ENUMERATION_ADD_MAPPING_STATUS_OK = __BT_FUNC_STATUS_OK, +} bt_field_class_enumeration_add_mapping_status; -extern bt_field_class_enumeration_map_range_status -bt_field_class_unsigned_enumeration_map_range( +extern bt_field_class_enumeration_add_mapping_status +bt_field_class_enumeration_unsigned_add_mapping( bt_field_class *field_class, const char *label, - uint64_t range_lower, uint64_t range_upper); + const bt_integer_range_set_unsigned *range_set); -extern bt_field_class_enumeration_map_range_status -bt_field_class_signed_enumeration_map_range( +extern bt_field_class_enumeration_add_mapping_status +bt_field_class_enumeration_signed_add_mapping( bt_field_class *field_class, const char *label, - int64_t range_lower, int64_t range_upper); + const bt_integer_range_set_signed *range_set); extern bt_field_class *bt_field_class_string_create( bt_trace_class *trace_class); @@ -109,64 +101,51 @@ extern bt_field_class_structure_member * bt_field_class_structure_borrow_member_by_name( bt_field_class *field_class, const char *name); -extern bt_field_class *bt_field_class_static_array_create( +extern bt_field_class *bt_field_class_array_static_create( bt_trace_class *trace_class, bt_field_class *elem_field_class, uint64_t length); -extern bt_field_class *bt_field_class_dynamic_array_create( +extern bt_field_class *bt_field_class_array_dynamic_create( bt_trace_class *trace_class, - bt_field_class *elem_field_class); + bt_field_class *elem_field_class, + bt_field_class *length_field_class); extern bt_field_class *bt_field_class_array_borrow_element_field_class( bt_field_class *field_class); -typedef enum bt_field_class_dynamic_array_set_length_field_class_status { - BT_FIELD_CLASS_DYNAMIC_ARRAY_SET_LENGTH_FIELD_CLASS_STATUS_MEMORY_ERROR = __BT_FUNC_STATUS_MEMORY_ERROR, - BT_FIELD_CLASS_DYNAMIC_ARRAY_SET_LENGTH_FIELD_CLASS_STATUS_OK = __BT_FUNC_STATUS_OK, -} bt_field_class_dynamic_array_set_length_field_class_status; - -extern bt_field_class_dynamic_array_set_length_field_class_status -bt_field_class_dynamic_array_set_length_field_class( - bt_field_class *field_class, - bt_field_class *length_field_class); - extern bt_field_class *bt_field_class_variant_create( - bt_trace_class *trace_class); - -typedef enum bt_field_class_variant_set_selector_field_class_status { - BT_FIELD_CLASS_VARIANT_SET_SELECTOR_FIELD_CLASS_STATUS_MEMORY_ERROR = __BT_FUNC_STATUS_MEMORY_ERROR, - BT_FIELD_CLASS_VARIANT_SET_SELECTOR_FIELD_CLASS_STATUS_OK = __BT_FUNC_STATUS_OK, -} bt_field_class_variant_set_selector_field_class_status; - -extern bt_field_class_variant_set_selector_field_class_status -bt_field_class_variant_set_selector_field_class(bt_field_class *field_class, + bt_trace_class *trace_class, bt_field_class *selector_field_class); -typedef enum bt_field_class_variant_append_option_status { - BT_FIELD_CLASS_VARIANT_APPEND_OPTION_STATUS_MEMORY_ERROR = __BT_FUNC_STATUS_MEMORY_ERROR, - BT_FIELD_CLASS_VARIANT_APPEND_OPTION_STATUS_OK = __BT_FUNC_STATUS_OK, -} bt_field_class_variant_append_option_status; +typedef enum bt_field_class_variant_without_selector_append_option_status { + BT_FIELD_CLASS_VARIANT_WITHOUT_SELECTOR_APPEND_OPTION_STATUS_MEMORY_ERROR = __BT_FUNC_STATUS_MEMORY_ERROR, + BT_FIELD_CLASS_VARIANT_WITHOUT_SELECTOR_APPEND_OPTION_STATUS_OK = __BT_FUNC_STATUS_OK, +} bt_field_class_variant_without_selector_append_option_status; -extern bt_field_class_variant_append_option_status -bt_field_class_variant_append_option( - bt_field_class *var_field_class, - const char *name, bt_field_class *field_class); +extern bt_field_class_variant_without_selector_append_option_status +bt_field_class_variant_without_selector_append_option( + bt_field_class *var_field_class, const char *name, + bt_field_class *field_class); -extern bt_field_class_variant_option * -bt_field_class_variant_borrow_option_by_index( - bt_field_class *field_class, uint64_t index); +typedef enum bt_field_class_variant_with_selector_append_option_status { + BT_FIELD_CLASS_VARIANT_WITH_SELECTOR_APPEND_OPTION_STATUS_MEMORY_ERROR = __BT_FUNC_STATUS_MEMORY_ERROR, + BT_FIELD_CLASS_VARIANT_WITH_SELECTOR_APPEND_OPTION_STATUS_OK = __BT_FUNC_STATUS_OK, +} bt_field_class_variant_with_selector_append_option_status; -extern bt_field_class_variant_option * -bt_field_class_variant_borrow_option_by_name( - bt_field_class *field_class, const char *name); +extern bt_field_class_variant_with_selector_append_option_status +bt_field_class_variant_with_selector_unsigned_append_option( + bt_field_class *var_field_class, const char *name, + bt_field_class *field_class, + const bt_integer_range_set_unsigned *range_set); -extern bt_field_class *bt_field_class_variant_option_borrow_field_class( - bt_field_class_variant_option *option); +extern bt_field_class_variant_with_selector_append_option_status +bt_field_class_variant_with_selector_signed_append_option( + bt_field_class *var_field_class, const char *name, + bt_field_class *field_class, + const bt_integer_range_set_signed *range_set); #ifdef __cplusplus } #endif -#include - #endif /* BABELTRACE2_TRACE_IR_FIELD_CLASS_H */