diff options
author | Jason Merrill <jason@gcc.gnu.org> | 2001-01-02 15:14:57 -0500 |
---|---|---|
committer | Jason Merrill <jason@gcc.gnu.org> | 2001-01-02 15:14:57 -0500 |
commit | f941340f5a825b0320300e70ed828577d4b46260 (patch) | |
tree | a69e9d8adf91a6ada2c79350abe09cb07288efcb | |
parent | 96d6c6107ae89e779b41cca083c7c453f690bcc1 (diff) | |
download | gcc-f941340f5a825b0320300e70ed828577d4b46260.zip gcc-f941340f5a825b0320300e70ed828577d4b46260.tar.gz gcc-f941340f5a825b0320300e70ed828577d4b46260.tar.bz2 |
* typeck.c (build_binary_op): Fix pmf comparison logic.
From-SVN: r38637
-rw-r--r-- | gcc/testsuite/g++.old-deja/g++.other/pmf6.C | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.old-deja/g++.other/pmf6.C b/gcc/testsuite/g++.old-deja/g++.other/pmf6.C new file mode 100644 index 0000000..cb9da30 --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.other/pmf6.C @@ -0,0 +1,26 @@ +// Test that we only call f once and that pointers to different subobjects +// compare as different. + +struct A { void f() { } }; +struct B: public A { }; +struct C: public A { }; +struct D : public B, public C { }; + +typedef void (B::*bp)(); +typedef void (C::*cp)(); +typedef void (D::*dp)(); + +dp d1; + +int call; + +dp f () { ++call; return d1; } + +int main() +{ + bp b = &A::f; + cp c = &A::f; + d1 = b; + dp d2 = c; + return (f() == d2 || call != 1); +} |