/* Copy of g++.dg/warn/Winfinite-recursion-2.C */ /* { dg-do compile { target c++11 } } */ namespace std { class type_info { public: void k() const; }; } // namespace std using std::type_info; template struct f { static constexpr int c = a; }; struct h { typedef int e; }; template struct m; template struct m : m {}; template struct m : f {}; template struct n; template struct n : n {}; template struct n<0, j, ac...> : h {}; template class F { template struct I : m<0, i, l...> {}; template struct s : n {}; static const type_info *const b[]; struct G { template operator ag() const { return *this; /* { dg-warning "-Wanalyzer-infinite-recursion" } */ } }; unsigned o; G ah; public: F(); long t() const { return o; } const type_info &m_fn3() const { return *b[o]; } template typename s::e *m_fn4() const { if (o != ab) return nullptr; return ah; } template void m_fn5() const { m_fn4(); const type_info &r = m_fn3(); r.k(); } template void u() const { m_fn5::c>(); } }; template const type_info *const F::b[] {&typeid(l)...}; using am = unsigned char; class H { enum bd : am { be = 2 }; using bf = F; bf ah; template void v() const { ah.u(); } void w() const; }; void H::w() const { bd d = bd(ah.t()); switch (d) case be: v(); }