aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoel Brobecker <brobecker@gnat.com>2007-12-24 06:29:27 +0000
committerJoel Brobecker <brobecker@gnat.com>2007-12-24 06:29:27 +0000
commit7b9f71f2886b62bb3c0e2b5df7cbcf1ff70d77b5 (patch)
tree9d652fc333bd358f666cbf265c5521d4cca2759f
parent5209009a1b5cd9e55c6289e4f958f771548e5dc8 (diff)
downloadgdb-7b9f71f2886b62bb3c0e2b5df7cbcf1ff70d77b5.zip
gdb-7b9f71f2886b62bb3c0e2b5df7cbcf1ff70d77b5.tar.gz
gdb-7b9f71f2886b62bb3c0e2b5df7cbcf1ff70d77b5.tar.bz2
* dwarf2read.c (read_base_type): Set code to TYPE_CODE_CHAR
for char and unsigned char types of Ada compilation units. * ada-lang.c (ada_is_character_type): Always return true if the type code is TYPE_CODE_CHAR.
-rw-r--r--gdb/ChangeLog7
-rw-r--r--gdb/ada-lang.c25
-rw-r--r--gdb/dwarf2read.c4
3 files changed, 25 insertions, 11 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index ba70631..716c12b 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,3 +1,10 @@
+2007-12-24 Joel Brobecker <brobecker@adacore.com>
+
+ * dwarf2read.c (read_base_type): Set code to TYPE_CODE_CHAR
+ for char and unsigned char types of Ada compilation units.
+ * ada-lang.c (ada_is_character_type): Always return true if
+ the type code is TYPE_CODE_CHAR.
+
2007-12-23 Joel Brobecker <brobecker@adacore.com>
* infrun.c (handle_inferior_event): Remove code that made us
diff --git a/gdb/ada-lang.c b/gdb/ada-lang.c
index d549662..83afdd7 100644
--- a/gdb/ada-lang.c
+++ b/gdb/ada-lang.c
@@ -7286,15 +7286,22 @@ value_val_atr (struct type *type, struct value *arg)
int
ada_is_character_type (struct type *type)
{
- const char *name = ada_type_name (type);
- return
- name != NULL
- && (TYPE_CODE (type) == TYPE_CODE_CHAR
- || TYPE_CODE (type) == TYPE_CODE_INT
- || TYPE_CODE (type) == TYPE_CODE_RANGE)
- && (strcmp (name, "character") == 0
- || strcmp (name, "wide_character") == 0
- || strcmp (name, "unsigned char") == 0);
+ const char *name;
+
+ /* If the type code says it's a character, then assume it really is,
+ and don't check any further. */
+ if (TYPE_CODE (type) == TYPE_CODE_CHAR)
+ return 1;
+
+ /* Otherwise, assume it's a character type iff it is a discrete type
+ with a known character type name. */
+ name = ada_type_name (type);
+ return (name != NULL
+ && (TYPE_CODE (type) == TYPE_CODE_INT
+ || TYPE_CODE (type) == TYPE_CODE_RANGE)
+ && (strcmp (name, "character") == 0
+ || strcmp (name, "wide_character") == 0
+ || strcmp (name, "unsigned char") == 0));
}
/* True if TYPE appears to be an Ada string type. */
diff --git a/gdb/dwarf2read.c b/gdb/dwarf2read.c
index 48f02dd..e47ef93 100644
--- a/gdb/dwarf2read.c
+++ b/gdb/dwarf2read.c
@@ -5007,11 +5007,11 @@ read_base_type (struct die_info *die, struct dwarf2_cu *cu)
type_flags |= TYPE_FLAG_UNSIGNED;
break;
case DW_ATE_signed_char:
- if (cu->language == language_m2)
+ if (cu->language == language_ada && cu->language == language_m2)
code = TYPE_CODE_CHAR;
break;
case DW_ATE_unsigned_char:
- if (cu->language == language_m2)
+ if (cu->language == language_ada && cu->language == language_m2)
code = TYPE_CODE_CHAR;
type_flags |= TYPE_FLAG_UNSIGNED;
break;