X-Git-Url: http://git.efficios.com/?p=babeltrace.git;a=blobdiff_plain;f=formats%2Fctf%2Ftypes%2Fenum.c;h=15e2590ad6b2cb1c65e57857234eb91dfe1ba22f;hp=a1d034c38b79f39903e2a593e9aed3e1e68b31ee;hb=f66259163f060ada8d0fee348857c968e338ea40;hpb=ccd7e1c86f36342b0b06651cc52df86bb663c271 diff --git a/formats/ctf/types/enum.c b/formats/ctf/types/enum.c index a1d034c3..15e2590a 100644 --- a/formats/ctf/types/enum.c +++ b/formats/ctf/types/enum.c @@ -3,7 +3,7 @@ * * Enumeration mapping strings (quarks) from/to integers. * - * Copyright 2010 - Mathieu Desnoyers + * Copyright 2010, 2011 - Mathieu Desnoyers * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -20,39 +20,45 @@ #include #include -GQuark ctf_enum_read(struct stream_pos *pos, - const struct type_class_enum *src) +/* + * The caller should unref the GArray. + */ +GArray *ctf_enum_read(struct stream_pos *pos, + const struct declaration_enum *src) { - struct type_class_integer *int_class = &src->p; + const struct declaration_integer *integer_declaration = src->integer_declaration; - if (!int_class->signedness) { + if (!integer_declaration->signedness) { uint64_t v; - v = ctf_uint_read(pos, int_class); - return enum_uint_to_quark(src, v); + v = ctf_uint_read(pos, integer_declaration); + return enum_uint_to_quark_set(src, v); } else { int64_t v; - v = fsrc->ctf_int_read(pos, int_class); - return enum_int_to_quark(src, v); + v = ctf_int_read(pos, integer_declaration); + return enum_int_to_quark_set(src, v); } } -size_t ctf_enum_write(struct stream_pos *pos, - const struct type_class_enum *dest, - GQuark q) +/* + * Arbitrarily choose the start of the first matching range. + */ +void ctf_enum_write(struct stream_pos *pos, + const struct declaration_enum *dest, + GQuark q) { - struct type_class_integer *int_class = &dest->p; + const struct declaration_integer *integer_declaration = dest->integer_declaration; + GArray *array; - if (!int_class->signedness) { - uint64_t v; + array = enum_quark_to_range_set(dest, q); + assert(array); - v = enum_quark_to_uint(dest, q); - return ctf_uint_write(pos, int_class, v); + if (!integer_declaration->signedness) { + uint64_t v = g_array_index(array, struct enum_range, 0).start._unsigned; + ctf_uint_write(pos, integer_declaration, v); } else { - int64_t v; - - v = enum_quark_to_int(dest, q); - return ctf_int_write(pos, int_class, v); + int64_t v = g_array_index(array, struct enum_range, 0).start._unsigned; + ctf_int_write(pos, integer_declaration, v); } }