API doc: add int/float field type examples
[babeltrace.git] / include / babeltrace / ctf-ir / field-types-internal.h
CommitLineData
2e33ac5a
PP
1#ifndef BABELTRACE_CTF_IR_FIELD_TYPES_INTERNAL_H
2#define BABELTRACE_CTF_IR_FIELD_TYPES_INTERNAL_H
273b65be
JG
3
4/*
2e33ac5a 5 * BabelTrace - CTF IR: Event field types internal
273b65be 6 *
de9dd397 7 * Copyright 2013, 2014 Jérémie Galarneau <jeremie.galarneau@efficios.com>
273b65be
JG
8 *
9 * Author: Jérémie Galarneau <jeremie.galarneau@efficios.com>
10 *
11 * Permission is hereby granted, free of charge, to any person obtaining a copy
12 * of this software and associated documentation files (the "Software"), to deal
13 * in the Software without restriction, including without limitation the rights
14 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
15 * copies of the Software, and to permit persons to whom the Software is
16 * furnished to do so, subject to the following conditions:
17 *
18 * The above copyright notice and this permission notice shall be included in
19 * all copies or substantial portions of the Software.
20 *
21 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
22 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
23 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
24 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
25 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
26 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
27 * SOFTWARE.
28 */
29
30#include <babeltrace/ctf-writer/event-types.h>
273b65be
JG
31#include <babeltrace/ctf-writer/event-fields.h>
32#include <babeltrace/ctf-writer/writer.h>
bc37ae52 33#include <babeltrace/ctf-ir/trace-internal.h>
ac0c6bdd 34#include <babeltrace/ctf-ir/clock-class.h>
273b65be 35#include <babeltrace/babeltrace-internal.h>
83509119 36#include <babeltrace/object-internal.h>
273b65be
JG
37#include <babeltrace/types.h>
38#include <babeltrace/ctf/events.h>
39#include <glib.h>
40
b75277fb
JG
41typedef void (*type_freeze_func)(struct bt_ctf_field_type *);
42typedef int (*type_serialize_func)(struct bt_ctf_field_type *,
273b65be
JG
43 struct metadata_context *);
44
45struct bt_ctf_field_type {
83509119 46 struct bt_object base;
273b65be
JG
47 struct bt_declaration *declaration;
48 type_freeze_func freeze;
49 type_serialize_func serialize;
50 /*
51 * A type can't be modified once it is added to an event or after a
52 * a field has been instanciated from it.
53 */
54 int frozen;
81e36fac
PP
55
56 /*
57 * This flag indicates if the field type is valid. A valid
58 * field type is _always_ frozen. All the nested field types of
59 * a valid field type are also valid (and thus frozen).
60 */
61 int valid;
273b65be
JG
62};
63
64struct bt_ctf_field_type_integer {
65 struct bt_ctf_field_type parent;
66 struct declaration_integer declaration;
ac0c6bdd 67 struct bt_ctf_clock_class *mapped_clock;
445c3471
PP
68
69 /*
70 * This is what the user sets and is never modified by internal
71 * code.
72 *
73 * This field must contain a `BT_CTF_BYTE_ORDER_*` value.
74 */
75 enum bt_ctf_byte_order user_byte_order;
273b65be
JG
76};
77
78struct enumeration_mapping {
b92ddaaa
JG
79 union {
80 uint64_t _unsigned;
81 int64_t _signed;
82 } range_start;
83
84 union {
85 uint64_t _unsigned;
86 int64_t _signed;
87 } range_end;
273b65be
JG
88 GQuark string;
89};
90
91struct bt_ctf_field_type_enumeration {
92 struct bt_ctf_field_type parent;
93 struct bt_ctf_field_type *container;
db8ef253 94 GPtrArray *entries; /* Array of ptrs to struct enumeration_mapping */
273b65be
JG
95 struct declaration_enum declaration;
96};
97
98struct bt_ctf_field_type_floating_point {
99 struct bt_ctf_field_type parent;
100 struct declaration_float declaration;
d480b699
PP
101
102 /*
103 * The `declaration` field above contains 3 pointers pointing
104 * to the fields below. This avoids unnecessary dynamic
105 * allocations.
106 */
273b65be
JG
107 struct declaration_integer sign;
108 struct declaration_integer mantissa;
109 struct declaration_integer exp;
445c3471
PP
110
111 /*
112 * This is what the user sets and is never modified by internal
113 * code.
114 *
115 * This field must contain a `BT_CTF_BYTE_ORDER_*` value.
116 */
117 enum bt_ctf_byte_order user_byte_order;
273b65be
JG
118};
119
120struct structure_field {
121 GQuark name;
122 struct bt_ctf_field_type *type;
123};
124
125struct bt_ctf_field_type_structure {
126 struct bt_ctf_field_type parent;
127 GHashTable *field_name_to_index;
128 GPtrArray *fields; /* Array of pointers to struct structure_field */
24724933 129 struct declaration_struct declaration;
273b65be
JG
130};
131
132struct bt_ctf_field_type_variant {
133 struct bt_ctf_field_type parent;
134 GString *tag_name;
135 struct bt_ctf_field_type_enumeration *tag;
b011f6b0 136 struct bt_ctf_field_path *tag_field_path;
273b65be
JG
137 GHashTable *field_name_to_index;
138 GPtrArray *fields; /* Array of pointers to struct structure_field */
139 struct declaration_variant declaration;
140};
141
142struct bt_ctf_field_type_array {
143 struct bt_ctf_field_type parent;
144 struct bt_ctf_field_type *element_type;
145 unsigned int length; /* Number of elements */
146 struct declaration_array declaration;
147};
148
149struct bt_ctf_field_type_sequence {
150 struct bt_ctf_field_type parent;
151 struct bt_ctf_field_type *element_type;
152 GString *length_field_name;
aa4e271c 153 struct bt_ctf_field_path *length_field_path;
273b65be
JG
154 struct declaration_sequence declaration;
155};
156
157struct bt_ctf_field_type_string {
158 struct bt_ctf_field_type parent;
159 struct declaration_string declaration;
160};
161
162BT_HIDDEN
163void bt_ctf_field_type_freeze(struct bt_ctf_field_type *type);
164
165BT_HIDDEN
b92ddaaa
JG
166struct bt_ctf_field_type *bt_ctf_field_type_variant_get_field_type_signed(
167 struct bt_ctf_field_type_variant *variant, int64_t tag_value);
273b65be
JG
168
169BT_HIDDEN
b92ddaaa
JG
170struct bt_ctf_field_type *bt_ctf_field_type_variant_get_field_type_unsigned(
171 struct bt_ctf_field_type_variant *variant, uint64_t tag_value);
273b65be
JG
172
173BT_HIDDEN
174int bt_ctf_field_type_serialize(struct bt_ctf_field_type *type,
175 struct metadata_context *context);
176
9ce21c30
JG
177BT_HIDDEN
178int bt_ctf_field_type_validate(struct bt_ctf_field_type *type);
179
e5958c30
JG
180BT_HIDDEN
181const char *bt_ctf_field_type_enumeration_get_mapping_name_unsigned(
182 struct bt_ctf_field_type_enumeration *enumeration_type,
183 uint64_t value);
184
185BT_HIDDEN
186const char *bt_ctf_field_type_enumeration_get_mapping_name_signed(
187 struct bt_ctf_field_type_enumeration *enumeration_type,
188 int64_t value);
189
c35a1669
JG
190/* Override field type's byte order only if it is set to "native" */
191BT_HIDDEN
192void bt_ctf_field_type_set_native_byte_order(
193 struct bt_ctf_field_type *type, int byte_order);
24724933 194
39a5e0db
JG
195BT_HIDDEN
196int bt_ctf_field_type_structure_get_field_name_index(
197 struct bt_ctf_field_type *structure, const char *name);
736133f1 198
5cec03e4
JG
199/* Replace an existing field's type in a structure */
200BT_HIDDEN
201int bt_ctf_field_type_structure_set_field_index(
202 struct bt_ctf_field_type *structure,
203 struct bt_ctf_field_type *field, int index);
204
736133f1
JG
205BT_HIDDEN
206int bt_ctf_field_type_variant_get_field_name_index(
207 struct bt_ctf_field_type *variant, const char *name);
aa4e271c
JG
208
209BT_HIDDEN
210int bt_ctf_field_type_sequence_set_length_field_path(
211 struct bt_ctf_field_type *type,
212 struct bt_ctf_field_path *path);
4a1e8671
JG
213
214BT_HIDDEN
215int bt_ctf_field_type_variant_set_tag_field_path(struct bt_ctf_field_type *type,
216 struct bt_ctf_field_path *path);
3f39933a
JG
217
218BT_HIDDEN
4b5fcb78
PP
219int bt_ctf_field_type_variant_set_tag_field_type(struct bt_ctf_field_type *type,
220 struct bt_ctf_field_type *tag_type);
3f39933a 221
5cec03e4
JG
222/* Replace an existing field's type in a variant */
223BT_HIDDEN
224int bt_ctf_field_type_variant_set_field_index(
225 struct bt_ctf_field_type *variant,
226 struct bt_ctf_field_type *field, int index);
227
626e93aa
PP
228BT_HIDDEN
229int bt_ctf_field_type_array_set_element_type(struct bt_ctf_field_type *array,
230 struct bt_ctf_field_type *element_type);
231
232BT_HIDDEN
233int bt_ctf_field_type_sequence_set_element_type(struct bt_ctf_field_type *array,
234 struct bt_ctf_field_type *element_type);
235
09840de5
PP
236BT_HIDDEN
237int bt_ctf_field_type_get_field_count(struct bt_ctf_field_type *type);
238
239BT_HIDDEN
240struct bt_ctf_field_type *bt_ctf_field_type_get_field_at_index(
241 struct bt_ctf_field_type *type, int index);
242
243BT_HIDDEN
244int bt_ctf_field_type_get_field_index(struct bt_ctf_field_type *type,
245 const char *name);
246
2e33ac5a 247#endif /* BABELTRACE_CTF_IR_FIELD_TYPES_INTERNAL_H */
This page took 0.046158 seconds and 4 git commands to generate.