diff options
Diffstat (limited to 'clang/lib/Sema')
| -rw-r--r-- | clang/lib/Sema/SemaTemplateInstantiateDecl.cpp | 10 | 
1 files changed, 8 insertions, 2 deletions
| diff --git a/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp b/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp index e909c4f0b9b..e6be5389cd0 100644 --- a/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp +++ b/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp @@ -717,7 +717,10 @@ Decl *TemplateDeclInstantiator::VisitFunctionDecl(FunctionDecl *D,        return Info->Function;    } -  Sema::LocalInstantiationScope Scope(SemaRef, TemplateParams != 0); +  bool MergeWithParentScope = (TemplateParams != 0) || +    !(isa<Decl>(Owner) &&  +      cast<Decl>(Owner)->isDefinedOutsideFunctionOrMethod()); +  Sema::LocalInstantiationScope Scope(SemaRef, MergeWithParentScope);    llvm::SmallVector<ParmVarDecl *, 4> Params;    QualType T = SubstFunctionType(D, Params); @@ -844,7 +847,10 @@ TemplateDeclInstantiator::VisitCXXMethodDecl(CXXMethodDecl *D,        return Info->Function;    } -  Sema::LocalInstantiationScope Scope(SemaRef, TemplateParams != 0); +  bool MergeWithParentScope = (TemplateParams != 0) || +    !(isa<Decl>(Owner) &&  +      cast<Decl>(Owner)->isDefinedOutsideFunctionOrMethod()); +  Sema::LocalInstantiationScope Scope(SemaRef, MergeWithParentScope);    llvm::SmallVector<ParmVarDecl *, 4> Params;    QualType T = SubstFunctionType(D, Params); | 

