diff options
author | Joel Brobecker <brobecker@gnat.com> | 2011-07-01 18:25:17 +0000 |
---|---|---|
committer | Joel Brobecker <brobecker@gnat.com> | 2011-07-01 18:25:17 +0000 |
commit | 18920c42269018b87630cab5d90ed7b323dbfd55 (patch) | |
tree | 2ec74f0260fb2958393f00d98094e9b1466f3dc6 /config-ml.in | |
parent | c90092fe9e8d9932f59c5927c67d83c231e47407 (diff) | |
download | gdb-18920c42269018b87630cab5d90ed7b323dbfd55.zip gdb-18920c42269018b87630cab5d90ed7b323dbfd55.tar.gz gdb-18920c42269018b87630cab5d90ed7b323dbfd55.tar.bz2 |
handle character-based enumeration typedefs
Consider the following type:
type Char_Enum_Type is ('A', 'B', 'C', 'D');
If the compiler generates a Char_Enum_Type typedef in the debugging
information, the debugger fails in the following case:
(gdb) p Char_Enum_Type'('B')
$1 = 66
For our type, the underlying value of 'B' is actually 1, not 66
(ASCII 'B'). We are failing this case because we were not handling
typedef to enum types before. This patch fixes this.
gdb/ChangeLog:
* ada-exp.y (convert_char_literal): Handle typedef types.
gdb/testsuite/ChangeLog:
* gdb.ada/char_enum: New testcase.
Diffstat (limited to 'config-ml.in')
0 files changed, 0 insertions, 0 deletions