diff options
author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2008-11-09 23:41:00 +0000 |
---|---|---|
committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2008-11-09 23:41:00 +0000 |
commit | 5239304ff761b8b03eefb772bd5d830a9b9f1aea (patch) | |
tree | 53033fe5ea5d74e5ba0656a854938755a05018ef /test/SemaCXX/nested-name-spec.cpp | |
parent | 0f84a23cc542a76f97aee735cdf3ff948b149879 (diff) |
Introduce ScopedDecl::getLexicalDeclContext() which is different from ScopedDecl::getDeclContext() when there are nested-names.
e.g.:
namespace A {
void f(); // SemanticDC (getDeclContext) == LexicalDC (getLexicalDeclContext) == 'namespace A'
}
void A::f(); // SemanticDC == namespace 'A'
// LexicalDC == global namespace
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@58948 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/SemaCXX/nested-name-spec.cpp')
-rw-r--r-- | test/SemaCXX/nested-name-spec.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/test/SemaCXX/nested-name-spec.cpp b/test/SemaCXX/nested-name-spec.cpp index bbca04cd9a..cf0500dffe 100644 --- a/test/SemaCXX/nested-name-spec.cpp +++ b/test/SemaCXX/nested-name-spec.cpp @@ -42,6 +42,15 @@ struct A::C c2; struct S : public A::C {}; struct A::undef; // expected-error {{'undef' does not name a tag member in the specified scope}} +namespace A2 { + typedef int INT; + struct RC; +} + +struct A2::RC { + INT x; +}; + void f3() { N::x = 0; // expected-error {{use of undeclared identifier 'N'}} int N; |