aboutsummaryrefslogtreecommitdiff
path: root/gdb/valprint.c
diff options
context:
space:
mode:
authorFred Fish <fnf@specifix.com>1991-10-24 10:58:41 +0000
committerFred Fish <fnf@specifix.com>1991-10-24 10:58:41 +0000
commite2aab0314f833f6b930a5aaae4a93024a41dc1a0 (patch)
tree336c705144e2c34e0ba98b3f177a3d61c7ce326c /gdb/valprint.c
parent020706804bcb9cc69cdafb2f959a4fd5ee557899 (diff)
downloadgdb-e2aab0314f833f6b930a5aaae4a93024a41dc1a0.zip
gdb-e2aab0314f833f6b930a5aaae4a93024a41dc1a0.tar.gz
gdb-e2aab0314f833f6b930a5aaae4a93024a41dc1a0.tar.bz2
Add three new builtin types (builtin_type_long_double, builtin_type_complex,
and builtin_type_double_complex). Also add and use various TARGET_<TYPE>_BIT macros to indicate the sizes of various types on the target machine.
Diffstat (limited to 'gdb/valprint.c')
-rw-r--r--gdb/valprint.c73
1 files changed, 42 insertions, 31 deletions
diff --git a/gdb/valprint.c b/gdb/valprint.c
index 246c66a..f893eda 100644
--- a/gdb/valprint.c
+++ b/gdb/valprint.c
@@ -1212,6 +1212,11 @@ val_print (type, valaddr, address, stream, format,
fprintf_filtered (stream, "?");
break;
+ case TYPE_CODE_RANGE:
+ /* FIXME, we should not ever have to print one of these yet. */
+ fprintf_filtered (stream, "<range type>");
+ break;
+
default:
error ("Invalid type code in symbol table.");
}
@@ -1599,7 +1604,7 @@ type_print_base (type, stream, show, level)
wrap_here (" ");
if (type == 0)
{
- fprintf_filtered (stream, "type unknown");
+ fprintf_filtered (stream, "<type unknown>");
return;
}
@@ -1813,14 +1818,19 @@ type_print_base (type, stream, show, level)
fprintf_filtered (stream, "void");
break;
- case 0:
- fprintf_filtered (stream, "struct unknown");
+ case TYPE_CODE_UNDEF:
+ fprintf_filtered (stream, "struct <unknown>");
break;
case TYPE_CODE_ERROR:
fprintf_filtered (stream, "<unknown type>");
break;
+ case TYPE_CODE_RANGE:
+ /* This should not occur */
+ fprintf_filtered (stream, "<range type>");
+ break;
+
default:
error ("Invalid type code in symbol table.");
}
@@ -2017,35 +2027,36 @@ _initialize_valprint ()
print_max = 200;
- /* FIXME! This assumes that these sizes and types are the same on the
- host and target machines! */
- unsigned_type_table
- = (char **) xmalloc ((1 + sizeof (unsigned LONGEST)) * sizeof (char *));
- bzero (unsigned_type_table, (1 + sizeof (unsigned LONGEST)));
- unsigned_type_table[sizeof (unsigned char)] = "unsigned char";
- unsigned_type_table[sizeof (unsigned short)] = "unsigned short";
- unsigned_type_table[sizeof (unsigned long)] = "unsigned long";
- unsigned_type_table[sizeof (unsigned int)] = "unsigned int";
-#ifdef LONG_LONG
- unsigned_type_table[TARGET_LONG_LONG_BIT/TARGET_CHAR_BIT] =
- "unsigned long long";
-#endif
-
- signed_type_table
- = (char **) xmalloc ((1 + sizeof (LONGEST)) * sizeof (char *));
- bzero (signed_type_table, (1 + sizeof (LONGEST)));
- signed_type_table[sizeof (char)] = "char";
- signed_type_table[sizeof (short)] = "short";
- signed_type_table[sizeof (long)] = "long";
- signed_type_table[sizeof (int)] = "int";
-#ifdef LONG_LONG
+ /* Initialize the names of the various types based on their lengths on
+ the target, in bits. Note that ordering is important, so that for example,
+ if ints and longs are the same size, that size will default to "int". */
+
+ unsigned_type_table = (char **)
+ xmalloc ((1 + (TARGET_LONG_LONG_BIT/TARGET_CHAR_BIT)) * sizeof (char *));
+ bzero (unsigned_type_table, (1 + (TARGET_LONG_LONG_BIT/TARGET_CHAR_BIT)));
+ unsigned_type_table[TARGET_CHAR_BIT/TARGET_CHAR_BIT] = "unsigned char";
+ unsigned_type_table[TARGET_SHORT_BIT/TARGET_CHAR_BIT] = "unsigned short";
+ unsigned_type_table[TARGET_LONG_LONG_BIT/TARGET_CHAR_BIT] = "unsigned long long";
+ unsigned_type_table[TARGET_LONG_BIT/TARGET_CHAR_BIT] = "unsigned long";
+ unsigned_type_table[TARGET_INT_BIT/TARGET_CHAR_BIT] = "unsigned int";
+
+ signed_type_table = (char **)
+ xmalloc ((1 + (TARGET_LONG_LONG_BIT/TARGET_CHAR_BIT)) * sizeof (char *));
+ bzero (signed_type_table, (1 + (TARGET_LONG_LONG_BIT/TARGET_CHAR_BIT)));
+ signed_type_table[TARGET_CHAR_BIT/TARGET_CHAR_BIT] = "char";
+ signed_type_table[TARGET_SHORT_BIT/TARGET_CHAR_BIT] = "short";
signed_type_table[TARGET_LONG_LONG_BIT/TARGET_CHAR_BIT] = "long long";
-#endif
+ signed_type_table[TARGET_LONG_BIT/TARGET_CHAR_BIT] = "long";
+ signed_type_table[TARGET_INT_BIT/TARGET_CHAR_BIT] = "int";
+
+ float_type_table = (char **)
+ xmalloc ((1 + (TARGET_LONG_DOUBLE_BIT/TARGET_CHAR_BIT)) * sizeof (char *));
+ bzero (float_type_table, (1 + (TARGET_LONG_DOUBLE_BIT/TARGET_CHAR_BIT)));
+ float_type_table[TARGET_FLOAT_BIT/TARGET_CHAR_BIT] = "float";
+ float_type_table[TARGET_DOUBLE_COMPLEX_BIT/TARGET_CHAR_BIT] = "double complex";
+ float_type_table[TARGET_COMPLEX_BIT/TARGET_CHAR_BIT] = "complex";
+ float_type_table[TARGET_LONG_DOUBLE_BIT/TARGET_CHAR_BIT] = "long double";
+ float_type_table[TARGET_DOUBLE_BIT/TARGET_CHAR_BIT] = "double";
- float_type_table
- = (char **) xmalloc ((1 + sizeof (double)) * sizeof (char *));
- bzero (float_type_table, (1 + sizeof (double)));
- float_type_table[sizeof (float)] = "float";
- float_type_table[sizeof (double)] = "double";
obstack_begin (&dont_print_obstack, 32 * sizeof (struct type *));
}