X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=include%2Fbabeltrace%2Ftrace-ir%2Ffield-class-const.h;h=9f2f960b40ec9ff4b4b4612ef9eb8c9c70f2caa8;hb=005f1204d7620018bb2c1406b6194940f0ee119f;hp=da751ebec9faffe3bf18eb956c96e0811534699a;hpb=b19ff26f04df428047676dd736bd7cc9473906fe;p=babeltrace.git diff --git a/include/babeltrace/trace-ir/field-class-const.h b/include/babeltrace/trace-ir/field-class-const.h index da751ebe..9f2f960b 100644 --- a/include/babeltrace/trace-ir/field-class-const.h +++ b/include/babeltrace/trace-ir/field-class-const.h @@ -28,10 +28,11 @@ */ /* - * For bt_bool, bt_field_class bt_field_path - * bt_field_class_signed_enumeration_mapping_ranges - * bt_field_class_unsigned_enumeration_mapping_ranges, - * bt_field_class_enumeration_mapping_label_array + * For bt_bool, bt_field_class, bt_field_path, + * bt_field_class_enumeration_mapping, + * bt_field_class_unsigned_enumeration_mapping, + * bt_field_class_signed_enumeration_mapping, + * bt_field_class_enumeration_mapping_label_array, __BT_UPCAST_CONST */ #include @@ -42,7 +43,12 @@ extern "C" { #endif -enum bt_field_class_type { +typedef enum bt_field_class_status { + BT_FIELD_CLASS_STATUS_OK = 0, + BT_FIELD_CLASS_STATUS_NOMEM = -12, +} bt_field_class_status; + +typedef enum bt_field_class_type { BT_FIELD_CLASS_TYPE_UNSIGNED_INTEGER, BT_FIELD_CLASS_TYPE_SIGNED_INTEGER, BT_FIELD_CLASS_TYPE_UNSIGNED_ENUMERATION, @@ -53,22 +59,22 @@ enum bt_field_class_type { BT_FIELD_CLASS_TYPE_STATIC_ARRAY, BT_FIELD_CLASS_TYPE_DYNAMIC_ARRAY, BT_FIELD_CLASS_TYPE_VARIANT, -}; +} bt_field_class_type; -enum bt_field_class_integer_preferred_display_base { +typedef enum bt_field_class_integer_preferred_display_base { BT_FIELD_CLASS_INTEGER_PREFERRED_DISPLAY_BASE_BINARY, BT_FIELD_CLASS_INTEGER_PREFERRED_DISPLAY_BASE_OCTAL, BT_FIELD_CLASS_INTEGER_PREFERRED_DISPLAY_BASE_DECIMAL, BT_FIELD_CLASS_INTEGER_PREFERRED_DISPLAY_BASE_HEXADECIMAL, -}; +} bt_field_class_integer_preferred_display_base; -extern enum bt_field_class_type bt_field_class_get_type( +extern bt_field_class_type bt_field_class_get_type( const bt_field_class *field_class); extern uint64_t bt_field_class_integer_get_field_value_range( const bt_field_class *field_class); -extern enum bt_field_class_integer_preferred_display_base +extern bt_field_class_integer_preferred_display_base bt_field_class_integer_get_preferred_display_base( const bt_field_class *field_class); @@ -78,40 +84,54 @@ extern bt_bool bt_field_class_real_is_single_precision( extern uint64_t bt_field_class_enumeration_get_mapping_count( const bt_field_class *field_class); -extern void bt_field_class_unsigned_enumeration_borrow_mapping_by_index_const( - const bt_field_class *field_class, uint64_t index, - const char **label, - const bt_field_class_unsigned_enumeration_mapping_ranges **ranges); +extern const bt_field_class_unsigned_enumeration_mapping * +bt_field_class_unsigned_enumeration_borrow_mapping_by_index_const( + const bt_field_class *field_class, uint64_t index); + +extern const bt_field_class_signed_enumeration_mapping * +bt_field_class_signed_enumeration_borrow_mapping_by_index_const( + const bt_field_class *field_class, uint64_t index); + +static inline +const bt_field_class_enumeration_mapping * +bt_field_class_unsigned_enumeration_mapping_as_mapping_const( + const bt_field_class_unsigned_enumeration_mapping *mapping) +{ + return __BT_UPCAST_CONST(bt_field_class_enumeration_mapping, mapping); +} -extern void bt_field_class_signed_enumeration_borrow_mapping_by_index_const( - const bt_field_class *field_class, uint64_t index, - const char **label, - const bt_field_class_signed_enumeration_mapping_ranges **ranges); +static inline +const bt_field_class_enumeration_mapping * +bt_field_class_signed_enumeration_mapping_as_mapping_const( + const bt_field_class_signed_enumeration_mapping *mapping) +{ + return __BT_UPCAST_CONST(bt_field_class_enumeration_mapping, mapping); +} -extern uint64_t -bt_field_class_unsigned_enumeration_mapping_ranges_get_range_count( - const bt_field_class_unsigned_enumeration_mapping_ranges *ranges); +extern const char *bt_field_class_enumeration_mapping_get_label( + const bt_field_class_enumeration_mapping *mapping); -extern uint64_t -bt_field_class_signed_enumeration_mapping_ranges_get_range_count( - const bt_field_class_signed_enumeration_mapping_ranges *ranges); +extern uint64_t bt_field_class_enumeration_mapping_get_range_count( + const bt_field_class_enumeration_mapping *mapping); extern void -bt_field_class_unsigned_enumeration_mapping_ranges_get_range_by_index( - const bt_field_class_unsigned_enumeration_mapping_ranges *ranges, +bt_field_class_unsigned_enumeration_mapping_get_range_by_index( + const bt_field_class_unsigned_enumeration_mapping *mapping, uint64_t index, uint64_t *lower, uint64_t *upper); extern void -bt_field_class_signed_enumeration_mapping_ranges_get_range_by_index( - const bt_field_class_unsigned_enumeration_mapping_ranges *ranges, +bt_field_class_signed_enumeration_mapping_get_range_by_index( + const bt_field_class_signed_enumeration_mapping *mapping, uint64_t index, int64_t *lower, int64_t *upper); -extern int bt_field_class_unsigned_enumeration_get_mapping_labels_by_value( +extern bt_field_class_status +bt_field_class_unsigned_enumeration_get_mapping_labels_by_value( const bt_field_class *field_class, uint64_t value, bt_field_class_enumeration_mapping_label_array *label_array, uint64_t *count); -extern int bt_field_class_signed_enumeration_get_mapping_labels_by_value( +extern bt_field_class_status +bt_field_class_signed_enumeration_get_mapping_labels_by_value( const bt_field_class *field_class, int64_t value, bt_field_class_enumeration_mapping_label_array *label_array, uint64_t *count); @@ -119,15 +139,21 @@ extern int bt_field_class_signed_enumeration_get_mapping_labels_by_value( extern uint64_t bt_field_class_structure_get_member_count( const bt_field_class *field_class); -extern void bt_field_class_structure_borrow_member_by_index_const( - const bt_field_class *struct_field_class, uint64_t index, - const char **name, const bt_field_class **field_class); +extern const bt_field_class_structure_member * +bt_field_class_structure_borrow_member_by_index_const( + const bt_field_class *field_class, uint64_t index); -extern -const bt_field_class * -bt_field_class_structure_borrow_member_field_class_by_name_const( +extern const bt_field_class_structure_member * +bt_field_class_structure_borrow_member_by_name_const( const bt_field_class *field_class, const char *name); +extern const char *bt_field_class_structure_member_get_name( + const bt_field_class_structure_member *member); + +extern const bt_field_class * +bt_field_class_structure_member_borrow_field_class_const( + const bt_field_class_structure_member *member); + extern const bt_field_class * bt_field_class_array_borrow_element_field_class_const( const bt_field_class *field_class); @@ -146,15 +172,20 @@ bt_field_class_variant_borrow_selector_field_path_const( extern uint64_t bt_field_class_variant_get_option_count( const bt_field_class *field_class); -extern void bt_field_class_variant_borrow_option_by_index_const( - const bt_field_class *variant_field_class, uint64_t index, - const char **name, const bt_field_class **field_class); +extern const bt_field_class_variant_option * +bt_field_class_variant_borrow_option_by_index_const( + const bt_field_class *field_class, uint64_t index); + +extern const bt_field_class_variant_option * +bt_field_class_variant_borrow_option_by_name_const( + const bt_field_class *field_class, const char *name); + +extern const char *bt_field_class_variant_option_get_name( + const bt_field_class_variant_option *option); -extern -const bt_field_class * -bt_field_class_variant_borrow_option_field_class_by_name_const( - const bt_field_class *field_class, - const char *name); +extern const bt_field_class * +bt_field_class_variant_option_borrow_field_class_const( + const bt_field_class_variant_option *option); extern void bt_field_class_get_ref(const bt_field_class *field_class);