#include <stdio.h>
#include <inttypes.h>
#include <stdint.h>
+#include <babeltrace/bitfield.h>
int ctf_text_integer_write(struct stream_pos *ppos, struct definition *definition)
{
g_quark_to_string(definition->name));
switch (integer_declaration->base) {
+ case 0: /* default */
+ case 10:
+ if (!integer_declaration->signedness) {
+ fprintf(pos->fp, "%" PRIu64,
+ integer_definition->value._unsigned);
+ } else {
+ fprintf(pos->fp, "%" PRId64,
+ integer_definition->value._signed);
+ }
+ break;
case 2:
{
int bitnr;
- uint64_t v = integer_definition->value._unsigned;
+ uint64_t v;
+
+ if (!integer_declaration->signedness)
+ v = integer_definition->value._unsigned;
+ else
+ v = (uint64_t) integer_definition->value._signed;
fprintf(pos->fp, "b");
- for (bitnr = 0; bitnr < integer_declaration->len; bitnr++)
- v <<= 1;
- for (; bitnr < sizeof(v) * CHAR_BIT; bitnr++) {
- fprintf(pos->fp, "%u", ((v & 1ULL) << 63) ? 1 : 0);
- v <<= 1;
+ v = _bt_piecewise_lshift(v, 64 - integer_declaration->len);
+ for (bitnr = 0; bitnr < integer_declaration->len; bitnr++) {
+ fprintf(pos->fp, "%u", (v & (1ULL << 63)) ? 1 : 0);
+ v = _bt_piecewise_lshift(v, 1);
}
break;
}
case 8:
+ {
+ uint64_t v;
+
+ if (!integer_declaration->signedness)
+ v = integer_definition->value._unsigned;
+ else
+ v = (uint64_t) integer_definition->value._signed;
+
fprintf(pos->fp, "0%" PRIo64,
integer_definition->value._unsigned);
break;
- case 10:
- if (!integer_declaration->signedness) {
- fprintf(pos->fp, "%" PRIu64,
- integer_definition->value._unsigned);
- } else {
- fprintf(pos->fp, "%" PRId64,
- integer_definition->value._signed);
- }
- break;
+ }
case 16:
+ {
+ uint64_t v;
+
+ if (!integer_declaration->signedness)
+ v = integer_definition->value._unsigned;
+ else
+ v = (uint64_t) integer_definition->value._signed;
+
fprintf(pos->fp, "0x%" PRIX64,
integer_definition->value._unsigned);
break;
+ }
default:
return -EINVAL;
}
fprintf(fd, "[error] %s: cannot find typealias \"%s\".\n", __func__, g_quark_to_string(alias_q));
return NULL;
}
+ if (nested_declaration->id == CTF_TYPE_INTEGER) {
+ struct declaration_integer *integer_declaration =
+ container_of(nested_declaration, struct declaration_integer, p);
+ /* For base to 16 for pointers (expected pretty-print) */
+ if (!integer_declaration->base)
+ integer_declaration->base = 16;
+ }
} else {
nested_declaration = ctf_type_specifier_list_visit(fd, depth,
type_specifier_list, declaration_scope, trace);
int byte_order = trace->byte_order;
int signedness = 0;
int has_alignment = 0, has_size = 0;
- int base = 10;
+ int base = 0;
struct declaration_integer *integer_declaration;
cds_list_for_each_entry(expression, expressions, siblings) {