return fdest->enum_write(dest, enum_class, v);
}
+void enum_type_free(struct type_class_enum *enum_class)
+{
+ g_hash_table_destroy(enum_class->table.value_to_quark);
+ g_hash_table_destroy(enum_class->table.quark_to_value);
+ g_free(enum_class);
+}
+
+static
+void _enum_type_free(struct type_class *type_class)
+{
+ struct type_class_enum *enum_class =
+ container_of(type_class, struct type_class_enum, p);
+ enum_type_free(enum_class);
+}
+
struct type_class_enum *enum_type_new(const char *name,
- size_t start_offset,
size_t len, int byte_order,
int signedness,
size_t alignment)
g_direct_equal,
NULL, enum_val_free);
bitfield_class = &enum_class->p;
- bitfield_class->start_offset = start_offset;
int_class = &bitfield_class->p;
int_class->p.name = g_quark_from_string(name);
int_class->p.alignment = alignment;
+ int_class->p.copy = enum_copy;
+ int_class->p.free = _enum_type_free;
int_class->len = len;
int_class->byte_order = byte_order;
int_class->signedness = signedness;
- bitfield_class->start_offset = start_offset;
if (int_class->p.name) {
ret = register_type(&int_class->p);
if (ret) {
}
return enum_class;
}
-
-void enum_type_free(struct type_class_enum *enum_class)
-{
- g_hash_table_destroy(enum_class->table.value_to_quark);
- g_hash_table_destroy(enum_class->table.quark_to_value);
- g_free(enum_class);
-}