aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJason Merrill <jason@gcc.gnu.org>2001-01-02 15:14:57 -0500
committerJason Merrill <jason@gcc.gnu.org>2001-01-02 15:14:57 -0500
commitf941340f5a825b0320300e70ed828577d4b46260 (patch)
treea69e9d8adf91a6ada2c79350abe09cb07288efcb
parent96d6c6107ae89e779b41cca083c7c453f690bcc1 (diff)
downloadgcc-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.C26
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);
+}