X-Git-Url: http://git.efficios.com/?p=babeltrace.git;a=blobdiff_plain;f=types%2Finteger.c;h=808a4893680d3dc302a62d93f9b400299da9cffd;hp=59a6c1bb792c5a4aa1474cc4f0764c6e533320fb;hb=9ff2b8adeaadc0a8fbd8c5aa23f2cbadf2f1a55f;hpb=3122e6f075647374e7a98ae9501d100de8d004a9 diff --git a/types/integer.c b/types/integer.c index 59a6c1bb..808a4893 100644 --- a/types/integer.c +++ b/types/integer.c @@ -107,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; @@ -122,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;