Add sequence
[babeltrace.git] / types / integer.c
index cf01f07a70fea8b45d0cdffcce9f45244ebcb5a2..7b2a3a97437f4053a3c70aad8a95d5601b89f060 100644 (file)
@@ -30,26 +30,32 @@ size_t integer_copy(unsigned char *dest, const struct format *fdest,
        struct type_class_integer *int_class =
                container_of(type_class, struct type_class_integer, p);
 
-       if (fsrc->p.alignment)
-               src = PTR_ALIGN(src, fsrc->p.alignment / CHAR_BIT);
-       if (fdest->p.alignment)
-               dest = PTR_ALIGN(dest, fdest->p.alignment / CHAR_BIT);
-
        if (!int_class->signedness) {
                uint64_t v;
 
-               v = fsrc->uint_read(src, int_class->len, int_class->byte_order);
-               return fdest->uint_write(dest, int_class->len, int_class->byte_order, v);
+               v = fsrc->uint_read(src, int_class);
+               return fdest->uint_write(dest, int_class, v);
        } else {
                int64_t v;
 
-               v = fsrc->int_read(src, int_class->len, int_class->byte_order);
-               return fdest->int_write(dest, int_class->len, int_class->byte_order, v);
+               v = fsrc->int_read(src, int_class);
+               return fdest->int_write(dest, int_class, v);
        }
 }
 
+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 signedness,
                                            size_t alignment)
@@ -61,11 +67,12 @@ struct type_class_integer *integer_type_new(const char *name,
        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;
        if (int_class->p.name) {
-               ret = ctf_register_type(&int_class.p);
+               ret = ctf_register_type(&int_class->p);
                if (ret) {
                        g_free(int_class);
                        return NULL;
@@ -73,8 +80,3 @@ struct type_class_integer *integer_type_new(const char *name,
        }
        return int_class;
 }
-
-void integer_type_free(struct type_class_integer *int_class)
-{
-       g_free(int_class);
-}
This page took 0.029911 seconds and 4 git commands to generate.