]> git.ipfire.org Git - thirdparty/gcc.git/blame - gcc/testsuite/g++.dg/ipa/pr63595.C
ICF is more strict about non-common function and var
[thirdparty/gcc.git] / gcc / testsuite / g++.dg / ipa / pr63595.C
CommitLineData
fd43cc59 1/* { dg-do compile } */
2/* { dg-options "-O2 -fdump-ipa-icf-details" } */
3
4template <int dim> class B;
5template <int, int dim> class TriaObjectAccessor;
6template <int, typename Accessor> class A;
7template <int dim> class TriaDimensionInfo {
8public:
9 typedef A<3, TriaObjectAccessor<2, 3> > raw_quad_iterator;
10 typedef A<3, B<3> > raw_hex_iterator;
11 typedef raw_hex_iterator raw_cell_iterator;
12};
13template <int dim> class Triangulation : public TriaDimensionInfo<1> {
14 public:
15 typedef typename TriaDimensionInfo<dim>::raw_quad_iterator raw_quad_iterator;
16 TriaDimensionInfo::raw_cell_iterator end() const;
17 raw_quad_iterator end_quad() const {
18 return raw_quad_iterator(const_cast<Triangulation *>(this), 0, 0);
19 }
20};
21template <int dim> class TriaAccessor {
22public:
23 typedef void AccessorData;
24 TriaAccessor(const Triangulation<dim> * = 0);
25 Triangulation<1> *tria;
26
27 int a, b, c;
28};
29template <int dim> class TriaObjectAccessor<2, dim> : public TriaAccessor<dim> {
30public:
31 typedef typename TriaAccessor<dim>::AccessorData AccessorData;
32 TriaObjectAccessor(const Triangulation<dim> * = 0);
33};
34template <int dim> class TriaObjectAccessor<3, dim> : public TriaAccessor<dim> {
35public:
36 typedef typename TriaAccessor<dim>::AccessorData AccessorData;
37 TriaObjectAccessor(const Triangulation<dim> * = 0);
38};
39template <int dim> class B : public TriaObjectAccessor<dim, dim> {
40public:
41 typedef typename TriaObjectAccessor<dim, dim>::AccessorData AccessorData;
42 B(const Triangulation<dim> * = 0);
43};
44template <int dim, typename Accessor> class A {
45public:
46 A(const A &);
47 A(const Triangulation<dim> *, int, int);
48 Accessor accessor;
49};
50template class Triangulation<3>;
51template <int dim, typename Accessor>
52A<dim, Accessor>::A(const Triangulation<dim> *, int, int) {}
53template <int dim>
54TriaAccessor<dim>::TriaAccessor(const Triangulation<dim> *)
55 : tria(), a(-1), b(-2), c(-3) {}
56template <int dim>
57TriaObjectAccessor<2, dim>::TriaObjectAccessor(const Triangulation<dim> *) {}
58template <int dim>
59TriaObjectAccessor<3, dim>::TriaObjectAccessor(const Triangulation<dim> *) {}
60template <int dim> B<dim>::B(const Triangulation<dim> *) {}
61template <>
62TriaDimensionInfo<3>::raw_cell_iterator Triangulation<3>::end() const {
63 return raw_hex_iterator(const_cast<Triangulation *>(this), 0, 0);
64}
65
66#pragma GCC optimize ("-O0")
67int main()
68{
69 Triangulation <3> t;
70 Triangulation<3>::raw_quad_iterator i1 = t.end_quad();
71 TriaDimensionInfo<3>::raw_cell_iterator i2 = t.end();
72
73 if(i2.accessor.c != -3)
74 return 1;
75
76 return 0;
77}
78
2f3662f2 79/* { dg-final { scan-ipa-dump "Equal symbols: 0" "icf" } } */
fd43cc59 80/* { dg-final { cleanup-ipa-dump "icf" } } */