Fix API : functions to access fields properties
[babeltrace.git] / types / integer.c
index 9e6df588f9764537a9969a0937274b941fa70aa8..808a4893680d3dc302a62d93f9b400299da9cffd 100644 (file)
@@ -21,6 +21,7 @@
 #include <babeltrace/compiler.h>
 #include <babeltrace/align.h>
 #include <babeltrace/format.h>
+#include <babeltrace/types.h>
 #include <stdint.h>
 
 static
@@ -42,7 +43,8 @@ void _integer_declaration_free(struct declaration *declaration)
 struct declaration_integer *
        integer_declaration_new(size_t len, int byte_order,
                         int signedness, size_t alignment, int base,
-                        enum ctf_string_encoding encoding)
+                        enum ctf_string_encoding encoding,
+                        struct ctf_clock *clock)
 {
        struct declaration_integer *integer_declaration;
 
@@ -58,6 +60,7 @@ struct declaration_integer *
        integer_declaration->signedness = signedness;
        integer_declaration->base = base;
        integer_declaration->encoding = encoding;
+       integer_declaration->clock = clock;
        return integer_declaration;
 }
 
@@ -104,7 +107,51 @@ void _integer_definition_free(struct definition *definition)
        g_free(integer);
 }
 
-uint64_t get_unsigned_int(struct definition *field)
+enum ctf_string_encoding get_int_encoding(const 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;
+
+       return integer_declaration->encoding;
+}
+
+int get_int_base(const 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;
+
+       return integer_declaration->base;
+}
+
+int get_int_byte_order(const 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;
+
+       return integer_declaration->byte_order;
+}
+
+int get_int_signedness(const 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;
+
+       return integer_declaration->signedness;
+}
+
+uint64_t get_unsigned_int(const struct definition *field)
 {
        struct definition_integer *integer_definition;
        const struct declaration_integer *integer_declaration;
@@ -119,7 +166,7 @@ uint64_t get_unsigned_int(struct definition *field)
        return (uint64_t)integer_definition->value._signed;
 }
 
-int64_t get_signed_int(struct definition *field)
+int64_t get_signed_int(const struct definition *field)
 {
        struct definition_integer *integer_definition;
        const struct declaration_integer *integer_declaration;
This page took 0.023528 seconds and 4 git commands to generate.