aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJason Merrill <jason@gcc.gnu.org>1999-01-04 06:55:40 -0500
committerJason Merrill <jason@gcc.gnu.org>1999-01-04 06:55:40 -0500
commit02275c91e6770dee4d1e354a050fef86d901dcc9 (patch)
tree6598316ce5c96bf7f53685226e5a63a1a6cee1d4 /gcc
parent8d7f862cfb3846ee764e9ec4fbe4fbb3d3ceaace (diff)
downloadgcc-02275c91e6770dee4d1e354a050fef86d901dcc9.zip
gcc-02275c91e6770dee4d1e354a050fef86d901dcc9.tar.gz
gcc-02275c91e6770dee4d1e354a050fef86d901dcc9.tar.bz2
new
From-SVN: r24482
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/g++.old-deja/g++.ext/bound1.C29
1 files changed, 29 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.old-deja/g++.ext/bound1.C b/gcc/testsuite/g++.old-deja/g++.ext/bound1.C
new file mode 100644
index 0000000..3b926a4
--- /dev/null
+++ b/gcc/testsuite/g++.old-deja/g++.ext/bound1.C
@@ -0,0 +1,29 @@
+// Testcase for cast of bound pointer to member function.
+// Special g++ Options: -Wno-pmf-conversions
+// Build don't link:
+
+struct A {
+ int f ();
+};
+
+typedef int (*fptr)(A *);
+typedef void* vptr;
+typedef int (A::*pmf)();
+
+int foo (A* ap, pmf fp, int A::* ip)
+{
+ fptr p;
+ vptr q;
+ A a;
+
+ p = (fptr)(ap->*fp);
+ p = (fptr)(ap->*fp);
+ p = (fptr)(ap->*(&A::f));
+ p = (fptr)(a.*fp);
+ p = (fptr)(a.*(&A::f));
+
+ q = (vptr)(ap->*fp);
+ q = (vptr)(ap->*(&A::f));
+ q = (vptr)(a.*fp);
+ q = (vptr)(a.*(&A::f));
+}