aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Mitchell <mmitchel@gcc.gnu.org>2000-03-22 17:25:56 +0000
committerMark Mitchell <mmitchel@gcc.gnu.org>2000-03-22 17:25:56 +0000
commit9ffccc97f575eae67b2db66bd18fbc98eb8fef48 (patch)
treea8c86ca804ed0791272f8ca7876757e80d87fce5
parentde76b467535988c00f9bc1bd97d9674ddfe84ed1 (diff)
downloadgcc-9ffccc97f575eae67b2db66bd18fbc98eb8fef48.zip
gcc-9ffccc97f575eae67b2db66bd18fbc98eb8fef48.tar.gz
gcc-9ffccc97f575eae67b2db66bd18fbc98eb8fef48.tar.bz2
New test case.
From-SVN: r32686
-rw-r--r--gcc/testsuite/g++.old-deja/g++.abi/primary.C72
1 files changed, 72 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.old-deja/g++.abi/primary.C b/gcc/testsuite/g++.old-deja/g++.abi/primary.C
new file mode 100644
index 0000000..3108fbd
--- /dev/null
+++ b/gcc/testsuite/g++.old-deja/g++.abi/primary.C
@@ -0,0 +1,72 @@
+// Test to see that primary bases are selected correctly.
+// Origin: Mark Mitchell <mark@codesourcery.com>
+
+#if defined (__GXX_ABI_VERSION) && __GXX_ABI_VERSION >= 100
+
+// S1 is a nearly-empty base.
+
+struct S1
+{
+ virtual void f ()
+ {
+ }
+};
+
+// S2 is a dynamic, but not nearly-empty, base.
+
+struct S2
+{
+ virtual void g ()
+ {
+ }
+
+ int i;
+};
+
+// S1 should be the primary base.
+
+struct T1 : public S1, public S2
+{
+};
+
+// S2 should be the primary base.
+
+struct T2 : public S2, public S1
+{
+};
+
+// S2 should be the primary base.
+
+struct T3 : virtual public S1, public S2
+{
+};
+
+// S1 should be the primary base.
+
+struct T4 : virtual public S1, virtual public S2
+{
+};
+
+// Check that Y is the primary base for X. Otherwise, return N.
+#define CHECK_PRIMARY_BASE(X, Y, N) \
+ { \
+ X x; \
+ if ((void*) &x != (void *) (Y*) (&x)) \
+ return N; \
+ }
+
+int main ()
+{
+ CHECK_PRIMARY_BASE (T1, S1, 1);
+ CHECK_PRIMARY_BASE (T2, S2, 2);
+ CHECK_PRIMARY_BASE (T3, S2, 3);
+ CHECK_PRIMARY_BASE (T4, S1, 4);
+}
+
+#else /* !(defined (__GXX_ABI_VERSION) && __GXX_ABI_VERSION >= 100) */
+
+int main ()
+{
+}
+
+#endif /* !(defined (__GXX_ABI_VERSION) && __GXX_ABI_VERSION >= 100) */