// RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 %s
struct global {
};
namespace PR10127 {
struct outer {
struct middle {
struct inner {
int func();
int i;
};
struct inner2 {
};
struct inner3 {
};
int mfunc();
};
typedef int td_int;
};
struct str {
operator decltype(outer::middle::inner()) ();
operator decltype(outer::middle())::inner2 ();
operator decltype(outer())::middle::inner3 ();
str(int (decltype(outer::middle::inner())::*n)(),
int (decltype(outer::middle())::inner::*o)(),
int (decltype(outer())::middle::inner::*p)());
};
decltype(outer::middle::inner()) a;
void scope() {
a.decltype(outer::middle())::mfunc(); // expected-error{{'PR10127::outer::middle::mfunc' is not a member of class 'decltype(outer::middle::inner())'}}
a.decltype(outer::middle::inner())::func();
a.decltype(outer::middle())::inner::func();
a.decltype(outer())::middle::inner::func();
a.decltype(outer())::middle::inner::~inner();
decltype(outer())::middle::inner().func();
}
decltype(outer::middle())::inner b;
decltype(outer())::middle::inner c;
decltype(outer())::fail d; // expected-error{{no type named 'fail' in 'PR10127::outer'}}
decltype(outer())::fail::inner e; // expected-error{{no member named 'fail' in 'PR10127::outer'}}
decltype()::fail f; // expected-error{{expected expression}}
decltype()::middle::fail g; // expected-error{{expected expression}}
decltype(int()) h;
decltype(int())::PR10127::outer i; // expected-error{{'decltype(int())' (aka 'int') is not a class, namespace, or scoped enumeration}}
decltype(int())::global j; // expected-error{{'decltype(int())' (aka 'int') is not a class, namespace, or scoped enumeration}}
outer::middle k = decltype(outer())::middle();
outer::middle::inner l = decltype(outer())::middle::inner();
template<typename T>
struct templ {
typename decltype(T())::middle::inner x; // expected-error{{type 'decltype(int())' (aka 'int') cannot be used prior to '::' because it has no members}}
};
template class templ<int>; // expected-note{{in instantiation of template class 'PR10127::templ<int>' requested here}}
template class templ<outer>;
enum class foo {
bar,
baz
};
foo m = decltype(foo::bar)::baz;
enum E {
};
struct bar {
enum E : decltype(outer())::td_int(4);
enum F : decltype(outer())::td_int;
enum G : decltype; // expected-error{{expected '(' after 'decltype'}}
};
}