1 //===--- SemaTemplateInstantiateDecl.cpp - C++ Template Decl Instantiation ===/
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //===----------------------------------------------------------------------===/
8 //
9 //  This file implements C++ template instantiation for declarations.
10 //
11 //===----------------------------------------------------------------------===/
12 #include "clang/Sema/SemaInternal.h"
13 #include "clang/AST/ASTConsumer.h"
14 #include "clang/AST/ASTContext.h"
15 #include "clang/AST/ASTMutationListener.h"
16 #include "clang/AST/DeclTemplate.h"
17 #include "clang/AST/DeclVisitor.h"
18 #include "clang/AST/DependentDiagnostic.h"
19 #include "clang/AST/Expr.h"
20 #include "clang/AST/ExprCXX.h"
21 #include "clang/AST/TypeLoc.h"
22 #include "clang/Sema/Lookup.h"
23 #include "clang/Sema/PrettyDeclStackTrace.h"
24 #include "clang/Sema/Template.h"
25 
26 using namespace clang;
27 
28 static bool isDeclWithinFunction(const Decl *D) {
29   const DeclContext *DC = D->getDeclContext();
30   if (DC->isFunctionOrMethod())
31     return true;
32 
33   if (DC->isRecord())
34     return cast<CXXRecordDecl>(DC)->isLocalClass();
35 
36   return false;
37 }
38 
39 template<typename DeclT>
40 static bool SubstQualifier(Sema &SemaRef, const DeclT *OldDecl, DeclT *NewDecl,
41                            const MultiLevelTemplateArgumentList &TemplateArgs) {
42   if (!OldDecl->getQualifierLoc())
43     return false;
44 
45   assert((NewDecl->getFriendObjectKind() ||
46           !OldDecl->getLexicalDeclContext()->isDependentContext()) &&
47          "non-friend with qualified name defined in dependent context");
48   Sema::ContextRAII SavedContext(
49       SemaRef,
50       const_cast<DeclContext *>(NewDecl->getFriendObjectKind()
51                                     ? NewDecl->getLexicalDeclContext()
52                                     : OldDecl->getLexicalDeclContext()));
53 
54   NestedNameSpecifierLoc NewQualifierLoc
55       = SemaRef.SubstNestedNameSpecifierLoc(OldDecl->getQualifierLoc(),
56                                             TemplateArgs);
57 
58   if (!NewQualifierLoc)
59     return true;
60 
61   NewDecl->setQualifierInfo(NewQualifierLoc);
62   return false;
63 }
64 
65 bool TemplateDeclInstantiator::SubstQualifier(const DeclaratorDecl *OldDecl,
66                                               DeclaratorDecl *NewDecl) {
67   return ::SubstQualifier(SemaRef, OldDecl, NewDecl, TemplateArgs);
68 }
69 
70 bool TemplateDeclInstantiator::SubstQualifier(const TagDecl *OldDecl,
71                                               TagDecl *NewDecl) {
72   return ::SubstQualifier(SemaRef, OldDecl, NewDecl, TemplateArgs);
73 }
74 
75 // Include attribute instantiation code.
76 #include "clang/Sema/AttrTemplateInstantiate.inc"
77 
78 static void instantiateDependentAlignedAttr(
79     Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs,
80     const AlignedAttr *Aligned, Decl *New, bool IsPackExpansion) {
81   if (Aligned->isAlignmentExpr()) {
82     // The alignment expression is a constant expression.
83     EnterExpressionEvaluationContext Unevaluated(S, Sema::ConstantEvaluated);
84     ExprResult Result = S.SubstExpr(Aligned->getAlignmentExpr(), TemplateArgs);
85     if (!Result.isInvalid())
86       S.AddAlignedAttr(Aligned->getLocation(), New, Result.getAs<Expr>(),
87                        Aligned->getSpellingListIndex(), IsPackExpansion);
88   } else {
89     TypeSourceInfo *Result = S.SubstType(Aligned->getAlignmentType(),
90                                          TemplateArgs, Aligned->getLocation(),
91                                          DeclarationName());
92     if (Result)
93       S.AddAlignedAttr(Aligned->getLocation(), New, Result,
94                        Aligned->getSpellingListIndex(), IsPackExpansion);
95   }
96 }
97 
98 static void instantiateDependentAlignedAttr(
99     Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs,
100     const AlignedAttr *Aligned, Decl *New) {
101   if (!Aligned->isPackExpansion()) {
102     instantiateDependentAlignedAttr(S, TemplateArgs, Aligned, New, false);
103     return;
104   }
105 
106   SmallVector<UnexpandedParameterPack, 2> Unexpanded;
107   if (Aligned->isAlignmentExpr())
108     S.collectUnexpandedParameterPacks(Aligned->getAlignmentExpr(),
109                                       Unexpanded);
110   else
111     S.collectUnexpandedParameterPacks(Aligned->getAlignmentType()->getTypeLoc(),
112                                       Unexpanded);
113   assert(!Unexpanded.empty() && "Pack expansion without parameter packs?");
114 
115   // Determine whether we can expand this attribute pack yet.
116   bool Expand = true, RetainExpansion = false;
117   Optional<unsigned> NumExpansions;
118   // FIXME: Use the actual location of the ellipsis.
119   SourceLocation EllipsisLoc = Aligned->getLocation();
120   if (S.CheckParameterPacksForExpansion(EllipsisLoc, Aligned->getRange(),
121                                         Unexpanded, TemplateArgs, Expand,
122                                         RetainExpansion, NumExpansions))
123     return;
124 
125   if (!Expand) {
126     Sema::ArgumentPackSubstitutionIndexRAII SubstIndex(S, -1);
127     instantiateDependentAlignedAttr(S, TemplateArgs, Aligned, New, true);
128   } else {
129     for (unsigned I = 0; I != *NumExpansions; ++I) {
130       Sema::ArgumentPackSubstitutionIndexRAII SubstIndex(S, I);
131       instantiateDependentAlignedAttr(S, TemplateArgs, Aligned, New, false);
132     }
133   }
134 }
135 
136 static void instantiateDependentAssumeAlignedAttr(
137     Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs,
138     const AssumeAlignedAttr *Aligned, Decl *New) {
139   // The alignment expression is a constant expression.
140   EnterExpressionEvaluationContext Unevaluated(S, Sema::ConstantEvaluated);
141 
142   Expr *E, *OE = nullptr;
143   ExprResult Result = S.SubstExpr(Aligned->getAlignment(), TemplateArgs);
144   if (Result.isInvalid())
145     return;
146   E = Result.getAs<Expr>();
147 
148   if (Aligned->getOffset()) {
149     Result = S.SubstExpr(Aligned->getOffset(), TemplateArgs);
150     if (Result.isInvalid())
151       return;
152     OE = Result.getAs<Expr>();
153   }
154 
155   S.AddAssumeAlignedAttr(Aligned->getLocation(), New, E, OE,
156                          Aligned->getSpellingListIndex());
157 }
158 
159 static void instantiateDependentAlignValueAttr(
160     Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs,
161     const AlignValueAttr *Aligned, Decl *New) {
162   // The alignment expression is a constant expression.
163   EnterExpressionEvaluationContext Unevaluated(S, Sema::ConstantEvaluated);
164   ExprResult Result = S.SubstExpr(Aligned->getAlignment(), TemplateArgs);
165   if (!Result.isInvalid())
166     S.AddAlignValueAttr(Aligned->getLocation(), New, Result.getAs<Expr>(),
167                         Aligned->getSpellingListIndex());
168 }
169 
170 static void instantiateDependentEnableIfAttr(
171     Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs,
172     const EnableIfAttr *A, const Decl *Tmpl, Decl *New) {
173   Expr *Cond = nullptr;
174   {
175     EnterExpressionEvaluationContext Unevaluated(S, Sema::Unevaluated);
176     ExprResult Result = S.SubstExpr(A->getCond(), TemplateArgs);
177     if (Result.isInvalid())
178       return;
179     Cond = Result.getAs<Expr>();
180   }
181   if (A->getCond()->isTypeDependent() && !Cond->isTypeDependent()) {
182     ExprResult Converted = S.PerformContextuallyConvertToBool(Cond);
183     if (Converted.isInvalid())
184       return;
185     Cond = Converted.get();
186   }
187 
188   SmallVector<PartialDiagnosticAt, 8> Diags;
189   if (A->getCond()->isValueDependent() && !Cond->isValueDependent() &&
190       !Expr::isPotentialConstantExprUnevaluated(Cond, cast<FunctionDecl>(Tmpl),
191                                                 Diags)) {
192     S.Diag(A->getLocation(), diag::err_enable_if_never_constant_expr);
193     for (int I = 0, N = Diags.size(); I != N; ++I)
194       S.Diag(Diags[I].first, Diags[I].second);
195     return;
196   }
197 
198   EnableIfAttr *EIA = new (S.getASTContext())
199                         EnableIfAttr(A->getLocation(), S.getASTContext(), Cond,
200                                      A->getMessage(),
201                                      A->getSpellingListIndex());
202   New->addAttr(EIA);
203 }
204 
205 // Constructs and adds to New a new instance of CUDALaunchBoundsAttr using
206 // template A as the base and arguments from TemplateArgs.
207 static void instantiateDependentCUDALaunchBoundsAttr(
208     Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs,
209     const CUDALaunchBoundsAttr &Attr, Decl *New) {
210   // The alignment expression is a constant expression.
211   EnterExpressionEvaluationContext Unevaluated(S, Sema::ConstantEvaluated);
212 
213   ExprResult Result = S.SubstExpr(Attr.getMaxThreads(), TemplateArgs);
214   if (Result.isInvalid())
215     return;
216   Expr *MaxThreads = Result.getAs<Expr>();
217 
218   Expr *MinBlocks = nullptr;
219   if (Attr.getMinBlocks()) {
220     Result = S.SubstExpr(Attr.getMinBlocks(), TemplateArgs);
221     if (Result.isInvalid())
222       return;
223     MinBlocks = Result.getAs<Expr>();
224   }
225 
226   S.AddLaunchBoundsAttr(Attr.getLocation(), New, MaxThreads, MinBlocks,
227                         Attr.getSpellingListIndex());
228 }
229 
230 static void
231 instantiateDependentModeAttr(Sema &S,
232                              const MultiLevelTemplateArgumentList &TemplateArgs,
233                              const ModeAttr &Attr, Decl *New) {
234   S.AddModeAttr(Attr.getRange(), New, Attr.getMode(),
235                 Attr.getSpellingListIndex(), /*InInstantiation=*/true);
236 }
237 
238 /// Instantiation of 'declare simd' attribute and its arguments.
239 static void instantiateOMPDeclareSimdDeclAttr(
240     Sema &S, const MultiLevelTemplateArgumentList &TemplateArgs,
241     const OMPDeclareSimdDeclAttr &Attr, Decl *New) {
242   // Allow 'this' in clauses with varlists.
243   if (auto *FTD = dyn_cast<FunctionTemplateDecl>(New))
244     New = FTD->getTemplatedDecl();
245   auto *FD = cast<FunctionDecl>(New);
246   auto *ThisContext = dyn_cast_or_null<CXXRecordDecl>(FD->getDeclContext());
247   SmallVector<Expr *, 4> Uniforms, Aligneds, Alignments, Linears, Steps;
248   SmallVector<unsigned, 4> LinModifiers;
249 
250   auto &&Subst = [&](Expr *E) -> ExprResult {
251     if (auto *DRE = dyn_cast<DeclRefExpr>(E->IgnoreParenImpCasts()))
252       if (auto *PVD = dyn_cast<ParmVarDecl>(DRE->getDecl())) {
253         Sema::ContextRAII SavedContext(S, FD);
254         LocalInstantiationScope Local(S);
255         if (FD->getNumParams() > PVD->getFunctionScopeIndex())
256           Local.InstantiatedLocal(
257               PVD, FD->getParamDecl(PVD->getFunctionScopeIndex()));
258         return S.SubstExpr(E, TemplateArgs);
259       }
260     Sema::CXXThisScopeRAII ThisScope(S, ThisContext, /*TypeQuals=*/0,
261                                      FD->isCXXInstanceMember());
262     return S.SubstExpr(E, TemplateArgs);
263   };
264 
265   ExprResult Simdlen;
266   if (auto *E = Attr.getSimdlen())
267     Simdlen = Subst(E);
268 
269   if (Attr.uniforms_size() > 0) {
270     for(auto *E : Attr.uniforms()) {
271       ExprResult Inst = Subst(E);
272       if (Inst.isInvalid())
273         continue;
274       Uniforms.push_back(Inst.get());
275     }
276   }
277 
278   auto AI = Attr.alignments_begin();
279   for (auto *E : Attr.aligneds()) {
280     ExprResult Inst = Subst(E);
281     if (Inst.isInvalid())
282       continue;
283     Aligneds.push_back(Inst.get());
284     Inst = ExprEmpty();
285     if (*AI)
286       Inst = S.SubstExpr(*AI, TemplateArgs);
287     Alignments.push_back(Inst.get());
288     ++AI;
289   }
290 
291   auto SI = Attr.steps_begin();
292   for (auto *E : Attr.linears()) {
293     ExprResult Inst = Subst(E);
294     if (Inst.isInvalid())
295       continue;
296     Linears.push_back(Inst.get());
297     Inst = ExprEmpty();
298     if (*SI)
299       Inst = S.SubstExpr(*SI, TemplateArgs);
300     Steps.push_back(Inst.get());
301     ++SI;
302   }
303   LinModifiers.append(Attr.modifiers_begin(), Attr.modifiers_end());
304   (void)S.ActOnOpenMPDeclareSimdDirective(
305       S.ConvertDeclToDeclGroup(New), Attr.getBranchState(), Simdlen.get(),
306       Uniforms, Aligneds, Alignments, Linears, LinModifiers, Steps,
307       Attr.getRange());
308 }
309 
310 void Sema::InstantiateAttrs(const MultiLevelTemplateArgumentList &TemplateArgs,
311                             const Decl *Tmpl, Decl *New,
312                             LateInstantiatedAttrVec *LateAttrs,
313                             LocalInstantiationScope *OuterMostScope) {
314   for (const auto *TmplAttr : Tmpl->attrs()) {
315     // FIXME: This should be generalized to more than just the AlignedAttr.
316     const AlignedAttr *Aligned = dyn_cast<AlignedAttr>(TmplAttr);
317     if (Aligned && Aligned->isAlignmentDependent()) {
318       instantiateDependentAlignedAttr(*this, TemplateArgs, Aligned, New);
319       continue;
320     }
321 
322     const AssumeAlignedAttr *AssumeAligned = dyn_cast<AssumeAlignedAttr>(TmplAttr);
323     if (AssumeAligned) {
324       instantiateDependentAssumeAlignedAttr(*this, TemplateArgs, AssumeAligned, New);
325       continue;
326     }
327 
328     const AlignValueAttr *AlignValue = dyn_cast<AlignValueAttr>(TmplAttr);
329     if (AlignValue) {
330       instantiateDependentAlignValueAttr(*this, TemplateArgs, AlignValue, New);
331       continue;
332     }
333 
334     const EnableIfAttr *EnableIf = dyn_cast<EnableIfAttr>(TmplAttr);
335     if (EnableIf && EnableIf->getCond()->isValueDependent()) {
336       instantiateDependentEnableIfAttr(*this, TemplateArgs, EnableIf, Tmpl,
337                                        New);
338       continue;
339     }
340 
341     if (const CUDALaunchBoundsAttr *CUDALaunchBounds =
342             dyn_cast<CUDALaunchBoundsAttr>(TmplAttr)) {
343       instantiateDependentCUDALaunchBoundsAttr(*this, TemplateArgs,
344                                                *CUDALaunchBounds, New);
345       continue;
346     }
347 
348     if (const ModeAttr *Mode = dyn_cast<ModeAttr>(TmplAttr)) {
349       instantiateDependentModeAttr(*this, TemplateArgs, *Mode, New);
350       continue;
351     }
352 
353     if (const auto *OMPAttr = dyn_cast<OMPDeclareSimdDeclAttr>(TmplAttr)) {
354       instantiateOMPDeclareSimdDeclAttr(*this, TemplateArgs, *OMPAttr, New);
355       continue;
356     }
357 
358     // Existing DLL attribute on the instantiation takes precedence.
359     if (TmplAttr->getKind() == attr::DLLExport ||
360         TmplAttr->getKind() == attr::DLLImport) {
361       if (New->hasAttr<DLLExportAttr>() || New->hasAttr<DLLImportAttr>()) {
362         continue;
363       }
364     }
365 
366     if (auto ABIAttr = dyn_cast<ParameterABIAttr>(TmplAttr)) {
367       AddParameterABIAttr(ABIAttr->getRange(), New, ABIAttr->getABI(),
368                           ABIAttr->getSpellingListIndex());
369       continue;
370     }
371 
372     if (isa<NSConsumedAttr>(TmplAttr) || isa<CFConsumedAttr>(TmplAttr)) {
373       AddNSConsumedAttr(TmplAttr->getRange(), New,
374                         TmplAttr->getSpellingListIndex(),
375                         isa<NSConsumedAttr>(TmplAttr),
376                         /*template instantiation*/ true);
377       continue;
378     }
379 
380     assert(!TmplAttr->isPackExpansion());
381     if (TmplAttr->isLateParsed() && LateAttrs) {
382       // Late parsed attributes must be instantiated and attached after the
383       // enclosing class has been instantiated.  See Sema::InstantiateClass.
384       LocalInstantiationScope *Saved = nullptr;
385       if (CurrentInstantiationScope)
386         Saved = CurrentInstantiationScope->cloneScopes(OuterMostScope);
387       LateAttrs->push_back(LateInstantiatedAttribute(TmplAttr, Saved, New));
388     } else {
389       // Allow 'this' within late-parsed attributes.
390       NamedDecl *ND = dyn_cast<NamedDecl>(New);
391       CXXRecordDecl *ThisContext =
392           dyn_cast_or_null<CXXRecordDecl>(ND->getDeclContext());
393       CXXThisScopeRAII ThisScope(*this, ThisContext, /*TypeQuals*/0,
394                                  ND && ND->isCXXInstanceMember());
395 
396       Attr *NewAttr = sema::instantiateTemplateAttribute(TmplAttr, Context,
397                                                          *this, TemplateArgs);
398       if (NewAttr)
399         New->addAttr(NewAttr);
400     }
401   }
402 }
403 
404 /// Get the previous declaration of a declaration for the purposes of template
405 /// instantiation. If this finds a previous declaration, then the previous
406 /// declaration of the instantiation of D should be an instantiation of the
407 /// result of this function.
408 template<typename DeclT>
409 static DeclT *getPreviousDeclForInstantiation(DeclT *D) {
410   DeclT *Result = D->getPreviousDecl();
411 
412   // If the declaration is within a class, and the previous declaration was
413   // merged from a different definition of that class, then we don't have a
414   // previous declaration for the purpose of template instantiation.
415   if (Result && isa<CXXRecordDecl>(D->getDeclContext()) &&
416       D->getLexicalDeclContext() != Result->getLexicalDeclContext())
417     return nullptr;
418 
419   return Result;
420 }
421 
422 Decl *
423 TemplateDeclInstantiator::VisitTranslationUnitDecl(TranslationUnitDecl *D) {
424   llvm_unreachable("Translation units cannot be instantiated");
425 }
426 
427 Decl *
428 TemplateDeclInstantiator::VisitPragmaCommentDecl(PragmaCommentDecl *D) {
429   llvm_unreachable("pragma comment cannot be instantiated");
430 }
431 
432 Decl *TemplateDeclInstantiator::VisitPragmaDetectMismatchDecl(
433     PragmaDetectMismatchDecl *D) {
434   llvm_unreachable("pragma comment cannot be instantiated");
435 }
436 
437 Decl *
438 TemplateDeclInstantiator::VisitExternCContextDecl(ExternCContextDecl *D) {
439   llvm_unreachable("extern \"C\" context cannot be instantiated");
440 }
441 
442 Decl *
443 TemplateDeclInstantiator::VisitLabelDecl(LabelDecl *D) {
444   LabelDecl *Inst = LabelDecl::Create(SemaRef.Context, Owner, D->getLocation(),
445                                       D->getIdentifier());
446   Owner->addDecl(Inst);
447   return Inst;
448 }
449 
450 Decl *
451 TemplateDeclInstantiator::VisitNamespaceDecl(NamespaceDecl *D) {
452   llvm_unreachable("Namespaces cannot be instantiated");
453 }
454 
455 Decl *
456 TemplateDeclInstantiator::VisitNamespaceAliasDecl(NamespaceAliasDecl *D) {
457   NamespaceAliasDecl *Inst
458     = NamespaceAliasDecl::Create(SemaRef.Context, Owner,
459                                  D->getNamespaceLoc(),
460                                  D->getAliasLoc(),
461                                  D->getIdentifier(),
462                                  D->getQualifierLoc(),
463                                  D->getTargetNameLoc(),
464                                  D->getNamespace());
465   Owner->addDecl(Inst);
466   return Inst;
467 }
468 
469 Decl *TemplateDeclInstantiator::InstantiateTypedefNameDecl(TypedefNameDecl *D,
470                                                            bool IsTypeAlias) {
471   bool Invalid = false;
472   TypeSourceInfo *DI = D->getTypeSourceInfo();
473   if (DI->getType()->isInstantiationDependentType() ||
474       DI->getType()->isVariablyModifiedType()) {
475     DI = SemaRef.SubstType(DI, TemplateArgs,
476                            D->getLocation(), D->getDeclName());
477     if (!DI) {
478       Invalid = true;
479       DI = SemaRef.Context.getTrivialTypeSourceInfo(SemaRef.Context.IntTy);
480     }
481   } else {
482     SemaRef.MarkDeclarationsReferencedInType(D->getLocation(), DI->getType());
483   }
484 
485   // HACK: g++ has a bug where it gets the value kind of ?: wrong.
486   // libstdc++ relies upon this bug in its implementation of common_type.
487   // If we happen to be processing that implementation, fake up the g++ ?:
488   // semantics. See LWG issue 2141 for more information on the bug.
489   const DecltypeType *DT = DI->getType()->getAs<DecltypeType>();
490   CXXRecordDecl *RD = dyn_cast<CXXRecordDecl>(D->getDeclContext());
491   if (DT && RD && isa<ConditionalOperator>(DT->getUnderlyingExpr()) &&
492       DT->isReferenceType() &&
493       RD->getEnclosingNamespaceContext() == SemaRef.getStdNamespace() &&
494       RD->getIdentifier() && RD->getIdentifier()->isStr("common_type") &&
495       D->getIdentifier() && D->getIdentifier()->isStr("type") &&
496       SemaRef.getSourceManager().isInSystemHeader(D->getLocStart()))
497     // Fold it to the (non-reference) type which g++ would have produced.
498     DI = SemaRef.Context.getTrivialTypeSourceInfo(
499       DI->getType().getNonReferenceType());
500 
501   // Create the new typedef
502   TypedefNameDecl *Typedef;
503   if (IsTypeAlias)
504     Typedef = TypeAliasDecl::Create(SemaRef.Context, Owner, D->getLocStart(),
505                                     D->getLocation(), D->getIdentifier(), DI);
506   else
507     Typedef = TypedefDecl::Create(SemaRef.Context, Owner, D->getLocStart(),
508                                   D->getLocation(), D->getIdentifier(), DI);
509   if (Invalid)
510     Typedef->setInvalidDecl();
511 
512   // If the old typedef was the name for linkage purposes of an anonymous
513   // tag decl, re-establish that relationship for the new typedef.
514   if (const TagType *oldTagType = D->getUnderlyingType()->getAs<TagType>()) {
515     TagDecl *oldTag = oldTagType->getDecl();
516     if (oldTag->getTypedefNameForAnonDecl() == D && !Invalid) {
517       TagDecl *newTag = DI->getType()->castAs<TagType>()->getDecl();
518       assert(!newTag->hasNameForLinkage());
519       newTag->setTypedefNameForAnonDecl(Typedef);
520     }
521   }
522 
523   if (TypedefNameDecl *Prev = getPreviousDeclForInstantiation(D)) {
524     NamedDecl *InstPrev = SemaRef.FindInstantiatedDecl(D->getLocation(), Prev,
525                                                        TemplateArgs);
526     if (!InstPrev)
527       return nullptr;
528 
529     TypedefNameDecl *InstPrevTypedef = cast<TypedefNameDecl>(InstPrev);
530 
531     // If the typedef types are not identical, reject them.
532     SemaRef.isIncompatibleTypedef(InstPrevTypedef, Typedef);
533 
534     Typedef->setPreviousDecl(InstPrevTypedef);
535   }
536 
537   SemaRef.InstantiateAttrs(TemplateArgs, D, Typedef);
538 
539   Typedef->setAccess(D->getAccess());
540 
541   return Typedef;
542 }
543 
544 Decl *TemplateDeclInstantiator::VisitTypedefDecl(TypedefDecl *D) {
545   Decl *Typedef = InstantiateTypedefNameDecl(D, /*IsTypeAlias=*/false);
546   if (Typedef)
547     Owner->addDecl(Typedef);
548   return Typedef;
549 }
550 
551 Decl *TemplateDeclInstantiator::VisitTypeAliasDecl(TypeAliasDecl *D) {
552   Decl *Typedef = InstantiateTypedefNameDecl(D, /*IsTypeAlias=*/true);
553   if (Typedef)
554     Owner->addDecl(Typedef);
555   return Typedef;
556 }
557 
558 Decl *
559 TemplateDeclInstantiator::VisitTypeAliasTemplateDecl(TypeAliasTemplateDecl *D) {
560   // Create a local instantiation scope for this type alias template, which
561   // will contain the instantiations of the template parameters.
562   LocalInstantiationScope Scope(SemaRef);
563 
564   TemplateParameterList *TempParams = D->getTemplateParameters();
565   TemplateParameterList *InstParams = SubstTemplateParams(TempParams);
566   if (!InstParams)
567     return nullptr;
568 
569   TypeAliasDecl *Pattern = D->getTemplatedDecl();
570 
571   TypeAliasTemplateDecl *PrevAliasTemplate = nullptr;
572   if (getPreviousDeclForInstantiation<TypedefNameDecl>(Pattern)) {
573     DeclContext::lookup_result Found = Owner->lookup(Pattern->getDeclName());
574     if (!Found.empty()) {
575       PrevAliasTemplate = dyn_cast<TypeAliasTemplateDecl>(Found.front());
576     }
577   }
578 
579   TypeAliasDecl *AliasInst = cast_or_null<TypeAliasDecl>(
580     InstantiateTypedefNameDecl(Pattern, /*IsTypeAlias=*/true));
581   if (!AliasInst)
582     return nullptr;
583 
584   TypeAliasTemplateDecl *Inst
585     = TypeAliasTemplateDecl::Create(SemaRef.Context, Owner, D->getLocation(),
586                                     D->getDeclName(), InstParams, AliasInst);
587   AliasInst->setDescribedAliasTemplate(Inst);
588   if (PrevAliasTemplate)
589     Inst->setPreviousDecl(PrevAliasTemplate);
590 
591   Inst->setAccess(D->getAccess());
592 
593   if (!PrevAliasTemplate)
594     Inst->setInstantiatedFromMemberTemplate(D);
595 
596   Owner->addDecl(Inst);
597 
598   return Inst;
599 }
600 
601 Decl *TemplateDeclInstantiator::VisitVarDecl(VarDecl *D) {
602   return VisitVarDecl(D, /*InstantiatingVarTemplate=*/false);
603 }
604 
605 Decl *TemplateDeclInstantiator::VisitVarDecl(VarDecl *D,
606                                              bool InstantiatingVarTemplate) {
607 
608   // Do substitution on the type of the declaration
609   TypeSourceInfo *DI = SemaRef.SubstType(D->getTypeSourceInfo(),
610                                          TemplateArgs,
611                                          D->getTypeSpecStartLoc(),
612                                          D->getDeclName());
613   if (!DI)
614     return nullptr;
615 
616   if (DI->getType()->isFunctionType()) {
617     SemaRef.Diag(D->getLocation(), diag::err_variable_instantiates_to_function)
618       << D->isStaticDataMember() << DI->getType();
619     return nullptr;
620   }
621 
622   DeclContext *DC = Owner;
623   if (D->isLocalExternDecl())
624     SemaRef.adjustContextForLocalExternDecl(DC);
625 
626   // Build the instantiated declaration.
627   VarDecl *Var = VarDecl::Create(SemaRef.Context, DC, D->getInnerLocStart(),
628                                  D->getLocation(), D->getIdentifier(),
629                                  DI->getType(), DI, D->getStorageClass());
630 
631   // In ARC, infer 'retaining' for variables of retainable type.
632   if (SemaRef.getLangOpts().ObjCAutoRefCount &&
633       SemaRef.inferObjCARCLifetime(Var))
634     Var->setInvalidDecl();
635 
636   // Substitute the nested name specifier, if any.
637   if (SubstQualifier(D, Var))
638     return nullptr;
639 
640   SemaRef.BuildVariableInstantiation(Var, D, TemplateArgs, LateAttrs, Owner,
641                                      StartingScope, InstantiatingVarTemplate);
642 
643   if (D->isNRVOVariable()) {
644     QualType ReturnType = cast<FunctionDecl>(DC)->getReturnType();
645     if (SemaRef.isCopyElisionCandidate(ReturnType, Var, false))
646       Var->setNRVOVariable(true);
647   }
648 
649   Var->setImplicit(D->isImplicit());
650 
651   return Var;
652 }
653 
654 Decl *TemplateDeclInstantiator::VisitAccessSpecDecl(AccessSpecDecl *D) {
655   AccessSpecDecl* AD
656     = AccessSpecDecl::Create(SemaRef.Context, D->getAccess(), Owner,
657                              D->getAccessSpecifierLoc(), D->getColonLoc());
658   Owner->addHiddenDecl(AD);
659   return AD;
660 }
661 
662 Decl *TemplateDeclInstantiator::VisitFieldDecl(FieldDecl *D) {
663   bool Invalid = false;
664   TypeSourceInfo *DI = D->getTypeSourceInfo();
665   if (DI->getType()->isInstantiationDependentType() ||
666       DI->getType()->isVariablyModifiedType())  {
667     DI = SemaRef.SubstType(DI, TemplateArgs,
668                            D->getLocation(), D->getDeclName());
669     if (!DI) {
670       DI = D->getTypeSourceInfo();
671       Invalid = true;
672     } else if (DI->getType()->isFunctionType()) {
673       // C++ [temp.arg.type]p3:
674       //   If a declaration acquires a function type through a type
675       //   dependent on a template-parameter and this causes a
676       //   declaration that does not use the syntactic form of a
677       //   function declarator to have function type, the program is
678       //   ill-formed.
679       SemaRef.Diag(D->getLocation(), diag::err_field_instantiates_to_function)
680         << DI->getType();
681       Invalid = true;
682     }
683   } else {
684     SemaRef.MarkDeclarationsReferencedInType(D->getLocation(), DI->getType());
685   }
686 
687   Expr *BitWidth = D->getBitWidth();
688   if (Invalid)
689     BitWidth = nullptr;
690   else if (BitWidth) {
691     // The bit-width expression is a constant expression.
692     EnterExpressionEvaluationContext Unevaluated(SemaRef,
693                                                  Sema::ConstantEvaluated);
694 
695     ExprResult InstantiatedBitWidth
696       = SemaRef.SubstExpr(BitWidth, TemplateArgs);
697     if (InstantiatedBitWidth.isInvalid()) {
698       Invalid = true;
699       BitWidth = nullptr;
700     } else
701       BitWidth = InstantiatedBitWidth.getAs<Expr>();
702   }
703 
704   FieldDecl *Field = SemaRef.CheckFieldDecl(D->getDeclName(),
705                                             DI->getType(), DI,
706                                             cast<RecordDecl>(Owner),
707                                             D->getLocation(),
708                                             D->isMutable(),
709                                             BitWidth,
710                                             D->getInClassInitStyle(),
711                                             D->getInnerLocStart(),
712                                             D->getAccess(),
713                                             nullptr);
714   if (!Field) {
715     cast<Decl>(Owner)->setInvalidDecl();
716     return nullptr;
717   }
718 
719   SemaRef.InstantiateAttrs(TemplateArgs, D, Field, LateAttrs, StartingScope);
720 
721   if (Field->hasAttrs())
722     SemaRef.CheckAlignasUnderalignment(Field);
723 
724   if (Invalid)
725     Field->setInvalidDecl();
726 
727   if (!Field->getDeclName()) {
728     // Keep track of where this decl came from.
729     SemaRef.Context.setInstantiatedFromUnnamedFieldDecl(Field, D);
730   }
731   if (CXXRecordDecl *Parent= dyn_cast<CXXRecordDecl>(Field->getDeclContext())) {
732     if (Parent->isAnonymousStructOrUnion() &&
733         Parent->getRedeclContext()->isFunctionOrMethod())
734       SemaRef.CurrentInstantiationScope->InstantiatedLocal(D, Field);
735   }
736 
737   Field->setImplicit(D->isImplicit());
738   Field->setAccess(D->getAccess());
739   Owner->addDecl(Field);
740 
741   return Field;
742 }
743 
744 Decl *TemplateDeclInstantiator::VisitMSPropertyDecl(MSPropertyDecl *D) {
745   bool Invalid = false;
746   TypeSourceInfo *DI = D->getTypeSourceInfo();
747 
748   if (DI->getType()->isVariablyModifiedType()) {
749     SemaRef.Diag(D->getLocation(), diag::err_property_is_variably_modified)
750       << D;
751     Invalid = true;
752   } else if (DI->getType()->isInstantiationDependentType())  {
753     DI = SemaRef.SubstType(DI, TemplateArgs,
754                            D->getLocation(), D->getDeclName());
755     if (!DI) {
756       DI = D->getTypeSourceInfo();
757       Invalid = true;
758     } else if (DI->getType()->isFunctionType()) {
759       // C++ [temp.arg.type]p3:
760       //   If a declaration acquires a function type through a type
761       //   dependent on a template-parameter and this causes a
762       //   declaration that does not use the syntactic form of a
763       //   function declarator to have function type, the program is
764       //   ill-formed.
765       SemaRef.Diag(D->getLocation(), diag::err_field_instantiates_to_function)
766       << DI->getType();
767       Invalid = true;
768     }
769   } else {
770     SemaRef.MarkDeclarationsReferencedInType(D->getLocation(), DI->getType());
771   }
772 
773   MSPropertyDecl *Property = MSPropertyDecl::Create(
774       SemaRef.Context, Owner, D->getLocation(), D->getDeclName(), DI->getType(),
775       DI, D->getLocStart(), D->getGetterId(), D->getSetterId());
776 
777   SemaRef.InstantiateAttrs(TemplateArgs, D, Property, LateAttrs,
778                            StartingScope);
779 
780   if (Invalid)
781     Property->setInvalidDecl();
782 
783   Property->setAccess(D->getAccess());
784   Owner->addDecl(Property);
785 
786   return Property;
787 }
788 
789 Decl *TemplateDeclInstantiator::VisitIndirectFieldDecl(IndirectFieldDecl *D) {
790   NamedDecl **NamedChain =
791     new (SemaRef.Context)NamedDecl*[D->getChainingSize()];
792 
793   int i = 0;
794   for (auto *PI : D->chain()) {
795     NamedDecl *Next = SemaRef.FindInstantiatedDecl(D->getLocation(), PI,
796                                               TemplateArgs);
797     if (!Next)
798       return nullptr;
799 
800     NamedChain[i++] = Next;
801   }
802 
803   QualType T = cast<FieldDecl>(NamedChain[i-1])->getType();
804   IndirectFieldDecl *IndirectField = IndirectFieldDecl::Create(
805       SemaRef.Context, Owner, D->getLocation(), D->getIdentifier(), T,
806       NamedChain, D->getChainingSize());
807 
808   for (const auto *Attr : D->attrs())
809     IndirectField->addAttr(Attr->clone(SemaRef.Context));
810 
811   IndirectField->setImplicit(D->isImplicit());
812   IndirectField->setAccess(D->getAccess());
813   Owner->addDecl(IndirectField);
814   return IndirectField;
815 }
816 
817 Decl *TemplateDeclInstantiator::VisitFriendDecl(FriendDecl *D) {
818   // Handle friend type expressions by simply substituting template
819   // parameters into the pattern type and checking the result.
820   if (TypeSourceInfo *Ty = D->getFriendType()) {
821     TypeSourceInfo *InstTy;
822     // If this is an unsupported friend, don't bother substituting template
823     // arguments into it. The actual type referred to won't be used by any
824     // parts of Clang, and may not be valid for instantiating. Just use the
825     // same info for the instantiated friend.
826     if (D->isUnsupportedFriend()) {
827       InstTy = Ty;
828     } else {
829       InstTy = SemaRef.SubstType(Ty, TemplateArgs,
830                                  D->getLocation(), DeclarationName());
831     }
832     if (!InstTy)
833       return nullptr;
834 
835     FriendDecl *FD = SemaRef.CheckFriendTypeDecl(D->getLocStart(),
836                                                  D->getFriendLoc(), InstTy);
837     if (!FD)
838       return nullptr;
839 
840     FD->setAccess(AS_public);
841     FD->setUnsupportedFriend(D->isUnsupportedFriend());
842     Owner->addDecl(FD);
843     return FD;
844   }
845 
846   NamedDecl *ND = D->getFriendDecl();
847   assert(ND && "friend decl must be a decl or a type!");
848 
849   // All of the Visit implementations for the various potential friend
850   // declarations have to be carefully written to work for friend
851   // objects, with the most important detail being that the target
852   // decl should almost certainly not be placed in Owner.
853   Decl *NewND = Visit(ND);
854   if (!NewND) return nullptr;
855 
856   FriendDecl *FD =
857     FriendDecl::Create(SemaRef.Context, Owner, D->getLocation(),
858                        cast<NamedDecl>(NewND), D->getFriendLoc());
859   FD->setAccess(AS_public);
860   FD->setUnsupportedFriend(D->isUnsupportedFriend());
861   Owner->addDecl(FD);
862   return FD;
863 }
864 
865 Decl *TemplateDeclInstantiator::VisitStaticAssertDecl(StaticAssertDecl *D) {
866   Expr *AssertExpr = D->getAssertExpr();
867 
868   // The expression in a static assertion is a constant expression.
869   EnterExpressionEvaluationContext Unevaluated(SemaRef,
870                                                Sema::ConstantEvaluated);
871 
872   ExprResult InstantiatedAssertExpr
873     = SemaRef.SubstExpr(AssertExpr, TemplateArgs);
874   if (InstantiatedAssertExpr.isInvalid())
875     return nullptr;
876 
877   return SemaRef.BuildStaticAssertDeclaration(D->getLocation(),
878                                               InstantiatedAssertExpr.get(),
879                                               D->getMessage(),
880                                               D->getRParenLoc(),
881                                               D->isFailed());
882 }
883 
884 Decl *TemplateDeclInstantiator::VisitEnumDecl(EnumDecl *D) {
885   EnumDecl *PrevDecl = nullptr;
886   if (EnumDecl *PatternPrev = getPreviousDeclForInstantiation(D)) {
887     NamedDecl *Prev = SemaRef.FindInstantiatedDecl(D->getLocation(),
888                                                    PatternPrev,
889                                                    TemplateArgs);
890     if (!Prev) return nullptr;
891     PrevDecl = cast<EnumDecl>(Prev);
892   }
893 
894   EnumDecl *Enum = EnumDecl::Create(SemaRef.Context, Owner, D->getLocStart(),
895                                     D->getLocation(), D->getIdentifier(),
896                                     PrevDecl, D->isScoped(),
897                                     D->isScopedUsingClassTag(), D->isFixed());
898   if (D->isFixed()) {
899     if (TypeSourceInfo *TI = D->getIntegerTypeSourceInfo()) {
900       // If we have type source information for the underlying type, it means it
901       // has been explicitly set by the user. Perform substitution on it before
902       // moving on.
903       SourceLocation UnderlyingLoc = TI->getTypeLoc().getBeginLoc();
904       TypeSourceInfo *NewTI = SemaRef.SubstType(TI, TemplateArgs, UnderlyingLoc,
905                                                 DeclarationName());
906       if (!NewTI || SemaRef.CheckEnumUnderlyingType(NewTI))
907         Enum->setIntegerType(SemaRef.Context.IntTy);
908       else
909         Enum->setIntegerTypeSourceInfo(NewTI);
910     } else {
911       assert(!D->getIntegerType()->isDependentType()
912              && "Dependent type without type source info");
913       Enum->setIntegerType(D->getIntegerType());
914     }
915   }
916 
917   SemaRef.InstantiateAttrs(TemplateArgs, D, Enum);
918 
919   Enum->setInstantiationOfMemberEnum(D, TSK_ImplicitInstantiation);
920   Enum->setAccess(D->getAccess());
921   // Forward the mangling number from the template to the instantiated decl.
922   SemaRef.Context.setManglingNumber(Enum, SemaRef.Context.getManglingNumber(D));
923   // See if the old tag was defined along with a declarator.
924   // If it did, mark the new tag as being associated with that declarator.
925   if (DeclaratorDecl *DD = SemaRef.Context.getDeclaratorForUnnamedTagDecl(D))
926     SemaRef.Context.addDeclaratorForUnnamedTagDecl(Enum, DD);
927   // See if the old tag was defined along with a typedef.
928   // If it did, mark the new tag as being associated with that typedef.
929   if (TypedefNameDecl *TND = SemaRef.Context.getTypedefNameForUnnamedTagDecl(D))
930     SemaRef.Context.addTypedefNameForUnnamedTagDecl(Enum, TND);
931   if (SubstQualifier(D, Enum)) return nullptr;
932   Owner->addDecl(Enum);
933 
934   EnumDecl *Def = D->getDefinition();
935   if (Def && Def != D) {
936     // If this is an out-of-line definition of an enum member template, check
937     // that the underlying types match in the instantiation of both
938     // declarations.
939     if (TypeSourceInfo *TI = Def->getIntegerTypeSourceInfo()) {
940       SourceLocation UnderlyingLoc = TI->getTypeLoc().getBeginLoc();
941       QualType DefnUnderlying =
942         SemaRef.SubstType(TI->getType(), TemplateArgs,
943                           UnderlyingLoc, DeclarationName());
944       SemaRef.CheckEnumRedeclaration(Def->getLocation(), Def->isScoped(),
945                                      DefnUnderlying,
946                                      /*EnumUnderlyingIsImplicit=*/false, Enum);
947     }
948   }
949 
950   // C++11 [temp.inst]p1: The implicit instantiation of a class template
951   // specialization causes the implicit instantiation of the declarations, but
952   // not the definitions of scoped member enumerations.
953   //
954   // DR1484 clarifies that enumeration definitions inside of a template
955   // declaration aren't considered entities that can be separately instantiated
956   // from the rest of the entity they are declared inside of.
957   if (isDeclWithinFunction(D) ? D == Def : Def && !Enum->isScoped()) {
958     SemaRef.CurrentInstantiationScope->InstantiatedLocal(D, Enum);
959     InstantiateEnumDefinition(Enum, Def);
960   }
961 
962   return Enum;
963 }
964 
965 void TemplateDeclInstantiator::InstantiateEnumDefinition(
966     EnumDecl *Enum, EnumDecl *Pattern) {
967   Enum->startDefinition();
968 
969   // Update the location to refer to the definition.
970   Enum->setLocation(Pattern->getLocation());
971 
972   SmallVector<Decl*, 4> Enumerators;
973 
974   EnumConstantDecl *LastEnumConst = nullptr;
975   for (auto *EC : Pattern->enumerators()) {
976     // The specified value for the enumerator.
977     ExprResult Value((Expr *)nullptr);
978     if (Expr *UninstValue = EC->getInitExpr()) {
979       // The enumerator's value expression is a constant expression.
980       EnterExpressionEvaluationContext Unevaluated(SemaRef,
981                                                    Sema::ConstantEvaluated);
982 
983       Value = SemaRef.SubstExpr(UninstValue, TemplateArgs);
984     }
985 
986     // Drop the initial value and continue.
987     bool isInvalid = false;
988     if (Value.isInvalid()) {
989       Value = nullptr;
990       isInvalid = true;
991     }
992 
993     EnumConstantDecl *EnumConst
994       = SemaRef.CheckEnumConstant(Enum, LastEnumConst,
995                                   EC->getLocation(), EC->getIdentifier(),
996                                   Value.get());
997 
998     if (isInvalid) {
999       if (EnumConst)
1000         EnumConst->setInvalidDecl();
1001       Enum->setInvalidDecl();
1002     }
1003 
1004     if (EnumConst) {
1005       SemaRef.InstantiateAttrs(TemplateArgs, EC, EnumConst);
1006 
1007       EnumConst->setAccess(Enum->getAccess());
1008       Enum->addDecl(EnumConst);
1009       Enumerators.push_back(EnumConst);
1010       LastEnumConst = EnumConst;
1011 
1012       if (Pattern->getDeclContext()->isFunctionOrMethod() &&
1013           !Enum->isScoped()) {
1014         // If the enumeration is within a function or method, record the enum
1015         // constant as a local.
1016         SemaRef.CurrentInstantiationScope->InstantiatedLocal(EC, EnumConst);
1017       }
1018     }
1019   }
1020 
1021   // FIXME: Fixup LBraceLoc
1022   SemaRef.ActOnEnumBody(Enum->getLocation(), SourceLocation(),
1023                         Enum->getRBraceLoc(), Enum,
1024                         Enumerators,
1025                         nullptr, nullptr);
1026 }
1027 
1028 Decl *TemplateDeclInstantiator::VisitEnumConstantDecl(EnumConstantDecl *D) {
1029   llvm_unreachable("EnumConstantDecls can only occur within EnumDecls.");
1030 }
1031 
1032 Decl *
1033 TemplateDeclInstantiator::VisitBuiltinTemplateDecl(BuiltinTemplateDecl *D) {
1034   llvm_unreachable("BuiltinTemplateDecls cannot be instantiated.");
1035 }
1036 
1037 Decl *TemplateDeclInstantiator::VisitClassTemplateDecl(ClassTemplateDecl *D) {
1038   bool isFriend = (D->getFriendObjectKind() != Decl::FOK_None);
1039 
1040   // Create a local instantiation scope for this class template, which
1041   // will contain the instantiations of the template parameters.
1042   LocalInstantiationScope Scope(SemaRef);
1043   TemplateParameterList *TempParams = D->getTemplateParameters();
1044   TemplateParameterList *InstParams = SubstTemplateParams(TempParams);
1045   if (!InstParams)
1046     return nullptr;
1047 
1048   CXXRecordDecl *Pattern = D->getTemplatedDecl();
1049 
1050   // Instantiate the qualifier.  We have to do this first in case
1051   // we're a friend declaration, because if we are then we need to put
1052   // the new declaration in the appropriate context.
1053   NestedNameSpecifierLoc QualifierLoc = Pattern->getQualifierLoc();
1054   if (QualifierLoc) {
1055     QualifierLoc = SemaRef.SubstNestedNameSpecifierLoc(QualifierLoc,
1056                                                        TemplateArgs);
1057     if (!QualifierLoc)
1058       return nullptr;
1059   }
1060 
1061   CXXRecordDecl *PrevDecl = nullptr;
1062   ClassTemplateDecl *PrevClassTemplate = nullptr;
1063 
1064   if (!isFriend && getPreviousDeclForInstantiation(Pattern)) {
1065     DeclContext::lookup_result Found = Owner->lookup(Pattern->getDeclName());
1066     if (!Found.empty()) {
1067       PrevClassTemplate = dyn_cast<ClassTemplateDecl>(Found.front());
1068       if (PrevClassTemplate)
1069         PrevDecl = PrevClassTemplate->getTemplatedDecl();
1070     }
1071   }
1072 
1073   // If this isn't a friend, then it's a member template, in which
1074   // case we just want to build the instantiation in the
1075   // specialization.  If it is a friend, we want to build it in
1076   // the appropriate context.
1077   DeclContext *DC = Owner;
1078   if (isFriend) {
1079     if (QualifierLoc) {
1080       CXXScopeSpec SS;
1081       SS.Adopt(QualifierLoc);
1082       DC = SemaRef.computeDeclContext(SS);
1083       if (!DC) return nullptr;
1084     } else {
1085       DC = SemaRef.FindInstantiatedContext(Pattern->getLocation(),
1086                                            Pattern->getDeclContext(),
1087                                            TemplateArgs);
1088     }
1089 
1090     // Look for a previous declaration of the template in the owning
1091     // context.
1092     LookupResult R(SemaRef, Pattern->getDeclName(), Pattern->getLocation(),
1093                    Sema::LookupOrdinaryName, Sema::ForRedeclaration);
1094     SemaRef.LookupQualifiedName(R, DC);
1095 
1096     if (R.isSingleResult()) {
1097       PrevClassTemplate = R.getAsSingle<ClassTemplateDecl>();
1098       if (PrevClassTemplate)
1099         PrevDecl = PrevClassTemplate->getTemplatedDecl();
1100     }
1101 
1102     if (!PrevClassTemplate && QualifierLoc) {
1103       SemaRef.Diag(Pattern->getLocation(), diag::err_not_tag_in_scope)
1104         << D->getTemplatedDecl()->getTagKind() << Pattern->getDeclName() << DC
1105         << QualifierLoc.getSourceRange();
1106       return nullptr;
1107     }
1108 
1109     bool AdoptedPreviousTemplateParams = false;
1110     if (PrevClassTemplate) {
1111       bool Complain = true;
1112 
1113       // HACK: libstdc++ 4.2.1 contains an ill-formed friend class
1114       // template for struct std::tr1::__detail::_Map_base, where the
1115       // template parameters of the friend declaration don't match the
1116       // template parameters of the original declaration. In this one
1117       // case, we don't complain about the ill-formed friend
1118       // declaration.
1119       if (isFriend && Pattern->getIdentifier() &&
1120           Pattern->getIdentifier()->isStr("_Map_base") &&
1121           DC->isNamespace() &&
1122           cast<NamespaceDecl>(DC)->getIdentifier() &&
1123           cast<NamespaceDecl>(DC)->getIdentifier()->isStr("__detail")) {
1124         DeclContext *DCParent = DC->getParent();
1125         if (DCParent->isNamespace() &&
1126             cast<NamespaceDecl>(DCParent)->getIdentifier() &&
1127             cast<NamespaceDecl>(DCParent)->getIdentifier()->isStr("tr1")) {
1128           if (cast<Decl>(DCParent)->isInStdNamespace())
1129             Complain = false;
1130         }
1131       }
1132 
1133       TemplateParameterList *PrevParams
1134         = PrevClassTemplate->getTemplateParameters();
1135 
1136       // Make sure the parameter lists match.
1137       if (!SemaRef.TemplateParameterListsAreEqual(InstParams, PrevParams,
1138                                                   Complain,
1139                                                   Sema::TPL_TemplateMatch)) {
1140         if (Complain)
1141           return nullptr;
1142 
1143         AdoptedPreviousTemplateParams = true;
1144         InstParams = PrevParams;
1145       }
1146 
1147       // Do some additional validation, then merge default arguments
1148       // from the existing declarations.
1149       if (!AdoptedPreviousTemplateParams &&
1150           SemaRef.CheckTemplateParameterList(InstParams, PrevParams,
1151                                              Sema::TPC_ClassTemplate))
1152         return nullptr;
1153     }
1154   }
1155 
1156   CXXRecordDecl *RecordInst
1157     = CXXRecordDecl::Create(SemaRef.Context, Pattern->getTagKind(), DC,
1158                             Pattern->getLocStart(), Pattern->getLocation(),
1159                             Pattern->getIdentifier(), PrevDecl,
1160                             /*DelayTypeCreation=*/true);
1161 
1162   if (QualifierLoc)
1163     RecordInst->setQualifierInfo(QualifierLoc);
1164 
1165   ClassTemplateDecl *Inst
1166     = ClassTemplateDecl::Create(SemaRef.Context, DC, D->getLocation(),
1167                                 D->getIdentifier(), InstParams, RecordInst,
1168                                 PrevClassTemplate);
1169   RecordInst->setDescribedClassTemplate(Inst);
1170 
1171   if (isFriend) {
1172     if (PrevClassTemplate)
1173       Inst->setAccess(PrevClassTemplate->getAccess());
1174     else
1175       Inst->setAccess(D->getAccess());
1176 
1177     Inst->setObjectOfFriendDecl();
1178     // TODO: do we want to track the instantiation progeny of this
1179     // friend target decl?
1180   } else {
1181     Inst->setAccess(D->getAccess());
1182     if (!PrevClassTemplate)
1183       Inst->setInstantiatedFromMemberTemplate(D);
1184   }
1185 
1186   // Trigger creation of the type for the instantiation.
1187   SemaRef.Context.getInjectedClassNameType(RecordInst,
1188                                     Inst->getInjectedClassNameSpecialization());
1189 
1190   // Finish handling of friends.
1191   if (isFriend) {
1192     DC->makeDeclVisibleInContext(Inst);
1193     Inst->setLexicalDeclContext(Owner);
1194     RecordInst->setLexicalDeclContext(Owner);
1195     return Inst;
1196   }
1197 
1198   if (D->isOutOfLine()) {
1199     Inst->setLexicalDeclContext(D->getLexicalDeclContext());
1200     RecordInst->setLexicalDeclContext(D->getLexicalDeclContext());
1201   }
1202 
1203   Owner->addDecl(Inst);
1204 
1205   if (!PrevClassTemplate) {
1206     // Queue up any out-of-line partial specializations of this member
1207     // class template; the client will force their instantiation once
1208     // the enclosing class has been instantiated.
1209     SmallVector<ClassTemplatePartialSpecializationDecl *, 4> PartialSpecs;
1210     D->getPartialSpecializations(PartialSpecs);
1211     for (unsigned I = 0, N = PartialSpecs.size(); I != N; ++I)
1212       if (PartialSpecs[I]->getFirstDecl()->isOutOfLine())
1213         OutOfLinePartialSpecs.push_back(std::make_pair(Inst, PartialSpecs[I]));
1214   }
1215 
1216   return Inst;
1217 }
1218 
1219 Decl *
1220 TemplateDeclInstantiator::VisitClassTemplatePartialSpecializationDecl(
1221                                    ClassTemplatePartialSpecializationDecl *D) {
1222   ClassTemplateDecl *ClassTemplate = D->getSpecializedTemplate();
1223 
1224   // Lookup the already-instantiated declaration in the instantiation
1225   // of the class template and return that.
1226   DeclContext::lookup_result Found
1227     = Owner->lookup(ClassTemplate->getDeclName());
1228   if (Found.empty())
1229     return nullptr;
1230 
1231   ClassTemplateDecl *InstClassTemplate
1232     = dyn_cast<ClassTemplateDecl>(Found.front());
1233   if (!InstClassTemplate)
1234     return nullptr;
1235 
1236   if (ClassTemplatePartialSpecializationDecl *Result
1237         = InstClassTemplate->findPartialSpecInstantiatedFromMember(D))
1238     return Result;
1239 
1240   return InstantiateClassTemplatePartialSpecialization(InstClassTemplate, D);
1241 }
1242 
1243 Decl *TemplateDeclInstantiator::VisitVarTemplateDecl(VarTemplateDecl *D) {
1244   assert(D->getTemplatedDecl()->isStaticDataMember() &&
1245          "Only static data member templates are allowed.");
1246 
1247   // Create a local instantiation scope for this variable template, which
1248   // will contain the instantiations of the template parameters.
1249   LocalInstantiationScope Scope(SemaRef);
1250   TemplateParameterList *TempParams = D->getTemplateParameters();
1251   TemplateParameterList *InstParams = SubstTemplateParams(TempParams);
1252   if (!InstParams)
1253     return nullptr;
1254 
1255   VarDecl *Pattern = D->getTemplatedDecl();
1256   VarTemplateDecl *PrevVarTemplate = nullptr;
1257 
1258   if (getPreviousDeclForInstantiation(Pattern)) {
1259     DeclContext::lookup_result Found = Owner->lookup(Pattern->getDeclName());
1260     if (!Found.empty())
1261       PrevVarTemplate = dyn_cast<VarTemplateDecl>(Found.front());
1262   }
1263 
1264   VarDecl *VarInst =
1265       cast_or_null<VarDecl>(VisitVarDecl(Pattern,
1266                                          /*InstantiatingVarTemplate=*/true));
1267   if (!VarInst) return nullptr;
1268 
1269   DeclContext *DC = Owner;
1270 
1271   VarTemplateDecl *Inst = VarTemplateDecl::Create(
1272       SemaRef.Context, DC, D->getLocation(), D->getIdentifier(), InstParams,
1273       VarInst);
1274   VarInst->setDescribedVarTemplate(Inst);
1275   Inst->setPreviousDecl(PrevVarTemplate);
1276 
1277   Inst->setAccess(D->getAccess());
1278   if (!PrevVarTemplate)
1279     Inst->setInstantiatedFromMemberTemplate(D);
1280 
1281   if (D->isOutOfLine()) {
1282     Inst->setLexicalDeclContext(D->getLexicalDeclContext());
1283     VarInst->setLexicalDeclContext(D->getLexicalDeclContext());
1284   }
1285 
1286   Owner->addDecl(Inst);
1287 
1288   if (!PrevVarTemplate) {
1289     // Queue up any out-of-line partial specializations of this member
1290     // variable template; the client will force their instantiation once
1291     // the enclosing class has been instantiated.
1292     SmallVector<VarTemplatePartialSpecializationDecl *, 4> PartialSpecs;
1293     D->getPartialSpecializations(PartialSpecs);
1294     for (unsigned I = 0, N = PartialSpecs.size(); I != N; ++I)
1295       if (PartialSpecs[I]->getFirstDecl()->isOutOfLine())
1296         OutOfLineVarPartialSpecs.push_back(
1297             std::make_pair(Inst, PartialSpecs[I]));
1298   }
1299 
1300   return Inst;
1301 }
1302 
1303 Decl *TemplateDeclInstantiator::VisitVarTemplatePartialSpecializationDecl(
1304     VarTemplatePartialSpecializationDecl *D) {
1305   assert(D->isStaticDataMember() &&
1306          "Only static data member templates are allowed.");
1307 
1308   VarTemplateDecl *VarTemplate = D->getSpecializedTemplate();
1309 
1310   // Lookup the already-instantiated declaration and return that.
1311   DeclContext::lookup_result Found = Owner->lookup(VarTemplate->getDeclName());
1312   assert(!Found.empty() && "Instantiation found nothing?");
1313 
1314   VarTemplateDecl *InstVarTemplate = dyn_cast<VarTemplateDecl>(Found.front());
1315   assert(InstVarTemplate && "Instantiation did not find a variable template?");
1316 
1317   if (VarTemplatePartialSpecializationDecl *Result =
1318           InstVarTemplate->findPartialSpecInstantiatedFromMember(D))
1319     return Result;
1320 
1321   return InstantiateVarTemplatePartialSpecialization(InstVarTemplate, D);
1322 }
1323 
1324 Decl *
1325 TemplateDeclInstantiator::VisitFunctionTemplateDecl(FunctionTemplateDecl *D) {
1326   // Create a local instantiation scope for this function template, which
1327   // will contain the instantiations of the template parameters and then get
1328   // merged with the local instantiation scope for the function template
1329   // itself.
1330   LocalInstantiationScope Scope(SemaRef);
1331 
1332   TemplateParameterList *TempParams = D->getTemplateParameters();
1333   TemplateParameterList *InstParams = SubstTemplateParams(TempParams);
1334   if (!InstParams)
1335     return nullptr;
1336 
1337   FunctionDecl *Instantiated = nullptr;
1338   if (CXXMethodDecl *DMethod = dyn_cast<CXXMethodDecl>(D->getTemplatedDecl()))
1339     Instantiated = cast_or_null<FunctionDecl>(VisitCXXMethodDecl(DMethod,
1340                                                                  InstParams));
1341   else
1342     Instantiated = cast_or_null<FunctionDecl>(VisitFunctionDecl(
1343                                                           D->getTemplatedDecl(),
1344                                                                 InstParams));
1345 
1346   if (!Instantiated)
1347     return nullptr;
1348 
1349   // Link the instantiated function template declaration to the function
1350   // template from which it was instantiated.
1351   FunctionTemplateDecl *InstTemplate
1352     = Instantiated->getDescribedFunctionTemplate();
1353   InstTemplate->setAccess(D->getAccess());
1354   assert(InstTemplate &&
1355          "VisitFunctionDecl/CXXMethodDecl didn't create a template!");
1356 
1357   bool isFriend = (InstTemplate->getFriendObjectKind() != Decl::FOK_None);
1358 
1359   // Link the instantiation back to the pattern *unless* this is a
1360   // non-definition friend declaration.
1361   if (!InstTemplate->getInstantiatedFromMemberTemplate() &&
1362       !(isFriend && !D->getTemplatedDecl()->isThisDeclarationADefinition()))
1363     InstTemplate->setInstantiatedFromMemberTemplate(D);
1364 
1365   // Make declarations visible in the appropriate context.
1366   if (!isFriend) {
1367     Owner->addDecl(InstTemplate);
1368   } else if (InstTemplate->getDeclContext()->isRecord() &&
1369              !getPreviousDeclForInstantiation(D)) {
1370     SemaRef.CheckFriendAccess(InstTemplate);
1371   }
1372 
1373   return InstTemplate;
1374 }
1375 
1376 Decl *TemplateDeclInstantiator::VisitCXXRecordDecl(CXXRecordDecl *D) {
1377   CXXRecordDecl *PrevDecl = nullptr;
1378   if (D->isInjectedClassName())
1379     PrevDecl = cast<CXXRecordDecl>(Owner);
1380   else if (CXXRecordDecl *PatternPrev = getPreviousDeclForInstantiation(D)) {
1381     NamedDecl *Prev = SemaRef.FindInstantiatedDecl(D->getLocation(),
1382                                                    PatternPrev,
1383                                                    TemplateArgs);
1384     if (!Prev) return nullptr;
1385     PrevDecl = cast<CXXRecordDecl>(Prev);
1386   }
1387 
1388   CXXRecordDecl *Record
1389     = CXXRecordDecl::Create(SemaRef.Context, D->getTagKind(), Owner,
1390                             D->getLocStart(), D->getLocation(),
1391                             D->getIdentifier(), PrevDecl);
1392 
1393   // Substitute the nested name specifier, if any.
1394   if (SubstQualifier(D, Record))
1395     return nullptr;
1396 
1397   Record->setImplicit(D->isImplicit());
1398   // FIXME: Check against AS_none is an ugly hack to work around the issue that
1399   // the tag decls introduced by friend class declarations don't have an access
1400   // specifier. Remove once this area of the code gets sorted out.
1401   if (D->getAccess() != AS_none)
1402     Record->setAccess(D->getAccess());
1403   if (!D->isInjectedClassName())
1404     Record->setInstantiationOfMemberClass(D, TSK_ImplicitInstantiation);
1405 
1406   // If the original function was part of a friend declaration,
1407   // inherit its namespace state.
1408   if (D->getFriendObjectKind())
1409     Record->setObjectOfFriendDecl();
1410 
1411   // Make sure that anonymous structs and unions are recorded.
1412   if (D->isAnonymousStructOrUnion())
1413     Record->setAnonymousStructOrUnion(true);
1414 
1415   if (D->isLocalClass())
1416     SemaRef.CurrentInstantiationScope->InstantiatedLocal(D, Record);
1417 
1418   // Forward the mangling number from the template to the instantiated decl.
1419   SemaRef.Context.setManglingNumber(Record,
1420                                     SemaRef.Context.getManglingNumber(D));
1421 
1422   // See if the old tag was defined along with a declarator.
1423   // If it did, mark the new tag as being associated with that declarator.
1424   if (DeclaratorDecl *DD = SemaRef.Context.getDeclaratorForUnnamedTagDecl(D))
1425     SemaRef.Context.addDeclaratorForUnnamedTagDecl(Record, DD);
1426 
1427   // See if the old tag was defined along with a typedef.
1428   // If it did, mark the new tag as being associated with that typedef.
1429   if (TypedefNameDecl *TND = SemaRef.Context.getTypedefNameForUnnamedTagDecl(D))
1430     SemaRef.Context.addTypedefNameForUnnamedTagDecl(Record, TND);
1431 
1432   Owner->addDecl(Record);
1433 
1434   // DR1484 clarifies that the members of a local class are instantiated as part
1435   // of the instantiation of their enclosing entity.
1436   if (D->isCompleteDefinition() && D->isLocalClass()) {
1437     Sema::SavePendingLocalImplicitInstantiationsRAII
1438         SavedPendingLocalImplicitInstantiations(SemaRef);
1439 
1440     SemaRef.InstantiateClass(D->getLocation(), Record, D, TemplateArgs,
1441                              TSK_ImplicitInstantiation,
1442                              /*Complain=*/true);
1443 
1444     SemaRef.InstantiateClassMembers(D->getLocation(), Record, TemplateArgs,
1445                                     TSK_ImplicitInstantiation);
1446 
1447     // This class may have local implicit instantiations that need to be
1448     // performed within this scope.
1449     SemaRef.PerformPendingInstantiations(/*LocalOnly=*/true);
1450   }
1451 
1452   SemaRef.DiagnoseUnusedNestedTypedefs(Record);
1453 
1454   return Record;
1455 }
1456 
1457 /// \brief Adjust the given function type for an instantiation of the
1458 /// given declaration, to cope with modifications to the function's type that
1459 /// aren't reflected in the type-source information.
1460 ///
1461 /// \param D The declaration we're instantiating.
1462 /// \param TInfo The already-instantiated type.
1463 static QualType adjustFunctionTypeForInstantiation(ASTContext &Context,
1464                                                    FunctionDecl *D,
1465                                                    TypeSourceInfo *TInfo) {
1466   const FunctionProtoType *OrigFunc
1467     = D->getType()->castAs<FunctionProtoType>();
1468   const FunctionProtoType *NewFunc
1469     = TInfo->getType()->castAs<FunctionProtoType>();
1470   if (OrigFunc->getExtInfo() == NewFunc->getExtInfo())
1471     return TInfo->getType();
1472 
1473   FunctionProtoType::ExtProtoInfo NewEPI = NewFunc->getExtProtoInfo();
1474   NewEPI.ExtInfo = OrigFunc->getExtInfo();
1475   return Context.getFunctionType(NewFunc->getReturnType(),
1476                                  NewFunc->getParamTypes(), NewEPI);
1477 }
1478 
1479 /// Normal class members are of more specific types and therefore
1480 /// don't make it here.  This function serves two purposes:
1481 ///   1) instantiating function templates
1482 ///   2) substituting friend declarations
1483 Decl *TemplateDeclInstantiator::VisitFunctionDecl(FunctionDecl *D,
1484                                        TemplateParameterList *TemplateParams) {
1485   // Check whether there is already a function template specialization for
1486   // this declaration.
1487   FunctionTemplateDecl *FunctionTemplate = D->getDescribedFunctionTemplate();
1488   if (FunctionTemplate && !TemplateParams) {
1489     ArrayRef<TemplateArgument> Innermost = TemplateArgs.getInnermost();
1490 
1491     void *InsertPos = nullptr;
1492     FunctionDecl *SpecFunc
1493       = FunctionTemplate->findSpecialization(Innermost, InsertPos);
1494 
1495     // If we already have a function template specialization, return it.
1496     if (SpecFunc)
1497       return SpecFunc;
1498   }
1499 
1500   bool isFriend;
1501   if (FunctionTemplate)
1502     isFriend = (FunctionTemplate->getFriendObjectKind() != Decl::FOK_None);
1503   else
1504     isFriend = (D->getFriendObjectKind() != Decl::FOK_None);
1505 
1506   bool MergeWithParentScope = (TemplateParams != nullptr) ||
1507     Owner->isFunctionOrMethod() ||
1508     !(isa<Decl>(Owner) &&
1509       cast<Decl>(Owner)->isDefinedOutsideFunctionOrMethod());
1510   LocalInstantiationScope Scope(SemaRef, MergeWithParentScope);
1511 
1512   SmallVector<ParmVarDecl *, 4> Params;
1513   TypeSourceInfo *TInfo = SubstFunctionType(D, Params);
1514   if (!TInfo)
1515     return nullptr;
1516   QualType T = adjustFunctionTypeForInstantiation(SemaRef.Context, D, TInfo);
1517 
1518   NestedNameSpecifierLoc QualifierLoc = D->getQualifierLoc();
1519   if (QualifierLoc) {
1520     QualifierLoc = SemaRef.SubstNestedNameSpecifierLoc(QualifierLoc,
1521                                                        TemplateArgs);
1522     if (!QualifierLoc)
1523       return nullptr;
1524   }
1525 
1526   // If we're instantiating a local function declaration, put the result
1527   // in the enclosing namespace; otherwise we need to find the instantiated
1528   // context.
1529   DeclContext *DC;
1530   if (D->isLocalExternDecl()) {
1531     DC = Owner;
1532     SemaRef.adjustContextForLocalExternDecl(DC);
1533   } else if (isFriend && QualifierLoc) {
1534     CXXScopeSpec SS;
1535     SS.Adopt(QualifierLoc);
1536     DC = SemaRef.computeDeclContext(SS);
1537     if (!DC) return nullptr;
1538   } else {
1539     DC = SemaRef.FindInstantiatedContext(D->getLocation(), D->getDeclContext(),
1540                                          TemplateArgs);
1541   }
1542 
1543   FunctionDecl *Function =
1544       FunctionDecl::Create(SemaRef.Context, DC, D->getInnerLocStart(),
1545                            D->getNameInfo(), T, TInfo,
1546                            D->getCanonicalDecl()->getStorageClass(),
1547                            D->isInlineSpecified(), D->hasWrittenPrototype(),
1548                            D->isConstexpr());
1549   Function->setRangeEnd(D->getSourceRange().getEnd());
1550 
1551   if (D->isInlined())
1552     Function->setImplicitlyInline();
1553 
1554   if (QualifierLoc)
1555     Function->setQualifierInfo(QualifierLoc);
1556 
1557   if (D->isLocalExternDecl())
1558     Function->setLocalExternDecl();
1559 
1560   DeclContext *LexicalDC = Owner;
1561   if (!isFriend && D->isOutOfLine() && !D->isLocalExternDecl()) {
1562     assert(D->getDeclContext()->isFileContext());
1563     LexicalDC = D->getDeclContext();
1564   }
1565 
1566   Function->setLexicalDeclContext(LexicalDC);
1567 
1568   // Attach the parameters
1569   for (unsigned P = 0; P < Params.size(); ++P)
1570     if (Params[P])
1571       Params[P]->setOwningFunction(Function);
1572   Function->setParams(Params);
1573 
1574   SourceLocation InstantiateAtPOI;
1575   if (TemplateParams) {
1576     // Our resulting instantiation is actually a function template, since we
1577     // are substituting only the outer template parameters. For example, given
1578     //
1579     //   template<typename T>
1580     //   struct X {
1581     //     template<typename U> friend void f(T, U);
1582     //   };
1583     //
1584     //   X<int> x;
1585     //
1586     // We are instantiating the friend function template "f" within X<int>,
1587     // which means substituting int for T, but leaving "f" as a friend function
1588     // template.
1589     // Build the function template itself.
1590     FunctionTemplate = FunctionTemplateDecl::Create(SemaRef.Context, DC,
1591                                                     Function->getLocation(),
1592                                                     Function->getDeclName(),
1593                                                     TemplateParams, Function);
1594     Function->setDescribedFunctionTemplate(FunctionTemplate);
1595 
1596     FunctionTemplate->setLexicalDeclContext(LexicalDC);
1597 
1598     if (isFriend && D->isThisDeclarationADefinition()) {
1599       // TODO: should we remember this connection regardless of whether
1600       // the friend declaration provided a body?
1601       FunctionTemplate->setInstantiatedFromMemberTemplate(
1602                                            D->getDescribedFunctionTemplate());
1603     }
1604   } else if (FunctionTemplate) {
1605     // Record this function template specialization.
1606     ArrayRef<TemplateArgument> Innermost = TemplateArgs.getInnermost();
1607     Function->setFunctionTemplateSpecialization(FunctionTemplate,
1608                             TemplateArgumentList::CreateCopy(SemaRef.Context,
1609                                                              Innermost.begin(),
1610                                                              Innermost.size()),
1611                                                 /*InsertPos=*/nullptr);
1612   } else if (isFriend) {
1613     // Note, we need this connection even if the friend doesn't have a body.
1614     // Its body may exist but not have been attached yet due to deferred
1615     // parsing.
1616     // FIXME: It might be cleaner to set this when attaching the body to the
1617     // friend function declaration, however that would require finding all the
1618     // instantiations and modifying them.
1619     Function->setInstantiationOfMemberFunction(D, TSK_ImplicitInstantiation);
1620   }
1621 
1622   if (InitFunctionInstantiation(Function, D))
1623     Function->setInvalidDecl();
1624 
1625   bool isExplicitSpecialization = false;
1626 
1627   LookupResult Previous(
1628       SemaRef, Function->getDeclName(), SourceLocation(),
1629       D->isLocalExternDecl() ? Sema::LookupRedeclarationWithLinkage
1630                              : Sema::LookupOrdinaryName,
1631       Sema::ForRedeclaration);
1632 
1633   if (DependentFunctionTemplateSpecializationInfo *Info
1634         = D->getDependentSpecializationInfo()) {
1635     assert(isFriend && "non-friend has dependent specialization info?");
1636 
1637     // This needs to be set now for future sanity.
1638     Function->setObjectOfFriendDecl();
1639 
1640     // Instantiate the explicit template arguments.
1641     TemplateArgumentListInfo ExplicitArgs(Info->getLAngleLoc(),
1642                                           Info->getRAngleLoc());
1643     if (SemaRef.Subst(Info->getTemplateArgs(), Info->getNumTemplateArgs(),
1644                       ExplicitArgs, TemplateArgs))
1645       return nullptr;
1646 
1647     // Map the candidate templates to their instantiations.
1648     for (unsigned I = 0, E = Info->getNumTemplates(); I != E; ++I) {
1649       Decl *Temp = SemaRef.FindInstantiatedDecl(D->getLocation(),
1650                                                 Info->getTemplate(I),
1651                                                 TemplateArgs);
1652       if (!Temp) return nullptr;
1653 
1654       Previous.addDecl(cast<FunctionTemplateDecl>(Temp));
1655     }
1656 
1657     if (SemaRef.CheckFunctionTemplateSpecialization(Function,
1658                                                     &ExplicitArgs,
1659                                                     Previous))
1660       Function->setInvalidDecl();
1661 
1662     isExplicitSpecialization = true;
1663 
1664   } else if (TemplateParams || !FunctionTemplate) {
1665     // Look only into the namespace where the friend would be declared to
1666     // find a previous declaration. This is the innermost enclosing namespace,
1667     // as described in ActOnFriendFunctionDecl.
1668     SemaRef.LookupQualifiedName(Previous, DC);
1669 
1670     // In C++, the previous declaration we find might be a tag type
1671     // (class or enum). In this case, the new declaration will hide the
1672     // tag type. Note that this does does not apply if we're declaring a
1673     // typedef (C++ [dcl.typedef]p4).
1674     if (Previous.isSingleTagDecl())
1675       Previous.clear();
1676   }
1677 
1678   SemaRef.CheckFunctionDeclaration(/*Scope*/ nullptr, Function, Previous,
1679                                    isExplicitSpecialization);
1680 
1681   NamedDecl *PrincipalDecl = (TemplateParams
1682                               ? cast<NamedDecl>(FunctionTemplate)
1683                               : Function);
1684 
1685   // If the original function was part of a friend declaration,
1686   // inherit its namespace state and add it to the owner.
1687   if (isFriend) {
1688     PrincipalDecl->setObjectOfFriendDecl();
1689     DC->makeDeclVisibleInContext(PrincipalDecl);
1690 
1691     bool QueuedInstantiation = false;
1692 
1693     // C++11 [temp.friend]p4 (DR329):
1694     //   When a function is defined in a friend function declaration in a class
1695     //   template, the function is instantiated when the function is odr-used.
1696     //   The same restrictions on multiple declarations and definitions that
1697     //   apply to non-template function declarations and definitions also apply
1698     //   to these implicit definitions.
1699     if (D->isThisDeclarationADefinition()) {
1700       // Check for a function body.
1701       const FunctionDecl *Definition = nullptr;
1702       if (Function->isDefined(Definition) &&
1703           Definition->getTemplateSpecializationKind() == TSK_Undeclared) {
1704         SemaRef.Diag(Function->getLocation(), diag::err_redefinition)
1705             << Function->getDeclName();
1706         SemaRef.Diag(Definition->getLocation(), diag::note_previous_definition);
1707       }
1708       // Check for redefinitions due to other instantiations of this or
1709       // a similar friend function.
1710       else for (auto R : Function->redecls()) {
1711         if (R == Function)
1712           continue;
1713 
1714         // If some prior declaration of this function has been used, we need
1715         // to instantiate its definition.
1716         if (!QueuedInstantiation && R->isUsed(false)) {
1717           if (MemberSpecializationInfo *MSInfo =
1718                   Function->getMemberSpecializationInfo()) {
1719             if (MSInfo->getPointOfInstantiation().isInvalid()) {
1720               SourceLocation Loc = R->getLocation(); // FIXME
1721               MSInfo->setPointOfInstantiation(Loc);
1722               SemaRef.PendingLocalImplicitInstantiations.push_back(
1723                                                std::make_pair(Function, Loc));
1724               QueuedInstantiation = true;
1725             }
1726           }
1727         }
1728 
1729         // If some prior declaration of this function was a friend with an
1730         // uninstantiated definition, reject it.
1731         if (R->getFriendObjectKind()) {
1732           if (const FunctionDecl *RPattern =
1733                   R->getTemplateInstantiationPattern()) {
1734             if (RPattern->isDefined(RPattern)) {
1735               SemaRef.Diag(Function->getLocation(), diag::err_redefinition)
1736                 << Function->getDeclName();
1737               SemaRef.Diag(R->getLocation(), diag::note_previous_definition);
1738               break;
1739             }
1740           }
1741         }
1742       }
1743     }
1744   }
1745 
1746   if (Function->isLocalExternDecl() && !Function->getPreviousDecl())
1747     DC->makeDeclVisibleInContext(PrincipalDecl);
1748 
1749   if (Function->isOverloadedOperator() && !DC->isRecord() &&
1750       PrincipalDecl->isInIdentifierNamespace(Decl::IDNS_Ordinary))
1751     PrincipalDecl->setNonMemberOperator();
1752 
1753   assert(!D->isDefaulted() && "only methods should be defaulted");
1754   return Function;
1755 }
1756 
1757 Decl *
1758 TemplateDeclInstantiator::VisitCXXMethodDecl(CXXMethodDecl *D,
1759                                       TemplateParameterList *TemplateParams,
1760                                       bool IsClassScopeSpecialization) {
1761   FunctionTemplateDecl *FunctionTemplate = D->getDescribedFunctionTemplate();
1762   if (FunctionTemplate && !TemplateParams) {
1763     // We are creating a function template specialization from a function
1764     // template. Check whether there is already a function template
1765     // specialization for this particular set of template arguments.
1766     ArrayRef<TemplateArgument> Innermost = TemplateArgs.getInnermost();
1767 
1768     void *InsertPos = nullptr;
1769     FunctionDecl *SpecFunc
1770       = FunctionTemplate->findSpecialization(Innermost, InsertPos);
1771 
1772     // If we already have a function template specialization, return it.
1773     if (SpecFunc)
1774       return SpecFunc;
1775   }
1776 
1777   bool isFriend;
1778   if (FunctionTemplate)
1779     isFriend = (FunctionTemplate->getFriendObjectKind() != Decl::FOK_None);
1780   else
1781     isFriend = (D->getFriendObjectKind() != Decl::FOK_None);
1782 
1783   bool MergeWithParentScope = (TemplateParams != nullptr) ||
1784     !(isa<Decl>(Owner) &&
1785       cast<Decl>(Owner)->isDefinedOutsideFunctionOrMethod());
1786   LocalInstantiationScope Scope(SemaRef, MergeWithParentScope);
1787 
1788   // Instantiate enclosing template arguments for friends.
1789   SmallVector<TemplateParameterList *, 4> TempParamLists;
1790   unsigned NumTempParamLists = 0;
1791   if (isFriend && (NumTempParamLists = D->getNumTemplateParameterLists())) {
1792     TempParamLists.resize(NumTempParamLists);
1793     for (unsigned I = 0; I != NumTempParamLists; ++I) {
1794       TemplateParameterList *TempParams = D->getTemplateParameterList(I);
1795       TemplateParameterList *InstParams = SubstTemplateParams(TempParams);
1796       if (!InstParams)
1797         return nullptr;
1798       TempParamLists[I] = InstParams;
1799     }
1800   }
1801 
1802   SmallVector<ParmVarDecl *, 4> Params;
1803   TypeSourceInfo *TInfo = SubstFunctionType(D, Params);
1804   if (!TInfo)
1805     return nullptr;
1806   QualType T = adjustFunctionTypeForInstantiation(SemaRef.Context, D, TInfo);
1807 
1808   NestedNameSpecifierLoc QualifierLoc = D->getQualifierLoc();
1809   if (QualifierLoc) {
1810     QualifierLoc = SemaRef.SubstNestedNameSpecifierLoc(QualifierLoc,
1811                                                  TemplateArgs);
1812     if (!QualifierLoc)
1813       return nullptr;
1814   }
1815 
1816   DeclContext *DC = Owner;
1817   if (isFriend) {
1818     if (QualifierLoc) {
1819       CXXScopeSpec SS;
1820       SS.Adopt(QualifierLoc);
1821       DC = SemaRef.computeDeclContext(SS);
1822 
1823       if (DC && SemaRef.RequireCompleteDeclContext(SS, DC))
1824         return nullptr;
1825     } else {
1826       DC = SemaRef.FindInstantiatedContext(D->getLocation(),
1827                                            D->getDeclContext(),
1828                                            TemplateArgs);
1829     }
1830     if (!DC) return nullptr;
1831   }
1832 
1833   // Build the instantiated method declaration.
1834   CXXRecordDecl *Record = cast<CXXRecordDecl>(DC);
1835   CXXMethodDecl *Method = nullptr;
1836 
1837   SourceLocation StartLoc = D->getInnerLocStart();
1838   DeclarationNameInfo NameInfo
1839     = SemaRef.SubstDeclarationNameInfo(D->getNameInfo(), TemplateArgs);
1840   if (CXXConstructorDecl *Constructor = dyn_cast<CXXConstructorDecl>(D)) {
1841     Method = CXXConstructorDecl::Create(SemaRef.Context, Record,
1842                                         StartLoc, NameInfo, T, TInfo,
1843                                         Constructor->isExplicit(),
1844                                         Constructor->isInlineSpecified(),
1845                                         false, Constructor->isConstexpr());
1846 
1847     // Claim that the instantiation of a constructor or constructor template
1848     // inherits the same constructor that the template does.
1849     if (CXXConstructorDecl *Inh = const_cast<CXXConstructorDecl *>(
1850             Constructor->getInheritedConstructor())) {
1851       // If we're instantiating a specialization of a function template, our
1852       // "inherited constructor" will actually itself be a function template.
1853       // Instantiate a declaration of it, too.
1854       if (FunctionTemplate) {
1855         assert(!TemplateParams && Inh->getDescribedFunctionTemplate() &&
1856                !Inh->getParent()->isDependentContext() &&
1857                "inheriting constructor template in dependent context?");
1858         Sema::InstantiatingTemplate Inst(SemaRef, Constructor->getLocation(),
1859                                          Inh);
1860         if (Inst.isInvalid())
1861           return nullptr;
1862         Sema::ContextRAII SavedContext(SemaRef, Inh->getDeclContext());
1863         LocalInstantiationScope LocalScope(SemaRef);
1864 
1865         // Use the same template arguments that we deduced for the inheriting
1866         // constructor. There's no way they could be deduced differently.
1867         MultiLevelTemplateArgumentList InheritedArgs;
1868         InheritedArgs.addOuterTemplateArguments(TemplateArgs.getInnermost());
1869         Inh = cast_or_null<CXXConstructorDecl>(
1870             SemaRef.SubstDecl(Inh, Inh->getDeclContext(), InheritedArgs));
1871         if (!Inh)
1872           return nullptr;
1873       }
1874       cast<CXXConstructorDecl>(Method)->setInheritedConstructor(Inh);
1875     }
1876   } else if (CXXDestructorDecl *Destructor = dyn_cast<CXXDestructorDecl>(D)) {
1877     Method = CXXDestructorDecl::Create(SemaRef.Context, Record,
1878                                        StartLoc, NameInfo, T, TInfo,
1879                                        Destructor->isInlineSpecified(),
1880                                        false);
1881   } else if (CXXConversionDecl *Conversion = dyn_cast<CXXConversionDecl>(D)) {
1882     Method = CXXConversionDecl::Create(SemaRef.Context, Record,
1883                                        StartLoc, NameInfo, T, TInfo,
1884                                        Conversion->isInlineSpecified(),
1885                                        Conversion->isExplicit(),
1886                                        Conversion->isConstexpr(),
1887                                        Conversion->getLocEnd());
1888   } else {
1889     StorageClass SC = D->isStatic() ? SC_Static : SC_None;
1890     Method = CXXMethodDecl::Create(SemaRef.Context, Record,
1891                                    StartLoc, NameInfo, T, TInfo,
1892                                    SC, D->isInlineSpecified(),
1893                                    D->isConstexpr(), D->getLocEnd());
1894   }
1895 
1896   if (D->isInlined())
1897     Method->setImplicitlyInline();
1898 
1899   if (QualifierLoc)
1900     Method->setQualifierInfo(QualifierLoc);
1901 
1902   if (TemplateParams) {
1903     // Our resulting instantiation is actually a function template, since we
1904     // are substituting only the outer template parameters. For example, given
1905     //
1906     //   template<typename T>
1907     //   struct X {
1908     //     template<typename U> void f(T, U);
1909     //   };
1910     //
1911     //   X<int> x;
1912     //
1913     // We are instantiating the member template "f" within X<int>, which means
1914     // substituting int for T, but leaving "f" as a member function template.
1915     // Build the function template itself.
1916     FunctionTemplate = FunctionTemplateDecl::Create(SemaRef.Context, Record,
1917                                                     Method->getLocation(),
1918                                                     Method->getDeclName(),
1919                                                     TemplateParams, Method);
1920     if (isFriend) {
1921       FunctionTemplate->setLexicalDeclContext(Owner);
1922       FunctionTemplate->setObjectOfFriendDecl();
1923     } else if (D->isOutOfLine())
1924       FunctionTemplate->setLexicalDeclContext(D->getLexicalDeclContext());
1925     Method->setDescribedFunctionTemplate(FunctionTemplate);
1926   } else if (FunctionTemplate) {
1927     // Record this function template specialization.
1928     ArrayRef<TemplateArgument> Innermost = TemplateArgs.getInnermost();
1929     Method->setFunctionTemplateSpecialization(FunctionTemplate,
1930                          TemplateArgumentList::CreateCopy(SemaRef.Context,
1931                                                           Innermost.begin(),
1932                                                           Innermost.size()),
1933                                               /*InsertPos=*/nullptr);
1934   } else if (!isFriend) {
1935     // Record that this is an instantiation of a member function.
1936     Method->setInstantiationOfMemberFunction(D, TSK_ImplicitInstantiation);
1937   }
1938 
1939   // If we are instantiating a member function defined
1940   // out-of-line, the instantiation will have the same lexical
1941   // context (which will be a namespace scope) as the template.
1942   if (isFriend) {
1943     if (NumTempParamLists)
1944       Method->setTemplateParameterListsInfo(
1945           SemaRef.Context,
1946           llvm::makeArrayRef(TempParamLists.data(), NumTempParamLists));
1947 
1948     Method->setLexicalDeclContext(Owner);
1949     Method->setObjectOfFriendDecl();
1950   } else if (D->isOutOfLine())
1951     Method->setLexicalDeclContext(D->getLexicalDeclContext());
1952 
1953   // Attach the parameters
1954   for (unsigned P = 0; P < Params.size(); ++P)
1955     Params[P]->setOwningFunction(Method);
1956   Method->setParams(Params);
1957 
1958   if (InitMethodInstantiation(Method, D))
1959     Method->setInvalidDecl();
1960 
1961   LookupResult Previous(SemaRef, NameInfo, Sema::LookupOrdinaryName,
1962                         Sema::ForRedeclaration);
1963 
1964   if (!FunctionTemplate || TemplateParams || isFriend) {
1965     SemaRef.LookupQualifiedName(Previous, Record);
1966 
1967     // In C++, the previous declaration we find might be a tag type
1968     // (class or enum). In this case, the new declaration will hide the
1969     // tag type. Note that this does does not apply if we're declaring a
1970     // typedef (C++ [dcl.typedef]p4).
1971     if (Previous.isSingleTagDecl())
1972       Previous.clear();
1973   }
1974 
1975   if (!IsClassScopeSpecialization)
1976     SemaRef.CheckFunctionDeclaration(nullptr, Method, Previous, false);
1977 
1978   if (D->isPure())
1979     SemaRef.CheckPureMethod(Method, SourceRange());
1980 
1981   // Propagate access.  For a non-friend declaration, the access is
1982   // whatever we're propagating from.  For a friend, it should be the
1983   // previous declaration we just found.
1984   if (isFriend && Method->getPreviousDecl())
1985     Method->setAccess(Method->getPreviousDecl()->getAccess());
1986   else
1987     Method->setAccess(D->getAccess());
1988   if (FunctionTemplate)
1989     FunctionTemplate->setAccess(Method->getAccess());
1990 
1991   SemaRef.CheckOverrideControl(Method);
1992 
1993   // If a function is defined as defaulted or deleted, mark it as such now.
1994   if (D->isExplicitlyDefaulted())
1995     SemaRef.SetDeclDefaulted(Method, Method->getLocation());
1996   if (D->isDeletedAsWritten())
1997     SemaRef.SetDeclDeleted(Method, Method->getLocation());
1998 
1999   // If there's a function template, let our caller handle it.
2000   if (FunctionTemplate) {
2001     // do nothing
2002 
2003   // Don't hide a (potentially) valid declaration with an invalid one.
2004   } else if (Method->isInvalidDecl() && !Previous.empty()) {
2005     // do nothing
2006 
2007   // Otherwise, check access to friends and make them visible.
2008   } else if (isFriend) {
2009     // We only need to re-check access for methods which we didn't
2010     // manage to match during parsing.
2011     if (!D->getPreviousDecl())
2012       SemaRef.CheckFriendAccess(Method);
2013 
2014     Record->makeDeclVisibleInContext(Method);
2015 
2016   // Otherwise, add the declaration.  We don't need to do this for
2017   // class-scope specializations because we'll have matched them with
2018   // the appropriate template.
2019   } else if (!IsClassScopeSpecialization) {
2020     Owner->addDecl(Method);
2021   }
2022 
2023   return Method;
2024 }
2025 
2026 Decl *TemplateDeclInstantiator::VisitCXXConstructorDecl(CXXConstructorDecl *D) {
2027   return VisitCXXMethodDecl(D);
2028 }
2029 
2030 Decl *TemplateDeclInstantiator::VisitCXXDestructorDecl(CXXDestructorDecl *D) {
2031   return VisitCXXMethodDecl(D);
2032 }
2033 
2034 Decl *TemplateDeclInstantiator::VisitCXXConversionDecl(CXXConversionDecl *D) {
2035   return VisitCXXMethodDecl(D);
2036 }
2037 
2038 Decl *TemplateDeclInstantiator::VisitParmVarDecl(ParmVarDecl *D) {
2039   return SemaRef.SubstParmVarDecl(D, TemplateArgs, /*indexAdjustment*/ 0, None,
2040                                   /*ExpectParameterPack=*/ false);
2041 }
2042 
2043 Decl *TemplateDeclInstantiator::VisitTemplateTypeParmDecl(
2044                                                     TemplateTypeParmDecl *D) {
2045   // TODO: don't always clone when decls are refcounted.
2046   assert(D->getTypeForDecl()->isTemplateTypeParmType());
2047 
2048   TemplateTypeParmDecl *Inst =
2049     TemplateTypeParmDecl::Create(SemaRef.Context, Owner,
2050                                  D->getLocStart(), D->getLocation(),
2051                                  D->getDepth() - TemplateArgs.getNumLevels(),
2052                                  D->getIndex(), D->getIdentifier(),
2053                                  D->wasDeclaredWithTypename(),
2054                                  D->isParameterPack());
2055   Inst->setAccess(AS_public);
2056 
2057   if (D->hasDefaultArgument() && !D->defaultArgumentWasInherited()) {
2058     TypeSourceInfo *InstantiatedDefaultArg =
2059         SemaRef.SubstType(D->getDefaultArgumentInfo(), TemplateArgs,
2060                           D->getDefaultArgumentLoc(), D->getDeclName());
2061     if (InstantiatedDefaultArg)
2062       Inst->setDefaultArgument(InstantiatedDefaultArg);
2063   }
2064 
2065   // Introduce this template parameter's instantiation into the instantiation
2066   // scope.
2067   SemaRef.CurrentInstantiationScope->InstantiatedLocal(D, Inst);
2068 
2069   return Inst;
2070 }
2071 
2072 Decl *TemplateDeclInstantiator::VisitNonTypeTemplateParmDecl(
2073                                                  NonTypeTemplateParmDecl *D) {
2074   // Substitute into the type of the non-type template parameter.
2075   TypeLoc TL = D->getTypeSourceInfo()->getTypeLoc();
2076   SmallVector<TypeSourceInfo *, 4> ExpandedParameterPackTypesAsWritten;
2077   SmallVector<QualType, 4> ExpandedParameterPackTypes;
2078   bool IsExpandedParameterPack = false;
2079   TypeSourceInfo *DI;
2080   QualType T;
2081   bool Invalid = false;
2082 
2083   if (D->isExpandedParameterPack()) {
2084     // The non-type template parameter pack is an already-expanded pack
2085     // expansion of types. Substitute into each of the expanded types.
2086     ExpandedParameterPackTypes.reserve(D->getNumExpansionTypes());
2087     ExpandedParameterPackTypesAsWritten.reserve(D->getNumExpansionTypes());
2088     for (unsigned I = 0, N = D->getNumExpansionTypes(); I != N; ++I) {
2089       TypeSourceInfo *NewDI =SemaRef.SubstType(D->getExpansionTypeSourceInfo(I),
2090                                                TemplateArgs,
2091                                                D->getLocation(),
2092                                                D->getDeclName());
2093       if (!NewDI)
2094         return nullptr;
2095 
2096       ExpandedParameterPackTypesAsWritten.push_back(NewDI);
2097       QualType NewT =SemaRef.CheckNonTypeTemplateParameterType(NewDI->getType(),
2098                                                               D->getLocation());
2099       if (NewT.isNull())
2100         return nullptr;
2101       ExpandedParameterPackTypes.push_back(NewT);
2102     }
2103 
2104     IsExpandedParameterPack = true;
2105     DI = D->getTypeSourceInfo();
2106     T = DI->getType();
2107   } else if (D->isPackExpansion()) {
2108     // The non-type template parameter pack's type is a pack expansion of types.
2109     // Determine whether we need to expand this parameter pack into separate
2110     // types.
2111     PackExpansionTypeLoc Expansion = TL.castAs<PackExpansionTypeLoc>();
2112     TypeLoc Pattern = Expansion.getPatternLoc();
2113     SmallVector<UnexpandedParameterPack, 2> Unexpanded;
2114     SemaRef.collectUnexpandedParameterPacks(Pattern, Unexpanded);
2115 
2116     // Determine whether the set of unexpanded parameter packs can and should
2117     // be expanded.
2118     bool Expand = true;
2119     bool RetainExpansion = false;
2120     Optional<unsigned> OrigNumExpansions
2121       = Expansion.getTypePtr()->getNumExpansions();
2122     Optional<unsigned> NumExpansions = OrigNumExpansions;
2123     if (SemaRef.CheckParameterPacksForExpansion(Expansion.getEllipsisLoc(),
2124                                                 Pattern.getSourceRange(),
2125                                                 Unexpanded,
2126                                                 TemplateArgs,
2127                                                 Expand, RetainExpansion,
2128                                                 NumExpansions))
2129       return nullptr;
2130 
2131     if (Expand) {
2132       for (unsigned I = 0; I != *NumExpansions; ++I) {
2133         Sema::ArgumentPackSubstitutionIndexRAII SubstIndex(SemaRef, I);
2134         TypeSourceInfo *NewDI = SemaRef.SubstType(Pattern, TemplateArgs,
2135                                                   D->getLocation(),
2136                                                   D->getDeclName());
2137         if (!NewDI)
2138           return nullptr;
2139 
2140         ExpandedParameterPackTypesAsWritten.push_back(NewDI);
2141         QualType NewT = SemaRef.CheckNonTypeTemplateParameterType(
2142                                                               NewDI->getType(),
2143                                                               D->getLocation());
2144         if (NewT.isNull())
2145           return nullptr;
2146         ExpandedParameterPackTypes.push_back(NewT);
2147       }
2148 
2149       // Note that we have an expanded parameter pack. The "type" of this
2150       // expanded parameter pack is the original expansion type, but callers
2151       // will end up using the expanded parameter pack types for type-checking.
2152       IsExpandedParameterPack = true;
2153       DI = D->getTypeSourceInfo();
2154       T = DI->getType();
2155     } else {
2156       // We cannot fully expand the pack expansion now, so substitute into the
2157       // pattern and create a new pack expansion type.
2158       Sema::ArgumentPackSubstitutionIndexRAII SubstIndex(SemaRef, -1);
2159       TypeSourceInfo *NewPattern = SemaRef.SubstType(Pattern, TemplateArgs,
2160                                                      D->getLocation(),
2161                                                      D->getDeclName());
2162       if (!NewPattern)
2163         return nullptr;
2164 
2165       DI = SemaRef.CheckPackExpansion(NewPattern, Expansion.getEllipsisLoc(),
2166                                       NumExpansions);
2167       if (!DI)
2168         return nullptr;
2169 
2170       T = DI->getType();
2171     }
2172   } else {
2173     // Simple case: substitution into a parameter that is not a parameter pack.
2174     DI = SemaRef.SubstType(D->getTypeSourceInfo(), TemplateArgs,
2175                            D->getLocation(), D->getDeclName());
2176     if (!DI)
2177       return nullptr;
2178 
2179     // Check that this type is acceptable for a non-type template parameter.
2180     T = SemaRef.CheckNonTypeTemplateParameterType(DI->getType(),
2181                                                   D->getLocation());
2182     if (T.isNull()) {
2183       T = SemaRef.Context.IntTy;
2184       Invalid = true;
2185     }
2186   }
2187 
2188   NonTypeTemplateParmDecl *Param;
2189   if (IsExpandedParameterPack)
2190     Param = NonTypeTemplateParmDecl::Create(SemaRef.Context, Owner,
2191                                             D->getInnerLocStart(),
2192                                             D->getLocation(),
2193                                     D->getDepth() - TemplateArgs.getNumLevels(),
2194                                             D->getPosition(),
2195                                             D->getIdentifier(), T,
2196                                             DI,
2197                                             ExpandedParameterPackTypes.data(),
2198                                             ExpandedParameterPackTypes.size(),
2199                                     ExpandedParameterPackTypesAsWritten.data());
2200   else
2201     Param = NonTypeTemplateParmDecl::Create(SemaRef.Context, Owner,
2202                                             D->getInnerLocStart(),
2203                                             D->getLocation(),
2204                                     D->getDepth() - TemplateArgs.getNumLevels(),
2205                                             D->getPosition(),
2206                                             D->getIdentifier(), T,
2207                                             D->isParameterPack(), DI);
2208 
2209   Param->setAccess(AS_public);
2210   if (Invalid)
2211     Param->setInvalidDecl();
2212 
2213   if (D->hasDefaultArgument() && !D->defaultArgumentWasInherited()) {
2214     EnterExpressionEvaluationContext ConstantEvaluated(SemaRef,
2215                                                        Sema::ConstantEvaluated);
2216     ExprResult Value = SemaRef.SubstExpr(D->getDefaultArgument(), TemplateArgs);
2217     if (!Value.isInvalid())
2218       Param->setDefaultArgument(Value.get());
2219   }
2220 
2221   // Introduce this template parameter's instantiation into the instantiation
2222   // scope.
2223   SemaRef.CurrentInstantiationScope->InstantiatedLocal(D, Param);
2224   return Param;
2225 }
2226 
2227 static void collectUnexpandedParameterPacks(
2228     Sema &S,
2229     TemplateParameterList *Params,
2230     SmallVectorImpl<UnexpandedParameterPack> &Unexpanded) {
2231   for (const auto &P : *Params) {
2232     if (P->isTemplateParameterPack())
2233       continue;
2234     if (NonTypeTemplateParmDecl *NTTP = dyn_cast<NonTypeTemplateParmDecl>(P))
2235       S.collectUnexpandedParameterPacks(NTTP->getTypeSourceInfo()->getTypeLoc(),
2236                                         Unexpanded);
2237     if (TemplateTemplateParmDecl *TTP = dyn_cast<TemplateTemplateParmDecl>(P))
2238       collectUnexpandedParameterPacks(S, TTP->getTemplateParameters(),
2239                                       Unexpanded);
2240   }
2241 }
2242 
2243 Decl *
2244 TemplateDeclInstantiator::VisitTemplateTemplateParmDecl(
2245                                                   TemplateTemplateParmDecl *D) {
2246   // Instantiate the template parameter list of the template template parameter.
2247   TemplateParameterList *TempParams = D->getTemplateParameters();
2248   TemplateParameterList *InstParams;
2249   SmallVector<TemplateParameterList*, 8> ExpandedParams;
2250 
2251   bool IsExpandedParameterPack = false;
2252 
2253   if (D->isExpandedParameterPack()) {
2254     // The template template parameter pack is an already-expanded pack
2255     // expansion of template parameters. Substitute into each of the expanded
2256     // parameters.
2257     ExpandedParams.reserve(D->getNumExpansionTemplateParameters());
2258     for (unsigned I = 0, N = D->getNumExpansionTemplateParameters();
2259          I != N; ++I) {
2260       LocalInstantiationScope Scope(SemaRef);
2261       TemplateParameterList *Expansion =
2262         SubstTemplateParams(D->getExpansionTemplateParameters(I));
2263       if (!Expansion)
2264         return nullptr;
2265       ExpandedParams.push_back(Expansion);
2266     }
2267 
2268     IsExpandedParameterPack = true;
2269     InstParams = TempParams;
2270   } else if (D->isPackExpansion()) {
2271     // The template template parameter pack expands to a pack of template
2272     // template parameters. Determine whether we need to expand this parameter
2273     // pack into separate parameters.
2274     SmallVector<UnexpandedParameterPack, 2> Unexpanded;
2275     collectUnexpandedParameterPacks(SemaRef, D->getTemplateParameters(),
2276                                     Unexpanded);
2277 
2278     // Determine whether the set of unexpanded parameter packs can and should
2279     // be expanded.
2280     bool Expand = true;
2281     bool RetainExpansion = false;
2282     Optional<unsigned> NumExpansions;
2283     if (SemaRef.CheckParameterPacksForExpansion(D->getLocation(),
2284                                                 TempParams->getSourceRange(),
2285                                                 Unexpanded,
2286                                                 TemplateArgs,
2287                                                 Expand, RetainExpansion,
2288                                                 NumExpansions))
2289       return nullptr;
2290 
2291     if (Expand) {
2292       for (unsigned I = 0; I != *NumExpansions; ++I) {
2293         Sema::ArgumentPackSubstitutionIndexRAII SubstIndex(SemaRef, I);
2294         LocalInstantiationScope Scope(SemaRef);
2295         TemplateParameterList *Expansion = SubstTemplateParams(TempParams);
2296         if (!Expansion)
2297           return nullptr;
2298         ExpandedParams.push_back(Expansion);
2299       }
2300 
2301       // Note that we have an expanded parameter pack. The "type" of this
2302       // expanded parameter pack is the original expansion type, but callers
2303       // will end up using the expanded parameter pack types for type-checking.
2304       IsExpandedParameterPack = true;
2305       InstParams = TempParams;
2306     } else {
2307       // We cannot fully expand the pack expansion now, so just substitute
2308       // into the pattern.
2309       Sema::ArgumentPackSubstitutionIndexRAII SubstIndex(SemaRef, -1);
2310 
2311       LocalInstantiationScope Scope(SemaRef);
2312       InstParams = SubstTemplateParams(TempParams);
2313       if (!InstParams)
2314         return nullptr;
2315     }
2316   } else {
2317     // Perform the actual substitution of template parameters within a new,
2318     // local instantiation scope.
2319     LocalInstantiationScope Scope(SemaRef);
2320     InstParams = SubstTemplateParams(TempParams);
2321     if (!InstParams)
2322       return nullptr;
2323   }
2324 
2325   // Build the template template parameter.
2326   TemplateTemplateParmDecl *Param;
2327   if (IsExpandedParameterPack)
2328     Param = TemplateTemplateParmDecl::Create(SemaRef.Context, Owner,
2329                                              D->getLocation(),
2330                                    D->getDepth() - TemplateArgs.getNumLevels(),
2331                                              D->getPosition(),
2332                                              D->getIdentifier(), InstParams,
2333                                              ExpandedParams);
2334   else
2335     Param = TemplateTemplateParmDecl::Create(SemaRef.Context, Owner,
2336                                              D->getLocation(),
2337                                    D->getDepth() - TemplateArgs.getNumLevels(),
2338                                              D->getPosition(),
2339                                              D->isParameterPack(),
2340                                              D->getIdentifier(), InstParams);
2341   if (D->hasDefaultArgument() && !D->defaultArgumentWasInherited()) {
2342     NestedNameSpecifierLoc QualifierLoc =
2343         D->getDefaultArgument().getTemplateQualifierLoc();
2344     QualifierLoc =
2345         SemaRef.SubstNestedNameSpecifierLoc(QualifierLoc, TemplateArgs);
2346     TemplateName TName = SemaRef.SubstTemplateName(
2347         QualifierLoc, D->getDefaultArgument().getArgument().getAsTemplate(),
2348         D->getDefaultArgument().getTemplateNameLoc(), TemplateArgs);
2349     if (!TName.isNull())
2350       Param->setDefaultArgument(
2351           SemaRef.Context,
2352           TemplateArgumentLoc(TemplateArgument(TName),
2353                               D->getDefaultArgument().getTemplateQualifierLoc(),
2354                               D->getDefaultArgument().getTemplateNameLoc()));
2355   }
2356   Param->setAccess(AS_public);
2357 
2358   // Introduce this template parameter's instantiation into the instantiation
2359   // scope.
2360   SemaRef.CurrentInstantiationScope->InstantiatedLocal(D, Param);
2361 
2362   return Param;
2363 }
2364 
2365 Decl *TemplateDeclInstantiator::VisitUsingDirectiveDecl(UsingDirectiveDecl *D) {
2366   // Using directives are never dependent (and never contain any types or
2367   // expressions), so they require no explicit instantiation work.
2368 
2369   UsingDirectiveDecl *Inst
2370     = UsingDirectiveDecl::Create(SemaRef.Context, Owner, D->getLocation(),
2371                                  D->getNamespaceKeyLocation(),
2372                                  D->getQualifierLoc(),
2373                                  D->getIdentLocation(),
2374                                  D->getNominatedNamespace(),
2375                                  D->getCommonAncestor());
2376 
2377   // Add the using directive to its declaration context
2378   // only if this is not a function or method.
2379   if (!Owner->isFunctionOrMethod())
2380     Owner->addDecl(Inst);
2381 
2382   return Inst;
2383 }
2384 
2385 Decl *TemplateDeclInstantiator::VisitUsingDecl(UsingDecl *D) {
2386 
2387   // The nested name specifier may be dependent, for example
2388   //     template <typename T> struct t {
2389   //       struct s1 { T f1(); };
2390   //       struct s2 : s1 { using s1::f1; };
2391   //     };
2392   //     template struct t<int>;
2393   // Here, in using s1::f1, s1 refers to t<T>::s1;
2394   // we need to substitute for t<int>::s1.
2395   NestedNameSpecifierLoc QualifierLoc
2396     = SemaRef.SubstNestedNameSpecifierLoc(D->getQualifierLoc(),
2397                                           TemplateArgs);
2398   if (!QualifierLoc)
2399     return nullptr;
2400 
2401   // The name info is non-dependent, so no transformation
2402   // is required.
2403   DeclarationNameInfo NameInfo = D->getNameInfo();
2404 
2405   // We only need to do redeclaration lookups if we're in a class
2406   // scope (in fact, it's not really even possible in non-class
2407   // scopes).
2408   bool CheckRedeclaration = Owner->isRecord();
2409 
2410   LookupResult Prev(SemaRef, NameInfo, Sema::LookupUsingDeclName,
2411                     Sema::ForRedeclaration);
2412 
2413   UsingDecl *NewUD = UsingDecl::Create(SemaRef.Context, Owner,
2414                                        D->getUsingLoc(),
2415                                        QualifierLoc,
2416                                        NameInfo,
2417                                        D->hasTypename());
2418 
2419   CXXScopeSpec SS;
2420   SS.Adopt(QualifierLoc);
2421   if (CheckRedeclaration) {
2422     Prev.setHideTags(false);
2423     SemaRef.LookupQualifiedName(Prev, Owner);
2424 
2425     // Check for invalid redeclarations.
2426     if (SemaRef.CheckUsingDeclRedeclaration(D->getUsingLoc(),
2427                                             D->hasTypename(), SS,
2428                                             D->getLocation(), Prev))
2429       NewUD->setInvalidDecl();
2430 
2431   }
2432 
2433   if (!NewUD->isInvalidDecl() &&
2434       SemaRef.CheckUsingDeclQualifier(D->getUsingLoc(), SS, NameInfo,
2435                                       D->getLocation()))
2436     NewUD->setInvalidDecl();
2437 
2438   SemaRef.Context.setInstantiatedFromUsingDecl(NewUD, D);
2439   NewUD->setAccess(D->getAccess());
2440   Owner->addDecl(NewUD);
2441 
2442   // Don't process the shadow decls for an invalid decl.
2443   if (NewUD->isInvalidDecl())
2444     return NewUD;
2445 
2446   if (NameInfo.getName().getNameKind() == DeclarationName::CXXConstructorName) {
2447     SemaRef.CheckInheritingConstructorUsingDecl(NewUD);
2448     return NewUD;
2449   }
2450 
2451   bool isFunctionScope = Owner->isFunctionOrMethod();
2452 
2453   // Process the shadow decls.
2454   for (auto *Shadow : D->shadows()) {
2455     NamedDecl *InstTarget =
2456         cast_or_null<NamedDecl>(SemaRef.FindInstantiatedDecl(
2457             Shadow->getLocation(), Shadow->getTargetDecl(), TemplateArgs));
2458     if (!InstTarget)
2459       return nullptr;
2460 
2461     UsingShadowDecl *PrevDecl = nullptr;
2462     if (CheckRedeclaration) {
2463       if (SemaRef.CheckUsingShadowDecl(NewUD, InstTarget, Prev, PrevDecl))
2464         continue;
2465     } else if (UsingShadowDecl *OldPrev =
2466                    getPreviousDeclForInstantiation(Shadow)) {
2467       PrevDecl = cast_or_null<UsingShadowDecl>(SemaRef.FindInstantiatedDecl(
2468           Shadow->getLocation(), OldPrev, TemplateArgs));
2469     }
2470 
2471     UsingShadowDecl *InstShadow =
2472         SemaRef.BuildUsingShadowDecl(/*Scope*/nullptr, NewUD, InstTarget,
2473                                      PrevDecl);
2474     SemaRef.Context.setInstantiatedFromUsingShadowDecl(InstShadow, Shadow);
2475 
2476     if (isFunctionScope)
2477       SemaRef.CurrentInstantiationScope->InstantiatedLocal(Shadow, InstShadow);
2478   }
2479 
2480   return NewUD;
2481 }
2482 
2483 Decl *TemplateDeclInstantiator::VisitUsingShadowDecl(UsingShadowDecl *D) {
2484   // Ignore these;  we handle them in bulk when processing the UsingDecl.
2485   return nullptr;
2486 }
2487 
2488 Decl * TemplateDeclInstantiator
2489     ::VisitUnresolvedUsingTypenameDecl(UnresolvedUsingTypenameDecl *D) {
2490   NestedNameSpecifierLoc QualifierLoc
2491     = SemaRef.SubstNestedNameSpecifierLoc(D->getQualifierLoc(),
2492                                           TemplateArgs);
2493   if (!QualifierLoc)
2494     return nullptr;
2495 
2496   CXXScopeSpec SS;
2497   SS.Adopt(QualifierLoc);
2498 
2499   // Since NameInfo refers to a typename, it cannot be a C++ special name.
2500   // Hence, no transformation is required for it.
2501   DeclarationNameInfo NameInfo(D->getDeclName(), D->getLocation());
2502   NamedDecl *UD =
2503     SemaRef.BuildUsingDeclaration(/*Scope*/ nullptr, D->getAccess(),
2504                                   D->getUsingLoc(), SS, NameInfo, nullptr,
2505                                   /*instantiation*/ true,
2506                                   /*typename*/ true, D->getTypenameLoc());
2507   if (UD)
2508     SemaRef.Context.setInstantiatedFromUsingDecl(cast<UsingDecl>(UD), D);
2509 
2510   return UD;
2511 }
2512 
2513 Decl * TemplateDeclInstantiator
2514     ::VisitUnresolvedUsingValueDecl(UnresolvedUsingValueDecl *D) {
2515   NestedNameSpecifierLoc QualifierLoc
2516       = SemaRef.SubstNestedNameSpecifierLoc(D->getQualifierLoc(), TemplateArgs);
2517   if (!QualifierLoc)
2518     return nullptr;
2519 
2520   CXXScopeSpec SS;
2521   SS.Adopt(QualifierLoc);
2522 
2523   DeclarationNameInfo NameInfo
2524     = SemaRef.SubstDeclarationNameInfo(D->getNameInfo(), TemplateArgs);
2525 
2526   NamedDecl *UD =
2527     SemaRef.BuildUsingDeclaration(/*Scope*/ nullptr, D->getAccess(),
2528                                   D->getUsingLoc(), SS, NameInfo, nullptr,
2529                                   /*instantiation*/ true,
2530                                   /*typename*/ false, SourceLocation());
2531   if (UD)
2532     SemaRef.Context.setInstantiatedFromUsingDecl(cast<UsingDecl>(UD), D);
2533 
2534   return UD;
2535 }
2536 
2537 
2538 Decl *TemplateDeclInstantiator::VisitClassScopeFunctionSpecializationDecl(
2539                                      ClassScopeFunctionSpecializationDecl *Decl) {
2540   CXXMethodDecl *OldFD = Decl->getSpecialization();
2541   CXXMethodDecl *NewFD =
2542     cast_or_null<CXXMethodDecl>(VisitCXXMethodDecl(OldFD, nullptr, true));
2543   if (!NewFD)
2544     return nullptr;
2545 
2546   LookupResult Previous(SemaRef, NewFD->getNameInfo(), Sema::LookupOrdinaryName,
2547                         Sema::ForRedeclaration);
2548 
2549   TemplateArgumentListInfo TemplateArgs;
2550   TemplateArgumentListInfo *TemplateArgsPtr = nullptr;
2551   if (Decl->hasExplicitTemplateArgs()) {
2552     TemplateArgs = Decl->templateArgs();
2553     TemplateArgsPtr = &TemplateArgs;
2554   }
2555 
2556   SemaRef.LookupQualifiedName(Previous, SemaRef.CurContext);
2557   if (SemaRef.CheckFunctionTemplateSpecialization(NewFD, TemplateArgsPtr,
2558                                                   Previous)) {
2559     NewFD->setInvalidDecl();
2560     return NewFD;
2561   }
2562 
2563   // Associate the specialization with the pattern.
2564   FunctionDecl *Specialization = cast<FunctionDecl>(Previous.getFoundDecl());
2565   assert(Specialization && "Class scope Specialization is null");
2566   SemaRef.Context.setClassScopeSpecializationPattern(Specialization, OldFD);
2567 
2568   return NewFD;
2569 }
2570 
2571 Decl *TemplateDeclInstantiator::VisitOMPThreadPrivateDecl(
2572                                      OMPThreadPrivateDecl *D) {
2573   SmallVector<Expr *, 5> Vars;
2574   for (auto *I : D->varlists()) {
2575     Expr *Var = SemaRef.SubstExpr(I, TemplateArgs).get();
2576     assert(isa<DeclRefExpr>(Var) && "threadprivate arg is not a DeclRefExpr");
2577     Vars.push_back(Var);
2578   }
2579 
2580   OMPThreadPrivateDecl *TD =
2581     SemaRef.CheckOMPThreadPrivateDecl(D->getLocation(), Vars);
2582 
2583   TD->setAccess(AS_public);
2584   Owner->addDecl(TD);
2585 
2586   return TD;
2587 }
2588 
2589 Decl *TemplateDeclInstantiator::VisitOMPDeclareReductionDecl(
2590     OMPDeclareReductionDecl *D) {
2591   // Instantiate type and check if it is allowed.
2592   QualType SubstReductionType = SemaRef.ActOnOpenMPDeclareReductionType(
2593       D->getLocation(),
2594       ParsedType::make(SemaRef.SubstType(D->getType(), TemplateArgs,
2595                                          D->getLocation(), DeclarationName())));
2596   if (SubstReductionType.isNull())
2597     return nullptr;
2598   bool IsCorrect = !SubstReductionType.isNull();
2599   // Create instantiated copy.
2600   std::pair<QualType, SourceLocation> ReductionTypes[] = {
2601       std::make_pair(SubstReductionType, D->getLocation())};
2602   auto *PrevDeclInScope = D->getPrevDeclInScope();
2603   if (PrevDeclInScope && !PrevDeclInScope->isInvalidDecl()) {
2604     PrevDeclInScope = cast<OMPDeclareReductionDecl>(
2605         SemaRef.CurrentInstantiationScope->findInstantiationOf(PrevDeclInScope)
2606             ->get<Decl *>());
2607   }
2608   auto DRD = SemaRef.ActOnOpenMPDeclareReductionDirectiveStart(
2609       /*S=*/nullptr, Owner, D->getDeclName(), ReductionTypes, D->getAccess(),
2610       PrevDeclInScope);
2611   auto *NewDRD = cast<OMPDeclareReductionDecl>(DRD.get().getSingleDecl());
2612   if (isDeclWithinFunction(NewDRD))
2613     SemaRef.CurrentInstantiationScope->InstantiatedLocal(D, NewDRD);
2614   Expr *SubstCombiner = nullptr;
2615   Expr *SubstInitializer = nullptr;
2616   // Combiners instantiation sequence.
2617   if (D->getCombiner()) {
2618     SemaRef.ActOnOpenMPDeclareReductionCombinerStart(
2619         /*S=*/nullptr, NewDRD);
2620     const char *Names[] = {"omp_in", "omp_out"};
2621     for (auto &Name : Names) {
2622       DeclarationName DN(&SemaRef.Context.Idents.get(Name));
2623       auto OldLookup = D->lookup(DN);
2624       auto Lookup = NewDRD->lookup(DN);
2625       if (!OldLookup.empty() && !Lookup.empty()) {
2626         assert(Lookup.size() == 1 && OldLookup.size() == 1);
2627         SemaRef.CurrentInstantiationScope->InstantiatedLocal(OldLookup.front(),
2628                                                              Lookup.front());
2629       }
2630     }
2631     SubstCombiner = SemaRef.SubstExpr(D->getCombiner(), TemplateArgs).get();
2632     SemaRef.ActOnOpenMPDeclareReductionCombinerEnd(NewDRD, SubstCombiner);
2633     // Initializers instantiation sequence.
2634     if (D->getInitializer()) {
2635       SemaRef.ActOnOpenMPDeclareReductionInitializerStart(
2636           /*S=*/nullptr, NewDRD);
2637       const char *Names[] = {"omp_orig", "omp_priv"};
2638       for (auto &Name : Names) {
2639         DeclarationName DN(&SemaRef.Context.Idents.get(Name));
2640         auto OldLookup = D->lookup(DN);
2641         auto Lookup = NewDRD->lookup(DN);
2642         if (!OldLookup.empty() && !Lookup.empty()) {
2643           assert(Lookup.size() == 1 && OldLookup.size() == 1);
2644           SemaRef.CurrentInstantiationScope->InstantiatedLocal(
2645               OldLookup.front(), Lookup.front());
2646         }
2647       }
2648       SubstInitializer =
2649           SemaRef.SubstExpr(D->getInitializer(), TemplateArgs).get();
2650       SemaRef.ActOnOpenMPDeclareReductionInitializerEnd(NewDRD,
2651                                                         SubstInitializer);
2652     }
2653     IsCorrect = IsCorrect && SubstCombiner &&
2654                 (!D->getInitializer() || SubstInitializer);
2655   } else
2656     IsCorrect = false;
2657 
2658   (void)SemaRef.ActOnOpenMPDeclareReductionDirectiveEnd(/*S=*/nullptr, DRD,
2659                                                         IsCorrect);
2660 
2661   return NewDRD;
2662 }
2663 
2664 Decl *TemplateDeclInstantiator::VisitOMPCapturedExprDecl(
2665     OMPCapturedExprDecl * /*D*/) {
2666   llvm_unreachable("Should not be met in templates");
2667 }
2668 
2669 Decl *TemplateDeclInstantiator::VisitFunctionDecl(FunctionDecl *D) {
2670   return VisitFunctionDecl(D, nullptr);
2671 }
2672 
2673 Decl *TemplateDeclInstantiator::VisitCXXMethodDecl(CXXMethodDecl *D) {
2674   return VisitCXXMethodDecl(D, nullptr);
2675 }
2676 
2677 Decl *TemplateDeclInstantiator::VisitRecordDecl(RecordDecl *D) {
2678   llvm_unreachable("There are only CXXRecordDecls in C++");
2679 }
2680 
2681 Decl *
2682 TemplateDeclInstantiator::VisitClassTemplateSpecializationDecl(
2683     ClassTemplateSpecializationDecl *D) {
2684   // As a MS extension, we permit class-scope explicit specialization
2685   // of member class templates.
2686   ClassTemplateDecl *ClassTemplate = D->getSpecializedTemplate();
2687   assert(ClassTemplate->getDeclContext()->isRecord() &&
2688          D->getTemplateSpecializationKind() == TSK_ExplicitSpecialization &&
2689          "can only instantiate an explicit specialization "
2690          "for a member class template");
2691 
2692   // Lookup the already-instantiated declaration in the instantiation
2693   // of the class template. FIXME: Diagnose or assert if this fails?
2694   DeclContext::lookup_result Found
2695     = Owner->lookup(ClassTemplate->getDeclName());
2696   if (Found.empty())
2697     return nullptr;
2698   ClassTemplateDecl *InstClassTemplate
2699     = dyn_cast<ClassTemplateDecl>(Found.front());
2700   if (!InstClassTemplate)
2701     return nullptr;
2702 
2703   // Substitute into the template arguments of the class template explicit
2704   // specialization.
2705   TemplateSpecializationTypeLoc Loc = D->getTypeAsWritten()->getTypeLoc().
2706                                         castAs<TemplateSpecializationTypeLoc>();
2707   TemplateArgumentListInfo InstTemplateArgs(Loc.getLAngleLoc(),
2708                                             Loc.getRAngleLoc());
2709   SmallVector<TemplateArgumentLoc, 4> ArgLocs;
2710   for (unsigned I = 0; I != Loc.getNumArgs(); ++I)
2711     ArgLocs.push_back(Loc.getArgLoc(I));
2712   if (SemaRef.Subst(ArgLocs.data(), ArgLocs.size(),
2713                     InstTemplateArgs, TemplateArgs))
2714     return nullptr;
2715 
2716   // Check that the template argument list is well-formed for this
2717   // class template.
2718   SmallVector<TemplateArgument, 4> Converted;
2719   if (SemaRef.CheckTemplateArgumentList(InstClassTemplate,
2720                                         D->getLocation(),
2721                                         InstTemplateArgs,
2722                                         false,
2723                                         Converted))
2724     return nullptr;
2725 
2726   // Figure out where to insert this class template explicit specialization
2727   // in the member template's set of class template explicit specializations.
2728   void *InsertPos = nullptr;
2729   ClassTemplateSpecializationDecl *PrevDecl =
2730       InstClassTemplate->findSpecialization(Converted, InsertPos);
2731 
2732   // Check whether we've already seen a conflicting instantiation of this
2733   // declaration (for instance, if there was a prior implicit instantiation).
2734   bool Ignored;
2735   if (PrevDecl &&
2736       SemaRef.CheckSpecializationInstantiationRedecl(D->getLocation(),
2737                                                      D->getSpecializationKind(),
2738                                                      PrevDecl,
2739                                                      PrevDecl->getSpecializationKind(),
2740                                                      PrevDecl->getPointOfInstantiation(),
2741                                                      Ignored))
2742     return nullptr;
2743 
2744   // If PrevDecl was a definition and D is also a definition, diagnose.
2745   // This happens in cases like:
2746   //
2747   //   template<typename T, typename U>
2748   //   struct Outer {
2749   //     template<typename X> struct Inner;
2750   //     template<> struct Inner<T> {};
2751   //     template<> struct Inner<U> {};
2752   //   };
2753   //
2754   //   Outer<int, int> outer; // error: the explicit specializations of Inner
2755   //                          // have the same signature.
2756   if (PrevDecl && PrevDecl->getDefinition() &&
2757       D->isThisDeclarationADefinition()) {
2758     SemaRef.Diag(D->getLocation(), diag::err_redefinition) << PrevDecl;
2759     SemaRef.Diag(PrevDecl->getDefinition()->getLocation(),
2760                  diag::note_previous_definition);
2761     return nullptr;
2762   }
2763 
2764   // Create the class template partial specialization declaration.
2765   ClassTemplateSpecializationDecl *InstD
2766     = ClassTemplateSpecializationDecl::Create(SemaRef.Context,
2767                                               D->getTagKind(),
2768                                               Owner,
2769                                               D->getLocStart(),
2770                                               D->getLocation(),
2771                                               InstClassTemplate,
2772                                               Converted.data(),
2773                                               Converted.size(),
2774                                               PrevDecl);
2775 
2776   // Add this partial specialization to the set of class template partial
2777   // specializations.
2778   if (!PrevDecl)
2779     InstClassTemplate->AddSpecialization(InstD, InsertPos);
2780 
2781   // Substitute the nested name specifier, if any.
2782   if (SubstQualifier(D, InstD))
2783     return nullptr;
2784 
2785   // Build the canonical type that describes the converted template
2786   // arguments of the class template explicit specialization.
2787   QualType CanonType = SemaRef.Context.getTemplateSpecializationType(
2788       TemplateName(InstClassTemplate), Converted.data(), Converted.size(),
2789       SemaRef.Context.getRecordType(InstD));
2790 
2791   // Build the fully-sugared type for this class template
2792   // specialization as the user wrote in the specialization
2793   // itself. This means that we'll pretty-print the type retrieved
2794   // from the specialization's declaration the way that the user
2795   // actually wrote the specialization, rather than formatting the
2796   // name based on the "canonical" representation used to store the
2797   // template arguments in the specialization.
2798   TypeSourceInfo *WrittenTy = SemaRef.Context.getTemplateSpecializationTypeInfo(
2799       TemplateName(InstClassTemplate), D->getLocation(), InstTemplateArgs,
2800       CanonType);
2801 
2802   InstD->setAccess(D->getAccess());
2803   InstD->setInstantiationOfMemberClass(D, TSK_ImplicitInstantiation);
2804   InstD->setSpecializationKind(D->getSpecializationKind());
2805   InstD->setTypeAsWritten(WrittenTy);
2806   InstD->setExternLoc(D->getExternLoc());
2807   InstD->setTemplateKeywordLoc(D->getTemplateKeywordLoc());
2808 
2809   Owner->addDecl(InstD);
2810 
2811   // Instantiate the members of the class-scope explicit specialization eagerly.
2812   // We don't have support for lazy instantiation of an explicit specialization
2813   // yet, and MSVC eagerly instantiates in this case.
2814   if (D->isThisDeclarationADefinition() &&
2815       SemaRef.InstantiateClass(D->getLocation(), InstD, D, TemplateArgs,
2816                                TSK_ImplicitInstantiation,
2817                                /*Complain=*/true))
2818     return nullptr;
2819 
2820   return InstD;
2821 }
2822 
2823 Decl *TemplateDeclInstantiator::VisitVarTemplateSpecializationDecl(
2824     VarTemplateSpecializationDecl *D) {
2825 
2826   TemplateArgumentListInfo VarTemplateArgsInfo;
2827   VarTemplateDecl *VarTemplate = D->getSpecializedTemplate();
2828   assert(VarTemplate &&
2829          "A template specialization without specialized template?");
2830 
2831   // Substitute the current template arguments.
2832   const TemplateArgumentListInfo &TemplateArgsInfo = D->getTemplateArgsInfo();
2833   VarTemplateArgsInfo.setLAngleLoc(TemplateArgsInfo.getLAngleLoc());
2834   VarTemplateArgsInfo.setRAngleLoc(TemplateArgsInfo.getRAngleLoc());
2835 
2836   if (SemaRef.Subst(TemplateArgsInfo.getArgumentArray(),
2837                     TemplateArgsInfo.size(), VarTemplateArgsInfo, TemplateArgs))
2838     return nullptr;
2839 
2840   // Check that the template argument list is well-formed for this template.
2841   SmallVector<TemplateArgument, 4> Converted;
2842   if (SemaRef.CheckTemplateArgumentList(
2843           VarTemplate, VarTemplate->getLocStart(),
2844           const_cast<TemplateArgumentListInfo &>(VarTemplateArgsInfo), false,
2845           Converted))
2846     return nullptr;
2847 
2848   // Find the variable template specialization declaration that
2849   // corresponds to these arguments.
2850   void *InsertPos = nullptr;
2851   if (VarTemplateSpecializationDecl *VarSpec = VarTemplate->findSpecialization(
2852           Converted, InsertPos))
2853     // If we already have a variable template specialization, return it.
2854     return VarSpec;
2855 
2856   return VisitVarTemplateSpecializationDecl(VarTemplate, D, InsertPos,
2857                                             VarTemplateArgsInfo, Converted);
2858 }
2859 
2860 Decl *TemplateDeclInstantiator::VisitVarTemplateSpecializationDecl(
2861     VarTemplateDecl *VarTemplate, VarDecl *D, void *InsertPos,
2862     const TemplateArgumentListInfo &TemplateArgsInfo,
2863     ArrayRef<TemplateArgument> Converted) {
2864 
2865   // Do substitution on the type of the declaration
2866   TypeSourceInfo *DI =
2867       SemaRef.SubstType(D->getTypeSourceInfo(), TemplateArgs,
2868                         D->getTypeSpecStartLoc(), D->getDeclName());
2869   if (!DI)
2870     return nullptr;
2871 
2872   if (DI->getType()->isFunctionType()) {
2873     SemaRef.Diag(D->getLocation(), diag::err_variable_instantiates_to_function)
2874         << D->isStaticDataMember() << DI->getType();
2875     return nullptr;
2876   }
2877 
2878   // Build the instantiated declaration
2879   VarTemplateSpecializationDecl *Var = VarTemplateSpecializationDecl::Create(
2880       SemaRef.Context, Owner, D->getInnerLocStart(), D->getLocation(),
2881       VarTemplate, DI->getType(), DI, D->getStorageClass(), Converted.data(),
2882       Converted.size());
2883   Var->setTemplateArgsInfo(TemplateArgsInfo);
2884   if (InsertPos)
2885     VarTemplate->AddSpecialization(Var, InsertPos);
2886 
2887   // Substitute the nested name specifier, if any.
2888   if (SubstQualifier(D, Var))
2889     return nullptr;
2890 
2891   SemaRef.BuildVariableInstantiation(Var, D, TemplateArgs, LateAttrs,
2892                                      Owner, StartingScope);
2893 
2894   return Var;
2895 }
2896 
2897 Decl *TemplateDeclInstantiator::VisitObjCAtDefsFieldDecl(ObjCAtDefsFieldDecl *D) {
2898   llvm_unreachable("@defs is not supported in Objective-C++");
2899 }
2900 
2901 Decl *TemplateDeclInstantiator::VisitFriendTemplateDecl(FriendTemplateDecl *D) {
2902   // FIXME: We need to be able to instantiate FriendTemplateDecls.
2903   unsigned DiagID = SemaRef.getDiagnostics().getCustomDiagID(
2904                                                DiagnosticsEngine::Error,
2905                                                "cannot instantiate %0 yet");
2906   SemaRef.Diag(D->getLocation(), DiagID)
2907     << D->getDeclKindName();
2908 
2909   return nullptr;
2910 }
2911 
2912 Decl *TemplateDeclInstantiator::VisitDecl(Decl *D) {
2913   llvm_unreachable("Unexpected decl");
2914 }
2915 
2916 Decl *Sema::SubstDecl(Decl *D, DeclContext *Owner,
2917                       const MultiLevelTemplateArgumentList &TemplateArgs) {
2918   TemplateDeclInstantiator Instantiator(*this, Owner, TemplateArgs);
2919   if (D->isInvalidDecl())
2920     return nullptr;
2921 
2922   return Instantiator.Visit(D);
2923 }
2924 
2925 /// \brief Instantiates a nested template parameter list in the current
2926 /// instantiation context.
2927 ///
2928 /// \param L The parameter list to instantiate
2929 ///
2930 /// \returns NULL if there was an error
2931 TemplateParameterList *
2932 TemplateDeclInstantiator::SubstTemplateParams(TemplateParameterList *L) {
2933   // Get errors for all the parameters before bailing out.
2934   bool Invalid = false;
2935 
2936   unsigned N = L->size();
2937   typedef SmallVector<NamedDecl *, 8> ParamVector;
2938   ParamVector Params;
2939   Params.reserve(N);
2940   for (auto &P : *L) {
2941     NamedDecl *D = cast_or_null<NamedDecl>(Visit(P));
2942     Params.push_back(D);
2943     Invalid = Invalid || !D || D->isInvalidDecl();
2944   }
2945 
2946   // Clean up if we had an error.
2947   if (Invalid)
2948     return nullptr;
2949 
2950   TemplateParameterList *InstL
2951     = TemplateParameterList::Create(SemaRef.Context, L->getTemplateLoc(),
2952                                     L->getLAngleLoc(), Params,
2953                                     L->getRAngleLoc());
2954   return InstL;
2955 }
2956 
2957 /// \brief Instantiate the declaration of a class template partial
2958 /// specialization.
2959 ///
2960 /// \param ClassTemplate the (instantiated) class template that is partially
2961 // specialized by the instantiation of \p PartialSpec.
2962 ///
2963 /// \param PartialSpec the (uninstantiated) class template partial
2964 /// specialization that we are instantiating.
2965 ///
2966 /// \returns The instantiated partial specialization, if successful; otherwise,
2967 /// NULL to indicate an error.
2968 ClassTemplatePartialSpecializationDecl *
2969 TemplateDeclInstantiator::InstantiateClassTemplatePartialSpecialization(
2970                                             ClassTemplateDecl *ClassTemplate,
2971                           ClassTemplatePartialSpecializationDecl *PartialSpec) {
2972   // Create a local instantiation scope for this class template partial
2973   // specialization, which will contain the instantiations of the template
2974   // parameters.
2975   LocalInstantiationScope Scope(SemaRef);
2976 
2977   // Substitute into the template parameters of the class template partial
2978   // specialization.
2979   TemplateParameterList *TempParams = PartialSpec->getTemplateParameters();
2980   TemplateParameterList *InstParams = SubstTemplateParams(TempParams);
2981   if (!InstParams)
2982     return nullptr;
2983 
2984   // Substitute into the template arguments of the class template partial
2985   // specialization.
2986   const ASTTemplateArgumentListInfo *TemplArgInfo
2987     = PartialSpec->getTemplateArgsAsWritten();
2988   TemplateArgumentListInfo InstTemplateArgs(TemplArgInfo->LAngleLoc,
2989                                             TemplArgInfo->RAngleLoc);
2990   if (SemaRef.Subst(TemplArgInfo->getTemplateArgs(),
2991                     TemplArgInfo->NumTemplateArgs,
2992                     InstTemplateArgs, TemplateArgs))
2993     return nullptr;
2994 
2995   // Check that the template argument list is well-formed for this
2996   // class template.
2997   SmallVector<TemplateArgument, 4> Converted;
2998   if (SemaRef.CheckTemplateArgumentList(ClassTemplate,
2999                                         PartialSpec->getLocation(),
3000                                         InstTemplateArgs,
3001                                         false,
3002                                         Converted))
3003     return nullptr;
3004 
3005   // Figure out where to insert this class template partial specialization
3006   // in the member template's set of class template partial specializations.
3007   void *InsertPos = nullptr;
3008   ClassTemplateSpecializationDecl *PrevDecl
3009     = ClassTemplate->findPartialSpecialization(Converted, InsertPos);
3010 
3011   // Build the canonical type that describes the converted template
3012   // arguments of the class template partial specialization.
3013   QualType CanonType
3014     = SemaRef.Context.getTemplateSpecializationType(TemplateName(ClassTemplate),
3015                                                     Converted.data(),
3016                                                     Converted.size());
3017 
3018   // Build the fully-sugared type for this class template
3019   // specialization as the user wrote in the specialization
3020   // itself. This means that we'll pretty-print the type retrieved
3021   // from the specialization's declaration the way that the user
3022   // actually wrote the specialization, rather than formatting the
3023   // name based on the "canonical" representation used to store the
3024   // template arguments in the specialization.
3025   TypeSourceInfo *WrittenTy
3026     = SemaRef.Context.getTemplateSpecializationTypeInfo(
3027                                                     TemplateName(ClassTemplate),
3028                                                     PartialSpec->getLocation(),
3029                                                     InstTemplateArgs,
3030                                                     CanonType);
3031 
3032   if (PrevDecl) {
3033     // We've already seen a partial specialization with the same template
3034     // parameters and template arguments. This can happen, for example, when
3035     // substituting the outer template arguments ends up causing two
3036     // class template partial specializations of a member class template
3037     // to have identical forms, e.g.,
3038     //
3039     //   template<typename T, typename U>
3040     //   struct Outer {
3041     //     template<typename X, typename Y> struct Inner;
3042     //     template<typename Y> struct Inner<T, Y>;
3043     //     template<typename Y> struct Inner<U, Y>;
3044     //   };
3045     //
3046     //   Outer<int, int> outer; // error: the partial specializations of Inner
3047     //                          // have the same signature.
3048     SemaRef.Diag(PartialSpec->getLocation(), diag::err_partial_spec_redeclared)
3049       << WrittenTy->getType();
3050     SemaRef.Diag(PrevDecl->getLocation(), diag::note_prev_partial_spec_here)
3051       << SemaRef.Context.getTypeDeclType(PrevDecl);
3052     return nullptr;
3053   }
3054 
3055 
3056   // Create the class template partial specialization declaration.
3057   ClassTemplatePartialSpecializationDecl *InstPartialSpec
3058     = ClassTemplatePartialSpecializationDecl::Create(SemaRef.Context,
3059                                                      PartialSpec->getTagKind(),
3060                                                      Owner,
3061                                                      PartialSpec->getLocStart(),
3062                                                      PartialSpec->getLocation(),
3063                                                      InstParams,
3064                                                      ClassTemplate,
3065                                                      Converted.data(),
3066                                                      Converted.size(),
3067                                                      InstTemplateArgs,
3068                                                      CanonType,
3069                                                      nullptr);
3070   // Substitute the nested name specifier, if any.
3071   if (SubstQualifier(PartialSpec, InstPartialSpec))
3072     return nullptr;
3073 
3074   InstPartialSpec->setInstantiatedFromMember(PartialSpec);
3075   InstPartialSpec->setTypeAsWritten(WrittenTy);
3076 
3077   // Add this partial specialization to the set of class template partial
3078   // specializations.
3079   ClassTemplate->AddPartialSpecialization(InstPartialSpec,
3080                                           /*InsertPos=*/nullptr);
3081   return InstPartialSpec;
3082 }
3083 
3084 /// \brief Instantiate the declaration of a variable template partial
3085 /// specialization.
3086 ///
3087 /// \param VarTemplate the (instantiated) variable template that is partially
3088 /// specialized by the instantiation of \p PartialSpec.
3089 ///
3090 /// \param PartialSpec the (uninstantiated) variable template partial
3091 /// specialization that we are instantiating.
3092 ///
3093 /// \returns The instantiated partial specialization, if successful; otherwise,
3094 /// NULL to indicate an error.
3095 VarTemplatePartialSpecializationDecl *
3096 TemplateDeclInstantiator::InstantiateVarTemplatePartialSpecialization(
3097     VarTemplateDecl *VarTemplate,
3098     VarTemplatePartialSpecializationDecl *PartialSpec) {
3099   // Create a local instantiation scope for this variable template partial
3100   // specialization, which will contain the instantiations of the template
3101   // parameters.
3102   LocalInstantiationScope Scope(SemaRef);
3103 
3104   // Substitute into the template parameters of the variable template partial
3105   // specialization.
3106   TemplateParameterList *TempParams = PartialSpec->getTemplateParameters();
3107   TemplateParameterList *InstParams = SubstTemplateParams(TempParams);
3108   if (!InstParams)
3109     return nullptr;
3110 
3111   // Substitute into the template arguments of the variable template partial
3112   // specialization.
3113   const ASTTemplateArgumentListInfo *TemplArgInfo
3114     = PartialSpec->getTemplateArgsAsWritten();
3115   TemplateArgumentListInfo InstTemplateArgs(TemplArgInfo->LAngleLoc,
3116                                             TemplArgInfo->RAngleLoc);
3117   if (SemaRef.Subst(TemplArgInfo->getTemplateArgs(),
3118                     TemplArgInfo->NumTemplateArgs,
3119                     InstTemplateArgs, TemplateArgs))
3120     return nullptr;
3121 
3122   // Check that the template argument list is well-formed for this
3123   // class template.
3124   SmallVector<TemplateArgument, 4> Converted;
3125   if (SemaRef.CheckTemplateArgumentList(VarTemplate, PartialSpec->getLocation(),
3126                                         InstTemplateArgs, false, Converted))
3127     return nullptr;
3128 
3129   // Figure out where to insert this variable template partial specialization
3130   // in the member template's set of variable template partial specializations.
3131   void *InsertPos = nullptr;
3132   VarTemplateSpecializationDecl *PrevDecl =
3133       VarTemplate->findPartialSpecialization(Converted, InsertPos);
3134 
3135   // Build the canonical type that describes the converted template
3136   // arguments of the variable template partial specialization.
3137   QualType CanonType = SemaRef.Context.getTemplateSpecializationType(
3138       TemplateName(VarTemplate), Converted.data(), Converted.size());
3139 
3140   // Build the fully-sugared type for this variable template
3141   // specialization as the user wrote in the specialization
3142   // itself. This means that we'll pretty-print the type retrieved
3143   // from the specialization's declaration the way that the user
3144   // actually wrote the specialization, rather than formatting the
3145   // name based on the "canonical" representation used to store the
3146   // template arguments in the specialization.
3147   TypeSourceInfo *WrittenTy = SemaRef.Context.getTemplateSpecializationTypeInfo(
3148       TemplateName(VarTemplate), PartialSpec->getLocation(), InstTemplateArgs,
3149       CanonType);
3150 
3151   if (PrevDecl) {
3152     // We've already seen a partial specialization with the same template
3153     // parameters and template arguments. This can happen, for example, when
3154     // substituting the outer template arguments ends up causing two
3155     // variable template partial specializations of a member variable template
3156     // to have identical forms, e.g.,
3157     //
3158     //   template<typename T, typename U>
3159     //   struct Outer {
3160     //     template<typename X, typename Y> pair<X,Y> p;
3161     //     template<typename Y> pair<T, Y> p;
3162     //     template<typename Y> pair<U, Y> p;
3163     //   };
3164     //
3165     //   Outer<int, int> outer; // error: the partial specializations of Inner
3166     //                          // have the same signature.
3167     SemaRef.Diag(PartialSpec->getLocation(),
3168                  diag::err_var_partial_spec_redeclared)
3169         << WrittenTy->getType();
3170     SemaRef.Diag(PrevDecl->getLocation(),
3171                  diag::note_var_prev_partial_spec_here);
3172     return nullptr;
3173   }
3174 
3175   // Do substitution on the type of the declaration
3176   TypeSourceInfo *DI = SemaRef.SubstType(
3177       PartialSpec->getTypeSourceInfo(), TemplateArgs,
3178       PartialSpec->getTypeSpecStartLoc(), PartialSpec->getDeclName());
3179   if (!DI)
3180     return nullptr;
3181 
3182   if (DI->getType()->isFunctionType()) {
3183     SemaRef.Diag(PartialSpec->getLocation(),
3184                  diag::err_variable_instantiates_to_function)
3185         << PartialSpec->isStaticDataMember() << DI->getType();
3186     return nullptr;
3187   }
3188 
3189   // Create the variable template partial specialization declaration.
3190   VarTemplatePartialSpecializationDecl *InstPartialSpec =
3191       VarTemplatePartialSpecializationDecl::Create(
3192           SemaRef.Context, Owner, PartialSpec->getInnerLocStart(),
3193           PartialSpec->getLocation(), InstParams, VarTemplate, DI->getType(),
3194           DI, PartialSpec->getStorageClass(), Converted.data(),
3195           Converted.size(), InstTemplateArgs);
3196 
3197   // Substitute the nested name specifier, if any.
3198   if (SubstQualifier(PartialSpec, InstPartialSpec))
3199     return nullptr;
3200 
3201   InstPartialSpec->setInstantiatedFromMember(PartialSpec);
3202   InstPartialSpec->setTypeAsWritten(WrittenTy);
3203 
3204   // Add this partial specialization to the set of variable template partial
3205   // specializations. The instantiation of the initializer is not necessary.
3206   VarTemplate->AddPartialSpecialization(InstPartialSpec, /*InsertPos=*/nullptr);
3207 
3208   SemaRef.BuildVariableInstantiation(InstPartialSpec, PartialSpec, TemplateArgs,
3209                                      LateAttrs, Owner, StartingScope);
3210 
3211   return InstPartialSpec;
3212 }
3213 
3214 TypeSourceInfo*
3215 TemplateDeclInstantiator::SubstFunctionType(FunctionDecl *D,
3216                               SmallVectorImpl<ParmVarDecl *> &Params) {
3217   TypeSourceInfo *OldTInfo = D->getTypeSourceInfo();
3218   assert(OldTInfo && "substituting function without type source info");
3219   assert(Params.empty() && "parameter vector is non-empty at start");
3220 
3221   CXXRecordDecl *ThisContext = nullptr;
3222   unsigned ThisTypeQuals = 0;
3223   if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(D)) {
3224     ThisContext = cast<CXXRecordDecl>(Owner);
3225     ThisTypeQuals = Method->getTypeQualifiers();
3226   }
3227 
3228   TypeSourceInfo *NewTInfo
3229     = SemaRef.SubstFunctionDeclType(OldTInfo, TemplateArgs,
3230                                     D->getTypeSpecStartLoc(),
3231                                     D->getDeclName(),
3232                                     ThisContext, ThisTypeQuals);
3233   if (!NewTInfo)
3234     return nullptr;
3235 
3236   TypeLoc OldTL = OldTInfo->getTypeLoc().IgnoreParens();
3237   if (FunctionProtoTypeLoc OldProtoLoc = OldTL.getAs<FunctionProtoTypeLoc>()) {
3238     if (NewTInfo != OldTInfo) {
3239       // Get parameters from the new type info.
3240       TypeLoc NewTL = NewTInfo->getTypeLoc().IgnoreParens();
3241       FunctionProtoTypeLoc NewProtoLoc = NewTL.castAs<FunctionProtoTypeLoc>();
3242       unsigned NewIdx = 0;
3243       for (unsigned OldIdx = 0, NumOldParams = OldProtoLoc.getNumParams();
3244            OldIdx != NumOldParams; ++OldIdx) {
3245         ParmVarDecl *OldParam = OldProtoLoc.getParam(OldIdx);
3246         LocalInstantiationScope *Scope = SemaRef.CurrentInstantiationScope;
3247 
3248         Optional<unsigned> NumArgumentsInExpansion;
3249         if (OldParam->isParameterPack())
3250           NumArgumentsInExpansion =
3251               SemaRef.getNumArgumentsInExpansion(OldParam->getType(),
3252                                                  TemplateArgs);
3253         if (!NumArgumentsInExpansion) {
3254           // Simple case: normal parameter, or a parameter pack that's
3255           // instantiated to a (still-dependent) parameter pack.
3256           ParmVarDecl *NewParam = NewProtoLoc.getParam(NewIdx++);
3257           Params.push_back(NewParam);
3258           Scope->InstantiatedLocal(OldParam, NewParam);
3259         } else {
3260           // Parameter pack expansion: make the instantiation an argument pack.
3261           Scope->MakeInstantiatedLocalArgPack(OldParam);
3262           for (unsigned I = 0; I != *NumArgumentsInExpansion; ++I) {
3263             ParmVarDecl *NewParam = NewProtoLoc.getParam(NewIdx++);
3264             Params.push_back(NewParam);
3265             Scope->InstantiatedLocalPackArg(OldParam, NewParam);
3266           }
3267         }
3268       }
3269     } else {
3270       // The function type itself was not dependent and therefore no
3271       // substitution occurred. However, we still need to instantiate
3272       // the function parameters themselves.
3273       const FunctionProtoType *OldProto =
3274           cast<FunctionProtoType>(OldProtoLoc.getType());
3275       for (unsigned i = 0, i_end = OldProtoLoc.getNumParams(); i != i_end;
3276            ++i) {
3277         ParmVarDecl *OldParam = OldProtoLoc.getParam(i);
3278         if (!OldParam) {
3279           Params.push_back(SemaRef.BuildParmVarDeclForTypedef(
3280               D, D->getLocation(), OldProto->getParamType(i)));
3281           continue;
3282         }
3283 
3284         ParmVarDecl *Parm =
3285             cast_or_null<ParmVarDecl>(VisitParmVarDecl(OldParam));
3286         if (!Parm)
3287           return nullptr;
3288         Params.push_back(Parm);
3289       }
3290     }
3291   } else {
3292     // If the type of this function, after ignoring parentheses, is not
3293     // *directly* a function type, then we're instantiating a function that
3294     // was declared via a typedef or with attributes, e.g.,
3295     //
3296     //   typedef int functype(int, int);
3297     //   functype func;
3298     //   int __cdecl meth(int, int);
3299     //
3300     // In this case, we'll just go instantiate the ParmVarDecls that we
3301     // synthesized in the method declaration.
3302     SmallVector<QualType, 4> ParamTypes;
3303     Sema::ExtParameterInfoBuilder ExtParamInfos;
3304     if (SemaRef.SubstParmTypes(D->getLocation(), D->param_begin(),
3305                                D->getNumParams(), nullptr, TemplateArgs,
3306                                ParamTypes, &Params, ExtParamInfos))
3307       return nullptr;
3308   }
3309 
3310   return NewTInfo;
3311 }
3312 
3313 /// Introduce the instantiated function parameters into the local
3314 /// instantiation scope, and set the parameter names to those used
3315 /// in the template.
3316 static bool addInstantiatedParametersToScope(Sema &S, FunctionDecl *Function,
3317                                              const FunctionDecl *PatternDecl,
3318                                              LocalInstantiationScope &Scope,
3319                            const MultiLevelTemplateArgumentList &TemplateArgs) {
3320   unsigned FParamIdx = 0;
3321   for (unsigned I = 0, N = PatternDecl->getNumParams(); I != N; ++I) {
3322     const ParmVarDecl *PatternParam = PatternDecl->getParamDecl(I);
3323     if (!PatternParam->isParameterPack()) {
3324       // Simple case: not a parameter pack.
3325       assert(FParamIdx < Function->getNumParams());
3326       ParmVarDecl *FunctionParam = Function->getParamDecl(FParamIdx);
3327       FunctionParam->setDeclName(PatternParam->getDeclName());
3328       // If the parameter's type is not dependent, update it to match the type
3329       // in the pattern. They can differ in top-level cv-qualifiers, and we want
3330       // the pattern's type here. If the type is dependent, they can't differ,
3331       // per core issue 1668. Substitute into the type from the pattern, in case
3332       // it's instantiation-dependent.
3333       // FIXME: Updating the type to work around this is at best fragile.
3334       if (!PatternDecl->getType()->isDependentType()) {
3335         QualType T = S.SubstType(PatternParam->getType(), TemplateArgs,
3336                                  FunctionParam->getLocation(),
3337                                  FunctionParam->getDeclName());
3338         if (T.isNull())
3339           return true;
3340         FunctionParam->setType(T);
3341       }
3342 
3343       Scope.InstantiatedLocal(PatternParam, FunctionParam);
3344       ++FParamIdx;
3345       continue;
3346     }
3347 
3348     // Expand the parameter pack.
3349     Scope.MakeInstantiatedLocalArgPack(PatternParam);
3350     Optional<unsigned> NumArgumentsInExpansion
3351       = S.getNumArgumentsInExpansion(PatternParam->getType(), TemplateArgs);
3352     assert(NumArgumentsInExpansion &&
3353            "should only be called when all template arguments are known");
3354     QualType PatternType =
3355         PatternParam->getType()->castAs<PackExpansionType>()->getPattern();
3356     for (unsigned Arg = 0; Arg < *NumArgumentsInExpansion; ++Arg) {
3357       ParmVarDecl *FunctionParam = Function->getParamDecl(FParamIdx);
3358       FunctionParam->setDeclName(PatternParam->getDeclName());
3359       if (!PatternDecl->getType()->isDependentType()) {
3360         Sema::ArgumentPackSubstitutionIndexRAII SubstIndex(S, Arg);
3361         QualType T = S.SubstType(PatternType, TemplateArgs,
3362                                  FunctionParam->getLocation(),
3363                                  FunctionParam->getDeclName());
3364         if (T.isNull())
3365           return true;
3366         FunctionParam->setType(T);
3367       }
3368 
3369       Scope.InstantiatedLocalPackArg(PatternParam, FunctionParam);
3370       ++FParamIdx;
3371     }
3372   }
3373 
3374   return false;
3375 }
3376 
3377 void Sema::InstantiateExceptionSpec(SourceLocation PointOfInstantiation,
3378                                     FunctionDecl *Decl) {
3379   const FunctionProtoType *Proto = Decl->getType()->castAs<FunctionProtoType>();
3380   if (Proto->getExceptionSpecType() != EST_Uninstantiated)
3381     return;
3382 
3383   InstantiatingTemplate Inst(*this, PointOfInstantiation, Decl,
3384                              InstantiatingTemplate::ExceptionSpecification());
3385   if (Inst.isInvalid()) {
3386     // We hit the instantiation depth limit. Clear the exception specification
3387     // so that our callers don't have to cope with EST_Uninstantiated.
3388     UpdateExceptionSpec(Decl, EST_None);
3389     return;
3390   }
3391 
3392   // Enter the scope of this instantiation. We don't use
3393   // PushDeclContext because we don't have a scope.
3394   Sema::ContextRAII savedContext(*this, Decl);
3395   LocalInstantiationScope Scope(*this);
3396 
3397   MultiLevelTemplateArgumentList TemplateArgs =
3398     getTemplateInstantiationArgs(Decl, nullptr, /*RelativeToPrimary*/true);
3399 
3400   FunctionDecl *Template = Proto->getExceptionSpecTemplate();
3401   if (addInstantiatedParametersToScope(*this, Decl, Template, Scope,
3402                                        TemplateArgs)) {
3403     UpdateExceptionSpec(Decl, EST_None);
3404     return;
3405   }
3406 
3407   SubstExceptionSpec(Decl, Template->getType()->castAs<FunctionProtoType>(),
3408                      TemplateArgs);
3409 }
3410 
3411 /// \brief Initializes the common fields of an instantiation function
3412 /// declaration (New) from the corresponding fields of its template (Tmpl).
3413 ///
3414 /// \returns true if there was an error
3415 bool
3416 TemplateDeclInstantiator::InitFunctionInstantiation(FunctionDecl *New,
3417                                                     FunctionDecl *Tmpl) {
3418   if (Tmpl->isDeleted())
3419     New->setDeletedAsWritten();
3420 
3421   // Forward the mangling number from the template to the instantiated decl.
3422   SemaRef.Context.setManglingNumber(New,
3423                                     SemaRef.Context.getManglingNumber(Tmpl));
3424 
3425   // If we are performing substituting explicitly-specified template arguments
3426   // or deduced template arguments into a function template and we reach this
3427   // point, we are now past the point where SFINAE applies and have committed
3428   // to keeping the new function template specialization. We therefore
3429   // convert the active template instantiation for the function template
3430   // into a template instantiation for this specific function template
3431   // specialization, which is not a SFINAE context, so that we diagnose any
3432   // further errors in the declaration itself.
3433   typedef Sema::ActiveTemplateInstantiation ActiveInstType;
3434   ActiveInstType &ActiveInst = SemaRef.ActiveTemplateInstantiations.back();
3435   if (ActiveInst.Kind == ActiveInstType::ExplicitTemplateArgumentSubstitution ||
3436       ActiveInst.Kind == ActiveInstType::DeducedTemplateArgumentSubstitution) {
3437     if (FunctionTemplateDecl *FunTmpl
3438           = dyn_cast<FunctionTemplateDecl>(ActiveInst.Entity)) {
3439       assert(FunTmpl->getTemplatedDecl() == Tmpl &&
3440              "Deduction from the wrong function template?");
3441       (void) FunTmpl;
3442       ActiveInst.Kind = ActiveInstType::TemplateInstantiation;
3443       ActiveInst.Entity = New;
3444     }
3445   }
3446 
3447   const FunctionProtoType *Proto = Tmpl->getType()->getAs<FunctionProtoType>();
3448   assert(Proto && "Function template without prototype?");
3449 
3450   if (Proto->hasExceptionSpec() || Proto->getNoReturnAttr()) {
3451     FunctionProtoType::ExtProtoInfo EPI = Proto->getExtProtoInfo();
3452 
3453     // DR1330: In C++11, defer instantiation of a non-trivial
3454     // exception specification.
3455     // DR1484: Local classes and their members are instantiated along with the
3456     // containing function.
3457     if (SemaRef.getLangOpts().CPlusPlus11 &&
3458         EPI.ExceptionSpec.Type != EST_None &&
3459         EPI.ExceptionSpec.Type != EST_DynamicNone &&
3460         EPI.ExceptionSpec.Type != EST_BasicNoexcept &&
3461         !Tmpl->isLexicallyWithinFunctionOrMethod()) {
3462       FunctionDecl *ExceptionSpecTemplate = Tmpl;
3463       if (EPI.ExceptionSpec.Type == EST_Uninstantiated)
3464         ExceptionSpecTemplate = EPI.ExceptionSpec.SourceTemplate;
3465       ExceptionSpecificationType NewEST = EST_Uninstantiated;
3466       if (EPI.ExceptionSpec.Type == EST_Unevaluated)
3467         NewEST = EST_Unevaluated;
3468 
3469       // Mark the function has having an uninstantiated exception specification.
3470       const FunctionProtoType *NewProto
3471         = New->getType()->getAs<FunctionProtoType>();
3472       assert(NewProto && "Template instantiation without function prototype?");
3473       EPI = NewProto->getExtProtoInfo();
3474       EPI.ExceptionSpec.Type = NewEST;
3475       EPI.ExceptionSpec.SourceDecl = New;
3476       EPI.ExceptionSpec.SourceTemplate = ExceptionSpecTemplate;
3477       New->setType(SemaRef.Context.getFunctionType(
3478           NewProto->getReturnType(), NewProto->getParamTypes(), EPI));
3479     } else {
3480       SemaRef.SubstExceptionSpec(New, Proto, TemplateArgs);
3481     }
3482   }
3483 
3484   // Get the definition. Leaves the variable unchanged if undefined.
3485   const FunctionDecl *Definition = Tmpl;
3486   Tmpl->isDefined(Definition);
3487 
3488   SemaRef.InstantiateAttrs(TemplateArgs, Definition, New,
3489                            LateAttrs, StartingScope);
3490 
3491   return false;
3492 }
3493 
3494 /// \brief Initializes common fields of an instantiated method
3495 /// declaration (New) from the corresponding fields of its template
3496 /// (Tmpl).
3497 ///
3498 /// \returns true if there was an error
3499 bool
3500 TemplateDeclInstantiator::InitMethodInstantiation(CXXMethodDecl *New,
3501                                                   CXXMethodDecl *Tmpl) {
3502   if (InitFunctionInstantiation(New, Tmpl))
3503     return true;
3504 
3505   New->setAccess(Tmpl->getAccess());
3506   if (Tmpl->isVirtualAsWritten())
3507     New->setVirtualAsWritten(true);
3508 
3509   // FIXME: New needs a pointer to Tmpl
3510   return false;
3511 }
3512 
3513 /// \brief Instantiate the definition of the given function from its
3514 /// template.
3515 ///
3516 /// \param PointOfInstantiation the point at which the instantiation was
3517 /// required. Note that this is not precisely a "point of instantiation"
3518 /// for the function, but it's close.
3519 ///
3520 /// \param Function the already-instantiated declaration of a
3521 /// function template specialization or member function of a class template
3522 /// specialization.
3523 ///
3524 /// \param Recursive if true, recursively instantiates any functions that
3525 /// are required by this instantiation.
3526 ///
3527 /// \param DefinitionRequired if true, then we are performing an explicit
3528 /// instantiation where the body of the function is required. Complain if
3529 /// there is no such body.
3530 void Sema::InstantiateFunctionDefinition(SourceLocation PointOfInstantiation,
3531                                          FunctionDecl *Function,
3532                                          bool Recursive,
3533                                          bool DefinitionRequired,
3534                                          bool AtEndOfTU) {
3535   if (Function->isInvalidDecl() || Function->isDefined())
3536     return;
3537 
3538   // Never instantiate an explicit specialization except if it is a class scope
3539   // explicit specialization.
3540   if (Function->getTemplateSpecializationKind() == TSK_ExplicitSpecialization &&
3541       !Function->getClassScopeSpecializationPattern())
3542     return;
3543 
3544   // Find the function body that we'll be substituting.
3545   const FunctionDecl *PatternDecl = Function->getTemplateInstantiationPattern();
3546   assert(PatternDecl && "instantiating a non-template");
3547 
3548   Stmt *Pattern = PatternDecl->getBody(PatternDecl);
3549   assert(PatternDecl && "template definition is not a template");
3550   if (!Pattern) {
3551     // Try to find a defaulted definition
3552     PatternDecl->isDefined(PatternDecl);
3553   }
3554   assert(PatternDecl && "template definition is not a template");
3555 
3556   // Postpone late parsed template instantiations.
3557   if (PatternDecl->isLateTemplateParsed() &&
3558       !LateTemplateParser) {
3559     PendingInstantiations.push_back(
3560       std::make_pair(Function, PointOfInstantiation));
3561     return;
3562   }
3563 
3564   // If we're performing recursive template instantiation, create our own
3565   // queue of pending implicit instantiations that we will instantiate later,
3566   // while we're still within our own instantiation context.
3567   // This has to happen before LateTemplateParser below is called, so that
3568   // it marks vtables used in late parsed templates as used.
3569   SavePendingLocalImplicitInstantiationsRAII
3570       SavedPendingLocalImplicitInstantiations(*this);
3571   SavePendingInstantiationsAndVTableUsesRAII
3572       SavePendingInstantiationsAndVTableUses(*this, /*Enabled=*/Recursive);
3573 
3574   // Call the LateTemplateParser callback if there is a need to late parse
3575   // a templated function definition.
3576   if (!Pattern && PatternDecl->isLateTemplateParsed() &&
3577       LateTemplateParser) {
3578     // FIXME: Optimize to allow individual templates to be deserialized.
3579     if (PatternDecl->isFromASTFile())
3580       ExternalSource->ReadLateParsedTemplates(LateParsedTemplateMap);
3581 
3582     LateParsedTemplate *LPT = LateParsedTemplateMap.lookup(PatternDecl);
3583     assert(LPT && "missing LateParsedTemplate");
3584     LateTemplateParser(OpaqueParser, *LPT);
3585     Pattern = PatternDecl->getBody(PatternDecl);
3586   }
3587 
3588   if (!Pattern && !PatternDecl->isDefaulted()) {
3589     if (DefinitionRequired) {
3590       if (Function->getPrimaryTemplate())
3591         Diag(PointOfInstantiation,
3592              diag::err_explicit_instantiation_undefined_func_template)
3593           << Function->getPrimaryTemplate();
3594       else
3595         Diag(PointOfInstantiation,
3596              diag::err_explicit_instantiation_undefined_member)
3597           << 1 << Function->getDeclName() << Function->getDeclContext();
3598 
3599       if (PatternDecl)
3600         Diag(PatternDecl->getLocation(),
3601              diag::note_explicit_instantiation_here);
3602       Function->setInvalidDecl();
3603     } else if (Function->getTemplateSpecializationKind()
3604                  == TSK_ExplicitInstantiationDefinition) {
3605       assert(!Recursive);
3606       PendingInstantiations.push_back(
3607         std::make_pair(Function, PointOfInstantiation));
3608     } else if (Function->getTemplateSpecializationKind()
3609                  == TSK_ImplicitInstantiation) {
3610       if (AtEndOfTU && !getDiagnostics().hasErrorOccurred()) {
3611         Diag(PointOfInstantiation, diag::warn_func_template_missing)
3612           << Function;
3613         Diag(PatternDecl->getLocation(), diag::note_forward_template_decl);
3614         if (getLangOpts().CPlusPlus11)
3615           Diag(PointOfInstantiation, diag::note_inst_declaration_hint)
3616             << Function;
3617       }
3618     }
3619 
3620     return;
3621   }
3622 
3623   // C++1y [temp.explicit]p10:
3624   //   Except for inline functions, declarations with types deduced from their
3625   //   initializer or return value, and class template specializations, other
3626   //   explicit instantiation declarations have the effect of suppressing the
3627   //   implicit instantiation of the entity to which they refer.
3628   if (Function->getTemplateSpecializationKind() ==
3629           TSK_ExplicitInstantiationDeclaration &&
3630       !PatternDecl->isInlined() &&
3631       !PatternDecl->getReturnType()->getContainedAutoType())
3632     return;
3633 
3634   if (PatternDecl->isInlined()) {
3635     // Function, and all later redeclarations of it (from imported modules,
3636     // for instance), are now implicitly inline.
3637     for (auto *D = Function->getMostRecentDecl(); /**/;
3638          D = D->getPreviousDecl()) {
3639       D->setImplicitlyInline();
3640       if (D == Function)
3641         break;
3642     }
3643   }
3644 
3645   InstantiatingTemplate Inst(*this, PointOfInstantiation, Function);
3646   if (Inst.isInvalid())
3647     return;
3648 
3649   // Copy the inner loc start from the pattern.
3650   Function->setInnerLocStart(PatternDecl->getInnerLocStart());
3651 
3652   EnterExpressionEvaluationContext EvalContext(*this,
3653                                                Sema::PotentiallyEvaluated);
3654 
3655   // Introduce a new scope where local variable instantiations will be
3656   // recorded, unless we're actually a member function within a local
3657   // class, in which case we need to merge our results with the parent
3658   // scope (of the enclosing function).
3659   bool MergeWithParentScope = false;
3660   if (CXXRecordDecl *Rec = dyn_cast<CXXRecordDecl>(Function->getDeclContext()))
3661     MergeWithParentScope = Rec->isLocalClass();
3662 
3663   LocalInstantiationScope Scope(*this, MergeWithParentScope);
3664 
3665   if (PatternDecl->isDefaulted())
3666     SetDeclDefaulted(Function, PatternDecl->getLocation());
3667   else {
3668     MultiLevelTemplateArgumentList TemplateArgs =
3669       getTemplateInstantiationArgs(Function, nullptr, false, PatternDecl);
3670 
3671     // Substitute into the qualifier; we can get a substitution failure here
3672     // through evil use of alias templates.
3673     // FIXME: Is CurContext correct for this? Should we go to the (instantiation
3674     // of the) lexical context of the pattern?
3675     SubstQualifier(*this, PatternDecl, Function, TemplateArgs);
3676 
3677     ActOnStartOfFunctionDef(nullptr, Function);
3678 
3679     // Enter the scope of this instantiation. We don't use
3680     // PushDeclContext because we don't have a scope.
3681     Sema::ContextRAII savedContext(*this, Function);
3682 
3683     if (addInstantiatedParametersToScope(*this, Function, PatternDecl, Scope,
3684                                          TemplateArgs))
3685       return;
3686 
3687     // If this is a constructor, instantiate the member initializers.
3688     if (const CXXConstructorDecl *Ctor =
3689           dyn_cast<CXXConstructorDecl>(PatternDecl)) {
3690       InstantiateMemInitializers(cast<CXXConstructorDecl>(Function), Ctor,
3691                                  TemplateArgs);
3692     }
3693 
3694     // Instantiate the function body.
3695     StmtResult Body = SubstStmt(Pattern, TemplateArgs);
3696 
3697     if (Body.isInvalid())
3698       Function->setInvalidDecl();
3699 
3700     ActOnFinishFunctionBody(Function, Body.get(),
3701                             /*IsInstantiation=*/true);
3702 
3703     PerformDependentDiagnostics(PatternDecl, TemplateArgs);
3704 
3705     if (auto *Listener = getASTMutationListener())
3706       Listener->FunctionDefinitionInstantiated(Function);
3707 
3708     savedContext.pop();
3709   }
3710 
3711   DeclGroupRef DG(Function);
3712   Consumer.HandleTopLevelDecl(DG);
3713 
3714   // This class may have local implicit instantiations that need to be
3715   // instantiation within this scope.
3716   PerformPendingInstantiations(/*LocalOnly=*/true);
3717   Scope.Exit();
3718 
3719   if (Recursive) {
3720     // Define any pending vtables.
3721     DefineUsedVTables();
3722 
3723     // Instantiate any pending implicit instantiations found during the
3724     // instantiation of this template.
3725     PerformPendingInstantiations();
3726 
3727     // PendingInstantiations and VTableUses are restored through
3728     // SavePendingInstantiationsAndVTableUses's destructor.
3729   }
3730 }
3731 
3732 VarTemplateSpecializationDecl *Sema::BuildVarTemplateInstantiation(
3733     VarTemplateDecl *VarTemplate, VarDecl *FromVar,
3734     const TemplateArgumentList &TemplateArgList,
3735     const TemplateArgumentListInfo &TemplateArgsInfo,
3736     SmallVectorImpl<TemplateArgument> &Converted,
3737     SourceLocation PointOfInstantiation, void *InsertPos,
3738     LateInstantiatedAttrVec *LateAttrs,
3739     LocalInstantiationScope *StartingScope) {
3740   if (FromVar->isInvalidDecl())
3741     return nullptr;
3742 
3743   InstantiatingTemplate Inst(*this, PointOfInstantiation, FromVar);
3744   if (Inst.isInvalid())
3745     return nullptr;
3746 
3747   MultiLevelTemplateArgumentList TemplateArgLists;
3748   TemplateArgLists.addOuterTemplateArguments(&TemplateArgList);
3749 
3750   // Instantiate the first declaration of the variable template: for a partial
3751   // specialization of a static data member template, the first declaration may
3752   // or may not be the declaration in the class; if it's in the class, we want
3753   // to instantiate a member in the class (a declaration), and if it's outside,
3754   // we want to instantiate a definition.
3755   //
3756   // If we're instantiating an explicitly-specialized member template or member
3757   // partial specialization, don't do this. The member specialization completely
3758   // replaces the original declaration in this case.
3759   bool IsMemberSpec = false;
3760   if (VarTemplatePartialSpecializationDecl *PartialSpec =
3761           dyn_cast<VarTemplatePartialSpecializationDecl>(FromVar))
3762     IsMemberSpec = PartialSpec->isMemberSpecialization();
3763   else if (VarTemplateDecl *FromTemplate = FromVar->getDescribedVarTemplate())
3764     IsMemberSpec = FromTemplate->isMemberSpecialization();
3765   if (!IsMemberSpec)
3766     FromVar = FromVar->getFirstDecl();
3767 
3768   MultiLevelTemplateArgumentList MultiLevelList(TemplateArgList);
3769   TemplateDeclInstantiator Instantiator(*this, FromVar->getDeclContext(),
3770                                         MultiLevelList);
3771 
3772   // TODO: Set LateAttrs and StartingScope ...
3773 
3774   return cast_or_null<VarTemplateSpecializationDecl>(
3775       Instantiator.VisitVarTemplateSpecializationDecl(
3776           VarTemplate, FromVar, InsertPos, TemplateArgsInfo, Converted));
3777 }
3778 
3779 /// \brief Instantiates a variable template specialization by completing it
3780 /// with appropriate type information and initializer.
3781 VarTemplateSpecializationDecl *Sema::CompleteVarTemplateSpecializationDecl(
3782     VarTemplateSpecializationDecl *VarSpec, VarDecl *PatternDecl,
3783     const MultiLevelTemplateArgumentList &TemplateArgs) {
3784 
3785   // Do substitution on the type of the declaration
3786   TypeSourceInfo *DI =
3787       SubstType(PatternDecl->getTypeSourceInfo(), TemplateArgs,
3788                 PatternDecl->getTypeSpecStartLoc(), PatternDecl->getDeclName());
3789   if (!DI)
3790     return nullptr;
3791 
3792   // Update the type of this variable template specialization.
3793   VarSpec->setType(DI->getType());
3794 
3795   // Instantiate the initializer.
3796   InstantiateVariableInitializer(VarSpec, PatternDecl, TemplateArgs);
3797 
3798   return VarSpec;
3799 }
3800 
3801 /// BuildVariableInstantiation - Used after a new variable has been created.
3802 /// Sets basic variable data and decides whether to postpone the
3803 /// variable instantiation.
3804 void Sema::BuildVariableInstantiation(
3805     VarDecl *NewVar, VarDecl *OldVar,
3806     const MultiLevelTemplateArgumentList &TemplateArgs,
3807     LateInstantiatedAttrVec *LateAttrs, DeclContext *Owner,
3808     LocalInstantiationScope *StartingScope,
3809     bool InstantiatingVarTemplate) {
3810 
3811   // If we are instantiating a local extern declaration, the
3812   // instantiation belongs lexically to the containing function.
3813   // If we are instantiating a static data member defined
3814   // out-of-line, the instantiation will have the same lexical
3815   // context (which will be a namespace scope) as the template.
3816   if (OldVar->isLocalExternDecl()) {
3817     NewVar->setLocalExternDecl();
3818     NewVar->setLexicalDeclContext(Owner);
3819   } else if (OldVar->isOutOfLine())
3820     NewVar->setLexicalDeclContext(OldVar->getLexicalDeclContext());
3821   NewVar->setTSCSpec(OldVar->getTSCSpec());
3822   NewVar->setInitStyle(OldVar->getInitStyle());
3823   NewVar->setCXXForRangeDecl(OldVar->isCXXForRangeDecl());
3824   NewVar->setConstexpr(OldVar->isConstexpr());
3825   NewVar->setInitCapture(OldVar->isInitCapture());
3826   NewVar->setPreviousDeclInSameBlockScope(
3827       OldVar->isPreviousDeclInSameBlockScope());
3828   NewVar->setAccess(OldVar->getAccess());
3829 
3830   if (!OldVar->isStaticDataMember()) {
3831     if (OldVar->isUsed(false))
3832       NewVar->setIsUsed();
3833     NewVar->setReferenced(OldVar->isReferenced());
3834   }
3835 
3836   InstantiateAttrs(TemplateArgs, OldVar, NewVar, LateAttrs, StartingScope);
3837 
3838   LookupResult Previous(
3839       *this, NewVar->getDeclName(), NewVar->getLocation(),
3840       NewVar->isLocalExternDecl() ? Sema::LookupRedeclarationWithLinkage
3841                                   : Sema::LookupOrdinaryName,
3842       Sema::ForRedeclaration);
3843 
3844   if (NewVar->isLocalExternDecl() && OldVar->getPreviousDecl() &&
3845       (!OldVar->getPreviousDecl()->getDeclContext()->isDependentContext() ||
3846        OldVar->getPreviousDecl()->getDeclContext()==OldVar->getDeclContext())) {
3847     // We have a previous declaration. Use that one, so we merge with the
3848     // right type.
3849     if (NamedDecl *NewPrev = FindInstantiatedDecl(
3850             NewVar->getLocation(), OldVar->getPreviousDecl(), TemplateArgs))
3851       Previous.addDecl(NewPrev);
3852   } else if (!isa<VarTemplateSpecializationDecl>(NewVar) &&
3853              OldVar->hasLinkage())
3854     LookupQualifiedName(Previous, NewVar->getDeclContext(), false);
3855   CheckVariableDeclaration(NewVar, Previous);
3856 
3857   if (!InstantiatingVarTemplate) {
3858     NewVar->getLexicalDeclContext()->addHiddenDecl(NewVar);
3859     if (!NewVar->isLocalExternDecl() || !NewVar->getPreviousDecl())
3860       NewVar->getDeclContext()->makeDeclVisibleInContext(NewVar);
3861   }
3862 
3863   if (!OldVar->isOutOfLine()) {
3864     if (NewVar->getDeclContext()->isFunctionOrMethod())
3865       CurrentInstantiationScope->InstantiatedLocal(OldVar, NewVar);
3866   }
3867 
3868   // Link instantiations of static data members back to the template from
3869   // which they were instantiated.
3870   if (NewVar->isStaticDataMember() && !InstantiatingVarTemplate)
3871     NewVar->setInstantiationOfStaticDataMember(OldVar,
3872                                                TSK_ImplicitInstantiation);
3873 
3874   // Forward the mangling number from the template to the instantiated decl.
3875   Context.setManglingNumber(NewVar, Context.getManglingNumber(OldVar));
3876   Context.setStaticLocalNumber(NewVar, Context.getStaticLocalNumber(OldVar));
3877 
3878   // Delay instantiation of the initializer for variable templates until a
3879   // definition of the variable is needed. We need it right away if the type
3880   // contains 'auto'.
3881   if ((!isa<VarTemplateSpecializationDecl>(NewVar) &&
3882        !InstantiatingVarTemplate) ||
3883       NewVar->getType()->isUndeducedType())
3884     InstantiateVariableInitializer(NewVar, OldVar, TemplateArgs);
3885 
3886   // Diagnose unused local variables with dependent types, where the diagnostic
3887   // will have been deferred.
3888   if (!NewVar->isInvalidDecl() &&
3889       NewVar->getDeclContext()->isFunctionOrMethod() &&
3890       OldVar->getType()->isDependentType())
3891     DiagnoseUnusedDecl(NewVar);
3892 }
3893 
3894 /// \brief Instantiate the initializer of a variable.
3895 void Sema::InstantiateVariableInitializer(
3896     VarDecl *Var, VarDecl *OldVar,
3897     const MultiLevelTemplateArgumentList &TemplateArgs) {
3898 
3899   if (Var->getAnyInitializer())
3900     // We already have an initializer in the class.
3901     return;
3902 
3903   if (OldVar->getInit()) {
3904     if (Var->isStaticDataMember() && !OldVar->isOutOfLine())
3905       PushExpressionEvaluationContext(Sema::ConstantEvaluated, OldVar);
3906     else
3907       PushExpressionEvaluationContext(Sema::PotentiallyEvaluated, OldVar);
3908 
3909     // Instantiate the initializer.
3910     ExprResult Init;
3911 
3912     {
3913       ContextRAII SwitchContext(*this, Var->getDeclContext());
3914       Init = SubstInitializer(OldVar->getInit(), TemplateArgs,
3915                               OldVar->getInitStyle() == VarDecl::CallInit);
3916     }
3917 
3918     if (!Init.isInvalid()) {
3919       bool TypeMayContainAuto = true;
3920       Expr *InitExpr = Init.get();
3921 
3922       if (Var->hasAttr<DLLImportAttr>() &&
3923           (!InitExpr ||
3924            !InitExpr->isConstantInitializer(getASTContext(), false))) {
3925         // Do not dynamically initialize dllimport variables.
3926       } else if (InitExpr) {
3927         bool DirectInit = OldVar->isDirectInit();
3928         AddInitializerToDecl(Var, InitExpr, DirectInit, TypeMayContainAuto);
3929       } else
3930         ActOnUninitializedDecl(Var, TypeMayContainAuto);
3931     } else {
3932       // FIXME: Not too happy about invalidating the declaration
3933       // because of a bogus initializer.
3934       Var->setInvalidDecl();
3935     }
3936 
3937     PopExpressionEvaluationContext();
3938   } else if ((!Var->isStaticDataMember() || Var->isOutOfLine()) &&
3939              !Var->isCXXForRangeDecl())
3940     ActOnUninitializedDecl(Var, false);
3941 }
3942 
3943 /// \brief Instantiate the definition of the given variable from its
3944 /// template.
3945 ///
3946 /// \param PointOfInstantiation the point at which the instantiation was
3947 /// required. Note that this is not precisely a "point of instantiation"
3948 /// for the function, but it's close.
3949 ///
3950 /// \param Var the already-instantiated declaration of a static member
3951 /// variable of a class template specialization.
3952 ///
3953 /// \param Recursive if true, recursively instantiates any functions that
3954 /// are required by this instantiation.
3955 ///
3956 /// \param DefinitionRequired if true, then we are performing an explicit
3957 /// instantiation where an out-of-line definition of the member variable
3958 /// is required. Complain if there is no such definition.
3959 void Sema::InstantiateStaticDataMemberDefinition(
3960                                           SourceLocation PointOfInstantiation,
3961                                                  VarDecl *Var,
3962                                                  bool Recursive,
3963                                                  bool DefinitionRequired) {
3964   InstantiateVariableDefinition(PointOfInstantiation, Var, Recursive,
3965                                 DefinitionRequired);
3966 }
3967 
3968 void Sema::InstantiateVariableDefinition(SourceLocation PointOfInstantiation,
3969                                          VarDecl *Var, bool Recursive,
3970                                       bool DefinitionRequired, bool AtEndOfTU) {
3971   if (Var->isInvalidDecl())
3972     return;
3973 
3974   VarTemplateSpecializationDecl *VarSpec =
3975       dyn_cast<VarTemplateSpecializationDecl>(Var);
3976   VarDecl *PatternDecl = nullptr, *Def = nullptr;
3977   MultiLevelTemplateArgumentList TemplateArgs =
3978       getTemplateInstantiationArgs(Var);
3979 
3980   if (VarSpec) {
3981     // If this is a variable template specialization, make sure that it is
3982     // non-dependent, then find its instantiation pattern.
3983     bool InstantiationDependent = false;
3984     assert(!TemplateSpecializationType::anyDependentTemplateArguments(
3985                VarSpec->getTemplateArgsInfo(), InstantiationDependent) &&
3986            "Only instantiate variable template specializations that are "
3987            "not type-dependent");
3988     (void)InstantiationDependent;
3989 
3990     // Find the variable initialization that we'll be substituting. If the
3991     // pattern was instantiated from a member template, look back further to
3992     // find the real pattern.
3993     assert(VarSpec->getSpecializedTemplate() &&
3994            "Specialization without specialized template?");
3995     llvm::PointerUnion<VarTemplateDecl *,
3996                        VarTemplatePartialSpecializationDecl *> PatternPtr =
3997         VarSpec->getSpecializedTemplateOrPartial();
3998     if (PatternPtr.is<VarTemplatePartialSpecializationDecl *>()) {
3999       VarTemplatePartialSpecializationDecl *Tmpl =
4000           PatternPtr.get<VarTemplatePartialSpecializationDecl *>();
4001       while (VarTemplatePartialSpecializationDecl *From =
4002                  Tmpl->getInstantiatedFromMember()) {
4003         if (Tmpl->isMemberSpecialization())
4004           break;
4005 
4006         Tmpl = From;
4007       }
4008       PatternDecl = Tmpl;
4009     } else {
4010       VarTemplateDecl *Tmpl = PatternPtr.get<VarTemplateDecl *>();
4011       while (VarTemplateDecl *From =
4012                  Tmpl->getInstantiatedFromMemberTemplate()) {
4013         if (Tmpl->isMemberSpecialization())
4014           break;
4015 
4016         Tmpl = From;
4017       }
4018       PatternDecl = Tmpl->getTemplatedDecl();
4019     }
4020 
4021     // If this is a static data member template, there might be an
4022     // uninstantiated initializer on the declaration. If so, instantiate
4023     // it now.
4024     if (PatternDecl->isStaticDataMember() &&
4025         (PatternDecl = PatternDecl->getFirstDecl())->hasInit() &&
4026         !Var->hasInit()) {
4027       // FIXME: Factor out the duplicated instantiation context setup/tear down
4028       // code here.
4029       InstantiatingTemplate Inst(*this, PointOfInstantiation, Var);
4030       if (Inst.isInvalid())
4031         return;
4032 
4033       // If we're performing recursive template instantiation, create our own
4034       // queue of pending implicit instantiations that we will instantiate
4035       // later, while we're still within our own instantiation context.
4036       SavePendingInstantiationsAndVTableUsesRAII
4037           SavePendingInstantiationsAndVTableUses(*this, /*Enabled=*/Recursive);
4038 
4039       LocalInstantiationScope Local(*this);
4040 
4041       // Enter the scope of this instantiation. We don't use
4042       // PushDeclContext because we don't have a scope.
4043       ContextRAII PreviousContext(*this, Var->getDeclContext());
4044       InstantiateVariableInitializer(Var, PatternDecl, TemplateArgs);
4045       PreviousContext.pop();
4046 
4047       // FIXME: Need to inform the ASTConsumer that we instantiated the
4048       // initializer?
4049 
4050       // This variable may have local implicit instantiations that need to be
4051       // instantiated within this scope.
4052       PerformPendingInstantiations(/*LocalOnly=*/true);
4053 
4054       Local.Exit();
4055 
4056       if (Recursive) {
4057         // Define any newly required vtables.
4058         DefineUsedVTables();
4059 
4060         // Instantiate any pending implicit instantiations found during the
4061         // instantiation of this template.
4062         PerformPendingInstantiations();
4063 
4064         // PendingInstantiations and VTableUses are restored through
4065         // SavePendingInstantiationsAndVTableUses's destructor.
4066       }
4067     }
4068 
4069     // Find actual definition
4070     Def = PatternDecl->getDefinition(getASTContext());
4071   } else {
4072     // If this is a static data member, find its out-of-line definition.
4073     assert(Var->isStaticDataMember() && "not a static data member?");
4074     PatternDecl = Var->getInstantiatedFromStaticDataMember();
4075 
4076     assert(PatternDecl && "data member was not instantiated from a template?");
4077     assert(PatternDecl->isStaticDataMember() && "not a static data member?");
4078     Def = PatternDecl->getOutOfLineDefinition();
4079   }
4080 
4081   // If we don't have a definition of the variable template, we won't perform
4082   // any instantiation. Rather, we rely on the user to instantiate this
4083   // definition (or provide a specialization for it) in another translation
4084   // unit.
4085   if (!Def) {
4086     if (DefinitionRequired) {
4087       if (VarSpec)
4088         Diag(PointOfInstantiation,
4089              diag::err_explicit_instantiation_undefined_var_template) << Var;
4090       else
4091         Diag(PointOfInstantiation,
4092              diag::err_explicit_instantiation_undefined_member)
4093             << 2 << Var->getDeclName() << Var->getDeclContext();
4094       Diag(PatternDecl->getLocation(),
4095            diag::note_explicit_instantiation_here);
4096       if (VarSpec)
4097         Var->setInvalidDecl();
4098     } else if (Var->getTemplateSpecializationKind()
4099                  == TSK_ExplicitInstantiationDefinition) {
4100       PendingInstantiations.push_back(
4101         std::make_pair(Var, PointOfInstantiation));
4102     } else if (Var->getTemplateSpecializationKind()
4103                  == TSK_ImplicitInstantiation) {
4104       // Warn about missing definition at the end of translation unit.
4105       if (AtEndOfTU && !getDiagnostics().hasErrorOccurred()) {
4106         Diag(PointOfInstantiation, diag::warn_var_template_missing)
4107           << Var;
4108         Diag(PatternDecl->getLocation(), diag::note_forward_template_decl);
4109         if (getLangOpts().CPlusPlus11)
4110           Diag(PointOfInstantiation, diag::note_inst_declaration_hint) << Var;
4111       }
4112     }
4113 
4114     return;
4115   }
4116 
4117   TemplateSpecializationKind TSK = Var->getTemplateSpecializationKind();
4118 
4119   // Never instantiate an explicit specialization.
4120   if (TSK == TSK_ExplicitSpecialization)
4121     return;
4122 
4123   // C++11 [temp.explicit]p10:
4124   //   Except for inline functions, [...] explicit instantiation declarations
4125   //   have the effect of suppressing the implicit instantiation of the entity
4126   //   to which they refer.
4127   if (TSK == TSK_ExplicitInstantiationDeclaration)
4128     return;
4129 
4130   // Make sure to pass the instantiated variable to the consumer at the end.
4131   struct PassToConsumerRAII {
4132     ASTConsumer &Consumer;
4133     VarDecl *Var;
4134 
4135     PassToConsumerRAII(ASTConsumer &Consumer, VarDecl *Var)
4136       : Consumer(Consumer), Var(Var) { }
4137 
4138     ~PassToConsumerRAII() {
4139       Consumer.HandleCXXStaticMemberVarInstantiation(Var);
4140     }
4141   } PassToConsumerRAII(Consumer, Var);
4142 
4143   // If we already have a definition, we're done.
4144   if (VarDecl *Def = Var->getDefinition()) {
4145     // We may be explicitly instantiating something we've already implicitly
4146     // instantiated.
4147     Def->setTemplateSpecializationKind(Var->getTemplateSpecializationKind(),
4148                                        PointOfInstantiation);
4149     return;
4150   }
4151 
4152   InstantiatingTemplate Inst(*this, PointOfInstantiation, Var);
4153   if (Inst.isInvalid())
4154     return;
4155 
4156   // If we're performing recursive template instantiation, create our own
4157   // queue of pending implicit instantiations that we will instantiate later,
4158   // while we're still within our own instantiation context.
4159   SavePendingLocalImplicitInstantiationsRAII
4160       SavedPendingLocalImplicitInstantiations(*this);
4161   SavePendingInstantiationsAndVTableUsesRAII
4162       SavePendingInstantiationsAndVTableUses(*this, /*Enabled=*/Recursive);
4163 
4164   // Enter the scope of this instantiation. We don't use
4165   // PushDeclContext because we don't have a scope.
4166   ContextRAII PreviousContext(*this, Var->getDeclContext());
4167   LocalInstantiationScope Local(*this);
4168 
4169   VarDecl *OldVar = Var;
4170   if (!VarSpec)
4171     Var = cast_or_null<VarDecl>(SubstDecl(Def, Var->getDeclContext(),
4172                                           TemplateArgs));
4173   else if (Var->isStaticDataMember() &&
4174            Var->getLexicalDeclContext()->isRecord()) {
4175     // We need to instantiate the definition of a static data member template,
4176     // and all we have is the in-class declaration of it. Instantiate a separate
4177     // declaration of the definition.
4178     TemplateDeclInstantiator Instantiator(*this, Var->getDeclContext(),
4179                                           TemplateArgs);
4180     Var = cast_or_null<VarDecl>(Instantiator.VisitVarTemplateSpecializationDecl(
4181         VarSpec->getSpecializedTemplate(), Def, nullptr,
4182         VarSpec->getTemplateArgsInfo(), VarSpec->getTemplateArgs().asArray()));
4183     if (Var) {
4184       llvm::PointerUnion<VarTemplateDecl *,
4185                          VarTemplatePartialSpecializationDecl *> PatternPtr =
4186           VarSpec->getSpecializedTemplateOrPartial();
4187       if (VarTemplatePartialSpecializationDecl *Partial =
4188           PatternPtr.dyn_cast<VarTemplatePartialSpecializationDecl *>())
4189         cast<VarTemplateSpecializationDecl>(Var)->setInstantiationOf(
4190             Partial, &VarSpec->getTemplateInstantiationArgs());
4191 
4192       // Merge the definition with the declaration.
4193       LookupResult R(*this, Var->getDeclName(), Var->getLocation(),
4194                      LookupOrdinaryName, ForRedeclaration);
4195       R.addDecl(OldVar);
4196       MergeVarDecl(Var, R);
4197 
4198       // Attach the initializer.
4199       InstantiateVariableInitializer(Var, Def, TemplateArgs);
4200     }
4201   } else
4202     // Complete the existing variable's definition with an appropriately
4203     // substituted type and initializer.
4204     Var = CompleteVarTemplateSpecializationDecl(VarSpec, Def, TemplateArgs);
4205 
4206   PreviousContext.pop();
4207 
4208   if (Var) {
4209     PassToConsumerRAII.Var = Var;
4210     Var->setTemplateSpecializationKind(OldVar->getTemplateSpecializationKind(),
4211                                        OldVar->getPointOfInstantiation());
4212   }
4213 
4214   // This variable may have local implicit instantiations that need to be
4215   // instantiated within this scope.
4216   PerformPendingInstantiations(/*LocalOnly=*/true);
4217 
4218   Local.Exit();
4219 
4220   if (Recursive) {
4221     // Define any newly required vtables.
4222     DefineUsedVTables();
4223 
4224     // Instantiate any pending implicit instantiations found during the
4225     // instantiation of this template.
4226     PerformPendingInstantiations();
4227 
4228     // PendingInstantiations and VTableUses are restored through
4229     // SavePendingInstantiationsAndVTableUses's destructor.
4230   }
4231 }
4232 
4233 void
4234 Sema::InstantiateMemInitializers(CXXConstructorDecl *New,
4235                                  const CXXConstructorDecl *Tmpl,
4236                            const MultiLevelTemplateArgumentList &TemplateArgs) {
4237 
4238   SmallVector<CXXCtorInitializer*, 4> NewInits;
4239   bool AnyErrors = Tmpl->isInvalidDecl();
4240 
4241   // Instantiate all the initializers.
4242   for (const auto *Init : Tmpl->inits()) {
4243     // Only instantiate written initializers, let Sema re-construct implicit
4244     // ones.
4245     if (!Init->isWritten())
4246       continue;
4247 
4248     SourceLocation EllipsisLoc;
4249 
4250     if (Init->isPackExpansion()) {
4251       // This is a pack expansion. We should expand it now.
4252       TypeLoc BaseTL = Init->getTypeSourceInfo()->getTypeLoc();
4253       SmallVector<UnexpandedParameterPack, 4> Unexpanded;
4254       collectUnexpandedParameterPacks(BaseTL, Unexpanded);
4255       collectUnexpandedParameterPacks(Init->getInit(), Unexpanded);
4256       bool ShouldExpand = false;
4257       bool RetainExpansion = false;
4258       Optional<unsigned> NumExpansions;
4259       if (CheckParameterPacksForExpansion(Init->getEllipsisLoc(),
4260                                           BaseTL.getSourceRange(),
4261                                           Unexpanded,
4262                                           TemplateArgs, ShouldExpand,
4263                                           RetainExpansion,
4264                                           NumExpansions)) {
4265         AnyErrors = true;
4266         New->setInvalidDecl();
4267         continue;
4268       }
4269       assert(ShouldExpand && "Partial instantiation of base initializer?");
4270 
4271       // Loop over all of the arguments in the argument pack(s),
4272       for (unsigned I = 0; I != *NumExpansions; ++I) {
4273         Sema::ArgumentPackSubstitutionIndexRAII SubstIndex(*this, I);
4274 
4275         // Instantiate the initializer.
4276         ExprResult TempInit = SubstInitializer(Init->getInit(), TemplateArgs,
4277                                                /*CXXDirectInit=*/true);
4278         if (TempInit.isInvalid()) {
4279           AnyErrors = true;
4280           break;
4281         }
4282 
4283         // Instantiate the base type.
4284         TypeSourceInfo *BaseTInfo = SubstType(Init->getTypeSourceInfo(),
4285                                               TemplateArgs,
4286                                               Init->getSourceLocation(),
4287                                               New->getDeclName());
4288         if (!BaseTInfo) {
4289           AnyErrors = true;
4290           break;
4291         }
4292 
4293         // Build the initializer.
4294         MemInitResult NewInit = BuildBaseInitializer(BaseTInfo->getType(),
4295                                                      BaseTInfo, TempInit.get(),
4296                                                      New->getParent(),
4297                                                      SourceLocation());
4298         if (NewInit.isInvalid()) {
4299           AnyErrors = true;
4300           break;
4301         }
4302 
4303         NewInits.push_back(NewInit.get());
4304       }
4305 
4306       continue;
4307     }
4308 
4309     // Instantiate the initializer.
4310     ExprResult TempInit = SubstInitializer(Init->getInit(), TemplateArgs,
4311                                            /*CXXDirectInit=*/true);
4312     if (TempInit.isInvalid()) {
4313       AnyErrors = true;
4314       continue;
4315     }
4316 
4317     MemInitResult NewInit;
4318     if (Init->isDelegatingInitializer() || Init->isBaseInitializer()) {
4319       TypeSourceInfo *TInfo = SubstType(Init->getTypeSourceInfo(),
4320                                         TemplateArgs,
4321                                         Init->getSourceLocation(),
4322                                         New->getDeclName());
4323       if (!TInfo) {
4324         AnyErrors = true;
4325         New->setInvalidDecl();
4326         continue;
4327       }
4328 
4329       if (Init->isBaseInitializer())
4330         NewInit = BuildBaseInitializer(TInfo->getType(), TInfo, TempInit.get(),
4331                                        New->getParent(), EllipsisLoc);
4332       else
4333         NewInit = BuildDelegatingInitializer(TInfo, TempInit.get(),
4334                                   cast<CXXRecordDecl>(CurContext->getParent()));
4335     } else if (Init->isMemberInitializer()) {
4336       FieldDecl *Member = cast_or_null<FieldDecl>(FindInstantiatedDecl(
4337                                                      Init->getMemberLocation(),
4338                                                      Init->getMember(),
4339                                                      TemplateArgs));
4340       if (!Member) {
4341         AnyErrors = true;
4342         New->setInvalidDecl();
4343         continue;
4344       }
4345 
4346       NewInit = BuildMemberInitializer(Member, TempInit.get(),
4347                                        Init->getSourceLocation());
4348     } else if (Init->isIndirectMemberInitializer()) {
4349       IndirectFieldDecl *IndirectMember =
4350          cast_or_null<IndirectFieldDecl>(FindInstantiatedDecl(
4351                                  Init->getMemberLocation(),
4352                                  Init->getIndirectMember(), TemplateArgs));
4353 
4354       if (!IndirectMember) {
4355         AnyErrors = true;
4356         New->setInvalidDecl();
4357         continue;
4358       }
4359 
4360       NewInit = BuildMemberInitializer(IndirectMember, TempInit.get(),
4361                                        Init->getSourceLocation());
4362     }
4363 
4364     if (NewInit.isInvalid()) {
4365       AnyErrors = true;
4366       New->setInvalidDecl();
4367     } else {
4368       NewInits.push_back(NewInit.get());
4369     }
4370   }
4371 
4372   // Assign all the initializers to the new constructor.
4373   ActOnMemInitializers(New,
4374                        /*FIXME: ColonLoc */
4375                        SourceLocation(),
4376                        NewInits,
4377                        AnyErrors);
4378 }
4379 
4380 // TODO: this could be templated if the various decl types used the
4381 // same method name.
4382 static bool isInstantiationOf(ClassTemplateDecl *Pattern,
4383                               ClassTemplateDecl *Instance) {
4384   Pattern = Pattern->getCanonicalDecl();
4385 
4386   do {
4387     Instance = Instance->getCanonicalDecl();
4388     if (Pattern == Instance) return true;
4389     Instance = Instance->getInstantiatedFromMemberTemplate();
4390   } while (Instance);
4391 
4392   return false;
4393 }
4394 
4395 static bool isInstantiationOf(FunctionTemplateDecl *Pattern,
4396                               FunctionTemplateDecl *Instance) {
4397   Pattern = Pattern->getCanonicalDecl();
4398 
4399   do {
4400     Instance = Instance->getCanonicalDecl();
4401     if (Pattern == Instance) return true;
4402     Instance = Instance->getInstantiatedFromMemberTemplate();
4403   } while (Instance);
4404 
4405   return false;
4406 }
4407 
4408 static bool
4409 isInstantiationOf(ClassTemplatePartialSpecializationDecl *Pattern,
4410                   ClassTemplatePartialSpecializationDecl *Instance) {
4411   Pattern
4412     = cast<ClassTemplatePartialSpecializationDecl>(Pattern->getCanonicalDecl());
4413   do {
4414     Instance = cast<ClassTemplatePartialSpecializationDecl>(
4415                                                 Instance->getCanonicalDecl());
4416     if (Pattern == Instance)
4417       return true;
4418     Instance = Instance->getInstantiatedFromMember();
4419   } while (Instance);
4420 
4421   return false;
4422 }
4423 
4424 static bool isInstantiationOf(CXXRecordDecl *Pattern,
4425                               CXXRecordDecl *Instance) {
4426   Pattern = Pattern->getCanonicalDecl();
4427 
4428   do {
4429     Instance = Instance->getCanonicalDecl();
4430     if (Pattern == Instance) return true;
4431     Instance = Instance->getInstantiatedFromMemberClass();
4432   } while (Instance);
4433 
4434   return false;
4435 }
4436 
4437 static bool isInstantiationOf(FunctionDecl *Pattern,
4438                               FunctionDecl *Instance) {
4439   Pattern = Pattern->getCanonicalDecl();
4440 
4441   do {
4442     Instance = Instance->getCanonicalDecl();
4443     if (Pattern == Instance) return true;
4444     Instance = Instance->getInstantiatedFromMemberFunction();
4445   } while (Instance);
4446 
4447   return false;
4448 }
4449 
4450 static bool isInstantiationOf(EnumDecl *Pattern,
4451                               EnumDecl *Instance) {
4452   Pattern = Pattern->getCanonicalDecl();
4453 
4454   do {
4455     Instance = Instance->getCanonicalDecl();
4456     if (Pattern == Instance) return true;
4457     Instance = Instance->getInstantiatedFromMemberEnum();
4458   } while (Instance);
4459 
4460   return false;
4461 }
4462 
4463 static bool isInstantiationOf(UsingShadowDecl *Pattern,
4464                               UsingShadowDecl *Instance,
4465                               ASTContext &C) {
4466   return declaresSameEntity(C.getInstantiatedFromUsingShadowDecl(Instance),
4467                             Pattern);
4468 }
4469 
4470 static bool isInstantiationOf(UsingDecl *Pattern,
4471                               UsingDecl *Instance,
4472                               ASTContext &C) {
4473   return declaresSameEntity(C.getInstantiatedFromUsingDecl(Instance), Pattern);
4474 }
4475 
4476 static bool isInstantiationOf(UnresolvedUsingValueDecl *Pattern,
4477                               UsingDecl *Instance,
4478                               ASTContext &C) {
4479   return declaresSameEntity(C.getInstantiatedFromUsingDecl(Instance), Pattern);
4480 }
4481 
4482 static bool isInstantiationOf(UnresolvedUsingTypenameDecl *Pattern,
4483                               UsingDecl *Instance,
4484                               ASTContext &C) {
4485   return declaresSameEntity(C.getInstantiatedFromUsingDecl(Instance), Pattern);
4486 }
4487 
4488 static bool isInstantiationOfStaticDataMember(VarDecl *Pattern,
4489                                               VarDecl *Instance) {
4490   assert(Instance->isStaticDataMember());
4491 
4492   Pattern = Pattern->getCanonicalDecl();
4493 
4494   do {
4495     Instance = Instance->getCanonicalDecl();
4496     if (Pattern == Instance) return true;
4497     Instance = Instance->getInstantiatedFromStaticDataMember();
4498   } while (Instance);
4499 
4500   return false;
4501 }
4502 
4503 // Other is the prospective instantiation
4504 // D is the prospective pattern
4505 static bool isInstantiationOf(ASTContext &Ctx, NamedDecl *D, Decl *Other) {
4506   if (D->getKind() != Other->getKind()) {
4507     if (UnresolvedUsingTypenameDecl *UUD
4508           = dyn_cast<UnresolvedUsingTypenameDecl>(D)) {
4509       if (UsingDecl *UD = dyn_cast<UsingDecl>(Other)) {
4510         return isInstantiationOf(UUD, UD, Ctx);
4511       }
4512     }
4513 
4514     if (UnresolvedUsingValueDecl *UUD
4515           = dyn_cast<UnresolvedUsingValueDecl>(D)) {
4516       if (UsingDecl *UD = dyn_cast<UsingDecl>(Other)) {
4517         return isInstantiationOf(UUD, UD, Ctx);
4518       }
4519     }
4520 
4521     return false;
4522   }
4523 
4524   if (CXXRecordDecl *Record = dyn_cast<CXXRecordDecl>(Other))
4525     return isInstantiationOf(cast<CXXRecordDecl>(D), Record);
4526 
4527   if (FunctionDecl *Function = dyn_cast<FunctionDecl>(Other))
4528     return isInstantiationOf(cast<FunctionDecl>(D), Function);
4529 
4530   if (EnumDecl *Enum = dyn_cast<EnumDecl>(Other))
4531     return isInstantiationOf(cast<EnumDecl>(D), Enum);
4532 
4533   if (VarDecl *Var = dyn_cast<VarDecl>(Other))
4534     if (Var->isStaticDataMember())
4535       return isInstantiationOfStaticDataMember(cast<VarDecl>(D), Var);
4536 
4537   if (ClassTemplateDecl *Temp = dyn_cast<ClassTemplateDecl>(Other))
4538     return isInstantiationOf(cast<ClassTemplateDecl>(D), Temp);
4539 
4540   if (FunctionTemplateDecl *Temp = dyn_cast<FunctionTemplateDecl>(Other))
4541     return isInstantiationOf(cast<FunctionTemplateDecl>(D), Temp);
4542 
4543   if (ClassTemplatePartialSpecializationDecl *PartialSpec
4544         = dyn_cast<ClassTemplatePartialSpecializationDecl>(Other))
4545     return isInstantiationOf(cast<ClassTemplatePartialSpecializationDecl>(D),
4546                              PartialSpec);
4547 
4548   if (FieldDecl *Field = dyn_cast<FieldDecl>(Other)) {
4549     if (!Field->getDeclName()) {
4550       // This is an unnamed field.
4551       return declaresSameEntity(Ctx.getInstantiatedFromUnnamedFieldDecl(Field),
4552                                 cast<FieldDecl>(D));
4553     }
4554   }
4555 
4556   if (UsingDecl *Using = dyn_cast<UsingDecl>(Other))
4557     return isInstantiationOf(cast<UsingDecl>(D), Using, Ctx);
4558 
4559   if (UsingShadowDecl *Shadow = dyn_cast<UsingShadowDecl>(Other))
4560     return isInstantiationOf(cast<UsingShadowDecl>(D), Shadow, Ctx);
4561 
4562   return D->getDeclName() && isa<NamedDecl>(Other) &&
4563     D->getDeclName() == cast<NamedDecl>(Other)->getDeclName();
4564 }
4565 
4566 template<typename ForwardIterator>
4567 static NamedDecl *findInstantiationOf(ASTContext &Ctx,
4568                                       NamedDecl *D,
4569                                       ForwardIterator first,
4570                                       ForwardIterator last) {
4571   for (; first != last; ++first)
4572     if (isInstantiationOf(Ctx, D, *first))
4573       return cast<NamedDecl>(*first);
4574 
4575   return nullptr;
4576 }
4577 
4578 /// \brief Finds the instantiation of the given declaration context
4579 /// within the current instantiation.
4580 ///
4581 /// \returns NULL if there was an error
4582 DeclContext *Sema::FindInstantiatedContext(SourceLocation Loc, DeclContext* DC,
4583                           const MultiLevelTemplateArgumentList &TemplateArgs) {
4584   if (NamedDecl *D = dyn_cast<NamedDecl>(DC)) {
4585     Decl* ID = FindInstantiatedDecl(Loc, D, TemplateArgs);
4586     return cast_or_null<DeclContext>(ID);
4587   } else return DC;
4588 }
4589 
4590 /// \brief Find the instantiation of the given declaration within the
4591 /// current instantiation.
4592 ///
4593 /// This routine is intended to be used when \p D is a declaration
4594 /// referenced from within a template, that needs to mapped into the
4595 /// corresponding declaration within an instantiation. For example,
4596 /// given:
4597 ///
4598 /// \code
4599 /// template<typename T>
4600 /// struct X {
4601 ///   enum Kind {
4602 ///     KnownValue = sizeof(T)
4603 ///   };
4604 ///
4605 ///   bool getKind() const { return KnownValue; }
4606 /// };
4607 ///
4608 /// template struct X<int>;
4609 /// \endcode
4610 ///
4611 /// In the instantiation of <tt>X<int>::getKind()</tt>, we need to map the
4612 /// \p EnumConstantDecl for \p KnownValue (which refers to
4613 /// <tt>X<T>::<Kind>::KnownValue</tt>) to its instantiation
4614 /// (<tt>X<int>::<Kind>::KnownValue</tt>). \p FindInstantiatedDecl performs
4615 /// this mapping from within the instantiation of <tt>X<int></tt>.
4616 NamedDecl *Sema::FindInstantiatedDecl(SourceLocation Loc, NamedDecl *D,
4617                           const MultiLevelTemplateArgumentList &TemplateArgs) {
4618   DeclContext *ParentDC = D->getDeclContext();
4619   // FIXME: Parmeters of pointer to functions (y below) that are themselves
4620   // parameters (p below) can have their ParentDC set to the translation-unit
4621   // - thus we can not consistently check if the ParentDC of such a parameter
4622   // is Dependent or/and a FunctionOrMethod.
4623   // For e.g. this code, during Template argument deduction tries to
4624   // find an instantiated decl for (T y) when the ParentDC for y is
4625   // the translation unit.
4626   //   e.g. template <class T> void Foo(auto (*p)(T y) -> decltype(y())) {}
4627   //   float baz(float(*)()) { return 0.0; }
4628   //   Foo(baz);
4629   // The better fix here is perhaps to ensure that a ParmVarDecl, by the time
4630   // it gets here, always has a FunctionOrMethod as its ParentDC??
4631   // For now:
4632   //  - as long as we have a ParmVarDecl whose parent is non-dependent and
4633   //    whose type is not instantiation dependent, do nothing to the decl
4634   //  - otherwise find its instantiated decl.
4635   if (isa<ParmVarDecl>(D) && !ParentDC->isDependentContext() &&
4636       !cast<ParmVarDecl>(D)->getType()->isInstantiationDependentType())
4637     return D;
4638   if (isa<ParmVarDecl>(D) || isa<NonTypeTemplateParmDecl>(D) ||
4639       isa<TemplateTypeParmDecl>(D) || isa<TemplateTemplateParmDecl>(D) ||
4640       (ParentDC->isFunctionOrMethod() && ParentDC->isDependentContext()) ||
4641       (isa<CXXRecordDecl>(D) && cast<CXXRecordDecl>(D)->isLambda())) {
4642     // D is a local of some kind. Look into the map of local
4643     // declarations to their instantiations.
4644     if (CurrentInstantiationScope) {
4645       if (auto Found = CurrentInstantiationScope->findInstantiationOf(D)) {
4646         if (Decl *FD = Found->dyn_cast<Decl *>())
4647           return cast<NamedDecl>(FD);
4648 
4649         int PackIdx = ArgumentPackSubstitutionIndex;
4650         assert(PackIdx != -1 &&
4651                "found declaration pack but not pack expanding");
4652         typedef LocalInstantiationScope::DeclArgumentPack DeclArgumentPack;
4653         return cast<NamedDecl>((*Found->get<DeclArgumentPack *>())[PackIdx]);
4654       }
4655     }
4656 
4657     // If we're performing a partial substitution during template argument
4658     // deduction, we may not have values for template parameters yet. They
4659     // just map to themselves.
4660     if (isa<NonTypeTemplateParmDecl>(D) || isa<TemplateTypeParmDecl>(D) ||
4661         isa<TemplateTemplateParmDecl>(D))
4662       return D;
4663 
4664     if (D->isInvalidDecl())
4665       return nullptr;
4666 
4667     // Normally this function only searches for already instantiated declaration
4668     // however we have to make an exclusion for local types used before
4669     // definition as in the code:
4670     //
4671     //   template<typename T> void f1() {
4672     //     void g1(struct x1);
4673     //     struct x1 {};
4674     //   }
4675     //
4676     // In this case instantiation of the type of 'g1' requires definition of
4677     // 'x1', which is defined later. Error recovery may produce an enum used
4678     // before definition. In these cases we need to instantiate relevant
4679     // declarations here.
4680     bool NeedInstantiate = false;
4681     if (CXXRecordDecl *RD = dyn_cast<CXXRecordDecl>(D))
4682       NeedInstantiate = RD->isLocalClass();
4683     else
4684       NeedInstantiate = isa<EnumDecl>(D);
4685     if (NeedInstantiate) {
4686       Decl *Inst = SubstDecl(D, CurContext, TemplateArgs);
4687       CurrentInstantiationScope->InstantiatedLocal(D, Inst);
4688       return cast<TypeDecl>(Inst);
4689     }
4690 
4691     // If we didn't find the decl, then we must have a label decl that hasn't
4692     // been found yet.  Lazily instantiate it and return it now.
4693     assert(isa<LabelDecl>(D));
4694 
4695     Decl *Inst = SubstDecl(D, CurContext, TemplateArgs);
4696     assert(Inst && "Failed to instantiate label??");
4697 
4698     CurrentInstantiationScope->InstantiatedLocal(D, Inst);
4699     return cast<LabelDecl>(Inst);
4700   }
4701 
4702   // For variable template specializations, update those that are still
4703   // type-dependent.
4704   if (VarTemplateSpecializationDecl *VarSpec =
4705           dyn_cast<VarTemplateSpecializationDecl>(D)) {
4706     bool InstantiationDependent = false;
4707     const TemplateArgumentListInfo &VarTemplateArgs =
4708         VarSpec->getTemplateArgsInfo();
4709     if (TemplateSpecializationType::anyDependentTemplateArguments(
4710             VarTemplateArgs, InstantiationDependent))
4711       D = cast<NamedDecl>(
4712           SubstDecl(D, VarSpec->getDeclContext(), TemplateArgs));
4713     return D;
4714   }
4715 
4716   if (CXXRecordDecl *Record = dyn_cast<CXXRecordDecl>(D)) {
4717     if (!Record->isDependentContext())
4718       return D;
4719 
4720     // Determine whether this record is the "templated" declaration describing
4721     // a class template or class template partial specialization.
4722     ClassTemplateDecl *ClassTemplate = Record->getDescribedClassTemplate();
4723     if (ClassTemplate)
4724       ClassTemplate = ClassTemplate->getCanonicalDecl();
4725     else if (ClassTemplatePartialSpecializationDecl *PartialSpec
4726                = dyn_cast<ClassTemplatePartialSpecializationDecl>(Record))
4727       ClassTemplate = PartialSpec->getSpecializedTemplate()->getCanonicalDecl();
4728 
4729     // Walk the current context to find either the record or an instantiation of
4730     // it.
4731     DeclContext *DC = CurContext;
4732     while (!DC->isFileContext()) {
4733       // If we're performing substitution while we're inside the template
4734       // definition, we'll find our own context. We're done.
4735       if (DC->Equals(Record))
4736         return Record;
4737 
4738       if (CXXRecordDecl *InstRecord = dyn_cast<CXXRecordDecl>(DC)) {
4739         // Check whether we're in the process of instantiating a class template
4740         // specialization of the template we're mapping.
4741         if (ClassTemplateSpecializationDecl *InstSpec
4742                       = dyn_cast<ClassTemplateSpecializationDecl>(InstRecord)){
4743           ClassTemplateDecl *SpecTemplate = InstSpec->getSpecializedTemplate();
4744           if (ClassTemplate && isInstantiationOf(ClassTemplate, SpecTemplate))
4745             return InstRecord;
4746         }
4747 
4748         // Check whether we're in the process of instantiating a member class.
4749         if (isInstantiationOf(Record, InstRecord))
4750           return InstRecord;
4751       }
4752 
4753       // Move to the outer template scope.
4754       if (FunctionDecl *FD = dyn_cast<FunctionDecl>(DC)) {
4755         if (FD->getFriendObjectKind() && FD->getDeclContext()->isFileContext()){
4756           DC = FD->getLexicalDeclContext();
4757           continue;
4758         }
4759       }
4760 
4761       DC = DC->getParent();
4762     }
4763 
4764     // Fall through to deal with other dependent record types (e.g.,
4765     // anonymous unions in class templates).
4766   }
4767 
4768   if (!ParentDC->isDependentContext())
4769     return D;
4770 
4771   ParentDC = FindInstantiatedContext(Loc, ParentDC, TemplateArgs);
4772   if (!ParentDC)
4773     return nullptr;
4774 
4775   if (ParentDC != D->getDeclContext()) {
4776     // We performed some kind of instantiation in the parent context,
4777     // so now we need to look into the instantiated parent context to
4778     // find the instantiation of the declaration D.
4779 
4780     // If our context used to be dependent, we may need to instantiate
4781     // it before performing lookup into that context.
4782     bool IsBeingInstantiated = false;
4783     if (CXXRecordDecl *Spec = dyn_cast<CXXRecordDecl>(ParentDC)) {
4784       if (!Spec->isDependentContext()) {
4785         QualType T = Context.getTypeDeclType(Spec);
4786         const RecordType *Tag = T->getAs<RecordType>();
4787         assert(Tag && "type of non-dependent record is not a RecordType");
4788         if (Tag->isBeingDefined())
4789           IsBeingInstantiated = true;
4790         if (!Tag->isBeingDefined() &&
4791             RequireCompleteType(Loc, T, diag::err_incomplete_type))
4792           return nullptr;
4793 
4794         ParentDC = Tag->getDecl();
4795       }
4796     }
4797 
4798     NamedDecl *Result = nullptr;
4799     if (D->getDeclName()) {
4800       DeclContext::lookup_result Found = ParentDC->lookup(D->getDeclName());
4801       Result = findInstantiationOf(Context, D, Found.begin(), Found.end());
4802     } else {
4803       // Since we don't have a name for the entity we're looking for,
4804       // our only option is to walk through all of the declarations to
4805       // find that name. This will occur in a few cases:
4806       //
4807       //   - anonymous struct/union within a template
4808       //   - unnamed class/struct/union/enum within a template
4809       //
4810       // FIXME: Find a better way to find these instantiations!
4811       Result = findInstantiationOf(Context, D,
4812                                    ParentDC->decls_begin(),
4813                                    ParentDC->decls_end());
4814     }
4815 
4816     if (!Result) {
4817       if (isa<UsingShadowDecl>(D)) {
4818         // UsingShadowDecls can instantiate to nothing because of using hiding.
4819       } else if (Diags.hasErrorOccurred()) {
4820         // We've already complained about something, so most likely this
4821         // declaration failed to instantiate. There's no point in complaining
4822         // further, since this is normal in invalid code.
4823       } else if (IsBeingInstantiated) {
4824         // The class in which this member exists is currently being
4825         // instantiated, and we haven't gotten around to instantiating this
4826         // member yet. This can happen when the code uses forward declarations
4827         // of member classes, and introduces ordering dependencies via
4828         // template instantiation.
4829         Diag(Loc, diag::err_member_not_yet_instantiated)
4830           << D->getDeclName()
4831           << Context.getTypeDeclType(cast<CXXRecordDecl>(ParentDC));
4832         Diag(D->getLocation(), diag::note_non_instantiated_member_here);
4833       } else if (EnumConstantDecl *ED = dyn_cast<EnumConstantDecl>(D)) {
4834         // This enumeration constant was found when the template was defined,
4835         // but can't be found in the instantiation. This can happen if an
4836         // unscoped enumeration member is explicitly specialized.
4837         EnumDecl *Enum = cast<EnumDecl>(ED->getLexicalDeclContext());
4838         EnumDecl *Spec = cast<EnumDecl>(FindInstantiatedDecl(Loc, Enum,
4839                                                              TemplateArgs));
4840         assert(Spec->getTemplateSpecializationKind() ==
4841                  TSK_ExplicitSpecialization);
4842         Diag(Loc, diag::err_enumerator_does_not_exist)
4843           << D->getDeclName()
4844           << Context.getTypeDeclType(cast<TypeDecl>(Spec->getDeclContext()));
4845         Diag(Spec->getLocation(), diag::note_enum_specialized_here)
4846           << Context.getTypeDeclType(Spec);
4847       } else {
4848         // We should have found something, but didn't.
4849         llvm_unreachable("Unable to find instantiation of declaration!");
4850       }
4851     }
4852 
4853     D = Result;
4854   }
4855 
4856   return D;
4857 }
4858 
4859 /// \brief Performs template instantiation for all implicit template
4860 /// instantiations we have seen until this point.
4861 void Sema::PerformPendingInstantiations(bool LocalOnly) {
4862   while (!PendingLocalImplicitInstantiations.empty() ||
4863          (!LocalOnly && !PendingInstantiations.empty())) {
4864     PendingImplicitInstantiation Inst;
4865 
4866     if (PendingLocalImplicitInstantiations.empty()) {
4867       Inst = PendingInstantiations.front();
4868       PendingInstantiations.pop_front();
4869     } else {
4870       Inst = PendingLocalImplicitInstantiations.front();
4871       PendingLocalImplicitInstantiations.pop_front();
4872     }
4873 
4874     // Instantiate function definitions
4875     if (FunctionDecl *Function = dyn_cast<FunctionDecl>(Inst.first)) {
4876       PrettyDeclStackTraceEntry CrashInfo(*this, Function, SourceLocation(),
4877                                           "instantiating function definition");
4878       bool DefinitionRequired = Function->getTemplateSpecializationKind() ==
4879                                 TSK_ExplicitInstantiationDefinition;
4880       InstantiateFunctionDefinition(/*FIXME:*/Inst.second, Function, true,
4881                                     DefinitionRequired, true);
4882       continue;
4883     }
4884 
4885     // Instantiate variable definitions
4886     VarDecl *Var = cast<VarDecl>(Inst.first);
4887 
4888     assert((Var->isStaticDataMember() ||
4889             isa<VarTemplateSpecializationDecl>(Var)) &&
4890            "Not a static data member, nor a variable template"
4891            " specialization?");
4892 
4893     // Don't try to instantiate declarations if the most recent redeclaration
4894     // is invalid.
4895     if (Var->getMostRecentDecl()->isInvalidDecl())
4896       continue;
4897 
4898     // Check if the most recent declaration has changed the specialization kind
4899     // and removed the need for implicit instantiation.
4900     switch (Var->getMostRecentDecl()->getTemplateSpecializationKind()) {
4901     case TSK_Undeclared:
4902       llvm_unreachable("Cannot instantitiate an undeclared specialization.");
4903     case TSK_ExplicitInstantiationDeclaration:
4904     case TSK_ExplicitSpecialization:
4905       continue;  // No longer need to instantiate this type.
4906     case TSK_ExplicitInstantiationDefinition:
4907       // We only need an instantiation if the pending instantiation *is* the
4908       // explicit instantiation.
4909       if (Var != Var->getMostRecentDecl()) continue;
4910     case TSK_ImplicitInstantiation:
4911       break;
4912     }
4913 
4914     PrettyDeclStackTraceEntry CrashInfo(*this, Var, SourceLocation(),
4915                                         "instantiating variable definition");
4916     bool DefinitionRequired = Var->getTemplateSpecializationKind() ==
4917                               TSK_ExplicitInstantiationDefinition;
4918 
4919     // Instantiate static data member definitions or variable template
4920     // specializations.
4921     InstantiateVariableDefinition(/*FIXME:*/ Inst.second, Var, true,
4922                                   DefinitionRequired, true);
4923   }
4924 }
4925 
4926 void Sema::PerformDependentDiagnostics(const DeclContext *Pattern,
4927                        const MultiLevelTemplateArgumentList &TemplateArgs) {
4928   for (auto DD : Pattern->ddiags()) {
4929     switch (DD->getKind()) {
4930     case DependentDiagnostic::Access:
4931       HandleDependentAccessCheck(*DD, TemplateArgs);
4932       break;
4933     }
4934   }
4935 }
4936