diff options
author | Daniel Jacobowitz <drow@false.org> | 2007-01-03 18:05:45 +0000 |
---|---|---|
committer | Daniel Jacobowitz <drow@false.org> | 2007-01-03 18:05:45 +0000 |
commit | 0d5de0100fd9c669790851af4f9f50704a24b453 (patch) | |
tree | f24fc195c586568deff26d6561c24cd65f1fd186 /gdb/testsuite | |
parent | 9d6063994fbb0f0ec4fb8005f18bc84768592368 (diff) | |
download | gdb-0d5de0100fd9c669790851af4f9f50704a24b453.zip gdb-0d5de0100fd9c669790851af4f9f50704a24b453.tar.gz gdb-0d5de0100fd9c669790851af4f9f50704a24b453.tar.bz2 |
* NEWS: Mention pointer to member improvements.
* Makefile.in (gnu-v3-abi.o): Delete special rule.
(eval.o, gnu-v3-abi.o, ia64-tdep.o): Update.
* ada-valprint.c (ada_print_scalar): Update for new type codes.
* c-typeprint.c (c_print_type): Update for new type codes.
(c_type_print_varspec_prefix, c_type_print_varspec_suffix)
(c_type_print_base): Likewise.
(c_type_print_args): Rewrite.
* c-valprint.c (c_val_print): Update for new type codes. Remove
support for references to members. Treat methods like functions.
* cp-abi.c (cplus_print_method_ptr, cplus_method_ptr_size)
(cplus_make_method_ptr, cplus_method_ptr_to_value): New.
* cp-abi.h (cplus_print_method_ptr, cplus_method_ptr_size)
(cplus_make_method_ptr, cplus_method_ptr_to_value): New prototypes.
(struct cp_abi_ops): Add corresponding members.
* cp-valprint.c (cp_print_class_method): Delete.
(cp_find_class_member): New function.
(cp_print_class_member): Use it. Simplify support for bogus
member pointers.
* dwarf2read.c (quirk_gcc_member_function_pointer): Use
lookup_methodptr_type.
(read_tag_ptr_to_member_type): Likewise, and lookup_memberptr_type.
* eval.c (evaluate_subexp_standard): Implement EVAL_SKIP for
OP_SCOPE. Update call to value_aggregate_elt. Rewrite member
pointer support.
(evaluate_subexp_for_address): Handle OP_SCOPE explicitly. Handle
references returned by user defined operators.
* f-typeprint.c (f_print_type, f_type_print_varspec_prefix)
(f_type_print_varspec_suffix): Remove support for member pointers.
* gdbtypes.c (lookup_memberptr_type): Renamed from lookup_member_type
and adjusted.
(smash_to_memberptr_type): Likewise, from smash_to_member_type.
(lookup_methodptr_type): New.
(rank_one_type): Adjust for TYPE_CODE_MEMBERPTR.
(recursive_dump_type): Update for new types.
* gdbtypes.h (enum type_code): Replace TYPE_CODE_MEMBER with
TYPE_CODE_MEMBERPTR and TYPE_CODE_METHODPTR.
(lookup_memberptr_type, lookup_methodptr_type)
(smash_to_memberptr_type): New prototypes.
(smash_to_method_type): Formatting fix.
(lookup_member_type, smash_to_member_type): Delete prototypes.
* gnu-v3-abi.c (gnuv3_get_vtable, gnuv3_get_virtual_fn): New.
Do not rely on debug information for the vptr or the method's
enclosing type. Handle function descriptors for IA64.
(gnuv3_virtual_fn_field): Rewrite using the new functions.
(gnuv3_find_method_in, gnuv3_print_method_ptr)
(gnuv3_method_ptr_size, gnuv3_make_method_ptr)
(gnuv3_method_ptr_to_value): New.
(init_gnuv3_ops): Set new members of gnu_v3_abi_ops.
* hpread.c (hpread_type_lookup): Update for new types.
* infcall.c (value_arg_coerce): Likewise.
* m2-typeprint.c (m2_print_type): Remove explicit support
for member pointers.
* m2-valprint.c (m2_val_print): Likewise.
* p-typeprint.c (pascal_type_print_varspec_prefix)
(pascal_type_print_varspec_suffix, pascal_type_print_base): Likewise.
* p-valprint.c (pascal_val_print): Likewise.
(pascal_object_print_class_method, pascal_object_print_class_member):
Delete.
* p-lang.h (pascal_object_print_class_method)
(pascal_object_print_class_member): Delete prototypes.
* stabsread.c (read_type): Update for new types.
* typeprint.c (print_type_scalar): Likewise.
* valops.c (value_struct_elt_for_reference, value_namespace_elt)
(value_maybe_namespace_elt, value_aggregate_elt): Add want_address
argument. Construct a pointer to member if the address of a
function or data member is requested.
(value_cast_pointers): Don't modify the input value.
(value_cast): Adjust pointer to member handling for new types.
Allow null pointer to member constants. Don't modify the input
value.
(value_ind): Remove pointer to member check. Handle function
descriptors for function pointers.
(value_struct_elt, value_find_oload_method_list, check_field):
Remove pointer to member checks.
* value.c (unpack_long): Allow pointers to data members.
(value_from_longest): Allow member pointers.
* value.h (value_aggregate_elt): Add want_address.
* varobj.c (c_variable_editable): Remove check for members.
* gdbarch.sh: Add vtable_function_descriptors and vbit_in_delta.
* ia64-tdep.c (ia64_convert_from_func_ptr_addr): Handle descriptors
in virtual tables.
(ia64_gdbarch_init): Call set_gdbarch_vtable_function_descriptors.
* c-lang.h (cp_print_class_method): Delete prototype.
* arm-tdep.c (arm_gdbarch_init): Call set_gdbarch_vbit_in_delta.
* mips-tdep.c (mips_gdbarch_init): Likewise.
* gdbarch.c, gdbarch.h: Regenerated.
* gdb.cp/classes.exp (test_pointers_to_class_members): Update expected
output. Test the types of members and member pointers.
* gdb.cp/inherit.exp (test_print_mi_member_types): Remove KFAILs for
gdb/2092.
* gdb.cp/member-ptr.exp: Search for a comment instead of a
statement. Enable for GCC. Update expected output for some tests
and add new tests. Remove obsolete GCC KFAILs. Allow GCC's class
layout.
* gdb.cp/member-ptr.cc (Padding, Padding::vspacer, Base, Base::get_x)
(Base::vget_base, Left, Left::vget, Right, Right::vget, Diamond)
(Diamond::vget_base): New.
(main): Add new tests.
* gdb.cp/printmethod.exp: Update expected output for member functions.
* gdb.cp/virtfunc.exp (test_virtual_calls): Add a KFAIL for
print pEe->D::vg().
Diffstat (limited to 'gdb/testsuite')
-rw-r--r-- | gdb/testsuite/ChangeLog | 18 | ||||
-rw-r--r-- | gdb/testsuite/gdb.cp/classes.exp | 9 | ||||
-rw-r--r-- | gdb/testsuite/gdb.cp/inherit.exp | 36 | ||||
-rw-r--r-- | gdb/testsuite/gdb.cp/member-ptr.cc | 100 | ||||
-rw-r--r-- | gdb/testsuite/gdb.cp/member-ptr.exp | 85 | ||||
-rw-r--r-- | gdb/testsuite/gdb.cp/printmethod.exp | 10 | ||||
-rw-r--r-- | gdb/testsuite/gdb.cp/virtfunc.exp | 11 |
7 files changed, 200 insertions, 69 deletions
diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog index dd8c387..57f8aa6 100644 --- a/gdb/testsuite/ChangeLog +++ b/gdb/testsuite/ChangeLog @@ -1,5 +1,23 @@ 2007-01-03 Daniel Jacobowitz <dan@codesourcery.com> + * gdb.cp/classes.exp (test_pointers_to_class_members): Update expected + output. Test the types of members and member pointers. + * gdb.cp/inherit.exp (test_print_mi_member_types): Remove KFAILs for + gdb/2092. + * gdb.cp/member-ptr.exp: Search for a comment instead of a + statement. Enable for GCC. Update expected output for some tests + and add new tests. Remove obsolete GCC KFAILs. Allow GCC's class + layout. + * gdb.cp/member-ptr.cc (Padding, Padding::vspacer, Base, Base::get_x) + (Base::vget_base, Left, Left::vget, Right, Right::vget, Diamond) + (Diamond::vget_base): New. + (main): Add new tests. + * gdb.cp/printmethod.exp: Update expected output for member functions. + * gdb.cp/virtfunc.exp (test_virtual_calls): Add a KFAIL for + print pEe->D::vg(). + +2007-01-03 Daniel Jacobowitz <dan@codesourcery.com> + * gdb.threads/tls.exp: Allow stops in sem_post. 2006-12-31 Daniel Jacobowitz <dan@codesourcery.com> diff --git a/gdb/testsuite/gdb.cp/classes.exp b/gdb/testsuite/gdb.cp/classes.exp index e072667..0f8592d 100644 --- a/gdb/testsuite/gdb.cp/classes.exp +++ b/gdb/testsuite/gdb.cp/classes.exp @@ -1,5 +1,5 @@ # Copyright 1992, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. +# 2003, 2004, 2006 Free Software Foundation, Inc. # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -498,11 +498,14 @@ proc test_enums {} { # Pointers to class members proc test_pointers_to_class_members {} { - gdb_test "print Bar::z" "\\$\[0-9\]+ = \\(int ?\\( ?Bar::& ?\\) ?\\) ?Bar::z" - gdb_test "print &Foo::x" "\\$\[0-9\]+ = \\(int ?\\( ?Foo::\\* ?\\) ?\\) ?&Foo::x" + gdb_test "print Bar::z" "Cannot reference non-static field \"z\"" + gdb_test "print &Foo::x" "\\$\[0-9\]+ = &Foo::x" gdb_test "print (int)&Foo::x" "\\$\[0-9\]+ = 0" gdb_test "print (int)&Bar::y == 2*sizeof(int)" "\\$\[0-9\]+ = true" + gdb_test "ptype Bar::z" "type = int" + gdb_test "ptype &Bar::z" "type = int Bar::\\*" + # TODO: this is a bogus test. It's looking at a variable that # has not even been declared yet, so it's accessing random junk # on the stack and comparing that it's NOT equal to a specific diff --git a/gdb/testsuite/gdb.cp/inherit.exp b/gdb/testsuite/gdb.cp/inherit.exp index 47a08ae..40433de 100644 --- a/gdb/testsuite/gdb.cp/inherit.exp +++ b/gdb/testsuite/gdb.cp/inherit.exp @@ -389,29 +389,19 @@ proc test_print_mi_member_types {} { # Print the types of qualified members; none of these tests pass today. # Print all members of g_A. - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_A.A::a" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_A.A::x" "type = int" # Print all members of g_B. - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_B.A::a" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_B.A::x" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_B.B::b" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_B.B::x" "type = int" # Print all members of g_C. - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_C.A::a" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_C.A::x" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_C.C::c" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_C.C::x" "type = int" # Print all members of g_D. @@ -423,9 +413,6 @@ proc test_print_mi_member_types {} { set name "ptype g_D.A::a" gdb_test_multiple "ptype g_D.A::a" $name { - -re "Attempt to take address of non-lval$nl$gdb_prompt $" { - kfail "gdb/2092" "$name" - } -re "type = int$nl$gdb_prompt $" { kfail "gdb/68" "ptype g_D.A::a" } @@ -433,25 +420,16 @@ proc test_print_mi_member_types {} { set name "ptype g_D.A::x" gdb_test_multiple "ptype g_D.A::x" $name { - -re "Attempt to take address of non-lval$nl$gdb_prompt $" { - kfail "gdb/2092" "$name" - } -re "type = int$nl$gdb_prompt $" { kfail "gdb/68" "ptype g_D.A::x" } } - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_D.B::b" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_D.B::x" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_D.C::c" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_D.C::x" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_D.D::d" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_D.D::x" "type = int" # Print all members of g_E. @@ -459,9 +437,6 @@ proc test_print_mi_member_types {} { set name "ptype g_E.A::a" gdb_test_multiple "ptype g_E.A::a" $name { - -re "Attempt to take address of non-lval$nl$gdb_prompt $" { - kfail "gdb/2092" "$name" - } -re "type = int$nl$gdb_prompt $" { kfail "gdb/68" "ptype g_E.A::a" } @@ -469,29 +444,18 @@ proc test_print_mi_member_types {} { set name "ptype g_E.A::x" gdb_test_multiple "ptype g_E.A::x" $name { - -re "Attempt to take address of non-lval$nl$gdb_prompt $" { - kfail "gdb/2092" "$name" - } -re "type = int$nl$gdb_prompt $" { kfail "gdb/68" "ptype g_E.A::x" } } - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_E.B::b" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_E.B::x" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_E.C::c" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_E.C::x" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_E.D::d" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_E.D::x" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_E.E::e" "type = int" - setup_kfail "gdb/2092" "*-*-*" gdb_test "ptype g_E.E::x" "type = int" } diff --git a/gdb/testsuite/gdb.cp/member-ptr.cc b/gdb/testsuite/gdb.cp/member-ptr.cc index e668c46..d93875b 100644 --- a/gdb/testsuite/gdb.cp/member-ptr.cc +++ b/gdb/testsuite/gdb.cp/member-ptr.cc @@ -1,6 +1,6 @@ /* This testcase is part of GDB, the GNU debugger. - Copyright 1998, 1999, 2004 Free Software Foundation, Inc. + Copyright 1998, 1999, 2004, 2006 Free Software Foundation, Inc. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -81,6 +81,69 @@ typedef int (A::*PMF)(int); typedef int A::*PMI; +/* This class is in front of the other base classes of Diamond, so + that we can detect if the offset for Left or the first Base is + added twice - otherwise it would be 2 * 0 == 0. */ +class Padding +{ + int spacer; + virtual int vspacer(); +}; + +int Padding::vspacer() +{ + return this->spacer; +} + +class Base +{ +public: + int x; + int get_x(); + virtual int vget_base (); +}; + +int Base::get_x () +{ + return this->x; +} + +int Base::vget_base () +{ + return this->x + 1000; +} + +class Left : public Base { +public: + virtual int vget (); +}; + +int Left::vget () +{ + return this->x + 100; +} + +class Right : public Base { +public: + virtual int vget (); +}; + +int Right::vget () +{ + return this->x + 200; +} + +class Diamond : public Padding, public Left, public Right +{ +public: + virtual int vget_base (); +}; + +int Diamond::vget_base () +{ + return this->Left::x + 2000; +} + int main () { A a; @@ -90,6 +153,18 @@ int main () PMF * pmf_p; PMI pmi; + Diamond diamond; + int (Diamond::*left_pmf) (); + int (Diamond::*right_pmf) (); + int (Diamond::*left_vpmf) (); + int (Diamond::*left_base_vpmf) (); + int (Diamond::*right_vpmf) (); + int (Base::*base_vpmf) (); + int Diamond::*diamond_pmi; + + PMI null_pmi; + PMF null_pmf; + a.j = 121; a.jj = 1331; @@ -101,8 +176,27 @@ int main () pmf = &A::bar; pmf_p = &pmf; - pmi = NULL; - + diamond.Left::x = 77; + diamond.Right::x = 88; + + /* Some valid pointer to members from a base class. */ + left_pmf = (int (Diamond::*) ()) (int (Left::*) ()) (&Base::get_x); + right_pmf = (int (Diamond::*) ()) (int (Right::*) ()) (&Base::get_x); + left_vpmf = &Left::vget; + left_base_vpmf = (int (Diamond::*) ()) (int (Left::*) ()) (&Base::vget_base); + right_vpmf = &Right::vget; + + /* An unspecified, value preserving pointer to member cast. */ + base_vpmf = (int (Base::*) ()) (int (Left::*) ()) &Diamond::vget_base; + + /* A pointer to data member from a base class. */ + diamond_pmi = (int Diamond::*) (int Left::*) &Base::x; + + null_pmi = NULL; + null_pmf = NULL; + + pmi = NULL; /* Breakpoint 1 here. */ + k = (a.*pmf)(3); pmi = &A::jj; diff --git a/gdb/testsuite/gdb.cp/member-ptr.exp b/gdb/testsuite/gdb.cp/member-ptr.exp index ee1d1ab..07a9767 100644 --- a/gdb/testsuite/gdb.cp/member-ptr.exp +++ b/gdb/testsuite/gdb.cp/member-ptr.exp @@ -1,4 +1,4 @@ -# Copyright 1998, 1999, 2003, 2004 Free Software Foundation, Inc. +# Copyright 1998, 1999, 2003, 2004, 2006 Free Software Foundation, Inc. # This file is part of the gdb testsuite @@ -20,8 +20,6 @@ # Written by Satish Pai <pai@apollo.hp.com> 1997-08-19 # Rewritten by Michael Chastain <mec.gnu@mindspring.com> 2004-01-11 -# TODO: copyright notice for member-ptr.cc - set vhn "\\$\[0-9\]+" if $tracelevel then { @@ -56,16 +54,9 @@ if ![runto_main] then { continue } -gdb_breakpoint [gdb_get_line_number "pmi = NULL"] +gdb_breakpoint [gdb_get_line_number "Breakpoint 1 here"] gdb_continue_to_breakpoint "continue to pmi = NULL" -# gcc is not ready for production -# -- chastain 2004-01-12 - -if { [test_compiler_info "gcc-*"] } { - continue -} - # ====================== # pointer to member data # ====================== @@ -74,14 +65,9 @@ if { [test_compiler_info "gcc-*"] } { set name "ptype pmi (A::j)" gdb_test_multiple "ptype pmi" $name { - -re "type = int *\\( ?A::\\*\\)\r\n$gdb_prompt $" { + -re "type = int A::\\*\r\n$gdb_prompt $" { pass $name } - -re "type = int *A::\r\n$gdb_prompt $" { - # gcc HEAD 2004-01-10 -gdwarf-2 - # gcc HEAD 2004-01-10 -gstabs+ - kfail "gdb/NNNN" $name - } } # print pointer to data member @@ -390,7 +376,7 @@ gdb_test_multiple "ptype *pmi" $name { set name "print (int) pmi" gdb_test_multiple "print (int) pmi" $name { - -re "$vhn = (4|8)\r\n$gdb_prompt" { + -re "$vhn = (4|8|12)\r\n$gdb_prompt" { pass $name } } @@ -412,7 +398,7 @@ gdb_test_multiple "print ((int) pmi) == ((char *) &a.j - (char *) & a)" $name { set name "ptype pmf" gdb_test_multiple "ptype pmf" $name { - -re "type = int \\( ?A::\\*\\)\\(int\\)\r\n$gdb_prompt $" { + -re "type = int \\( ?A::\\*\\)\\(A \\*, int\\)\r\n$gdb_prompt $" { pass $name } -re "type = int \\( ?A::\\*\\)\\(void\\)\r\n$gdb_prompt $" { @@ -434,7 +420,7 @@ gdb_test_multiple "ptype pmf" $name { set name "print pmf" gdb_test_multiple "print pmf" $name { - -re "$vhn = &A::bar\r\n$gdb_prompt $" { + -re "$vhn = $hex <A::bar\\(int\\)>\r\n$gdb_prompt $" { pass $name } -re "$vhn = .*not supported with HP aCC.*\r\n$gdb_prompt $" { @@ -456,7 +442,7 @@ gdb_test_multiple "print pmf" $name { set name "ptype pmf_p" gdb_test_multiple "ptype pmf_p" $name { - -re "type = int \\( ?A::\\*\\*\\)\\(int\\)\r\n$gdb_prompt $" { + -re "type = int \\( ?A::\\*\\*\\)\\(A \\*, int\\)\r\n$gdb_prompt $" { pass $name } -re "type = int \\( ?A::\\*\\*\\)\\(void\\)\r\n$gdb_prompt $" { @@ -498,7 +484,7 @@ gdb_test_multiple "print pmf_p" $name { set name "print a.*pmf" gdb_test_multiple "print a.*pmf" $name { - -re "$vhn = \\(int \\(\\*\\)\\(int\\)\\) $hex <A::bar\\(int\\)>\r\n$gdb_prompt$ " { + -re "$vhn = {int \\(A \\*, int\\)} $hex <A::bar\\(int\\)>\r\n$gdb_prompt $" { pass $name } -re "Pointers to methods not supported with HP aCC\r\n$gdb_prompt $" { @@ -520,7 +506,7 @@ gdb_test_multiple "print a.*pmf" $name { set name "print a_p->*pmf" gdb_test_multiple "print a_p->*pmf" $name { - -re "$vhn = \\(int \\(\\*\\)\\(int\\)\\) $hex <A::bar\\(int\\)>\r\n$gdb_prompt$ " { + -re "$vhn = {int \\(A \\*, int\\)} $hex <A::bar\\(int\\)>\r\n$gdb_prompt $" { pass $name } -re "Pointers to methods not supported with HP aCC\r\n$gdb_prompt $" { @@ -621,3 +607,56 @@ gdb_test_multiple "print (a.*pmf)(3)" $name { kfail "gdb/NNNN" $name } } + +# Print out a pointer to data member which requires looking into +# a base class. +gdb_test "print diamond_pmi" "$vhn = &Base::x" +gdb_test "print diamond.*diamond_pmi" "$vhn = 77" + +# Examine some more complicated pmfs, which require adjusting "this" +# and looking through virtual tables. + +# These two have a different object adjustment, but call the same method. +gdb_test "print diamond.*left_pmf" \ + "$vhn = {int \\(Diamond \\*\\)} $hex <Base::get_x\\((void|)\\)>" +gdb_test "print diamond.*right_pmf" \ + "$vhn = {int \\(Diamond \\*\\)} $hex <Base::get_x\\((void|)\\)>" + +gdb_test "print (diamond.*left_pmf) ()" "$vhn = 77" +gdb_test "print (diamond.*right_pmf) ()" "$vhn = 88" + +# These two point to different methods, although they have the same +# virtual table offsets. +gdb_test "print diamond.*left_vpmf" \ + "$vhn = {int \\(Diamond \\*\\)} $hex <Left::vget\\((void|)\\)>" +gdb_test "print diamond.*right_vpmf" \ + "$vhn = {int \\(Diamond \\*\\)} $hex <Right::vget\\((void|)\\)>" + +gdb_test "print (diamond.*left_vpmf) ()" "$vhn = 177" +gdb_test "print (diamond.*left_base_vpmf) ()" "$vhn = 2077" +gdb_test "print (diamond.*right_vpmf) ()" "$vhn = 288" + +# We should be able to figure out left_vpmf even without an object, +# because it comes from a non-virtual base. The same for right_vpmf. +gdb_test "print left_vpmf" "$vhn = &virtual Left::vget\\(\\)" +gdb_test "print right_vpmf" "$vhn = &virtual Right::vget\\(\\)" + +# But we should gracefully fail to figure out base_vpmf, because +# its runtime type is more derived than its static type. This +# is a valid but unspecified cast (it is value preserving, i.e. +# can be casted back to the correct type and used). +gdb_test "print base_vpmf" \ + "$vhn = &virtual table offset \[0-9\]*, this adjustment -\[0-9\]*" + +# Make sure we parse this correctly; it's invalid. +gdb_test "print diamond.*left_vpmf ()" \ + "Invalid data type for function to be called\\." + +# NULL pointer to member tests. +gdb_test "print null_pmi" "$vhn = NULL" +gdb_test "print null_pmi = &A::j" "$vhn = &A::j" +gdb_test "print null_pmi = 0" "$vhn = NULL" + +gdb_test "print null_pmf" "$vhn = NULL" +gdb_test "print null_pmf = &A::foo" "$vhn = $hex <A::foo ?\\(int\\)>" +gdb_test "print null_pmf = 0" "$vhn = NULL" diff --git a/gdb/testsuite/gdb.cp/printmethod.exp b/gdb/testsuite/gdb.cp/printmethod.exp index 8c7a9c0..0726956 100644 --- a/gdb/testsuite/gdb.cp/printmethod.exp +++ b/gdb/testsuite/gdb.cp/printmethod.exp @@ -1,4 +1,4 @@ -# Copyright 2002, 2003, 2005 Free Software Foundation, Inc. +# Copyright 2002, 2003, 2005, 2006 Free Software Foundation, Inc. # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -63,8 +63,12 @@ gdb_continue_to_breakpoint "end of constructors" # The first of these is for PR gdb/653. -gdb_test "print theA->virt" "\\$\[0-9\]* = &A::virt\\((void|)\\)" "print virtual method." -gdb_test "print theA->nonvirt" "\\$\[0-9\]* = &A::nonvirt\\((void|)\\)" "print nonvirtual method." +gdb_test "print theA->virt" \ + "\\$\[0-9\]* = {void \\(A \\*\\)} $hex <A::virt\\((void|)\\)>" \ + "print virtual method." +gdb_test "print theA->nonvirt" \ + "\\$\[0-9\]* = {void \\(A \\*\\)} $hex <A::nonvirt\\((void|)\\)>" \ + "print nonvirtual method." gdb_exit return 0 diff --git a/gdb/testsuite/gdb.cp/virtfunc.exp b/gdb/testsuite/gdb.cp/virtfunc.exp index 2da0763..a9c9c7b 100644 --- a/gdb/testsuite/gdb.cp/virtfunc.exp +++ b/gdb/testsuite/gdb.cp/virtfunc.exp @@ -1,4 +1,5 @@ -# Copyright 1992, 1994, 1995, 1996, 1997, 1998, 1999, 2001, 2002, 2003, 2004 +# Copyright 1992, 1994, 1995, 1996, 1997, 1998, 1999, 2001, 2002, 2003, 2004, +# 2006 # Free Software Foundation, Inc. # This program is free software; you can redistribute it and/or modify @@ -217,6 +218,14 @@ proc test_virtual_calls {} { -re "\\$\[0-9]+ = 102$nl$gdb_prompt $" { pass "print pEe->D::vg()" } + -re "\\$\[0-9]+ = 202$nl$gdb_prompt $" { + # To get this result, we have called pEe->*(&D::vg) (). + # That's how GDB interprets this, but it's wrong; in fact + # the explicit D:: means to bypass virtual function lookup, + # and call D::vg as if it were non-virtual. We still have + # to e.g. adjust "this", though. + kfail "gdb/1064" "print pEe->D::vg()" + } -re "Attempt to take address of value not located in memory.$nl$gdb_prompt $" { kfail "gdb/1064" "print pEe->D::vg()" } |