annotate gcc/testsuite/g++.dg/torture/pr40323.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 /* Testcase for PR 40323. */
kono
parents:
diff changeset
2 /* { dg-do compile } */
kono
parents:
diff changeset
3 /* { dg-options "-fno-early-inlining" } */
kono
parents:
diff changeset
4 /* { dg-add-options bind_pic_locally } */
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 extern void do_something (const char *, int);
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 class Parent
kono
parents:
diff changeset
9 {
kono
parents:
diff changeset
10 private:
kono
parents:
diff changeset
11 const char *data;
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 public:
kono
parents:
diff changeset
14 Parent (const char *d) : data(d)
kono
parents:
diff changeset
15 {}
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 int funcOne (int delim) const;
kono
parents:
diff changeset
18 };
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 class AnotherParent
kono
parents:
diff changeset
21 {
kono
parents:
diff changeset
22 private:
kono
parents:
diff changeset
23 double d;
kono
parents:
diff changeset
24 public:
kono
parents:
diff changeset
25 AnotherParent (void) : d(0)
kono
parents:
diff changeset
26 {}
kono
parents:
diff changeset
27 };
kono
parents:
diff changeset
28
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 class Child : public AnotherParent, Parent
kono
parents:
diff changeset
31 {
kono
parents:
diff changeset
32 private:
kono
parents:
diff changeset
33 int zzz;
kono
parents:
diff changeset
34 public:
kono
parents:
diff changeset
35 Child (const char *d) : Parent(d)
kono
parents:
diff changeset
36 {}
kono
parents:
diff changeset
37 };
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 int Parent::funcOne (int delim) const
kono
parents:
diff changeset
41 {
kono
parents:
diff changeset
42 int i;
kono
parents:
diff changeset
43 for (i = 0; i < delim; i++)
kono
parents:
diff changeset
44 do_something(data, i);
kono
parents:
diff changeset
45
kono
parents:
diff changeset
46 return 1;
kono
parents:
diff changeset
47 }
kono
parents:
diff changeset
48
kono
parents:
diff changeset
49 int docalling (int (Child::* f)(int delim) const)
kono
parents:
diff changeset
50 {
kono
parents:
diff changeset
51 Child S ("muhehehe");
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 return (S.*f)(4);
kono
parents:
diff changeset
54 }
kono
parents:
diff changeset
55
kono
parents:
diff changeset
56 typedef int (Parent::* my_mp_type)(int delim);
kono
parents:
diff changeset
57
kono
parents:
diff changeset
58 int main (int argc, char *argv[])
kono
parents:
diff changeset
59 {
kono
parents:
diff changeset
60 int i;
kono
parents:
diff changeset
61 int (Parent::* f)(int ) const;
kono
parents:
diff changeset
62 int (Child::* g)(int ) const;
kono
parents:
diff changeset
63
kono
parents:
diff changeset
64 f = &Parent::funcOne;
kono
parents:
diff changeset
65 g = (int (Child::* )(int) const) f;
kono
parents:
diff changeset
66 i = docalling (g);
kono
parents:
diff changeset
67 return i;
kono
parents:
diff changeset
68 }