diff options
author | John McCall <rjmccall@apple.com> | 2010-04-29 00:35:03 +0000 |
---|---|---|
committer | John McCall <rjmccall@apple.com> | 2010-04-29 00:35:03 +0000 |
commit | 80e58cd3e942f821c0c78d43ce93f8ecc39e30ea (patch) | |
tree | 9ba86109427fa7501d2d137136636aa14f7b9b5e /clang/lib/Sema/SemaTemplateInstantiate.cpp | |
parent | d17020676106cd77cd35d263c5549b605dad0225 (diff) | |
download | bcm5719-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.cpp | 5 |
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 |