diff options
author | dim <dim@FreeBSD.org> | 2013-12-22 00:07:40 +0000 |
---|---|---|
committer | dim <dim@FreeBSD.org> | 2013-12-22 00:07:40 +0000 |
commit | 952eddef9aff85b1e92626e89baaf7a360e2ac85 (patch) | |
tree | df8df0b0067b381eab470a3b8f28d14a552a6340 /test/SemaTemplate/ms-lookup-template-base-classes.cpp | |
parent | ea266cad53e3d49771fa38103913d3ec7a166694 (diff) | |
download | FreeBSD-src-952eddef9aff85b1e92626e89baaf7a360e2ac85.zip FreeBSD-src-952eddef9aff85b1e92626e89baaf7a360e2ac85.tar.gz |
Vendor import of clang release_34 branch r197841 (effectively, 3.4 RC3):
https://llvm.org/svn/llvm-project/cfe/branches/release_34@197841
Diffstat (limited to 'test/SemaTemplate/ms-lookup-template-base-classes.cpp')
-rw-r--r-- | test/SemaTemplate/ms-lookup-template-base-classes.cpp | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/test/SemaTemplate/ms-lookup-template-base-classes.cpp b/test/SemaTemplate/ms-lookup-template-base-classes.cpp index cb1a7f5..72ce056 100644 --- a/test/SemaTemplate/ms-lookup-template-base-classes.cpp +++ b/test/SemaTemplate/ms-lookup-template-base-classes.cpp @@ -196,3 +196,43 @@ void f() { } } // namespace PR12701 + +namespace PR16014 { + +struct A { + int a; + static int sa; +}; +template <typename T> struct B : T { + int foo() { return a; } + int *bar() { return &a; } + int baz() { return T::a; } + int T::*qux() { return &T::a; } + static int T::*stuff() { return &T::a; } + static int stuff1() { return T::sa; } + static int *stuff2() { return &T::sa; } +}; + +template <typename T> struct C : T { + int foo() { return b; } // expected-error {{no member named 'b' in 'PR16014::C<PR16014::A>'}} + int *bar() { return &b; } // expected-error {{no member named 'b' in 'PR16014::C<PR16014::A>'}} + int baz() { return T::b; } // expected-error {{no member named 'b' in 'PR16014::A'}} + int T::*qux() { return &T::b; } // expected-error {{no member named 'b' in 'PR16014::A'}} + int T::*fuz() { return &U::a; } // expected-error {{use of undeclared identifier 'U'}} +}; + +template struct B<A>; +template struct C<A>; // expected-note-re 1+ {{in instantiation of member function 'PR16014::C<PR16014::A>::.*' requested here}} + +template <typename T> struct D : T { + struct Inner { + int foo() { + // FIXME: MSVC can find this in D's base T! Even worse, if ::sa exists, + // clang will use it instead. + return sa; // expected-error {{use of undeclared identifier 'sa'}} + } + }; +}; +template struct D<A>; + +} |