+
+void ir_print_type(char *buffer, size_t buffer_size, const ir_type *type)
+{
+ ident *id;
+ int p;
+ type_dbg_info *tdbgi = get_type_dbg_info(type);
+ if (tdbgi != NULL) {
+ ir_retrieve_type_dbg_info(buffer, buffer_size, tdbgi);
+ return;
+ }
+
+ /* we have to construct some name... */
+ switch (get_type_tpop_code(type)) {
+ case tpo_uninitialized:
+ break;
+ case tpo_code:
+ snprintf(buffer, buffer_size, "code");
+ return;
+
+ case tpo_class:
+ id = get_class_ident(type);
+ snprintf(buffer, buffer_size, "class '%s'", get_id_str(id));
+ return;
+
+ case tpo_struct:
+ id = get_struct_ident(type);
+ snprintf(buffer, buffer_size, "struct '%s'", get_id_str(id));
+ return;
+
+ case tpo_union:
+ id = get_union_ident(type);
+ snprintf(buffer, buffer_size, "union '%s'", get_id_str(id));
+ return;
+
+ case tpo_enumeration:
+ id = get_enumeration_ident(type);
+ snprintf(buffer, buffer_size, "enumeration '%s'", get_id_str(id));
+ return;
+
+ case tpo_unknown:
+ snprintf(buffer, buffer_size, "unknown type");
+ return;
+
+ case tpo_pointer:
+ p = snprintf(buffer, buffer_size, "pointer to ");
+ buffer += p;
+ buffer_size -= p;
+ ir_print_type(buffer, buffer_size, get_pointer_points_to_type(type));
+ return;
+
+ case tpo_array:
+ p = snprintf(buffer, buffer_size, "array of ");
+ buffer += p;
+ buffer_size -= p;
+ ir_print_type(buffer, buffer_size, get_array_element_type(type));
+ return;
+
+ case tpo_primitive:
+ id = get_mode_ident(get_type_mode(type));
+ snprintf(buffer, buffer_size, "%s", get_id_str(id));
+ return;
+
+ case tpo_none:
+ snprintf(buffer, buffer_size, "none");
+ return;
+ case tpo_method:
+ /* TODO: we should print argument and return types here... */
+ snprintf(buffer, buffer_size, "method type");
+ return;
+ }
+ snprintf(buffer, buffer_size, "invalid type");
+}