summaryrefslogtreecommitdiff
path: root/gcc/testsuite/g++.old-deja/g++.mike/p1567.C
diff options
context:
space:
mode:
authorYamaArashi <shadow962@live.com>2016-01-06 01:47:28 -0800
committerYamaArashi <shadow962@live.com>2016-01-06 01:47:28 -0800
commitbe8b04496302184c6e8f04d6179f9c3afc50aeb6 (patch)
tree726e2468c0c07add773c0dbd86ab6386844259ae /gcc/testsuite/g++.old-deja/g++.mike/p1567.C
initial commit
Diffstat (limited to 'gcc/testsuite/g++.old-deja/g++.mike/p1567.C')
-rwxr-xr-xgcc/testsuite/g++.old-deja/g++.mike/p1567.C41
1 files changed, 41 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.old-deja/g++.mike/p1567.C b/gcc/testsuite/g++.old-deja/g++.mike/p1567.C
new file mode 100755
index 0000000..0b35bd9
--- /dev/null
+++ b/gcc/testsuite/g++.old-deja/g++.mike/p1567.C
@@ -0,0 +1,41 @@
+// GROUPS passed vtable
+extern "C" int printf (const char *, ...);
+extern "C" void exit(int);
+
+class A {
+public:
+ virtual const char* f1() { return "A::f1"; }
+ virtual const char* f2() { return "A::f2"; }
+ virtual const char* f3() { printf("FAIL\n"); exit(1); return "A::f3"; }
+};
+
+class B {
+public:
+ virtual const char* f2() { return "B::f2"; }
+ virtual const char* f3() { return "B::f3"; }
+};
+
+class C: public A, public B {
+public:
+ const char* f2() { return B::f2(); }
+ const char* f1() { return f2(); }
+ const char* f3() { return A::f3(); }
+};
+
+class D: public A, public B {
+public:
+ const char* f2() { return B::f2(); }
+ const char* f1() { return D :: f2(); }
+ const char* f3() { return A::f3(); }
+};
+
+int main() {
+ C* tempC = new C;
+ D* tempD = new D;
+ A* a = tempC;
+ printf("calling f1 on a C gives %s\n", a->f1());
+ a = tempD;
+ printf("calling f1 on a D gives %s\n", a->f1());
+ printf("PASS\n");
+ return 0;
+}