diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-05-28 16:34:51 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-05-28 16:34:51 +0000 |
commit | 9e927abc417973bb3d571c9f6c72597f62ae34fc (patch) | |
tree | 1221db09e4e1777d20b4a51cb7fe89c1f57dacc7 /clang/lib/AST/DeclBase.cpp | |
parent | 335311c67a09feee64d640835a1f6f39fc7769a5 (diff) | |
download | bcm5719-llvm-9e927abc417973bb3d571c9f6c72597f62ae34fc.tar.gz bcm5719-llvm-9e927abc417973bb3d571c9f6c72597f62ae34fc.zip |
Introduced DeclContext::isDependentContext, which determines whether a
given DeclContext is dependent on type parameters. Use this to
properly determine whether a TagDecl is dependent; previously, we were
missing the case where the TagDecl is a local class of a member
function of a class template (phew!).
Also, make sure that, when we instantiate declarations within a member
function of a class template (or a function template, eventually),
that we add those declarations to the "instantiated locals" map so
that they can be found when instantiating declaration references.
Unfortunately, I was not able to write a useful test for this change,
although the assert() that fires when uncommenting the FIXME'd line in
test/SemaTemplate/instantiate-declref.cpp tells the "experienced user"
that we're now doing the right thing.
llvm-svn: 72526
Diffstat (limited to 'clang/lib/AST/DeclBase.cpp')
-rw-r--r-- | clang/lib/AST/DeclBase.cpp | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/clang/lib/AST/DeclBase.cpp b/clang/lib/AST/DeclBase.cpp index 071fb791013..ba8f3351c3a 100644 --- a/clang/lib/AST/DeclBase.cpp +++ b/clang/lib/AST/DeclBase.cpp @@ -396,6 +396,21 @@ void DeclContext::DestroyDecls(ASTContext &C) { (*D++)->Destroy(C); } +bool DeclContext::isDependentContext() const { + if (isFileContext()) + return false; + + if (const CXXRecordDecl *Record = dyn_cast<CXXRecordDecl>(this)) + if (Record->getDescribedClassTemplate()) + return true; + + if (const FunctionDecl *Function = dyn_cast<FunctionDecl>(this)) + if (Function->getDescribedFunctionTemplate()) + return true; + + return getParent() && getParent()->isDependentContext(); +} + bool DeclContext::isTransparentContext() const { if (DeclKind == Decl::Enum) return true; // FIXME: Check for C++0x scoped enums |