summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaTemplateInstantiate.cpp
diff options
context:
space:
mode:
authorJohn McCall <rjmccall@apple.com>2010-04-29 00:35:03 +0000
committerJohn McCall <rjmccall@apple.com>2010-04-29 00:35:03 +0000
commit80e58cd3e942f821c0c78d43ce93f8ecc39e30ea (patch)
tree9ba86109427fa7501d2d137136636aa14f7b9b5e /clang/lib/Sema/SemaTemplateInstantiate.cpp
parentd17020676106cd77cd35d263c5549b605dad0225 (diff)
downloadbcm5719-llvm-80e58cd3e942f821c0c78d43ce93f8ecc39e30ea.tar.gz
bcm5719-llvm-80e58cd3e942f821c0c78d43ce93f8ecc39e30ea.zip
Properly switch into the declaring scope of a template when performing
template argument deduction or (more importantly) the final substitution required by such deduction. Makes access control magically work in these cases. Fixes PR6967. llvm-svn: 102572
Diffstat (limited to 'clang/lib/Sema/SemaTemplateInstantiate.cpp')
-rw-r--r--clang/lib/Sema/SemaTemplateInstantiate.cpp5
1 files changed, 2 insertions, 3 deletions
diff --git a/clang/lib/Sema/SemaTemplateInstantiate.cpp b/clang/lib/Sema/SemaTemplateInstantiate.cpp
index 6fdf243d7bb..7dee0ad99bf 100644
--- a/clang/lib/Sema/SemaTemplateInstantiate.cpp
+++ b/clang/lib/Sema/SemaTemplateInstantiate.cpp
@@ -1167,8 +1167,7 @@ Sema::InstantiateClass(SourceLocation PointOfInstantiation,
// Enter the scope of this instantiation. We don't use
// PushDeclContext because we don't have a scope.
- DeclContext *PreviousContext = CurContext;
- CurContext = Instantiation;
+ ContextRAII SavedContext(*this, Instantiation);
// If this is an instantiation of a local class, merge this local
// instantiation scope with the enclosing scope. Otherwise, every
@@ -1209,7 +1208,7 @@ Sema::InstantiateClass(SourceLocation PointOfInstantiation,
Invalid = true;
// Exit the scope of this instantiation.
- CurContext = PreviousContext;
+ SavedContext.pop();
// If this is a polymorphic C++ class without a key function, we'll
// have to mark all of the virtual members to allow emission of a vtable
OpenPOWER on IntegriCloud