size_t (*copy)(unsigned char *dest, const struct format *fdest,
const unsigned char *src, const struct format *fsrc,
const struct type_class *type_class);
+ void (*free)(struct type_class *type_class);
};
struct type_class_integer {
}
}
+void bitfield_type_free(struct type_class_bitfield *bitfield_class)
+{
+ g_free(bitfield_class);
+}
+
+static void _bitfield_type_free(struct type_class *type_class)
+{
+ struct type_class_bitfield *bitfield_class =
+ container_of(type_class, struct type_class_bitfield, p);
+ bitfield_type_free(bitfield_class);
+}
+
struct type_class_bitfield *bitfield_type_new(const char *name,
size_t start_offset,
size_t len, int byte_order,
int_class = &bitfield_class->p;
int_class->p.name = g_quark_from_string(name);
int_class->p.alignment = alignment;
+ int_class->p.copy = bitfield_copy;
+ int_class->p.free = _bitfield_type_free;
int_class->len = len;
int_class->byte_order = byte_order;
int_class->signedness = signedness;
}
return bitfield_class;
}
-
-void bitfield_type_free(struct type_class_bitfield *bitfield_class)
-{
- g_free(bitfield_class);
-}
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_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;
}
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);
-}
}
}
+void float_type_free(struct type_class_float *float_class)
+{
+ g_free(float_class);
+}
+
+static void _float_type_free(struct type_class *type_class)
+{
+ struct type_class_float *float_class =
+ container_of(type_class, struct type_class_float, p);
+ float_type_free(float_class);
+}
+
struct type_class_float *float_type_new(const char *name,
size_t mantissa_len,
size_t exp_len, int byte_order,
float_class = g_new(struct type_class_float, 1);
float_class->p.name = g_quark_from_string(name);
float_class->p.alignment = alignment;
+ float_class->p.copy = float_copy;
+ float_class->p.free = _float_type_free;
float_class->mantissa_len = mantissa_len;
float_class->exp_len = exp_len;
float_class->byte_order = byte_order;
}
return float_class;
}
-
-void float_type_free(struct type_class_float *float_class)
-{
- g_free(float_class);
-}
}
}
+void integer_type_free(struct type_class_integer *int_class)
+{
+ g_free(int_class);
+}
+
+static void _integer_type_free(struct type_class *type_class)
+{
+ struct type_class_integer *int_class =
+ container_of(type_class, struct type_class_integer, p);
+ integer_type_free(int_class);
+}
+
struct type_class_integer *integer_type_new(const char *name,
size_t start_offset,
size_t len, int byte_order,
int_class->p.name = g_quark_from_string(name);
int_class->p.alignment = alignment;
int_class->p.copy = integer_copy;
+ int_class->p.free = _integer_type_free;
int_class->len = len;
int_class->byte_order = byte_order;
int_class->signedness = signedness;
}
return int_class;
}
-
-void integer_type_free(struct type_class_integer *int_class)
-{
- g_free(int_class);
-}
(gconstpointer) (unsigned long) qname)
}
+static void free_type(struct type_class *type_class)
+{
+ type_class->free(type_class);
+}
+
int ctf_register_type(struct type_class *type_class)
{
if (ctf_lookup_type_class(type_class->name))
int ctf_init_types(void)
{
type_classes = g_hash_table_new_full(g_direct_hash, g_direct_equal,
- NULL, g_free);
+ NULL, free_type);
if (!type_classes)
return -ENOMEM;
return 0;