lib: add bt_field_class_variant_borrow_option_by_{index,name}()
[babeltrace.git] / include / babeltrace2 / trace-ir / field-class.h
index a8c3feafe4f4a4e4cda2ce5937ca4f9c6c279472..083facbe7b3d6fa79313bb2e6b4d428a6ce224a4 100644 (file)
 extern "C" {
 #endif
 
-extern bt_field_class *bt_field_class_unsigned_integer_create(
+extern bt_field_class *bt_field_class_bool_create(
                bt_trace_class *trace_class);
 
-extern bt_field_class *bt_field_class_signed_integer_create(
+extern bt_field_class *bt_field_class_bit_array_create(
+               bt_trace_class *trace_class, uint64_t length);
+
+extern bt_field_class *bt_field_class_integer_unsigned_create(
+               bt_trace_class *trace_class);
+
+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(
@@ -56,10 +62,10 @@ 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_add_mapping_status {
@@ -68,12 +74,12 @@ typedef enum bt_field_class_enumeration_add_mapping_status {
 } bt_field_class_enumeration_add_mapping_status;
 
 extern bt_field_class_enumeration_add_mapping_status
-bt_field_class_unsigned_enumeration_add_mapping(
+bt_field_class_enumeration_unsigned_add_mapping(
                bt_field_class *field_class, const char *label,
                const bt_integer_range_set_unsigned *range_set);
 
 extern bt_field_class_enumeration_add_mapping_status
-bt_field_class_signed_enumeration_add_mapping(
+bt_field_class_enumeration_signed_add_mapping(
                bt_field_class *field_class, const char *label,
                const bt_integer_range_set_signed *range_set);
 
@@ -101,26 +107,22 @@ 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_option_create(
+               bt_trace_class *trace_class,
+               bt_field_class *content_field_class,
+               bt_field_class *selector_field_class);
 
 extern bt_field_class *bt_field_class_variant_create(
                bt_trace_class *trace_class,
@@ -142,17 +144,25 @@ typedef enum bt_field_class_variant_with_selector_append_option_status {
 } bt_field_class_variant_with_selector_append_option_status;
 
 extern bt_field_class_variant_with_selector_append_option_status
-bt_field_class_variant_with_unsigned_selector_append_option(
+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_variant_with_selector_append_option_status
-bt_field_class_variant_with_signed_selector_append_option(
+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);
 
+extern bt_field_class_variant_option *
+bt_field_class_variant_borrow_option_by_index(
+               bt_field_class *field_class, uint64_t index);
+
+extern bt_field_class_variant_option *
+bt_field_class_variant_borrow_option_by_name(
+               bt_field_class *field_class, const char *name);
+
 #ifdef __cplusplus
 }
 #endif
This page took 0.02549 seconds and 4 git commands to generate.