From: Fred Fish Date: Sat, 18 Feb 2006 20:01:17 +0000 (+0000) Subject: 2006-02-16 Fred Fish X-Git-Url: http://drtracing.org/?a=commitdiff_plain;h=f8261448b0d358daa49883a5c4b91a876010a3b1;p=deliverable%2Fbinutils-gdb.git 2006-02-16 Fred Fish * gdb.base/whatis.c: Define variables using typedefs char_addr, ushort_addr, and slong_addr, so the typedefs are not optimized away. * gdb.base/whatis.exp: Add tests using type name for struct type, union type, enum type, and typedef. --- diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog index dfcae4987d..ea33a482d9 100644 --- a/gdb/testsuite/ChangeLog +++ b/gdb/testsuite/ChangeLog @@ -1,3 +1,11 @@ +2006-02-16 Fred Fish + + * gdb.base/whatis.c: Define variables using typedefs char_addr, + ushort_addr, and slong_addr, so the typedefs are not optimized + away. + * gdb.base/whatis.exp: Add tests using type name for struct type, + union type, enum type, and typedef. + 2006-02-13 Mark Kettenis * gdb.arch/i386-prologue.exp: Add testcase for PR breakpoints/2080. diff --git a/gdb/testsuite/gdb.base/whatis.c b/gdb/testsuite/gdb.base/whatis.c index 7d4a647781..5b1319fd55 100644 --- a/gdb/testsuite/gdb.base/whatis.c +++ b/gdb/testsuite/gdb.base/whatis.c @@ -79,8 +79,11 @@ double v_double_array[2]; a special case kludge in GDB (Unix system include files like to define caddr_t), but for a variety of types. */ typedef char *char_addr; +static char_addr a_char_addr; typedef unsigned short *ushort_addr; +static ushort_addr a_ushort_addr; typedef signed long *slong_addr; +static slong_addr a_slong_addr; char *v_char_pointer; signed char *v_signed_char_pointer; diff --git a/gdb/testsuite/gdb.base/whatis.exp b/gdb/testsuite/gdb.base/whatis.exp index 9b41d6a2ff..fdc86f98d4 100644 --- a/gdb/testsuite/gdb.base/whatis.exp +++ b/gdb/testsuite/gdb.base/whatis.exp @@ -273,6 +273,10 @@ gdb_test "whatis v_struct1" \ "type = struct t_struct" \ "whatis named structure" +gdb_test "whatis struct t_struct" \ + "type = struct t_struct" \ + "whatis named structure using type name" + gdb_test "whatis v_struct2" \ "type = struct \{$unstruct\}" \ "whatis unnamed structure" @@ -283,6 +287,10 @@ gdb_test "whatis v_union" \ "type = union t_union" \ "whatis named union" +gdb_test "whatis union t_union" \ + "type = union t_union" \ + "whatis named union using type name" + gdb_test "whatis v_union2" \ "type = union \{$ununion\}" \ "whatis unnamed union" @@ -371,6 +379,10 @@ gdb_test "whatis clunker" \ "type = enum cars" \ "whatis enumeration" +gdb_test "whatis enum cars" \ + "type = enum cars" \ + "whatis enumeration using type name" + # test whatis command with nested struct and union gdb_test "whatis nested_su" \ @@ -402,3 +414,13 @@ gdb_test "whatis nested_su.inner_union_instance" \ gdb_test "whatis nested_su.inner_union_instance.inner_union_int" \ "type = int" \ "whatis inner union member" + +# test whatis command with typedefs + +gdb_test "whatis char_addr" \ + "type = char \\*" \ + "whatis using typedef type name" + +gdb_test "whatis a_char_addr" \ + "type = char_addr" \ + "whatis applied to variable defined by typedef"