case SIDE_TYPE_S16:
case SIDE_TYPE_S32:
case SIDE_TYPE_S64:
- if (type_desc->u.side_integer.byte_order != SIDE_TYPE_BYTE_ORDER_HOST)
- return true;
- else
- return false;
- break;
case SIDE_TYPE_POINTER32:
case SIDE_TYPE_POINTER64:
if (type_desc->u.side_integer.byte_order != SIDE_TYPE_BYTE_ORDER_HOST)
printf("{ key%s \"%s\", value%s ", separator, attr->key, separator);
switch (attr->value.type) {
case SIDE_ATTR_TYPE_BOOL:
- printf("%s", attr->value.u.side_bool ? "true" : "false");
+ printf("%s", attr->value.u.bool_value ? "true" : "false");
break;
case SIDE_ATTR_TYPE_U8:
printf("%" PRIu8, attr->value.u.integer_value.side_u8);
abort();
#endif
case SIDE_ATTR_TYPE_STRING:
- printf("\"%s\"", (const char *)(uintptr_t) attr->value.u.string);
+ printf("\"%s\"", (const char *)(uintptr_t) attr->value.u.string_value);
break;
default:
fprintf(stderr, "ERROR: <UNKNOWN ATTRIBUTE TYPE>");
printf("{ ");
switch (type) {
+ case SIDE_TYPE_NULL:
+ tracer_print_type_header(":", type_desc->u.side_null.attr, type_desc->u.side_null.nr_attr);
+ printf("<NULL TYPE>");
+ break;
+
case SIDE_TYPE_BOOL:
- tracer_print_type_header(":", type_desc->u.side_basic.attr, type_desc->u.side_basic.nr_attr);
- printf("%s", item->u.side_bool ? "true" : "false");
+ tracer_print_type_header(":", type_desc->u.side_bool.attr, type_desc->u.side_bool.nr_attr);
+ printf("%s", item->u.bool_value ? "true" : "false");
break;
case SIDE_TYPE_U8:
break;
case SIDE_TYPE_BYTE:
- tracer_print_type_header(":", type_desc->u.side_basic.attr, type_desc->u.side_basic.nr_attr);
- printf("0x%" PRIx8, item->u.side_byte);
+ tracer_print_type_header(":", type_desc->u.side_byte.attr, type_desc->u.side_byte.nr_attr);
+ printf("0x%" PRIx8, item->u.byte_value);
break;
case SIDE_TYPE_ENUM:
break;
case SIDE_TYPE_STRING:
- tracer_print_type_header(":", type_desc->u.side_basic.attr, type_desc->u.side_basic.nr_attr);
- printf("\"%s\"", (const char *)(uintptr_t) item->u.string);
+ tracer_print_type_header(":", type_desc->u.side_string.attr, type_desc->u.side_string.nr_attr);
+ printf("\"%s\"", (const char *)(uintptr_t) item->u.string_value);
break;
case SIDE_TYPE_STRUCT:
tracer_print_struct(type_desc, item->u.side_struct);
tracer_print_vla_fixint(type_desc, item);
break;
case SIDE_TYPE_DYNAMIC:
- tracer_print_type_header(":", type_desc->u.side_basic.attr, type_desc->u.side_basic.nr_attr);
- tracer_print_dynamic(&item->u.dynamic);
+ tracer_print_type_header(":", type_desc->u.side_dynamic.attr, type_desc->u.side_dynamic.nr_attr);
+ tracer_print_dynamic(&item->u.dynamic_value);
break;
default:
fprintf(stderr, "<UNKNOWN TYPE>");
printf("{ ");
switch (sg_type->type) {
+ case SIDE_TYPE_SG_NULL:
+ tracer_print_type_header(":", sg_type->u.side_null.attr, sg_type->u.side_null.nr_attr);
+ printf("<NULL TYPE>");
+ break;
+
case SIDE_TYPE_SG_UNSIGNED_INT:
case SIDE_TYPE_SG_SIGNED_INT:
switch (sg_type->u.side_integer.type.integer_size_bits) {
default:
abort();
}
+ memcpy(&value, ptr + sg_type->offset, sg_type->u.side_integer.type.integer_size_bits >> 3);
+ tracer_print_type_integer(":", &sg_type->u.side_integer.type, &value,
+ sg_type->u.side_integer.offset_bits, TRACER_DISPLAY_BASE_10);
+ break;
+ default:
+ fprintf(stderr, "<UNKNOWN TYPE>");
+ abort();
}
- memcpy(&value, ptr + sg_type->offset, sg_type->u.side_integer.type.integer_size_bits >> 3);
- tracer_print_type_integer(":", &sg_type->u.side_integer.type, &value,
- sg_type->u.side_integer.offset_bits, TRACER_DISPLAY_BASE_10);
printf(" }");
}
sav_elem.u.integer_value.side_s64 = ((const int64_t *) p)[i];
break;
case SIDE_TYPE_BYTE:
- sav_elem.u.side_byte = ((const uint8_t *) p)[i];
+ sav_elem.u.byte_value = ((const uint8_t *) p)[i];
break;
case SIDE_TYPE_POINTER32:
sav_elem.u.integer_value.side_u32 = ((const uint32_t *) p)[i];
sav_elem.u.integer_value.side_s64 = ((const int64_t *) p)[i];
break;
case SIDE_TYPE_BYTE:
- sav_elem.u.side_byte = ((const uint8_t *) p)[i];
+ sav_elem.u.byte_value = ((const uint8_t *) p)[i];
break;
case SIDE_TYPE_POINTER32:
sav_elem.u.integer_value.side_u32 = ((const uint32_t *) p)[i];
printf("{ ");
switch (item->dynamic_type) {
case SIDE_DYNAMIC_TYPE_NULL:
- tracer_print_type_header("::", item->u.side_basic.attr, item->u.side_basic.nr_attr);
+ tracer_print_type_header("::", item->u.side_null.attr, item->u.side_null.nr_attr);
printf("<NULL TYPE>");
break;
case SIDE_DYNAMIC_TYPE_BOOL:
- tracer_print_type_header("::", item->u.side_basic.attr, item->u.side_basic.nr_attr);
- printf("%s", item->u.side_basic.u.side_bool ? "true" : "false");
+ tracer_print_type_header("::", item->u.side_bool.type.attr, item->u.side_bool.type.nr_attr);
+ printf("%s", item->u.side_bool.value ? "true" : "false");
break;
case SIDE_DYNAMIC_TYPE_U8:
case SIDE_DYNAMIC_TYPE_U16:
TRACER_DISPLAY_BASE_10);
break;
case SIDE_DYNAMIC_TYPE_BYTE:
- tracer_print_type_header("::", item->u.side_basic.attr, item->u.side_basic.nr_attr);
- printf("0x%" PRIx8, item->u.side_basic.u.side_byte);
+ tracer_print_type_header("::", item->u.side_byte.type.attr, item->u.side_byte.type.nr_attr);
+ printf("0x%" PRIx8, item->u.side_byte.value);
break;
case SIDE_DYNAMIC_TYPE_POINTER32:
break;
case SIDE_DYNAMIC_TYPE_STRING:
- tracer_print_type_header("::", item->u.side_basic.attr, item->u.side_basic.nr_attr);
- printf("\"%s\"", (const char *)(uintptr_t) item->u.side_basic.u.string);
+ tracer_print_type_header("::", item->u.side_string.type.attr, item->u.side_string.type.nr_attr);
+ printf("\"%s\"", (const char *)(uintptr_t) item->u.side_string.value);
break;
case SIDE_DYNAMIC_TYPE_STRUCT:
tracer_print_dynamic_struct(item->u.side_dynamic_struct);