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/SemaCXX/access.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/SemaCXX/access.cpp')
-rw-r--r-- | test/SemaCXX/access.cpp | 34 |
1 files changed, 32 insertions, 2 deletions
diff --git a/test/SemaCXX/access.cpp b/test/SemaCXX/access.cpp index 50f2eff..5ccd418 100644 --- a/test/SemaCXX/access.cpp +++ b/test/SemaCXX/access.cpp @@ -26,9 +26,11 @@ private: namespace test1 { class A { private: - class X; // expected-note {{previously declared 'private' here}} + class X; // expected-note {{previously declared 'private' here}} \ + // expected-note {{previous declaration is here}} public: - class X; // expected-error {{'X' redeclared with 'public' access}} + class X; // expected-error {{'X' redeclared with 'public' access}} \ + // expected-warning {{class member cannot be redeclared}} class X {}; }; } @@ -106,3 +108,31 @@ namespace PR15209 { } } } + +namespace PR7434 { + namespace comment0 { + template <typename T> struct X; + namespace N { + class Y { + template<typename T> friend struct X; + int t; // expected-note {{here}} + }; + } + template<typename T> struct X { + X() { (void)N::Y().t; } // expected-error {{private}} + }; + X<char> x; + } + namespace comment2 { + struct X; + namespace N { + class Y { + friend struct X; + int t; // expected-note {{here}} + }; + } + struct X { + X() { (void)N::Y().t; } // expected-error {{private}} + }; + } +} |