annotate gcc/testsuite/g++.dg/inherit/thunk1.C @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 // { dg-do run { target arm*-*-* aarch64*-*-* i?86-*-* x86_64-*-* s390*-*-* alpha*-*-* ia64-*-* sparc*-*-* } }
kono
parents:
diff changeset
2 // { dg-skip-if "" { arm_thumb1_ok } }
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 #include <stdarg.h>
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 extern "C" void abort ();
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 struct A {
kono
parents:
diff changeset
9 virtual void f (int, ...) {}
kono
parents:
diff changeset
10 int i;
kono
parents:
diff changeset
11 };
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 struct B : virtual public A {
kono
parents:
diff changeset
14 };
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 struct C : public B {
kono
parents:
diff changeset
17 C ();
kono
parents:
diff changeset
18 virtual void f (int, ...);
kono
parents:
diff changeset
19 };
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 extern C* cp;
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 C::C () { cp = this; }
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 void C::f (int i, ...) {
kono
parents:
diff changeset
26 if (this != cp)
kono
parents:
diff changeset
27 abort ();
kono
parents:
diff changeset
28 va_list ap;
kono
parents:
diff changeset
29 if (i != 3)
kono
parents:
diff changeset
30 abort ();
kono
parents:
diff changeset
31 va_start (ap, i);
kono
parents:
diff changeset
32 if (va_arg (ap, int) != 7)
kono
parents:
diff changeset
33 abort ();
kono
parents:
diff changeset
34 va_end (ap);
kono
parents:
diff changeset
35 }
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 C* cp = new C;
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 int main ()
kono
parents:
diff changeset
40 {
kono
parents:
diff changeset
41 cp->f (3, 7);
kono
parents:
diff changeset
42 }