xref: /aosp_15_r20/external/clang/lib/Sema/SemaTemplateInstantiate.cpp (revision 67e74705e28f6214e480b399dd47ea732279e315)
1*67e74705SXin Li //===------- SemaTemplateInstantiate.cpp - C++ Template Instantiation ------===/
2*67e74705SXin Li //
3*67e74705SXin Li //                     The LLVM Compiler Infrastructure
4*67e74705SXin Li //
5*67e74705SXin Li // This file is distributed under the University of Illinois Open Source
6*67e74705SXin Li // License. See LICENSE.TXT for details.
7*67e74705SXin Li //===----------------------------------------------------------------------===/
8*67e74705SXin Li //
9*67e74705SXin Li //  This file implements C++ template instantiation.
10*67e74705SXin Li //
11*67e74705SXin Li //===----------------------------------------------------------------------===/
12*67e74705SXin Li 
13*67e74705SXin Li #include "clang/Sema/SemaInternal.h"
14*67e74705SXin Li #include "TreeTransform.h"
15*67e74705SXin Li #include "clang/AST/ASTConsumer.h"
16*67e74705SXin Li #include "clang/AST/ASTContext.h"
17*67e74705SXin Li #include "clang/AST/ASTLambda.h"
18*67e74705SXin Li #include "clang/AST/DeclTemplate.h"
19*67e74705SXin Li #include "clang/AST/Expr.h"
20*67e74705SXin Li #include "clang/Basic/LangOptions.h"
21*67e74705SXin Li #include "clang/Sema/DeclSpec.h"
22*67e74705SXin Li #include "clang/Sema/Initialization.h"
23*67e74705SXin Li #include "clang/Sema/Lookup.h"
24*67e74705SXin Li #include "clang/Sema/PrettyDeclStackTrace.h"
25*67e74705SXin Li #include "clang/Sema/Template.h"
26*67e74705SXin Li #include "clang/Sema/TemplateDeduction.h"
27*67e74705SXin Li 
28*67e74705SXin Li using namespace clang;
29*67e74705SXin Li using namespace sema;
30*67e74705SXin Li 
31*67e74705SXin Li //===----------------------------------------------------------------------===/
32*67e74705SXin Li // Template Instantiation Support
33*67e74705SXin Li //===----------------------------------------------------------------------===/
34*67e74705SXin Li 
35*67e74705SXin Li /// \brief Retrieve the template argument list(s) that should be used to
36*67e74705SXin Li /// instantiate the definition of the given declaration.
37*67e74705SXin Li ///
38*67e74705SXin Li /// \param D the declaration for which we are computing template instantiation
39*67e74705SXin Li /// arguments.
40*67e74705SXin Li ///
41*67e74705SXin Li /// \param Innermost if non-NULL, the innermost template argument list.
42*67e74705SXin Li ///
43*67e74705SXin Li /// \param RelativeToPrimary true if we should get the template
44*67e74705SXin Li /// arguments relative to the primary template, even when we're
45*67e74705SXin Li /// dealing with a specialization. This is only relevant for function
46*67e74705SXin Li /// template specializations.
47*67e74705SXin Li ///
48*67e74705SXin Li /// \param Pattern If non-NULL, indicates the pattern from which we will be
49*67e74705SXin Li /// instantiating the definition of the given declaration, \p D. This is
50*67e74705SXin Li /// used to determine the proper set of template instantiation arguments for
51*67e74705SXin Li /// friend function template specializations.
52*67e74705SXin Li MultiLevelTemplateArgumentList
getTemplateInstantiationArgs(NamedDecl * D,const TemplateArgumentList * Innermost,bool RelativeToPrimary,const FunctionDecl * Pattern)53*67e74705SXin Li Sema::getTemplateInstantiationArgs(NamedDecl *D,
54*67e74705SXin Li                                    const TemplateArgumentList *Innermost,
55*67e74705SXin Li                                    bool RelativeToPrimary,
56*67e74705SXin Li                                    const FunctionDecl *Pattern) {
57*67e74705SXin Li   // Accumulate the set of template argument lists in this structure.
58*67e74705SXin Li   MultiLevelTemplateArgumentList Result;
59*67e74705SXin Li 
60*67e74705SXin Li   if (Innermost)
61*67e74705SXin Li     Result.addOuterTemplateArguments(Innermost);
62*67e74705SXin Li 
63*67e74705SXin Li   DeclContext *Ctx = dyn_cast<DeclContext>(D);
64*67e74705SXin Li   if (!Ctx) {
65*67e74705SXin Li     Ctx = D->getDeclContext();
66*67e74705SXin Li 
67*67e74705SXin Li     // Add template arguments from a variable template instantiation.
68*67e74705SXin Li     if (VarTemplateSpecializationDecl *Spec =
69*67e74705SXin Li             dyn_cast<VarTemplateSpecializationDecl>(D)) {
70*67e74705SXin Li       // We're done when we hit an explicit specialization.
71*67e74705SXin Li       if (Spec->getSpecializationKind() == TSK_ExplicitSpecialization &&
72*67e74705SXin Li           !isa<VarTemplatePartialSpecializationDecl>(Spec))
73*67e74705SXin Li         return Result;
74*67e74705SXin Li 
75*67e74705SXin Li       Result.addOuterTemplateArguments(&Spec->getTemplateInstantiationArgs());
76*67e74705SXin Li 
77*67e74705SXin Li       // If this variable template specialization was instantiated from a
78*67e74705SXin Li       // specialized member that is a variable template, we're done.
79*67e74705SXin Li       assert(Spec->getSpecializedTemplate() && "No variable template?");
80*67e74705SXin Li       llvm::PointerUnion<VarTemplateDecl*,
81*67e74705SXin Li                          VarTemplatePartialSpecializationDecl*> Specialized
82*67e74705SXin Li                              = Spec->getSpecializedTemplateOrPartial();
83*67e74705SXin Li       if (VarTemplatePartialSpecializationDecl *Partial =
84*67e74705SXin Li               Specialized.dyn_cast<VarTemplatePartialSpecializationDecl *>()) {
85*67e74705SXin Li         if (Partial->isMemberSpecialization())
86*67e74705SXin Li           return Result;
87*67e74705SXin Li       } else {
88*67e74705SXin Li         VarTemplateDecl *Tmpl = Specialized.get<VarTemplateDecl *>();
89*67e74705SXin Li         if (Tmpl->isMemberSpecialization())
90*67e74705SXin Li           return Result;
91*67e74705SXin Li       }
92*67e74705SXin Li     }
93*67e74705SXin Li 
94*67e74705SXin Li     // If we have a template template parameter with translation unit context,
95*67e74705SXin Li     // then we're performing substitution into a default template argument of
96*67e74705SXin Li     // this template template parameter before we've constructed the template
97*67e74705SXin Li     // that will own this template template parameter. In this case, we
98*67e74705SXin Li     // use empty template parameter lists for all of the outer templates
99*67e74705SXin Li     // to avoid performing any substitutions.
100*67e74705SXin Li     if (Ctx->isTranslationUnit()) {
101*67e74705SXin Li       if (TemplateTemplateParmDecl *TTP
102*67e74705SXin Li                                       = dyn_cast<TemplateTemplateParmDecl>(D)) {
103*67e74705SXin Li         for (unsigned I = 0, N = TTP->getDepth() + 1; I != N; ++I)
104*67e74705SXin Li           Result.addOuterTemplateArguments(None);
105*67e74705SXin Li         return Result;
106*67e74705SXin Li       }
107*67e74705SXin Li     }
108*67e74705SXin Li   }
109*67e74705SXin Li 
110*67e74705SXin Li   while (!Ctx->isFileContext()) {
111*67e74705SXin Li     // Add template arguments from a class template instantiation.
112*67e74705SXin Li     if (ClassTemplateSpecializationDecl *Spec
113*67e74705SXin Li           = dyn_cast<ClassTemplateSpecializationDecl>(Ctx)) {
114*67e74705SXin Li       // We're done when we hit an explicit specialization.
115*67e74705SXin Li       if (Spec->getSpecializationKind() == TSK_ExplicitSpecialization &&
116*67e74705SXin Li           !isa<ClassTemplatePartialSpecializationDecl>(Spec))
117*67e74705SXin Li         break;
118*67e74705SXin Li 
119*67e74705SXin Li       Result.addOuterTemplateArguments(&Spec->getTemplateInstantiationArgs());
120*67e74705SXin Li 
121*67e74705SXin Li       // If this class template specialization was instantiated from a
122*67e74705SXin Li       // specialized member that is a class template, we're done.
123*67e74705SXin Li       assert(Spec->getSpecializedTemplate() && "No class template?");
124*67e74705SXin Li       if (Spec->getSpecializedTemplate()->isMemberSpecialization())
125*67e74705SXin Li         break;
126*67e74705SXin Li     }
127*67e74705SXin Li     // Add template arguments from a function template specialization.
128*67e74705SXin Li     else if (FunctionDecl *Function = dyn_cast<FunctionDecl>(Ctx)) {
129*67e74705SXin Li       if (!RelativeToPrimary &&
130*67e74705SXin Li           (Function->getTemplateSpecializationKind() ==
131*67e74705SXin Li                                                   TSK_ExplicitSpecialization &&
132*67e74705SXin Li            !Function->getClassScopeSpecializationPattern()))
133*67e74705SXin Li         break;
134*67e74705SXin Li 
135*67e74705SXin Li       if (const TemplateArgumentList *TemplateArgs
136*67e74705SXin Li             = Function->getTemplateSpecializationArgs()) {
137*67e74705SXin Li         // Add the template arguments for this specialization.
138*67e74705SXin Li         Result.addOuterTemplateArguments(TemplateArgs);
139*67e74705SXin Li 
140*67e74705SXin Li         // If this function was instantiated from a specialized member that is
141*67e74705SXin Li         // a function template, we're done.
142*67e74705SXin Li         assert(Function->getPrimaryTemplate() && "No function template?");
143*67e74705SXin Li         if (Function->getPrimaryTemplate()->isMemberSpecialization())
144*67e74705SXin Li           break;
145*67e74705SXin Li 
146*67e74705SXin Li         // If this function is a generic lambda specialization, we are done.
147*67e74705SXin Li         if (isGenericLambdaCallOperatorSpecialization(Function))
148*67e74705SXin Li           break;
149*67e74705SXin Li 
150*67e74705SXin Li       } else if (FunctionTemplateDecl *FunTmpl
151*67e74705SXin Li                                    = Function->getDescribedFunctionTemplate()) {
152*67e74705SXin Li         // Add the "injected" template arguments.
153*67e74705SXin Li         Result.addOuterTemplateArguments(FunTmpl->getInjectedTemplateArgs());
154*67e74705SXin Li       }
155*67e74705SXin Li 
156*67e74705SXin Li       // If this is a friend declaration and it declares an entity at
157*67e74705SXin Li       // namespace scope, take arguments from its lexical parent
158*67e74705SXin Li       // instead of its semantic parent, unless of course the pattern we're
159*67e74705SXin Li       // instantiating actually comes from the file's context!
160*67e74705SXin Li       if (Function->getFriendObjectKind() &&
161*67e74705SXin Li           Function->getDeclContext()->isFileContext() &&
162*67e74705SXin Li           (!Pattern || !Pattern->getLexicalDeclContext()->isFileContext())) {
163*67e74705SXin Li         Ctx = Function->getLexicalDeclContext();
164*67e74705SXin Li         RelativeToPrimary = false;
165*67e74705SXin Li         continue;
166*67e74705SXin Li       }
167*67e74705SXin Li     } else if (CXXRecordDecl *Rec = dyn_cast<CXXRecordDecl>(Ctx)) {
168*67e74705SXin Li       if (ClassTemplateDecl *ClassTemplate = Rec->getDescribedClassTemplate()) {
169*67e74705SXin Li         QualType T = ClassTemplate->getInjectedClassNameSpecialization();
170*67e74705SXin Li         const TemplateSpecializationType *TST =
171*67e74705SXin Li             cast<TemplateSpecializationType>(Context.getCanonicalType(T));
172*67e74705SXin Li         Result.addOuterTemplateArguments(
173*67e74705SXin Li             llvm::makeArrayRef(TST->getArgs(), TST->getNumArgs()));
174*67e74705SXin Li         if (ClassTemplate->isMemberSpecialization())
175*67e74705SXin Li           break;
176*67e74705SXin Li       }
177*67e74705SXin Li     }
178*67e74705SXin Li 
179*67e74705SXin Li     Ctx = Ctx->getParent();
180*67e74705SXin Li     RelativeToPrimary = false;
181*67e74705SXin Li   }
182*67e74705SXin Li 
183*67e74705SXin Li   return Result;
184*67e74705SXin Li }
185*67e74705SXin Li 
isInstantiationRecord() const186*67e74705SXin Li bool Sema::ActiveTemplateInstantiation::isInstantiationRecord() const {
187*67e74705SXin Li   switch (Kind) {
188*67e74705SXin Li   case TemplateInstantiation:
189*67e74705SXin Li   case ExceptionSpecInstantiation:
190*67e74705SXin Li   case DefaultTemplateArgumentInstantiation:
191*67e74705SXin Li   case DefaultFunctionArgumentInstantiation:
192*67e74705SXin Li   case ExplicitTemplateArgumentSubstitution:
193*67e74705SXin Li   case DeducedTemplateArgumentSubstitution:
194*67e74705SXin Li   case PriorTemplateArgumentSubstitution:
195*67e74705SXin Li     return true;
196*67e74705SXin Li 
197*67e74705SXin Li   case DefaultTemplateArgumentChecking:
198*67e74705SXin Li     return false;
199*67e74705SXin Li   }
200*67e74705SXin Li 
201*67e74705SXin Li   llvm_unreachable("Invalid InstantiationKind!");
202*67e74705SXin Li }
203*67e74705SXin Li 
InstantiatingTemplate(Sema & SemaRef,ActiveTemplateInstantiation::InstantiationKind Kind,SourceLocation PointOfInstantiation,SourceRange InstantiationRange,Decl * Entity,NamedDecl * Template,ArrayRef<TemplateArgument> TemplateArgs,sema::TemplateDeductionInfo * DeductionInfo)204*67e74705SXin Li Sema::InstantiatingTemplate::InstantiatingTemplate(
205*67e74705SXin Li     Sema &SemaRef, ActiveTemplateInstantiation::InstantiationKind Kind,
206*67e74705SXin Li     SourceLocation PointOfInstantiation, SourceRange InstantiationRange,
207*67e74705SXin Li     Decl *Entity, NamedDecl *Template, ArrayRef<TemplateArgument> TemplateArgs,
208*67e74705SXin Li     sema::TemplateDeductionInfo *DeductionInfo)
209*67e74705SXin Li     : SemaRef(SemaRef), SavedInNonInstantiationSFINAEContext(
210*67e74705SXin Li                             SemaRef.InNonInstantiationSFINAEContext) {
211*67e74705SXin Li   // Don't allow further instantiation if a fatal error has occcured.  Any
212*67e74705SXin Li   // diagnostics we might have raised will not be visible.
213*67e74705SXin Li   if (SemaRef.Diags.hasFatalErrorOccurred()) {
214*67e74705SXin Li     Invalid = true;
215*67e74705SXin Li     return;
216*67e74705SXin Li   }
217*67e74705SXin Li   Invalid = CheckInstantiationDepth(PointOfInstantiation, InstantiationRange);
218*67e74705SXin Li   if (!Invalid) {
219*67e74705SXin Li     ActiveTemplateInstantiation Inst;
220*67e74705SXin Li     Inst.Kind = Kind;
221*67e74705SXin Li     Inst.PointOfInstantiation = PointOfInstantiation;
222*67e74705SXin Li     Inst.Entity = Entity;
223*67e74705SXin Li     Inst.Template = Template;
224*67e74705SXin Li     Inst.TemplateArgs = TemplateArgs.data();
225*67e74705SXin Li     Inst.NumTemplateArgs = TemplateArgs.size();
226*67e74705SXin Li     Inst.DeductionInfo = DeductionInfo;
227*67e74705SXin Li     Inst.InstantiationRange = InstantiationRange;
228*67e74705SXin Li     SemaRef.InNonInstantiationSFINAEContext = false;
229*67e74705SXin Li     SemaRef.ActiveTemplateInstantiations.push_back(Inst);
230*67e74705SXin Li     if (!Inst.isInstantiationRecord())
231*67e74705SXin Li       ++SemaRef.NonInstantiationEntries;
232*67e74705SXin Li   }
233*67e74705SXin Li }
234*67e74705SXin Li 
InstantiatingTemplate(Sema & SemaRef,SourceLocation PointOfInstantiation,Decl * Entity,SourceRange InstantiationRange)235*67e74705SXin Li Sema::InstantiatingTemplate::InstantiatingTemplate(
236*67e74705SXin Li     Sema &SemaRef, SourceLocation PointOfInstantiation, Decl *Entity,
237*67e74705SXin Li     SourceRange InstantiationRange)
238*67e74705SXin Li     : InstantiatingTemplate(SemaRef,
239*67e74705SXin Li                             ActiveTemplateInstantiation::TemplateInstantiation,
240*67e74705SXin Li                             PointOfInstantiation, InstantiationRange, Entity) {}
241*67e74705SXin Li 
InstantiatingTemplate(Sema & SemaRef,SourceLocation PointOfInstantiation,FunctionDecl * Entity,ExceptionSpecification,SourceRange InstantiationRange)242*67e74705SXin Li Sema::InstantiatingTemplate::InstantiatingTemplate(
243*67e74705SXin Li     Sema &SemaRef, SourceLocation PointOfInstantiation, FunctionDecl *Entity,
244*67e74705SXin Li     ExceptionSpecification, SourceRange InstantiationRange)
245*67e74705SXin Li     : InstantiatingTemplate(
246*67e74705SXin Li           SemaRef, ActiveTemplateInstantiation::ExceptionSpecInstantiation,
247*67e74705SXin Li           PointOfInstantiation, InstantiationRange, Entity) {}
248*67e74705SXin Li 
InstantiatingTemplate(Sema & SemaRef,SourceLocation PointOfInstantiation,TemplateDecl * Template,ArrayRef<TemplateArgument> TemplateArgs,SourceRange InstantiationRange)249*67e74705SXin Li Sema::InstantiatingTemplate::InstantiatingTemplate(
250*67e74705SXin Li     Sema &SemaRef, SourceLocation PointOfInstantiation, TemplateDecl *Template,
251*67e74705SXin Li     ArrayRef<TemplateArgument> TemplateArgs, SourceRange InstantiationRange)
252*67e74705SXin Li     : InstantiatingTemplate(
253*67e74705SXin Li           SemaRef,
254*67e74705SXin Li           ActiveTemplateInstantiation::DefaultTemplateArgumentInstantiation,
255*67e74705SXin Li           PointOfInstantiation, InstantiationRange, Template, nullptr,
256*67e74705SXin Li           TemplateArgs) {}
257*67e74705SXin Li 
InstantiatingTemplate(Sema & SemaRef,SourceLocation PointOfInstantiation,FunctionTemplateDecl * FunctionTemplate,ArrayRef<TemplateArgument> TemplateArgs,ActiveTemplateInstantiation::InstantiationKind Kind,sema::TemplateDeductionInfo & DeductionInfo,SourceRange InstantiationRange)258*67e74705SXin Li Sema::InstantiatingTemplate::InstantiatingTemplate(
259*67e74705SXin Li     Sema &SemaRef, SourceLocation PointOfInstantiation,
260*67e74705SXin Li     FunctionTemplateDecl *FunctionTemplate,
261*67e74705SXin Li     ArrayRef<TemplateArgument> TemplateArgs,
262*67e74705SXin Li     ActiveTemplateInstantiation::InstantiationKind Kind,
263*67e74705SXin Li     sema::TemplateDeductionInfo &DeductionInfo, SourceRange InstantiationRange)
264*67e74705SXin Li     : InstantiatingTemplate(SemaRef, Kind, PointOfInstantiation,
265*67e74705SXin Li                             InstantiationRange, FunctionTemplate, nullptr,
266*67e74705SXin Li                             TemplateArgs, &DeductionInfo) {}
267*67e74705SXin Li 
InstantiatingTemplate(Sema & SemaRef,SourceLocation PointOfInstantiation,ClassTemplatePartialSpecializationDecl * PartialSpec,ArrayRef<TemplateArgument> TemplateArgs,sema::TemplateDeductionInfo & DeductionInfo,SourceRange InstantiationRange)268*67e74705SXin Li Sema::InstantiatingTemplate::InstantiatingTemplate(
269*67e74705SXin Li     Sema &SemaRef, SourceLocation PointOfInstantiation,
270*67e74705SXin Li     ClassTemplatePartialSpecializationDecl *PartialSpec,
271*67e74705SXin Li     ArrayRef<TemplateArgument> TemplateArgs,
272*67e74705SXin Li     sema::TemplateDeductionInfo &DeductionInfo, SourceRange InstantiationRange)
273*67e74705SXin Li     : InstantiatingTemplate(
274*67e74705SXin Li           SemaRef,
275*67e74705SXin Li           ActiveTemplateInstantiation::DeducedTemplateArgumentSubstitution,
276*67e74705SXin Li           PointOfInstantiation, InstantiationRange, PartialSpec, nullptr,
277*67e74705SXin Li           TemplateArgs, &DeductionInfo) {}
278*67e74705SXin Li 
InstantiatingTemplate(Sema & SemaRef,SourceLocation PointOfInstantiation,VarTemplatePartialSpecializationDecl * PartialSpec,ArrayRef<TemplateArgument> TemplateArgs,sema::TemplateDeductionInfo & DeductionInfo,SourceRange InstantiationRange)279*67e74705SXin Li Sema::InstantiatingTemplate::InstantiatingTemplate(
280*67e74705SXin Li     Sema &SemaRef, SourceLocation PointOfInstantiation,
281*67e74705SXin Li     VarTemplatePartialSpecializationDecl *PartialSpec,
282*67e74705SXin Li     ArrayRef<TemplateArgument> TemplateArgs,
283*67e74705SXin Li     sema::TemplateDeductionInfo &DeductionInfo, SourceRange InstantiationRange)
284*67e74705SXin Li     : InstantiatingTemplate(
285*67e74705SXin Li           SemaRef,
286*67e74705SXin Li           ActiveTemplateInstantiation::DeducedTemplateArgumentSubstitution,
287*67e74705SXin Li           PointOfInstantiation, InstantiationRange, PartialSpec, nullptr,
288*67e74705SXin Li           TemplateArgs, &DeductionInfo) {}
289*67e74705SXin Li 
InstantiatingTemplate(Sema & SemaRef,SourceLocation PointOfInstantiation,ParmVarDecl * Param,ArrayRef<TemplateArgument> TemplateArgs,SourceRange InstantiationRange)290*67e74705SXin Li Sema::InstantiatingTemplate::InstantiatingTemplate(
291*67e74705SXin Li     Sema &SemaRef, SourceLocation PointOfInstantiation, ParmVarDecl *Param,
292*67e74705SXin Li     ArrayRef<TemplateArgument> TemplateArgs, SourceRange InstantiationRange)
293*67e74705SXin Li     : InstantiatingTemplate(
294*67e74705SXin Li           SemaRef,
295*67e74705SXin Li           ActiveTemplateInstantiation::DefaultFunctionArgumentInstantiation,
296*67e74705SXin Li           PointOfInstantiation, InstantiationRange, Param, nullptr,
297*67e74705SXin Li           TemplateArgs) {}
298*67e74705SXin Li 
InstantiatingTemplate(Sema & SemaRef,SourceLocation PointOfInstantiation,NamedDecl * Template,NonTypeTemplateParmDecl * Param,ArrayRef<TemplateArgument> TemplateArgs,SourceRange InstantiationRange)299*67e74705SXin Li Sema::InstantiatingTemplate::InstantiatingTemplate(
300*67e74705SXin Li     Sema &SemaRef, SourceLocation PointOfInstantiation, NamedDecl *Template,
301*67e74705SXin Li     NonTypeTemplateParmDecl *Param, ArrayRef<TemplateArgument> TemplateArgs,
302*67e74705SXin Li     SourceRange InstantiationRange)
303*67e74705SXin Li     : InstantiatingTemplate(
304*67e74705SXin Li           SemaRef,
305*67e74705SXin Li           ActiveTemplateInstantiation::PriorTemplateArgumentSubstitution,
306*67e74705SXin Li           PointOfInstantiation, InstantiationRange, Param, Template,
307*67e74705SXin Li           TemplateArgs) {}
308*67e74705SXin Li 
InstantiatingTemplate(Sema & SemaRef,SourceLocation PointOfInstantiation,NamedDecl * Template,TemplateTemplateParmDecl * Param,ArrayRef<TemplateArgument> TemplateArgs,SourceRange InstantiationRange)309*67e74705SXin Li Sema::InstantiatingTemplate::InstantiatingTemplate(
310*67e74705SXin Li     Sema &SemaRef, SourceLocation PointOfInstantiation, NamedDecl *Template,
311*67e74705SXin Li     TemplateTemplateParmDecl *Param, ArrayRef<TemplateArgument> TemplateArgs,
312*67e74705SXin Li     SourceRange InstantiationRange)
313*67e74705SXin Li     : InstantiatingTemplate(
314*67e74705SXin Li           SemaRef,
315*67e74705SXin Li           ActiveTemplateInstantiation::PriorTemplateArgumentSubstitution,
316*67e74705SXin Li           PointOfInstantiation, InstantiationRange, Param, Template,
317*67e74705SXin Li           TemplateArgs) {}
318*67e74705SXin Li 
InstantiatingTemplate(Sema & SemaRef,SourceLocation PointOfInstantiation,TemplateDecl * Template,NamedDecl * Param,ArrayRef<TemplateArgument> TemplateArgs,SourceRange InstantiationRange)319*67e74705SXin Li Sema::InstantiatingTemplate::InstantiatingTemplate(
320*67e74705SXin Li     Sema &SemaRef, SourceLocation PointOfInstantiation, TemplateDecl *Template,
321*67e74705SXin Li     NamedDecl *Param, ArrayRef<TemplateArgument> TemplateArgs,
322*67e74705SXin Li     SourceRange InstantiationRange)
323*67e74705SXin Li     : InstantiatingTemplate(
324*67e74705SXin Li           SemaRef, ActiveTemplateInstantiation::DefaultTemplateArgumentChecking,
325*67e74705SXin Li           PointOfInstantiation, InstantiationRange, Param, Template,
326*67e74705SXin Li           TemplateArgs) {}
327*67e74705SXin Li 
Clear()328*67e74705SXin Li void Sema::InstantiatingTemplate::Clear() {
329*67e74705SXin Li   if (!Invalid) {
330*67e74705SXin Li     if (!SemaRef.ActiveTemplateInstantiations.back().isInstantiationRecord()) {
331*67e74705SXin Li       assert(SemaRef.NonInstantiationEntries > 0);
332*67e74705SXin Li       --SemaRef.NonInstantiationEntries;
333*67e74705SXin Li     }
334*67e74705SXin Li     SemaRef.InNonInstantiationSFINAEContext
335*67e74705SXin Li       = SavedInNonInstantiationSFINAEContext;
336*67e74705SXin Li 
337*67e74705SXin Li     // Name lookup no longer looks in this template's defining module.
338*67e74705SXin Li     assert(SemaRef.ActiveTemplateInstantiations.size() >=
339*67e74705SXin Li            SemaRef.ActiveTemplateInstantiationLookupModules.size() &&
340*67e74705SXin Li            "forgot to remove a lookup module for a template instantiation");
341*67e74705SXin Li     if (SemaRef.ActiveTemplateInstantiations.size() ==
342*67e74705SXin Li         SemaRef.ActiveTemplateInstantiationLookupModules.size()) {
343*67e74705SXin Li       if (Module *M = SemaRef.ActiveTemplateInstantiationLookupModules.back())
344*67e74705SXin Li         SemaRef.LookupModulesCache.erase(M);
345*67e74705SXin Li       SemaRef.ActiveTemplateInstantiationLookupModules.pop_back();
346*67e74705SXin Li     }
347*67e74705SXin Li 
348*67e74705SXin Li     SemaRef.ActiveTemplateInstantiations.pop_back();
349*67e74705SXin Li     Invalid = true;
350*67e74705SXin Li   }
351*67e74705SXin Li }
352*67e74705SXin Li 
CheckInstantiationDepth(SourceLocation PointOfInstantiation,SourceRange InstantiationRange)353*67e74705SXin Li bool Sema::InstantiatingTemplate::CheckInstantiationDepth(
354*67e74705SXin Li                                         SourceLocation PointOfInstantiation,
355*67e74705SXin Li                                            SourceRange InstantiationRange) {
356*67e74705SXin Li   assert(SemaRef.NonInstantiationEntries <=
357*67e74705SXin Li                                    SemaRef.ActiveTemplateInstantiations.size());
358*67e74705SXin Li   if ((SemaRef.ActiveTemplateInstantiations.size() -
359*67e74705SXin Li           SemaRef.NonInstantiationEntries)
360*67e74705SXin Li         <= SemaRef.getLangOpts().InstantiationDepth)
361*67e74705SXin Li     return false;
362*67e74705SXin Li 
363*67e74705SXin Li   SemaRef.Diag(PointOfInstantiation,
364*67e74705SXin Li                diag::err_template_recursion_depth_exceeded)
365*67e74705SXin Li     << SemaRef.getLangOpts().InstantiationDepth
366*67e74705SXin Li     << InstantiationRange;
367*67e74705SXin Li   SemaRef.Diag(PointOfInstantiation, diag::note_template_recursion_depth)
368*67e74705SXin Li     << SemaRef.getLangOpts().InstantiationDepth;
369*67e74705SXin Li   return true;
370*67e74705SXin Li }
371*67e74705SXin Li 
372*67e74705SXin Li /// \brief Prints the current instantiation stack through a series of
373*67e74705SXin Li /// notes.
PrintInstantiationStack()374*67e74705SXin Li void Sema::PrintInstantiationStack() {
375*67e74705SXin Li   // Determine which template instantiations to skip, if any.
376*67e74705SXin Li   unsigned SkipStart = ActiveTemplateInstantiations.size(), SkipEnd = SkipStart;
377*67e74705SXin Li   unsigned Limit = Diags.getTemplateBacktraceLimit();
378*67e74705SXin Li   if (Limit && Limit < ActiveTemplateInstantiations.size()) {
379*67e74705SXin Li     SkipStart = Limit / 2 + Limit % 2;
380*67e74705SXin Li     SkipEnd = ActiveTemplateInstantiations.size() - Limit / 2;
381*67e74705SXin Li   }
382*67e74705SXin Li 
383*67e74705SXin Li   // FIXME: In all of these cases, we need to show the template arguments
384*67e74705SXin Li   unsigned InstantiationIdx = 0;
385*67e74705SXin Li   for (SmallVectorImpl<ActiveTemplateInstantiation>::reverse_iterator
386*67e74705SXin Li          Active = ActiveTemplateInstantiations.rbegin(),
387*67e74705SXin Li          ActiveEnd = ActiveTemplateInstantiations.rend();
388*67e74705SXin Li        Active != ActiveEnd;
389*67e74705SXin Li        ++Active, ++InstantiationIdx) {
390*67e74705SXin Li     // Skip this instantiation?
391*67e74705SXin Li     if (InstantiationIdx >= SkipStart && InstantiationIdx < SkipEnd) {
392*67e74705SXin Li       if (InstantiationIdx == SkipStart) {
393*67e74705SXin Li         // Note that we're skipping instantiations.
394*67e74705SXin Li         Diags.Report(Active->PointOfInstantiation,
395*67e74705SXin Li                      diag::note_instantiation_contexts_suppressed)
396*67e74705SXin Li           << unsigned(ActiveTemplateInstantiations.size() - Limit);
397*67e74705SXin Li       }
398*67e74705SXin Li       continue;
399*67e74705SXin Li     }
400*67e74705SXin Li 
401*67e74705SXin Li     switch (Active->Kind) {
402*67e74705SXin Li     case ActiveTemplateInstantiation::TemplateInstantiation: {
403*67e74705SXin Li       Decl *D = Active->Entity;
404*67e74705SXin Li       if (CXXRecordDecl *Record = dyn_cast<CXXRecordDecl>(D)) {
405*67e74705SXin Li         unsigned DiagID = diag::note_template_member_class_here;
406*67e74705SXin Li         if (isa<ClassTemplateSpecializationDecl>(Record))
407*67e74705SXin Li           DiagID = diag::note_template_class_instantiation_here;
408*67e74705SXin Li         Diags.Report(Active->PointOfInstantiation, DiagID)
409*67e74705SXin Li           << Context.getTypeDeclType(Record)
410*67e74705SXin Li           << Active->InstantiationRange;
411*67e74705SXin Li       } else if (FunctionDecl *Function = dyn_cast<FunctionDecl>(D)) {
412*67e74705SXin Li         unsigned DiagID;
413*67e74705SXin Li         if (Function->getPrimaryTemplate())
414*67e74705SXin Li           DiagID = diag::note_function_template_spec_here;
415*67e74705SXin Li         else
416*67e74705SXin Li           DiagID = diag::note_template_member_function_here;
417*67e74705SXin Li         Diags.Report(Active->PointOfInstantiation, DiagID)
418*67e74705SXin Li           << Function
419*67e74705SXin Li           << Active->InstantiationRange;
420*67e74705SXin Li       } else if (VarDecl *VD = dyn_cast<VarDecl>(D)) {
421*67e74705SXin Li         Diags.Report(Active->PointOfInstantiation,
422*67e74705SXin Li                      VD->isStaticDataMember()?
423*67e74705SXin Li                        diag::note_template_static_data_member_def_here
424*67e74705SXin Li                      : diag::note_template_variable_def_here)
425*67e74705SXin Li           << VD
426*67e74705SXin Li           << Active->InstantiationRange;
427*67e74705SXin Li       } else if (EnumDecl *ED = dyn_cast<EnumDecl>(D)) {
428*67e74705SXin Li         Diags.Report(Active->PointOfInstantiation,
429*67e74705SXin Li                      diag::note_template_enum_def_here)
430*67e74705SXin Li           << ED
431*67e74705SXin Li           << Active->InstantiationRange;
432*67e74705SXin Li       } else if (FieldDecl *FD = dyn_cast<FieldDecl>(D)) {
433*67e74705SXin Li         Diags.Report(Active->PointOfInstantiation,
434*67e74705SXin Li                      diag::note_template_nsdmi_here)
435*67e74705SXin Li             << FD << Active->InstantiationRange;
436*67e74705SXin Li       } else {
437*67e74705SXin Li         Diags.Report(Active->PointOfInstantiation,
438*67e74705SXin Li                      diag::note_template_type_alias_instantiation_here)
439*67e74705SXin Li           << cast<TypeAliasTemplateDecl>(D)
440*67e74705SXin Li           << Active->InstantiationRange;
441*67e74705SXin Li       }
442*67e74705SXin Li       break;
443*67e74705SXin Li     }
444*67e74705SXin Li 
445*67e74705SXin Li     case ActiveTemplateInstantiation::DefaultTemplateArgumentInstantiation: {
446*67e74705SXin Li       TemplateDecl *Template = cast<TemplateDecl>(Active->Entity);
447*67e74705SXin Li       SmallVector<char, 128> TemplateArgsStr;
448*67e74705SXin Li       llvm::raw_svector_ostream OS(TemplateArgsStr);
449*67e74705SXin Li       Template->printName(OS);
450*67e74705SXin Li       TemplateSpecializationType::PrintTemplateArgumentList(
451*67e74705SXin Li           OS, Active->template_arguments(), getPrintingPolicy());
452*67e74705SXin Li       Diags.Report(Active->PointOfInstantiation,
453*67e74705SXin Li                    diag::note_default_arg_instantiation_here)
454*67e74705SXin Li         << OS.str()
455*67e74705SXin Li         << Active->InstantiationRange;
456*67e74705SXin Li       break;
457*67e74705SXin Li     }
458*67e74705SXin Li 
459*67e74705SXin Li     case ActiveTemplateInstantiation::ExplicitTemplateArgumentSubstitution: {
460*67e74705SXin Li       FunctionTemplateDecl *FnTmpl = cast<FunctionTemplateDecl>(Active->Entity);
461*67e74705SXin Li       Diags.Report(Active->PointOfInstantiation,
462*67e74705SXin Li                    diag::note_explicit_template_arg_substitution_here)
463*67e74705SXin Li         << FnTmpl
464*67e74705SXin Li         << getTemplateArgumentBindingsText(FnTmpl->getTemplateParameters(),
465*67e74705SXin Li                                            Active->TemplateArgs,
466*67e74705SXin Li                                            Active->NumTemplateArgs)
467*67e74705SXin Li         << Active->InstantiationRange;
468*67e74705SXin Li       break;
469*67e74705SXin Li     }
470*67e74705SXin Li 
471*67e74705SXin Li     case ActiveTemplateInstantiation::DeducedTemplateArgumentSubstitution:
472*67e74705SXin Li       if (ClassTemplatePartialSpecializationDecl *PartialSpec =
473*67e74705SXin Li             dyn_cast<ClassTemplatePartialSpecializationDecl>(Active->Entity)) {
474*67e74705SXin Li         Diags.Report(Active->PointOfInstantiation,
475*67e74705SXin Li                      diag::note_partial_spec_deduct_instantiation_here)
476*67e74705SXin Li           << Context.getTypeDeclType(PartialSpec)
477*67e74705SXin Li           << getTemplateArgumentBindingsText(
478*67e74705SXin Li                                          PartialSpec->getTemplateParameters(),
479*67e74705SXin Li                                              Active->TemplateArgs,
480*67e74705SXin Li                                              Active->NumTemplateArgs)
481*67e74705SXin Li           << Active->InstantiationRange;
482*67e74705SXin Li       } else {
483*67e74705SXin Li         FunctionTemplateDecl *FnTmpl
484*67e74705SXin Li           = cast<FunctionTemplateDecl>(Active->Entity);
485*67e74705SXin Li         Diags.Report(Active->PointOfInstantiation,
486*67e74705SXin Li                      diag::note_function_template_deduction_instantiation_here)
487*67e74705SXin Li           << FnTmpl
488*67e74705SXin Li           << getTemplateArgumentBindingsText(FnTmpl->getTemplateParameters(),
489*67e74705SXin Li                                              Active->TemplateArgs,
490*67e74705SXin Li                                              Active->NumTemplateArgs)
491*67e74705SXin Li           << Active->InstantiationRange;
492*67e74705SXin Li       }
493*67e74705SXin Li       break;
494*67e74705SXin Li 
495*67e74705SXin Li     case ActiveTemplateInstantiation::DefaultFunctionArgumentInstantiation: {
496*67e74705SXin Li       ParmVarDecl *Param = cast<ParmVarDecl>(Active->Entity);
497*67e74705SXin Li       FunctionDecl *FD = cast<FunctionDecl>(Param->getDeclContext());
498*67e74705SXin Li 
499*67e74705SXin Li       SmallVector<char, 128> TemplateArgsStr;
500*67e74705SXin Li       llvm::raw_svector_ostream OS(TemplateArgsStr);
501*67e74705SXin Li       FD->printName(OS);
502*67e74705SXin Li       TemplateSpecializationType::PrintTemplateArgumentList(
503*67e74705SXin Li           OS, Active->template_arguments(), getPrintingPolicy());
504*67e74705SXin Li       Diags.Report(Active->PointOfInstantiation,
505*67e74705SXin Li                    diag::note_default_function_arg_instantiation_here)
506*67e74705SXin Li         << OS.str()
507*67e74705SXin Li         << Active->InstantiationRange;
508*67e74705SXin Li       break;
509*67e74705SXin Li     }
510*67e74705SXin Li 
511*67e74705SXin Li     case ActiveTemplateInstantiation::PriorTemplateArgumentSubstitution: {
512*67e74705SXin Li       NamedDecl *Parm = cast<NamedDecl>(Active->Entity);
513*67e74705SXin Li       std::string Name;
514*67e74705SXin Li       if (!Parm->getName().empty())
515*67e74705SXin Li         Name = std::string(" '") + Parm->getName().str() + "'";
516*67e74705SXin Li 
517*67e74705SXin Li       TemplateParameterList *TemplateParams = nullptr;
518*67e74705SXin Li       if (TemplateDecl *Template = dyn_cast<TemplateDecl>(Active->Template))
519*67e74705SXin Li         TemplateParams = Template->getTemplateParameters();
520*67e74705SXin Li       else
521*67e74705SXin Li         TemplateParams =
522*67e74705SXin Li           cast<ClassTemplatePartialSpecializationDecl>(Active->Template)
523*67e74705SXin Li                                                       ->getTemplateParameters();
524*67e74705SXin Li       Diags.Report(Active->PointOfInstantiation,
525*67e74705SXin Li                    diag::note_prior_template_arg_substitution)
526*67e74705SXin Li         << isa<TemplateTemplateParmDecl>(Parm)
527*67e74705SXin Li         << Name
528*67e74705SXin Li         << getTemplateArgumentBindingsText(TemplateParams,
529*67e74705SXin Li                                            Active->TemplateArgs,
530*67e74705SXin Li                                            Active->NumTemplateArgs)
531*67e74705SXin Li         << Active->InstantiationRange;
532*67e74705SXin Li       break;
533*67e74705SXin Li     }
534*67e74705SXin Li 
535*67e74705SXin Li     case ActiveTemplateInstantiation::DefaultTemplateArgumentChecking: {
536*67e74705SXin Li       TemplateParameterList *TemplateParams = nullptr;
537*67e74705SXin Li       if (TemplateDecl *Template = dyn_cast<TemplateDecl>(Active->Template))
538*67e74705SXin Li         TemplateParams = Template->getTemplateParameters();
539*67e74705SXin Li       else
540*67e74705SXin Li         TemplateParams =
541*67e74705SXin Li           cast<ClassTemplatePartialSpecializationDecl>(Active->Template)
542*67e74705SXin Li                                                       ->getTemplateParameters();
543*67e74705SXin Li 
544*67e74705SXin Li       Diags.Report(Active->PointOfInstantiation,
545*67e74705SXin Li                    diag::note_template_default_arg_checking)
546*67e74705SXin Li         << getTemplateArgumentBindingsText(TemplateParams,
547*67e74705SXin Li                                            Active->TemplateArgs,
548*67e74705SXin Li                                            Active->NumTemplateArgs)
549*67e74705SXin Li         << Active->InstantiationRange;
550*67e74705SXin Li       break;
551*67e74705SXin Li     }
552*67e74705SXin Li 
553*67e74705SXin Li     case ActiveTemplateInstantiation::ExceptionSpecInstantiation:
554*67e74705SXin Li       Diags.Report(Active->PointOfInstantiation,
555*67e74705SXin Li                    diag::note_template_exception_spec_instantiation_here)
556*67e74705SXin Li         << cast<FunctionDecl>(Active->Entity)
557*67e74705SXin Li         << Active->InstantiationRange;
558*67e74705SXin Li       break;
559*67e74705SXin Li     }
560*67e74705SXin Li   }
561*67e74705SXin Li }
562*67e74705SXin Li 
isSFINAEContext() const563*67e74705SXin Li Optional<TemplateDeductionInfo *> Sema::isSFINAEContext() const {
564*67e74705SXin Li   if (InNonInstantiationSFINAEContext)
565*67e74705SXin Li     return Optional<TemplateDeductionInfo *>(nullptr);
566*67e74705SXin Li 
567*67e74705SXin Li   for (SmallVectorImpl<ActiveTemplateInstantiation>::const_reverse_iterator
568*67e74705SXin Li          Active = ActiveTemplateInstantiations.rbegin(),
569*67e74705SXin Li          ActiveEnd = ActiveTemplateInstantiations.rend();
570*67e74705SXin Li        Active != ActiveEnd;
571*67e74705SXin Li        ++Active)
572*67e74705SXin Li   {
573*67e74705SXin Li     switch(Active->Kind) {
574*67e74705SXin Li     case ActiveTemplateInstantiation::TemplateInstantiation:
575*67e74705SXin Li       // An instantiation of an alias template may or may not be a SFINAE
576*67e74705SXin Li       // context, depending on what else is on the stack.
577*67e74705SXin Li       if (isa<TypeAliasTemplateDecl>(Active->Entity))
578*67e74705SXin Li         break;
579*67e74705SXin Li       // Fall through.
580*67e74705SXin Li     case ActiveTemplateInstantiation::DefaultFunctionArgumentInstantiation:
581*67e74705SXin Li     case ActiveTemplateInstantiation::ExceptionSpecInstantiation:
582*67e74705SXin Li       // This is a template instantiation, so there is no SFINAE.
583*67e74705SXin Li       return None;
584*67e74705SXin Li 
585*67e74705SXin Li     case ActiveTemplateInstantiation::DefaultTemplateArgumentInstantiation:
586*67e74705SXin Li     case ActiveTemplateInstantiation::PriorTemplateArgumentSubstitution:
587*67e74705SXin Li     case ActiveTemplateInstantiation::DefaultTemplateArgumentChecking:
588*67e74705SXin Li       // A default template argument instantiation and substitution into
589*67e74705SXin Li       // template parameters with arguments for prior parameters may or may
590*67e74705SXin Li       // not be a SFINAE context; look further up the stack.
591*67e74705SXin Li       break;
592*67e74705SXin Li 
593*67e74705SXin Li     case ActiveTemplateInstantiation::ExplicitTemplateArgumentSubstitution:
594*67e74705SXin Li     case ActiveTemplateInstantiation::DeducedTemplateArgumentSubstitution:
595*67e74705SXin Li       // We're either substitution explicitly-specified template arguments
596*67e74705SXin Li       // or deduced template arguments, so SFINAE applies.
597*67e74705SXin Li       assert(Active->DeductionInfo && "Missing deduction info pointer");
598*67e74705SXin Li       return Active->DeductionInfo;
599*67e74705SXin Li     }
600*67e74705SXin Li   }
601*67e74705SXin Li 
602*67e74705SXin Li   return None;
603*67e74705SXin Li }
604*67e74705SXin Li 
605*67e74705SXin Li /// \brief Retrieve the depth and index of a parameter pack.
606*67e74705SXin Li static std::pair<unsigned, unsigned>
getDepthAndIndex(NamedDecl * ND)607*67e74705SXin Li getDepthAndIndex(NamedDecl *ND) {
608*67e74705SXin Li   if (TemplateTypeParmDecl *TTP = dyn_cast<TemplateTypeParmDecl>(ND))
609*67e74705SXin Li     return std::make_pair(TTP->getDepth(), TTP->getIndex());
610*67e74705SXin Li 
611*67e74705SXin Li   if (NonTypeTemplateParmDecl *NTTP = dyn_cast<NonTypeTemplateParmDecl>(ND))
612*67e74705SXin Li     return std::make_pair(NTTP->getDepth(), NTTP->getIndex());
613*67e74705SXin Li 
614*67e74705SXin Li   TemplateTemplateParmDecl *TTP = cast<TemplateTemplateParmDecl>(ND);
615*67e74705SXin Li   return std::make_pair(TTP->getDepth(), TTP->getIndex());
616*67e74705SXin Li }
617*67e74705SXin Li 
618*67e74705SXin Li //===----------------------------------------------------------------------===/
619*67e74705SXin Li // Template Instantiation for Types
620*67e74705SXin Li //===----------------------------------------------------------------------===/
621*67e74705SXin Li namespace {
622*67e74705SXin Li   class TemplateInstantiator : public TreeTransform<TemplateInstantiator> {
623*67e74705SXin Li     const MultiLevelTemplateArgumentList &TemplateArgs;
624*67e74705SXin Li     SourceLocation Loc;
625*67e74705SXin Li     DeclarationName Entity;
626*67e74705SXin Li 
627*67e74705SXin Li   public:
628*67e74705SXin Li     typedef TreeTransform<TemplateInstantiator> inherited;
629*67e74705SXin Li 
TemplateInstantiator(Sema & SemaRef,const MultiLevelTemplateArgumentList & TemplateArgs,SourceLocation Loc,DeclarationName Entity)630*67e74705SXin Li     TemplateInstantiator(Sema &SemaRef,
631*67e74705SXin Li                          const MultiLevelTemplateArgumentList &TemplateArgs,
632*67e74705SXin Li                          SourceLocation Loc,
633*67e74705SXin Li                          DeclarationName Entity)
634*67e74705SXin Li       : inherited(SemaRef), TemplateArgs(TemplateArgs), Loc(Loc),
635*67e74705SXin Li         Entity(Entity) { }
636*67e74705SXin Li 
637*67e74705SXin Li     /// \brief Determine whether the given type \p T has already been
638*67e74705SXin Li     /// transformed.
639*67e74705SXin Li     ///
640*67e74705SXin Li     /// For the purposes of template instantiation, a type has already been
641*67e74705SXin Li     /// transformed if it is NULL or if it is not dependent.
642*67e74705SXin Li     bool AlreadyTransformed(QualType T);
643*67e74705SXin Li 
644*67e74705SXin Li     /// \brief Returns the location of the entity being instantiated, if known.
getBaseLocation()645*67e74705SXin Li     SourceLocation getBaseLocation() { return Loc; }
646*67e74705SXin Li 
647*67e74705SXin Li     /// \brief Returns the name of the entity being instantiated, if any.
getBaseEntity()648*67e74705SXin Li     DeclarationName getBaseEntity() { return Entity; }
649*67e74705SXin Li 
650*67e74705SXin Li     /// \brief Sets the "base" location and entity when that
651*67e74705SXin Li     /// information is known based on another transformation.
setBase(SourceLocation Loc,DeclarationName Entity)652*67e74705SXin Li     void setBase(SourceLocation Loc, DeclarationName Entity) {
653*67e74705SXin Li       this->Loc = Loc;
654*67e74705SXin Li       this->Entity = Entity;
655*67e74705SXin Li     }
656*67e74705SXin Li 
TryExpandParameterPacks(SourceLocation EllipsisLoc,SourceRange PatternRange,ArrayRef<UnexpandedParameterPack> Unexpanded,bool & ShouldExpand,bool & RetainExpansion,Optional<unsigned> & NumExpansions)657*67e74705SXin Li     bool TryExpandParameterPacks(SourceLocation EllipsisLoc,
658*67e74705SXin Li                                  SourceRange PatternRange,
659*67e74705SXin Li                                  ArrayRef<UnexpandedParameterPack> Unexpanded,
660*67e74705SXin Li                                  bool &ShouldExpand, bool &RetainExpansion,
661*67e74705SXin Li                                  Optional<unsigned> &NumExpansions) {
662*67e74705SXin Li       return getSema().CheckParameterPacksForExpansion(EllipsisLoc,
663*67e74705SXin Li                                                        PatternRange, Unexpanded,
664*67e74705SXin Li                                                        TemplateArgs,
665*67e74705SXin Li                                                        ShouldExpand,
666*67e74705SXin Li                                                        RetainExpansion,
667*67e74705SXin Li                                                        NumExpansions);
668*67e74705SXin Li     }
669*67e74705SXin Li 
ExpandingFunctionParameterPack(ParmVarDecl * Pack)670*67e74705SXin Li     void ExpandingFunctionParameterPack(ParmVarDecl *Pack) {
671*67e74705SXin Li       SemaRef.CurrentInstantiationScope->MakeInstantiatedLocalArgPack(Pack);
672*67e74705SXin Li     }
673*67e74705SXin Li 
ForgetPartiallySubstitutedPack()674*67e74705SXin Li     TemplateArgument ForgetPartiallySubstitutedPack() {
675*67e74705SXin Li       TemplateArgument Result;
676*67e74705SXin Li       if (NamedDecl *PartialPack
677*67e74705SXin Li             = SemaRef.CurrentInstantiationScope->getPartiallySubstitutedPack()){
678*67e74705SXin Li         MultiLevelTemplateArgumentList &TemplateArgs
679*67e74705SXin Li           = const_cast<MultiLevelTemplateArgumentList &>(this->TemplateArgs);
680*67e74705SXin Li         unsigned Depth, Index;
681*67e74705SXin Li         std::tie(Depth, Index) = getDepthAndIndex(PartialPack);
682*67e74705SXin Li         if (TemplateArgs.hasTemplateArgument(Depth, Index)) {
683*67e74705SXin Li           Result = TemplateArgs(Depth, Index);
684*67e74705SXin Li           TemplateArgs.setArgument(Depth, Index, TemplateArgument());
685*67e74705SXin Li         }
686*67e74705SXin Li       }
687*67e74705SXin Li 
688*67e74705SXin Li       return Result;
689*67e74705SXin Li     }
690*67e74705SXin Li 
RememberPartiallySubstitutedPack(TemplateArgument Arg)691*67e74705SXin Li     void RememberPartiallySubstitutedPack(TemplateArgument Arg) {
692*67e74705SXin Li       if (Arg.isNull())
693*67e74705SXin Li         return;
694*67e74705SXin Li 
695*67e74705SXin Li       if (NamedDecl *PartialPack
696*67e74705SXin Li             = SemaRef.CurrentInstantiationScope->getPartiallySubstitutedPack()){
697*67e74705SXin Li         MultiLevelTemplateArgumentList &TemplateArgs
698*67e74705SXin Li         = const_cast<MultiLevelTemplateArgumentList &>(this->TemplateArgs);
699*67e74705SXin Li         unsigned Depth, Index;
700*67e74705SXin Li         std::tie(Depth, Index) = getDepthAndIndex(PartialPack);
701*67e74705SXin Li         TemplateArgs.setArgument(Depth, Index, Arg);
702*67e74705SXin Li       }
703*67e74705SXin Li     }
704*67e74705SXin Li 
705*67e74705SXin Li     /// \brief Transform the given declaration by instantiating a reference to
706*67e74705SXin Li     /// this declaration.
707*67e74705SXin Li     Decl *TransformDecl(SourceLocation Loc, Decl *D);
708*67e74705SXin Li 
transformAttrs(Decl * Old,Decl * New)709*67e74705SXin Li     void transformAttrs(Decl *Old, Decl *New) {
710*67e74705SXin Li       SemaRef.InstantiateAttrs(TemplateArgs, Old, New);
711*67e74705SXin Li     }
712*67e74705SXin Li 
transformedLocalDecl(Decl * Old,Decl * New)713*67e74705SXin Li     void transformedLocalDecl(Decl *Old, Decl *New) {
714*67e74705SXin Li       // If we've instantiated the call operator of a lambda or the call
715*67e74705SXin Li       // operator template of a generic lambda, update the "instantiation of"
716*67e74705SXin Li       // information.
717*67e74705SXin Li       auto *NewMD = dyn_cast<CXXMethodDecl>(New);
718*67e74705SXin Li       if (NewMD && isLambdaCallOperator(NewMD)) {
719*67e74705SXin Li         auto *OldMD = dyn_cast<CXXMethodDecl>(Old);
720*67e74705SXin Li         if (auto *NewTD = NewMD->getDescribedFunctionTemplate())
721*67e74705SXin Li           NewTD->setInstantiatedFromMemberTemplate(
722*67e74705SXin Li               OldMD->getDescribedFunctionTemplate());
723*67e74705SXin Li         else
724*67e74705SXin Li           NewMD->setInstantiationOfMemberFunction(OldMD,
725*67e74705SXin Li                                                   TSK_ImplicitInstantiation);
726*67e74705SXin Li       }
727*67e74705SXin Li 
728*67e74705SXin Li       SemaRef.CurrentInstantiationScope->InstantiatedLocal(Old, New);
729*67e74705SXin Li 
730*67e74705SXin Li       // We recreated a local declaration, but not by instantiating it. There
731*67e74705SXin Li       // may be pending dependent diagnostics to produce.
732*67e74705SXin Li       if (auto *DC = dyn_cast<DeclContext>(Old))
733*67e74705SXin Li         SemaRef.PerformDependentDiagnostics(DC, TemplateArgs);
734*67e74705SXin Li     }
735*67e74705SXin Li 
736*67e74705SXin Li     /// \brief Transform the definition of the given declaration by
737*67e74705SXin Li     /// instantiating it.
738*67e74705SXin Li     Decl *TransformDefinition(SourceLocation Loc, Decl *D);
739*67e74705SXin Li 
740*67e74705SXin Li     /// \brief Transform the first qualifier within a scope by instantiating the
741*67e74705SXin Li     /// declaration.
742*67e74705SXin Li     NamedDecl *TransformFirstQualifierInScope(NamedDecl *D, SourceLocation Loc);
743*67e74705SXin Li 
744*67e74705SXin Li     /// \brief Rebuild the exception declaration and register the declaration
745*67e74705SXin Li     /// as an instantiated local.
746*67e74705SXin Li     VarDecl *RebuildExceptionDecl(VarDecl *ExceptionDecl,
747*67e74705SXin Li                                   TypeSourceInfo *Declarator,
748*67e74705SXin Li                                   SourceLocation StartLoc,
749*67e74705SXin Li                                   SourceLocation NameLoc,
750*67e74705SXin Li                                   IdentifierInfo *Name);
751*67e74705SXin Li 
752*67e74705SXin Li     /// \brief Rebuild the Objective-C exception declaration and register the
753*67e74705SXin Li     /// declaration as an instantiated local.
754*67e74705SXin Li     VarDecl *RebuildObjCExceptionDecl(VarDecl *ExceptionDecl,
755*67e74705SXin Li                                       TypeSourceInfo *TSInfo, QualType T);
756*67e74705SXin Li 
757*67e74705SXin Li     /// \brief Check for tag mismatches when instantiating an
758*67e74705SXin Li     /// elaborated type.
759*67e74705SXin Li     QualType RebuildElaboratedType(SourceLocation KeywordLoc,
760*67e74705SXin Li                                    ElaboratedTypeKeyword Keyword,
761*67e74705SXin Li                                    NestedNameSpecifierLoc QualifierLoc,
762*67e74705SXin Li                                    QualType T);
763*67e74705SXin Li 
764*67e74705SXin Li     TemplateName
765*67e74705SXin Li     TransformTemplateName(CXXScopeSpec &SS, TemplateName Name,
766*67e74705SXin Li                           SourceLocation NameLoc,
767*67e74705SXin Li                           QualType ObjectType = QualType(),
768*67e74705SXin Li                           NamedDecl *FirstQualifierInScope = nullptr);
769*67e74705SXin Li 
770*67e74705SXin Li     const LoopHintAttr *TransformLoopHintAttr(const LoopHintAttr *LH);
771*67e74705SXin Li 
772*67e74705SXin Li     ExprResult TransformPredefinedExpr(PredefinedExpr *E);
773*67e74705SXin Li     ExprResult TransformDeclRefExpr(DeclRefExpr *E);
774*67e74705SXin Li     ExprResult TransformCXXDefaultArgExpr(CXXDefaultArgExpr *E);
775*67e74705SXin Li 
776*67e74705SXin Li     ExprResult TransformTemplateParmRefExpr(DeclRefExpr *E,
777*67e74705SXin Li                                             NonTypeTemplateParmDecl *D);
778*67e74705SXin Li     ExprResult TransformSubstNonTypeTemplateParmPackExpr(
779*67e74705SXin Li                                            SubstNonTypeTemplateParmPackExpr *E);
780*67e74705SXin Li 
781*67e74705SXin Li     /// \brief Rebuild a DeclRefExpr for a ParmVarDecl reference.
782*67e74705SXin Li     ExprResult RebuildParmVarDeclRefExpr(ParmVarDecl *PD, SourceLocation Loc);
783*67e74705SXin Li 
784*67e74705SXin Li     /// \brief Transform a reference to a function parameter pack.
785*67e74705SXin Li     ExprResult TransformFunctionParmPackRefExpr(DeclRefExpr *E,
786*67e74705SXin Li                                                 ParmVarDecl *PD);
787*67e74705SXin Li 
788*67e74705SXin Li     /// \brief Transform a FunctionParmPackExpr which was built when we couldn't
789*67e74705SXin Li     /// expand a function parameter pack reference which refers to an expanded
790*67e74705SXin Li     /// pack.
791*67e74705SXin Li     ExprResult TransformFunctionParmPackExpr(FunctionParmPackExpr *E);
792*67e74705SXin Li 
TransformFunctionProtoType(TypeLocBuilder & TLB,FunctionProtoTypeLoc TL)793*67e74705SXin Li     QualType TransformFunctionProtoType(TypeLocBuilder &TLB,
794*67e74705SXin Li                                         FunctionProtoTypeLoc TL) {
795*67e74705SXin Li       // Call the base version; it will forward to our overridden version below.
796*67e74705SXin Li       return inherited::TransformFunctionProtoType(TLB, TL);
797*67e74705SXin Li     }
798*67e74705SXin Li 
799*67e74705SXin Li     template<typename Fn>
800*67e74705SXin Li     QualType TransformFunctionProtoType(TypeLocBuilder &TLB,
801*67e74705SXin Li                                         FunctionProtoTypeLoc TL,
802*67e74705SXin Li                                         CXXRecordDecl *ThisContext,
803*67e74705SXin Li                                         unsigned ThisTypeQuals,
804*67e74705SXin Li                                         Fn TransformExceptionSpec);
805*67e74705SXin Li 
806*67e74705SXin Li     ParmVarDecl *TransformFunctionTypeParam(ParmVarDecl *OldParm,
807*67e74705SXin Li                                             int indexAdjustment,
808*67e74705SXin Li                                             Optional<unsigned> NumExpansions,
809*67e74705SXin Li                                             bool ExpectParameterPack);
810*67e74705SXin Li 
811*67e74705SXin Li     /// \brief Transforms a template type parameter type by performing
812*67e74705SXin Li     /// substitution of the corresponding template type argument.
813*67e74705SXin Li     QualType TransformTemplateTypeParmType(TypeLocBuilder &TLB,
814*67e74705SXin Li                                            TemplateTypeParmTypeLoc TL);
815*67e74705SXin Li 
816*67e74705SXin Li     /// \brief Transforms an already-substituted template type parameter pack
817*67e74705SXin Li     /// into either itself (if we aren't substituting into its pack expansion)
818*67e74705SXin Li     /// or the appropriate substituted argument.
819*67e74705SXin Li     QualType TransformSubstTemplateTypeParmPackType(TypeLocBuilder &TLB,
820*67e74705SXin Li                                            SubstTemplateTypeParmPackTypeLoc TL);
821*67e74705SXin Li 
TransformLambdaExpr(LambdaExpr * E)822*67e74705SXin Li     ExprResult TransformLambdaExpr(LambdaExpr *E) {
823*67e74705SXin Li       LocalInstantiationScope Scope(SemaRef, /*CombineWithOuterScope=*/true);
824*67e74705SXin Li       return TreeTransform<TemplateInstantiator>::TransformLambdaExpr(E);
825*67e74705SXin Li     }
826*67e74705SXin Li 
TransformTemplateParameterList(TemplateParameterList * OrigTPL)827*67e74705SXin Li     TemplateParameterList *TransformTemplateParameterList(
828*67e74705SXin Li                               TemplateParameterList *OrigTPL)  {
829*67e74705SXin Li       if (!OrigTPL || !OrigTPL->size()) return OrigTPL;
830*67e74705SXin Li 
831*67e74705SXin Li       DeclContext *Owner = OrigTPL->getParam(0)->getDeclContext();
832*67e74705SXin Li       TemplateDeclInstantiator  DeclInstantiator(getSema(),
833*67e74705SXin Li                         /* DeclContext *Owner */ Owner, TemplateArgs);
834*67e74705SXin Li       return DeclInstantiator.SubstTemplateParams(OrigTPL);
835*67e74705SXin Li     }
836*67e74705SXin Li   private:
837*67e74705SXin Li     ExprResult transformNonTypeTemplateParmRef(NonTypeTemplateParmDecl *parm,
838*67e74705SXin Li                                                SourceLocation loc,
839*67e74705SXin Li                                                TemplateArgument arg);
840*67e74705SXin Li   };
841*67e74705SXin Li }
842*67e74705SXin Li 
AlreadyTransformed(QualType T)843*67e74705SXin Li bool TemplateInstantiator::AlreadyTransformed(QualType T) {
844*67e74705SXin Li   if (T.isNull())
845*67e74705SXin Li     return true;
846*67e74705SXin Li 
847*67e74705SXin Li   if (T->isInstantiationDependentType() || T->isVariablyModifiedType())
848*67e74705SXin Li     return false;
849*67e74705SXin Li 
850*67e74705SXin Li   getSema().MarkDeclarationsReferencedInType(Loc, T);
851*67e74705SXin Li   return true;
852*67e74705SXin Li }
853*67e74705SXin Li 
854*67e74705SXin Li static TemplateArgument
getPackSubstitutedTemplateArgument(Sema & S,TemplateArgument Arg)855*67e74705SXin Li getPackSubstitutedTemplateArgument(Sema &S, TemplateArgument Arg) {
856*67e74705SXin Li   assert(S.ArgumentPackSubstitutionIndex >= 0);
857*67e74705SXin Li   assert(S.ArgumentPackSubstitutionIndex < (int)Arg.pack_size());
858*67e74705SXin Li   Arg = Arg.pack_begin()[S.ArgumentPackSubstitutionIndex];
859*67e74705SXin Li   if (Arg.isPackExpansion())
860*67e74705SXin Li     Arg = Arg.getPackExpansionPattern();
861*67e74705SXin Li   return Arg;
862*67e74705SXin Li }
863*67e74705SXin Li 
TransformDecl(SourceLocation Loc,Decl * D)864*67e74705SXin Li Decl *TemplateInstantiator::TransformDecl(SourceLocation Loc, Decl *D) {
865*67e74705SXin Li   if (!D)
866*67e74705SXin Li     return nullptr;
867*67e74705SXin Li 
868*67e74705SXin Li   if (TemplateTemplateParmDecl *TTP = dyn_cast<TemplateTemplateParmDecl>(D)) {
869*67e74705SXin Li     if (TTP->getDepth() < TemplateArgs.getNumLevels()) {
870*67e74705SXin Li       // If the corresponding template argument is NULL or non-existent, it's
871*67e74705SXin Li       // because we are performing instantiation from explicitly-specified
872*67e74705SXin Li       // template arguments in a function template, but there were some
873*67e74705SXin Li       // arguments left unspecified.
874*67e74705SXin Li       if (!TemplateArgs.hasTemplateArgument(TTP->getDepth(),
875*67e74705SXin Li                                             TTP->getPosition()))
876*67e74705SXin Li         return D;
877*67e74705SXin Li 
878*67e74705SXin Li       TemplateArgument Arg = TemplateArgs(TTP->getDepth(), TTP->getPosition());
879*67e74705SXin Li 
880*67e74705SXin Li       if (TTP->isParameterPack()) {
881*67e74705SXin Li         assert(Arg.getKind() == TemplateArgument::Pack &&
882*67e74705SXin Li                "Missing argument pack");
883*67e74705SXin Li         Arg = getPackSubstitutedTemplateArgument(getSema(), Arg);
884*67e74705SXin Li       }
885*67e74705SXin Li 
886*67e74705SXin Li       TemplateName Template = Arg.getAsTemplate();
887*67e74705SXin Li       assert(!Template.isNull() && Template.getAsTemplateDecl() &&
888*67e74705SXin Li              "Wrong kind of template template argument");
889*67e74705SXin Li       return Template.getAsTemplateDecl();
890*67e74705SXin Li     }
891*67e74705SXin Li 
892*67e74705SXin Li     // Fall through to find the instantiated declaration for this template
893*67e74705SXin Li     // template parameter.
894*67e74705SXin Li   }
895*67e74705SXin Li 
896*67e74705SXin Li   return SemaRef.FindInstantiatedDecl(Loc, cast<NamedDecl>(D), TemplateArgs);
897*67e74705SXin Li }
898*67e74705SXin Li 
TransformDefinition(SourceLocation Loc,Decl * D)899*67e74705SXin Li Decl *TemplateInstantiator::TransformDefinition(SourceLocation Loc, Decl *D) {
900*67e74705SXin Li   Decl *Inst = getSema().SubstDecl(D, getSema().CurContext, TemplateArgs);
901*67e74705SXin Li   if (!Inst)
902*67e74705SXin Li     return nullptr;
903*67e74705SXin Li 
904*67e74705SXin Li   getSema().CurrentInstantiationScope->InstantiatedLocal(D, Inst);
905*67e74705SXin Li   return Inst;
906*67e74705SXin Li }
907*67e74705SXin Li 
908*67e74705SXin Li NamedDecl *
TransformFirstQualifierInScope(NamedDecl * D,SourceLocation Loc)909*67e74705SXin Li TemplateInstantiator::TransformFirstQualifierInScope(NamedDecl *D,
910*67e74705SXin Li                                                      SourceLocation Loc) {
911*67e74705SXin Li   // If the first part of the nested-name-specifier was a template type
912*67e74705SXin Li   // parameter, instantiate that type parameter down to a tag type.
913*67e74705SXin Li   if (TemplateTypeParmDecl *TTPD = dyn_cast_or_null<TemplateTypeParmDecl>(D)) {
914*67e74705SXin Li     const TemplateTypeParmType *TTP
915*67e74705SXin Li       = cast<TemplateTypeParmType>(getSema().Context.getTypeDeclType(TTPD));
916*67e74705SXin Li 
917*67e74705SXin Li     if (TTP->getDepth() < TemplateArgs.getNumLevels()) {
918*67e74705SXin Li       // FIXME: This needs testing w/ member access expressions.
919*67e74705SXin Li       TemplateArgument Arg = TemplateArgs(TTP->getDepth(), TTP->getIndex());
920*67e74705SXin Li 
921*67e74705SXin Li       if (TTP->isParameterPack()) {
922*67e74705SXin Li         assert(Arg.getKind() == TemplateArgument::Pack &&
923*67e74705SXin Li                "Missing argument pack");
924*67e74705SXin Li 
925*67e74705SXin Li         if (getSema().ArgumentPackSubstitutionIndex == -1)
926*67e74705SXin Li           return nullptr;
927*67e74705SXin Li 
928*67e74705SXin Li         Arg = getPackSubstitutedTemplateArgument(getSema(), Arg);
929*67e74705SXin Li       }
930*67e74705SXin Li 
931*67e74705SXin Li       QualType T = Arg.getAsType();
932*67e74705SXin Li       if (T.isNull())
933*67e74705SXin Li         return cast_or_null<NamedDecl>(TransformDecl(Loc, D));
934*67e74705SXin Li 
935*67e74705SXin Li       if (const TagType *Tag = T->getAs<TagType>())
936*67e74705SXin Li         return Tag->getDecl();
937*67e74705SXin Li 
938*67e74705SXin Li       // The resulting type is not a tag; complain.
939*67e74705SXin Li       getSema().Diag(Loc, diag::err_nested_name_spec_non_tag) << T;
940*67e74705SXin Li       return nullptr;
941*67e74705SXin Li     }
942*67e74705SXin Li   }
943*67e74705SXin Li 
944*67e74705SXin Li   return cast_or_null<NamedDecl>(TransformDecl(Loc, D));
945*67e74705SXin Li }
946*67e74705SXin Li 
947*67e74705SXin Li VarDecl *
RebuildExceptionDecl(VarDecl * ExceptionDecl,TypeSourceInfo * Declarator,SourceLocation StartLoc,SourceLocation NameLoc,IdentifierInfo * Name)948*67e74705SXin Li TemplateInstantiator::RebuildExceptionDecl(VarDecl *ExceptionDecl,
949*67e74705SXin Li                                            TypeSourceInfo *Declarator,
950*67e74705SXin Li                                            SourceLocation StartLoc,
951*67e74705SXin Li                                            SourceLocation NameLoc,
952*67e74705SXin Li                                            IdentifierInfo *Name) {
953*67e74705SXin Li   VarDecl *Var = inherited::RebuildExceptionDecl(ExceptionDecl, Declarator,
954*67e74705SXin Li                                                  StartLoc, NameLoc, Name);
955*67e74705SXin Li   if (Var)
956*67e74705SXin Li     getSema().CurrentInstantiationScope->InstantiatedLocal(ExceptionDecl, Var);
957*67e74705SXin Li   return Var;
958*67e74705SXin Li }
959*67e74705SXin Li 
RebuildObjCExceptionDecl(VarDecl * ExceptionDecl,TypeSourceInfo * TSInfo,QualType T)960*67e74705SXin Li VarDecl *TemplateInstantiator::RebuildObjCExceptionDecl(VarDecl *ExceptionDecl,
961*67e74705SXin Li                                                         TypeSourceInfo *TSInfo,
962*67e74705SXin Li                                                         QualType T) {
963*67e74705SXin Li   VarDecl *Var = inherited::RebuildObjCExceptionDecl(ExceptionDecl, TSInfo, T);
964*67e74705SXin Li   if (Var)
965*67e74705SXin Li     getSema().CurrentInstantiationScope->InstantiatedLocal(ExceptionDecl, Var);
966*67e74705SXin Li   return Var;
967*67e74705SXin Li }
968*67e74705SXin Li 
969*67e74705SXin Li QualType
RebuildElaboratedType(SourceLocation KeywordLoc,ElaboratedTypeKeyword Keyword,NestedNameSpecifierLoc QualifierLoc,QualType T)970*67e74705SXin Li TemplateInstantiator::RebuildElaboratedType(SourceLocation KeywordLoc,
971*67e74705SXin Li                                             ElaboratedTypeKeyword Keyword,
972*67e74705SXin Li                                             NestedNameSpecifierLoc QualifierLoc,
973*67e74705SXin Li                                             QualType T) {
974*67e74705SXin Li   if (const TagType *TT = T->getAs<TagType>()) {
975*67e74705SXin Li     TagDecl* TD = TT->getDecl();
976*67e74705SXin Li 
977*67e74705SXin Li     SourceLocation TagLocation = KeywordLoc;
978*67e74705SXin Li 
979*67e74705SXin Li     IdentifierInfo *Id = TD->getIdentifier();
980*67e74705SXin Li 
981*67e74705SXin Li     // TODO: should we even warn on struct/class mismatches for this?  Seems
982*67e74705SXin Li     // like it's likely to produce a lot of spurious errors.
983*67e74705SXin Li     if (Id && Keyword != ETK_None && Keyword != ETK_Typename) {
984*67e74705SXin Li       TagTypeKind Kind = TypeWithKeyword::getTagTypeKindForKeyword(Keyword);
985*67e74705SXin Li       if (!SemaRef.isAcceptableTagRedeclaration(TD, Kind, /*isDefinition*/false,
986*67e74705SXin Li                                                 TagLocation, Id)) {
987*67e74705SXin Li         SemaRef.Diag(TagLocation, diag::err_use_with_wrong_tag)
988*67e74705SXin Li           << Id
989*67e74705SXin Li           << FixItHint::CreateReplacement(SourceRange(TagLocation),
990*67e74705SXin Li                                           TD->getKindName());
991*67e74705SXin Li         SemaRef.Diag(TD->getLocation(), diag::note_previous_use);
992*67e74705SXin Li       }
993*67e74705SXin Li     }
994*67e74705SXin Li   }
995*67e74705SXin Li 
996*67e74705SXin Li   return TreeTransform<TemplateInstantiator>::RebuildElaboratedType(KeywordLoc,
997*67e74705SXin Li                                                                     Keyword,
998*67e74705SXin Li                                                                   QualifierLoc,
999*67e74705SXin Li                                                                     T);
1000*67e74705SXin Li }
1001*67e74705SXin Li 
TransformTemplateName(CXXScopeSpec & SS,TemplateName Name,SourceLocation NameLoc,QualType ObjectType,NamedDecl * FirstQualifierInScope)1002*67e74705SXin Li TemplateName TemplateInstantiator::TransformTemplateName(CXXScopeSpec &SS,
1003*67e74705SXin Li                                                          TemplateName Name,
1004*67e74705SXin Li                                                          SourceLocation NameLoc,
1005*67e74705SXin Li                                                          QualType ObjectType,
1006*67e74705SXin Li                                              NamedDecl *FirstQualifierInScope) {
1007*67e74705SXin Li   if (TemplateTemplateParmDecl *TTP
1008*67e74705SXin Li        = dyn_cast_or_null<TemplateTemplateParmDecl>(Name.getAsTemplateDecl())) {
1009*67e74705SXin Li     if (TTP->getDepth() < TemplateArgs.getNumLevels()) {
1010*67e74705SXin Li       // If the corresponding template argument is NULL or non-existent, it's
1011*67e74705SXin Li       // because we are performing instantiation from explicitly-specified
1012*67e74705SXin Li       // template arguments in a function template, but there were some
1013*67e74705SXin Li       // arguments left unspecified.
1014*67e74705SXin Li       if (!TemplateArgs.hasTemplateArgument(TTP->getDepth(),
1015*67e74705SXin Li                                             TTP->getPosition()))
1016*67e74705SXin Li         return Name;
1017*67e74705SXin Li 
1018*67e74705SXin Li       TemplateArgument Arg = TemplateArgs(TTP->getDepth(), TTP->getPosition());
1019*67e74705SXin Li 
1020*67e74705SXin Li       if (TTP->isParameterPack()) {
1021*67e74705SXin Li         assert(Arg.getKind() == TemplateArgument::Pack &&
1022*67e74705SXin Li                "Missing argument pack");
1023*67e74705SXin Li 
1024*67e74705SXin Li         if (getSema().ArgumentPackSubstitutionIndex == -1) {
1025*67e74705SXin Li           // We have the template argument pack to substitute, but we're not
1026*67e74705SXin Li           // actually expanding the enclosing pack expansion yet. So, just
1027*67e74705SXin Li           // keep the entire argument pack.
1028*67e74705SXin Li           return getSema().Context.getSubstTemplateTemplateParmPack(TTP, Arg);
1029*67e74705SXin Li         }
1030*67e74705SXin Li 
1031*67e74705SXin Li         Arg = getPackSubstitutedTemplateArgument(getSema(), Arg);
1032*67e74705SXin Li       }
1033*67e74705SXin Li 
1034*67e74705SXin Li       TemplateName Template = Arg.getAsTemplate();
1035*67e74705SXin Li       assert(!Template.isNull() && "Null template template argument");
1036*67e74705SXin Li 
1037*67e74705SXin Li       // We don't ever want to substitute for a qualified template name, since
1038*67e74705SXin Li       // the qualifier is handled separately. So, look through the qualified
1039*67e74705SXin Li       // template name to its underlying declaration.
1040*67e74705SXin Li       if (QualifiedTemplateName *QTN = Template.getAsQualifiedTemplateName())
1041*67e74705SXin Li         Template = TemplateName(QTN->getTemplateDecl());
1042*67e74705SXin Li 
1043*67e74705SXin Li       Template = getSema().Context.getSubstTemplateTemplateParm(TTP, Template);
1044*67e74705SXin Li       return Template;
1045*67e74705SXin Li     }
1046*67e74705SXin Li   }
1047*67e74705SXin Li 
1048*67e74705SXin Li   if (SubstTemplateTemplateParmPackStorage *SubstPack
1049*67e74705SXin Li       = Name.getAsSubstTemplateTemplateParmPack()) {
1050*67e74705SXin Li     if (getSema().ArgumentPackSubstitutionIndex == -1)
1051*67e74705SXin Li       return Name;
1052*67e74705SXin Li 
1053*67e74705SXin Li     TemplateArgument Arg = SubstPack->getArgumentPack();
1054*67e74705SXin Li     Arg = getPackSubstitutedTemplateArgument(getSema(), Arg);
1055*67e74705SXin Li     return Arg.getAsTemplate();
1056*67e74705SXin Li   }
1057*67e74705SXin Li 
1058*67e74705SXin Li   return inherited::TransformTemplateName(SS, Name, NameLoc, ObjectType,
1059*67e74705SXin Li                                           FirstQualifierInScope);
1060*67e74705SXin Li }
1061*67e74705SXin Li 
1062*67e74705SXin Li ExprResult
TransformPredefinedExpr(PredefinedExpr * E)1063*67e74705SXin Li TemplateInstantiator::TransformPredefinedExpr(PredefinedExpr *E) {
1064*67e74705SXin Li   if (!E->isTypeDependent())
1065*67e74705SXin Li     return E;
1066*67e74705SXin Li 
1067*67e74705SXin Li   return getSema().BuildPredefinedExpr(E->getLocation(), E->getIdentType());
1068*67e74705SXin Li }
1069*67e74705SXin Li 
1070*67e74705SXin Li ExprResult
TransformTemplateParmRefExpr(DeclRefExpr * E,NonTypeTemplateParmDecl * NTTP)1071*67e74705SXin Li TemplateInstantiator::TransformTemplateParmRefExpr(DeclRefExpr *E,
1072*67e74705SXin Li                                                NonTypeTemplateParmDecl *NTTP) {
1073*67e74705SXin Li   // If the corresponding template argument is NULL or non-existent, it's
1074*67e74705SXin Li   // because we are performing instantiation from explicitly-specified
1075*67e74705SXin Li   // template arguments in a function template, but there were some
1076*67e74705SXin Li   // arguments left unspecified.
1077*67e74705SXin Li   if (!TemplateArgs.hasTemplateArgument(NTTP->getDepth(),
1078*67e74705SXin Li                                         NTTP->getPosition()))
1079*67e74705SXin Li     return E;
1080*67e74705SXin Li 
1081*67e74705SXin Li   TemplateArgument Arg = TemplateArgs(NTTP->getDepth(), NTTP->getPosition());
1082*67e74705SXin Li   if (NTTP->isParameterPack()) {
1083*67e74705SXin Li     assert(Arg.getKind() == TemplateArgument::Pack &&
1084*67e74705SXin Li            "Missing argument pack");
1085*67e74705SXin Li 
1086*67e74705SXin Li     if (getSema().ArgumentPackSubstitutionIndex == -1) {
1087*67e74705SXin Li       // We have an argument pack, but we can't select a particular argument
1088*67e74705SXin Li       // out of it yet. Therefore, we'll build an expression to hold on to that
1089*67e74705SXin Li       // argument pack.
1090*67e74705SXin Li       QualType TargetType = SemaRef.SubstType(NTTP->getType(), TemplateArgs,
1091*67e74705SXin Li                                               E->getLocation(),
1092*67e74705SXin Li                                               NTTP->getDeclName());
1093*67e74705SXin Li       if (TargetType.isNull())
1094*67e74705SXin Li         return ExprError();
1095*67e74705SXin Li 
1096*67e74705SXin Li       return new (SemaRef.Context) SubstNonTypeTemplateParmPackExpr(TargetType,
1097*67e74705SXin Li                                                                     NTTP,
1098*67e74705SXin Li                                                               E->getLocation(),
1099*67e74705SXin Li                                                                     Arg);
1100*67e74705SXin Li     }
1101*67e74705SXin Li 
1102*67e74705SXin Li     Arg = getPackSubstitutedTemplateArgument(getSema(), Arg);
1103*67e74705SXin Li   }
1104*67e74705SXin Li 
1105*67e74705SXin Li   return transformNonTypeTemplateParmRef(NTTP, E->getLocation(), Arg);
1106*67e74705SXin Li }
1107*67e74705SXin Li 
1108*67e74705SXin Li const LoopHintAttr *
TransformLoopHintAttr(const LoopHintAttr * LH)1109*67e74705SXin Li TemplateInstantiator::TransformLoopHintAttr(const LoopHintAttr *LH) {
1110*67e74705SXin Li   Expr *TransformedExpr = getDerived().TransformExpr(LH->getValue()).get();
1111*67e74705SXin Li 
1112*67e74705SXin Li   if (TransformedExpr == LH->getValue())
1113*67e74705SXin Li     return LH;
1114*67e74705SXin Li 
1115*67e74705SXin Li   // Generate error if there is a problem with the value.
1116*67e74705SXin Li   if (getSema().CheckLoopHintExpr(TransformedExpr, LH->getLocation()))
1117*67e74705SXin Li     return LH;
1118*67e74705SXin Li 
1119*67e74705SXin Li   // Create new LoopHintValueAttr with integral expression in place of the
1120*67e74705SXin Li   // non-type template parameter.
1121*67e74705SXin Li   return LoopHintAttr::CreateImplicit(
1122*67e74705SXin Li       getSema().Context, LH->getSemanticSpelling(), LH->getOption(),
1123*67e74705SXin Li       LH->getState(), TransformedExpr, LH->getRange());
1124*67e74705SXin Li }
1125*67e74705SXin Li 
transformNonTypeTemplateParmRef(NonTypeTemplateParmDecl * parm,SourceLocation loc,TemplateArgument arg)1126*67e74705SXin Li ExprResult TemplateInstantiator::transformNonTypeTemplateParmRef(
1127*67e74705SXin Li                                                  NonTypeTemplateParmDecl *parm,
1128*67e74705SXin Li                                                  SourceLocation loc,
1129*67e74705SXin Li                                                  TemplateArgument arg) {
1130*67e74705SXin Li   ExprResult result;
1131*67e74705SXin Li   QualType type;
1132*67e74705SXin Li 
1133*67e74705SXin Li   // The template argument itself might be an expression, in which
1134*67e74705SXin Li   // case we just return that expression.
1135*67e74705SXin Li   if (arg.getKind() == TemplateArgument::Expression) {
1136*67e74705SXin Li     Expr *argExpr = arg.getAsExpr();
1137*67e74705SXin Li     result = argExpr;
1138*67e74705SXin Li     type = argExpr->getType();
1139*67e74705SXin Li 
1140*67e74705SXin Li   } else if (arg.getKind() == TemplateArgument::Declaration ||
1141*67e74705SXin Li              arg.getKind() == TemplateArgument::NullPtr) {
1142*67e74705SXin Li     ValueDecl *VD;
1143*67e74705SXin Li     if (arg.getKind() == TemplateArgument::Declaration) {
1144*67e74705SXin Li       VD = cast<ValueDecl>(arg.getAsDecl());
1145*67e74705SXin Li 
1146*67e74705SXin Li       // Find the instantiation of the template argument.  This is
1147*67e74705SXin Li       // required for nested templates.
1148*67e74705SXin Li       VD = cast_or_null<ValueDecl>(
1149*67e74705SXin Li              getSema().FindInstantiatedDecl(loc, VD, TemplateArgs));
1150*67e74705SXin Li       if (!VD)
1151*67e74705SXin Li         return ExprError();
1152*67e74705SXin Li     } else {
1153*67e74705SXin Li       // Propagate NULL template argument.
1154*67e74705SXin Li       VD = nullptr;
1155*67e74705SXin Li     }
1156*67e74705SXin Li 
1157*67e74705SXin Li     // Derive the type we want the substituted decl to have.  This had
1158*67e74705SXin Li     // better be non-dependent, or these checks will have serious problems.
1159*67e74705SXin Li     if (parm->isExpandedParameterPack()) {
1160*67e74705SXin Li       type = parm->getExpansionType(SemaRef.ArgumentPackSubstitutionIndex);
1161*67e74705SXin Li     } else if (parm->isParameterPack() &&
1162*67e74705SXin Li                isa<PackExpansionType>(parm->getType())) {
1163*67e74705SXin Li       type = SemaRef.SubstType(
1164*67e74705SXin Li                         cast<PackExpansionType>(parm->getType())->getPattern(),
1165*67e74705SXin Li                                      TemplateArgs, loc, parm->getDeclName());
1166*67e74705SXin Li     } else {
1167*67e74705SXin Li       type = SemaRef.SubstType(parm->getType(), TemplateArgs,
1168*67e74705SXin Li                                loc, parm->getDeclName());
1169*67e74705SXin Li     }
1170*67e74705SXin Li     assert(!type.isNull() && "type substitution failed for param type");
1171*67e74705SXin Li     assert(!type->isDependentType() && "param type still dependent");
1172*67e74705SXin Li     result = SemaRef.BuildExpressionFromDeclTemplateArgument(arg, type, loc);
1173*67e74705SXin Li 
1174*67e74705SXin Li     if (!result.isInvalid()) type = result.get()->getType();
1175*67e74705SXin Li   } else {
1176*67e74705SXin Li     result = SemaRef.BuildExpressionFromIntegralTemplateArgument(arg, loc);
1177*67e74705SXin Li 
1178*67e74705SXin Li     // Note that this type can be different from the type of 'result',
1179*67e74705SXin Li     // e.g. if it's an enum type.
1180*67e74705SXin Li     type = arg.getIntegralType();
1181*67e74705SXin Li   }
1182*67e74705SXin Li   if (result.isInvalid()) return ExprError();
1183*67e74705SXin Li 
1184*67e74705SXin Li   Expr *resultExpr = result.get();
1185*67e74705SXin Li   return new (SemaRef.Context) SubstNonTypeTemplateParmExpr(
1186*67e74705SXin Li       type, resultExpr->getValueKind(), loc, parm, resultExpr);
1187*67e74705SXin Li }
1188*67e74705SXin Li 
1189*67e74705SXin Li ExprResult
TransformSubstNonTypeTemplateParmPackExpr(SubstNonTypeTemplateParmPackExpr * E)1190*67e74705SXin Li TemplateInstantiator::TransformSubstNonTypeTemplateParmPackExpr(
1191*67e74705SXin Li                                           SubstNonTypeTemplateParmPackExpr *E) {
1192*67e74705SXin Li   if (getSema().ArgumentPackSubstitutionIndex == -1) {
1193*67e74705SXin Li     // We aren't expanding the parameter pack, so just return ourselves.
1194*67e74705SXin Li     return E;
1195*67e74705SXin Li   }
1196*67e74705SXin Li 
1197*67e74705SXin Li   TemplateArgument Arg = E->getArgumentPack();
1198*67e74705SXin Li   Arg = getPackSubstitutedTemplateArgument(getSema(), Arg);
1199*67e74705SXin Li   return transformNonTypeTemplateParmRef(E->getParameterPack(),
1200*67e74705SXin Li                                          E->getParameterPackLocation(),
1201*67e74705SXin Li                                          Arg);
1202*67e74705SXin Li }
1203*67e74705SXin Li 
1204*67e74705SXin Li ExprResult
RebuildParmVarDeclRefExpr(ParmVarDecl * PD,SourceLocation Loc)1205*67e74705SXin Li TemplateInstantiator::RebuildParmVarDeclRefExpr(ParmVarDecl *PD,
1206*67e74705SXin Li                                                 SourceLocation Loc) {
1207*67e74705SXin Li   DeclarationNameInfo NameInfo(PD->getDeclName(), Loc);
1208*67e74705SXin Li   return getSema().BuildDeclarationNameExpr(CXXScopeSpec(), NameInfo, PD);
1209*67e74705SXin Li }
1210*67e74705SXin Li 
1211*67e74705SXin Li ExprResult
TransformFunctionParmPackExpr(FunctionParmPackExpr * E)1212*67e74705SXin Li TemplateInstantiator::TransformFunctionParmPackExpr(FunctionParmPackExpr *E) {
1213*67e74705SXin Li   if (getSema().ArgumentPackSubstitutionIndex != -1) {
1214*67e74705SXin Li     // We can expand this parameter pack now.
1215*67e74705SXin Li     ParmVarDecl *D = E->getExpansion(getSema().ArgumentPackSubstitutionIndex);
1216*67e74705SXin Li     ValueDecl *VD = cast_or_null<ValueDecl>(TransformDecl(E->getExprLoc(), D));
1217*67e74705SXin Li     if (!VD)
1218*67e74705SXin Li       return ExprError();
1219*67e74705SXin Li     return RebuildParmVarDeclRefExpr(cast<ParmVarDecl>(VD), E->getExprLoc());
1220*67e74705SXin Li   }
1221*67e74705SXin Li 
1222*67e74705SXin Li   QualType T = TransformType(E->getType());
1223*67e74705SXin Li   if (T.isNull())
1224*67e74705SXin Li     return ExprError();
1225*67e74705SXin Li 
1226*67e74705SXin Li   // Transform each of the parameter expansions into the corresponding
1227*67e74705SXin Li   // parameters in the instantiation of the function decl.
1228*67e74705SXin Li   SmallVector<ParmVarDecl *, 8> Parms;
1229*67e74705SXin Li   Parms.reserve(E->getNumExpansions());
1230*67e74705SXin Li   for (FunctionParmPackExpr::iterator I = E->begin(), End = E->end();
1231*67e74705SXin Li        I != End; ++I) {
1232*67e74705SXin Li     ParmVarDecl *D =
1233*67e74705SXin Li         cast_or_null<ParmVarDecl>(TransformDecl(E->getExprLoc(), *I));
1234*67e74705SXin Li     if (!D)
1235*67e74705SXin Li       return ExprError();
1236*67e74705SXin Li     Parms.push_back(D);
1237*67e74705SXin Li   }
1238*67e74705SXin Li 
1239*67e74705SXin Li   return FunctionParmPackExpr::Create(getSema().Context, T,
1240*67e74705SXin Li                                       E->getParameterPack(),
1241*67e74705SXin Li                                       E->getParameterPackLocation(), Parms);
1242*67e74705SXin Li }
1243*67e74705SXin Li 
1244*67e74705SXin Li ExprResult
TransformFunctionParmPackRefExpr(DeclRefExpr * E,ParmVarDecl * PD)1245*67e74705SXin Li TemplateInstantiator::TransformFunctionParmPackRefExpr(DeclRefExpr *E,
1246*67e74705SXin Li                                                        ParmVarDecl *PD) {
1247*67e74705SXin Li   typedef LocalInstantiationScope::DeclArgumentPack DeclArgumentPack;
1248*67e74705SXin Li   llvm::PointerUnion<Decl *, DeclArgumentPack *> *Found
1249*67e74705SXin Li     = getSema().CurrentInstantiationScope->findInstantiationOf(PD);
1250*67e74705SXin Li   assert(Found && "no instantiation for parameter pack");
1251*67e74705SXin Li 
1252*67e74705SXin Li   Decl *TransformedDecl;
1253*67e74705SXin Li   if (DeclArgumentPack *Pack = Found->dyn_cast<DeclArgumentPack *>()) {
1254*67e74705SXin Li     // If this is a reference to a function parameter pack which we can
1255*67e74705SXin Li     // substitute but can't yet expand, build a FunctionParmPackExpr for it.
1256*67e74705SXin Li     if (getSema().ArgumentPackSubstitutionIndex == -1) {
1257*67e74705SXin Li       QualType T = TransformType(E->getType());
1258*67e74705SXin Li       if (T.isNull())
1259*67e74705SXin Li         return ExprError();
1260*67e74705SXin Li       return FunctionParmPackExpr::Create(getSema().Context, T, PD,
1261*67e74705SXin Li                                           E->getExprLoc(), *Pack);
1262*67e74705SXin Li     }
1263*67e74705SXin Li 
1264*67e74705SXin Li     TransformedDecl = (*Pack)[getSema().ArgumentPackSubstitutionIndex];
1265*67e74705SXin Li   } else {
1266*67e74705SXin Li     TransformedDecl = Found->get<Decl*>();
1267*67e74705SXin Li   }
1268*67e74705SXin Li 
1269*67e74705SXin Li   // We have either an unexpanded pack or a specific expansion.
1270*67e74705SXin Li   return RebuildParmVarDeclRefExpr(cast<ParmVarDecl>(TransformedDecl),
1271*67e74705SXin Li                                    E->getExprLoc());
1272*67e74705SXin Li }
1273*67e74705SXin Li 
1274*67e74705SXin Li ExprResult
TransformDeclRefExpr(DeclRefExpr * E)1275*67e74705SXin Li TemplateInstantiator::TransformDeclRefExpr(DeclRefExpr *E) {
1276*67e74705SXin Li   NamedDecl *D = E->getDecl();
1277*67e74705SXin Li 
1278*67e74705SXin Li   // Handle references to non-type template parameters and non-type template
1279*67e74705SXin Li   // parameter packs.
1280*67e74705SXin Li   if (NonTypeTemplateParmDecl *NTTP = dyn_cast<NonTypeTemplateParmDecl>(D)) {
1281*67e74705SXin Li     if (NTTP->getDepth() < TemplateArgs.getNumLevels())
1282*67e74705SXin Li       return TransformTemplateParmRefExpr(E, NTTP);
1283*67e74705SXin Li 
1284*67e74705SXin Li     // We have a non-type template parameter that isn't fully substituted;
1285*67e74705SXin Li     // FindInstantiatedDecl will find it in the local instantiation scope.
1286*67e74705SXin Li   }
1287*67e74705SXin Li 
1288*67e74705SXin Li   // Handle references to function parameter packs.
1289*67e74705SXin Li   if (ParmVarDecl *PD = dyn_cast<ParmVarDecl>(D))
1290*67e74705SXin Li     if (PD->isParameterPack())
1291*67e74705SXin Li       return TransformFunctionParmPackRefExpr(E, PD);
1292*67e74705SXin Li 
1293*67e74705SXin Li   return TreeTransform<TemplateInstantiator>::TransformDeclRefExpr(E);
1294*67e74705SXin Li }
1295*67e74705SXin Li 
TransformCXXDefaultArgExpr(CXXDefaultArgExpr * E)1296*67e74705SXin Li ExprResult TemplateInstantiator::TransformCXXDefaultArgExpr(
1297*67e74705SXin Li     CXXDefaultArgExpr *E) {
1298*67e74705SXin Li   assert(!cast<FunctionDecl>(E->getParam()->getDeclContext())->
1299*67e74705SXin Li              getDescribedFunctionTemplate() &&
1300*67e74705SXin Li          "Default arg expressions are never formed in dependent cases.");
1301*67e74705SXin Li   return SemaRef.BuildCXXDefaultArgExpr(E->getUsedLocation(),
1302*67e74705SXin Li                            cast<FunctionDecl>(E->getParam()->getDeclContext()),
1303*67e74705SXin Li                                         E->getParam());
1304*67e74705SXin Li }
1305*67e74705SXin Li 
1306*67e74705SXin Li template<typename Fn>
TransformFunctionProtoType(TypeLocBuilder & TLB,FunctionProtoTypeLoc TL,CXXRecordDecl * ThisContext,unsigned ThisTypeQuals,Fn TransformExceptionSpec)1307*67e74705SXin Li QualType TemplateInstantiator::TransformFunctionProtoType(TypeLocBuilder &TLB,
1308*67e74705SXin Li                                  FunctionProtoTypeLoc TL,
1309*67e74705SXin Li                                  CXXRecordDecl *ThisContext,
1310*67e74705SXin Li                                  unsigned ThisTypeQuals,
1311*67e74705SXin Li                                  Fn TransformExceptionSpec) {
1312*67e74705SXin Li   // We need a local instantiation scope for this function prototype.
1313*67e74705SXin Li   LocalInstantiationScope Scope(SemaRef, /*CombineWithOuterScope=*/true);
1314*67e74705SXin Li   return inherited::TransformFunctionProtoType(
1315*67e74705SXin Li       TLB, TL, ThisContext, ThisTypeQuals, TransformExceptionSpec);
1316*67e74705SXin Li }
1317*67e74705SXin Li 
1318*67e74705SXin Li ParmVarDecl *
TransformFunctionTypeParam(ParmVarDecl * OldParm,int indexAdjustment,Optional<unsigned> NumExpansions,bool ExpectParameterPack)1319*67e74705SXin Li TemplateInstantiator::TransformFunctionTypeParam(ParmVarDecl *OldParm,
1320*67e74705SXin Li                                                  int indexAdjustment,
1321*67e74705SXin Li                                                Optional<unsigned> NumExpansions,
1322*67e74705SXin Li                                                  bool ExpectParameterPack) {
1323*67e74705SXin Li   return SemaRef.SubstParmVarDecl(OldParm, TemplateArgs, indexAdjustment,
1324*67e74705SXin Li                                   NumExpansions, ExpectParameterPack);
1325*67e74705SXin Li }
1326*67e74705SXin Li 
1327*67e74705SXin Li QualType
TransformTemplateTypeParmType(TypeLocBuilder & TLB,TemplateTypeParmTypeLoc TL)1328*67e74705SXin Li TemplateInstantiator::TransformTemplateTypeParmType(TypeLocBuilder &TLB,
1329*67e74705SXin Li                                                 TemplateTypeParmTypeLoc TL) {
1330*67e74705SXin Li   const TemplateTypeParmType *T = TL.getTypePtr();
1331*67e74705SXin Li   if (T->getDepth() < TemplateArgs.getNumLevels()) {
1332*67e74705SXin Li     // Replace the template type parameter with its corresponding
1333*67e74705SXin Li     // template argument.
1334*67e74705SXin Li 
1335*67e74705SXin Li     // If the corresponding template argument is NULL or doesn't exist, it's
1336*67e74705SXin Li     // because we are performing instantiation from explicitly-specified
1337*67e74705SXin Li     // template arguments in a function template class, but there were some
1338*67e74705SXin Li     // arguments left unspecified.
1339*67e74705SXin Li     if (!TemplateArgs.hasTemplateArgument(T->getDepth(), T->getIndex())) {
1340*67e74705SXin Li       TemplateTypeParmTypeLoc NewTL
1341*67e74705SXin Li         = TLB.push<TemplateTypeParmTypeLoc>(TL.getType());
1342*67e74705SXin Li       NewTL.setNameLoc(TL.getNameLoc());
1343*67e74705SXin Li       return TL.getType();
1344*67e74705SXin Li     }
1345*67e74705SXin Li 
1346*67e74705SXin Li     TemplateArgument Arg = TemplateArgs(T->getDepth(), T->getIndex());
1347*67e74705SXin Li 
1348*67e74705SXin Li     if (T->isParameterPack()) {
1349*67e74705SXin Li       assert(Arg.getKind() == TemplateArgument::Pack &&
1350*67e74705SXin Li              "Missing argument pack");
1351*67e74705SXin Li 
1352*67e74705SXin Li       if (getSema().ArgumentPackSubstitutionIndex == -1) {
1353*67e74705SXin Li         // We have the template argument pack, but we're not expanding the
1354*67e74705SXin Li         // enclosing pack expansion yet. Just save the template argument
1355*67e74705SXin Li         // pack for later substitution.
1356*67e74705SXin Li         QualType Result
1357*67e74705SXin Li           = getSema().Context.getSubstTemplateTypeParmPackType(T, Arg);
1358*67e74705SXin Li         SubstTemplateTypeParmPackTypeLoc NewTL
1359*67e74705SXin Li           = TLB.push<SubstTemplateTypeParmPackTypeLoc>(Result);
1360*67e74705SXin Li         NewTL.setNameLoc(TL.getNameLoc());
1361*67e74705SXin Li         return Result;
1362*67e74705SXin Li       }
1363*67e74705SXin Li 
1364*67e74705SXin Li       Arg = getPackSubstitutedTemplateArgument(getSema(), Arg);
1365*67e74705SXin Li     }
1366*67e74705SXin Li 
1367*67e74705SXin Li     assert(Arg.getKind() == TemplateArgument::Type &&
1368*67e74705SXin Li            "Template argument kind mismatch");
1369*67e74705SXin Li 
1370*67e74705SXin Li     QualType Replacement = Arg.getAsType();
1371*67e74705SXin Li 
1372*67e74705SXin Li     // TODO: only do this uniquing once, at the start of instantiation.
1373*67e74705SXin Li     QualType Result
1374*67e74705SXin Li       = getSema().Context.getSubstTemplateTypeParmType(T, Replacement);
1375*67e74705SXin Li     SubstTemplateTypeParmTypeLoc NewTL
1376*67e74705SXin Li       = TLB.push<SubstTemplateTypeParmTypeLoc>(Result);
1377*67e74705SXin Li     NewTL.setNameLoc(TL.getNameLoc());
1378*67e74705SXin Li     return Result;
1379*67e74705SXin Li   }
1380*67e74705SXin Li 
1381*67e74705SXin Li   // The template type parameter comes from an inner template (e.g.,
1382*67e74705SXin Li   // the template parameter list of a member template inside the
1383*67e74705SXin Li   // template we are instantiating). Create a new template type
1384*67e74705SXin Li   // parameter with the template "level" reduced by one.
1385*67e74705SXin Li   TemplateTypeParmDecl *NewTTPDecl = nullptr;
1386*67e74705SXin Li   if (TemplateTypeParmDecl *OldTTPDecl = T->getDecl())
1387*67e74705SXin Li     NewTTPDecl = cast_or_null<TemplateTypeParmDecl>(
1388*67e74705SXin Li                                   TransformDecl(TL.getNameLoc(), OldTTPDecl));
1389*67e74705SXin Li 
1390*67e74705SXin Li   QualType Result
1391*67e74705SXin Li     = getSema().Context.getTemplateTypeParmType(T->getDepth()
1392*67e74705SXin Li                                                  - TemplateArgs.getNumLevels(),
1393*67e74705SXin Li                                                 T->getIndex(),
1394*67e74705SXin Li                                                 T->isParameterPack(),
1395*67e74705SXin Li                                                 NewTTPDecl);
1396*67e74705SXin Li   TemplateTypeParmTypeLoc NewTL = TLB.push<TemplateTypeParmTypeLoc>(Result);
1397*67e74705SXin Li   NewTL.setNameLoc(TL.getNameLoc());
1398*67e74705SXin Li   return Result;
1399*67e74705SXin Li }
1400*67e74705SXin Li 
1401*67e74705SXin Li QualType
TransformSubstTemplateTypeParmPackType(TypeLocBuilder & TLB,SubstTemplateTypeParmPackTypeLoc TL)1402*67e74705SXin Li TemplateInstantiator::TransformSubstTemplateTypeParmPackType(
1403*67e74705SXin Li                                                             TypeLocBuilder &TLB,
1404*67e74705SXin Li                                          SubstTemplateTypeParmPackTypeLoc TL) {
1405*67e74705SXin Li   if (getSema().ArgumentPackSubstitutionIndex == -1) {
1406*67e74705SXin Li     // We aren't expanding the parameter pack, so just return ourselves.
1407*67e74705SXin Li     SubstTemplateTypeParmPackTypeLoc NewTL
1408*67e74705SXin Li       = TLB.push<SubstTemplateTypeParmPackTypeLoc>(TL.getType());
1409*67e74705SXin Li     NewTL.setNameLoc(TL.getNameLoc());
1410*67e74705SXin Li     return TL.getType();
1411*67e74705SXin Li   }
1412*67e74705SXin Li 
1413*67e74705SXin Li   TemplateArgument Arg = TL.getTypePtr()->getArgumentPack();
1414*67e74705SXin Li   Arg = getPackSubstitutedTemplateArgument(getSema(), Arg);
1415*67e74705SXin Li   QualType Result = Arg.getAsType();
1416*67e74705SXin Li 
1417*67e74705SXin Li   Result = getSema().Context.getSubstTemplateTypeParmType(
1418*67e74705SXin Li                                       TL.getTypePtr()->getReplacedParameter(),
1419*67e74705SXin Li                                                           Result);
1420*67e74705SXin Li   SubstTemplateTypeParmTypeLoc NewTL
1421*67e74705SXin Li     = TLB.push<SubstTemplateTypeParmTypeLoc>(Result);
1422*67e74705SXin Li   NewTL.setNameLoc(TL.getNameLoc());
1423*67e74705SXin Li   return Result;
1424*67e74705SXin Li }
1425*67e74705SXin Li 
1426*67e74705SXin Li /// \brief Perform substitution on the type T with a given set of template
1427*67e74705SXin Li /// arguments.
1428*67e74705SXin Li ///
1429*67e74705SXin Li /// This routine substitutes the given template arguments into the
1430*67e74705SXin Li /// type T and produces the instantiated type.
1431*67e74705SXin Li ///
1432*67e74705SXin Li /// \param T the type into which the template arguments will be
1433*67e74705SXin Li /// substituted. If this type is not dependent, it will be returned
1434*67e74705SXin Li /// immediately.
1435*67e74705SXin Li ///
1436*67e74705SXin Li /// \param Args the template arguments that will be
1437*67e74705SXin Li /// substituted for the top-level template parameters within T.
1438*67e74705SXin Li ///
1439*67e74705SXin Li /// \param Loc the location in the source code where this substitution
1440*67e74705SXin Li /// is being performed. It will typically be the location of the
1441*67e74705SXin Li /// declarator (if we're instantiating the type of some declaration)
1442*67e74705SXin Li /// or the location of the type in the source code (if, e.g., we're
1443*67e74705SXin Li /// instantiating the type of a cast expression).
1444*67e74705SXin Li ///
1445*67e74705SXin Li /// \param Entity the name of the entity associated with a declaration
1446*67e74705SXin Li /// being instantiated (if any). May be empty to indicate that there
1447*67e74705SXin Li /// is no such entity (if, e.g., this is a type that occurs as part of
1448*67e74705SXin Li /// a cast expression) or that the entity has no name (e.g., an
1449*67e74705SXin Li /// unnamed function parameter).
1450*67e74705SXin Li ///
1451*67e74705SXin Li /// \returns If the instantiation succeeds, the instantiated
1452*67e74705SXin Li /// type. Otherwise, produces diagnostics and returns a NULL type.
SubstType(TypeSourceInfo * T,const MultiLevelTemplateArgumentList & Args,SourceLocation Loc,DeclarationName Entity)1453*67e74705SXin Li TypeSourceInfo *Sema::SubstType(TypeSourceInfo *T,
1454*67e74705SXin Li                                 const MultiLevelTemplateArgumentList &Args,
1455*67e74705SXin Li                                 SourceLocation Loc,
1456*67e74705SXin Li                                 DeclarationName Entity) {
1457*67e74705SXin Li   assert(!ActiveTemplateInstantiations.empty() &&
1458*67e74705SXin Li          "Cannot perform an instantiation without some context on the "
1459*67e74705SXin Li          "instantiation stack");
1460*67e74705SXin Li 
1461*67e74705SXin Li   if (!T->getType()->isInstantiationDependentType() &&
1462*67e74705SXin Li       !T->getType()->isVariablyModifiedType())
1463*67e74705SXin Li     return T;
1464*67e74705SXin Li 
1465*67e74705SXin Li   TemplateInstantiator Instantiator(*this, Args, Loc, Entity);
1466*67e74705SXin Li   return Instantiator.TransformType(T);
1467*67e74705SXin Li }
1468*67e74705SXin Li 
SubstType(TypeLoc TL,const MultiLevelTemplateArgumentList & Args,SourceLocation Loc,DeclarationName Entity)1469*67e74705SXin Li TypeSourceInfo *Sema::SubstType(TypeLoc TL,
1470*67e74705SXin Li                                 const MultiLevelTemplateArgumentList &Args,
1471*67e74705SXin Li                                 SourceLocation Loc,
1472*67e74705SXin Li                                 DeclarationName Entity) {
1473*67e74705SXin Li   assert(!ActiveTemplateInstantiations.empty() &&
1474*67e74705SXin Li          "Cannot perform an instantiation without some context on the "
1475*67e74705SXin Li          "instantiation stack");
1476*67e74705SXin Li 
1477*67e74705SXin Li   if (TL.getType().isNull())
1478*67e74705SXin Li     return nullptr;
1479*67e74705SXin Li 
1480*67e74705SXin Li   if (!TL.getType()->isInstantiationDependentType() &&
1481*67e74705SXin Li       !TL.getType()->isVariablyModifiedType()) {
1482*67e74705SXin Li     // FIXME: Make a copy of the TypeLoc data here, so that we can
1483*67e74705SXin Li     // return a new TypeSourceInfo. Inefficient!
1484*67e74705SXin Li     TypeLocBuilder TLB;
1485*67e74705SXin Li     TLB.pushFullCopy(TL);
1486*67e74705SXin Li     return TLB.getTypeSourceInfo(Context, TL.getType());
1487*67e74705SXin Li   }
1488*67e74705SXin Li 
1489*67e74705SXin Li   TemplateInstantiator Instantiator(*this, Args, Loc, Entity);
1490*67e74705SXin Li   TypeLocBuilder TLB;
1491*67e74705SXin Li   TLB.reserve(TL.getFullDataSize());
1492*67e74705SXin Li   QualType Result = Instantiator.TransformType(TLB, TL);
1493*67e74705SXin Li   if (Result.isNull())
1494*67e74705SXin Li     return nullptr;
1495*67e74705SXin Li 
1496*67e74705SXin Li   return TLB.getTypeSourceInfo(Context, Result);
1497*67e74705SXin Li }
1498*67e74705SXin Li 
1499*67e74705SXin Li /// Deprecated form of the above.
SubstType(QualType T,const MultiLevelTemplateArgumentList & TemplateArgs,SourceLocation Loc,DeclarationName Entity)1500*67e74705SXin Li QualType Sema::SubstType(QualType T,
1501*67e74705SXin Li                          const MultiLevelTemplateArgumentList &TemplateArgs,
1502*67e74705SXin Li                          SourceLocation Loc, DeclarationName Entity) {
1503*67e74705SXin Li   assert(!ActiveTemplateInstantiations.empty() &&
1504*67e74705SXin Li          "Cannot perform an instantiation without some context on the "
1505*67e74705SXin Li          "instantiation stack");
1506*67e74705SXin Li 
1507*67e74705SXin Li   // If T is not a dependent type or a variably-modified type, there
1508*67e74705SXin Li   // is nothing to do.
1509*67e74705SXin Li   if (!T->isInstantiationDependentType() && !T->isVariablyModifiedType())
1510*67e74705SXin Li     return T;
1511*67e74705SXin Li 
1512*67e74705SXin Li   TemplateInstantiator Instantiator(*this, TemplateArgs, Loc, Entity);
1513*67e74705SXin Li   return Instantiator.TransformType(T);
1514*67e74705SXin Li }
1515*67e74705SXin Li 
NeedsInstantiationAsFunctionType(TypeSourceInfo * T)1516*67e74705SXin Li static bool NeedsInstantiationAsFunctionType(TypeSourceInfo *T) {
1517*67e74705SXin Li   if (T->getType()->isInstantiationDependentType() ||
1518*67e74705SXin Li       T->getType()->isVariablyModifiedType())
1519*67e74705SXin Li     return true;
1520*67e74705SXin Li 
1521*67e74705SXin Li   TypeLoc TL = T->getTypeLoc().IgnoreParens();
1522*67e74705SXin Li   if (!TL.getAs<FunctionProtoTypeLoc>())
1523*67e74705SXin Li     return false;
1524*67e74705SXin Li 
1525*67e74705SXin Li   FunctionProtoTypeLoc FP = TL.castAs<FunctionProtoTypeLoc>();
1526*67e74705SXin Li   for (ParmVarDecl *P : FP.getParams()) {
1527*67e74705SXin Li     // This must be synthesized from a typedef.
1528*67e74705SXin Li     if (!P) continue;
1529*67e74705SXin Li 
1530*67e74705SXin Li     // If there are any parameters, a new TypeSourceInfo that refers to the
1531*67e74705SXin Li     // instantiated parameters must be built.
1532*67e74705SXin Li     return true;
1533*67e74705SXin Li   }
1534*67e74705SXin Li 
1535*67e74705SXin Li   return false;
1536*67e74705SXin Li }
1537*67e74705SXin Li 
1538*67e74705SXin Li /// A form of SubstType intended specifically for instantiating the
1539*67e74705SXin Li /// type of a FunctionDecl.  Its purpose is solely to force the
1540*67e74705SXin Li /// instantiation of default-argument expressions and to avoid
1541*67e74705SXin Li /// instantiating an exception-specification.
SubstFunctionDeclType(TypeSourceInfo * T,const MultiLevelTemplateArgumentList & Args,SourceLocation Loc,DeclarationName Entity,CXXRecordDecl * ThisContext,unsigned ThisTypeQuals)1542*67e74705SXin Li TypeSourceInfo *Sema::SubstFunctionDeclType(TypeSourceInfo *T,
1543*67e74705SXin Li                                 const MultiLevelTemplateArgumentList &Args,
1544*67e74705SXin Li                                 SourceLocation Loc,
1545*67e74705SXin Li                                 DeclarationName Entity,
1546*67e74705SXin Li                                 CXXRecordDecl *ThisContext,
1547*67e74705SXin Li                                 unsigned ThisTypeQuals) {
1548*67e74705SXin Li   assert(!ActiveTemplateInstantiations.empty() &&
1549*67e74705SXin Li          "Cannot perform an instantiation without some context on the "
1550*67e74705SXin Li          "instantiation stack");
1551*67e74705SXin Li 
1552*67e74705SXin Li   if (!NeedsInstantiationAsFunctionType(T))
1553*67e74705SXin Li     return T;
1554*67e74705SXin Li 
1555*67e74705SXin Li   TemplateInstantiator Instantiator(*this, Args, Loc, Entity);
1556*67e74705SXin Li 
1557*67e74705SXin Li   TypeLocBuilder TLB;
1558*67e74705SXin Li 
1559*67e74705SXin Li   TypeLoc TL = T->getTypeLoc();
1560*67e74705SXin Li   TLB.reserve(TL.getFullDataSize());
1561*67e74705SXin Li 
1562*67e74705SXin Li   QualType Result;
1563*67e74705SXin Li 
1564*67e74705SXin Li   if (FunctionProtoTypeLoc Proto =
1565*67e74705SXin Li           TL.IgnoreParens().getAs<FunctionProtoTypeLoc>()) {
1566*67e74705SXin Li     // Instantiate the type, other than its exception specification. The
1567*67e74705SXin Li     // exception specification is instantiated in InitFunctionInstantiation
1568*67e74705SXin Li     // once we've built the FunctionDecl.
1569*67e74705SXin Li     // FIXME: Set the exception specification to EST_Uninstantiated here,
1570*67e74705SXin Li     // instead of rebuilding the function type again later.
1571*67e74705SXin Li     Result = Instantiator.TransformFunctionProtoType(
1572*67e74705SXin Li         TLB, Proto, ThisContext, ThisTypeQuals,
1573*67e74705SXin Li         [](FunctionProtoType::ExceptionSpecInfo &ESI,
1574*67e74705SXin Li            bool &Changed) { return false; });
1575*67e74705SXin Li   } else {
1576*67e74705SXin Li     Result = Instantiator.TransformType(TLB, TL);
1577*67e74705SXin Li   }
1578*67e74705SXin Li   if (Result.isNull())
1579*67e74705SXin Li     return nullptr;
1580*67e74705SXin Li 
1581*67e74705SXin Li   return TLB.getTypeSourceInfo(Context, Result);
1582*67e74705SXin Li }
1583*67e74705SXin Li 
SubstExceptionSpec(FunctionDecl * New,const FunctionProtoType * Proto,const MultiLevelTemplateArgumentList & Args)1584*67e74705SXin Li void Sema::SubstExceptionSpec(FunctionDecl *New, const FunctionProtoType *Proto,
1585*67e74705SXin Li                               const MultiLevelTemplateArgumentList &Args) {
1586*67e74705SXin Li   FunctionProtoType::ExceptionSpecInfo ESI =
1587*67e74705SXin Li       Proto->getExtProtoInfo().ExceptionSpec;
1588*67e74705SXin Li   assert(ESI.Type != EST_Uninstantiated);
1589*67e74705SXin Li 
1590*67e74705SXin Li   TemplateInstantiator Instantiator(*this, Args, New->getLocation(),
1591*67e74705SXin Li                                     New->getDeclName());
1592*67e74705SXin Li 
1593*67e74705SXin Li   SmallVector<QualType, 4> ExceptionStorage;
1594*67e74705SXin Li   bool Changed = false;
1595*67e74705SXin Li   if (Instantiator.TransformExceptionSpec(
1596*67e74705SXin Li           New->getTypeSourceInfo()->getTypeLoc().getLocEnd(), ESI,
1597*67e74705SXin Li           ExceptionStorage, Changed))
1598*67e74705SXin Li     // On error, recover by dropping the exception specification.
1599*67e74705SXin Li     ESI.Type = EST_None;
1600*67e74705SXin Li 
1601*67e74705SXin Li   UpdateExceptionSpec(New, ESI);
1602*67e74705SXin Li }
1603*67e74705SXin Li 
SubstParmVarDecl(ParmVarDecl * OldParm,const MultiLevelTemplateArgumentList & TemplateArgs,int indexAdjustment,Optional<unsigned> NumExpansions,bool ExpectParameterPack)1604*67e74705SXin Li ParmVarDecl *Sema::SubstParmVarDecl(ParmVarDecl *OldParm,
1605*67e74705SXin Li                             const MultiLevelTemplateArgumentList &TemplateArgs,
1606*67e74705SXin Li                                     int indexAdjustment,
1607*67e74705SXin Li                                     Optional<unsigned> NumExpansions,
1608*67e74705SXin Li                                     bool ExpectParameterPack) {
1609*67e74705SXin Li   TypeSourceInfo *OldDI = OldParm->getTypeSourceInfo();
1610*67e74705SXin Li   TypeSourceInfo *NewDI = nullptr;
1611*67e74705SXin Li 
1612*67e74705SXin Li   TypeLoc OldTL = OldDI->getTypeLoc();
1613*67e74705SXin Li   if (PackExpansionTypeLoc ExpansionTL = OldTL.getAs<PackExpansionTypeLoc>()) {
1614*67e74705SXin Li 
1615*67e74705SXin Li     // We have a function parameter pack. Substitute into the pattern of the
1616*67e74705SXin Li     // expansion.
1617*67e74705SXin Li     NewDI = SubstType(ExpansionTL.getPatternLoc(), TemplateArgs,
1618*67e74705SXin Li                       OldParm->getLocation(), OldParm->getDeclName());
1619*67e74705SXin Li     if (!NewDI)
1620*67e74705SXin Li       return nullptr;
1621*67e74705SXin Li 
1622*67e74705SXin Li     if (NewDI->getType()->containsUnexpandedParameterPack()) {
1623*67e74705SXin Li       // We still have unexpanded parameter packs, which means that
1624*67e74705SXin Li       // our function parameter is still a function parameter pack.
1625*67e74705SXin Li       // Therefore, make its type a pack expansion type.
1626*67e74705SXin Li       NewDI = CheckPackExpansion(NewDI, ExpansionTL.getEllipsisLoc(),
1627*67e74705SXin Li                                  NumExpansions);
1628*67e74705SXin Li     } else if (ExpectParameterPack) {
1629*67e74705SXin Li       // We expected to get a parameter pack but didn't (because the type
1630*67e74705SXin Li       // itself is not a pack expansion type), so complain. This can occur when
1631*67e74705SXin Li       // the substitution goes through an alias template that "loses" the
1632*67e74705SXin Li       // pack expansion.
1633*67e74705SXin Li       Diag(OldParm->getLocation(),
1634*67e74705SXin Li            diag::err_function_parameter_pack_without_parameter_packs)
1635*67e74705SXin Li         << NewDI->getType();
1636*67e74705SXin Li       return nullptr;
1637*67e74705SXin Li     }
1638*67e74705SXin Li   } else {
1639*67e74705SXin Li     NewDI = SubstType(OldDI, TemplateArgs, OldParm->getLocation(),
1640*67e74705SXin Li                       OldParm->getDeclName());
1641*67e74705SXin Li   }
1642*67e74705SXin Li 
1643*67e74705SXin Li   if (!NewDI)
1644*67e74705SXin Li     return nullptr;
1645*67e74705SXin Li 
1646*67e74705SXin Li   if (NewDI->getType()->isVoidType()) {
1647*67e74705SXin Li     Diag(OldParm->getLocation(), diag::err_param_with_void_type);
1648*67e74705SXin Li     return nullptr;
1649*67e74705SXin Li   }
1650*67e74705SXin Li 
1651*67e74705SXin Li   ParmVarDecl *NewParm = CheckParameter(Context.getTranslationUnitDecl(),
1652*67e74705SXin Li                                         OldParm->getInnerLocStart(),
1653*67e74705SXin Li                                         OldParm->getLocation(),
1654*67e74705SXin Li                                         OldParm->getIdentifier(),
1655*67e74705SXin Li                                         NewDI->getType(), NewDI,
1656*67e74705SXin Li                                         OldParm->getStorageClass());
1657*67e74705SXin Li   if (!NewParm)
1658*67e74705SXin Li     return nullptr;
1659*67e74705SXin Li 
1660*67e74705SXin Li   // Mark the (new) default argument as uninstantiated (if any).
1661*67e74705SXin Li   if (OldParm->hasUninstantiatedDefaultArg()) {
1662*67e74705SXin Li     Expr *Arg = OldParm->getUninstantiatedDefaultArg();
1663*67e74705SXin Li     NewParm->setUninstantiatedDefaultArg(Arg);
1664*67e74705SXin Li   } else if (OldParm->hasUnparsedDefaultArg()) {
1665*67e74705SXin Li     NewParm->setUnparsedDefaultArg();
1666*67e74705SXin Li     UnparsedDefaultArgInstantiations[OldParm].push_back(NewParm);
1667*67e74705SXin Li   } else if (Expr *Arg = OldParm->getDefaultArg()) {
1668*67e74705SXin Li     FunctionDecl *OwningFunc = cast<FunctionDecl>(OldParm->getDeclContext());
1669*67e74705SXin Li     if (OwningFunc->isLexicallyWithinFunctionOrMethod()) {
1670*67e74705SXin Li       // Instantiate default arguments for methods of local classes (DR1484)
1671*67e74705SXin Li       // and non-defining declarations.
1672*67e74705SXin Li       Sema::ContextRAII SavedContext(*this, OwningFunc);
1673*67e74705SXin Li       LocalInstantiationScope Local(*this);
1674*67e74705SXin Li       ExprResult NewArg = SubstExpr(Arg, TemplateArgs);
1675*67e74705SXin Li       if (NewArg.isUsable()) {
1676*67e74705SXin Li         // It would be nice if we still had this.
1677*67e74705SXin Li         SourceLocation EqualLoc = NewArg.get()->getLocStart();
1678*67e74705SXin Li         SetParamDefaultArgument(NewParm, NewArg.get(), EqualLoc);
1679*67e74705SXin Li       }
1680*67e74705SXin Li     } else {
1681*67e74705SXin Li       // FIXME: if we non-lazily instantiated non-dependent default args for
1682*67e74705SXin Li       // non-dependent parameter types we could remove a bunch of duplicate
1683*67e74705SXin Li       // conversion warnings for such arguments.
1684*67e74705SXin Li       NewParm->setUninstantiatedDefaultArg(Arg);
1685*67e74705SXin Li     }
1686*67e74705SXin Li   }
1687*67e74705SXin Li 
1688*67e74705SXin Li   NewParm->setHasInheritedDefaultArg(OldParm->hasInheritedDefaultArg());
1689*67e74705SXin Li 
1690*67e74705SXin Li   if (OldParm->isParameterPack() && !NewParm->isParameterPack()) {
1691*67e74705SXin Li     // Add the new parameter to the instantiated parameter pack.
1692*67e74705SXin Li     CurrentInstantiationScope->InstantiatedLocalPackArg(OldParm, NewParm);
1693*67e74705SXin Li   } else {
1694*67e74705SXin Li     // Introduce an Old -> New mapping
1695*67e74705SXin Li     CurrentInstantiationScope->InstantiatedLocal(OldParm, NewParm);
1696*67e74705SXin Li   }
1697*67e74705SXin Li 
1698*67e74705SXin Li   // FIXME: OldParm may come from a FunctionProtoType, in which case CurContext
1699*67e74705SXin Li   // can be anything, is this right ?
1700*67e74705SXin Li   NewParm->setDeclContext(CurContext);
1701*67e74705SXin Li 
1702*67e74705SXin Li   NewParm->setScopeInfo(OldParm->getFunctionScopeDepth(),
1703*67e74705SXin Li                         OldParm->getFunctionScopeIndex() + indexAdjustment);
1704*67e74705SXin Li 
1705*67e74705SXin Li   InstantiateAttrs(TemplateArgs, OldParm, NewParm);
1706*67e74705SXin Li 
1707*67e74705SXin Li   return NewParm;
1708*67e74705SXin Li }
1709*67e74705SXin Li 
1710*67e74705SXin Li /// \brief Substitute the given template arguments into the given set of
1711*67e74705SXin Li /// parameters, producing the set of parameter types that would be generated
1712*67e74705SXin Li /// from such a substitution.
SubstParmTypes(SourceLocation Loc,ArrayRef<ParmVarDecl * > Params,const FunctionProtoType::ExtParameterInfo * ExtParamInfos,const MultiLevelTemplateArgumentList & TemplateArgs,SmallVectorImpl<QualType> & ParamTypes,SmallVectorImpl<ParmVarDecl * > * OutParams,ExtParameterInfoBuilder & ParamInfos)1713*67e74705SXin Li bool Sema::SubstParmTypes(
1714*67e74705SXin Li     SourceLocation Loc, ArrayRef<ParmVarDecl *> Params,
1715*67e74705SXin Li     const FunctionProtoType::ExtParameterInfo *ExtParamInfos,
1716*67e74705SXin Li     const MultiLevelTemplateArgumentList &TemplateArgs,
1717*67e74705SXin Li     SmallVectorImpl<QualType> &ParamTypes,
1718*67e74705SXin Li     SmallVectorImpl<ParmVarDecl *> *OutParams,
1719*67e74705SXin Li     ExtParameterInfoBuilder &ParamInfos) {
1720*67e74705SXin Li   assert(!ActiveTemplateInstantiations.empty() &&
1721*67e74705SXin Li          "Cannot perform an instantiation without some context on the "
1722*67e74705SXin Li          "instantiation stack");
1723*67e74705SXin Li 
1724*67e74705SXin Li   TemplateInstantiator Instantiator(*this, TemplateArgs, Loc,
1725*67e74705SXin Li                                     DeclarationName());
1726*67e74705SXin Li   return Instantiator.TransformFunctionTypeParams(
1727*67e74705SXin Li       Loc, Params, nullptr, ExtParamInfos, ParamTypes, OutParams, ParamInfos);
1728*67e74705SXin Li }
1729*67e74705SXin Li 
1730*67e74705SXin Li /// \brief Perform substitution on the base class specifiers of the
1731*67e74705SXin Li /// given class template specialization.
1732*67e74705SXin Li ///
1733*67e74705SXin Li /// Produces a diagnostic and returns true on error, returns false and
1734*67e74705SXin Li /// attaches the instantiated base classes to the class template
1735*67e74705SXin Li /// specialization if successful.
1736*67e74705SXin Li bool
SubstBaseSpecifiers(CXXRecordDecl * Instantiation,CXXRecordDecl * Pattern,const MultiLevelTemplateArgumentList & TemplateArgs)1737*67e74705SXin Li Sema::SubstBaseSpecifiers(CXXRecordDecl *Instantiation,
1738*67e74705SXin Li                           CXXRecordDecl *Pattern,
1739*67e74705SXin Li                           const MultiLevelTemplateArgumentList &TemplateArgs) {
1740*67e74705SXin Li   bool Invalid = false;
1741*67e74705SXin Li   SmallVector<CXXBaseSpecifier*, 4> InstantiatedBases;
1742*67e74705SXin Li   for (const auto &Base : Pattern->bases()) {
1743*67e74705SXin Li     if (!Base.getType()->isDependentType()) {
1744*67e74705SXin Li       if (const CXXRecordDecl *RD = Base.getType()->getAsCXXRecordDecl()) {
1745*67e74705SXin Li         if (RD->isInvalidDecl())
1746*67e74705SXin Li           Instantiation->setInvalidDecl();
1747*67e74705SXin Li       }
1748*67e74705SXin Li       InstantiatedBases.push_back(new (Context) CXXBaseSpecifier(Base));
1749*67e74705SXin Li       continue;
1750*67e74705SXin Li     }
1751*67e74705SXin Li 
1752*67e74705SXin Li     SourceLocation EllipsisLoc;
1753*67e74705SXin Li     TypeSourceInfo *BaseTypeLoc;
1754*67e74705SXin Li     if (Base.isPackExpansion()) {
1755*67e74705SXin Li       // This is a pack expansion. See whether we should expand it now, or
1756*67e74705SXin Li       // wait until later.
1757*67e74705SXin Li       SmallVector<UnexpandedParameterPack, 2> Unexpanded;
1758*67e74705SXin Li       collectUnexpandedParameterPacks(Base.getTypeSourceInfo()->getTypeLoc(),
1759*67e74705SXin Li                                       Unexpanded);
1760*67e74705SXin Li       bool ShouldExpand = false;
1761*67e74705SXin Li       bool RetainExpansion = false;
1762*67e74705SXin Li       Optional<unsigned> NumExpansions;
1763*67e74705SXin Li       if (CheckParameterPacksForExpansion(Base.getEllipsisLoc(),
1764*67e74705SXin Li                                           Base.getSourceRange(),
1765*67e74705SXin Li                                           Unexpanded,
1766*67e74705SXin Li                                           TemplateArgs, ShouldExpand,
1767*67e74705SXin Li                                           RetainExpansion,
1768*67e74705SXin Li                                           NumExpansions)) {
1769*67e74705SXin Li         Invalid = true;
1770*67e74705SXin Li         continue;
1771*67e74705SXin Li       }
1772*67e74705SXin Li 
1773*67e74705SXin Li       // If we should expand this pack expansion now, do so.
1774*67e74705SXin Li       if (ShouldExpand) {
1775*67e74705SXin Li         for (unsigned I = 0; I != *NumExpansions; ++I) {
1776*67e74705SXin Li             Sema::ArgumentPackSubstitutionIndexRAII SubstIndex(*this, I);
1777*67e74705SXin Li 
1778*67e74705SXin Li           TypeSourceInfo *BaseTypeLoc = SubstType(Base.getTypeSourceInfo(),
1779*67e74705SXin Li                                                   TemplateArgs,
1780*67e74705SXin Li                                               Base.getSourceRange().getBegin(),
1781*67e74705SXin Li                                                   DeclarationName());
1782*67e74705SXin Li           if (!BaseTypeLoc) {
1783*67e74705SXin Li             Invalid = true;
1784*67e74705SXin Li             continue;
1785*67e74705SXin Li           }
1786*67e74705SXin Li 
1787*67e74705SXin Li           if (CXXBaseSpecifier *InstantiatedBase
1788*67e74705SXin Li                 = CheckBaseSpecifier(Instantiation,
1789*67e74705SXin Li                                      Base.getSourceRange(),
1790*67e74705SXin Li                                      Base.isVirtual(),
1791*67e74705SXin Li                                      Base.getAccessSpecifierAsWritten(),
1792*67e74705SXin Li                                      BaseTypeLoc,
1793*67e74705SXin Li                                      SourceLocation()))
1794*67e74705SXin Li             InstantiatedBases.push_back(InstantiatedBase);
1795*67e74705SXin Li           else
1796*67e74705SXin Li             Invalid = true;
1797*67e74705SXin Li         }
1798*67e74705SXin Li 
1799*67e74705SXin Li         continue;
1800*67e74705SXin Li       }
1801*67e74705SXin Li 
1802*67e74705SXin Li       // The resulting base specifier will (still) be a pack expansion.
1803*67e74705SXin Li       EllipsisLoc = Base.getEllipsisLoc();
1804*67e74705SXin Li       Sema::ArgumentPackSubstitutionIndexRAII SubstIndex(*this, -1);
1805*67e74705SXin Li       BaseTypeLoc = SubstType(Base.getTypeSourceInfo(),
1806*67e74705SXin Li                               TemplateArgs,
1807*67e74705SXin Li                               Base.getSourceRange().getBegin(),
1808*67e74705SXin Li                               DeclarationName());
1809*67e74705SXin Li     } else {
1810*67e74705SXin Li       BaseTypeLoc = SubstType(Base.getTypeSourceInfo(),
1811*67e74705SXin Li                               TemplateArgs,
1812*67e74705SXin Li                               Base.getSourceRange().getBegin(),
1813*67e74705SXin Li                               DeclarationName());
1814*67e74705SXin Li     }
1815*67e74705SXin Li 
1816*67e74705SXin Li     if (!BaseTypeLoc) {
1817*67e74705SXin Li       Invalid = true;
1818*67e74705SXin Li       continue;
1819*67e74705SXin Li     }
1820*67e74705SXin Li 
1821*67e74705SXin Li     if (CXXBaseSpecifier *InstantiatedBase
1822*67e74705SXin Li           = CheckBaseSpecifier(Instantiation,
1823*67e74705SXin Li                                Base.getSourceRange(),
1824*67e74705SXin Li                                Base.isVirtual(),
1825*67e74705SXin Li                                Base.getAccessSpecifierAsWritten(),
1826*67e74705SXin Li                                BaseTypeLoc,
1827*67e74705SXin Li                                EllipsisLoc))
1828*67e74705SXin Li       InstantiatedBases.push_back(InstantiatedBase);
1829*67e74705SXin Li     else
1830*67e74705SXin Li       Invalid = true;
1831*67e74705SXin Li   }
1832*67e74705SXin Li 
1833*67e74705SXin Li   if (!Invalid && AttachBaseSpecifiers(Instantiation, InstantiatedBases))
1834*67e74705SXin Li     Invalid = true;
1835*67e74705SXin Li 
1836*67e74705SXin Li   return Invalid;
1837*67e74705SXin Li }
1838*67e74705SXin Li 
1839*67e74705SXin Li // Defined via #include from SemaTemplateInstantiateDecl.cpp
1840*67e74705SXin Li namespace clang {
1841*67e74705SXin Li   namespace sema {
1842*67e74705SXin Li     Attr *instantiateTemplateAttribute(const Attr *At, ASTContext &C, Sema &S,
1843*67e74705SXin Li                             const MultiLevelTemplateArgumentList &TemplateArgs);
1844*67e74705SXin Li   }
1845*67e74705SXin Li }
1846*67e74705SXin Li 
1847*67e74705SXin Li /// Determine whether we would be unable to instantiate this template (because
1848*67e74705SXin Li /// it either has no definition, or is in the process of being instantiated).
DiagnoseUninstantiableTemplate(Sema & S,SourceLocation PointOfInstantiation,TagDecl * Instantiation,bool InstantiatedFromMember,TagDecl * Pattern,TagDecl * PatternDef,TemplateSpecializationKind TSK,bool Complain=true)1849*67e74705SXin Li static bool DiagnoseUninstantiableTemplate(Sema &S,
1850*67e74705SXin Li                                            SourceLocation PointOfInstantiation,
1851*67e74705SXin Li                                            TagDecl *Instantiation,
1852*67e74705SXin Li                                            bool InstantiatedFromMember,
1853*67e74705SXin Li                                            TagDecl *Pattern,
1854*67e74705SXin Li                                            TagDecl *PatternDef,
1855*67e74705SXin Li                                            TemplateSpecializationKind TSK,
1856*67e74705SXin Li                                            bool Complain = true) {
1857*67e74705SXin Li   if (PatternDef && !PatternDef->isBeingDefined()) {
1858*67e74705SXin Li     NamedDecl *SuggestedDef = nullptr;
1859*67e74705SXin Li     if (!S.hasVisibleDefinition(PatternDef, &SuggestedDef,
1860*67e74705SXin Li                                 /*OnlyNeedComplete*/false)) {
1861*67e74705SXin Li       // If we're allowed to diagnose this and recover, do so.
1862*67e74705SXin Li       bool Recover = Complain && !S.isSFINAEContext();
1863*67e74705SXin Li       if (Complain)
1864*67e74705SXin Li         S.diagnoseMissingImport(PointOfInstantiation, SuggestedDef,
1865*67e74705SXin Li                                 Sema::MissingImportKind::Definition, Recover);
1866*67e74705SXin Li       return !Recover;
1867*67e74705SXin Li     }
1868*67e74705SXin Li     return false;
1869*67e74705SXin Li   }
1870*67e74705SXin Li 
1871*67e74705SXin Li   if (!Complain || (PatternDef && PatternDef->isInvalidDecl())) {
1872*67e74705SXin Li     // Say nothing
1873*67e74705SXin Li   } else if (PatternDef) {
1874*67e74705SXin Li     assert(PatternDef->isBeingDefined());
1875*67e74705SXin Li     S.Diag(PointOfInstantiation,
1876*67e74705SXin Li            diag::err_template_instantiate_within_definition)
1877*67e74705SXin Li       << (TSK != TSK_ImplicitInstantiation)
1878*67e74705SXin Li       << S.Context.getTypeDeclType(Instantiation);
1879*67e74705SXin Li     // Not much point in noting the template declaration here, since
1880*67e74705SXin Li     // we're lexically inside it.
1881*67e74705SXin Li     Instantiation->setInvalidDecl();
1882*67e74705SXin Li   } else if (InstantiatedFromMember) {
1883*67e74705SXin Li     S.Diag(PointOfInstantiation,
1884*67e74705SXin Li            diag::err_implicit_instantiate_member_undefined)
1885*67e74705SXin Li       << S.Context.getTypeDeclType(Instantiation);
1886*67e74705SXin Li     S.Diag(Pattern->getLocation(), diag::note_member_declared_at);
1887*67e74705SXin Li   } else {
1888*67e74705SXin Li     S.Diag(PointOfInstantiation, diag::err_template_instantiate_undefined)
1889*67e74705SXin Li       << (TSK != TSK_ImplicitInstantiation)
1890*67e74705SXin Li       << S.Context.getTypeDeclType(Instantiation);
1891*67e74705SXin Li     S.Diag(Pattern->getLocation(), diag::note_template_decl_here);
1892*67e74705SXin Li   }
1893*67e74705SXin Li 
1894*67e74705SXin Li   // In general, Instantiation isn't marked invalid to get more than one
1895*67e74705SXin Li   // error for multiple undefined instantiations. But the code that does
1896*67e74705SXin Li   // explicit declaration -> explicit definition conversion can't handle
1897*67e74705SXin Li   // invalid declarations, so mark as invalid in that case.
1898*67e74705SXin Li   if (TSK == TSK_ExplicitInstantiationDeclaration)
1899*67e74705SXin Li     Instantiation->setInvalidDecl();
1900*67e74705SXin Li   return true;
1901*67e74705SXin Li }
1902*67e74705SXin Li 
1903*67e74705SXin Li /// \brief Instantiate the definition of a class from a given pattern.
1904*67e74705SXin Li ///
1905*67e74705SXin Li /// \param PointOfInstantiation The point of instantiation within the
1906*67e74705SXin Li /// source code.
1907*67e74705SXin Li ///
1908*67e74705SXin Li /// \param Instantiation is the declaration whose definition is being
1909*67e74705SXin Li /// instantiated. This will be either a class template specialization
1910*67e74705SXin Li /// or a member class of a class template specialization.
1911*67e74705SXin Li ///
1912*67e74705SXin Li /// \param Pattern is the pattern from which the instantiation
1913*67e74705SXin Li /// occurs. This will be either the declaration of a class template or
1914*67e74705SXin Li /// the declaration of a member class of a class template.
1915*67e74705SXin Li ///
1916*67e74705SXin Li /// \param TemplateArgs The template arguments to be substituted into
1917*67e74705SXin Li /// the pattern.
1918*67e74705SXin Li ///
1919*67e74705SXin Li /// \param TSK the kind of implicit or explicit instantiation to perform.
1920*67e74705SXin Li ///
1921*67e74705SXin Li /// \param Complain whether to complain if the class cannot be instantiated due
1922*67e74705SXin Li /// to the lack of a definition.
1923*67e74705SXin Li ///
1924*67e74705SXin Li /// \returns true if an error occurred, false otherwise.
1925*67e74705SXin Li bool
InstantiateClass(SourceLocation PointOfInstantiation,CXXRecordDecl * Instantiation,CXXRecordDecl * Pattern,const MultiLevelTemplateArgumentList & TemplateArgs,TemplateSpecializationKind TSK,bool Complain)1926*67e74705SXin Li Sema::InstantiateClass(SourceLocation PointOfInstantiation,
1927*67e74705SXin Li                        CXXRecordDecl *Instantiation, CXXRecordDecl *Pattern,
1928*67e74705SXin Li                        const MultiLevelTemplateArgumentList &TemplateArgs,
1929*67e74705SXin Li                        TemplateSpecializationKind TSK,
1930*67e74705SXin Li                        bool Complain) {
1931*67e74705SXin Li   CXXRecordDecl *PatternDef
1932*67e74705SXin Li     = cast_or_null<CXXRecordDecl>(Pattern->getDefinition());
1933*67e74705SXin Li   if (DiagnoseUninstantiableTemplate(*this, PointOfInstantiation, Instantiation,
1934*67e74705SXin Li                                 Instantiation->getInstantiatedFromMemberClass(),
1935*67e74705SXin Li                                      Pattern, PatternDef, TSK, Complain))
1936*67e74705SXin Li     return true;
1937*67e74705SXin Li   Pattern = PatternDef;
1938*67e74705SXin Li 
1939*67e74705SXin Li   // \brief Record the point of instantiation.
1940*67e74705SXin Li   if (MemberSpecializationInfo *MSInfo
1941*67e74705SXin Li         = Instantiation->getMemberSpecializationInfo()) {
1942*67e74705SXin Li     MSInfo->setTemplateSpecializationKind(TSK);
1943*67e74705SXin Li     MSInfo->setPointOfInstantiation(PointOfInstantiation);
1944*67e74705SXin Li   } else if (ClassTemplateSpecializationDecl *Spec
1945*67e74705SXin Li         = dyn_cast<ClassTemplateSpecializationDecl>(Instantiation)) {
1946*67e74705SXin Li     Spec->setTemplateSpecializationKind(TSK);
1947*67e74705SXin Li     Spec->setPointOfInstantiation(PointOfInstantiation);
1948*67e74705SXin Li   }
1949*67e74705SXin Li 
1950*67e74705SXin Li   InstantiatingTemplate Inst(*this, PointOfInstantiation, Instantiation);
1951*67e74705SXin Li   if (Inst.isInvalid())
1952*67e74705SXin Li     return true;
1953*67e74705SXin Li   PrettyDeclStackTraceEntry CrashInfo(*this, Instantiation, SourceLocation(),
1954*67e74705SXin Li                                       "instantiating class definition");
1955*67e74705SXin Li 
1956*67e74705SXin Li   // Enter the scope of this instantiation. We don't use
1957*67e74705SXin Li   // PushDeclContext because we don't have a scope.
1958*67e74705SXin Li   ContextRAII SavedContext(*this, Instantiation);
1959*67e74705SXin Li   EnterExpressionEvaluationContext EvalContext(*this,
1960*67e74705SXin Li                                                Sema::PotentiallyEvaluated);
1961*67e74705SXin Li 
1962*67e74705SXin Li   // If this is an instantiation of a local class, merge this local
1963*67e74705SXin Li   // instantiation scope with the enclosing scope. Otherwise, every
1964*67e74705SXin Li   // instantiation of a class has its own local instantiation scope.
1965*67e74705SXin Li   bool MergeWithParentScope = !Instantiation->isDefinedOutsideFunctionOrMethod();
1966*67e74705SXin Li   LocalInstantiationScope Scope(*this, MergeWithParentScope);
1967*67e74705SXin Li 
1968*67e74705SXin Li   // All dllexported classes created during instantiation should be fully
1969*67e74705SXin Li   // emitted after instantiation completes. We may not be ready to emit any
1970*67e74705SXin Li   // delayed classes already on the stack, so save them away and put them back
1971*67e74705SXin Li   // later.
1972*67e74705SXin Li   decltype(DelayedDllExportClasses) ExportedClasses;
1973*67e74705SXin Li   std::swap(ExportedClasses, DelayedDllExportClasses);
1974*67e74705SXin Li 
1975*67e74705SXin Li   // Pull attributes from the pattern onto the instantiation.
1976*67e74705SXin Li   InstantiateAttrs(TemplateArgs, Pattern, Instantiation);
1977*67e74705SXin Li 
1978*67e74705SXin Li   // Start the definition of this instantiation.
1979*67e74705SXin Li   Instantiation->startDefinition();
1980*67e74705SXin Li 
1981*67e74705SXin Li   // The instantiation is visible here, even if it was first declared in an
1982*67e74705SXin Li   // unimported module.
1983*67e74705SXin Li   Instantiation->setHidden(false);
1984*67e74705SXin Li 
1985*67e74705SXin Li   // FIXME: This loses the as-written tag kind for an explicit instantiation.
1986*67e74705SXin Li   Instantiation->setTagKind(Pattern->getTagKind());
1987*67e74705SXin Li 
1988*67e74705SXin Li   // Do substitution on the base class specifiers.
1989*67e74705SXin Li   if (SubstBaseSpecifiers(Instantiation, Pattern, TemplateArgs))
1990*67e74705SXin Li     Instantiation->setInvalidDecl();
1991*67e74705SXin Li 
1992*67e74705SXin Li   TemplateDeclInstantiator Instantiator(*this, Instantiation, TemplateArgs);
1993*67e74705SXin Li   SmallVector<Decl*, 4> Fields;
1994*67e74705SXin Li   // Delay instantiation of late parsed attributes.
1995*67e74705SXin Li   LateInstantiatedAttrVec LateAttrs;
1996*67e74705SXin Li   Instantiator.enableLateAttributeInstantiation(&LateAttrs);
1997*67e74705SXin Li 
1998*67e74705SXin Li   for (auto *Member : Pattern->decls()) {
1999*67e74705SXin Li     // Don't instantiate members not belonging in this semantic context.
2000*67e74705SXin Li     // e.g. for:
2001*67e74705SXin Li     // @code
2002*67e74705SXin Li     //    template <int i> class A {
2003*67e74705SXin Li     //      class B *g;
2004*67e74705SXin Li     //    };
2005*67e74705SXin Li     // @endcode
2006*67e74705SXin Li     // 'class B' has the template as lexical context but semantically it is
2007*67e74705SXin Li     // introduced in namespace scope.
2008*67e74705SXin Li     if (Member->getDeclContext() != Pattern)
2009*67e74705SXin Li       continue;
2010*67e74705SXin Li 
2011*67e74705SXin Li     if (Member->isInvalidDecl()) {
2012*67e74705SXin Li       Instantiation->setInvalidDecl();
2013*67e74705SXin Li       continue;
2014*67e74705SXin Li     }
2015*67e74705SXin Li 
2016*67e74705SXin Li     Decl *NewMember = Instantiator.Visit(Member);
2017*67e74705SXin Li     if (NewMember) {
2018*67e74705SXin Li       if (FieldDecl *Field = dyn_cast<FieldDecl>(NewMember)) {
2019*67e74705SXin Li         Fields.push_back(Field);
2020*67e74705SXin Li       } else if (EnumDecl *Enum = dyn_cast<EnumDecl>(NewMember)) {
2021*67e74705SXin Li         // C++11 [temp.inst]p1: The implicit instantiation of a class template
2022*67e74705SXin Li         // specialization causes the implicit instantiation of the definitions
2023*67e74705SXin Li         // of unscoped member enumerations.
2024*67e74705SXin Li         // Record a point of instantiation for this implicit instantiation.
2025*67e74705SXin Li         if (TSK == TSK_ImplicitInstantiation && !Enum->isScoped() &&
2026*67e74705SXin Li             Enum->isCompleteDefinition()) {
2027*67e74705SXin Li           MemberSpecializationInfo *MSInfo =Enum->getMemberSpecializationInfo();
2028*67e74705SXin Li           assert(MSInfo && "no spec info for member enum specialization");
2029*67e74705SXin Li           MSInfo->setTemplateSpecializationKind(TSK_ImplicitInstantiation);
2030*67e74705SXin Li           MSInfo->setPointOfInstantiation(PointOfInstantiation);
2031*67e74705SXin Li         }
2032*67e74705SXin Li       } else if (StaticAssertDecl *SA = dyn_cast<StaticAssertDecl>(NewMember)) {
2033*67e74705SXin Li         if (SA->isFailed()) {
2034*67e74705SXin Li           // A static_assert failed. Bail out; instantiating this
2035*67e74705SXin Li           // class is probably not meaningful.
2036*67e74705SXin Li           Instantiation->setInvalidDecl();
2037*67e74705SXin Li           break;
2038*67e74705SXin Li         }
2039*67e74705SXin Li       }
2040*67e74705SXin Li 
2041*67e74705SXin Li       if (NewMember->isInvalidDecl())
2042*67e74705SXin Li         Instantiation->setInvalidDecl();
2043*67e74705SXin Li     } else {
2044*67e74705SXin Li       // FIXME: Eventually, a NULL return will mean that one of the
2045*67e74705SXin Li       // instantiations was a semantic disaster, and we'll want to mark the
2046*67e74705SXin Li       // declaration invalid.
2047*67e74705SXin Li       // For now, we expect to skip some members that we can't yet handle.
2048*67e74705SXin Li     }
2049*67e74705SXin Li   }
2050*67e74705SXin Li 
2051*67e74705SXin Li   // Finish checking fields.
2052*67e74705SXin Li   ActOnFields(nullptr, Instantiation->getLocation(), Instantiation, Fields,
2053*67e74705SXin Li               SourceLocation(), SourceLocation(), nullptr);
2054*67e74705SXin Li   CheckCompletedCXXClass(Instantiation);
2055*67e74705SXin Li 
2056*67e74705SXin Li   // Default arguments are parsed, if not instantiated. We can go instantiate
2057*67e74705SXin Li   // default arg exprs for default constructors if necessary now.
2058*67e74705SXin Li   ActOnFinishCXXNonNestedClass(Instantiation);
2059*67e74705SXin Li 
2060*67e74705SXin Li   // Put back the delayed exported classes that we moved out of the way.
2061*67e74705SXin Li   std::swap(ExportedClasses, DelayedDllExportClasses);
2062*67e74705SXin Li 
2063*67e74705SXin Li   // Instantiate late parsed attributes, and attach them to their decls.
2064*67e74705SXin Li   // See Sema::InstantiateAttrs
2065*67e74705SXin Li   for (LateInstantiatedAttrVec::iterator I = LateAttrs.begin(),
2066*67e74705SXin Li        E = LateAttrs.end(); I != E; ++I) {
2067*67e74705SXin Li     assert(CurrentInstantiationScope == Instantiator.getStartingScope());
2068*67e74705SXin Li     CurrentInstantiationScope = I->Scope;
2069*67e74705SXin Li 
2070*67e74705SXin Li     // Allow 'this' within late-parsed attributes.
2071*67e74705SXin Li     NamedDecl *ND = dyn_cast<NamedDecl>(I->NewDecl);
2072*67e74705SXin Li     CXXRecordDecl *ThisContext =
2073*67e74705SXin Li         dyn_cast_or_null<CXXRecordDecl>(ND->getDeclContext());
2074*67e74705SXin Li     CXXThisScopeRAII ThisScope(*this, ThisContext, /*TypeQuals*/0,
2075*67e74705SXin Li                                ND && ND->isCXXInstanceMember());
2076*67e74705SXin Li 
2077*67e74705SXin Li     Attr *NewAttr =
2078*67e74705SXin Li       instantiateTemplateAttribute(I->TmplAttr, Context, *this, TemplateArgs);
2079*67e74705SXin Li     I->NewDecl->addAttr(NewAttr);
2080*67e74705SXin Li     LocalInstantiationScope::deleteScopes(I->Scope,
2081*67e74705SXin Li                                           Instantiator.getStartingScope());
2082*67e74705SXin Li   }
2083*67e74705SXin Li   Instantiator.disableLateAttributeInstantiation();
2084*67e74705SXin Li   LateAttrs.clear();
2085*67e74705SXin Li 
2086*67e74705SXin Li   ActOnFinishDelayedMemberInitializers(Instantiation);
2087*67e74705SXin Li 
2088*67e74705SXin Li   // FIXME: We should do something similar for explicit instantiations so they
2089*67e74705SXin Li   // end up in the right module.
2090*67e74705SXin Li   if (TSK == TSK_ImplicitInstantiation) {
2091*67e74705SXin Li     Instantiation->setLocation(Pattern->getLocation());
2092*67e74705SXin Li     Instantiation->setLocStart(Pattern->getInnerLocStart());
2093*67e74705SXin Li     Instantiation->setRBraceLoc(Pattern->getRBraceLoc());
2094*67e74705SXin Li   }
2095*67e74705SXin Li 
2096*67e74705SXin Li   if (!Instantiation->isInvalidDecl()) {
2097*67e74705SXin Li     // Perform any dependent diagnostics from the pattern.
2098*67e74705SXin Li     PerformDependentDiagnostics(Pattern, TemplateArgs);
2099*67e74705SXin Li 
2100*67e74705SXin Li     // Instantiate any out-of-line class template partial
2101*67e74705SXin Li     // specializations now.
2102*67e74705SXin Li     for (TemplateDeclInstantiator::delayed_partial_spec_iterator
2103*67e74705SXin Li               P = Instantiator.delayed_partial_spec_begin(),
2104*67e74705SXin Li            PEnd = Instantiator.delayed_partial_spec_end();
2105*67e74705SXin Li          P != PEnd; ++P) {
2106*67e74705SXin Li       if (!Instantiator.InstantiateClassTemplatePartialSpecialization(
2107*67e74705SXin Li               P->first, P->second)) {
2108*67e74705SXin Li         Instantiation->setInvalidDecl();
2109*67e74705SXin Li         break;
2110*67e74705SXin Li       }
2111*67e74705SXin Li     }
2112*67e74705SXin Li 
2113*67e74705SXin Li     // Instantiate any out-of-line variable template partial
2114*67e74705SXin Li     // specializations now.
2115*67e74705SXin Li     for (TemplateDeclInstantiator::delayed_var_partial_spec_iterator
2116*67e74705SXin Li               P = Instantiator.delayed_var_partial_spec_begin(),
2117*67e74705SXin Li            PEnd = Instantiator.delayed_var_partial_spec_end();
2118*67e74705SXin Li          P != PEnd; ++P) {
2119*67e74705SXin Li       if (!Instantiator.InstantiateVarTemplatePartialSpecialization(
2120*67e74705SXin Li               P->first, P->second)) {
2121*67e74705SXin Li         Instantiation->setInvalidDecl();
2122*67e74705SXin Li         break;
2123*67e74705SXin Li       }
2124*67e74705SXin Li     }
2125*67e74705SXin Li   }
2126*67e74705SXin Li 
2127*67e74705SXin Li   // Exit the scope of this instantiation.
2128*67e74705SXin Li   SavedContext.pop();
2129*67e74705SXin Li 
2130*67e74705SXin Li   if (!Instantiation->isInvalidDecl()) {
2131*67e74705SXin Li     Consumer.HandleTagDeclDefinition(Instantiation);
2132*67e74705SXin Li 
2133*67e74705SXin Li     // Always emit the vtable for an explicit instantiation definition
2134*67e74705SXin Li     // of a polymorphic class template specialization.
2135*67e74705SXin Li     if (TSK == TSK_ExplicitInstantiationDefinition)
2136*67e74705SXin Li       MarkVTableUsed(PointOfInstantiation, Instantiation, true);
2137*67e74705SXin Li   }
2138*67e74705SXin Li 
2139*67e74705SXin Li   return Instantiation->isInvalidDecl();
2140*67e74705SXin Li }
2141*67e74705SXin Li 
2142*67e74705SXin Li /// \brief Instantiate the definition of an enum from a given pattern.
2143*67e74705SXin Li ///
2144*67e74705SXin Li /// \param PointOfInstantiation The point of instantiation within the
2145*67e74705SXin Li ///        source code.
2146*67e74705SXin Li /// \param Instantiation is the declaration whose definition is being
2147*67e74705SXin Li ///        instantiated. This will be a member enumeration of a class
2148*67e74705SXin Li ///        temploid specialization, or a local enumeration within a
2149*67e74705SXin Li ///        function temploid specialization.
2150*67e74705SXin Li /// \param Pattern The templated declaration from which the instantiation
2151*67e74705SXin Li ///        occurs.
2152*67e74705SXin Li /// \param TemplateArgs The template arguments to be substituted into
2153*67e74705SXin Li ///        the pattern.
2154*67e74705SXin Li /// \param TSK The kind of implicit or explicit instantiation to perform.
2155*67e74705SXin Li ///
2156*67e74705SXin Li /// \return \c true if an error occurred, \c false otherwise.
InstantiateEnum(SourceLocation PointOfInstantiation,EnumDecl * Instantiation,EnumDecl * Pattern,const MultiLevelTemplateArgumentList & TemplateArgs,TemplateSpecializationKind TSK)2157*67e74705SXin Li bool Sema::InstantiateEnum(SourceLocation PointOfInstantiation,
2158*67e74705SXin Li                            EnumDecl *Instantiation, EnumDecl *Pattern,
2159*67e74705SXin Li                            const MultiLevelTemplateArgumentList &TemplateArgs,
2160*67e74705SXin Li                            TemplateSpecializationKind TSK) {
2161*67e74705SXin Li   EnumDecl *PatternDef = Pattern->getDefinition();
2162*67e74705SXin Li   if (DiagnoseUninstantiableTemplate(*this, PointOfInstantiation, Instantiation,
2163*67e74705SXin Li                                  Instantiation->getInstantiatedFromMemberEnum(),
2164*67e74705SXin Li                                      Pattern, PatternDef, TSK,/*Complain*/true))
2165*67e74705SXin Li     return true;
2166*67e74705SXin Li   Pattern = PatternDef;
2167*67e74705SXin Li 
2168*67e74705SXin Li   // Record the point of instantiation.
2169*67e74705SXin Li   if (MemberSpecializationInfo *MSInfo
2170*67e74705SXin Li         = Instantiation->getMemberSpecializationInfo()) {
2171*67e74705SXin Li     MSInfo->setTemplateSpecializationKind(TSK);
2172*67e74705SXin Li     MSInfo->setPointOfInstantiation(PointOfInstantiation);
2173*67e74705SXin Li   }
2174*67e74705SXin Li 
2175*67e74705SXin Li   InstantiatingTemplate Inst(*this, PointOfInstantiation, Instantiation);
2176*67e74705SXin Li   if (Inst.isInvalid())
2177*67e74705SXin Li     return true;
2178*67e74705SXin Li   PrettyDeclStackTraceEntry CrashInfo(*this, Instantiation, SourceLocation(),
2179*67e74705SXin Li                                       "instantiating enum definition");
2180*67e74705SXin Li 
2181*67e74705SXin Li   // The instantiation is visible here, even if it was first declared in an
2182*67e74705SXin Li   // unimported module.
2183*67e74705SXin Li   Instantiation->setHidden(false);
2184*67e74705SXin Li 
2185*67e74705SXin Li   // Enter the scope of this instantiation. We don't use
2186*67e74705SXin Li   // PushDeclContext because we don't have a scope.
2187*67e74705SXin Li   ContextRAII SavedContext(*this, Instantiation);
2188*67e74705SXin Li   EnterExpressionEvaluationContext EvalContext(*this,
2189*67e74705SXin Li                                                Sema::PotentiallyEvaluated);
2190*67e74705SXin Li 
2191*67e74705SXin Li   LocalInstantiationScope Scope(*this, /*MergeWithParentScope*/true);
2192*67e74705SXin Li 
2193*67e74705SXin Li   // Pull attributes from the pattern onto the instantiation.
2194*67e74705SXin Li   InstantiateAttrs(TemplateArgs, Pattern, Instantiation);
2195*67e74705SXin Li 
2196*67e74705SXin Li   TemplateDeclInstantiator Instantiator(*this, Instantiation, TemplateArgs);
2197*67e74705SXin Li   Instantiator.InstantiateEnumDefinition(Instantiation, Pattern);
2198*67e74705SXin Li 
2199*67e74705SXin Li   // Exit the scope of this instantiation.
2200*67e74705SXin Li   SavedContext.pop();
2201*67e74705SXin Li 
2202*67e74705SXin Li   return Instantiation->isInvalidDecl();
2203*67e74705SXin Li }
2204*67e74705SXin Li 
2205*67e74705SXin Li 
2206*67e74705SXin Li /// \brief Instantiate the definition of a field from the given pattern.
2207*67e74705SXin Li ///
2208*67e74705SXin Li /// \param PointOfInstantiation The point of instantiation within the
2209*67e74705SXin Li ///        source code.
2210*67e74705SXin Li /// \param Instantiation is the declaration whose definition is being
2211*67e74705SXin Li ///        instantiated. This will be a class of a class temploid
2212*67e74705SXin Li ///        specialization, or a local enumeration within a function temploid
2213*67e74705SXin Li ///        specialization.
2214*67e74705SXin Li /// \param Pattern The templated declaration from which the instantiation
2215*67e74705SXin Li ///        occurs.
2216*67e74705SXin Li /// \param TemplateArgs The template arguments to be substituted into
2217*67e74705SXin Li ///        the pattern.
2218*67e74705SXin Li ///
2219*67e74705SXin Li /// \return \c true if an error occurred, \c false otherwise.
InstantiateInClassInitializer(SourceLocation PointOfInstantiation,FieldDecl * Instantiation,FieldDecl * Pattern,const MultiLevelTemplateArgumentList & TemplateArgs)2220*67e74705SXin Li bool Sema::InstantiateInClassInitializer(
2221*67e74705SXin Li     SourceLocation PointOfInstantiation, FieldDecl *Instantiation,
2222*67e74705SXin Li     FieldDecl *Pattern, const MultiLevelTemplateArgumentList &TemplateArgs) {
2223*67e74705SXin Li   // If there is no initializer, we don't need to do anything.
2224*67e74705SXin Li   if (!Pattern->hasInClassInitializer())
2225*67e74705SXin Li     return false;
2226*67e74705SXin Li 
2227*67e74705SXin Li   assert(Instantiation->getInClassInitStyle() ==
2228*67e74705SXin Li              Pattern->getInClassInitStyle() &&
2229*67e74705SXin Li          "pattern and instantiation disagree about init style");
2230*67e74705SXin Li 
2231*67e74705SXin Li   // Error out if we haven't parsed the initializer of the pattern yet because
2232*67e74705SXin Li   // we are waiting for the closing brace of the outer class.
2233*67e74705SXin Li   Expr *OldInit = Pattern->getInClassInitializer();
2234*67e74705SXin Li   if (!OldInit) {
2235*67e74705SXin Li     RecordDecl *PatternRD = Pattern->getParent();
2236*67e74705SXin Li     RecordDecl *OutermostClass = PatternRD->getOuterLexicalRecordContext();
2237*67e74705SXin Li     if (OutermostClass == PatternRD) {
2238*67e74705SXin Li       Diag(Pattern->getLocEnd(), diag::err_in_class_initializer_not_yet_parsed)
2239*67e74705SXin Li           << PatternRD << Pattern;
2240*67e74705SXin Li     } else {
2241*67e74705SXin Li       Diag(Pattern->getLocEnd(),
2242*67e74705SXin Li            diag::err_in_class_initializer_not_yet_parsed_outer_class)
2243*67e74705SXin Li           << PatternRD << OutermostClass << Pattern;
2244*67e74705SXin Li     }
2245*67e74705SXin Li     Instantiation->setInvalidDecl();
2246*67e74705SXin Li     return true;
2247*67e74705SXin Li   }
2248*67e74705SXin Li 
2249*67e74705SXin Li   InstantiatingTemplate Inst(*this, PointOfInstantiation, Instantiation);
2250*67e74705SXin Li   if (Inst.isInvalid())
2251*67e74705SXin Li     return true;
2252*67e74705SXin Li   PrettyDeclStackTraceEntry CrashInfo(*this, Instantiation, SourceLocation(),
2253*67e74705SXin Li                                       "instantiating default member init");
2254*67e74705SXin Li 
2255*67e74705SXin Li   // Enter the scope of this instantiation. We don't use PushDeclContext because
2256*67e74705SXin Li   // we don't have a scope.
2257*67e74705SXin Li   ContextRAII SavedContext(*this, Instantiation->getParent());
2258*67e74705SXin Li   EnterExpressionEvaluationContext EvalContext(*this,
2259*67e74705SXin Li                                                Sema::PotentiallyEvaluated);
2260*67e74705SXin Li 
2261*67e74705SXin Li   LocalInstantiationScope Scope(*this, true);
2262*67e74705SXin Li 
2263*67e74705SXin Li   // Instantiate the initializer.
2264*67e74705SXin Li   ActOnStartCXXInClassMemberInitializer();
2265*67e74705SXin Li   CXXThisScopeRAII ThisScope(*this, Instantiation->getParent(), /*TypeQuals=*/0);
2266*67e74705SXin Li 
2267*67e74705SXin Li   ExprResult NewInit = SubstInitializer(OldInit, TemplateArgs,
2268*67e74705SXin Li                                         /*CXXDirectInit=*/false);
2269*67e74705SXin Li   Expr *Init = NewInit.get();
2270*67e74705SXin Li   assert((!Init || !isa<ParenListExpr>(Init)) && "call-style init in class");
2271*67e74705SXin Li   ActOnFinishCXXInClassMemberInitializer(
2272*67e74705SXin Li       Instantiation, Init ? Init->getLocStart() : SourceLocation(), Init);
2273*67e74705SXin Li 
2274*67e74705SXin Li   // Exit the scope of this instantiation.
2275*67e74705SXin Li   SavedContext.pop();
2276*67e74705SXin Li 
2277*67e74705SXin Li   // Return true if the in-class initializer is still missing.
2278*67e74705SXin Li   return !Instantiation->getInClassInitializer();
2279*67e74705SXin Li }
2280*67e74705SXin Li 
2281*67e74705SXin Li namespace {
2282*67e74705SXin Li   /// \brief A partial specialization whose template arguments have matched
2283*67e74705SXin Li   /// a given template-id.
2284*67e74705SXin Li   struct PartialSpecMatchResult {
2285*67e74705SXin Li     ClassTemplatePartialSpecializationDecl *Partial;
2286*67e74705SXin Li     TemplateArgumentList *Args;
2287*67e74705SXin Li   };
2288*67e74705SXin Li }
2289*67e74705SXin Li 
InstantiateClassTemplateSpecialization(SourceLocation PointOfInstantiation,ClassTemplateSpecializationDecl * ClassTemplateSpec,TemplateSpecializationKind TSK,bool Complain)2290*67e74705SXin Li bool Sema::InstantiateClassTemplateSpecialization(
2291*67e74705SXin Li     SourceLocation PointOfInstantiation,
2292*67e74705SXin Li     ClassTemplateSpecializationDecl *ClassTemplateSpec,
2293*67e74705SXin Li     TemplateSpecializationKind TSK, bool Complain) {
2294*67e74705SXin Li   // Perform the actual instantiation on the canonical declaration.
2295*67e74705SXin Li   ClassTemplateSpec = cast<ClassTemplateSpecializationDecl>(
2296*67e74705SXin Li                                          ClassTemplateSpec->getCanonicalDecl());
2297*67e74705SXin Li   if (ClassTemplateSpec->isInvalidDecl())
2298*67e74705SXin Li     return true;
2299*67e74705SXin Li 
2300*67e74705SXin Li   ClassTemplateDecl *Template = ClassTemplateSpec->getSpecializedTemplate();
2301*67e74705SXin Li   CXXRecordDecl *Pattern = nullptr;
2302*67e74705SXin Li 
2303*67e74705SXin Li   // C++ [temp.class.spec.match]p1:
2304*67e74705SXin Li   //   When a class template is used in a context that requires an
2305*67e74705SXin Li   //   instantiation of the class, it is necessary to determine
2306*67e74705SXin Li   //   whether the instantiation is to be generated using the primary
2307*67e74705SXin Li   //   template or one of the partial specializations. This is done by
2308*67e74705SXin Li   //   matching the template arguments of the class template
2309*67e74705SXin Li   //   specialization with the template argument lists of the partial
2310*67e74705SXin Li   //   specializations.
2311*67e74705SXin Li   typedef PartialSpecMatchResult MatchResult;
2312*67e74705SXin Li   SmallVector<MatchResult, 4> Matched;
2313*67e74705SXin Li   SmallVector<ClassTemplatePartialSpecializationDecl *, 4> PartialSpecs;
2314*67e74705SXin Li   Template->getPartialSpecializations(PartialSpecs);
2315*67e74705SXin Li   TemplateSpecCandidateSet FailedCandidates(PointOfInstantiation);
2316*67e74705SXin Li   for (unsigned I = 0, N = PartialSpecs.size(); I != N; ++I) {
2317*67e74705SXin Li     ClassTemplatePartialSpecializationDecl *Partial = PartialSpecs[I];
2318*67e74705SXin Li     TemplateDeductionInfo Info(FailedCandidates.getLocation());
2319*67e74705SXin Li     if (TemplateDeductionResult Result
2320*67e74705SXin Li           = DeduceTemplateArguments(Partial,
2321*67e74705SXin Li                                     ClassTemplateSpec->getTemplateArgs(),
2322*67e74705SXin Li                                     Info)) {
2323*67e74705SXin Li       // Store the failed-deduction information for use in diagnostics, later.
2324*67e74705SXin Li       // TODO: Actually use the failed-deduction info?
2325*67e74705SXin Li       FailedCandidates.addCandidate().set(
2326*67e74705SXin Li           DeclAccessPair::make(Template, AS_public), Partial,
2327*67e74705SXin Li           MakeDeductionFailureInfo(Context, Result, Info));
2328*67e74705SXin Li       (void)Result;
2329*67e74705SXin Li     } else {
2330*67e74705SXin Li       Matched.push_back(PartialSpecMatchResult());
2331*67e74705SXin Li       Matched.back().Partial = Partial;
2332*67e74705SXin Li       Matched.back().Args = Info.take();
2333*67e74705SXin Li     }
2334*67e74705SXin Li   }
2335*67e74705SXin Li 
2336*67e74705SXin Li   // If we're dealing with a member template where the template parameters
2337*67e74705SXin Li   // have been instantiated, this provides the original template parameters
2338*67e74705SXin Li   // from which the member template's parameters were instantiated.
2339*67e74705SXin Li 
2340*67e74705SXin Li   if (Matched.size() >= 1) {
2341*67e74705SXin Li     SmallVectorImpl<MatchResult>::iterator Best = Matched.begin();
2342*67e74705SXin Li     if (Matched.size() == 1) {
2343*67e74705SXin Li       //   -- If exactly one matching specialization is found, the
2344*67e74705SXin Li       //      instantiation is generated from that specialization.
2345*67e74705SXin Li       // We don't need to do anything for this.
2346*67e74705SXin Li     } else {
2347*67e74705SXin Li       //   -- If more than one matching specialization is found, the
2348*67e74705SXin Li       //      partial order rules (14.5.4.2) are used to determine
2349*67e74705SXin Li       //      whether one of the specializations is more specialized
2350*67e74705SXin Li       //      than the others. If none of the specializations is more
2351*67e74705SXin Li       //      specialized than all of the other matching
2352*67e74705SXin Li       //      specializations, then the use of the class template is
2353*67e74705SXin Li       //      ambiguous and the program is ill-formed.
2354*67e74705SXin Li       for (SmallVectorImpl<MatchResult>::iterator P = Best + 1,
2355*67e74705SXin Li                                                PEnd = Matched.end();
2356*67e74705SXin Li            P != PEnd; ++P) {
2357*67e74705SXin Li         if (getMoreSpecializedPartialSpecialization(P->Partial, Best->Partial,
2358*67e74705SXin Li                                                     PointOfInstantiation)
2359*67e74705SXin Li               == P->Partial)
2360*67e74705SXin Li           Best = P;
2361*67e74705SXin Li       }
2362*67e74705SXin Li 
2363*67e74705SXin Li       // Determine if the best partial specialization is more specialized than
2364*67e74705SXin Li       // the others.
2365*67e74705SXin Li       bool Ambiguous = false;
2366*67e74705SXin Li       for (SmallVectorImpl<MatchResult>::iterator P = Matched.begin(),
2367*67e74705SXin Li                                                PEnd = Matched.end();
2368*67e74705SXin Li            P != PEnd; ++P) {
2369*67e74705SXin Li         if (P != Best &&
2370*67e74705SXin Li             getMoreSpecializedPartialSpecialization(P->Partial, Best->Partial,
2371*67e74705SXin Li                                                     PointOfInstantiation)
2372*67e74705SXin Li               != Best->Partial) {
2373*67e74705SXin Li           Ambiguous = true;
2374*67e74705SXin Li           break;
2375*67e74705SXin Li         }
2376*67e74705SXin Li       }
2377*67e74705SXin Li 
2378*67e74705SXin Li       if (Ambiguous) {
2379*67e74705SXin Li         // Partial ordering did not produce a clear winner. Complain.
2380*67e74705SXin Li         ClassTemplateSpec->setInvalidDecl();
2381*67e74705SXin Li         Diag(PointOfInstantiation, diag::err_partial_spec_ordering_ambiguous)
2382*67e74705SXin Li           << ClassTemplateSpec;
2383*67e74705SXin Li 
2384*67e74705SXin Li         // Print the matching partial specializations.
2385*67e74705SXin Li         for (SmallVectorImpl<MatchResult>::iterator P = Matched.begin(),
2386*67e74705SXin Li                                                  PEnd = Matched.end();
2387*67e74705SXin Li              P != PEnd; ++P)
2388*67e74705SXin Li           Diag(P->Partial->getLocation(), diag::note_partial_spec_match)
2389*67e74705SXin Li             << getTemplateArgumentBindingsText(
2390*67e74705SXin Li                                             P->Partial->getTemplateParameters(),
2391*67e74705SXin Li                                                *P->Args);
2392*67e74705SXin Li 
2393*67e74705SXin Li         return true;
2394*67e74705SXin Li       }
2395*67e74705SXin Li     }
2396*67e74705SXin Li 
2397*67e74705SXin Li     // Instantiate using the best class template partial specialization.
2398*67e74705SXin Li     ClassTemplatePartialSpecializationDecl *OrigPartialSpec = Best->Partial;
2399*67e74705SXin Li     while (OrigPartialSpec->getInstantiatedFromMember()) {
2400*67e74705SXin Li       // If we've found an explicit specialization of this class template,
2401*67e74705SXin Li       // stop here and use that as the pattern.
2402*67e74705SXin Li       if (OrigPartialSpec->isMemberSpecialization())
2403*67e74705SXin Li         break;
2404*67e74705SXin Li 
2405*67e74705SXin Li       OrigPartialSpec = OrigPartialSpec->getInstantiatedFromMember();
2406*67e74705SXin Li     }
2407*67e74705SXin Li 
2408*67e74705SXin Li     Pattern = OrigPartialSpec;
2409*67e74705SXin Li     ClassTemplateSpec->setInstantiationOf(Best->Partial, Best->Args);
2410*67e74705SXin Li   } else {
2411*67e74705SXin Li     //   -- If no matches are found, the instantiation is generated
2412*67e74705SXin Li     //      from the primary template.
2413*67e74705SXin Li     ClassTemplateDecl *OrigTemplate = Template;
2414*67e74705SXin Li     while (OrigTemplate->getInstantiatedFromMemberTemplate()) {
2415*67e74705SXin Li       // If we've found an explicit specialization of this class template,
2416*67e74705SXin Li       // stop here and use that as the pattern.
2417*67e74705SXin Li       if (OrigTemplate->isMemberSpecialization())
2418*67e74705SXin Li         break;
2419*67e74705SXin Li 
2420*67e74705SXin Li       OrigTemplate = OrigTemplate->getInstantiatedFromMemberTemplate();
2421*67e74705SXin Li     }
2422*67e74705SXin Li 
2423*67e74705SXin Li     Pattern = OrigTemplate->getTemplatedDecl();
2424*67e74705SXin Li   }
2425*67e74705SXin Li 
2426*67e74705SXin Li   bool Result = InstantiateClass(PointOfInstantiation, ClassTemplateSpec,
2427*67e74705SXin Li                                  Pattern,
2428*67e74705SXin Li                                 getTemplateInstantiationArgs(ClassTemplateSpec),
2429*67e74705SXin Li                                  TSK,
2430*67e74705SXin Li                                  Complain);
2431*67e74705SXin Li 
2432*67e74705SXin Li   return Result;
2433*67e74705SXin Li }
2434*67e74705SXin Li 
2435*67e74705SXin Li /// \brief Instantiates the definitions of all of the member
2436*67e74705SXin Li /// of the given class, which is an instantiation of a class template
2437*67e74705SXin Li /// or a member class of a template.
2438*67e74705SXin Li void
InstantiateClassMembers(SourceLocation PointOfInstantiation,CXXRecordDecl * Instantiation,const MultiLevelTemplateArgumentList & TemplateArgs,TemplateSpecializationKind TSK)2439*67e74705SXin Li Sema::InstantiateClassMembers(SourceLocation PointOfInstantiation,
2440*67e74705SXin Li                               CXXRecordDecl *Instantiation,
2441*67e74705SXin Li                         const MultiLevelTemplateArgumentList &TemplateArgs,
2442*67e74705SXin Li                               TemplateSpecializationKind TSK) {
2443*67e74705SXin Li   // FIXME: We need to notify the ASTMutationListener that we did all of these
2444*67e74705SXin Li   // things, in case we have an explicit instantiation definition in a PCM, a
2445*67e74705SXin Li   // module, or preamble, and the declaration is in an imported AST.
2446*67e74705SXin Li   assert(
2447*67e74705SXin Li       (TSK == TSK_ExplicitInstantiationDefinition ||
2448*67e74705SXin Li        TSK == TSK_ExplicitInstantiationDeclaration ||
2449*67e74705SXin Li        (TSK == TSK_ImplicitInstantiation && Instantiation->isLocalClass())) &&
2450*67e74705SXin Li       "Unexpected template specialization kind!");
2451*67e74705SXin Li   for (auto *D : Instantiation->decls()) {
2452*67e74705SXin Li     bool SuppressNew = false;
2453*67e74705SXin Li     if (auto *Function = dyn_cast<FunctionDecl>(D)) {
2454*67e74705SXin Li       if (FunctionDecl *Pattern
2455*67e74705SXin Li             = Function->getInstantiatedFromMemberFunction()) {
2456*67e74705SXin Li         MemberSpecializationInfo *MSInfo
2457*67e74705SXin Li           = Function->getMemberSpecializationInfo();
2458*67e74705SXin Li         assert(MSInfo && "No member specialization information?");
2459*67e74705SXin Li         if (MSInfo->getTemplateSpecializationKind()
2460*67e74705SXin Li                                                  == TSK_ExplicitSpecialization)
2461*67e74705SXin Li           continue;
2462*67e74705SXin Li 
2463*67e74705SXin Li         if (CheckSpecializationInstantiationRedecl(PointOfInstantiation, TSK,
2464*67e74705SXin Li                                                    Function,
2465*67e74705SXin Li                                         MSInfo->getTemplateSpecializationKind(),
2466*67e74705SXin Li                                               MSInfo->getPointOfInstantiation(),
2467*67e74705SXin Li                                                    SuppressNew) ||
2468*67e74705SXin Li             SuppressNew)
2469*67e74705SXin Li           continue;
2470*67e74705SXin Li 
2471*67e74705SXin Li         // C++11 [temp.explicit]p8:
2472*67e74705SXin Li         //   An explicit instantiation definition that names a class template
2473*67e74705SXin Li         //   specialization explicitly instantiates the class template
2474*67e74705SXin Li         //   specialization and is only an explicit instantiation definition
2475*67e74705SXin Li         //   of members whose definition is visible at the point of
2476*67e74705SXin Li         //   instantiation.
2477*67e74705SXin Li         if (TSK == TSK_ExplicitInstantiationDefinition && !Pattern->isDefined())
2478*67e74705SXin Li           continue;
2479*67e74705SXin Li 
2480*67e74705SXin Li         Function->setTemplateSpecializationKind(TSK, PointOfInstantiation);
2481*67e74705SXin Li 
2482*67e74705SXin Li         if (Function->isDefined()) {
2483*67e74705SXin Li           // Let the ASTConsumer know that this function has been explicitly
2484*67e74705SXin Li           // instantiated now, and its linkage might have changed.
2485*67e74705SXin Li           Consumer.HandleTopLevelDecl(DeclGroupRef(Function));
2486*67e74705SXin Li         } else if (TSK == TSK_ExplicitInstantiationDefinition) {
2487*67e74705SXin Li           InstantiateFunctionDefinition(PointOfInstantiation, Function);
2488*67e74705SXin Li         } else if (TSK == TSK_ImplicitInstantiation) {
2489*67e74705SXin Li           PendingLocalImplicitInstantiations.push_back(
2490*67e74705SXin Li               std::make_pair(Function, PointOfInstantiation));
2491*67e74705SXin Li         }
2492*67e74705SXin Li       }
2493*67e74705SXin Li     } else if (auto *Var = dyn_cast<VarDecl>(D)) {
2494*67e74705SXin Li       if (isa<VarTemplateSpecializationDecl>(Var))
2495*67e74705SXin Li         continue;
2496*67e74705SXin Li 
2497*67e74705SXin Li       if (Var->isStaticDataMember()) {
2498*67e74705SXin Li         MemberSpecializationInfo *MSInfo = Var->getMemberSpecializationInfo();
2499*67e74705SXin Li         assert(MSInfo && "No member specialization information?");
2500*67e74705SXin Li         if (MSInfo->getTemplateSpecializationKind()
2501*67e74705SXin Li                                                  == TSK_ExplicitSpecialization)
2502*67e74705SXin Li           continue;
2503*67e74705SXin Li 
2504*67e74705SXin Li         if (CheckSpecializationInstantiationRedecl(PointOfInstantiation, TSK,
2505*67e74705SXin Li                                                    Var,
2506*67e74705SXin Li                                         MSInfo->getTemplateSpecializationKind(),
2507*67e74705SXin Li                                               MSInfo->getPointOfInstantiation(),
2508*67e74705SXin Li                                                    SuppressNew) ||
2509*67e74705SXin Li             SuppressNew)
2510*67e74705SXin Li           continue;
2511*67e74705SXin Li 
2512*67e74705SXin Li         if (TSK == TSK_ExplicitInstantiationDefinition) {
2513*67e74705SXin Li           // C++0x [temp.explicit]p8:
2514*67e74705SXin Li           //   An explicit instantiation definition that names a class template
2515*67e74705SXin Li           //   specialization explicitly instantiates the class template
2516*67e74705SXin Li           //   specialization and is only an explicit instantiation definition
2517*67e74705SXin Li           //   of members whose definition is visible at the point of
2518*67e74705SXin Li           //   instantiation.
2519*67e74705SXin Li           if (!Var->getInstantiatedFromStaticDataMember()->getDefinition())
2520*67e74705SXin Li             continue;
2521*67e74705SXin Li 
2522*67e74705SXin Li           Var->setTemplateSpecializationKind(TSK, PointOfInstantiation);
2523*67e74705SXin Li           InstantiateStaticDataMemberDefinition(PointOfInstantiation, Var);
2524*67e74705SXin Li         } else {
2525*67e74705SXin Li           Var->setTemplateSpecializationKind(TSK, PointOfInstantiation);
2526*67e74705SXin Li         }
2527*67e74705SXin Li       }
2528*67e74705SXin Li     } else if (auto *Record = dyn_cast<CXXRecordDecl>(D)) {
2529*67e74705SXin Li       // Always skip the injected-class-name, along with any
2530*67e74705SXin Li       // redeclarations of nested classes, since both would cause us
2531*67e74705SXin Li       // to try to instantiate the members of a class twice.
2532*67e74705SXin Li       // Skip closure types; they'll get instantiated when we instantiate
2533*67e74705SXin Li       // the corresponding lambda-expression.
2534*67e74705SXin Li       if (Record->isInjectedClassName() || Record->getPreviousDecl() ||
2535*67e74705SXin Li           Record->isLambda())
2536*67e74705SXin Li         continue;
2537*67e74705SXin Li 
2538*67e74705SXin Li       MemberSpecializationInfo *MSInfo = Record->getMemberSpecializationInfo();
2539*67e74705SXin Li       assert(MSInfo && "No member specialization information?");
2540*67e74705SXin Li 
2541*67e74705SXin Li       if (MSInfo->getTemplateSpecializationKind()
2542*67e74705SXin Li                                                 == TSK_ExplicitSpecialization)
2543*67e74705SXin Li         continue;
2544*67e74705SXin Li 
2545*67e74705SXin Li       if (Context.getTargetInfo().getCXXABI().isMicrosoft() &&
2546*67e74705SXin Li           TSK == TSK_ExplicitInstantiationDeclaration) {
2547*67e74705SXin Li         // In MSVC mode, explicit instantiation decl of the outer class doesn't
2548*67e74705SXin Li         // affect the inner class.
2549*67e74705SXin Li         continue;
2550*67e74705SXin Li       }
2551*67e74705SXin Li 
2552*67e74705SXin Li       if (CheckSpecializationInstantiationRedecl(PointOfInstantiation, TSK,
2553*67e74705SXin Li                                                  Record,
2554*67e74705SXin Li                                         MSInfo->getTemplateSpecializationKind(),
2555*67e74705SXin Li                                               MSInfo->getPointOfInstantiation(),
2556*67e74705SXin Li                                                  SuppressNew) ||
2557*67e74705SXin Li           SuppressNew)
2558*67e74705SXin Li         continue;
2559*67e74705SXin Li 
2560*67e74705SXin Li       CXXRecordDecl *Pattern = Record->getInstantiatedFromMemberClass();
2561*67e74705SXin Li       assert(Pattern && "Missing instantiated-from-template information");
2562*67e74705SXin Li 
2563*67e74705SXin Li       if (!Record->getDefinition()) {
2564*67e74705SXin Li         if (!Pattern->getDefinition()) {
2565*67e74705SXin Li           // C++0x [temp.explicit]p8:
2566*67e74705SXin Li           //   An explicit instantiation definition that names a class template
2567*67e74705SXin Li           //   specialization explicitly instantiates the class template
2568*67e74705SXin Li           //   specialization and is only an explicit instantiation definition
2569*67e74705SXin Li           //   of members whose definition is visible at the point of
2570*67e74705SXin Li           //   instantiation.
2571*67e74705SXin Li           if (TSK == TSK_ExplicitInstantiationDeclaration) {
2572*67e74705SXin Li             MSInfo->setTemplateSpecializationKind(TSK);
2573*67e74705SXin Li             MSInfo->setPointOfInstantiation(PointOfInstantiation);
2574*67e74705SXin Li           }
2575*67e74705SXin Li 
2576*67e74705SXin Li           continue;
2577*67e74705SXin Li         }
2578*67e74705SXin Li 
2579*67e74705SXin Li         InstantiateClass(PointOfInstantiation, Record, Pattern,
2580*67e74705SXin Li                          TemplateArgs,
2581*67e74705SXin Li                          TSK);
2582*67e74705SXin Li       } else {
2583*67e74705SXin Li         if (TSK == TSK_ExplicitInstantiationDefinition &&
2584*67e74705SXin Li             Record->getTemplateSpecializationKind() ==
2585*67e74705SXin Li                 TSK_ExplicitInstantiationDeclaration) {
2586*67e74705SXin Li           Record->setTemplateSpecializationKind(TSK);
2587*67e74705SXin Li           MarkVTableUsed(PointOfInstantiation, Record, true);
2588*67e74705SXin Li         }
2589*67e74705SXin Li       }
2590*67e74705SXin Li 
2591*67e74705SXin Li       Pattern = cast_or_null<CXXRecordDecl>(Record->getDefinition());
2592*67e74705SXin Li       if (Pattern)
2593*67e74705SXin Li         InstantiateClassMembers(PointOfInstantiation, Pattern, TemplateArgs,
2594*67e74705SXin Li                                 TSK);
2595*67e74705SXin Li     } else if (auto *Enum = dyn_cast<EnumDecl>(D)) {
2596*67e74705SXin Li       MemberSpecializationInfo *MSInfo = Enum->getMemberSpecializationInfo();
2597*67e74705SXin Li       assert(MSInfo && "No member specialization information?");
2598*67e74705SXin Li 
2599*67e74705SXin Li       if (MSInfo->getTemplateSpecializationKind()
2600*67e74705SXin Li             == TSK_ExplicitSpecialization)
2601*67e74705SXin Li         continue;
2602*67e74705SXin Li 
2603*67e74705SXin Li       if (CheckSpecializationInstantiationRedecl(
2604*67e74705SXin Li             PointOfInstantiation, TSK, Enum,
2605*67e74705SXin Li             MSInfo->getTemplateSpecializationKind(),
2606*67e74705SXin Li             MSInfo->getPointOfInstantiation(), SuppressNew) ||
2607*67e74705SXin Li           SuppressNew)
2608*67e74705SXin Li         continue;
2609*67e74705SXin Li 
2610*67e74705SXin Li       if (Enum->getDefinition())
2611*67e74705SXin Li         continue;
2612*67e74705SXin Li 
2613*67e74705SXin Li       EnumDecl *Pattern = Enum->getTemplateInstantiationPattern();
2614*67e74705SXin Li       assert(Pattern && "Missing instantiated-from-template information");
2615*67e74705SXin Li 
2616*67e74705SXin Li       if (TSK == TSK_ExplicitInstantiationDefinition) {
2617*67e74705SXin Li         if (!Pattern->getDefinition())
2618*67e74705SXin Li           continue;
2619*67e74705SXin Li 
2620*67e74705SXin Li         InstantiateEnum(PointOfInstantiation, Enum, Pattern, TemplateArgs, TSK);
2621*67e74705SXin Li       } else {
2622*67e74705SXin Li         MSInfo->setTemplateSpecializationKind(TSK);
2623*67e74705SXin Li         MSInfo->setPointOfInstantiation(PointOfInstantiation);
2624*67e74705SXin Li       }
2625*67e74705SXin Li     } else if (auto *Field = dyn_cast<FieldDecl>(D)) {
2626*67e74705SXin Li       // No need to instantiate in-class initializers during explicit
2627*67e74705SXin Li       // instantiation.
2628*67e74705SXin Li       if (Field->hasInClassInitializer() && TSK == TSK_ImplicitInstantiation) {
2629*67e74705SXin Li         CXXRecordDecl *ClassPattern =
2630*67e74705SXin Li             Instantiation->getTemplateInstantiationPattern();
2631*67e74705SXin Li         DeclContext::lookup_result Lookup =
2632*67e74705SXin Li             ClassPattern->lookup(Field->getDeclName());
2633*67e74705SXin Li         FieldDecl *Pattern = cast<FieldDecl>(Lookup.front());
2634*67e74705SXin Li         InstantiateInClassInitializer(PointOfInstantiation, Field, Pattern,
2635*67e74705SXin Li                                       TemplateArgs);
2636*67e74705SXin Li       }
2637*67e74705SXin Li     }
2638*67e74705SXin Li   }
2639*67e74705SXin Li }
2640*67e74705SXin Li 
2641*67e74705SXin Li /// \brief Instantiate the definitions of all of the members of the
2642*67e74705SXin Li /// given class template specialization, which was named as part of an
2643*67e74705SXin Li /// explicit instantiation.
2644*67e74705SXin Li void
InstantiateClassTemplateSpecializationMembers(SourceLocation PointOfInstantiation,ClassTemplateSpecializationDecl * ClassTemplateSpec,TemplateSpecializationKind TSK)2645*67e74705SXin Li Sema::InstantiateClassTemplateSpecializationMembers(
2646*67e74705SXin Li                                            SourceLocation PointOfInstantiation,
2647*67e74705SXin Li                             ClassTemplateSpecializationDecl *ClassTemplateSpec,
2648*67e74705SXin Li                                                TemplateSpecializationKind TSK) {
2649*67e74705SXin Li   // C++0x [temp.explicit]p7:
2650*67e74705SXin Li   //   An explicit instantiation that names a class template
2651*67e74705SXin Li   //   specialization is an explicit instantion of the same kind
2652*67e74705SXin Li   //   (declaration or definition) of each of its members (not
2653*67e74705SXin Li   //   including members inherited from base classes) that has not
2654*67e74705SXin Li   //   been previously explicitly specialized in the translation unit
2655*67e74705SXin Li   //   containing the explicit instantiation, except as described
2656*67e74705SXin Li   //   below.
2657*67e74705SXin Li   InstantiateClassMembers(PointOfInstantiation, ClassTemplateSpec,
2658*67e74705SXin Li                           getTemplateInstantiationArgs(ClassTemplateSpec),
2659*67e74705SXin Li                           TSK);
2660*67e74705SXin Li }
2661*67e74705SXin Li 
2662*67e74705SXin Li StmtResult
SubstStmt(Stmt * S,const MultiLevelTemplateArgumentList & TemplateArgs)2663*67e74705SXin Li Sema::SubstStmt(Stmt *S, const MultiLevelTemplateArgumentList &TemplateArgs) {
2664*67e74705SXin Li   if (!S)
2665*67e74705SXin Li     return S;
2666*67e74705SXin Li 
2667*67e74705SXin Li   TemplateInstantiator Instantiator(*this, TemplateArgs,
2668*67e74705SXin Li                                     SourceLocation(),
2669*67e74705SXin Li                                     DeclarationName());
2670*67e74705SXin Li   return Instantiator.TransformStmt(S);
2671*67e74705SXin Li }
2672*67e74705SXin Li 
2673*67e74705SXin Li ExprResult
SubstExpr(Expr * E,const MultiLevelTemplateArgumentList & TemplateArgs)2674*67e74705SXin Li Sema::SubstExpr(Expr *E, const MultiLevelTemplateArgumentList &TemplateArgs) {
2675*67e74705SXin Li   if (!E)
2676*67e74705SXin Li     return E;
2677*67e74705SXin Li 
2678*67e74705SXin Li   TemplateInstantiator Instantiator(*this, TemplateArgs,
2679*67e74705SXin Li                                     SourceLocation(),
2680*67e74705SXin Li                                     DeclarationName());
2681*67e74705SXin Li   return Instantiator.TransformExpr(E);
2682*67e74705SXin Li }
2683*67e74705SXin Li 
SubstInitializer(Expr * Init,const MultiLevelTemplateArgumentList & TemplateArgs,bool CXXDirectInit)2684*67e74705SXin Li ExprResult Sema::SubstInitializer(Expr *Init,
2685*67e74705SXin Li                           const MultiLevelTemplateArgumentList &TemplateArgs,
2686*67e74705SXin Li                           bool CXXDirectInit) {
2687*67e74705SXin Li   TemplateInstantiator Instantiator(*this, TemplateArgs,
2688*67e74705SXin Li                                     SourceLocation(),
2689*67e74705SXin Li                                     DeclarationName());
2690*67e74705SXin Li   return Instantiator.TransformInitializer(Init, CXXDirectInit);
2691*67e74705SXin Li }
2692*67e74705SXin Li 
SubstExprs(ArrayRef<Expr * > Exprs,bool IsCall,const MultiLevelTemplateArgumentList & TemplateArgs,SmallVectorImpl<Expr * > & Outputs)2693*67e74705SXin Li bool Sema::SubstExprs(ArrayRef<Expr *> Exprs, bool IsCall,
2694*67e74705SXin Li                       const MultiLevelTemplateArgumentList &TemplateArgs,
2695*67e74705SXin Li                       SmallVectorImpl<Expr *> &Outputs) {
2696*67e74705SXin Li   if (Exprs.empty())
2697*67e74705SXin Li     return false;
2698*67e74705SXin Li 
2699*67e74705SXin Li   TemplateInstantiator Instantiator(*this, TemplateArgs,
2700*67e74705SXin Li                                     SourceLocation(),
2701*67e74705SXin Li                                     DeclarationName());
2702*67e74705SXin Li   return Instantiator.TransformExprs(Exprs.data(), Exprs.size(),
2703*67e74705SXin Li                                      IsCall, Outputs);
2704*67e74705SXin Li }
2705*67e74705SXin Li 
2706*67e74705SXin Li NestedNameSpecifierLoc
SubstNestedNameSpecifierLoc(NestedNameSpecifierLoc NNS,const MultiLevelTemplateArgumentList & TemplateArgs)2707*67e74705SXin Li Sema::SubstNestedNameSpecifierLoc(NestedNameSpecifierLoc NNS,
2708*67e74705SXin Li                         const MultiLevelTemplateArgumentList &TemplateArgs) {
2709*67e74705SXin Li   if (!NNS)
2710*67e74705SXin Li     return NestedNameSpecifierLoc();
2711*67e74705SXin Li 
2712*67e74705SXin Li   TemplateInstantiator Instantiator(*this, TemplateArgs, NNS.getBeginLoc(),
2713*67e74705SXin Li                                     DeclarationName());
2714*67e74705SXin Li   return Instantiator.TransformNestedNameSpecifierLoc(NNS);
2715*67e74705SXin Li }
2716*67e74705SXin Li 
2717*67e74705SXin Li /// \brief Do template substitution on declaration name info.
2718*67e74705SXin Li DeclarationNameInfo
SubstDeclarationNameInfo(const DeclarationNameInfo & NameInfo,const MultiLevelTemplateArgumentList & TemplateArgs)2719*67e74705SXin Li Sema::SubstDeclarationNameInfo(const DeclarationNameInfo &NameInfo,
2720*67e74705SXin Li                          const MultiLevelTemplateArgumentList &TemplateArgs) {
2721*67e74705SXin Li   TemplateInstantiator Instantiator(*this, TemplateArgs, NameInfo.getLoc(),
2722*67e74705SXin Li                                     NameInfo.getName());
2723*67e74705SXin Li   return Instantiator.TransformDeclarationNameInfo(NameInfo);
2724*67e74705SXin Li }
2725*67e74705SXin Li 
2726*67e74705SXin Li TemplateName
SubstTemplateName(NestedNameSpecifierLoc QualifierLoc,TemplateName Name,SourceLocation Loc,const MultiLevelTemplateArgumentList & TemplateArgs)2727*67e74705SXin Li Sema::SubstTemplateName(NestedNameSpecifierLoc QualifierLoc,
2728*67e74705SXin Li                         TemplateName Name, SourceLocation Loc,
2729*67e74705SXin Li                         const MultiLevelTemplateArgumentList &TemplateArgs) {
2730*67e74705SXin Li   TemplateInstantiator Instantiator(*this, TemplateArgs, Loc,
2731*67e74705SXin Li                                     DeclarationName());
2732*67e74705SXin Li   CXXScopeSpec SS;
2733*67e74705SXin Li   SS.Adopt(QualifierLoc);
2734*67e74705SXin Li   return Instantiator.TransformTemplateName(SS, Name, Loc);
2735*67e74705SXin Li }
2736*67e74705SXin Li 
Subst(const TemplateArgumentLoc * Args,unsigned NumArgs,TemplateArgumentListInfo & Result,const MultiLevelTemplateArgumentList & TemplateArgs)2737*67e74705SXin Li bool Sema::Subst(const TemplateArgumentLoc *Args, unsigned NumArgs,
2738*67e74705SXin Li                  TemplateArgumentListInfo &Result,
2739*67e74705SXin Li                  const MultiLevelTemplateArgumentList &TemplateArgs) {
2740*67e74705SXin Li   TemplateInstantiator Instantiator(*this, TemplateArgs, SourceLocation(),
2741*67e74705SXin Li                                     DeclarationName());
2742*67e74705SXin Li 
2743*67e74705SXin Li   return Instantiator.TransformTemplateArguments(Args, NumArgs, Result);
2744*67e74705SXin Li }
2745*67e74705SXin Li 
getCanonicalParmVarDecl(const Decl * D)2746*67e74705SXin Li static const Decl *getCanonicalParmVarDecl(const Decl *D) {
2747*67e74705SXin Li   // When storing ParmVarDecls in the local instantiation scope, we always
2748*67e74705SXin Li   // want to use the ParmVarDecl from the canonical function declaration,
2749*67e74705SXin Li   // since the map is then valid for any redeclaration or definition of that
2750*67e74705SXin Li   // function.
2751*67e74705SXin Li   if (const ParmVarDecl *PV = dyn_cast<ParmVarDecl>(D)) {
2752*67e74705SXin Li     if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(PV->getDeclContext())) {
2753*67e74705SXin Li       unsigned i = PV->getFunctionScopeIndex();
2754*67e74705SXin Li       // This parameter might be from a freestanding function type within the
2755*67e74705SXin Li       // function and isn't necessarily referring to one of FD's parameters.
2756*67e74705SXin Li       if (FD->getParamDecl(i) == PV)
2757*67e74705SXin Li         return FD->getCanonicalDecl()->getParamDecl(i);
2758*67e74705SXin Li     }
2759*67e74705SXin Li   }
2760*67e74705SXin Li   return D;
2761*67e74705SXin Li }
2762*67e74705SXin Li 
2763*67e74705SXin Li 
2764*67e74705SXin Li llvm::PointerUnion<Decl *, LocalInstantiationScope::DeclArgumentPack *> *
findInstantiationOf(const Decl * D)2765*67e74705SXin Li LocalInstantiationScope::findInstantiationOf(const Decl *D) {
2766*67e74705SXin Li   D = getCanonicalParmVarDecl(D);
2767*67e74705SXin Li   for (LocalInstantiationScope *Current = this; Current;
2768*67e74705SXin Li        Current = Current->Outer) {
2769*67e74705SXin Li 
2770*67e74705SXin Li     // Check if we found something within this scope.
2771*67e74705SXin Li     const Decl *CheckD = D;
2772*67e74705SXin Li     do {
2773*67e74705SXin Li       LocalDeclsMap::iterator Found = Current->LocalDecls.find(CheckD);
2774*67e74705SXin Li       if (Found != Current->LocalDecls.end())
2775*67e74705SXin Li         return &Found->second;
2776*67e74705SXin Li 
2777*67e74705SXin Li       // If this is a tag declaration, it's possible that we need to look for
2778*67e74705SXin Li       // a previous declaration.
2779*67e74705SXin Li       if (const TagDecl *Tag = dyn_cast<TagDecl>(CheckD))
2780*67e74705SXin Li         CheckD = Tag->getPreviousDecl();
2781*67e74705SXin Li       else
2782*67e74705SXin Li         CheckD = nullptr;
2783*67e74705SXin Li     } while (CheckD);
2784*67e74705SXin Li 
2785*67e74705SXin Li     // If we aren't combined with our outer scope, we're done.
2786*67e74705SXin Li     if (!Current->CombineWithOuterScope)
2787*67e74705SXin Li       break;
2788*67e74705SXin Li   }
2789*67e74705SXin Li 
2790*67e74705SXin Li   // If we're performing a partial substitution during template argument
2791*67e74705SXin Li   // deduction, we may not have values for template parameters yet.
2792*67e74705SXin Li   if (isa<NonTypeTemplateParmDecl>(D) || isa<TemplateTypeParmDecl>(D) ||
2793*67e74705SXin Li       isa<TemplateTemplateParmDecl>(D))
2794*67e74705SXin Li     return nullptr;
2795*67e74705SXin Li 
2796*67e74705SXin Li   // Local types referenced prior to definition may require instantiation.
2797*67e74705SXin Li   if (const CXXRecordDecl *RD = dyn_cast<CXXRecordDecl>(D))
2798*67e74705SXin Li     if (RD->isLocalClass())
2799*67e74705SXin Li       return nullptr;
2800*67e74705SXin Li 
2801*67e74705SXin Li   // Enumeration types referenced prior to definition may appear as a result of
2802*67e74705SXin Li   // error recovery.
2803*67e74705SXin Li   if (isa<EnumDecl>(D))
2804*67e74705SXin Li     return nullptr;
2805*67e74705SXin Li 
2806*67e74705SXin Li   // If we didn't find the decl, then we either have a sema bug, or we have a
2807*67e74705SXin Li   // forward reference to a label declaration.  Return null to indicate that
2808*67e74705SXin Li   // we have an uninstantiated label.
2809*67e74705SXin Li   assert(isa<LabelDecl>(D) && "declaration not instantiated in this scope");
2810*67e74705SXin Li   return nullptr;
2811*67e74705SXin Li }
2812*67e74705SXin Li 
InstantiatedLocal(const Decl * D,Decl * Inst)2813*67e74705SXin Li void LocalInstantiationScope::InstantiatedLocal(const Decl *D, Decl *Inst) {
2814*67e74705SXin Li   D = getCanonicalParmVarDecl(D);
2815*67e74705SXin Li   llvm::PointerUnion<Decl *, DeclArgumentPack *> &Stored = LocalDecls[D];
2816*67e74705SXin Li   if (Stored.isNull()) {
2817*67e74705SXin Li #ifndef NDEBUG
2818*67e74705SXin Li     // It should not be present in any surrounding scope either.
2819*67e74705SXin Li     LocalInstantiationScope *Current = this;
2820*67e74705SXin Li     while (Current->CombineWithOuterScope && Current->Outer) {
2821*67e74705SXin Li       Current = Current->Outer;
2822*67e74705SXin Li       assert(Current->LocalDecls.find(D) == Current->LocalDecls.end() &&
2823*67e74705SXin Li              "Instantiated local in inner and outer scopes");
2824*67e74705SXin Li     }
2825*67e74705SXin Li #endif
2826*67e74705SXin Li     Stored = Inst;
2827*67e74705SXin Li   } else if (DeclArgumentPack *Pack = Stored.dyn_cast<DeclArgumentPack *>()) {
2828*67e74705SXin Li     Pack->push_back(cast<ParmVarDecl>(Inst));
2829*67e74705SXin Li   } else {
2830*67e74705SXin Li     assert(Stored.get<Decl *>() == Inst && "Already instantiated this local");
2831*67e74705SXin Li   }
2832*67e74705SXin Li }
2833*67e74705SXin Li 
InstantiatedLocalPackArg(const Decl * D,ParmVarDecl * Inst)2834*67e74705SXin Li void LocalInstantiationScope::InstantiatedLocalPackArg(const Decl *D,
2835*67e74705SXin Li                                                        ParmVarDecl *Inst) {
2836*67e74705SXin Li   D = getCanonicalParmVarDecl(D);
2837*67e74705SXin Li   DeclArgumentPack *Pack = LocalDecls[D].get<DeclArgumentPack *>();
2838*67e74705SXin Li   Pack->push_back(Inst);
2839*67e74705SXin Li }
2840*67e74705SXin Li 
MakeInstantiatedLocalArgPack(const Decl * D)2841*67e74705SXin Li void LocalInstantiationScope::MakeInstantiatedLocalArgPack(const Decl *D) {
2842*67e74705SXin Li #ifndef NDEBUG
2843*67e74705SXin Li   // This should be the first time we've been told about this decl.
2844*67e74705SXin Li   for (LocalInstantiationScope *Current = this;
2845*67e74705SXin Li        Current && Current->CombineWithOuterScope; Current = Current->Outer)
2846*67e74705SXin Li     assert(Current->LocalDecls.find(D) == Current->LocalDecls.end() &&
2847*67e74705SXin Li            "Creating local pack after instantiation of local");
2848*67e74705SXin Li #endif
2849*67e74705SXin Li 
2850*67e74705SXin Li   D = getCanonicalParmVarDecl(D);
2851*67e74705SXin Li   llvm::PointerUnion<Decl *, DeclArgumentPack *> &Stored = LocalDecls[D];
2852*67e74705SXin Li   DeclArgumentPack *Pack = new DeclArgumentPack;
2853*67e74705SXin Li   Stored = Pack;
2854*67e74705SXin Li   ArgumentPacks.push_back(Pack);
2855*67e74705SXin Li }
2856*67e74705SXin Li 
SetPartiallySubstitutedPack(NamedDecl * Pack,const TemplateArgument * ExplicitArgs,unsigned NumExplicitArgs)2857*67e74705SXin Li void LocalInstantiationScope::SetPartiallySubstitutedPack(NamedDecl *Pack,
2858*67e74705SXin Li                                           const TemplateArgument *ExplicitArgs,
2859*67e74705SXin Li                                                     unsigned NumExplicitArgs) {
2860*67e74705SXin Li   assert((!PartiallySubstitutedPack || PartiallySubstitutedPack == Pack) &&
2861*67e74705SXin Li          "Already have a partially-substituted pack");
2862*67e74705SXin Li   assert((!PartiallySubstitutedPack
2863*67e74705SXin Li           || NumArgsInPartiallySubstitutedPack == NumExplicitArgs) &&
2864*67e74705SXin Li          "Wrong number of arguments in partially-substituted pack");
2865*67e74705SXin Li   PartiallySubstitutedPack = Pack;
2866*67e74705SXin Li   ArgsInPartiallySubstitutedPack = ExplicitArgs;
2867*67e74705SXin Li   NumArgsInPartiallySubstitutedPack = NumExplicitArgs;
2868*67e74705SXin Li }
2869*67e74705SXin Li 
getPartiallySubstitutedPack(const TemplateArgument ** ExplicitArgs,unsigned * NumExplicitArgs) const2870*67e74705SXin Li NamedDecl *LocalInstantiationScope::getPartiallySubstitutedPack(
2871*67e74705SXin Li                                          const TemplateArgument **ExplicitArgs,
2872*67e74705SXin Li                                               unsigned *NumExplicitArgs) const {
2873*67e74705SXin Li   if (ExplicitArgs)
2874*67e74705SXin Li     *ExplicitArgs = nullptr;
2875*67e74705SXin Li   if (NumExplicitArgs)
2876*67e74705SXin Li     *NumExplicitArgs = 0;
2877*67e74705SXin Li 
2878*67e74705SXin Li   for (const LocalInstantiationScope *Current = this; Current;
2879*67e74705SXin Li        Current = Current->Outer) {
2880*67e74705SXin Li     if (Current->PartiallySubstitutedPack) {
2881*67e74705SXin Li       if (ExplicitArgs)
2882*67e74705SXin Li         *ExplicitArgs = Current->ArgsInPartiallySubstitutedPack;
2883*67e74705SXin Li       if (NumExplicitArgs)
2884*67e74705SXin Li         *NumExplicitArgs = Current->NumArgsInPartiallySubstitutedPack;
2885*67e74705SXin Li 
2886*67e74705SXin Li       return Current->PartiallySubstitutedPack;
2887*67e74705SXin Li     }
2888*67e74705SXin Li 
2889*67e74705SXin Li     if (!Current->CombineWithOuterScope)
2890*67e74705SXin Li       break;
2891*67e74705SXin Li   }
2892*67e74705SXin Li 
2893*67e74705SXin Li   return nullptr;
2894*67e74705SXin Li }
2895