gdb/m2-typeprint.c - gdb
Functions defined
Source code
- #include "defs.h"
- #include "gdb_obstack.h"
- #include "bfd.h"
- #include "symtab.h"
- #include "gdbtypes.h"
- #include "expression.h"
- #include "value.h"
- #include "gdbcore.h"
- #include "m2-lang.h"
- #include "target.h"
- #include "language.h"
- #include "demangle.h"
- #include "c-lang.h"
- #include "typeprint.h"
- #include "cp-abi.h"
- static void m2_print_bounds (struct type *type,
- struct ui_file *stream, int show, int level,
- int print_high);
- static void m2_typedef (struct type *, struct ui_file *, int, int,
- const struct type_print_options *);
- static void m2_array (struct type *, struct ui_file *, int, int,
- const struct type_print_options *);
- static void m2_pointer (struct type *, struct ui_file *, int, int,
- const struct type_print_options *);
- static void m2_ref (struct type *, struct ui_file *, int, int,
- const struct type_print_options *);
- static void m2_procedure (struct type *, struct ui_file *, int, int,
- const struct type_print_options *);
- static void m2_union (struct type *, struct ui_file *);
- static void m2_enum (struct type *, struct ui_file *, int, int);
- static void m2_range (struct type *, struct ui_file *, int, int,
- const struct type_print_options *);
- static void m2_type_name (struct type *type, struct ui_file *stream);
- static void m2_short_set (struct type *type, struct ui_file *stream,
- int show, int level);
- static int m2_long_set (struct type *type, struct ui_file *stream,
- int show, int level, const struct type_print_options *flags);
- static int m2_unbounded_array (struct type *type, struct ui_file *stream,
- int show, int level,
- const struct type_print_options *flags);
- static void m2_record_fields (struct type *type, struct ui_file *stream,
- int show, int level, const struct type_print_options *flags);
- static void m2_unknown (const char *s, struct type *type,
- struct ui_file *stream, int show, int level);
- int m2_is_long_set (struct type *type);
- int m2_is_long_set_of_type (struct type *type, struct type **of_type);
- int m2_is_unbounded_array (struct type *type);
- void
- m2_print_type (struct type *type, const char *varstring,
- struct ui_file *stream,
- int show, int level,
- const struct type_print_options *flags)
- {
- CHECK_TYPEDEF (type);
- QUIT;
- wrap_here (" ");
- if (type == NULL)
- {
- fputs_filtered (_("<type unknown>"), stream);
- return;
- }
- switch (TYPE_CODE (type))
- {
- case TYPE_CODE_SET:
- m2_short_set(type, stream, show, level);
- break;
- case TYPE_CODE_STRUCT:
- if (m2_long_set (type, stream, show, level, flags)
- || m2_unbounded_array (type, stream, show, level, flags))
- break;
- m2_record_fields (type, stream, show, level, flags);
- break;
- case TYPE_CODE_TYPEDEF:
- m2_typedef (type, stream, show, level, flags);
- break;
- case TYPE_CODE_ARRAY:
- m2_array (type, stream, show, level, flags);
- break;
- case TYPE_CODE_PTR:
- m2_pointer (type, stream, show, level, flags);
- break;
- case TYPE_CODE_REF:
- m2_ref (type, stream, show, level, flags);
- break;
- case TYPE_CODE_METHOD:
- m2_unknown (_("method"), type, stream, show, level);
- break;
- case TYPE_CODE_FUNC:
- m2_procedure (type, stream, show, level, flags);
- break;
- case TYPE_CODE_UNION:
- m2_union (type, stream);
- break;
- case TYPE_CODE_ENUM:
- m2_enum (type, stream, show, level);
- break;
- case TYPE_CODE_VOID:
- break;
- case TYPE_CODE_UNDEF:
-
- m2_unknown (_("undef"), type, stream, show, level);
- break;
- case TYPE_CODE_ERROR:
- m2_unknown (_("error"), type, stream, show, level);
- break;
- case TYPE_CODE_RANGE:
- m2_range (type, stream, show, level, flags);
- break;
- default:
- m2_type_name (type, stream);
- break;
- }
- }
- void
- m2_print_typedef (struct type *type, struct symbol *new_symbol,
- struct ui_file *stream)
- {
- CHECK_TYPEDEF (type);
- fprintf_filtered (stream, "TYPE ");
- if (!TYPE_NAME (SYMBOL_TYPE (new_symbol))
- || strcmp (TYPE_NAME ((SYMBOL_TYPE (new_symbol))),
- SYMBOL_LINKAGE_NAME (new_symbol)) != 0)
- fprintf_filtered (stream, "%s = ", SYMBOL_PRINT_NAME (new_symbol));
- else
- fprintf_filtered (stream, "<builtin> = ");
- type_print (type, "", stream, 0);
- fprintf_filtered (stream, ";\n");
- }
- void
- m2_type_name (struct type *type, struct ui_file *stream)
- {
- if (TYPE_NAME (type) != NULL)
- fputs_filtered (TYPE_NAME (type), stream);
- }
- void
- m2_range (struct type *type, struct ui_file *stream, int show,
- int level, const struct type_print_options *flags)
- {
- if (TYPE_HIGH_BOUND (type) == TYPE_LOW_BOUND (type))
- m2_print_type (TYPE_DOMAIN_TYPE (type), "", stream, show, level,
- flags);
- else
- {
- struct type *target = TYPE_TARGET_TYPE (type);
- fprintf_filtered (stream, "[");
- print_type_scalar (target, TYPE_LOW_BOUND (type), stream);
- fprintf_filtered (stream, "..");
- print_type_scalar (target, TYPE_HIGH_BOUND (type), stream);
- fprintf_filtered (stream, "]");
- }
- }
- static void
- m2_typedef (struct type *type, struct ui_file *stream, int show,
- int level, const struct type_print_options *flags)
- {
- if (TYPE_NAME (type) != NULL)
- {
- fputs_filtered (TYPE_NAME (type), stream);
- fputs_filtered (" = ", stream);
- }
- m2_print_type (TYPE_TARGET_TYPE (type), "", stream, show, level, flags);
- }
- static void m2_array (struct type *type, struct ui_file *stream,
- int show, int level, const struct type_print_options *flags)
- {
- fprintf_filtered (stream, "ARRAY [");
- if (TYPE_LENGTH (TYPE_TARGET_TYPE (type)) > 0
- && !TYPE_ARRAY_UPPER_BOUND_IS_UNDEFINED (type))
- {
- if (TYPE_INDEX_TYPE (type) != 0)
- {
- m2_print_bounds (TYPE_INDEX_TYPE (type), stream, show, -1, 0);
- fprintf_filtered (stream, "..");
- m2_print_bounds (TYPE_INDEX_TYPE (type), stream, show, -1, 1);
- }
- else
- fprintf_filtered (stream, "%d",
- (TYPE_LENGTH (type)
- / TYPE_LENGTH (TYPE_TARGET_TYPE (type))));
- }
- fprintf_filtered (stream, "] OF ");
- m2_print_type (TYPE_TARGET_TYPE (type), "", stream, show, level, flags);
- }
- static void
- m2_pointer (struct type *type, struct ui_file *stream, int show,
- int level, const struct type_print_options *flags)
- {
- if (TYPE_CONST (type))
- fprintf_filtered (stream, "[...] : ");
- else
- fprintf_filtered (stream, "POINTER TO ");
- m2_print_type (TYPE_TARGET_TYPE (type), "", stream, show, level, flags);
- }
- static void
- m2_ref (struct type *type, struct ui_file *stream, int show,
- int level, const struct type_print_options *flags)
- {
- fprintf_filtered (stream, "VAR");
- m2_print_type (TYPE_TARGET_TYPE (type), "", stream, show, level, flags);
- }
- static void
- m2_unknown (const char *s, struct type *type, struct ui_file *stream,
- int show, int level)
- {
- fprintf_filtered (stream, "%s %s", s, _("is unknown"));
- }
- static void m2_union (struct type *type, struct ui_file *stream)
- {
- fprintf_filtered (stream, "union");
- }
- static void
- m2_procedure (struct type *type, struct ui_file *stream,
- int show, int level, const struct type_print_options *flags)
- {
- fprintf_filtered (stream, "PROCEDURE ");
- m2_type_name (type, stream);
- if (TYPE_CODE (TYPE_TARGET_TYPE (type)) != TYPE_CODE_VOID)
- {
- int i, len = TYPE_NFIELDS (type);
- fprintf_filtered (stream, " (");
- for (i = 0; i < len; i++)
- {
- if (i > 0)
- {
- fputs_filtered (", ", stream);
- wrap_here (" ");
- }
- m2_print_type (TYPE_FIELD_TYPE (type, i), "", stream, -1, 0, flags);
- }
- if (TYPE_TARGET_TYPE (type) != NULL)
- {
- fprintf_filtered (stream, " : ");
- m2_print_type (TYPE_TARGET_TYPE (type), "", stream, 0, 0, flags);
- }
- }
- }
- static void
- m2_print_bounds (struct type *type,
- struct ui_file *stream, int show, int level,
- int print_high)
- {
- struct type *target = TYPE_TARGET_TYPE (type);
- if (TYPE_NFIELDS(type) == 0)
- return;
- if (print_high)
- print_type_scalar (target, TYPE_HIGH_BOUND (type), stream);
- else
- print_type_scalar (target, TYPE_LOW_BOUND (type), stream);
- }
- static void
- m2_short_set (struct type *type, struct ui_file *stream, int show, int level)
- {
- fprintf_filtered(stream, "SET [");
- m2_print_bounds (TYPE_INDEX_TYPE (type), stream,
- show - 1, level, 0);
- fprintf_filtered(stream, "..");
- m2_print_bounds (TYPE_INDEX_TYPE (type), stream,
- show - 1, level, 1);
- fprintf_filtered(stream, "]");
- }
- int
- m2_is_long_set (struct type *type)
- {
- LONGEST previous_high = 0;
- int len, i;
- struct type *range;
- if (TYPE_CODE (type) == TYPE_CODE_STRUCT)
- {
-
- len = TYPE_NFIELDS (type);
- for (i = TYPE_N_BASECLASSES (type); i < len; i++)
- {
- if (TYPE_FIELD_TYPE (type, i) == NULL)
- return 0;
- if (TYPE_CODE (TYPE_FIELD_TYPE (type, i)) != TYPE_CODE_SET)
- return 0;
- if (TYPE_FIELD_NAME (type, i) != NULL
- && (strcmp (TYPE_FIELD_NAME (type, i), "") != 0))
- return 0;
- range = TYPE_INDEX_TYPE (TYPE_FIELD_TYPE (type, i));
- if ((i > TYPE_N_BASECLASSES (type))
- && previous_high + 1 != TYPE_LOW_BOUND (range))
- return 0;
- previous_high = TYPE_HIGH_BOUND (range);
- }
- return len>0;
- }
- return 0;
- }
- static int
- m2_get_discrete_bounds (struct type *type, LONGEST *lowp, LONGEST *highp)
- {
- CHECK_TYPEDEF (type);
- switch (TYPE_CODE (type))
- {
- case TYPE_CODE_CHAR:
- if (TYPE_LENGTH (type) < sizeof (LONGEST))
- {
- if (!TYPE_UNSIGNED (type))
- {
- *lowp = -(1 << (TYPE_LENGTH (type) * TARGET_CHAR_BIT - 1));
- *highp = -*lowp - 1;
- return 0;
- }
- }
-
- default:
- return get_discrete_bounds (type, lowp, highp);
- }
- }
- int
- m2_is_long_set_of_type (struct type *type, struct type **of_type)
- {
- int len, i;
- struct type *range;
- struct type *target;
- LONGEST l1, l2;
- LONGEST h1, h2;
- if (TYPE_CODE (type) == TYPE_CODE_STRUCT)
- {
- len = TYPE_NFIELDS (type);
- i = TYPE_N_BASECLASSES (type);
- if (len == 0)
- return 0;
- range = TYPE_INDEX_TYPE (TYPE_FIELD_TYPE (type, i));
- target = TYPE_TARGET_TYPE (range);
- l1 = TYPE_LOW_BOUND (TYPE_INDEX_TYPE (TYPE_FIELD_TYPE (type, i)));
- h1 = TYPE_HIGH_BOUND (TYPE_INDEX_TYPE (TYPE_FIELD_TYPE (type, len-1)));
- *of_type = target;
- if (m2_get_discrete_bounds (target, &l2, &h2) >= 0)
- return (l1 == l2 && h1 == h2);
- error (_("long_set failed to find discrete bounds for its subtype"));
- return 0;
- }
- error (_("expecting long_set"));
- return 0;
- }
- static int
- m2_long_set (struct type *type, struct ui_file *stream, int show, int level,
- const struct type_print_options *flags)
- {
- struct type *of_type;
- int i;
- int len = TYPE_NFIELDS (type);
- LONGEST low;
- LONGEST high;
- if (m2_is_long_set (type))
- {
- if (TYPE_TAG_NAME (type) != NULL)
- {
- fputs_filtered (TYPE_TAG_NAME (type), stream);
- if (show == 0)
- return 1;
- }
- else if (TYPE_NAME (type) != NULL)
- {
- fputs_filtered (TYPE_NAME (type), stream);
- if (show == 0)
- return 1;
- }
- if (TYPE_TAG_NAME (type) != NULL || TYPE_NAME (type) != NULL)
- fputs_filtered (" = ", stream);
- if (get_long_set_bounds (type, &low, &high))
- {
- fprintf_filtered(stream, "SET OF ");
- i = TYPE_N_BASECLASSES (type);
- if (m2_is_long_set_of_type (type, &of_type))
- m2_print_type (of_type, "", stream, show - 1, level, flags);
- else
- {
- fprintf_filtered(stream, "[");
- m2_print_bounds (TYPE_INDEX_TYPE (TYPE_FIELD_TYPE (type, i)),
- stream, show - 1, level, 0);
- fprintf_filtered(stream, "..");
- m2_print_bounds (TYPE_INDEX_TYPE (TYPE_FIELD_TYPE (type, len-1)),
- stream, show - 1, level, 1);
- fprintf_filtered(stream, "]");
- }
- }
- else
-
- fprintf_filtered(stream, _("SET OF <unknown>"));
- return 1;
- }
- return 0;
- }
- int
- m2_is_unbounded_array (struct type *type)
- {
- if (TYPE_CODE (type) == TYPE_CODE_STRUCT)
- {
-
- if (TYPE_NFIELDS (type) != 2)
- return 0;
- if (strcmp (TYPE_FIELD_NAME (type, 0), "_m2_contents") != 0)
- return 0;
- if (strcmp (TYPE_FIELD_NAME (type, 1), "_m2_high") != 0)
- return 0;
- if (TYPE_CODE (TYPE_FIELD_TYPE (type, 0)) != TYPE_CODE_PTR)
- return 0;
- return 1;
- }
- return 0;
- }
- static int
- m2_unbounded_array (struct type *type, struct ui_file *stream, int show,
- int level, const struct type_print_options *flags)
- {
- if (m2_is_unbounded_array (type))
- {
- if (show > 0)
- {
- fputs_filtered ("ARRAY OF ", stream);
- m2_print_type (TYPE_TARGET_TYPE (TYPE_FIELD_TYPE (type, 0)),
- "", stream, 0, level, flags);
- }
- return 1;
- }
- return 0;
- }
- void
- m2_record_fields (struct type *type, struct ui_file *stream, int show,
- int level, const struct type_print_options *flags)
- {
-
- if (TYPE_TAG_NAME (type) != NULL)
- {
- if (strncmp (TYPE_TAG_NAME (type), "$$", 2) != 0)
- {
- fputs_filtered (TYPE_TAG_NAME (type), stream);
- if (show > 0)
- fprintf_filtered (stream, " = ");
- }
- }
- wrap_here (" ");
- if (show < 0)
- {
- if (TYPE_CODE (type) == TYPE_CODE_STRUCT)
- fprintf_filtered (stream, "RECORD ... END ");
- else if (TYPE_CODE (type) == TYPE_CODE_UNION)
- fprintf_filtered (stream, "CASE ... END ");
- }
- else if (show > 0)
- {
- int i;
- int len = TYPE_NFIELDS (type);
- if (TYPE_CODE (type) == TYPE_CODE_STRUCT)
- fprintf_filtered (stream, "RECORD\n");
- else if (TYPE_CODE (type) == TYPE_CODE_UNION)
-
- fprintf_filtered (stream, _("CASE <variant> OF\n"));
- for (i = TYPE_N_BASECLASSES (type); i < len; i++)
- {
- QUIT;
- print_spaces_filtered (level + 4, stream);
- fputs_filtered (TYPE_FIELD_NAME (type, i), stream);
- fputs_filtered (" : ", stream);
- m2_print_type (TYPE_FIELD_TYPE (type, i),
- "",
- stream, 0, level + 4, flags);
- if (TYPE_FIELD_PACKED (type, i))
- {
-
- fprintf_filtered (stream, " : %d",
- TYPE_FIELD_BITSIZE (type, i));
- }
- fprintf_filtered (stream, ";\n");
- }
- fprintfi_filtered (level, stream, "END ");
- }
- }
- void
- m2_enum (struct type *type, struct ui_file *stream, int show, int level)
- {
- LONGEST lastval;
- int i, len;
- if (show < 0)
- {
-
- if (TYPE_TAG_NAME (type) == NULL)
- fprintf_filtered (stream, "(...)");
- }
- else if (show > 0 || TYPE_TAG_NAME (type) == NULL)
- {
- fprintf_filtered (stream, "(");
- len = TYPE_NFIELDS (type);
- lastval = 0;
- for (i = 0; i < len; i++)
- {
- QUIT;
- if (i > 0)
- fprintf_filtered (stream, ", ");
- wrap_here (" ");
- fputs_filtered (TYPE_FIELD_NAME (type, i), stream);
- if (lastval != TYPE_FIELD_ENUMVAL (type, i))
- {
- fprintf_filtered (stream, " = %s",
- plongest (TYPE_FIELD_ENUMVAL (type, i)));
- lastval = TYPE_FIELD_ENUMVAL (type, i);
- }
- lastval++;
- }
- fprintf_filtered (stream, ")");
- }
- }