- int_class = g_new(struct type_class_integer, 1);
- int_class->p.name = g_quark_from_string(name);
- int_class->p.alignment = alignment;
- int_class->p.copy = integer_copy;
- int_class->len = len;
- int_class->byte_order = byte_order;
- int_class->signedness = signedness;
- if (int_class->p.name) {
- ret = ctf_register_type(&int_class.p);
- if (ret) {
- g_free(int_class);
- return NULL;
- }
+ integer->p.index = root_name ? INT_MAX : index;
+ integer->p.name = field_name;
+ integer->p.path = new_definition_path(parent_scope, field_name,
+ root_name);
+ integer->p.scope = NULL;
+ integer->value._unsigned = 0;
+ ret = register_field_definition(field_name, &integer->p,
+ parent_scope);
+ assert(!ret);
+ return &integer->p;
+}
+
+static
+void _integer_definition_free(struct definition *definition)
+{
+ struct definition_integer *integer =
+ container_of(definition, struct definition_integer, p);
+
+ declaration_unref(integer->p.declaration);
+ g_free(integer);
+}
+
+uint64_t get_unsigned_int(struct definition *field)
+{
+ struct definition_integer *integer_definition;
+ const struct declaration_integer *integer_declaration;
+
+ integer_definition = container_of(field, struct definition_integer, p);
+ integer_declaration = integer_definition->declaration;
+
+ if (!integer_declaration->signedness) {
+ return integer_definition->value._unsigned;