xref: /freebsd/contrib/llvm-project/clang/lib/Sema/SemaDeclCXX.cpp (revision 6c05f3a74f30934ee60919cc97e16ec69b542b06)
1  //===------ SemaDeclCXX.cpp - Semantic Analysis for C++ Declarations ------===//
2  //
3  // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4  // See https://llvm.org/LICENSE.txt for license information.
5  // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6  //
7  //===----------------------------------------------------------------------===//
8  //
9  //  This file implements semantic analysis for C++ declarations.
10  //
11  //===----------------------------------------------------------------------===//
12  
13  #include "clang/AST/ASTConsumer.h"
14  #include "clang/AST/ASTContext.h"
15  #include "clang/AST/ASTLambda.h"
16  #include "clang/AST/ASTMutationListener.h"
17  #include "clang/AST/CXXInheritance.h"
18  #include "clang/AST/CharUnits.h"
19  #include "clang/AST/ComparisonCategories.h"
20  #include "clang/AST/DeclCXX.h"
21  #include "clang/AST/DeclTemplate.h"
22  #include "clang/AST/EvaluatedExprVisitor.h"
23  #include "clang/AST/Expr.h"
24  #include "clang/AST/ExprCXX.h"
25  #include "clang/AST/RecordLayout.h"
26  #include "clang/AST/RecursiveASTVisitor.h"
27  #include "clang/AST/StmtVisitor.h"
28  #include "clang/AST/TypeLoc.h"
29  #include "clang/AST/TypeOrdering.h"
30  #include "clang/Basic/AttributeCommonInfo.h"
31  #include "clang/Basic/PartialDiagnostic.h"
32  #include "clang/Basic/Specifiers.h"
33  #include "clang/Basic/TargetInfo.h"
34  #include "clang/Lex/LiteralSupport.h"
35  #include "clang/Lex/Preprocessor.h"
36  #include "clang/Sema/CXXFieldCollector.h"
37  #include "clang/Sema/DeclSpec.h"
38  #include "clang/Sema/EnterExpressionEvaluationContext.h"
39  #include "clang/Sema/Initialization.h"
40  #include "clang/Sema/Lookup.h"
41  #include "clang/Sema/Ownership.h"
42  #include "clang/Sema/ParsedTemplate.h"
43  #include "clang/Sema/Scope.h"
44  #include "clang/Sema/ScopeInfo.h"
45  #include "clang/Sema/SemaCUDA.h"
46  #include "clang/Sema/SemaInternal.h"
47  #include "clang/Sema/SemaObjC.h"
48  #include "clang/Sema/SemaOpenMP.h"
49  #include "clang/Sema/Template.h"
50  #include "llvm/ADT/ArrayRef.h"
51  #include "llvm/ADT/STLExtras.h"
52  #include "llvm/ADT/STLForwardCompat.h"
53  #include "llvm/ADT/ScopeExit.h"
54  #include "llvm/ADT/SmallString.h"
55  #include "llvm/ADT/StringExtras.h"
56  #include "llvm/Support/ConvertUTF.h"
57  #include "llvm/Support/SaveAndRestore.h"
58  #include <map>
59  #include <optional>
60  #include <set>
61  
62  using namespace clang;
63  
64  //===----------------------------------------------------------------------===//
65  // CheckDefaultArgumentVisitor
66  //===----------------------------------------------------------------------===//
67  
68  namespace {
69  /// CheckDefaultArgumentVisitor - C++ [dcl.fct.default] Traverses
70  /// the default argument of a parameter to determine whether it
71  /// contains any ill-formed subexpressions. For example, this will
72  /// diagnose the use of local variables or parameters within the
73  /// default argument expression.
74  class CheckDefaultArgumentVisitor
75      : public ConstStmtVisitor<CheckDefaultArgumentVisitor, bool> {
76    Sema &S;
77    const Expr *DefaultArg;
78  
79  public:
80    CheckDefaultArgumentVisitor(Sema &S, const Expr *DefaultArg)
81        : S(S), DefaultArg(DefaultArg) {}
82  
83    bool VisitExpr(const Expr *Node);
84    bool VisitDeclRefExpr(const DeclRefExpr *DRE);
85    bool VisitCXXThisExpr(const CXXThisExpr *ThisE);
86    bool VisitLambdaExpr(const LambdaExpr *Lambda);
87    bool VisitPseudoObjectExpr(const PseudoObjectExpr *POE);
88  };
89  
90  /// VisitExpr - Visit all of the children of this expression.
91  bool CheckDefaultArgumentVisitor::VisitExpr(const Expr *Node) {
92    bool IsInvalid = false;
93    for (const Stmt *SubStmt : Node->children())
94      if (SubStmt)
95        IsInvalid |= Visit(SubStmt);
96    return IsInvalid;
97  }
98  
99  /// VisitDeclRefExpr - Visit a reference to a declaration, to
100  /// determine whether this declaration can be used in the default
101  /// argument expression.
102  bool CheckDefaultArgumentVisitor::VisitDeclRefExpr(const DeclRefExpr *DRE) {
103    const ValueDecl *Decl = dyn_cast<ValueDecl>(DRE->getDecl());
104  
105    if (!isa<VarDecl, BindingDecl>(Decl))
106      return false;
107  
108    if (const auto *Param = dyn_cast<ParmVarDecl>(Decl)) {
109      // C++ [dcl.fct.default]p9:
110      //   [...] parameters of a function shall not be used in default
111      //   argument expressions, even if they are not evaluated. [...]
112      //
113      // C++17 [dcl.fct.default]p9 (by CWG 2082):
114      //   [...] A parameter shall not appear as a potentially-evaluated
115      //   expression in a default argument. [...]
116      //
117      if (DRE->isNonOdrUse() != NOUR_Unevaluated)
118        return S.Diag(DRE->getBeginLoc(),
119                      diag::err_param_default_argument_references_param)
120               << Param->getDeclName() << DefaultArg->getSourceRange();
121    } else if (auto *VD = Decl->getPotentiallyDecomposedVarDecl()) {
122      // C++ [dcl.fct.default]p7:
123      //   Local variables shall not be used in default argument
124      //   expressions.
125      //
126      // C++17 [dcl.fct.default]p7 (by CWG 2082):
127      //   A local variable shall not appear as a potentially-evaluated
128      //   expression in a default argument.
129      //
130      // C++20 [dcl.fct.default]p7 (DR as part of P0588R1, see also CWG 2346):
131      //   Note: A local variable cannot be odr-used (6.3) in a default
132      //   argument.
133      //
134      if (VD->isLocalVarDecl() && !DRE->isNonOdrUse())
135        return S.Diag(DRE->getBeginLoc(),
136                      diag::err_param_default_argument_references_local)
137               << Decl << DefaultArg->getSourceRange();
138    }
139    return false;
140  }
141  
142  /// VisitCXXThisExpr - Visit a C++ "this" expression.
143  bool CheckDefaultArgumentVisitor::VisitCXXThisExpr(const CXXThisExpr *ThisE) {
144    // C++ [dcl.fct.default]p8:
145    //   The keyword this shall not be used in a default argument of a
146    //   member function.
147    return S.Diag(ThisE->getBeginLoc(),
148                  diag::err_param_default_argument_references_this)
149           << ThisE->getSourceRange();
150  }
151  
152  bool CheckDefaultArgumentVisitor::VisitPseudoObjectExpr(
153      const PseudoObjectExpr *POE) {
154    bool Invalid = false;
155    for (const Expr *E : POE->semantics()) {
156      // Look through bindings.
157      if (const auto *OVE = dyn_cast<OpaqueValueExpr>(E)) {
158        E = OVE->getSourceExpr();
159        assert(E && "pseudo-object binding without source expression?");
160      }
161  
162      Invalid |= Visit(E);
163    }
164    return Invalid;
165  }
166  
167  bool CheckDefaultArgumentVisitor::VisitLambdaExpr(const LambdaExpr *Lambda) {
168    // [expr.prim.lambda.capture]p9
169    // a lambda-expression appearing in a default argument cannot implicitly or
170    // explicitly capture any local entity. Such a lambda-expression can still
171    // have an init-capture if any full-expression in its initializer satisfies
172    // the constraints of an expression appearing in a default argument.
173    bool Invalid = false;
174    for (const LambdaCapture &LC : Lambda->captures()) {
175      if (!Lambda->isInitCapture(&LC))
176        return S.Diag(LC.getLocation(), diag::err_lambda_capture_default_arg);
177      // Init captures are always VarDecl.
178      auto *D = cast<VarDecl>(LC.getCapturedVar());
179      Invalid |= Visit(D->getInit());
180    }
181    return Invalid;
182  }
183  } // namespace
184  
185  void
186  Sema::ImplicitExceptionSpecification::CalledDecl(SourceLocation CallLoc,
187                                                   const CXXMethodDecl *Method) {
188    // If we have an MSAny spec already, don't bother.
189    if (!Method || ComputedEST == EST_MSAny)
190      return;
191  
192    const FunctionProtoType *Proto
193      = Method->getType()->getAs<FunctionProtoType>();
194    Proto = Self->ResolveExceptionSpec(CallLoc, Proto);
195    if (!Proto)
196      return;
197  
198    ExceptionSpecificationType EST = Proto->getExceptionSpecType();
199  
200    // If we have a throw-all spec at this point, ignore the function.
201    if (ComputedEST == EST_None)
202      return;
203  
204    if (EST == EST_None && Method->hasAttr<NoThrowAttr>())
205      EST = EST_BasicNoexcept;
206  
207    switch (EST) {
208    case EST_Unparsed:
209    case EST_Uninstantiated:
210    case EST_Unevaluated:
211      llvm_unreachable("should not see unresolved exception specs here");
212  
213    // If this function can throw any exceptions, make a note of that.
214    case EST_MSAny:
215    case EST_None:
216      // FIXME: Whichever we see last of MSAny and None determines our result.
217      // We should make a consistent, order-independent choice here.
218      ClearExceptions();
219      ComputedEST = EST;
220      return;
221    case EST_NoexceptFalse:
222      ClearExceptions();
223      ComputedEST = EST_None;
224      return;
225    // FIXME: If the call to this decl is using any of its default arguments, we
226    // need to search them for potentially-throwing calls.
227    // If this function has a basic noexcept, it doesn't affect the outcome.
228    case EST_BasicNoexcept:
229    case EST_NoexceptTrue:
230    case EST_NoThrow:
231      return;
232    // If we're still at noexcept(true) and there's a throw() callee,
233    // change to that specification.
234    case EST_DynamicNone:
235      if (ComputedEST == EST_BasicNoexcept)
236        ComputedEST = EST_DynamicNone;
237      return;
238    case EST_DependentNoexcept:
239      llvm_unreachable(
240          "should not generate implicit declarations for dependent cases");
241    case EST_Dynamic:
242      break;
243    }
244    assert(EST == EST_Dynamic && "EST case not considered earlier.");
245    assert(ComputedEST != EST_None &&
246           "Shouldn't collect exceptions when throw-all is guaranteed.");
247    ComputedEST = EST_Dynamic;
248    // Record the exceptions in this function's exception specification.
249    for (const auto &E : Proto->exceptions())
250      if (ExceptionsSeen.insert(Self->Context.getCanonicalType(E)).second)
251        Exceptions.push_back(E);
252  }
253  
254  void Sema::ImplicitExceptionSpecification::CalledStmt(Stmt *S) {
255    if (!S || ComputedEST == EST_MSAny)
256      return;
257  
258    // FIXME:
259    //
260    // C++0x [except.spec]p14:
261    //   [An] implicit exception-specification specifies the type-id T if and
262    // only if T is allowed by the exception-specification of a function directly
263    // invoked by f's implicit definition; f shall allow all exceptions if any
264    // function it directly invokes allows all exceptions, and f shall allow no
265    // exceptions if every function it directly invokes allows no exceptions.
266    //
267    // Note in particular that if an implicit exception-specification is generated
268    // for a function containing a throw-expression, that specification can still
269    // be noexcept(true).
270    //
271    // Note also that 'directly invoked' is not defined in the standard, and there
272    // is no indication that we should only consider potentially-evaluated calls.
273    //
274    // Ultimately we should implement the intent of the standard: the exception
275    // specification should be the set of exceptions which can be thrown by the
276    // implicit definition. For now, we assume that any non-nothrow expression can
277    // throw any exception.
278  
279    if (Self->canThrow(S))
280      ComputedEST = EST_None;
281  }
282  
283  ExprResult Sema::ConvertParamDefaultArgument(ParmVarDecl *Param, Expr *Arg,
284                                               SourceLocation EqualLoc) {
285    if (RequireCompleteType(Param->getLocation(), Param->getType(),
286                            diag::err_typecheck_decl_incomplete_type))
287      return true;
288  
289    // C++ [dcl.fct.default]p5
290    //   A default argument expression is implicitly converted (clause
291    //   4) to the parameter type. The default argument expression has
292    //   the same semantic constraints as the initializer expression in
293    //   a declaration of a variable of the parameter type, using the
294    //   copy-initialization semantics (8.5).
295    InitializedEntity Entity = InitializedEntity::InitializeParameter(Context,
296                                                                      Param);
297    InitializationKind Kind = InitializationKind::CreateCopy(Param->getLocation(),
298                                                             EqualLoc);
299    InitializationSequence InitSeq(*this, Entity, Kind, Arg);
300    ExprResult Result = InitSeq.Perform(*this, Entity, Kind, Arg);
301    if (Result.isInvalid())
302      return true;
303    Arg = Result.getAs<Expr>();
304  
305    CheckCompletedExpr(Arg, EqualLoc);
306    Arg = MaybeCreateExprWithCleanups(Arg);
307  
308    return Arg;
309  }
310  
311  void Sema::SetParamDefaultArgument(ParmVarDecl *Param, Expr *Arg,
312                                     SourceLocation EqualLoc) {
313    // Add the default argument to the parameter
314    Param->setDefaultArg(Arg);
315  
316    // We have already instantiated this parameter; provide each of the
317    // instantiations with the uninstantiated default argument.
318    UnparsedDefaultArgInstantiationsMap::iterator InstPos
319      = UnparsedDefaultArgInstantiations.find(Param);
320    if (InstPos != UnparsedDefaultArgInstantiations.end()) {
321      for (unsigned I = 0, N = InstPos->second.size(); I != N; ++I)
322        InstPos->second[I]->setUninstantiatedDefaultArg(Arg);
323  
324      // We're done tracking this parameter's instantiations.
325      UnparsedDefaultArgInstantiations.erase(InstPos);
326    }
327  }
328  
329  void
330  Sema::ActOnParamDefaultArgument(Decl *param, SourceLocation EqualLoc,
331                                  Expr *DefaultArg) {
332    if (!param || !DefaultArg)
333      return;
334  
335    ParmVarDecl *Param = cast<ParmVarDecl>(param);
336    UnparsedDefaultArgLocs.erase(Param);
337  
338    // Default arguments are only permitted in C++
339    if (!getLangOpts().CPlusPlus) {
340      Diag(EqualLoc, diag::err_param_default_argument)
341        << DefaultArg->getSourceRange();
342      return ActOnParamDefaultArgumentError(param, EqualLoc, DefaultArg);
343    }
344  
345    // Check for unexpanded parameter packs.
346    if (DiagnoseUnexpandedParameterPack(DefaultArg, UPPC_DefaultArgument))
347      return ActOnParamDefaultArgumentError(param, EqualLoc, DefaultArg);
348  
349    // C++11 [dcl.fct.default]p3
350    //   A default argument expression [...] shall not be specified for a
351    //   parameter pack.
352    if (Param->isParameterPack()) {
353      Diag(EqualLoc, diag::err_param_default_argument_on_parameter_pack)
354          << DefaultArg->getSourceRange();
355      // Recover by discarding the default argument.
356      Param->setDefaultArg(nullptr);
357      return;
358    }
359  
360    ExprResult Result = ConvertParamDefaultArgument(Param, DefaultArg, EqualLoc);
361    if (Result.isInvalid())
362      return ActOnParamDefaultArgumentError(param, EqualLoc, DefaultArg);
363  
364    DefaultArg = Result.getAs<Expr>();
365  
366    // Check that the default argument is well-formed
367    CheckDefaultArgumentVisitor DefaultArgChecker(*this, DefaultArg);
368    if (DefaultArgChecker.Visit(DefaultArg))
369      return ActOnParamDefaultArgumentError(param, EqualLoc, DefaultArg);
370  
371    SetParamDefaultArgument(Param, DefaultArg, EqualLoc);
372  }
373  
374  void Sema::ActOnParamUnparsedDefaultArgument(Decl *param,
375                                               SourceLocation EqualLoc,
376                                               SourceLocation ArgLoc) {
377    if (!param)
378      return;
379  
380    ParmVarDecl *Param = cast<ParmVarDecl>(param);
381    Param->setUnparsedDefaultArg();
382    UnparsedDefaultArgLocs[Param] = ArgLoc;
383  }
384  
385  void Sema::ActOnParamDefaultArgumentError(Decl *param, SourceLocation EqualLoc,
386                                            Expr *DefaultArg) {
387    if (!param)
388      return;
389  
390    ParmVarDecl *Param = cast<ParmVarDecl>(param);
391    Param->setInvalidDecl();
392    UnparsedDefaultArgLocs.erase(Param);
393    ExprResult RE;
394    if (DefaultArg) {
395      RE = CreateRecoveryExpr(EqualLoc, DefaultArg->getEndLoc(), {DefaultArg},
396                              Param->getType().getNonReferenceType());
397    } else {
398      RE = CreateRecoveryExpr(EqualLoc, EqualLoc, {},
399                              Param->getType().getNonReferenceType());
400    }
401    Param->setDefaultArg(RE.get());
402  }
403  
404  void Sema::CheckExtraCXXDefaultArguments(Declarator &D) {
405    // C++ [dcl.fct.default]p3
406    //   A default argument expression shall be specified only in the
407    //   parameter-declaration-clause of a function declaration or in a
408    //   template-parameter (14.1). It shall not be specified for a
409    //   parameter pack. If it is specified in a
410    //   parameter-declaration-clause, it shall not occur within a
411    //   declarator or abstract-declarator of a parameter-declaration.
412    bool MightBeFunction = D.isFunctionDeclarationContext();
413    for (unsigned i = 0, e = D.getNumTypeObjects(); i != e; ++i) {
414      DeclaratorChunk &chunk = D.getTypeObject(i);
415      if (chunk.Kind == DeclaratorChunk::Function) {
416        if (MightBeFunction) {
417          // This is a function declaration. It can have default arguments, but
418          // keep looking in case its return type is a function type with default
419          // arguments.
420          MightBeFunction = false;
421          continue;
422        }
423        for (unsigned argIdx = 0, e = chunk.Fun.NumParams; argIdx != e;
424             ++argIdx) {
425          ParmVarDecl *Param = cast<ParmVarDecl>(chunk.Fun.Params[argIdx].Param);
426          if (Param->hasUnparsedDefaultArg()) {
427            std::unique_ptr<CachedTokens> Toks =
428                std::move(chunk.Fun.Params[argIdx].DefaultArgTokens);
429            SourceRange SR;
430            if (Toks->size() > 1)
431              SR = SourceRange((*Toks)[1].getLocation(),
432                               Toks->back().getLocation());
433            else
434              SR = UnparsedDefaultArgLocs[Param];
435            Diag(Param->getLocation(), diag::err_param_default_argument_nonfunc)
436              << SR;
437          } else if (Param->getDefaultArg()) {
438            Diag(Param->getLocation(), diag::err_param_default_argument_nonfunc)
439              << Param->getDefaultArg()->getSourceRange();
440            Param->setDefaultArg(nullptr);
441          }
442        }
443      } else if (chunk.Kind != DeclaratorChunk::Paren) {
444        MightBeFunction = false;
445      }
446    }
447  }
448  
449  static bool functionDeclHasDefaultArgument(const FunctionDecl *FD) {
450    return llvm::any_of(FD->parameters(), [](ParmVarDecl *P) {
451      return P->hasDefaultArg() && !P->hasInheritedDefaultArg();
452    });
453  }
454  
455  bool Sema::MergeCXXFunctionDecl(FunctionDecl *New, FunctionDecl *Old,
456                                  Scope *S) {
457    bool Invalid = false;
458  
459    // The declaration context corresponding to the scope is the semantic
460    // parent, unless this is a local function declaration, in which case
461    // it is that surrounding function.
462    DeclContext *ScopeDC = New->isLocalExternDecl()
463                               ? New->getLexicalDeclContext()
464                               : New->getDeclContext();
465  
466    // Find the previous declaration for the purpose of default arguments.
467    FunctionDecl *PrevForDefaultArgs = Old;
468    for (/**/; PrevForDefaultArgs;
469         // Don't bother looking back past the latest decl if this is a local
470         // extern declaration; nothing else could work.
471         PrevForDefaultArgs = New->isLocalExternDecl()
472                                  ? nullptr
473                                  : PrevForDefaultArgs->getPreviousDecl()) {
474      // Ignore hidden declarations.
475      if (!LookupResult::isVisible(*this, PrevForDefaultArgs))
476        continue;
477  
478      if (S && !isDeclInScope(PrevForDefaultArgs, ScopeDC, S) &&
479          !New->isCXXClassMember()) {
480        // Ignore default arguments of old decl if they are not in
481        // the same scope and this is not an out-of-line definition of
482        // a member function.
483        continue;
484      }
485  
486      if (PrevForDefaultArgs->isLocalExternDecl() != New->isLocalExternDecl()) {
487        // If only one of these is a local function declaration, then they are
488        // declared in different scopes, even though isDeclInScope may think
489        // they're in the same scope. (If both are local, the scope check is
490        // sufficient, and if neither is local, then they are in the same scope.)
491        continue;
492      }
493  
494      // We found the right previous declaration.
495      break;
496    }
497  
498    // C++ [dcl.fct.default]p4:
499    //   For non-template functions, default arguments can be added in
500    //   later declarations of a function in the same
501    //   scope. Declarations in different scopes have completely
502    //   distinct sets of default arguments. That is, declarations in
503    //   inner scopes do not acquire default arguments from
504    //   declarations in outer scopes, and vice versa. In a given
505    //   function declaration, all parameters subsequent to a
506    //   parameter with a default argument shall have default
507    //   arguments supplied in this or previous declarations. A
508    //   default argument shall not be redefined by a later
509    //   declaration (not even to the same value).
510    //
511    // C++ [dcl.fct.default]p6:
512    //   Except for member functions of class templates, the default arguments
513    //   in a member function definition that appears outside of the class
514    //   definition are added to the set of default arguments provided by the
515    //   member function declaration in the class definition.
516    for (unsigned p = 0, NumParams = PrevForDefaultArgs
517                                         ? PrevForDefaultArgs->getNumParams()
518                                         : 0;
519         p < NumParams; ++p) {
520      ParmVarDecl *OldParam = PrevForDefaultArgs->getParamDecl(p);
521      ParmVarDecl *NewParam = New->getParamDecl(p);
522  
523      bool OldParamHasDfl = OldParam ? OldParam->hasDefaultArg() : false;
524      bool NewParamHasDfl = NewParam->hasDefaultArg();
525  
526      if (OldParamHasDfl && NewParamHasDfl) {
527        unsigned DiagDefaultParamID =
528          diag::err_param_default_argument_redefinition;
529  
530        // MSVC accepts that default parameters be redefined for member functions
531        // of template class. The new default parameter's value is ignored.
532        Invalid = true;
533        if (getLangOpts().MicrosoftExt) {
534          CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(New);
535          if (MD && MD->getParent()->getDescribedClassTemplate()) {
536            // Merge the old default argument into the new parameter.
537            NewParam->setHasInheritedDefaultArg();
538            if (OldParam->hasUninstantiatedDefaultArg())
539              NewParam->setUninstantiatedDefaultArg(
540                                        OldParam->getUninstantiatedDefaultArg());
541            else
542              NewParam->setDefaultArg(OldParam->getInit());
543            DiagDefaultParamID = diag::ext_param_default_argument_redefinition;
544            Invalid = false;
545          }
546        }
547  
548        // FIXME: If we knew where the '=' was, we could easily provide a fix-it
549        // hint here. Alternatively, we could walk the type-source information
550        // for NewParam to find the last source location in the type... but it
551        // isn't worth the effort right now. This is the kind of test case that
552        // is hard to get right:
553        //   int f(int);
554        //   void g(int (*fp)(int) = f);
555        //   void g(int (*fp)(int) = &f);
556        Diag(NewParam->getLocation(), DiagDefaultParamID)
557          << NewParam->getDefaultArgRange();
558  
559        // Look for the function declaration where the default argument was
560        // actually written, which may be a declaration prior to Old.
561        for (auto Older = PrevForDefaultArgs;
562             OldParam->hasInheritedDefaultArg(); /**/) {
563          Older = Older->getPreviousDecl();
564          OldParam = Older->getParamDecl(p);
565        }
566  
567        Diag(OldParam->getLocation(), diag::note_previous_definition)
568          << OldParam->getDefaultArgRange();
569      } else if (OldParamHasDfl) {
570        // Merge the old default argument into the new parameter unless the new
571        // function is a friend declaration in a template class. In the latter
572        // case the default arguments will be inherited when the friend
573        // declaration will be instantiated.
574        if (New->getFriendObjectKind() == Decl::FOK_None ||
575            !New->getLexicalDeclContext()->isDependentContext()) {
576          // It's important to use getInit() here;  getDefaultArg()
577          // strips off any top-level ExprWithCleanups.
578          NewParam->setHasInheritedDefaultArg();
579          if (OldParam->hasUnparsedDefaultArg())
580            NewParam->setUnparsedDefaultArg();
581          else if (OldParam->hasUninstantiatedDefaultArg())
582            NewParam->setUninstantiatedDefaultArg(
583                                         OldParam->getUninstantiatedDefaultArg());
584          else
585            NewParam->setDefaultArg(OldParam->getInit());
586        }
587      } else if (NewParamHasDfl) {
588        if (New->getDescribedFunctionTemplate()) {
589          // Paragraph 4, quoted above, only applies to non-template functions.
590          Diag(NewParam->getLocation(),
591               diag::err_param_default_argument_template_redecl)
592            << NewParam->getDefaultArgRange();
593          Diag(PrevForDefaultArgs->getLocation(),
594               diag::note_template_prev_declaration)
595              << false;
596        } else if (New->getTemplateSpecializationKind()
597                     != TSK_ImplicitInstantiation &&
598                   New->getTemplateSpecializationKind() != TSK_Undeclared) {
599          // C++ [temp.expr.spec]p21:
600          //   Default function arguments shall not be specified in a declaration
601          //   or a definition for one of the following explicit specializations:
602          //     - the explicit specialization of a function template;
603          //     - the explicit specialization of a member function template;
604          //     - the explicit specialization of a member function of a class
605          //       template where the class template specialization to which the
606          //       member function specialization belongs is implicitly
607          //       instantiated.
608          Diag(NewParam->getLocation(), diag::err_template_spec_default_arg)
609            << (New->getTemplateSpecializationKind() ==TSK_ExplicitSpecialization)
610            << New->getDeclName()
611            << NewParam->getDefaultArgRange();
612        } else if (New->getDeclContext()->isDependentContext()) {
613          // C++ [dcl.fct.default]p6 (DR217):
614          //   Default arguments for a member function of a class template shall
615          //   be specified on the initial declaration of the member function
616          //   within the class template.
617          //
618          // Reading the tea leaves a bit in DR217 and its reference to DR205
619          // leads me to the conclusion that one cannot add default function
620          // arguments for an out-of-line definition of a member function of a
621          // dependent type.
622          int WhichKind = 2;
623          if (CXXRecordDecl *Record
624                = dyn_cast<CXXRecordDecl>(New->getDeclContext())) {
625            if (Record->getDescribedClassTemplate())
626              WhichKind = 0;
627            else if (isa<ClassTemplatePartialSpecializationDecl>(Record))
628              WhichKind = 1;
629            else
630              WhichKind = 2;
631          }
632  
633          Diag(NewParam->getLocation(),
634               diag::err_param_default_argument_member_template_redecl)
635            << WhichKind
636            << NewParam->getDefaultArgRange();
637        }
638      }
639    }
640  
641    // DR1344: If a default argument is added outside a class definition and that
642    // default argument makes the function a special member function, the program
643    // is ill-formed. This can only happen for constructors.
644    if (isa<CXXConstructorDecl>(New) &&
645        New->getMinRequiredArguments() < Old->getMinRequiredArguments()) {
646      CXXSpecialMemberKind NewSM = getSpecialMember(cast<CXXMethodDecl>(New)),
647                           OldSM = getSpecialMember(cast<CXXMethodDecl>(Old));
648      if (NewSM != OldSM) {
649        ParmVarDecl *NewParam = New->getParamDecl(New->getMinRequiredArguments());
650        assert(NewParam->hasDefaultArg());
651        Diag(NewParam->getLocation(), diag::err_default_arg_makes_ctor_special)
652            << NewParam->getDefaultArgRange() << llvm::to_underlying(NewSM);
653        Diag(Old->getLocation(), diag::note_previous_declaration);
654      }
655    }
656  
657    const FunctionDecl *Def;
658    // C++11 [dcl.constexpr]p1: If any declaration of a function or function
659    // template has a constexpr specifier then all its declarations shall
660    // contain the constexpr specifier.
661    if (New->getConstexprKind() != Old->getConstexprKind()) {
662      Diag(New->getLocation(), diag::err_constexpr_redecl_mismatch)
663          << New << static_cast<int>(New->getConstexprKind())
664          << static_cast<int>(Old->getConstexprKind());
665      Diag(Old->getLocation(), diag::note_previous_declaration);
666      Invalid = true;
667    } else if (!Old->getMostRecentDecl()->isInlined() && New->isInlined() &&
668               Old->isDefined(Def) &&
669               // If a friend function is inlined but does not have 'inline'
670               // specifier, it is a definition. Do not report attribute conflict
671               // in this case, redefinition will be diagnosed later.
672               (New->isInlineSpecified() ||
673                New->getFriendObjectKind() == Decl::FOK_None)) {
674      // C++11 [dcl.fcn.spec]p4:
675      //   If the definition of a function appears in a translation unit before its
676      //   first declaration as inline, the program is ill-formed.
677      Diag(New->getLocation(), diag::err_inline_decl_follows_def) << New;
678      Diag(Def->getLocation(), diag::note_previous_definition);
679      Invalid = true;
680    }
681  
682    // C++17 [temp.deduct.guide]p3:
683    //   Two deduction guide declarations in the same translation unit
684    //   for the same class template shall not have equivalent
685    //   parameter-declaration-clauses.
686    if (isa<CXXDeductionGuideDecl>(New) &&
687        !New->isFunctionTemplateSpecialization() && isVisible(Old)) {
688      Diag(New->getLocation(), diag::err_deduction_guide_redeclared);
689      Diag(Old->getLocation(), diag::note_previous_declaration);
690    }
691  
692    // C++11 [dcl.fct.default]p4: If a friend declaration specifies a default
693    // argument expression, that declaration shall be a definition and shall be
694    // the only declaration of the function or function template in the
695    // translation unit.
696    if (Old->getFriendObjectKind() == Decl::FOK_Undeclared &&
697        functionDeclHasDefaultArgument(Old)) {
698      Diag(New->getLocation(), diag::err_friend_decl_with_def_arg_redeclared);
699      Diag(Old->getLocation(), diag::note_previous_declaration);
700      Invalid = true;
701    }
702  
703    // C++11 [temp.friend]p4 (DR329):
704    //   When a function is defined in a friend function declaration in a class
705    //   template, the function is instantiated when the function is odr-used.
706    //   The same restrictions on multiple declarations and definitions that
707    //   apply to non-template function declarations and definitions also apply
708    //   to these implicit definitions.
709    const FunctionDecl *OldDefinition = nullptr;
710    if (New->isThisDeclarationInstantiatedFromAFriendDefinition() &&
711        Old->isDefined(OldDefinition, true))
712      CheckForFunctionRedefinition(New, OldDefinition);
713  
714    return Invalid;
715  }
716  
717  void Sema::DiagPlaceholderVariableDefinition(SourceLocation Loc) {
718    Diag(Loc, getLangOpts().CPlusPlus26
719                  ? diag::warn_cxx23_placeholder_var_definition
720                  : diag::ext_placeholder_var_definition);
721  }
722  
723  NamedDecl *
724  Sema::ActOnDecompositionDeclarator(Scope *S, Declarator &D,
725                                     MultiTemplateParamsArg TemplateParamLists) {
726    assert(D.isDecompositionDeclarator());
727    const DecompositionDeclarator &Decomp = D.getDecompositionDeclarator();
728  
729    // The syntax only allows a decomposition declarator as a simple-declaration,
730    // a for-range-declaration, or a condition in Clang, but we parse it in more
731    // cases than that.
732    if (!D.mayHaveDecompositionDeclarator()) {
733      Diag(Decomp.getLSquareLoc(), diag::err_decomp_decl_context)
734        << Decomp.getSourceRange();
735      return nullptr;
736    }
737  
738    if (!TemplateParamLists.empty()) {
739      // FIXME: There's no rule against this, but there are also no rules that
740      // would actually make it usable, so we reject it for now.
741      Diag(TemplateParamLists.front()->getTemplateLoc(),
742           diag::err_decomp_decl_template);
743      return nullptr;
744    }
745  
746    Diag(Decomp.getLSquareLoc(),
747         !getLangOpts().CPlusPlus17
748             ? diag::ext_decomp_decl
749             : D.getContext() == DeclaratorContext::Condition
750                   ? diag::ext_decomp_decl_cond
751                   : diag::warn_cxx14_compat_decomp_decl)
752        << Decomp.getSourceRange();
753  
754    // The semantic context is always just the current context.
755    DeclContext *const DC = CurContext;
756  
757    // C++17 [dcl.dcl]/8:
758    //   The decl-specifier-seq shall contain only the type-specifier auto
759    //   and cv-qualifiers.
760    // C++20 [dcl.dcl]/8:
761    //   If decl-specifier-seq contains any decl-specifier other than static,
762    //   thread_local, auto, or cv-qualifiers, the program is ill-formed.
763    // C++23 [dcl.pre]/6:
764    //   Each decl-specifier in the decl-specifier-seq shall be static,
765    //   thread_local, auto (9.2.9.6 [dcl.spec.auto]), or a cv-qualifier.
766    auto &DS = D.getDeclSpec();
767    {
768      // Note: While constrained-auto needs to be checked, we do so separately so
769      // we can emit a better diagnostic.
770      SmallVector<StringRef, 8> BadSpecifiers;
771      SmallVector<SourceLocation, 8> BadSpecifierLocs;
772      SmallVector<StringRef, 8> CPlusPlus20Specifiers;
773      SmallVector<SourceLocation, 8> CPlusPlus20SpecifierLocs;
774      if (auto SCS = DS.getStorageClassSpec()) {
775        if (SCS == DeclSpec::SCS_static) {
776          CPlusPlus20Specifiers.push_back(DeclSpec::getSpecifierName(SCS));
777          CPlusPlus20SpecifierLocs.push_back(DS.getStorageClassSpecLoc());
778        } else {
779          BadSpecifiers.push_back(DeclSpec::getSpecifierName(SCS));
780          BadSpecifierLocs.push_back(DS.getStorageClassSpecLoc());
781        }
782      }
783      if (auto TSCS = DS.getThreadStorageClassSpec()) {
784        CPlusPlus20Specifiers.push_back(DeclSpec::getSpecifierName(TSCS));
785        CPlusPlus20SpecifierLocs.push_back(DS.getThreadStorageClassSpecLoc());
786      }
787      if (DS.hasConstexprSpecifier()) {
788        BadSpecifiers.push_back(
789            DeclSpec::getSpecifierName(DS.getConstexprSpecifier()));
790        BadSpecifierLocs.push_back(DS.getConstexprSpecLoc());
791      }
792      if (DS.isInlineSpecified()) {
793        BadSpecifiers.push_back("inline");
794        BadSpecifierLocs.push_back(DS.getInlineSpecLoc());
795      }
796  
797      if (!BadSpecifiers.empty()) {
798        auto &&Err = Diag(BadSpecifierLocs.front(), diag::err_decomp_decl_spec);
799        Err << (int)BadSpecifiers.size()
800            << llvm::join(BadSpecifiers.begin(), BadSpecifiers.end(), " ");
801        // Don't add FixItHints to remove the specifiers; we do still respect
802        // them when building the underlying variable.
803        for (auto Loc : BadSpecifierLocs)
804          Err << SourceRange(Loc, Loc);
805      } else if (!CPlusPlus20Specifiers.empty()) {
806        auto &&Warn = Diag(CPlusPlus20SpecifierLocs.front(),
807                           getLangOpts().CPlusPlus20
808                               ? diag::warn_cxx17_compat_decomp_decl_spec
809                               : diag::ext_decomp_decl_spec);
810        Warn << (int)CPlusPlus20Specifiers.size()
811             << llvm::join(CPlusPlus20Specifiers.begin(),
812                           CPlusPlus20Specifiers.end(), " ");
813        for (auto Loc : CPlusPlus20SpecifierLocs)
814          Warn << SourceRange(Loc, Loc);
815      }
816      // We can't recover from it being declared as a typedef.
817      if (DS.getStorageClassSpec() == DeclSpec::SCS_typedef)
818        return nullptr;
819    }
820  
821    // C++2a [dcl.struct.bind]p1:
822    //   A cv that includes volatile is deprecated
823    if ((DS.getTypeQualifiers() & DeclSpec::TQ_volatile) &&
824        getLangOpts().CPlusPlus20)
825      Diag(DS.getVolatileSpecLoc(),
826           diag::warn_deprecated_volatile_structured_binding);
827  
828    TypeSourceInfo *TInfo = GetTypeForDeclarator(D);
829    QualType R = TInfo->getType();
830  
831    if (DiagnoseUnexpandedParameterPack(D.getIdentifierLoc(), TInfo,
832                                        UPPC_DeclarationType))
833      D.setInvalidType();
834  
835    // The syntax only allows a single ref-qualifier prior to the decomposition
836    // declarator. No other declarator chunks are permitted. Also check the type
837    // specifier here.
838    if (DS.getTypeSpecType() != DeclSpec::TST_auto ||
839        D.hasGroupingParens() || D.getNumTypeObjects() > 1 ||
840        (D.getNumTypeObjects() == 1 &&
841         D.getTypeObject(0).Kind != DeclaratorChunk::Reference)) {
842      Diag(Decomp.getLSquareLoc(),
843           (D.hasGroupingParens() ||
844            (D.getNumTypeObjects() &&
845             D.getTypeObject(0).Kind == DeclaratorChunk::Paren))
846               ? diag::err_decomp_decl_parens
847               : diag::err_decomp_decl_type)
848          << R;
849  
850      // In most cases, there's no actual problem with an explicitly-specified
851      // type, but a function type won't work here, and ActOnVariableDeclarator
852      // shouldn't be called for such a type.
853      if (R->isFunctionType())
854        D.setInvalidType();
855    }
856  
857    // Constrained auto is prohibited by [decl.pre]p6, so check that here.
858    if (DS.isConstrainedAuto()) {
859      TemplateIdAnnotation *TemplRep = DS.getRepAsTemplateId();
860      assert(TemplRep->Kind == TNK_Concept_template &&
861             "No other template kind should be possible for a constrained auto");
862  
863      SourceRange TemplRange{TemplRep->TemplateNameLoc,
864                             TemplRep->RAngleLoc.isValid()
865                                 ? TemplRep->RAngleLoc
866                                 : TemplRep->TemplateNameLoc};
867      Diag(TemplRep->TemplateNameLoc, diag::err_decomp_decl_constraint)
868          << TemplRange << FixItHint::CreateRemoval(TemplRange);
869    }
870  
871    // Build the BindingDecls.
872    SmallVector<BindingDecl*, 8> Bindings;
873  
874    // Build the BindingDecls.
875    for (auto &B : D.getDecompositionDeclarator().bindings()) {
876      // Check for name conflicts.
877      DeclarationNameInfo NameInfo(B.Name, B.NameLoc);
878      IdentifierInfo *VarName = B.Name;
879      assert(VarName && "Cannot have an unnamed binding declaration");
880  
881      LookupResult Previous(*this, NameInfo, LookupOrdinaryName,
882                            RedeclarationKind::ForVisibleRedeclaration);
883      LookupName(Previous, S,
884                 /*CreateBuiltins*/DC->getRedeclContext()->isTranslationUnit());
885  
886      // It's not permitted to shadow a template parameter name.
887      if (Previous.isSingleResult() &&
888          Previous.getFoundDecl()->isTemplateParameter()) {
889        DiagnoseTemplateParameterShadow(D.getIdentifierLoc(),
890                                        Previous.getFoundDecl());
891        Previous.clear();
892      }
893  
894      auto *BD = BindingDecl::Create(Context, DC, B.NameLoc, VarName);
895  
896      ProcessDeclAttributeList(S, BD, *B.Attrs);
897  
898      // Find the shadowed declaration before filtering for scope.
899      NamedDecl *ShadowedDecl = D.getCXXScopeSpec().isEmpty()
900                                    ? getShadowedDeclaration(BD, Previous)
901                                    : nullptr;
902  
903      bool ConsiderLinkage = DC->isFunctionOrMethod() &&
904                             DS.getStorageClassSpec() == DeclSpec::SCS_extern;
905      FilterLookupForScope(Previous, DC, S, ConsiderLinkage,
906                           /*AllowInlineNamespace*/false);
907  
908      bool IsPlaceholder = DS.getStorageClassSpec() != DeclSpec::SCS_static &&
909                           DC->isFunctionOrMethod() && VarName->isPlaceholder();
910      if (!Previous.empty()) {
911        if (IsPlaceholder) {
912          bool sameDC = (Previous.end() - 1)
913                            ->getDeclContext()
914                            ->getRedeclContext()
915                            ->Equals(DC->getRedeclContext());
916          if (sameDC &&
917              isDeclInScope(*(Previous.end() - 1), CurContext, S, false)) {
918            Previous.clear();
919            DiagPlaceholderVariableDefinition(B.NameLoc);
920          }
921        } else {
922          auto *Old = Previous.getRepresentativeDecl();
923          Diag(B.NameLoc, diag::err_redefinition) << B.Name;
924          Diag(Old->getLocation(), diag::note_previous_definition);
925        }
926      } else if (ShadowedDecl && !D.isRedeclaration()) {
927        CheckShadow(BD, ShadowedDecl, Previous);
928      }
929      PushOnScopeChains(BD, S, true);
930      Bindings.push_back(BD);
931      ParsingInitForAutoVars.insert(BD);
932    }
933  
934    // There are no prior lookup results for the variable itself, because it
935    // is unnamed.
936    DeclarationNameInfo NameInfo((IdentifierInfo *)nullptr,
937                                 Decomp.getLSquareLoc());
938    LookupResult Previous(*this, NameInfo, LookupOrdinaryName,
939                          RedeclarationKind::ForVisibleRedeclaration);
940  
941    // Build the variable that holds the non-decomposed object.
942    bool AddToScope = true;
943    NamedDecl *New =
944        ActOnVariableDeclarator(S, D, DC, TInfo, Previous,
945                                MultiTemplateParamsArg(), AddToScope, Bindings);
946    if (AddToScope) {
947      S->AddDecl(New);
948      CurContext->addHiddenDecl(New);
949    }
950  
951    if (OpenMP().isInOpenMPDeclareTargetContext())
952      OpenMP().checkDeclIsAllowedInOpenMPTarget(nullptr, New);
953  
954    return New;
955  }
956  
957  static bool checkSimpleDecomposition(
958      Sema &S, ArrayRef<BindingDecl *> Bindings, ValueDecl *Src,
959      QualType DecompType, const llvm::APSInt &NumElems, QualType ElemType,
960      llvm::function_ref<ExprResult(SourceLocation, Expr *, unsigned)> GetInit) {
961    if ((int64_t)Bindings.size() != NumElems) {
962      S.Diag(Src->getLocation(), diag::err_decomp_decl_wrong_number_bindings)
963          << DecompType << (unsigned)Bindings.size()
964          << (unsigned)NumElems.getLimitedValue(UINT_MAX)
965          << toString(NumElems, 10) << (NumElems < Bindings.size());
966      return true;
967    }
968  
969    unsigned I = 0;
970    for (auto *B : Bindings) {
971      SourceLocation Loc = B->getLocation();
972      ExprResult E = S.BuildDeclRefExpr(Src, DecompType, VK_LValue, Loc);
973      if (E.isInvalid())
974        return true;
975      E = GetInit(Loc, E.get(), I++);
976      if (E.isInvalid())
977        return true;
978      B->setBinding(ElemType, E.get());
979    }
980  
981    return false;
982  }
983  
984  static bool checkArrayLikeDecomposition(Sema &S,
985                                          ArrayRef<BindingDecl *> Bindings,
986                                          ValueDecl *Src, QualType DecompType,
987                                          const llvm::APSInt &NumElems,
988                                          QualType ElemType) {
989    return checkSimpleDecomposition(
990        S, Bindings, Src, DecompType, NumElems, ElemType,
991        [&](SourceLocation Loc, Expr *Base, unsigned I) -> ExprResult {
992          ExprResult E = S.ActOnIntegerConstant(Loc, I);
993          if (E.isInvalid())
994            return ExprError();
995          return S.CreateBuiltinArraySubscriptExpr(Base, Loc, E.get(), Loc);
996        });
997  }
998  
999  static bool checkArrayDecomposition(Sema &S, ArrayRef<BindingDecl*> Bindings,
1000                                      ValueDecl *Src, QualType DecompType,
1001                                      const ConstantArrayType *CAT) {
1002    return checkArrayLikeDecomposition(S, Bindings, Src, DecompType,
1003                                       llvm::APSInt(CAT->getSize()),
1004                                       CAT->getElementType());
1005  }
1006  
1007  static bool checkVectorDecomposition(Sema &S, ArrayRef<BindingDecl*> Bindings,
1008                                       ValueDecl *Src, QualType DecompType,
1009                                       const VectorType *VT) {
1010    return checkArrayLikeDecomposition(
1011        S, Bindings, Src, DecompType, llvm::APSInt::get(VT->getNumElements()),
1012        S.Context.getQualifiedType(VT->getElementType(),
1013                                   DecompType.getQualifiers()));
1014  }
1015  
1016  static bool checkComplexDecomposition(Sema &S,
1017                                        ArrayRef<BindingDecl *> Bindings,
1018                                        ValueDecl *Src, QualType DecompType,
1019                                        const ComplexType *CT) {
1020    return checkSimpleDecomposition(
1021        S, Bindings, Src, DecompType, llvm::APSInt::get(2),
1022        S.Context.getQualifiedType(CT->getElementType(),
1023                                   DecompType.getQualifiers()),
1024        [&](SourceLocation Loc, Expr *Base, unsigned I) -> ExprResult {
1025          return S.CreateBuiltinUnaryOp(Loc, I ? UO_Imag : UO_Real, Base);
1026        });
1027  }
1028  
1029  static std::string printTemplateArgs(const PrintingPolicy &PrintingPolicy,
1030                                       TemplateArgumentListInfo &Args,
1031                                       const TemplateParameterList *Params) {
1032    SmallString<128> SS;
1033    llvm::raw_svector_ostream OS(SS);
1034    bool First = true;
1035    unsigned I = 0;
1036    for (auto &Arg : Args.arguments()) {
1037      if (!First)
1038        OS << ", ";
1039      Arg.getArgument().print(PrintingPolicy, OS,
1040                              TemplateParameterList::shouldIncludeTypeForArgument(
1041                                  PrintingPolicy, Params, I));
1042      First = false;
1043      I++;
1044    }
1045    return std::string(OS.str());
1046  }
1047  
1048  static bool lookupStdTypeTraitMember(Sema &S, LookupResult &TraitMemberLookup,
1049                                       SourceLocation Loc, StringRef Trait,
1050                                       TemplateArgumentListInfo &Args,
1051                                       unsigned DiagID) {
1052    auto DiagnoseMissing = [&] {
1053      if (DiagID)
1054        S.Diag(Loc, DiagID) << printTemplateArgs(S.Context.getPrintingPolicy(),
1055                                                 Args, /*Params*/ nullptr);
1056      return true;
1057    };
1058  
1059    // FIXME: Factor out duplication with lookupPromiseType in SemaCoroutine.
1060    NamespaceDecl *Std = S.getStdNamespace();
1061    if (!Std)
1062      return DiagnoseMissing();
1063  
1064    // Look up the trait itself, within namespace std. We can diagnose various
1065    // problems with this lookup even if we've been asked to not diagnose a
1066    // missing specialization, because this can only fail if the user has been
1067    // declaring their own names in namespace std or we don't support the
1068    // standard library implementation in use.
1069    LookupResult Result(S, &S.PP.getIdentifierTable().get(Trait),
1070                        Loc, Sema::LookupOrdinaryName);
1071    if (!S.LookupQualifiedName(Result, Std))
1072      return DiagnoseMissing();
1073    if (Result.isAmbiguous())
1074      return true;
1075  
1076    ClassTemplateDecl *TraitTD = Result.getAsSingle<ClassTemplateDecl>();
1077    if (!TraitTD) {
1078      Result.suppressDiagnostics();
1079      NamedDecl *Found = *Result.begin();
1080      S.Diag(Loc, diag::err_std_type_trait_not_class_template) << Trait;
1081      S.Diag(Found->getLocation(), diag::note_declared_at);
1082      return true;
1083    }
1084  
1085    // Build the template-id.
1086    QualType TraitTy = S.CheckTemplateIdType(TemplateName(TraitTD), Loc, Args);
1087    if (TraitTy.isNull())
1088      return true;
1089    if (!S.isCompleteType(Loc, TraitTy)) {
1090      if (DiagID)
1091        S.RequireCompleteType(
1092            Loc, TraitTy, DiagID,
1093            printTemplateArgs(S.Context.getPrintingPolicy(), Args,
1094                              TraitTD->getTemplateParameters()));
1095      return true;
1096    }
1097  
1098    CXXRecordDecl *RD = TraitTy->getAsCXXRecordDecl();
1099    assert(RD && "specialization of class template is not a class?");
1100  
1101    // Look up the member of the trait type.
1102    S.LookupQualifiedName(TraitMemberLookup, RD);
1103    return TraitMemberLookup.isAmbiguous();
1104  }
1105  
1106  static TemplateArgumentLoc
1107  getTrivialIntegralTemplateArgument(Sema &S, SourceLocation Loc, QualType T,
1108                                     uint64_t I) {
1109    TemplateArgument Arg(S.Context, S.Context.MakeIntValue(I, T), T);
1110    return S.getTrivialTemplateArgumentLoc(Arg, T, Loc);
1111  }
1112  
1113  static TemplateArgumentLoc
1114  getTrivialTypeTemplateArgument(Sema &S, SourceLocation Loc, QualType T) {
1115    return S.getTrivialTemplateArgumentLoc(TemplateArgument(T), QualType(), Loc);
1116  }
1117  
1118  namespace { enum class IsTupleLike { TupleLike, NotTupleLike, Error }; }
1119  
1120  static IsTupleLike isTupleLike(Sema &S, SourceLocation Loc, QualType T,
1121                                 llvm::APSInt &Size) {
1122    EnterExpressionEvaluationContext ContextRAII(
1123        S, Sema::ExpressionEvaluationContext::ConstantEvaluated);
1124  
1125    DeclarationName Value = S.PP.getIdentifierInfo("value");
1126    LookupResult R(S, Value, Loc, Sema::LookupOrdinaryName);
1127  
1128    // Form template argument list for tuple_size<T>.
1129    TemplateArgumentListInfo Args(Loc, Loc);
1130    Args.addArgument(getTrivialTypeTemplateArgument(S, Loc, T));
1131  
1132    // If there's no tuple_size specialization or the lookup of 'value' is empty,
1133    // it's not tuple-like.
1134    if (lookupStdTypeTraitMember(S, R, Loc, "tuple_size", Args, /*DiagID*/ 0) ||
1135        R.empty())
1136      return IsTupleLike::NotTupleLike;
1137  
1138    // If we get this far, we've committed to the tuple interpretation, but
1139    // we can still fail if there actually isn't a usable ::value.
1140  
1141    struct ICEDiagnoser : Sema::VerifyICEDiagnoser {
1142      LookupResult &R;
1143      TemplateArgumentListInfo &Args;
1144      ICEDiagnoser(LookupResult &R, TemplateArgumentListInfo &Args)
1145          : R(R), Args(Args) {}
1146      Sema::SemaDiagnosticBuilder diagnoseNotICE(Sema &S,
1147                                                 SourceLocation Loc) override {
1148        return S.Diag(Loc, diag::err_decomp_decl_std_tuple_size_not_constant)
1149               << printTemplateArgs(S.Context.getPrintingPolicy(), Args,
1150                                    /*Params*/ nullptr);
1151      }
1152    } Diagnoser(R, Args);
1153  
1154    ExprResult E =
1155        S.BuildDeclarationNameExpr(CXXScopeSpec(), R, /*NeedsADL*/false);
1156    if (E.isInvalid())
1157      return IsTupleLike::Error;
1158  
1159    E = S.VerifyIntegerConstantExpression(E.get(), &Size, Diagnoser);
1160    if (E.isInvalid())
1161      return IsTupleLike::Error;
1162  
1163    return IsTupleLike::TupleLike;
1164  }
1165  
1166  /// \return std::tuple_element<I, T>::type.
1167  static QualType getTupleLikeElementType(Sema &S, SourceLocation Loc,
1168                                          unsigned I, QualType T) {
1169    // Form template argument list for tuple_element<I, T>.
1170    TemplateArgumentListInfo Args(Loc, Loc);
1171    Args.addArgument(
1172        getTrivialIntegralTemplateArgument(S, Loc, S.Context.getSizeType(), I));
1173    Args.addArgument(getTrivialTypeTemplateArgument(S, Loc, T));
1174  
1175    DeclarationName TypeDN = S.PP.getIdentifierInfo("type");
1176    LookupResult R(S, TypeDN, Loc, Sema::LookupOrdinaryName);
1177    if (lookupStdTypeTraitMember(
1178            S, R, Loc, "tuple_element", Args,
1179            diag::err_decomp_decl_std_tuple_element_not_specialized))
1180      return QualType();
1181  
1182    auto *TD = R.getAsSingle<TypeDecl>();
1183    if (!TD) {
1184      R.suppressDiagnostics();
1185      S.Diag(Loc, diag::err_decomp_decl_std_tuple_element_not_specialized)
1186          << printTemplateArgs(S.Context.getPrintingPolicy(), Args,
1187                               /*Params*/ nullptr);
1188      if (!R.empty())
1189        S.Diag(R.getRepresentativeDecl()->getLocation(), diag::note_declared_at);
1190      return QualType();
1191    }
1192  
1193    return S.Context.getTypeDeclType(TD);
1194  }
1195  
1196  namespace {
1197  struct InitializingBinding {
1198    Sema &S;
1199    InitializingBinding(Sema &S, BindingDecl *BD) : S(S) {
1200      Sema::CodeSynthesisContext Ctx;
1201      Ctx.Kind = Sema::CodeSynthesisContext::InitializingStructuredBinding;
1202      Ctx.PointOfInstantiation = BD->getLocation();
1203      Ctx.Entity = BD;
1204      S.pushCodeSynthesisContext(Ctx);
1205    }
1206    ~InitializingBinding() {
1207      S.popCodeSynthesisContext();
1208    }
1209  };
1210  }
1211  
1212  static bool checkTupleLikeDecomposition(Sema &S,
1213                                          ArrayRef<BindingDecl *> Bindings,
1214                                          VarDecl *Src, QualType DecompType,
1215                                          const llvm::APSInt &TupleSize) {
1216    if ((int64_t)Bindings.size() != TupleSize) {
1217      S.Diag(Src->getLocation(), diag::err_decomp_decl_wrong_number_bindings)
1218          << DecompType << (unsigned)Bindings.size()
1219          << (unsigned)TupleSize.getLimitedValue(UINT_MAX)
1220          << toString(TupleSize, 10) << (TupleSize < Bindings.size());
1221      return true;
1222    }
1223  
1224    if (Bindings.empty())
1225      return false;
1226  
1227    DeclarationName GetDN = S.PP.getIdentifierInfo("get");
1228  
1229    // [dcl.decomp]p3:
1230    //   The unqualified-id get is looked up in the scope of E by class member
1231    //   access lookup ...
1232    LookupResult MemberGet(S, GetDN, Src->getLocation(), Sema::LookupMemberName);
1233    bool UseMemberGet = false;
1234    if (S.isCompleteType(Src->getLocation(), DecompType)) {
1235      if (auto *RD = DecompType->getAsCXXRecordDecl())
1236        S.LookupQualifiedName(MemberGet, RD);
1237      if (MemberGet.isAmbiguous())
1238        return true;
1239      //   ... and if that finds at least one declaration that is a function
1240      //   template whose first template parameter is a non-type parameter ...
1241      for (NamedDecl *D : MemberGet) {
1242        if (FunctionTemplateDecl *FTD =
1243                dyn_cast<FunctionTemplateDecl>(D->getUnderlyingDecl())) {
1244          TemplateParameterList *TPL = FTD->getTemplateParameters();
1245          if (TPL->size() != 0 &&
1246              isa<NonTypeTemplateParmDecl>(TPL->getParam(0))) {
1247            //   ... the initializer is e.get<i>().
1248            UseMemberGet = true;
1249            break;
1250          }
1251        }
1252      }
1253    }
1254  
1255    unsigned I = 0;
1256    for (auto *B : Bindings) {
1257      InitializingBinding InitContext(S, B);
1258      SourceLocation Loc = B->getLocation();
1259  
1260      ExprResult E = S.BuildDeclRefExpr(Src, DecompType, VK_LValue, Loc);
1261      if (E.isInvalid())
1262        return true;
1263  
1264      //   e is an lvalue if the type of the entity is an lvalue reference and
1265      //   an xvalue otherwise
1266      if (!Src->getType()->isLValueReferenceType())
1267        E = ImplicitCastExpr::Create(S.Context, E.get()->getType(), CK_NoOp,
1268                                     E.get(), nullptr, VK_XValue,
1269                                     FPOptionsOverride());
1270  
1271      TemplateArgumentListInfo Args(Loc, Loc);
1272      Args.addArgument(
1273          getTrivialIntegralTemplateArgument(S, Loc, S.Context.getSizeType(), I));
1274  
1275      if (UseMemberGet) {
1276        //   if [lookup of member get] finds at least one declaration, the
1277        //   initializer is e.get<i-1>().
1278        E = S.BuildMemberReferenceExpr(E.get(), DecompType, Loc, false,
1279                                       CXXScopeSpec(), SourceLocation(), nullptr,
1280                                       MemberGet, &Args, nullptr);
1281        if (E.isInvalid())
1282          return true;
1283  
1284        E = S.BuildCallExpr(nullptr, E.get(), Loc, std::nullopt, Loc);
1285      } else {
1286        //   Otherwise, the initializer is get<i-1>(e), where get is looked up
1287        //   in the associated namespaces.
1288        Expr *Get = UnresolvedLookupExpr::Create(
1289            S.Context, nullptr, NestedNameSpecifierLoc(), SourceLocation(),
1290            DeclarationNameInfo(GetDN, Loc), /*RequiresADL=*/true, &Args,
1291            UnresolvedSetIterator(), UnresolvedSetIterator(),
1292            /*KnownDependent=*/false, /*KnownInstantiationDependent=*/false);
1293  
1294        Expr *Arg = E.get();
1295        E = S.BuildCallExpr(nullptr, Get, Loc, Arg, Loc);
1296      }
1297      if (E.isInvalid())
1298        return true;
1299      Expr *Init = E.get();
1300  
1301      //   Given the type T designated by std::tuple_element<i - 1, E>::type,
1302      QualType T = getTupleLikeElementType(S, Loc, I, DecompType);
1303      if (T.isNull())
1304        return true;
1305  
1306      //   each vi is a variable of type "reference to T" initialized with the
1307      //   initializer, where the reference is an lvalue reference if the
1308      //   initializer is an lvalue and an rvalue reference otherwise
1309      QualType RefType =
1310          S.BuildReferenceType(T, E.get()->isLValue(), Loc, B->getDeclName());
1311      if (RefType.isNull())
1312        return true;
1313      auto *RefVD = VarDecl::Create(
1314          S.Context, Src->getDeclContext(), Loc, Loc,
1315          B->getDeclName().getAsIdentifierInfo(), RefType,
1316          S.Context.getTrivialTypeSourceInfo(T, Loc), Src->getStorageClass());
1317      RefVD->setLexicalDeclContext(Src->getLexicalDeclContext());
1318      RefVD->setTSCSpec(Src->getTSCSpec());
1319      RefVD->setImplicit();
1320      if (Src->isInlineSpecified())
1321        RefVD->setInlineSpecified();
1322      RefVD->getLexicalDeclContext()->addHiddenDecl(RefVD);
1323  
1324      InitializedEntity Entity = InitializedEntity::InitializeBinding(RefVD);
1325      InitializationKind Kind = InitializationKind::CreateCopy(Loc, Loc);
1326      InitializationSequence Seq(S, Entity, Kind, Init);
1327      E = Seq.Perform(S, Entity, Kind, Init);
1328      if (E.isInvalid())
1329        return true;
1330      E = S.ActOnFinishFullExpr(E.get(), Loc, /*DiscardedValue*/ false);
1331      if (E.isInvalid())
1332        return true;
1333      RefVD->setInit(E.get());
1334      S.CheckCompleteVariableDeclaration(RefVD);
1335  
1336      E = S.BuildDeclarationNameExpr(CXXScopeSpec(),
1337                                     DeclarationNameInfo(B->getDeclName(), Loc),
1338                                     RefVD);
1339      if (E.isInvalid())
1340        return true;
1341  
1342      B->setBinding(T, E.get());
1343      I++;
1344    }
1345  
1346    return false;
1347  }
1348  
1349  /// Find the base class to decompose in a built-in decomposition of a class type.
1350  /// This base class search is, unfortunately, not quite like any other that we
1351  /// perform anywhere else in C++.
1352  static DeclAccessPair findDecomposableBaseClass(Sema &S, SourceLocation Loc,
1353                                                  const CXXRecordDecl *RD,
1354                                                  CXXCastPath &BasePath) {
1355    auto BaseHasFields = [](const CXXBaseSpecifier *Specifier,
1356                            CXXBasePath &Path) {
1357      return Specifier->getType()->getAsCXXRecordDecl()->hasDirectFields();
1358    };
1359  
1360    const CXXRecordDecl *ClassWithFields = nullptr;
1361    AccessSpecifier AS = AS_public;
1362    if (RD->hasDirectFields())
1363      // [dcl.decomp]p4:
1364      //   Otherwise, all of E's non-static data members shall be public direct
1365      //   members of E ...
1366      ClassWithFields = RD;
1367    else {
1368      //   ... or of ...
1369      CXXBasePaths Paths;
1370      Paths.setOrigin(const_cast<CXXRecordDecl*>(RD));
1371      if (!RD->lookupInBases(BaseHasFields, Paths)) {
1372        // If no classes have fields, just decompose RD itself. (This will work
1373        // if and only if zero bindings were provided.)
1374        return DeclAccessPair::make(const_cast<CXXRecordDecl*>(RD), AS_public);
1375      }
1376  
1377      CXXBasePath *BestPath = nullptr;
1378      for (auto &P : Paths) {
1379        if (!BestPath)
1380          BestPath = &P;
1381        else if (!S.Context.hasSameType(P.back().Base->getType(),
1382                                        BestPath->back().Base->getType())) {
1383          //   ... the same ...
1384          S.Diag(Loc, diag::err_decomp_decl_multiple_bases_with_members)
1385            << false << RD << BestPath->back().Base->getType()
1386            << P.back().Base->getType();
1387          return DeclAccessPair();
1388        } else if (P.Access < BestPath->Access) {
1389          BestPath = &P;
1390        }
1391      }
1392  
1393      //   ... unambiguous ...
1394      QualType BaseType = BestPath->back().Base->getType();
1395      if (Paths.isAmbiguous(S.Context.getCanonicalType(BaseType))) {
1396        S.Diag(Loc, diag::err_decomp_decl_ambiguous_base)
1397          << RD << BaseType << S.getAmbiguousPathsDisplayString(Paths);
1398        return DeclAccessPair();
1399      }
1400  
1401      //   ... [accessible, implied by other rules] base class of E.
1402      S.CheckBaseClassAccess(Loc, BaseType, S.Context.getRecordType(RD),
1403                             *BestPath, diag::err_decomp_decl_inaccessible_base);
1404      AS = BestPath->Access;
1405  
1406      ClassWithFields = BaseType->getAsCXXRecordDecl();
1407      S.BuildBasePathArray(Paths, BasePath);
1408    }
1409  
1410    // The above search did not check whether the selected class itself has base
1411    // classes with fields, so check that now.
1412    CXXBasePaths Paths;
1413    if (ClassWithFields->lookupInBases(BaseHasFields, Paths)) {
1414      S.Diag(Loc, diag::err_decomp_decl_multiple_bases_with_members)
1415        << (ClassWithFields == RD) << RD << ClassWithFields
1416        << Paths.front().back().Base->getType();
1417      return DeclAccessPair();
1418    }
1419  
1420    return DeclAccessPair::make(const_cast<CXXRecordDecl*>(ClassWithFields), AS);
1421  }
1422  
1423  static bool checkMemberDecomposition(Sema &S, ArrayRef<BindingDecl*> Bindings,
1424                                       ValueDecl *Src, QualType DecompType,
1425                                       const CXXRecordDecl *OrigRD) {
1426    if (S.RequireCompleteType(Src->getLocation(), DecompType,
1427                              diag::err_incomplete_type))
1428      return true;
1429  
1430    CXXCastPath BasePath;
1431    DeclAccessPair BasePair =
1432        findDecomposableBaseClass(S, Src->getLocation(), OrigRD, BasePath);
1433    const CXXRecordDecl *RD = cast_or_null<CXXRecordDecl>(BasePair.getDecl());
1434    if (!RD)
1435      return true;
1436    QualType BaseType = S.Context.getQualifiedType(S.Context.getRecordType(RD),
1437                                                   DecompType.getQualifiers());
1438  
1439    auto DiagnoseBadNumberOfBindings = [&]() -> bool {
1440      unsigned NumFields = llvm::count_if(
1441          RD->fields(), [](FieldDecl *FD) { return !FD->isUnnamedBitField(); });
1442      assert(Bindings.size() != NumFields);
1443      S.Diag(Src->getLocation(), diag::err_decomp_decl_wrong_number_bindings)
1444          << DecompType << (unsigned)Bindings.size() << NumFields << NumFields
1445          << (NumFields < Bindings.size());
1446      return true;
1447    };
1448  
1449    //   all of E's non-static data members shall be [...] well-formed
1450    //   when named as e.name in the context of the structured binding,
1451    //   E shall not have an anonymous union member, ...
1452    unsigned I = 0;
1453    for (auto *FD : RD->fields()) {
1454      if (FD->isUnnamedBitField())
1455        continue;
1456  
1457      // All the non-static data members are required to be nameable, so they
1458      // must all have names.
1459      if (!FD->getDeclName()) {
1460        if (RD->isLambda()) {
1461          S.Diag(Src->getLocation(), diag::err_decomp_decl_lambda);
1462          S.Diag(RD->getLocation(), diag::note_lambda_decl);
1463          return true;
1464        }
1465  
1466        if (FD->isAnonymousStructOrUnion()) {
1467          S.Diag(Src->getLocation(), diag::err_decomp_decl_anon_union_member)
1468            << DecompType << FD->getType()->isUnionType();
1469          S.Diag(FD->getLocation(), diag::note_declared_at);
1470          return true;
1471        }
1472  
1473        // FIXME: Are there any other ways we could have an anonymous member?
1474      }
1475  
1476      // We have a real field to bind.
1477      if (I >= Bindings.size())
1478        return DiagnoseBadNumberOfBindings();
1479      auto *B = Bindings[I++];
1480      SourceLocation Loc = B->getLocation();
1481  
1482      // The field must be accessible in the context of the structured binding.
1483      // We already checked that the base class is accessible.
1484      // FIXME: Add 'const' to AccessedEntity's classes so we can remove the
1485      // const_cast here.
1486      S.CheckStructuredBindingMemberAccess(
1487          Loc, const_cast<CXXRecordDecl *>(OrigRD),
1488          DeclAccessPair::make(FD, CXXRecordDecl::MergeAccess(
1489                                       BasePair.getAccess(), FD->getAccess())));
1490  
1491      // Initialize the binding to Src.FD.
1492      ExprResult E = S.BuildDeclRefExpr(Src, DecompType, VK_LValue, Loc);
1493      if (E.isInvalid())
1494        return true;
1495      E = S.ImpCastExprToType(E.get(), BaseType, CK_UncheckedDerivedToBase,
1496                              VK_LValue, &BasePath);
1497      if (E.isInvalid())
1498        return true;
1499      E = S.BuildFieldReferenceExpr(E.get(), /*IsArrow*/ false, Loc,
1500                                    CXXScopeSpec(), FD,
1501                                    DeclAccessPair::make(FD, FD->getAccess()),
1502                                    DeclarationNameInfo(FD->getDeclName(), Loc));
1503      if (E.isInvalid())
1504        return true;
1505  
1506      // If the type of the member is T, the referenced type is cv T, where cv is
1507      // the cv-qualification of the decomposition expression.
1508      //
1509      // FIXME: We resolve a defect here: if the field is mutable, we do not add
1510      // 'const' to the type of the field.
1511      Qualifiers Q = DecompType.getQualifiers();
1512      if (FD->isMutable())
1513        Q.removeConst();
1514      B->setBinding(S.BuildQualifiedType(FD->getType(), Loc, Q), E.get());
1515    }
1516  
1517    if (I != Bindings.size())
1518      return DiagnoseBadNumberOfBindings();
1519  
1520    return false;
1521  }
1522  
1523  void Sema::CheckCompleteDecompositionDeclaration(DecompositionDecl *DD) {
1524    QualType DecompType = DD->getType();
1525  
1526    // If the type of the decomposition is dependent, then so is the type of
1527    // each binding.
1528    if (DecompType->isDependentType()) {
1529      for (auto *B : DD->bindings())
1530        B->setType(Context.DependentTy);
1531      return;
1532    }
1533  
1534    DecompType = DecompType.getNonReferenceType();
1535    ArrayRef<BindingDecl*> Bindings = DD->bindings();
1536  
1537    // C++1z [dcl.decomp]/2:
1538    //   If E is an array type [...]
1539    // As an extension, we also support decomposition of built-in complex and
1540    // vector types.
1541    if (auto *CAT = Context.getAsConstantArrayType(DecompType)) {
1542      if (checkArrayDecomposition(*this, Bindings, DD, DecompType, CAT))
1543        DD->setInvalidDecl();
1544      return;
1545    }
1546    if (auto *VT = DecompType->getAs<VectorType>()) {
1547      if (checkVectorDecomposition(*this, Bindings, DD, DecompType, VT))
1548        DD->setInvalidDecl();
1549      return;
1550    }
1551    if (auto *CT = DecompType->getAs<ComplexType>()) {
1552      if (checkComplexDecomposition(*this, Bindings, DD, DecompType, CT))
1553        DD->setInvalidDecl();
1554      return;
1555    }
1556  
1557    // C++1z [dcl.decomp]/3:
1558    //   if the expression std::tuple_size<E>::value is a well-formed integral
1559    //   constant expression, [...]
1560    llvm::APSInt TupleSize(32);
1561    switch (isTupleLike(*this, DD->getLocation(), DecompType, TupleSize)) {
1562    case IsTupleLike::Error:
1563      DD->setInvalidDecl();
1564      return;
1565  
1566    case IsTupleLike::TupleLike:
1567      if (checkTupleLikeDecomposition(*this, Bindings, DD, DecompType, TupleSize))
1568        DD->setInvalidDecl();
1569      return;
1570  
1571    case IsTupleLike::NotTupleLike:
1572      break;
1573    }
1574  
1575    // C++1z [dcl.dcl]/8:
1576    //   [E shall be of array or non-union class type]
1577    CXXRecordDecl *RD = DecompType->getAsCXXRecordDecl();
1578    if (!RD || RD->isUnion()) {
1579      Diag(DD->getLocation(), diag::err_decomp_decl_unbindable_type)
1580          << DD << !RD << DecompType;
1581      DD->setInvalidDecl();
1582      return;
1583    }
1584  
1585    // C++1z [dcl.decomp]/4:
1586    //   all of E's non-static data members shall be [...] direct members of
1587    //   E or of the same unambiguous public base class of E, ...
1588    if (checkMemberDecomposition(*this, Bindings, DD, DecompType, RD))
1589      DD->setInvalidDecl();
1590  }
1591  
1592  void Sema::MergeVarDeclExceptionSpecs(VarDecl *New, VarDecl *Old) {
1593    // Shortcut if exceptions are disabled.
1594    if (!getLangOpts().CXXExceptions)
1595      return;
1596  
1597    assert(Context.hasSameType(New->getType(), Old->getType()) &&
1598           "Should only be called if types are otherwise the same.");
1599  
1600    QualType NewType = New->getType();
1601    QualType OldType = Old->getType();
1602  
1603    // We're only interested in pointers and references to functions, as well
1604    // as pointers to member functions.
1605    if (const ReferenceType *R = NewType->getAs<ReferenceType>()) {
1606      NewType = R->getPointeeType();
1607      OldType = OldType->castAs<ReferenceType>()->getPointeeType();
1608    } else if (const PointerType *P = NewType->getAs<PointerType>()) {
1609      NewType = P->getPointeeType();
1610      OldType = OldType->castAs<PointerType>()->getPointeeType();
1611    } else if (const MemberPointerType *M = NewType->getAs<MemberPointerType>()) {
1612      NewType = M->getPointeeType();
1613      OldType = OldType->castAs<MemberPointerType>()->getPointeeType();
1614    }
1615  
1616    if (!NewType->isFunctionProtoType())
1617      return;
1618  
1619    // There's lots of special cases for functions. For function pointers, system
1620    // libraries are hopefully not as broken so that we don't need these
1621    // workarounds.
1622    if (CheckEquivalentExceptionSpec(
1623          OldType->getAs<FunctionProtoType>(), Old->getLocation(),
1624          NewType->getAs<FunctionProtoType>(), New->getLocation())) {
1625      New->setInvalidDecl();
1626    }
1627  }
1628  
1629  /// CheckCXXDefaultArguments - Verify that the default arguments for a
1630  /// function declaration are well-formed according to C++
1631  /// [dcl.fct.default].
1632  void Sema::CheckCXXDefaultArguments(FunctionDecl *FD) {
1633    // This checking doesn't make sense for explicit specializations; their
1634    // default arguments are determined by the declaration we're specializing,
1635    // not by FD.
1636    if (FD->getTemplateSpecializationKind() == TSK_ExplicitSpecialization)
1637      return;
1638    if (auto *FTD = FD->getDescribedFunctionTemplate())
1639      if (FTD->isMemberSpecialization())
1640        return;
1641  
1642    unsigned NumParams = FD->getNumParams();
1643    unsigned ParamIdx = 0;
1644  
1645    // Find first parameter with a default argument
1646    for (; ParamIdx < NumParams; ++ParamIdx) {
1647      ParmVarDecl *Param = FD->getParamDecl(ParamIdx);
1648      if (Param->hasDefaultArg())
1649        break;
1650    }
1651  
1652    // C++20 [dcl.fct.default]p4:
1653    //   In a given function declaration, each parameter subsequent to a parameter
1654    //   with a default argument shall have a default argument supplied in this or
1655    //   a previous declaration, unless the parameter was expanded from a
1656    //   parameter pack, or shall be a function parameter pack.
1657    for (++ParamIdx; ParamIdx < NumParams; ++ParamIdx) {
1658      ParmVarDecl *Param = FD->getParamDecl(ParamIdx);
1659      if (Param->hasDefaultArg() || Param->isParameterPack() ||
1660          (CurrentInstantiationScope &&
1661           CurrentInstantiationScope->isLocalPackExpansion(Param)))
1662        continue;
1663      if (Param->isInvalidDecl())
1664        /* We already complained about this parameter. */;
1665      else if (Param->getIdentifier())
1666        Diag(Param->getLocation(), diag::err_param_default_argument_missing_name)
1667            << Param->getIdentifier();
1668      else
1669        Diag(Param->getLocation(), diag::err_param_default_argument_missing);
1670    }
1671  }
1672  
1673  /// Check that the given type is a literal type. Issue a diagnostic if not,
1674  /// if Kind is Diagnose.
1675  /// \return \c true if a problem has been found (and optionally diagnosed).
1676  template <typename... Ts>
1677  static bool CheckLiteralType(Sema &SemaRef, Sema::CheckConstexprKind Kind,
1678                               SourceLocation Loc, QualType T, unsigned DiagID,
1679                               Ts &&...DiagArgs) {
1680    if (T->isDependentType())
1681      return false;
1682  
1683    switch (Kind) {
1684    case Sema::CheckConstexprKind::Diagnose:
1685      return SemaRef.RequireLiteralType(Loc, T, DiagID,
1686                                        std::forward<Ts>(DiagArgs)...);
1687  
1688    case Sema::CheckConstexprKind::CheckValid:
1689      return !T->isLiteralType(SemaRef.Context);
1690    }
1691  
1692    llvm_unreachable("unknown CheckConstexprKind");
1693  }
1694  
1695  /// Determine whether a destructor cannot be constexpr due to
1696  static bool CheckConstexprDestructorSubobjects(Sema &SemaRef,
1697                                                 const CXXDestructorDecl *DD,
1698                                                 Sema::CheckConstexprKind Kind) {
1699    assert(!SemaRef.getLangOpts().CPlusPlus23 &&
1700           "this check is obsolete for C++23");
1701    auto Check = [&](SourceLocation Loc, QualType T, const FieldDecl *FD) {
1702      const CXXRecordDecl *RD =
1703          T->getBaseElementTypeUnsafe()->getAsCXXRecordDecl();
1704      if (!RD || RD->hasConstexprDestructor())
1705        return true;
1706  
1707      if (Kind == Sema::CheckConstexprKind::Diagnose) {
1708        SemaRef.Diag(DD->getLocation(), diag::err_constexpr_dtor_subobject)
1709            << static_cast<int>(DD->getConstexprKind()) << !FD
1710            << (FD ? FD->getDeclName() : DeclarationName()) << T;
1711        SemaRef.Diag(Loc, diag::note_constexpr_dtor_subobject)
1712            << !FD << (FD ? FD->getDeclName() : DeclarationName()) << T;
1713      }
1714      return false;
1715    };
1716  
1717    const CXXRecordDecl *RD = DD->getParent();
1718    for (const CXXBaseSpecifier &B : RD->bases())
1719      if (!Check(B.getBaseTypeLoc(), B.getType(), nullptr))
1720        return false;
1721    for (const FieldDecl *FD : RD->fields())
1722      if (!Check(FD->getLocation(), FD->getType(), FD))
1723        return false;
1724    return true;
1725  }
1726  
1727  /// Check whether a function's parameter types are all literal types. If so,
1728  /// return true. If not, produce a suitable diagnostic and return false.
1729  static bool CheckConstexprParameterTypes(Sema &SemaRef,
1730                                           const FunctionDecl *FD,
1731                                           Sema::CheckConstexprKind Kind) {
1732    assert(!SemaRef.getLangOpts().CPlusPlus23 &&
1733           "this check is obsolete for C++23");
1734    unsigned ArgIndex = 0;
1735    const auto *FT = FD->getType()->castAs<FunctionProtoType>();
1736    for (FunctionProtoType::param_type_iterator i = FT->param_type_begin(),
1737                                                e = FT->param_type_end();
1738         i != e; ++i, ++ArgIndex) {
1739      const ParmVarDecl *PD = FD->getParamDecl(ArgIndex);
1740      assert(PD && "null in a parameter list");
1741      SourceLocation ParamLoc = PD->getLocation();
1742      if (CheckLiteralType(SemaRef, Kind, ParamLoc, *i,
1743                           diag::err_constexpr_non_literal_param, ArgIndex + 1,
1744                           PD->getSourceRange(), isa<CXXConstructorDecl>(FD),
1745                           FD->isConsteval()))
1746        return false;
1747    }
1748    return true;
1749  }
1750  
1751  /// Check whether a function's return type is a literal type. If so, return
1752  /// true. If not, produce a suitable diagnostic and return false.
1753  static bool CheckConstexprReturnType(Sema &SemaRef, const FunctionDecl *FD,
1754                                       Sema::CheckConstexprKind Kind) {
1755    assert(!SemaRef.getLangOpts().CPlusPlus23 &&
1756           "this check is obsolete for C++23");
1757    if (CheckLiteralType(SemaRef, Kind, FD->getLocation(), FD->getReturnType(),
1758                         diag::err_constexpr_non_literal_return,
1759                         FD->isConsteval()))
1760      return false;
1761    return true;
1762  }
1763  
1764  /// Get diagnostic %select index for tag kind for
1765  /// record diagnostic message.
1766  /// WARNING: Indexes apply to particular diagnostics only!
1767  ///
1768  /// \returns diagnostic %select index.
1769  static unsigned getRecordDiagFromTagKind(TagTypeKind Tag) {
1770    switch (Tag) {
1771    case TagTypeKind::Struct:
1772      return 0;
1773    case TagTypeKind::Interface:
1774      return 1;
1775    case TagTypeKind::Class:
1776      return 2;
1777    default: llvm_unreachable("Invalid tag kind for record diagnostic!");
1778    }
1779  }
1780  
1781  static bool CheckConstexprFunctionBody(Sema &SemaRef, const FunctionDecl *Dcl,
1782                                         Stmt *Body,
1783                                         Sema::CheckConstexprKind Kind);
1784  static bool CheckConstexprMissingReturn(Sema &SemaRef, const FunctionDecl *Dcl);
1785  
1786  bool Sema::CheckConstexprFunctionDefinition(const FunctionDecl *NewFD,
1787                                              CheckConstexprKind Kind) {
1788    const CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(NewFD);
1789    if (MD && MD->isInstance()) {
1790      // C++11 [dcl.constexpr]p4:
1791      //  The definition of a constexpr constructor shall satisfy the following
1792      //  constraints:
1793      //  - the class shall not have any virtual base classes;
1794      //
1795      // FIXME: This only applies to constructors and destructors, not arbitrary
1796      // member functions.
1797      const CXXRecordDecl *RD = MD->getParent();
1798      if (RD->getNumVBases()) {
1799        if (Kind == CheckConstexprKind::CheckValid)
1800          return false;
1801  
1802        Diag(NewFD->getLocation(), diag::err_constexpr_virtual_base)
1803          << isa<CXXConstructorDecl>(NewFD)
1804          << getRecordDiagFromTagKind(RD->getTagKind()) << RD->getNumVBases();
1805        for (const auto &I : RD->vbases())
1806          Diag(I.getBeginLoc(), diag::note_constexpr_virtual_base_here)
1807              << I.getSourceRange();
1808        return false;
1809      }
1810    }
1811  
1812    if (!isa<CXXConstructorDecl>(NewFD)) {
1813      // C++11 [dcl.constexpr]p3:
1814      //  The definition of a constexpr function shall satisfy the following
1815      //  constraints:
1816      // - it shall not be virtual; (removed in C++20)
1817      const CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(NewFD);
1818      if (Method && Method->isVirtual()) {
1819        if (getLangOpts().CPlusPlus20) {
1820          if (Kind == CheckConstexprKind::Diagnose)
1821            Diag(Method->getLocation(), diag::warn_cxx17_compat_constexpr_virtual);
1822        } else {
1823          if (Kind == CheckConstexprKind::CheckValid)
1824            return false;
1825  
1826          Method = Method->getCanonicalDecl();
1827          Diag(Method->getLocation(), diag::err_constexpr_virtual);
1828  
1829          // If it's not obvious why this function is virtual, find an overridden
1830          // function which uses the 'virtual' keyword.
1831          const CXXMethodDecl *WrittenVirtual = Method;
1832          while (!WrittenVirtual->isVirtualAsWritten())
1833            WrittenVirtual = *WrittenVirtual->begin_overridden_methods();
1834          if (WrittenVirtual != Method)
1835            Diag(WrittenVirtual->getLocation(),
1836                 diag::note_overridden_virtual_function);
1837          return false;
1838        }
1839      }
1840  
1841      // - its return type shall be a literal type; (removed in C++23)
1842      if (!getLangOpts().CPlusPlus23 &&
1843          !CheckConstexprReturnType(*this, NewFD, Kind))
1844        return false;
1845    }
1846  
1847    if (auto *Dtor = dyn_cast<CXXDestructorDecl>(NewFD)) {
1848      // A destructor can be constexpr only if the defaulted destructor could be;
1849      // we don't need to check the members and bases if we already know they all
1850      // have constexpr destructors. (removed in C++23)
1851      if (!getLangOpts().CPlusPlus23 &&
1852          !Dtor->getParent()->defaultedDestructorIsConstexpr()) {
1853        if (Kind == CheckConstexprKind::CheckValid)
1854          return false;
1855        if (!CheckConstexprDestructorSubobjects(*this, Dtor, Kind))
1856          return false;
1857      }
1858    }
1859  
1860    // - each of its parameter types shall be a literal type; (removed in C++23)
1861    if (!getLangOpts().CPlusPlus23 &&
1862        !CheckConstexprParameterTypes(*this, NewFD, Kind))
1863      return false;
1864  
1865    Stmt *Body = NewFD->getBody();
1866    assert(Body &&
1867           "CheckConstexprFunctionDefinition called on function with no body");
1868    return CheckConstexprFunctionBody(*this, NewFD, Body, Kind);
1869  }
1870  
1871  /// Check the given declaration statement is legal within a constexpr function
1872  /// body. C++11 [dcl.constexpr]p3,p4, and C++1y [dcl.constexpr]p3.
1873  ///
1874  /// \return true if the body is OK (maybe only as an extension), false if we
1875  ///         have diagnosed a problem.
1876  static bool CheckConstexprDeclStmt(Sema &SemaRef, const FunctionDecl *Dcl,
1877                                     DeclStmt *DS, SourceLocation &Cxx1yLoc,
1878                                     Sema::CheckConstexprKind Kind) {
1879    // C++11 [dcl.constexpr]p3 and p4:
1880    //  The definition of a constexpr function(p3) or constructor(p4) [...] shall
1881    //  contain only
1882    for (const auto *DclIt : DS->decls()) {
1883      switch (DclIt->getKind()) {
1884      case Decl::StaticAssert:
1885      case Decl::Using:
1886      case Decl::UsingShadow:
1887      case Decl::UsingDirective:
1888      case Decl::UnresolvedUsingTypename:
1889      case Decl::UnresolvedUsingValue:
1890      case Decl::UsingEnum:
1891        //   - static_assert-declarations
1892        //   - using-declarations,
1893        //   - using-directives,
1894        //   - using-enum-declaration
1895        continue;
1896  
1897      case Decl::Typedef:
1898      case Decl::TypeAlias: {
1899        //   - typedef declarations and alias-declarations that do not define
1900        //     classes or enumerations,
1901        const auto *TN = cast<TypedefNameDecl>(DclIt);
1902        if (TN->getUnderlyingType()->isVariablyModifiedType()) {
1903          // Don't allow variably-modified types in constexpr functions.
1904          if (Kind == Sema::CheckConstexprKind::Diagnose) {
1905            TypeLoc TL = TN->getTypeSourceInfo()->getTypeLoc();
1906            SemaRef.Diag(TL.getBeginLoc(), diag::err_constexpr_vla)
1907              << TL.getSourceRange() << TL.getType()
1908              << isa<CXXConstructorDecl>(Dcl);
1909          }
1910          return false;
1911        }
1912        continue;
1913      }
1914  
1915      case Decl::Enum:
1916      case Decl::CXXRecord:
1917        // C++1y allows types to be defined, not just declared.
1918        if (cast<TagDecl>(DclIt)->isThisDeclarationADefinition()) {
1919          if (Kind == Sema::CheckConstexprKind::Diagnose) {
1920            SemaRef.Diag(DS->getBeginLoc(),
1921                         SemaRef.getLangOpts().CPlusPlus14
1922                             ? diag::warn_cxx11_compat_constexpr_type_definition
1923                             : diag::ext_constexpr_type_definition)
1924                << isa<CXXConstructorDecl>(Dcl);
1925          } else if (!SemaRef.getLangOpts().CPlusPlus14) {
1926            return false;
1927          }
1928        }
1929        continue;
1930  
1931      case Decl::EnumConstant:
1932      case Decl::IndirectField:
1933      case Decl::ParmVar:
1934        // These can only appear with other declarations which are banned in
1935        // C++11 and permitted in C++1y, so ignore them.
1936        continue;
1937  
1938      case Decl::Var:
1939      case Decl::Decomposition: {
1940        // C++1y [dcl.constexpr]p3 allows anything except:
1941        //   a definition of a variable of non-literal type or of static or
1942        //   thread storage duration or [before C++2a] for which no
1943        //   initialization is performed.
1944        const auto *VD = cast<VarDecl>(DclIt);
1945        if (VD->isThisDeclarationADefinition()) {
1946          if (VD->isStaticLocal()) {
1947            if (Kind == Sema::CheckConstexprKind::Diagnose) {
1948              SemaRef.Diag(VD->getLocation(),
1949                           SemaRef.getLangOpts().CPlusPlus23
1950                               ? diag::warn_cxx20_compat_constexpr_var
1951                               : diag::ext_constexpr_static_var)
1952                  << isa<CXXConstructorDecl>(Dcl)
1953                  << (VD->getTLSKind() == VarDecl::TLS_Dynamic);
1954            } else if (!SemaRef.getLangOpts().CPlusPlus23) {
1955              return false;
1956            }
1957          }
1958          if (SemaRef.LangOpts.CPlusPlus23) {
1959            CheckLiteralType(SemaRef, Kind, VD->getLocation(), VD->getType(),
1960                             diag::warn_cxx20_compat_constexpr_var,
1961                             isa<CXXConstructorDecl>(Dcl),
1962                             /*variable of non-literal type*/ 2);
1963          } else if (CheckLiteralType(
1964                         SemaRef, Kind, VD->getLocation(), VD->getType(),
1965                         diag::err_constexpr_local_var_non_literal_type,
1966                         isa<CXXConstructorDecl>(Dcl))) {
1967            return false;
1968          }
1969          if (!VD->getType()->isDependentType() &&
1970              !VD->hasInit() && !VD->isCXXForRangeDecl()) {
1971            if (Kind == Sema::CheckConstexprKind::Diagnose) {
1972              SemaRef.Diag(
1973                  VD->getLocation(),
1974                  SemaRef.getLangOpts().CPlusPlus20
1975                      ? diag::warn_cxx17_compat_constexpr_local_var_no_init
1976                      : diag::ext_constexpr_local_var_no_init)
1977                  << isa<CXXConstructorDecl>(Dcl);
1978            } else if (!SemaRef.getLangOpts().CPlusPlus20) {
1979              return false;
1980            }
1981            continue;
1982          }
1983        }
1984        if (Kind == Sema::CheckConstexprKind::Diagnose) {
1985          SemaRef.Diag(VD->getLocation(),
1986                       SemaRef.getLangOpts().CPlusPlus14
1987                        ? diag::warn_cxx11_compat_constexpr_local_var
1988                        : diag::ext_constexpr_local_var)
1989            << isa<CXXConstructorDecl>(Dcl);
1990        } else if (!SemaRef.getLangOpts().CPlusPlus14) {
1991          return false;
1992        }
1993        continue;
1994      }
1995  
1996      case Decl::NamespaceAlias:
1997      case Decl::Function:
1998        // These are disallowed in C++11 and permitted in C++1y. Allow them
1999        // everywhere as an extension.
2000        if (!Cxx1yLoc.isValid())
2001          Cxx1yLoc = DS->getBeginLoc();
2002        continue;
2003  
2004      default:
2005        if (Kind == Sema::CheckConstexprKind::Diagnose) {
2006          SemaRef.Diag(DS->getBeginLoc(), diag::err_constexpr_body_invalid_stmt)
2007              << isa<CXXConstructorDecl>(Dcl) << Dcl->isConsteval();
2008        }
2009        return false;
2010      }
2011    }
2012  
2013    return true;
2014  }
2015  
2016  /// Check that the given field is initialized within a constexpr constructor.
2017  ///
2018  /// \param Dcl The constexpr constructor being checked.
2019  /// \param Field The field being checked. This may be a member of an anonymous
2020  ///        struct or union nested within the class being checked.
2021  /// \param Inits All declarations, including anonymous struct/union members and
2022  ///        indirect members, for which any initialization was provided.
2023  /// \param Diagnosed Whether we've emitted the error message yet. Used to attach
2024  ///        multiple notes for different members to the same error.
2025  /// \param Kind Whether we're diagnosing a constructor as written or determining
2026  ///        whether the formal requirements are satisfied.
2027  /// \return \c false if we're checking for validity and the constructor does
2028  ///         not satisfy the requirements on a constexpr constructor.
2029  static bool CheckConstexprCtorInitializer(Sema &SemaRef,
2030                                            const FunctionDecl *Dcl,
2031                                            FieldDecl *Field,
2032                                            llvm::SmallSet<Decl*, 16> &Inits,
2033                                            bool &Diagnosed,
2034                                            Sema::CheckConstexprKind Kind) {
2035    // In C++20 onwards, there's nothing to check for validity.
2036    if (Kind == Sema::CheckConstexprKind::CheckValid &&
2037        SemaRef.getLangOpts().CPlusPlus20)
2038      return true;
2039  
2040    if (Field->isInvalidDecl())
2041      return true;
2042  
2043    if (Field->isUnnamedBitField())
2044      return true;
2045  
2046    // Anonymous unions with no variant members and empty anonymous structs do not
2047    // need to be explicitly initialized. FIXME: Anonymous structs that contain no
2048    // indirect fields don't need initializing.
2049    if (Field->isAnonymousStructOrUnion() &&
2050        (Field->getType()->isUnionType()
2051             ? !Field->getType()->getAsCXXRecordDecl()->hasVariantMembers()
2052             : Field->getType()->getAsCXXRecordDecl()->isEmpty()))
2053      return true;
2054  
2055    if (!Inits.count(Field)) {
2056      if (Kind == Sema::CheckConstexprKind::Diagnose) {
2057        if (!Diagnosed) {
2058          SemaRef.Diag(Dcl->getLocation(),
2059                       SemaRef.getLangOpts().CPlusPlus20
2060                           ? diag::warn_cxx17_compat_constexpr_ctor_missing_init
2061                           : diag::ext_constexpr_ctor_missing_init);
2062          Diagnosed = true;
2063        }
2064        SemaRef.Diag(Field->getLocation(),
2065                     diag::note_constexpr_ctor_missing_init);
2066      } else if (!SemaRef.getLangOpts().CPlusPlus20) {
2067        return false;
2068      }
2069    } else if (Field->isAnonymousStructOrUnion()) {
2070      const RecordDecl *RD = Field->getType()->castAs<RecordType>()->getDecl();
2071      for (auto *I : RD->fields())
2072        // If an anonymous union contains an anonymous struct of which any member
2073        // is initialized, all members must be initialized.
2074        if (!RD->isUnion() || Inits.count(I))
2075          if (!CheckConstexprCtorInitializer(SemaRef, Dcl, I, Inits, Diagnosed,
2076                                             Kind))
2077            return false;
2078    }
2079    return true;
2080  }
2081  
2082  /// Check the provided statement is allowed in a constexpr function
2083  /// definition.
2084  static bool
2085  CheckConstexprFunctionStmt(Sema &SemaRef, const FunctionDecl *Dcl, Stmt *S,
2086                             SmallVectorImpl<SourceLocation> &ReturnStmts,
2087                             SourceLocation &Cxx1yLoc, SourceLocation &Cxx2aLoc,
2088                             SourceLocation &Cxx2bLoc,
2089                             Sema::CheckConstexprKind Kind) {
2090    // - its function-body shall be [...] a compound-statement that contains only
2091    switch (S->getStmtClass()) {
2092    case Stmt::NullStmtClass:
2093      //   - null statements,
2094      return true;
2095  
2096    case Stmt::DeclStmtClass:
2097      //   - static_assert-declarations
2098      //   - using-declarations,
2099      //   - using-directives,
2100      //   - typedef declarations and alias-declarations that do not define
2101      //     classes or enumerations,
2102      if (!CheckConstexprDeclStmt(SemaRef, Dcl, cast<DeclStmt>(S), Cxx1yLoc, Kind))
2103        return false;
2104      return true;
2105  
2106    case Stmt::ReturnStmtClass:
2107      //   - and exactly one return statement;
2108      if (isa<CXXConstructorDecl>(Dcl)) {
2109        // C++1y allows return statements in constexpr constructors.
2110        if (!Cxx1yLoc.isValid())
2111          Cxx1yLoc = S->getBeginLoc();
2112        return true;
2113      }
2114  
2115      ReturnStmts.push_back(S->getBeginLoc());
2116      return true;
2117  
2118    case Stmt::AttributedStmtClass:
2119      // Attributes on a statement don't affect its formal kind and hence don't
2120      // affect its validity in a constexpr function.
2121      return CheckConstexprFunctionStmt(
2122          SemaRef, Dcl, cast<AttributedStmt>(S)->getSubStmt(), ReturnStmts,
2123          Cxx1yLoc, Cxx2aLoc, Cxx2bLoc, Kind);
2124  
2125    case Stmt::CompoundStmtClass: {
2126      // C++1y allows compound-statements.
2127      if (!Cxx1yLoc.isValid())
2128        Cxx1yLoc = S->getBeginLoc();
2129  
2130      CompoundStmt *CompStmt = cast<CompoundStmt>(S);
2131      for (auto *BodyIt : CompStmt->body()) {
2132        if (!CheckConstexprFunctionStmt(SemaRef, Dcl, BodyIt, ReturnStmts,
2133                                        Cxx1yLoc, Cxx2aLoc, Cxx2bLoc, Kind))
2134          return false;
2135      }
2136      return true;
2137    }
2138  
2139    case Stmt::IfStmtClass: {
2140      // C++1y allows if-statements.
2141      if (!Cxx1yLoc.isValid())
2142        Cxx1yLoc = S->getBeginLoc();
2143  
2144      IfStmt *If = cast<IfStmt>(S);
2145      if (!CheckConstexprFunctionStmt(SemaRef, Dcl, If->getThen(), ReturnStmts,
2146                                      Cxx1yLoc, Cxx2aLoc, Cxx2bLoc, Kind))
2147        return false;
2148      if (If->getElse() &&
2149          !CheckConstexprFunctionStmt(SemaRef, Dcl, If->getElse(), ReturnStmts,
2150                                      Cxx1yLoc, Cxx2aLoc, Cxx2bLoc, Kind))
2151        return false;
2152      return true;
2153    }
2154  
2155    case Stmt::WhileStmtClass:
2156    case Stmt::DoStmtClass:
2157    case Stmt::ForStmtClass:
2158    case Stmt::CXXForRangeStmtClass:
2159    case Stmt::ContinueStmtClass:
2160      // C++1y allows all of these. We don't allow them as extensions in C++11,
2161      // because they don't make sense without variable mutation.
2162      if (!SemaRef.getLangOpts().CPlusPlus14)
2163        break;
2164      if (!Cxx1yLoc.isValid())
2165        Cxx1yLoc = S->getBeginLoc();
2166      for (Stmt *SubStmt : S->children()) {
2167        if (SubStmt &&
2168            !CheckConstexprFunctionStmt(SemaRef, Dcl, SubStmt, ReturnStmts,
2169                                        Cxx1yLoc, Cxx2aLoc, Cxx2bLoc, Kind))
2170          return false;
2171      }
2172      return true;
2173  
2174    case Stmt::SwitchStmtClass:
2175    case Stmt::CaseStmtClass:
2176    case Stmt::DefaultStmtClass:
2177    case Stmt::BreakStmtClass:
2178      // C++1y allows switch-statements, and since they don't need variable
2179      // mutation, we can reasonably allow them in C++11 as an extension.
2180      if (!Cxx1yLoc.isValid())
2181        Cxx1yLoc = S->getBeginLoc();
2182      for (Stmt *SubStmt : S->children()) {
2183        if (SubStmt &&
2184            !CheckConstexprFunctionStmt(SemaRef, Dcl, SubStmt, ReturnStmts,
2185                                        Cxx1yLoc, Cxx2aLoc, Cxx2bLoc, Kind))
2186          return false;
2187      }
2188      return true;
2189  
2190    case Stmt::LabelStmtClass:
2191    case Stmt::GotoStmtClass:
2192      if (Cxx2bLoc.isInvalid())
2193        Cxx2bLoc = S->getBeginLoc();
2194      for (Stmt *SubStmt : S->children()) {
2195        if (SubStmt &&
2196            !CheckConstexprFunctionStmt(SemaRef, Dcl, SubStmt, ReturnStmts,
2197                                        Cxx1yLoc, Cxx2aLoc, Cxx2bLoc, Kind))
2198          return false;
2199      }
2200      return true;
2201  
2202    case Stmt::GCCAsmStmtClass:
2203    case Stmt::MSAsmStmtClass:
2204      // C++2a allows inline assembly statements.
2205    case Stmt::CXXTryStmtClass:
2206      if (Cxx2aLoc.isInvalid())
2207        Cxx2aLoc = S->getBeginLoc();
2208      for (Stmt *SubStmt : S->children()) {
2209        if (SubStmt &&
2210            !CheckConstexprFunctionStmt(SemaRef, Dcl, SubStmt, ReturnStmts,
2211                                        Cxx1yLoc, Cxx2aLoc, Cxx2bLoc, Kind))
2212          return false;
2213      }
2214      return true;
2215  
2216    case Stmt::CXXCatchStmtClass:
2217      // Do not bother checking the language mode (already covered by the
2218      // try block check).
2219      if (!CheckConstexprFunctionStmt(
2220              SemaRef, Dcl, cast<CXXCatchStmt>(S)->getHandlerBlock(), ReturnStmts,
2221              Cxx1yLoc, Cxx2aLoc, Cxx2bLoc, Kind))
2222        return false;
2223      return true;
2224  
2225    default:
2226      if (!isa<Expr>(S))
2227        break;
2228  
2229      // C++1y allows expression-statements.
2230      if (!Cxx1yLoc.isValid())
2231        Cxx1yLoc = S->getBeginLoc();
2232      return true;
2233    }
2234  
2235    if (Kind == Sema::CheckConstexprKind::Diagnose) {
2236      SemaRef.Diag(S->getBeginLoc(), diag::err_constexpr_body_invalid_stmt)
2237          << isa<CXXConstructorDecl>(Dcl) << Dcl->isConsteval();
2238    }
2239    return false;
2240  }
2241  
2242  /// Check the body for the given constexpr function declaration only contains
2243  /// the permitted types of statement. C++11 [dcl.constexpr]p3,p4.
2244  ///
2245  /// \return true if the body is OK, false if we have found or diagnosed a
2246  /// problem.
2247  static bool CheckConstexprFunctionBody(Sema &SemaRef, const FunctionDecl *Dcl,
2248                                         Stmt *Body,
2249                                         Sema::CheckConstexprKind Kind) {
2250    SmallVector<SourceLocation, 4> ReturnStmts;
2251  
2252    if (isa<CXXTryStmt>(Body)) {
2253      // C++11 [dcl.constexpr]p3:
2254      //  The definition of a constexpr function shall satisfy the following
2255      //  constraints: [...]
2256      // - its function-body shall be = delete, = default, or a
2257      //   compound-statement
2258      //
2259      // C++11 [dcl.constexpr]p4:
2260      //  In the definition of a constexpr constructor, [...]
2261      // - its function-body shall not be a function-try-block;
2262      //
2263      // This restriction is lifted in C++2a, as long as inner statements also
2264      // apply the general constexpr rules.
2265      switch (Kind) {
2266      case Sema::CheckConstexprKind::CheckValid:
2267        if (!SemaRef.getLangOpts().CPlusPlus20)
2268          return false;
2269        break;
2270  
2271      case Sema::CheckConstexprKind::Diagnose:
2272        SemaRef.Diag(Body->getBeginLoc(),
2273             !SemaRef.getLangOpts().CPlusPlus20
2274                 ? diag::ext_constexpr_function_try_block_cxx20
2275                 : diag::warn_cxx17_compat_constexpr_function_try_block)
2276            << isa<CXXConstructorDecl>(Dcl);
2277        break;
2278      }
2279    }
2280  
2281    // - its function-body shall be [...] a compound-statement that contains only
2282    //   [... list of cases ...]
2283    //
2284    // Note that walking the children here is enough to properly check for
2285    // CompoundStmt and CXXTryStmt body.
2286    SourceLocation Cxx1yLoc, Cxx2aLoc, Cxx2bLoc;
2287    for (Stmt *SubStmt : Body->children()) {
2288      if (SubStmt &&
2289          !CheckConstexprFunctionStmt(SemaRef, Dcl, SubStmt, ReturnStmts,
2290                                      Cxx1yLoc, Cxx2aLoc, Cxx2bLoc, Kind))
2291        return false;
2292    }
2293  
2294    if (Kind == Sema::CheckConstexprKind::CheckValid) {
2295      // If this is only valid as an extension, report that we don't satisfy the
2296      // constraints of the current language.
2297      if ((Cxx2bLoc.isValid() && !SemaRef.getLangOpts().CPlusPlus23) ||
2298          (Cxx2aLoc.isValid() && !SemaRef.getLangOpts().CPlusPlus20) ||
2299          (Cxx1yLoc.isValid() && !SemaRef.getLangOpts().CPlusPlus17))
2300        return false;
2301    } else if (Cxx2bLoc.isValid()) {
2302      SemaRef.Diag(Cxx2bLoc,
2303                   SemaRef.getLangOpts().CPlusPlus23
2304                       ? diag::warn_cxx20_compat_constexpr_body_invalid_stmt
2305                       : diag::ext_constexpr_body_invalid_stmt_cxx23)
2306          << isa<CXXConstructorDecl>(Dcl);
2307    } else if (Cxx2aLoc.isValid()) {
2308      SemaRef.Diag(Cxx2aLoc,
2309           SemaRef.getLangOpts().CPlusPlus20
2310             ? diag::warn_cxx17_compat_constexpr_body_invalid_stmt
2311             : diag::ext_constexpr_body_invalid_stmt_cxx20)
2312        << isa<CXXConstructorDecl>(Dcl);
2313    } else if (Cxx1yLoc.isValid()) {
2314      SemaRef.Diag(Cxx1yLoc,
2315           SemaRef.getLangOpts().CPlusPlus14
2316             ? diag::warn_cxx11_compat_constexpr_body_invalid_stmt
2317             : diag::ext_constexpr_body_invalid_stmt)
2318        << isa<CXXConstructorDecl>(Dcl);
2319    }
2320  
2321    if (const CXXConstructorDecl *Constructor
2322          = dyn_cast<CXXConstructorDecl>(Dcl)) {
2323      const CXXRecordDecl *RD = Constructor->getParent();
2324      // DR1359:
2325      // - every non-variant non-static data member and base class sub-object
2326      //   shall be initialized;
2327      // DR1460:
2328      // - if the class is a union having variant members, exactly one of them
2329      //   shall be initialized;
2330      if (RD->isUnion()) {
2331        if (Constructor->getNumCtorInitializers() == 0 &&
2332            RD->hasVariantMembers()) {
2333          if (Kind == Sema::CheckConstexprKind::Diagnose) {
2334            SemaRef.Diag(
2335                Dcl->getLocation(),
2336                SemaRef.getLangOpts().CPlusPlus20
2337                    ? diag::warn_cxx17_compat_constexpr_union_ctor_no_init
2338                    : diag::ext_constexpr_union_ctor_no_init);
2339          } else if (!SemaRef.getLangOpts().CPlusPlus20) {
2340            return false;
2341          }
2342        }
2343      } else if (!Constructor->isDependentContext() &&
2344                 !Constructor->isDelegatingConstructor()) {
2345        assert(RD->getNumVBases() == 0 && "constexpr ctor with virtual bases");
2346  
2347        // Skip detailed checking if we have enough initializers, and we would
2348        // allow at most one initializer per member.
2349        bool AnyAnonStructUnionMembers = false;
2350        unsigned Fields = 0;
2351        for (CXXRecordDecl::field_iterator I = RD->field_begin(),
2352             E = RD->field_end(); I != E; ++I, ++Fields) {
2353          if (I->isAnonymousStructOrUnion()) {
2354            AnyAnonStructUnionMembers = true;
2355            break;
2356          }
2357        }
2358        // DR1460:
2359        // - if the class is a union-like class, but is not a union, for each of
2360        //   its anonymous union members having variant members, exactly one of
2361        //   them shall be initialized;
2362        if (AnyAnonStructUnionMembers ||
2363            Constructor->getNumCtorInitializers() != RD->getNumBases() + Fields) {
2364          // Check initialization of non-static data members. Base classes are
2365          // always initialized so do not need to be checked. Dependent bases
2366          // might not have initializers in the member initializer list.
2367          llvm::SmallSet<Decl*, 16> Inits;
2368          for (const auto *I: Constructor->inits()) {
2369            if (FieldDecl *FD = I->getMember())
2370              Inits.insert(FD);
2371            else if (IndirectFieldDecl *ID = I->getIndirectMember())
2372              Inits.insert(ID->chain_begin(), ID->chain_end());
2373          }
2374  
2375          bool Diagnosed = false;
2376          for (auto *I : RD->fields())
2377            if (!CheckConstexprCtorInitializer(SemaRef, Dcl, I, Inits, Diagnosed,
2378                                               Kind))
2379              return false;
2380        }
2381      }
2382    } else {
2383      if (ReturnStmts.empty()) {
2384        switch (Kind) {
2385        case Sema::CheckConstexprKind::Diagnose:
2386          if (!CheckConstexprMissingReturn(SemaRef, Dcl))
2387            return false;
2388          break;
2389  
2390        case Sema::CheckConstexprKind::CheckValid:
2391          // The formal requirements don't include this rule in C++14, even
2392          // though the "must be able to produce a constant expression" rules
2393          // still imply it in some cases.
2394          if (!SemaRef.getLangOpts().CPlusPlus14)
2395            return false;
2396          break;
2397        }
2398      } else if (ReturnStmts.size() > 1) {
2399        switch (Kind) {
2400        case Sema::CheckConstexprKind::Diagnose:
2401          SemaRef.Diag(
2402              ReturnStmts.back(),
2403              SemaRef.getLangOpts().CPlusPlus14
2404                  ? diag::warn_cxx11_compat_constexpr_body_multiple_return
2405                  : diag::ext_constexpr_body_multiple_return);
2406          for (unsigned I = 0; I < ReturnStmts.size() - 1; ++I)
2407            SemaRef.Diag(ReturnStmts[I],
2408                         diag::note_constexpr_body_previous_return);
2409          break;
2410  
2411        case Sema::CheckConstexprKind::CheckValid:
2412          if (!SemaRef.getLangOpts().CPlusPlus14)
2413            return false;
2414          break;
2415        }
2416      }
2417    }
2418  
2419    // C++11 [dcl.constexpr]p5:
2420    //   if no function argument values exist such that the function invocation
2421    //   substitution would produce a constant expression, the program is
2422    //   ill-formed; no diagnostic required.
2423    // C++11 [dcl.constexpr]p3:
2424    //   - every constructor call and implicit conversion used in initializing the
2425    //     return value shall be one of those allowed in a constant expression.
2426    // C++11 [dcl.constexpr]p4:
2427    //   - every constructor involved in initializing non-static data members and
2428    //     base class sub-objects shall be a constexpr constructor.
2429    //
2430    // Note that this rule is distinct from the "requirements for a constexpr
2431    // function", so is not checked in CheckValid mode. Because the check for
2432    // constexpr potential is expensive, skip the check if the diagnostic is
2433    // disabled, the function is declared in a system header, or we're in C++23
2434    // or later mode (see https://wg21.link/P2448).
2435    bool SkipCheck =
2436        !SemaRef.getLangOpts().CheckConstexprFunctionBodies ||
2437        SemaRef.getSourceManager().isInSystemHeader(Dcl->getLocation()) ||
2438        SemaRef.getDiagnostics().isIgnored(
2439            diag::ext_constexpr_function_never_constant_expr, Dcl->getLocation());
2440    SmallVector<PartialDiagnosticAt, 8> Diags;
2441    if (Kind == Sema::CheckConstexprKind::Diagnose && !SkipCheck &&
2442        !Expr::isPotentialConstantExpr(Dcl, Diags)) {
2443      SemaRef.Diag(Dcl->getLocation(),
2444                   diag::ext_constexpr_function_never_constant_expr)
2445          << isa<CXXConstructorDecl>(Dcl) << Dcl->isConsteval()
2446          << Dcl->getNameInfo().getSourceRange();
2447      for (size_t I = 0, N = Diags.size(); I != N; ++I)
2448        SemaRef.Diag(Diags[I].first, Diags[I].second);
2449      // Don't return false here: we allow this for compatibility in
2450      // system headers.
2451    }
2452  
2453    return true;
2454  }
2455  
2456  static bool CheckConstexprMissingReturn(Sema &SemaRef,
2457                                          const FunctionDecl *Dcl) {
2458    bool IsVoidOrDependentType = Dcl->getReturnType()->isVoidType() ||
2459                                 Dcl->getReturnType()->isDependentType();
2460    // Skip emitting a missing return error diagnostic for non-void functions
2461    // since C++23 no longer mandates constexpr functions to yield constant
2462    // expressions.
2463    if (SemaRef.getLangOpts().CPlusPlus23 && !IsVoidOrDependentType)
2464      return true;
2465  
2466    // C++14 doesn't require constexpr functions to contain a 'return'
2467    // statement. We still do, unless the return type might be void, because
2468    // otherwise if there's no return statement, the function cannot
2469    // be used in a core constant expression.
2470    bool OK = SemaRef.getLangOpts().CPlusPlus14 && IsVoidOrDependentType;
2471    SemaRef.Diag(Dcl->getLocation(),
2472                 OK ? diag::warn_cxx11_compat_constexpr_body_no_return
2473                    : diag::err_constexpr_body_no_return)
2474        << Dcl->isConsteval();
2475    return OK;
2476  }
2477  
2478  bool Sema::CheckImmediateEscalatingFunctionDefinition(
2479      FunctionDecl *FD, const sema::FunctionScopeInfo *FSI) {
2480    if (!getLangOpts().CPlusPlus20 || !FD->isImmediateEscalating())
2481      return true;
2482    FD->setBodyContainsImmediateEscalatingExpressions(
2483        FSI->FoundImmediateEscalatingExpression);
2484    if (FSI->FoundImmediateEscalatingExpression) {
2485      auto it = UndefinedButUsed.find(FD->getCanonicalDecl());
2486      if (it != UndefinedButUsed.end()) {
2487        Diag(it->second, diag::err_immediate_function_used_before_definition)
2488            << it->first;
2489        Diag(FD->getLocation(), diag::note_defined_here) << FD;
2490        if (FD->isImmediateFunction() && !FD->isConsteval())
2491          DiagnoseImmediateEscalatingReason(FD);
2492        return false;
2493      }
2494    }
2495    return true;
2496  }
2497  
2498  void Sema::DiagnoseImmediateEscalatingReason(FunctionDecl *FD) {
2499    assert(FD->isImmediateEscalating() && !FD->isConsteval() &&
2500           "expected an immediate function");
2501    assert(FD->hasBody() && "expected the function to have a body");
2502    struct ImmediateEscalatingExpressionsVisitor
2503        : public RecursiveASTVisitor<ImmediateEscalatingExpressionsVisitor> {
2504  
2505      using Base = RecursiveASTVisitor<ImmediateEscalatingExpressionsVisitor>;
2506      Sema &SemaRef;
2507  
2508      const FunctionDecl *ImmediateFn;
2509      bool ImmediateFnIsConstructor;
2510      CXXConstructorDecl *CurrentConstructor = nullptr;
2511      CXXCtorInitializer *CurrentInit = nullptr;
2512  
2513      ImmediateEscalatingExpressionsVisitor(Sema &SemaRef, FunctionDecl *FD)
2514          : SemaRef(SemaRef), ImmediateFn(FD),
2515            ImmediateFnIsConstructor(isa<CXXConstructorDecl>(FD)) {}
2516  
2517      bool shouldVisitImplicitCode() const { return true; }
2518      bool shouldVisitLambdaBody() const { return false; }
2519  
2520      void Diag(const Expr *E, const FunctionDecl *Fn, bool IsCall) {
2521        SourceLocation Loc = E->getBeginLoc();
2522        SourceRange Range = E->getSourceRange();
2523        if (CurrentConstructor && CurrentInit) {
2524          Loc = CurrentConstructor->getLocation();
2525          Range = CurrentInit->isWritten() ? CurrentInit->getSourceRange()
2526                                           : SourceRange();
2527        }
2528  
2529        FieldDecl* InitializedField = CurrentInit ? CurrentInit->getAnyMember() : nullptr;
2530  
2531        SemaRef.Diag(Loc, diag::note_immediate_function_reason)
2532            << ImmediateFn << Fn << Fn->isConsteval() << IsCall
2533            << isa<CXXConstructorDecl>(Fn) << ImmediateFnIsConstructor
2534            << (InitializedField != nullptr)
2535            << (CurrentInit && !CurrentInit->isWritten())
2536            << InitializedField << Range;
2537      }
2538      bool TraverseCallExpr(CallExpr *E) {
2539        if (const auto *DR =
2540                dyn_cast<DeclRefExpr>(E->getCallee()->IgnoreImplicit());
2541            DR && DR->isImmediateEscalating()) {
2542          Diag(E, E->getDirectCallee(), /*IsCall=*/true);
2543          return false;
2544        }
2545  
2546        for (Expr *A : E->arguments())
2547          if (!getDerived().TraverseStmt(A))
2548            return false;
2549  
2550        return true;
2551      }
2552  
2553      bool VisitDeclRefExpr(DeclRefExpr *E) {
2554        if (const auto *ReferencedFn = dyn_cast<FunctionDecl>(E->getDecl());
2555            ReferencedFn && E->isImmediateEscalating()) {
2556          Diag(E, ReferencedFn, /*IsCall=*/false);
2557          return false;
2558        }
2559  
2560        return true;
2561      }
2562  
2563      bool VisitCXXConstructExpr(CXXConstructExpr *E) {
2564        CXXConstructorDecl *D = E->getConstructor();
2565        if (E->isImmediateEscalating()) {
2566          Diag(E, D, /*IsCall=*/true);
2567          return false;
2568        }
2569        return true;
2570      }
2571  
2572      bool TraverseConstructorInitializer(CXXCtorInitializer *Init) {
2573        llvm::SaveAndRestore RAII(CurrentInit, Init);
2574        return Base::TraverseConstructorInitializer(Init);
2575      }
2576  
2577      bool TraverseCXXConstructorDecl(CXXConstructorDecl *Ctr) {
2578        llvm::SaveAndRestore RAII(CurrentConstructor, Ctr);
2579        return Base::TraverseCXXConstructorDecl(Ctr);
2580      }
2581  
2582      bool TraverseType(QualType T) { return true; }
2583      bool VisitBlockExpr(BlockExpr *T) { return true; }
2584  
2585    } Visitor(*this, FD);
2586    Visitor.TraverseDecl(FD);
2587  }
2588  
2589  CXXRecordDecl *Sema::getCurrentClass(Scope *, const CXXScopeSpec *SS) {
2590    assert(getLangOpts().CPlusPlus && "No class names in C!");
2591  
2592    if (SS && SS->isInvalid())
2593      return nullptr;
2594  
2595    if (SS && SS->isNotEmpty()) {
2596      DeclContext *DC = computeDeclContext(*SS, true);
2597      return dyn_cast_or_null<CXXRecordDecl>(DC);
2598    }
2599  
2600    return dyn_cast_or_null<CXXRecordDecl>(CurContext);
2601  }
2602  
2603  bool Sema::isCurrentClassName(const IdentifierInfo &II, Scope *S,
2604                                const CXXScopeSpec *SS) {
2605    CXXRecordDecl *CurDecl = getCurrentClass(S, SS);
2606    return CurDecl && &II == CurDecl->getIdentifier();
2607  }
2608  
2609  bool Sema::isCurrentClassNameTypo(IdentifierInfo *&II, const CXXScopeSpec *SS) {
2610    assert(getLangOpts().CPlusPlus && "No class names in C!");
2611  
2612    if (!getLangOpts().SpellChecking)
2613      return false;
2614  
2615    CXXRecordDecl *CurDecl;
2616    if (SS && SS->isSet() && !SS->isInvalid()) {
2617      DeclContext *DC = computeDeclContext(*SS, true);
2618      CurDecl = dyn_cast_or_null<CXXRecordDecl>(DC);
2619    } else
2620      CurDecl = dyn_cast_or_null<CXXRecordDecl>(CurContext);
2621  
2622    if (CurDecl && CurDecl->getIdentifier() && II != CurDecl->getIdentifier() &&
2623        3 * II->getName().edit_distance(CurDecl->getIdentifier()->getName())
2624            < II->getLength()) {
2625      II = CurDecl->getIdentifier();
2626      return true;
2627    }
2628  
2629    return false;
2630  }
2631  
2632  CXXBaseSpecifier *Sema::CheckBaseSpecifier(CXXRecordDecl *Class,
2633                                             SourceRange SpecifierRange,
2634                                             bool Virtual, AccessSpecifier Access,
2635                                             TypeSourceInfo *TInfo,
2636                                             SourceLocation EllipsisLoc) {
2637    QualType BaseType = TInfo->getType();
2638    SourceLocation BaseLoc = TInfo->getTypeLoc().getBeginLoc();
2639    if (BaseType->containsErrors()) {
2640      // Already emitted a diagnostic when parsing the error type.
2641      return nullptr;
2642    }
2643  
2644    if (EllipsisLoc.isValid() && !BaseType->containsUnexpandedParameterPack()) {
2645      Diag(EllipsisLoc, diag::err_pack_expansion_without_parameter_packs)
2646        << TInfo->getTypeLoc().getSourceRange();
2647      EllipsisLoc = SourceLocation();
2648    }
2649  
2650    auto *BaseDecl =
2651        dyn_cast_if_present<CXXRecordDecl>(computeDeclContext(BaseType));
2652    // C++ [class.derived.general]p2:
2653    //   A class-or-decltype shall denote a (possibly cv-qualified) class type
2654    //   that is not an incompletely defined class; any cv-qualifiers are
2655    //   ignored.
2656    if (BaseDecl) {
2657      // C++ [class.union.general]p4:
2658      // [...]  A union shall not be used as a base class.
2659      if (BaseDecl->isUnion()) {
2660        Diag(BaseLoc, diag::err_union_as_base_class) << SpecifierRange;
2661        return nullptr;
2662      }
2663  
2664      // For the MS ABI, propagate DLL attributes to base class templates.
2665      if (Context.getTargetInfo().getCXXABI().isMicrosoft() ||
2666          Context.getTargetInfo().getTriple().isPS()) {
2667        if (Attr *ClassAttr = getDLLAttr(Class)) {
2668          if (auto *BaseSpec =
2669                  dyn_cast<ClassTemplateSpecializationDecl>(BaseDecl)) {
2670            propagateDLLAttrToBaseClassTemplate(Class, ClassAttr, BaseSpec,
2671                                                BaseLoc);
2672          }
2673        }
2674      }
2675  
2676      if (RequireCompleteType(BaseLoc, BaseType, diag::err_incomplete_base_class,
2677                              SpecifierRange)) {
2678        Class->setInvalidDecl();
2679        return nullptr;
2680      }
2681  
2682      BaseDecl = BaseDecl->getDefinition();
2683      assert(BaseDecl && "Base type is not incomplete, but has no definition");
2684  
2685      // Microsoft docs say:
2686      // "If a base-class has a code_seg attribute, derived classes must have the
2687      // same attribute."
2688      const auto *BaseCSA = BaseDecl->getAttr<CodeSegAttr>();
2689      const auto *DerivedCSA = Class->getAttr<CodeSegAttr>();
2690      if ((DerivedCSA || BaseCSA) &&
2691          (!BaseCSA || !DerivedCSA ||
2692           BaseCSA->getName() != DerivedCSA->getName())) {
2693        Diag(Class->getLocation(), diag::err_mismatched_code_seg_base);
2694        Diag(BaseDecl->getLocation(), diag::note_base_class_specified_here)
2695            << BaseDecl;
2696        return nullptr;
2697      }
2698  
2699      // A class which contains a flexible array member is not suitable for use as
2700      // a base class:
2701      //   - If the layout determines that a base comes before another base,
2702      //     the flexible array member would index into the subsequent base.
2703      //   - If the layout determines that base comes before the derived class,
2704      //     the flexible array member would index into the derived class.
2705      if (BaseDecl->hasFlexibleArrayMember()) {
2706        Diag(BaseLoc, diag::err_base_class_has_flexible_array_member)
2707            << BaseDecl->getDeclName();
2708        return nullptr;
2709      }
2710  
2711      // C++ [class]p3:
2712      //   If a class is marked final and it appears as a base-type-specifier in
2713      //   base-clause, the program is ill-formed.
2714      if (FinalAttr *FA = BaseDecl->getAttr<FinalAttr>()) {
2715        Diag(BaseLoc, diag::err_class_marked_final_used_as_base)
2716            << BaseDecl->getDeclName() << FA->isSpelledAsSealed();
2717        Diag(BaseDecl->getLocation(), diag::note_entity_declared_at)
2718            << BaseDecl->getDeclName() << FA->getRange();
2719        return nullptr;
2720      }
2721  
2722      // If the base class is invalid the derived class is as well.
2723      if (BaseDecl->isInvalidDecl())
2724        Class->setInvalidDecl();
2725    } else if (BaseType->isDependentType()) {
2726      // Make sure that we don't make an ill-formed AST where the type of the
2727      // Class is non-dependent and its attached base class specifier is an
2728      // dependent type, which violates invariants in many clang code paths (e.g.
2729      // constexpr evaluator). If this case happens (in errory-recovery mode), we
2730      // explicitly mark the Class decl invalid. The diagnostic was already
2731      // emitted.
2732      if (!Class->isDependentContext())
2733        Class->setInvalidDecl();
2734    } else {
2735      // The base class is some non-dependent non-class type.
2736      Diag(BaseLoc, diag::err_base_must_be_class) << SpecifierRange;
2737      return nullptr;
2738    }
2739  
2740    // In HLSL, unspecified class access is public rather than private.
2741    if (getLangOpts().HLSL && Class->getTagKind() == TagTypeKind::Class &&
2742        Access == AS_none)
2743      Access = AS_public;
2744  
2745    // Create the base specifier.
2746    return new (Context) CXXBaseSpecifier(
2747        SpecifierRange, Virtual, Class->getTagKind() == TagTypeKind::Class,
2748        Access, TInfo, EllipsisLoc);
2749  }
2750  
2751  BaseResult Sema::ActOnBaseSpecifier(Decl *classdecl, SourceRange SpecifierRange,
2752                                      const ParsedAttributesView &Attributes,
2753                                      bool Virtual, AccessSpecifier Access,
2754                                      ParsedType basetype, SourceLocation BaseLoc,
2755                                      SourceLocation EllipsisLoc) {
2756    if (!classdecl)
2757      return true;
2758  
2759    AdjustDeclIfTemplate(classdecl);
2760    CXXRecordDecl *Class = dyn_cast<CXXRecordDecl>(classdecl);
2761    if (!Class)
2762      return true;
2763  
2764    // We haven't yet attached the base specifiers.
2765    Class->setIsParsingBaseSpecifiers();
2766  
2767    // We do not support any C++11 attributes on base-specifiers yet.
2768    // Diagnose any attributes we see.
2769    for (const ParsedAttr &AL : Attributes) {
2770      if (AL.isInvalid() || AL.getKind() == ParsedAttr::IgnoredAttribute)
2771        continue;
2772      if (AL.getKind() == ParsedAttr::UnknownAttribute)
2773        Diag(AL.getLoc(), diag::warn_unknown_attribute_ignored)
2774            << AL << AL.getRange();
2775      else
2776        Diag(AL.getLoc(), diag::err_base_specifier_attribute)
2777            << AL << AL.isRegularKeywordAttribute() << AL.getRange();
2778    }
2779  
2780    TypeSourceInfo *TInfo = nullptr;
2781    GetTypeFromParser(basetype, &TInfo);
2782  
2783    if (EllipsisLoc.isInvalid() &&
2784        DiagnoseUnexpandedParameterPack(SpecifierRange.getBegin(), TInfo,
2785                                        UPPC_BaseType))
2786      return true;
2787  
2788    // C++ [class.union.general]p4:
2789    //   [...] A union shall not have base classes.
2790    if (Class->isUnion()) {
2791      Diag(Class->getLocation(), diag::err_base_clause_on_union)
2792          << SpecifierRange;
2793      return true;
2794    }
2795  
2796    if (CXXBaseSpecifier *BaseSpec = CheckBaseSpecifier(Class, SpecifierRange,
2797                                                        Virtual, Access, TInfo,
2798                                                        EllipsisLoc))
2799      return BaseSpec;
2800  
2801    Class->setInvalidDecl();
2802    return true;
2803  }
2804  
2805  /// Use small set to collect indirect bases.  As this is only used
2806  /// locally, there's no need to abstract the small size parameter.
2807  typedef llvm::SmallPtrSet<QualType, 4> IndirectBaseSet;
2808  
2809  /// Recursively add the bases of Type.  Don't add Type itself.
2810  static void
2811  NoteIndirectBases(ASTContext &Context, IndirectBaseSet &Set,
2812                    const QualType &Type)
2813  {
2814    // Even though the incoming type is a base, it might not be
2815    // a class -- it could be a template parm, for instance.
2816    if (auto Rec = Type->getAs<RecordType>()) {
2817      auto Decl = Rec->getAsCXXRecordDecl();
2818  
2819      // Iterate over its bases.
2820      for (const auto &BaseSpec : Decl->bases()) {
2821        QualType Base = Context.getCanonicalType(BaseSpec.getType())
2822          .getUnqualifiedType();
2823        if (Set.insert(Base).second)
2824          // If we've not already seen it, recurse.
2825          NoteIndirectBases(Context, Set, Base);
2826      }
2827    }
2828  }
2829  
2830  bool Sema::AttachBaseSpecifiers(CXXRecordDecl *Class,
2831                                  MutableArrayRef<CXXBaseSpecifier *> Bases) {
2832   if (Bases.empty())
2833      return false;
2834  
2835    // Used to keep track of which base types we have already seen, so
2836    // that we can properly diagnose redundant direct base types. Note
2837    // that the key is always the unqualified canonical type of the base
2838    // class.
2839    std::map<QualType, CXXBaseSpecifier*, QualTypeOrdering> KnownBaseTypes;
2840  
2841    // Used to track indirect bases so we can see if a direct base is
2842    // ambiguous.
2843    IndirectBaseSet IndirectBaseTypes;
2844  
2845    // Copy non-redundant base specifiers into permanent storage.
2846    unsigned NumGoodBases = 0;
2847    bool Invalid = false;
2848    for (unsigned idx = 0; idx < Bases.size(); ++idx) {
2849      QualType NewBaseType
2850        = Context.getCanonicalType(Bases[idx]->getType());
2851      NewBaseType = NewBaseType.getLocalUnqualifiedType();
2852  
2853      CXXBaseSpecifier *&KnownBase = KnownBaseTypes[NewBaseType];
2854      if (KnownBase) {
2855        // C++ [class.mi]p3:
2856        //   A class shall not be specified as a direct base class of a
2857        //   derived class more than once.
2858        Diag(Bases[idx]->getBeginLoc(), diag::err_duplicate_base_class)
2859            << KnownBase->getType() << Bases[idx]->getSourceRange();
2860  
2861        // Delete the duplicate base class specifier; we're going to
2862        // overwrite its pointer later.
2863        Context.Deallocate(Bases[idx]);
2864  
2865        Invalid = true;
2866      } else {
2867        // Okay, add this new base class.
2868        KnownBase = Bases[idx];
2869        Bases[NumGoodBases++] = Bases[idx];
2870  
2871        if (NewBaseType->isDependentType())
2872          continue;
2873        // Note this base's direct & indirect bases, if there could be ambiguity.
2874        if (Bases.size() > 1)
2875          NoteIndirectBases(Context, IndirectBaseTypes, NewBaseType);
2876  
2877        if (const RecordType *Record = NewBaseType->getAs<RecordType>()) {
2878          const CXXRecordDecl *RD = cast<CXXRecordDecl>(Record->getDecl());
2879          if (Class->isInterface() &&
2880                (!RD->isInterfaceLike() ||
2881                 KnownBase->getAccessSpecifier() != AS_public)) {
2882            // The Microsoft extension __interface does not permit bases that
2883            // are not themselves public interfaces.
2884            Diag(KnownBase->getBeginLoc(), diag::err_invalid_base_in_interface)
2885                << getRecordDiagFromTagKind(RD->getTagKind()) << RD
2886                << RD->getSourceRange();
2887            Invalid = true;
2888          }
2889          if (RD->hasAttr<WeakAttr>())
2890            Class->addAttr(WeakAttr::CreateImplicit(Context));
2891        }
2892      }
2893    }
2894  
2895    // Attach the remaining base class specifiers to the derived class.
2896    Class->setBases(Bases.data(), NumGoodBases);
2897  
2898    // Check that the only base classes that are duplicate are virtual.
2899    for (unsigned idx = 0; idx < NumGoodBases; ++idx) {
2900      // Check whether this direct base is inaccessible due to ambiguity.
2901      QualType BaseType = Bases[idx]->getType();
2902  
2903      // Skip all dependent types in templates being used as base specifiers.
2904      // Checks below assume that the base specifier is a CXXRecord.
2905      if (BaseType->isDependentType())
2906        continue;
2907  
2908      CanQualType CanonicalBase = Context.getCanonicalType(BaseType)
2909        .getUnqualifiedType();
2910  
2911      if (IndirectBaseTypes.count(CanonicalBase)) {
2912        CXXBasePaths Paths(/*FindAmbiguities=*/true, /*RecordPaths=*/true,
2913                           /*DetectVirtual=*/true);
2914        bool found
2915          = Class->isDerivedFrom(CanonicalBase->getAsCXXRecordDecl(), Paths);
2916        assert(found);
2917        (void)found;
2918  
2919        if (Paths.isAmbiguous(CanonicalBase))
2920          Diag(Bases[idx]->getBeginLoc(), diag::warn_inaccessible_base_class)
2921              << BaseType << getAmbiguousPathsDisplayString(Paths)
2922              << Bases[idx]->getSourceRange();
2923        else
2924          assert(Bases[idx]->isVirtual());
2925      }
2926  
2927      // Delete the base class specifier, since its data has been copied
2928      // into the CXXRecordDecl.
2929      Context.Deallocate(Bases[idx]);
2930    }
2931  
2932    return Invalid;
2933  }
2934  
2935  void Sema::ActOnBaseSpecifiers(Decl *ClassDecl,
2936                                 MutableArrayRef<CXXBaseSpecifier *> Bases) {
2937    if (!ClassDecl || Bases.empty())
2938      return;
2939  
2940    AdjustDeclIfTemplate(ClassDecl);
2941    AttachBaseSpecifiers(cast<CXXRecordDecl>(ClassDecl), Bases);
2942  }
2943  
2944  bool Sema::IsDerivedFrom(SourceLocation Loc, QualType Derived, QualType Base) {
2945    if (!getLangOpts().CPlusPlus)
2946      return false;
2947  
2948    CXXRecordDecl *DerivedRD = Derived->getAsCXXRecordDecl();
2949    if (!DerivedRD)
2950      return false;
2951  
2952    CXXRecordDecl *BaseRD = Base->getAsCXXRecordDecl();
2953    if (!BaseRD)
2954      return false;
2955  
2956    // If either the base or the derived type is invalid, don't try to
2957    // check whether one is derived from the other.
2958    if (BaseRD->isInvalidDecl() || DerivedRD->isInvalidDecl())
2959      return false;
2960  
2961    // FIXME: In a modules build, do we need the entire path to be visible for us
2962    // to be able to use the inheritance relationship?
2963    if (!isCompleteType(Loc, Derived) && !DerivedRD->isBeingDefined())
2964      return false;
2965  
2966    return DerivedRD->isDerivedFrom(BaseRD);
2967  }
2968  
2969  bool Sema::IsDerivedFrom(SourceLocation Loc, QualType Derived, QualType Base,
2970                           CXXBasePaths &Paths) {
2971    if (!getLangOpts().CPlusPlus)
2972      return false;
2973  
2974    CXXRecordDecl *DerivedRD = Derived->getAsCXXRecordDecl();
2975    if (!DerivedRD)
2976      return false;
2977  
2978    CXXRecordDecl *BaseRD = Base->getAsCXXRecordDecl();
2979    if (!BaseRD)
2980      return false;
2981  
2982    if (!isCompleteType(Loc, Derived) && !DerivedRD->isBeingDefined())
2983      return false;
2984  
2985    return DerivedRD->isDerivedFrom(BaseRD, Paths);
2986  }
2987  
2988  static void BuildBasePathArray(const CXXBasePath &Path,
2989                                 CXXCastPath &BasePathArray) {
2990    // We first go backward and check if we have a virtual base.
2991    // FIXME: It would be better if CXXBasePath had the base specifier for
2992    // the nearest virtual base.
2993    unsigned Start = 0;
2994    for (unsigned I = Path.size(); I != 0; --I) {
2995      if (Path[I - 1].Base->isVirtual()) {
2996        Start = I - 1;
2997        break;
2998      }
2999    }
3000  
3001    // Now add all bases.
3002    for (unsigned I = Start, E = Path.size(); I != E; ++I)
3003      BasePathArray.push_back(const_cast<CXXBaseSpecifier*>(Path[I].Base));
3004  }
3005  
3006  
3007  void Sema::BuildBasePathArray(const CXXBasePaths &Paths,
3008                                CXXCastPath &BasePathArray) {
3009    assert(BasePathArray.empty() && "Base path array must be empty!");
3010    assert(Paths.isRecordingPaths() && "Must record paths!");
3011    return ::BuildBasePathArray(Paths.front(), BasePathArray);
3012  }
3013  
3014  bool
3015  Sema::CheckDerivedToBaseConversion(QualType Derived, QualType Base,
3016                                     unsigned InaccessibleBaseID,
3017                                     unsigned AmbiguousBaseConvID,
3018                                     SourceLocation Loc, SourceRange Range,
3019                                     DeclarationName Name,
3020                                     CXXCastPath *BasePath,
3021                                     bool IgnoreAccess) {
3022    // First, determine whether the path from Derived to Base is
3023    // ambiguous. This is slightly more expensive than checking whether
3024    // the Derived to Base conversion exists, because here we need to
3025    // explore multiple paths to determine if there is an ambiguity.
3026    CXXBasePaths Paths(/*FindAmbiguities=*/true, /*RecordPaths=*/true,
3027                       /*DetectVirtual=*/false);
3028    bool DerivationOkay = IsDerivedFrom(Loc, Derived, Base, Paths);
3029    if (!DerivationOkay)
3030      return true;
3031  
3032    const CXXBasePath *Path = nullptr;
3033    if (!Paths.isAmbiguous(Context.getCanonicalType(Base).getUnqualifiedType()))
3034      Path = &Paths.front();
3035  
3036    // For MSVC compatibility, check if Derived directly inherits from Base. Clang
3037    // warns about this hierarchy under -Winaccessible-base, but MSVC allows the
3038    // user to access such bases.
3039    if (!Path && getLangOpts().MSVCCompat) {
3040      for (const CXXBasePath &PossiblePath : Paths) {
3041        if (PossiblePath.size() == 1) {
3042          Path = &PossiblePath;
3043          if (AmbiguousBaseConvID)
3044            Diag(Loc, diag::ext_ms_ambiguous_direct_base)
3045                << Base << Derived << Range;
3046          break;
3047        }
3048      }
3049    }
3050  
3051    if (Path) {
3052      if (!IgnoreAccess) {
3053        // Check that the base class can be accessed.
3054        switch (
3055            CheckBaseClassAccess(Loc, Base, Derived, *Path, InaccessibleBaseID)) {
3056        case AR_inaccessible:
3057          return true;
3058        case AR_accessible:
3059        case AR_dependent:
3060        case AR_delayed:
3061          break;
3062        }
3063      }
3064  
3065      // Build a base path if necessary.
3066      if (BasePath)
3067        ::BuildBasePathArray(*Path, *BasePath);
3068      return false;
3069    }
3070  
3071    if (AmbiguousBaseConvID) {
3072      // We know that the derived-to-base conversion is ambiguous, and
3073      // we're going to produce a diagnostic. Perform the derived-to-base
3074      // search just one more time to compute all of the possible paths so
3075      // that we can print them out. This is more expensive than any of
3076      // the previous derived-to-base checks we've done, but at this point
3077      // performance isn't as much of an issue.
3078      Paths.clear();
3079      Paths.setRecordingPaths(true);
3080      bool StillOkay = IsDerivedFrom(Loc, Derived, Base, Paths);
3081      assert(StillOkay && "Can only be used with a derived-to-base conversion");
3082      (void)StillOkay;
3083  
3084      // Build up a textual representation of the ambiguous paths, e.g.,
3085      // D -> B -> A, that will be used to illustrate the ambiguous
3086      // conversions in the diagnostic. We only print one of the paths
3087      // to each base class subobject.
3088      std::string PathDisplayStr = getAmbiguousPathsDisplayString(Paths);
3089  
3090      Diag(Loc, AmbiguousBaseConvID)
3091      << Derived << Base << PathDisplayStr << Range << Name;
3092    }
3093    return true;
3094  }
3095  
3096  bool
3097  Sema::CheckDerivedToBaseConversion(QualType Derived, QualType Base,
3098                                     SourceLocation Loc, SourceRange Range,
3099                                     CXXCastPath *BasePath,
3100                                     bool IgnoreAccess) {
3101    return CheckDerivedToBaseConversion(
3102        Derived, Base, diag::err_upcast_to_inaccessible_base,
3103        diag::err_ambiguous_derived_to_base_conv, Loc, Range, DeclarationName(),
3104        BasePath, IgnoreAccess);
3105  }
3106  
3107  std::string Sema::getAmbiguousPathsDisplayString(CXXBasePaths &Paths) {
3108    std::string PathDisplayStr;
3109    std::set<unsigned> DisplayedPaths;
3110    for (CXXBasePaths::paths_iterator Path = Paths.begin();
3111         Path != Paths.end(); ++Path) {
3112      if (DisplayedPaths.insert(Path->back().SubobjectNumber).second) {
3113        // We haven't displayed a path to this particular base
3114        // class subobject yet.
3115        PathDisplayStr += "\n    ";
3116        PathDisplayStr += Context.getTypeDeclType(Paths.getOrigin()).getAsString();
3117        for (CXXBasePath::const_iterator Element = Path->begin();
3118             Element != Path->end(); ++Element)
3119          PathDisplayStr += " -> " + Element->Base->getType().getAsString();
3120      }
3121    }
3122  
3123    return PathDisplayStr;
3124  }
3125  
3126  //===----------------------------------------------------------------------===//
3127  // C++ class member Handling
3128  //===----------------------------------------------------------------------===//
3129  
3130  bool Sema::ActOnAccessSpecifier(AccessSpecifier Access, SourceLocation ASLoc,
3131                                  SourceLocation ColonLoc,
3132                                  const ParsedAttributesView &Attrs) {
3133    assert(Access != AS_none && "Invalid kind for syntactic access specifier!");
3134    AccessSpecDecl *ASDecl = AccessSpecDecl::Create(Context, Access, CurContext,
3135                                                    ASLoc, ColonLoc);
3136    CurContext->addHiddenDecl(ASDecl);
3137    return ProcessAccessDeclAttributeList(ASDecl, Attrs);
3138  }
3139  
3140  void Sema::CheckOverrideControl(NamedDecl *D) {
3141    if (D->isInvalidDecl())
3142      return;
3143  
3144    // We only care about "override" and "final" declarations.
3145    if (!D->hasAttr<OverrideAttr>() && !D->hasAttr<FinalAttr>())
3146      return;
3147  
3148    CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(D);
3149  
3150    // We can't check dependent instance methods.
3151    if (MD && MD->isInstance() &&
3152        (MD->getParent()->hasAnyDependentBases() ||
3153         MD->getType()->isDependentType()))
3154      return;
3155  
3156    if (MD && !MD->isVirtual()) {
3157      // If we have a non-virtual method, check if it hides a virtual method.
3158      // (In that case, it's most likely the method has the wrong type.)
3159      SmallVector<CXXMethodDecl *, 8> OverloadedMethods;
3160      FindHiddenVirtualMethods(MD, OverloadedMethods);
3161  
3162      if (!OverloadedMethods.empty()) {
3163        if (OverrideAttr *OA = D->getAttr<OverrideAttr>()) {
3164          Diag(OA->getLocation(),
3165               diag::override_keyword_hides_virtual_member_function)
3166            << "override" << (OverloadedMethods.size() > 1);
3167        } else if (FinalAttr *FA = D->getAttr<FinalAttr>()) {
3168          Diag(FA->getLocation(),
3169               diag::override_keyword_hides_virtual_member_function)
3170            << (FA->isSpelledAsSealed() ? "sealed" : "final")
3171            << (OverloadedMethods.size() > 1);
3172        }
3173        NoteHiddenVirtualMethods(MD, OverloadedMethods);
3174        MD->setInvalidDecl();
3175        return;
3176      }
3177      // Fall through into the general case diagnostic.
3178      // FIXME: We might want to attempt typo correction here.
3179    }
3180  
3181    if (!MD || !MD->isVirtual()) {
3182      if (OverrideAttr *OA = D->getAttr<OverrideAttr>()) {
3183        Diag(OA->getLocation(),
3184             diag::override_keyword_only_allowed_on_virtual_member_functions)
3185          << "override" << FixItHint::CreateRemoval(OA->getLocation());
3186        D->dropAttr<OverrideAttr>();
3187      }
3188      if (FinalAttr *FA = D->getAttr<FinalAttr>()) {
3189        Diag(FA->getLocation(),
3190             diag::override_keyword_only_allowed_on_virtual_member_functions)
3191          << (FA->isSpelledAsSealed() ? "sealed" : "final")
3192          << FixItHint::CreateRemoval(FA->getLocation());
3193        D->dropAttr<FinalAttr>();
3194      }
3195      return;
3196    }
3197  
3198    // C++11 [class.virtual]p5:
3199    //   If a function is marked with the virt-specifier override and
3200    //   does not override a member function of a base class, the program is
3201    //   ill-formed.
3202    bool HasOverriddenMethods = MD->size_overridden_methods() != 0;
3203    if (MD->hasAttr<OverrideAttr>() && !HasOverriddenMethods)
3204      Diag(MD->getLocation(), diag::err_function_marked_override_not_overriding)
3205        << MD->getDeclName();
3206  }
3207  
3208  void Sema::DiagnoseAbsenceOfOverrideControl(NamedDecl *D, bool Inconsistent) {
3209    if (D->isInvalidDecl() || D->hasAttr<OverrideAttr>())
3210      return;
3211    CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(D);
3212    if (!MD || MD->isImplicit() || MD->hasAttr<FinalAttr>())
3213      return;
3214  
3215    SourceLocation Loc = MD->getLocation();
3216    SourceLocation SpellingLoc = Loc;
3217    if (getSourceManager().isMacroArgExpansion(Loc))
3218      SpellingLoc = getSourceManager().getImmediateExpansionRange(Loc).getBegin();
3219    SpellingLoc = getSourceManager().getSpellingLoc(SpellingLoc);
3220    if (SpellingLoc.isValid() && getSourceManager().isInSystemHeader(SpellingLoc))
3221        return;
3222  
3223    if (MD->size_overridden_methods() > 0) {
3224      auto EmitDiag = [&](unsigned DiagInconsistent, unsigned DiagSuggest) {
3225        unsigned DiagID =
3226            Inconsistent && !Diags.isIgnored(DiagInconsistent, MD->getLocation())
3227                ? DiagInconsistent
3228                : DiagSuggest;
3229        Diag(MD->getLocation(), DiagID) << MD->getDeclName();
3230        const CXXMethodDecl *OMD = *MD->begin_overridden_methods();
3231        Diag(OMD->getLocation(), diag::note_overridden_virtual_function);
3232      };
3233      if (isa<CXXDestructorDecl>(MD))
3234        EmitDiag(
3235            diag::warn_inconsistent_destructor_marked_not_override_overriding,
3236            diag::warn_suggest_destructor_marked_not_override_overriding);
3237      else
3238        EmitDiag(diag::warn_inconsistent_function_marked_not_override_overriding,
3239                 diag::warn_suggest_function_marked_not_override_overriding);
3240    }
3241  }
3242  
3243  bool Sema::CheckIfOverriddenFunctionIsMarkedFinal(const CXXMethodDecl *New,
3244                                                    const CXXMethodDecl *Old) {
3245    FinalAttr *FA = Old->getAttr<FinalAttr>();
3246    if (!FA)
3247      return false;
3248  
3249    Diag(New->getLocation(), diag::err_final_function_overridden)
3250      << New->getDeclName()
3251      << FA->isSpelledAsSealed();
3252    Diag(Old->getLocation(), diag::note_overridden_virtual_function);
3253    return true;
3254  }
3255  
3256  static bool InitializationHasSideEffects(const FieldDecl &FD) {
3257    const Type *T = FD.getType()->getBaseElementTypeUnsafe();
3258    // FIXME: Destruction of ObjC lifetime types has side-effects.
3259    if (const CXXRecordDecl *RD = T->getAsCXXRecordDecl())
3260      return !RD->isCompleteDefinition() ||
3261             !RD->hasTrivialDefaultConstructor() ||
3262             !RD->hasTrivialDestructor();
3263    return false;
3264  }
3265  
3266  void Sema::CheckShadowInheritedFields(const SourceLocation &Loc,
3267                                        DeclarationName FieldName,
3268                                        const CXXRecordDecl *RD,
3269                                        bool DeclIsField) {
3270    if (Diags.isIgnored(diag::warn_shadow_field, Loc))
3271      return;
3272  
3273    // To record a shadowed field in a base
3274    std::map<CXXRecordDecl*, NamedDecl*> Bases;
3275    auto FieldShadowed = [&](const CXXBaseSpecifier *Specifier,
3276                             CXXBasePath &Path) {
3277      const auto Base = Specifier->getType()->getAsCXXRecordDecl();
3278      // Record an ambiguous path directly
3279      if (Bases.find(Base) != Bases.end())
3280        return true;
3281      for (const auto Field : Base->lookup(FieldName)) {
3282        if ((isa<FieldDecl>(Field) || isa<IndirectFieldDecl>(Field)) &&
3283            Field->getAccess() != AS_private) {
3284          assert(Field->getAccess() != AS_none);
3285          assert(Bases.find(Base) == Bases.end());
3286          Bases[Base] = Field;
3287          return true;
3288        }
3289      }
3290      return false;
3291    };
3292  
3293    CXXBasePaths Paths(/*FindAmbiguities=*/true, /*RecordPaths=*/true,
3294                       /*DetectVirtual=*/true);
3295    if (!RD->lookupInBases(FieldShadowed, Paths))
3296      return;
3297  
3298    for (const auto &P : Paths) {
3299      auto Base = P.back().Base->getType()->getAsCXXRecordDecl();
3300      auto It = Bases.find(Base);
3301      // Skip duplicated bases
3302      if (It == Bases.end())
3303        continue;
3304      auto BaseField = It->second;
3305      assert(BaseField->getAccess() != AS_private);
3306      if (AS_none !=
3307          CXXRecordDecl::MergeAccess(P.Access, BaseField->getAccess())) {
3308        Diag(Loc, diag::warn_shadow_field)
3309          << FieldName << RD << Base << DeclIsField;
3310        Diag(BaseField->getLocation(), diag::note_shadow_field);
3311        Bases.erase(It);
3312      }
3313    }
3314  }
3315  
3316  NamedDecl *
3317  Sema::ActOnCXXMemberDeclarator(Scope *S, AccessSpecifier AS, Declarator &D,
3318                                 MultiTemplateParamsArg TemplateParameterLists,
3319                                 Expr *BW, const VirtSpecifiers &VS,
3320                                 InClassInitStyle InitStyle) {
3321    const DeclSpec &DS = D.getDeclSpec();
3322    DeclarationNameInfo NameInfo = GetNameForDeclarator(D);
3323    DeclarationName Name = NameInfo.getName();
3324    SourceLocation Loc = NameInfo.getLoc();
3325  
3326    // For anonymous bitfields, the location should point to the type.
3327    if (Loc.isInvalid())
3328      Loc = D.getBeginLoc();
3329  
3330    Expr *BitWidth = static_cast<Expr*>(BW);
3331  
3332    assert(isa<CXXRecordDecl>(CurContext));
3333    assert(!DS.isFriendSpecified());
3334  
3335    bool isFunc = D.isDeclarationOfFunction();
3336    const ParsedAttr *MSPropertyAttr =
3337        D.getDeclSpec().getAttributes().getMSPropertyAttr();
3338  
3339    if (cast<CXXRecordDecl>(CurContext)->isInterface()) {
3340      // The Microsoft extension __interface only permits public member functions
3341      // and prohibits constructors, destructors, operators, non-public member
3342      // functions, static methods and data members.
3343      unsigned InvalidDecl;
3344      bool ShowDeclName = true;
3345      if (!isFunc &&
3346          (DS.getStorageClassSpec() == DeclSpec::SCS_typedef || MSPropertyAttr))
3347        InvalidDecl = 0;
3348      else if (!isFunc)
3349        InvalidDecl = 1;
3350      else if (AS != AS_public)
3351        InvalidDecl = 2;
3352      else if (DS.getStorageClassSpec() == DeclSpec::SCS_static)
3353        InvalidDecl = 3;
3354      else switch (Name.getNameKind()) {
3355        case DeclarationName::CXXConstructorName:
3356          InvalidDecl = 4;
3357          ShowDeclName = false;
3358          break;
3359  
3360        case DeclarationName::CXXDestructorName:
3361          InvalidDecl = 5;
3362          ShowDeclName = false;
3363          break;
3364  
3365        case DeclarationName::CXXOperatorName:
3366        case DeclarationName::CXXConversionFunctionName:
3367          InvalidDecl = 6;
3368          break;
3369  
3370        default:
3371          InvalidDecl = 0;
3372          break;
3373      }
3374  
3375      if (InvalidDecl) {
3376        if (ShowDeclName)
3377          Diag(Loc, diag::err_invalid_member_in_interface)
3378            << (InvalidDecl-1) << Name;
3379        else
3380          Diag(Loc, diag::err_invalid_member_in_interface)
3381            << (InvalidDecl-1) << "";
3382        return nullptr;
3383      }
3384    }
3385  
3386    // C++ 9.2p6: A member shall not be declared to have automatic storage
3387    // duration (auto, register) or with the extern storage-class-specifier.
3388    // C++ 7.1.1p8: The mutable specifier can be applied only to names of class
3389    // data members and cannot be applied to names declared const or static,
3390    // and cannot be applied to reference members.
3391    switch (DS.getStorageClassSpec()) {
3392    case DeclSpec::SCS_unspecified:
3393    case DeclSpec::SCS_typedef:
3394    case DeclSpec::SCS_static:
3395      break;
3396    case DeclSpec::SCS_mutable:
3397      if (isFunc) {
3398        Diag(DS.getStorageClassSpecLoc(), diag::err_mutable_function);
3399  
3400        // FIXME: It would be nicer if the keyword was ignored only for this
3401        // declarator. Otherwise we could get follow-up errors.
3402        D.getMutableDeclSpec().ClearStorageClassSpecs();
3403      }
3404      break;
3405    default:
3406      Diag(DS.getStorageClassSpecLoc(),
3407           diag::err_storageclass_invalid_for_member);
3408      D.getMutableDeclSpec().ClearStorageClassSpecs();
3409      break;
3410    }
3411  
3412    bool isInstField = (DS.getStorageClassSpec() == DeclSpec::SCS_unspecified ||
3413                        DS.getStorageClassSpec() == DeclSpec::SCS_mutable) &&
3414                       !isFunc && TemplateParameterLists.empty();
3415  
3416    if (DS.hasConstexprSpecifier() && isInstField) {
3417      SemaDiagnosticBuilder B =
3418          Diag(DS.getConstexprSpecLoc(), diag::err_invalid_constexpr_member);
3419      SourceLocation ConstexprLoc = DS.getConstexprSpecLoc();
3420      if (InitStyle == ICIS_NoInit) {
3421        B << 0 << 0;
3422        if (D.getDeclSpec().getTypeQualifiers() & DeclSpec::TQ_const)
3423          B << FixItHint::CreateRemoval(ConstexprLoc);
3424        else {
3425          B << FixItHint::CreateReplacement(ConstexprLoc, "const");
3426          D.getMutableDeclSpec().ClearConstexprSpec();
3427          const char *PrevSpec;
3428          unsigned DiagID;
3429          bool Failed = D.getMutableDeclSpec().SetTypeQual(
3430              DeclSpec::TQ_const, ConstexprLoc, PrevSpec, DiagID, getLangOpts());
3431          (void)Failed;
3432          assert(!Failed && "Making a constexpr member const shouldn't fail");
3433        }
3434      } else {
3435        B << 1;
3436        const char *PrevSpec;
3437        unsigned DiagID;
3438        if (D.getMutableDeclSpec().SetStorageClassSpec(
3439            *this, DeclSpec::SCS_static, ConstexprLoc, PrevSpec, DiagID,
3440            Context.getPrintingPolicy())) {
3441          assert(DS.getStorageClassSpec() == DeclSpec::SCS_mutable &&
3442                 "This is the only DeclSpec that should fail to be applied");
3443          B << 1;
3444        } else {
3445          B << 0 << FixItHint::CreateInsertion(ConstexprLoc, "static ");
3446          isInstField = false;
3447        }
3448      }
3449    }
3450  
3451    NamedDecl *Member;
3452    if (isInstField) {
3453      CXXScopeSpec &SS = D.getCXXScopeSpec();
3454  
3455      // Data members must have identifiers for names.
3456      if (!Name.isIdentifier()) {
3457        Diag(Loc, diag::err_bad_variable_name)
3458          << Name;
3459        return nullptr;
3460      }
3461  
3462      IdentifierInfo *II = Name.getAsIdentifierInfo();
3463      if (D.getName().getKind() == UnqualifiedIdKind::IK_TemplateId) {
3464        Diag(D.getIdentifierLoc(), diag::err_member_with_template_arguments)
3465            << II
3466            << SourceRange(D.getName().TemplateId->LAngleLoc,
3467                           D.getName().TemplateId->RAngleLoc)
3468            << D.getName().TemplateId->LAngleLoc;
3469        D.SetIdentifier(II, Loc);
3470      }
3471  
3472      if (SS.isSet() && !SS.isInvalid()) {
3473        // The user provided a superfluous scope specifier inside a class
3474        // definition:
3475        //
3476        // class X {
3477        //   int X::member;
3478        // };
3479        if (DeclContext *DC = computeDeclContext(SS, false)) {
3480          TemplateIdAnnotation *TemplateId =
3481              D.getName().getKind() == UnqualifiedIdKind::IK_TemplateId
3482                  ? D.getName().TemplateId
3483                  : nullptr;
3484          diagnoseQualifiedDeclaration(SS, DC, Name, D.getIdentifierLoc(),
3485                                       TemplateId,
3486                                       /*IsMemberSpecialization=*/false);
3487        } else {
3488          Diag(D.getIdentifierLoc(), diag::err_member_qualification)
3489            << Name << SS.getRange();
3490        }
3491        SS.clear();
3492      }
3493  
3494      if (MSPropertyAttr) {
3495        Member = HandleMSProperty(S, cast<CXXRecordDecl>(CurContext), Loc, D,
3496                                  BitWidth, InitStyle, AS, *MSPropertyAttr);
3497        if (!Member)
3498          return nullptr;
3499        isInstField = false;
3500      } else {
3501        Member = HandleField(S, cast<CXXRecordDecl>(CurContext), Loc, D,
3502                                  BitWidth, InitStyle, AS);
3503        if (!Member)
3504          return nullptr;
3505      }
3506  
3507      CheckShadowInheritedFields(Loc, Name, cast<CXXRecordDecl>(CurContext));
3508    } else {
3509      Member = HandleDeclarator(S, D, TemplateParameterLists);
3510      if (!Member)
3511        return nullptr;
3512  
3513      // Non-instance-fields can't have a bitfield.
3514      if (BitWidth) {
3515        if (Member->isInvalidDecl()) {
3516          // don't emit another diagnostic.
3517        } else if (isa<VarDecl>(Member) || isa<VarTemplateDecl>(Member)) {
3518          // C++ 9.6p3: A bit-field shall not be a static member.
3519          // "static member 'A' cannot be a bit-field"
3520          Diag(Loc, diag::err_static_not_bitfield)
3521            << Name << BitWidth->getSourceRange();
3522        } else if (isa<TypedefDecl>(Member)) {
3523          // "typedef member 'x' cannot be a bit-field"
3524          Diag(Loc, diag::err_typedef_not_bitfield)
3525            << Name << BitWidth->getSourceRange();
3526        } else {
3527          // A function typedef ("typedef int f(); f a;").
3528          // C++ 9.6p3: A bit-field shall have integral or enumeration type.
3529          Diag(Loc, diag::err_not_integral_type_bitfield)
3530            << Name << cast<ValueDecl>(Member)->getType()
3531            << BitWidth->getSourceRange();
3532        }
3533  
3534        BitWidth = nullptr;
3535        Member->setInvalidDecl();
3536      }
3537  
3538      NamedDecl *NonTemplateMember = Member;
3539      if (FunctionTemplateDecl *FunTmpl = dyn_cast<FunctionTemplateDecl>(Member))
3540        NonTemplateMember = FunTmpl->getTemplatedDecl();
3541      else if (VarTemplateDecl *VarTmpl = dyn_cast<VarTemplateDecl>(Member))
3542        NonTemplateMember = VarTmpl->getTemplatedDecl();
3543  
3544      Member->setAccess(AS);
3545  
3546      // If we have declared a member function template or static data member
3547      // template, set the access of the templated declaration as well.
3548      if (NonTemplateMember != Member)
3549        NonTemplateMember->setAccess(AS);
3550  
3551      // C++ [temp.deduct.guide]p3:
3552      //   A deduction guide [...] for a member class template [shall be
3553      //   declared] with the same access [as the template].
3554      if (auto *DG = dyn_cast<CXXDeductionGuideDecl>(NonTemplateMember)) {
3555        auto *TD = DG->getDeducedTemplate();
3556        // Access specifiers are only meaningful if both the template and the
3557        // deduction guide are from the same scope.
3558        if (AS != TD->getAccess() &&
3559            TD->getDeclContext()->getRedeclContext()->Equals(
3560                DG->getDeclContext()->getRedeclContext())) {
3561          Diag(DG->getBeginLoc(), diag::err_deduction_guide_wrong_access);
3562          Diag(TD->getBeginLoc(), diag::note_deduction_guide_template_access)
3563              << TD->getAccess();
3564          const AccessSpecDecl *LastAccessSpec = nullptr;
3565          for (const auto *D : cast<CXXRecordDecl>(CurContext)->decls()) {
3566            if (const auto *AccessSpec = dyn_cast<AccessSpecDecl>(D))
3567              LastAccessSpec = AccessSpec;
3568          }
3569          assert(LastAccessSpec && "differing access with no access specifier");
3570          Diag(LastAccessSpec->getBeginLoc(), diag::note_deduction_guide_access)
3571              << AS;
3572        }
3573      }
3574    }
3575  
3576    if (VS.isOverrideSpecified())
3577      Member->addAttr(OverrideAttr::Create(Context, VS.getOverrideLoc()));
3578    if (VS.isFinalSpecified())
3579      Member->addAttr(FinalAttr::Create(Context, VS.getFinalLoc(),
3580                                        VS.isFinalSpelledSealed()
3581                                            ? FinalAttr::Keyword_sealed
3582                                            : FinalAttr::Keyword_final));
3583  
3584    if (VS.getLastLocation().isValid()) {
3585      // Update the end location of a method that has a virt-specifiers.
3586      if (CXXMethodDecl *MD = dyn_cast_or_null<CXXMethodDecl>(Member))
3587        MD->setRangeEnd(VS.getLastLocation());
3588    }
3589  
3590    CheckOverrideControl(Member);
3591  
3592    assert((Name || isInstField) && "No identifier for non-field ?");
3593  
3594    if (isInstField) {
3595      FieldDecl *FD = cast<FieldDecl>(Member);
3596      FieldCollector->Add(FD);
3597  
3598      if (!Diags.isIgnored(diag::warn_unused_private_field, FD->getLocation())) {
3599        // Remember all explicit private FieldDecls that have a name, no side
3600        // effects and are not part of a dependent type declaration.
3601  
3602        auto DeclHasUnusedAttr = [](const QualType &T) {
3603          if (const TagDecl *TD = T->getAsTagDecl())
3604            return TD->hasAttr<UnusedAttr>();
3605          if (const TypedefType *TDT = T->getAs<TypedefType>())
3606            return TDT->getDecl()->hasAttr<UnusedAttr>();
3607          return false;
3608        };
3609  
3610        if (!FD->isImplicit() && FD->getDeclName() &&
3611            FD->getAccess() == AS_private &&
3612            !FD->hasAttr<UnusedAttr>() &&
3613            !FD->getParent()->isDependentContext() &&
3614            !DeclHasUnusedAttr(FD->getType()) &&
3615            !InitializationHasSideEffects(*FD))
3616          UnusedPrivateFields.insert(FD);
3617      }
3618    }
3619  
3620    return Member;
3621  }
3622  
3623  namespace {
3624    class UninitializedFieldVisitor
3625        : public EvaluatedExprVisitor<UninitializedFieldVisitor> {
3626      Sema &S;
3627      // List of Decls to generate a warning on.  Also remove Decls that become
3628      // initialized.
3629      llvm::SmallPtrSetImpl<ValueDecl*> &Decls;
3630      // List of base classes of the record.  Classes are removed after their
3631      // initializers.
3632      llvm::SmallPtrSetImpl<QualType> &BaseClasses;
3633      // Vector of decls to be removed from the Decl set prior to visiting the
3634      // nodes.  These Decls may have been initialized in the prior initializer.
3635      llvm::SmallVector<ValueDecl*, 4> DeclsToRemove;
3636      // If non-null, add a note to the warning pointing back to the constructor.
3637      const CXXConstructorDecl *Constructor;
3638      // Variables to hold state when processing an initializer list.  When
3639      // InitList is true, special case initialization of FieldDecls matching
3640      // InitListFieldDecl.
3641      bool InitList;
3642      FieldDecl *InitListFieldDecl;
3643      llvm::SmallVector<unsigned, 4> InitFieldIndex;
3644  
3645    public:
3646      typedef EvaluatedExprVisitor<UninitializedFieldVisitor> Inherited;
3647      UninitializedFieldVisitor(Sema &S,
3648                                llvm::SmallPtrSetImpl<ValueDecl*> &Decls,
3649                                llvm::SmallPtrSetImpl<QualType> &BaseClasses)
3650        : Inherited(S.Context), S(S), Decls(Decls), BaseClasses(BaseClasses),
3651          Constructor(nullptr), InitList(false), InitListFieldDecl(nullptr) {}
3652  
3653      // Returns true if the use of ME is not an uninitialized use.
3654      bool IsInitListMemberExprInitialized(MemberExpr *ME,
3655                                           bool CheckReferenceOnly) {
3656        llvm::SmallVector<FieldDecl*, 4> Fields;
3657        bool ReferenceField = false;
3658        while (ME) {
3659          FieldDecl *FD = dyn_cast<FieldDecl>(ME->getMemberDecl());
3660          if (!FD)
3661            return false;
3662          Fields.push_back(FD);
3663          if (FD->getType()->isReferenceType())
3664            ReferenceField = true;
3665          ME = dyn_cast<MemberExpr>(ME->getBase()->IgnoreParenImpCasts());
3666        }
3667  
3668        // Binding a reference to an uninitialized field is not an
3669        // uninitialized use.
3670        if (CheckReferenceOnly && !ReferenceField)
3671          return true;
3672  
3673        llvm::SmallVector<unsigned, 4> UsedFieldIndex;
3674        // Discard the first field since it is the field decl that is being
3675        // initialized.
3676        for (const FieldDecl *FD : llvm::drop_begin(llvm::reverse(Fields)))
3677          UsedFieldIndex.push_back(FD->getFieldIndex());
3678  
3679        for (auto UsedIter = UsedFieldIndex.begin(),
3680                  UsedEnd = UsedFieldIndex.end(),
3681                  OrigIter = InitFieldIndex.begin(),
3682                  OrigEnd = InitFieldIndex.end();
3683             UsedIter != UsedEnd && OrigIter != OrigEnd; ++UsedIter, ++OrigIter) {
3684          if (*UsedIter < *OrigIter)
3685            return true;
3686          if (*UsedIter > *OrigIter)
3687            break;
3688        }
3689  
3690        return false;
3691      }
3692  
3693      void HandleMemberExpr(MemberExpr *ME, bool CheckReferenceOnly,
3694                            bool AddressOf) {
3695        if (isa<EnumConstantDecl>(ME->getMemberDecl()))
3696          return;
3697  
3698        // FieldME is the inner-most MemberExpr that is not an anonymous struct
3699        // or union.
3700        MemberExpr *FieldME = ME;
3701  
3702        bool AllPODFields = FieldME->getType().isPODType(S.Context);
3703  
3704        Expr *Base = ME;
3705        while (MemberExpr *SubME =
3706                   dyn_cast<MemberExpr>(Base->IgnoreParenImpCasts())) {
3707  
3708          if (isa<VarDecl>(SubME->getMemberDecl()))
3709            return;
3710  
3711          if (FieldDecl *FD = dyn_cast<FieldDecl>(SubME->getMemberDecl()))
3712            if (!FD->isAnonymousStructOrUnion())
3713              FieldME = SubME;
3714  
3715          if (!FieldME->getType().isPODType(S.Context))
3716            AllPODFields = false;
3717  
3718          Base = SubME->getBase();
3719        }
3720  
3721        if (!isa<CXXThisExpr>(Base->IgnoreParenImpCasts())) {
3722          Visit(Base);
3723          return;
3724        }
3725  
3726        if (AddressOf && AllPODFields)
3727          return;
3728  
3729        ValueDecl* FoundVD = FieldME->getMemberDecl();
3730  
3731        if (ImplicitCastExpr *BaseCast = dyn_cast<ImplicitCastExpr>(Base)) {
3732          while (isa<ImplicitCastExpr>(BaseCast->getSubExpr())) {
3733            BaseCast = cast<ImplicitCastExpr>(BaseCast->getSubExpr());
3734          }
3735  
3736          if (BaseCast->getCastKind() == CK_UncheckedDerivedToBase) {
3737            QualType T = BaseCast->getType();
3738            if (T->isPointerType() &&
3739                BaseClasses.count(T->getPointeeType())) {
3740              S.Diag(FieldME->getExprLoc(), diag::warn_base_class_is_uninit)
3741                  << T->getPointeeType() << FoundVD;
3742            }
3743          }
3744        }
3745  
3746        if (!Decls.count(FoundVD))
3747          return;
3748  
3749        const bool IsReference = FoundVD->getType()->isReferenceType();
3750  
3751        if (InitList && !AddressOf && FoundVD == InitListFieldDecl) {
3752          // Special checking for initializer lists.
3753          if (IsInitListMemberExprInitialized(ME, CheckReferenceOnly)) {
3754            return;
3755          }
3756        } else {
3757          // Prevent double warnings on use of unbounded references.
3758          if (CheckReferenceOnly && !IsReference)
3759            return;
3760        }
3761  
3762        unsigned diag = IsReference
3763            ? diag::warn_reference_field_is_uninit
3764            : diag::warn_field_is_uninit;
3765        S.Diag(FieldME->getExprLoc(), diag) << FoundVD;
3766        if (Constructor)
3767          S.Diag(Constructor->getLocation(),
3768                 diag::note_uninit_in_this_constructor)
3769            << (Constructor->isDefaultConstructor() && Constructor->isImplicit());
3770  
3771      }
3772  
3773      void HandleValue(Expr *E, bool AddressOf) {
3774        E = E->IgnoreParens();
3775  
3776        if (MemberExpr *ME = dyn_cast<MemberExpr>(E)) {
3777          HandleMemberExpr(ME, false /*CheckReferenceOnly*/,
3778                           AddressOf /*AddressOf*/);
3779          return;
3780        }
3781  
3782        if (ConditionalOperator *CO = dyn_cast<ConditionalOperator>(E)) {
3783          Visit(CO->getCond());
3784          HandleValue(CO->getTrueExpr(), AddressOf);
3785          HandleValue(CO->getFalseExpr(), AddressOf);
3786          return;
3787        }
3788  
3789        if (BinaryConditionalOperator *BCO =
3790                dyn_cast<BinaryConditionalOperator>(E)) {
3791          Visit(BCO->getCond());
3792          HandleValue(BCO->getFalseExpr(), AddressOf);
3793          return;
3794        }
3795  
3796        if (OpaqueValueExpr *OVE = dyn_cast<OpaqueValueExpr>(E)) {
3797          HandleValue(OVE->getSourceExpr(), AddressOf);
3798          return;
3799        }
3800  
3801        if (BinaryOperator *BO = dyn_cast<BinaryOperator>(E)) {
3802          switch (BO->getOpcode()) {
3803          default:
3804            break;
3805          case(BO_PtrMemD):
3806          case(BO_PtrMemI):
3807            HandleValue(BO->getLHS(), AddressOf);
3808            Visit(BO->getRHS());
3809            return;
3810          case(BO_Comma):
3811            Visit(BO->getLHS());
3812            HandleValue(BO->getRHS(), AddressOf);
3813            return;
3814          }
3815        }
3816  
3817        Visit(E);
3818      }
3819  
3820      void CheckInitListExpr(InitListExpr *ILE) {
3821        InitFieldIndex.push_back(0);
3822        for (auto *Child : ILE->children()) {
3823          if (InitListExpr *SubList = dyn_cast<InitListExpr>(Child)) {
3824            CheckInitListExpr(SubList);
3825          } else {
3826            Visit(Child);
3827          }
3828          ++InitFieldIndex.back();
3829        }
3830        InitFieldIndex.pop_back();
3831      }
3832  
3833      void CheckInitializer(Expr *E, const CXXConstructorDecl *FieldConstructor,
3834                            FieldDecl *Field, const Type *BaseClass) {
3835        // Remove Decls that may have been initialized in the previous
3836        // initializer.
3837        for (ValueDecl* VD : DeclsToRemove)
3838          Decls.erase(VD);
3839        DeclsToRemove.clear();
3840  
3841        Constructor = FieldConstructor;
3842        InitListExpr *ILE = dyn_cast<InitListExpr>(E);
3843  
3844        if (ILE && Field) {
3845          InitList = true;
3846          InitListFieldDecl = Field;
3847          InitFieldIndex.clear();
3848          CheckInitListExpr(ILE);
3849        } else {
3850          InitList = false;
3851          Visit(E);
3852        }
3853  
3854        if (Field)
3855          Decls.erase(Field);
3856        if (BaseClass)
3857          BaseClasses.erase(BaseClass->getCanonicalTypeInternal());
3858      }
3859  
3860      void VisitMemberExpr(MemberExpr *ME) {
3861        // All uses of unbounded reference fields will warn.
3862        HandleMemberExpr(ME, true /*CheckReferenceOnly*/, false /*AddressOf*/);
3863      }
3864  
3865      void VisitImplicitCastExpr(ImplicitCastExpr *E) {
3866        if (E->getCastKind() == CK_LValueToRValue) {
3867          HandleValue(E->getSubExpr(), false /*AddressOf*/);
3868          return;
3869        }
3870  
3871        Inherited::VisitImplicitCastExpr(E);
3872      }
3873  
3874      void VisitCXXConstructExpr(CXXConstructExpr *E) {
3875        if (E->getConstructor()->isCopyConstructor()) {
3876          Expr *ArgExpr = E->getArg(0);
3877          if (InitListExpr *ILE = dyn_cast<InitListExpr>(ArgExpr))
3878            if (ILE->getNumInits() == 1)
3879              ArgExpr = ILE->getInit(0);
3880          if (ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(ArgExpr))
3881            if (ICE->getCastKind() == CK_NoOp)
3882              ArgExpr = ICE->getSubExpr();
3883          HandleValue(ArgExpr, false /*AddressOf*/);
3884          return;
3885        }
3886        Inherited::VisitCXXConstructExpr(E);
3887      }
3888  
3889      void VisitCXXMemberCallExpr(CXXMemberCallExpr *E) {
3890        Expr *Callee = E->getCallee();
3891        if (isa<MemberExpr>(Callee)) {
3892          HandleValue(Callee, false /*AddressOf*/);
3893          for (auto *Arg : E->arguments())
3894            Visit(Arg);
3895          return;
3896        }
3897  
3898        Inherited::VisitCXXMemberCallExpr(E);
3899      }
3900  
3901      void VisitCallExpr(CallExpr *E) {
3902        // Treat std::move as a use.
3903        if (E->isCallToStdMove()) {
3904          HandleValue(E->getArg(0), /*AddressOf=*/false);
3905          return;
3906        }
3907  
3908        Inherited::VisitCallExpr(E);
3909      }
3910  
3911      void VisitCXXOperatorCallExpr(CXXOperatorCallExpr *E) {
3912        Expr *Callee = E->getCallee();
3913  
3914        if (isa<UnresolvedLookupExpr>(Callee))
3915          return Inherited::VisitCXXOperatorCallExpr(E);
3916  
3917        Visit(Callee);
3918        for (auto *Arg : E->arguments())
3919          HandleValue(Arg->IgnoreParenImpCasts(), false /*AddressOf*/);
3920      }
3921  
3922      void VisitBinaryOperator(BinaryOperator *E) {
3923        // If a field assignment is detected, remove the field from the
3924        // uninitiailized field set.
3925        if (E->getOpcode() == BO_Assign)
3926          if (MemberExpr *ME = dyn_cast<MemberExpr>(E->getLHS()))
3927            if (FieldDecl *FD = dyn_cast<FieldDecl>(ME->getMemberDecl()))
3928              if (!FD->getType()->isReferenceType())
3929                DeclsToRemove.push_back(FD);
3930  
3931        if (E->isCompoundAssignmentOp()) {
3932          HandleValue(E->getLHS(), false /*AddressOf*/);
3933          Visit(E->getRHS());
3934          return;
3935        }
3936  
3937        Inherited::VisitBinaryOperator(E);
3938      }
3939  
3940      void VisitUnaryOperator(UnaryOperator *E) {
3941        if (E->isIncrementDecrementOp()) {
3942          HandleValue(E->getSubExpr(), false /*AddressOf*/);
3943          return;
3944        }
3945        if (E->getOpcode() == UO_AddrOf) {
3946          if (MemberExpr *ME = dyn_cast<MemberExpr>(E->getSubExpr())) {
3947            HandleValue(ME->getBase(), true /*AddressOf*/);
3948            return;
3949          }
3950        }
3951  
3952        Inherited::VisitUnaryOperator(E);
3953      }
3954    };
3955  
3956    // Diagnose value-uses of fields to initialize themselves, e.g.
3957    //   foo(foo)
3958    // where foo is not also a parameter to the constructor.
3959    // Also diagnose across field uninitialized use such as
3960    //   x(y), y(x)
3961    // TODO: implement -Wuninitialized and fold this into that framework.
3962    static void DiagnoseUninitializedFields(
3963        Sema &SemaRef, const CXXConstructorDecl *Constructor) {
3964  
3965      if (SemaRef.getDiagnostics().isIgnored(diag::warn_field_is_uninit,
3966                                             Constructor->getLocation())) {
3967        return;
3968      }
3969  
3970      if (Constructor->isInvalidDecl())
3971        return;
3972  
3973      const CXXRecordDecl *RD = Constructor->getParent();
3974  
3975      if (RD->isDependentContext())
3976        return;
3977  
3978      // Holds fields that are uninitialized.
3979      llvm::SmallPtrSet<ValueDecl*, 4> UninitializedFields;
3980  
3981      // At the beginning, all fields are uninitialized.
3982      for (auto *I : RD->decls()) {
3983        if (auto *FD = dyn_cast<FieldDecl>(I)) {
3984          UninitializedFields.insert(FD);
3985        } else if (auto *IFD = dyn_cast<IndirectFieldDecl>(I)) {
3986          UninitializedFields.insert(IFD->getAnonField());
3987        }
3988      }
3989  
3990      llvm::SmallPtrSet<QualType, 4> UninitializedBaseClasses;
3991      for (const auto &I : RD->bases())
3992        UninitializedBaseClasses.insert(I.getType().getCanonicalType());
3993  
3994      if (UninitializedFields.empty() && UninitializedBaseClasses.empty())
3995        return;
3996  
3997      UninitializedFieldVisitor UninitializedChecker(SemaRef,
3998                                                     UninitializedFields,
3999                                                     UninitializedBaseClasses);
4000  
4001      for (const auto *FieldInit : Constructor->inits()) {
4002        if (UninitializedFields.empty() && UninitializedBaseClasses.empty())
4003          break;
4004  
4005        Expr *InitExpr = FieldInit->getInit();
4006        if (!InitExpr)
4007          continue;
4008  
4009        if (CXXDefaultInitExpr *Default =
4010                dyn_cast<CXXDefaultInitExpr>(InitExpr)) {
4011          InitExpr = Default->getExpr();
4012          if (!InitExpr)
4013            continue;
4014          // In class initializers will point to the constructor.
4015          UninitializedChecker.CheckInitializer(InitExpr, Constructor,
4016                                                FieldInit->getAnyMember(),
4017                                                FieldInit->getBaseClass());
4018        } else {
4019          UninitializedChecker.CheckInitializer(InitExpr, nullptr,
4020                                                FieldInit->getAnyMember(),
4021                                                FieldInit->getBaseClass());
4022        }
4023      }
4024    }
4025  } // namespace
4026  
4027  void Sema::ActOnStartCXXInClassMemberInitializer() {
4028    // Create a synthetic function scope to represent the call to the constructor
4029    // that notionally surrounds a use of this initializer.
4030    PushFunctionScope();
4031  }
4032  
4033  void Sema::ActOnStartTrailingRequiresClause(Scope *S, Declarator &D) {
4034    if (!D.isFunctionDeclarator())
4035      return;
4036    auto &FTI = D.getFunctionTypeInfo();
4037    if (!FTI.Params)
4038      return;
4039    for (auto &Param : ArrayRef<DeclaratorChunk::ParamInfo>(FTI.Params,
4040                                                            FTI.NumParams)) {
4041      auto *ParamDecl = cast<NamedDecl>(Param.Param);
4042      if (ParamDecl->getDeclName())
4043        PushOnScopeChains(ParamDecl, S, /*AddToContext=*/false);
4044    }
4045  }
4046  
4047  ExprResult Sema::ActOnFinishTrailingRequiresClause(ExprResult ConstraintExpr) {
4048    return ActOnRequiresClause(ConstraintExpr);
4049  }
4050  
4051  ExprResult Sema::ActOnRequiresClause(ExprResult ConstraintExpr) {
4052    if (ConstraintExpr.isInvalid())
4053      return ExprError();
4054  
4055    ConstraintExpr = CorrectDelayedTyposInExpr(ConstraintExpr);
4056    if (ConstraintExpr.isInvalid())
4057      return ExprError();
4058  
4059    if (DiagnoseUnexpandedParameterPack(ConstraintExpr.get(),
4060                                        UPPC_RequiresClause))
4061      return ExprError();
4062  
4063    return ConstraintExpr;
4064  }
4065  
4066  ExprResult Sema::ConvertMemberDefaultInitExpression(FieldDecl *FD,
4067                                                      Expr *InitExpr,
4068                                                      SourceLocation InitLoc) {
4069    InitializedEntity Entity =
4070        InitializedEntity::InitializeMemberFromDefaultMemberInitializer(FD);
4071    InitializationKind Kind =
4072        FD->getInClassInitStyle() == ICIS_ListInit
4073            ? InitializationKind::CreateDirectList(InitExpr->getBeginLoc(),
4074                                                   InitExpr->getBeginLoc(),
4075                                                   InitExpr->getEndLoc())
4076            : InitializationKind::CreateCopy(InitExpr->getBeginLoc(), InitLoc);
4077    InitializationSequence Seq(*this, Entity, Kind, InitExpr);
4078    return Seq.Perform(*this, Entity, Kind, InitExpr);
4079  }
4080  
4081  void Sema::ActOnFinishCXXInClassMemberInitializer(Decl *D,
4082                                                    SourceLocation InitLoc,
4083                                                    Expr *InitExpr) {
4084    // Pop the notional constructor scope we created earlier.
4085    PopFunctionScopeInfo(nullptr, D);
4086  
4087    FieldDecl *FD = dyn_cast<FieldDecl>(D);
4088    assert((isa<MSPropertyDecl>(D) || FD->getInClassInitStyle() != ICIS_NoInit) &&
4089           "must set init style when field is created");
4090  
4091    if (!InitExpr) {
4092      D->setInvalidDecl();
4093      if (FD)
4094        FD->removeInClassInitializer();
4095      return;
4096    }
4097  
4098    if (DiagnoseUnexpandedParameterPack(InitExpr, UPPC_Initializer)) {
4099      FD->setInvalidDecl();
4100      FD->removeInClassInitializer();
4101      return;
4102    }
4103  
4104    ExprResult Init = CorrectDelayedTyposInExpr(InitExpr, /*InitDecl=*/nullptr,
4105                                                /*RecoverUncorrectedTypos=*/true);
4106    assert(Init.isUsable() && "Init should at least have a RecoveryExpr");
4107    if (!FD->getType()->isDependentType() && !Init.get()->isTypeDependent()) {
4108      Init = ConvertMemberDefaultInitExpression(FD, Init.get(), InitLoc);
4109      // C++11 [class.base.init]p7:
4110      //   The initialization of each base and member constitutes a
4111      //   full-expression.
4112      if (!Init.isInvalid())
4113        Init = ActOnFinishFullExpr(Init.get(), /*DiscarededValue=*/false);
4114      if (Init.isInvalid()) {
4115        FD->setInvalidDecl();
4116        return;
4117      }
4118    }
4119  
4120    FD->setInClassInitializer(Init.get());
4121  }
4122  
4123  /// Find the direct and/or virtual base specifiers that
4124  /// correspond to the given base type, for use in base initialization
4125  /// within a constructor.
4126  static bool FindBaseInitializer(Sema &SemaRef,
4127                                  CXXRecordDecl *ClassDecl,
4128                                  QualType BaseType,
4129                                  const CXXBaseSpecifier *&DirectBaseSpec,
4130                                  const CXXBaseSpecifier *&VirtualBaseSpec) {
4131    // First, check for a direct base class.
4132    DirectBaseSpec = nullptr;
4133    for (const auto &Base : ClassDecl->bases()) {
4134      if (SemaRef.Context.hasSameUnqualifiedType(BaseType, Base.getType())) {
4135        // We found a direct base of this type. That's what we're
4136        // initializing.
4137        DirectBaseSpec = &Base;
4138        break;
4139      }
4140    }
4141  
4142    // Check for a virtual base class.
4143    // FIXME: We might be able to short-circuit this if we know in advance that
4144    // there are no virtual bases.
4145    VirtualBaseSpec = nullptr;
4146    if (!DirectBaseSpec || !DirectBaseSpec->isVirtual()) {
4147      // We haven't found a base yet; search the class hierarchy for a
4148      // virtual base class.
4149      CXXBasePaths Paths(/*FindAmbiguities=*/true, /*RecordPaths=*/true,
4150                         /*DetectVirtual=*/false);
4151      if (SemaRef.IsDerivedFrom(ClassDecl->getLocation(),
4152                                SemaRef.Context.getTypeDeclType(ClassDecl),
4153                                BaseType, Paths)) {
4154        for (CXXBasePaths::paths_iterator Path = Paths.begin();
4155             Path != Paths.end(); ++Path) {
4156          if (Path->back().Base->isVirtual()) {
4157            VirtualBaseSpec = Path->back().Base;
4158            break;
4159          }
4160        }
4161      }
4162    }
4163  
4164    return DirectBaseSpec || VirtualBaseSpec;
4165  }
4166  
4167  MemInitResult
4168  Sema::ActOnMemInitializer(Decl *ConstructorD,
4169                            Scope *S,
4170                            CXXScopeSpec &SS,
4171                            IdentifierInfo *MemberOrBase,
4172                            ParsedType TemplateTypeTy,
4173                            const DeclSpec &DS,
4174                            SourceLocation IdLoc,
4175                            Expr *InitList,
4176                            SourceLocation EllipsisLoc) {
4177    return BuildMemInitializer(ConstructorD, S, SS, MemberOrBase, TemplateTypeTy,
4178                               DS, IdLoc, InitList,
4179                               EllipsisLoc);
4180  }
4181  
4182  MemInitResult
4183  Sema::ActOnMemInitializer(Decl *ConstructorD,
4184                            Scope *S,
4185                            CXXScopeSpec &SS,
4186                            IdentifierInfo *MemberOrBase,
4187                            ParsedType TemplateTypeTy,
4188                            const DeclSpec &DS,
4189                            SourceLocation IdLoc,
4190                            SourceLocation LParenLoc,
4191                            ArrayRef<Expr *> Args,
4192                            SourceLocation RParenLoc,
4193                            SourceLocation EllipsisLoc) {
4194    Expr *List = ParenListExpr::Create(Context, LParenLoc, Args, RParenLoc);
4195    return BuildMemInitializer(ConstructorD, S, SS, MemberOrBase, TemplateTypeTy,
4196                               DS, IdLoc, List, EllipsisLoc);
4197  }
4198  
4199  namespace {
4200  
4201  // Callback to only accept typo corrections that can be a valid C++ member
4202  // initializer: either a non-static field member or a base class.
4203  class MemInitializerValidatorCCC final : public CorrectionCandidateCallback {
4204  public:
4205    explicit MemInitializerValidatorCCC(CXXRecordDecl *ClassDecl)
4206        : ClassDecl(ClassDecl) {}
4207  
4208    bool ValidateCandidate(const TypoCorrection &candidate) override {
4209      if (NamedDecl *ND = candidate.getCorrectionDecl()) {
4210        if (FieldDecl *Member = dyn_cast<FieldDecl>(ND))
4211          return Member->getDeclContext()->getRedeclContext()->Equals(ClassDecl);
4212        return isa<TypeDecl>(ND);
4213      }
4214      return false;
4215    }
4216  
4217    std::unique_ptr<CorrectionCandidateCallback> clone() override {
4218      return std::make_unique<MemInitializerValidatorCCC>(*this);
4219    }
4220  
4221  private:
4222    CXXRecordDecl *ClassDecl;
4223  };
4224  
4225  }
4226  
4227  bool Sema::DiagRedefinedPlaceholderFieldDecl(SourceLocation Loc,
4228                                               RecordDecl *ClassDecl,
4229                                               const IdentifierInfo *Name) {
4230    DeclContextLookupResult Result = ClassDecl->lookup(Name);
4231    DeclContextLookupResult::iterator Found =
4232        llvm::find_if(Result, [this](const NamedDecl *Elem) {
4233          return isa<FieldDecl, IndirectFieldDecl>(Elem) &&
4234                 Elem->isPlaceholderVar(getLangOpts());
4235        });
4236    // We did not find a placeholder variable
4237    if (Found == Result.end())
4238      return false;
4239    Diag(Loc, diag::err_using_placeholder_variable) << Name;
4240    for (DeclContextLookupResult::iterator It = Found; It != Result.end(); It++) {
4241      const NamedDecl *ND = *It;
4242      if (ND->getDeclContext() != ND->getDeclContext())
4243        break;
4244      if (isa<FieldDecl, IndirectFieldDecl>(ND) &&
4245          ND->isPlaceholderVar(getLangOpts()))
4246        Diag(ND->getLocation(), diag::note_reference_placeholder) << ND;
4247    }
4248    return true;
4249  }
4250  
4251  ValueDecl *
4252  Sema::tryLookupUnambiguousFieldDecl(RecordDecl *ClassDecl,
4253                                      const IdentifierInfo *MemberOrBase) {
4254    ValueDecl *ND = nullptr;
4255    for (auto *D : ClassDecl->lookup(MemberOrBase)) {
4256      if (isa<FieldDecl, IndirectFieldDecl>(D)) {
4257        bool IsPlaceholder = D->isPlaceholderVar(getLangOpts());
4258        if (ND) {
4259          if (IsPlaceholder && D->getDeclContext() == ND->getDeclContext())
4260            return nullptr;
4261          break;
4262        }
4263        if (!IsPlaceholder)
4264          return cast<ValueDecl>(D);
4265        ND = cast<ValueDecl>(D);
4266      }
4267    }
4268    return ND;
4269  }
4270  
4271  ValueDecl *Sema::tryLookupCtorInitMemberDecl(CXXRecordDecl *ClassDecl,
4272                                               CXXScopeSpec &SS,
4273                                               ParsedType TemplateTypeTy,
4274                                               IdentifierInfo *MemberOrBase) {
4275    if (SS.getScopeRep() || TemplateTypeTy)
4276      return nullptr;
4277    return tryLookupUnambiguousFieldDecl(ClassDecl, MemberOrBase);
4278  }
4279  
4280  MemInitResult
4281  Sema::BuildMemInitializer(Decl *ConstructorD,
4282                            Scope *S,
4283                            CXXScopeSpec &SS,
4284                            IdentifierInfo *MemberOrBase,
4285                            ParsedType TemplateTypeTy,
4286                            const DeclSpec &DS,
4287                            SourceLocation IdLoc,
4288                            Expr *Init,
4289                            SourceLocation EllipsisLoc) {
4290    ExprResult Res = CorrectDelayedTyposInExpr(Init, /*InitDecl=*/nullptr,
4291                                               /*RecoverUncorrectedTypos=*/true);
4292    if (!Res.isUsable())
4293      return true;
4294    Init = Res.get();
4295  
4296    if (!ConstructorD)
4297      return true;
4298  
4299    AdjustDeclIfTemplate(ConstructorD);
4300  
4301    CXXConstructorDecl *Constructor
4302      = dyn_cast<CXXConstructorDecl>(ConstructorD);
4303    if (!Constructor) {
4304      // The user wrote a constructor initializer on a function that is
4305      // not a C++ constructor. Ignore the error for now, because we may
4306      // have more member initializers coming; we'll diagnose it just
4307      // once in ActOnMemInitializers.
4308      return true;
4309    }
4310  
4311    CXXRecordDecl *ClassDecl = Constructor->getParent();
4312  
4313    // C++ [class.base.init]p2:
4314    //   Names in a mem-initializer-id are looked up in the scope of the
4315    //   constructor's class and, if not found in that scope, are looked
4316    //   up in the scope containing the constructor's definition.
4317    //   [Note: if the constructor's class contains a member with the
4318    //   same name as a direct or virtual base class of the class, a
4319    //   mem-initializer-id naming the member or base class and composed
4320    //   of a single identifier refers to the class member. A
4321    //   mem-initializer-id for the hidden base class may be specified
4322    //   using a qualified name. ]
4323  
4324    // Look for a member, first.
4325    if (ValueDecl *Member = tryLookupCtorInitMemberDecl(
4326            ClassDecl, SS, TemplateTypeTy, MemberOrBase)) {
4327      if (EllipsisLoc.isValid())
4328        Diag(EllipsisLoc, diag::err_pack_expansion_member_init)
4329            << MemberOrBase
4330            << SourceRange(IdLoc, Init->getSourceRange().getEnd());
4331  
4332      return BuildMemberInitializer(Member, Init, IdLoc);
4333    }
4334    // It didn't name a member, so see if it names a class.
4335    QualType BaseType;
4336    TypeSourceInfo *TInfo = nullptr;
4337  
4338    if (TemplateTypeTy) {
4339      BaseType = GetTypeFromParser(TemplateTypeTy, &TInfo);
4340      if (BaseType.isNull())
4341        return true;
4342    } else if (DS.getTypeSpecType() == TST_decltype) {
4343      BaseType = BuildDecltypeType(DS.getRepAsExpr());
4344    } else if (DS.getTypeSpecType() == TST_decltype_auto) {
4345      Diag(DS.getTypeSpecTypeLoc(), diag::err_decltype_auto_invalid);
4346      return true;
4347    } else if (DS.getTypeSpecType() == TST_typename_pack_indexing) {
4348      BaseType =
4349          BuildPackIndexingType(DS.getRepAsType().get(), DS.getPackIndexingExpr(),
4350                                DS.getBeginLoc(), DS.getEllipsisLoc());
4351    } else {
4352      LookupResult R(*this, MemberOrBase, IdLoc, LookupOrdinaryName);
4353      LookupParsedName(R, S, &SS, /*ObjectType=*/QualType());
4354  
4355      TypeDecl *TyD = R.getAsSingle<TypeDecl>();
4356      if (!TyD) {
4357        if (R.isAmbiguous()) return true;
4358  
4359        // We don't want access-control diagnostics here.
4360        R.suppressDiagnostics();
4361  
4362        if (SS.isSet() && isDependentScopeSpecifier(SS)) {
4363          bool NotUnknownSpecialization = false;
4364          DeclContext *DC = computeDeclContext(SS, false);
4365          if (CXXRecordDecl *Record = dyn_cast_or_null<CXXRecordDecl>(DC))
4366            NotUnknownSpecialization = !Record->hasAnyDependentBases();
4367  
4368          if (!NotUnknownSpecialization) {
4369            // When the scope specifier can refer to a member of an unknown
4370            // specialization, we take it as a type name.
4371            BaseType = CheckTypenameType(
4372                ElaboratedTypeKeyword::None, SourceLocation(),
4373                SS.getWithLocInContext(Context), *MemberOrBase, IdLoc);
4374            if (BaseType.isNull())
4375              return true;
4376  
4377            TInfo = Context.CreateTypeSourceInfo(BaseType);
4378            DependentNameTypeLoc TL =
4379                TInfo->getTypeLoc().castAs<DependentNameTypeLoc>();
4380            if (!TL.isNull()) {
4381              TL.setNameLoc(IdLoc);
4382              TL.setElaboratedKeywordLoc(SourceLocation());
4383              TL.setQualifierLoc(SS.getWithLocInContext(Context));
4384            }
4385  
4386            R.clear();
4387            R.setLookupName(MemberOrBase);
4388          }
4389        }
4390  
4391        if (getLangOpts().MSVCCompat && !getLangOpts().CPlusPlus20) {
4392          if (auto UnqualifiedBase = R.getAsSingle<ClassTemplateDecl>()) {
4393            auto *TempSpec = cast<TemplateSpecializationType>(
4394                UnqualifiedBase->getInjectedClassNameSpecialization());
4395            TemplateName TN = TempSpec->getTemplateName();
4396            for (auto const &Base : ClassDecl->bases()) {
4397              auto BaseTemplate =
4398                  Base.getType()->getAs<TemplateSpecializationType>();
4399              if (BaseTemplate && Context.hasSameTemplateName(
4400                                      BaseTemplate->getTemplateName(), TN)) {
4401                Diag(IdLoc, diag::ext_unqualified_base_class)
4402                    << SourceRange(IdLoc, Init->getSourceRange().getEnd());
4403                BaseType = Base.getType();
4404                break;
4405              }
4406            }
4407          }
4408        }
4409  
4410        // If no results were found, try to correct typos.
4411        TypoCorrection Corr;
4412        MemInitializerValidatorCCC CCC(ClassDecl);
4413        if (R.empty() && BaseType.isNull() &&
4414            (Corr = CorrectTypo(R.getLookupNameInfo(), R.getLookupKind(), S, &SS,
4415                                CCC, CTK_ErrorRecovery, ClassDecl))) {
4416          if (FieldDecl *Member = Corr.getCorrectionDeclAs<FieldDecl>()) {
4417            // We have found a non-static data member with a similar
4418            // name to what was typed; complain and initialize that
4419            // member.
4420            diagnoseTypo(Corr,
4421                         PDiag(diag::err_mem_init_not_member_or_class_suggest)
4422                           << MemberOrBase << true);
4423            return BuildMemberInitializer(Member, Init, IdLoc);
4424          } else if (TypeDecl *Type = Corr.getCorrectionDeclAs<TypeDecl>()) {
4425            const CXXBaseSpecifier *DirectBaseSpec;
4426            const CXXBaseSpecifier *VirtualBaseSpec;
4427            if (FindBaseInitializer(*this, ClassDecl,
4428                                    Context.getTypeDeclType(Type),
4429                                    DirectBaseSpec, VirtualBaseSpec)) {
4430              // We have found a direct or virtual base class with a
4431              // similar name to what was typed; complain and initialize
4432              // that base class.
4433              diagnoseTypo(Corr,
4434                           PDiag(diag::err_mem_init_not_member_or_class_suggest)
4435                             << MemberOrBase << false,
4436                           PDiag() /*Suppress note, we provide our own.*/);
4437  
4438              const CXXBaseSpecifier *BaseSpec = DirectBaseSpec ? DirectBaseSpec
4439                                                                : VirtualBaseSpec;
4440              Diag(BaseSpec->getBeginLoc(), diag::note_base_class_specified_here)
4441                  << BaseSpec->getType() << BaseSpec->getSourceRange();
4442  
4443              TyD = Type;
4444            }
4445          }
4446        }
4447  
4448        if (!TyD && BaseType.isNull()) {
4449          Diag(IdLoc, diag::err_mem_init_not_member_or_class)
4450            << MemberOrBase << SourceRange(IdLoc,Init->getSourceRange().getEnd());
4451          return true;
4452        }
4453      }
4454  
4455      if (BaseType.isNull()) {
4456        BaseType = getElaboratedType(ElaboratedTypeKeyword::None, SS,
4457                                     Context.getTypeDeclType(TyD));
4458        MarkAnyDeclReferenced(TyD->getLocation(), TyD, /*OdrUse=*/false);
4459        TInfo = Context.CreateTypeSourceInfo(BaseType);
4460        ElaboratedTypeLoc TL = TInfo->getTypeLoc().castAs<ElaboratedTypeLoc>();
4461        TL.getNamedTypeLoc().castAs<TypeSpecTypeLoc>().setNameLoc(IdLoc);
4462        TL.setElaboratedKeywordLoc(SourceLocation());
4463        TL.setQualifierLoc(SS.getWithLocInContext(Context));
4464      }
4465    }
4466  
4467    if (!TInfo)
4468      TInfo = Context.getTrivialTypeSourceInfo(BaseType, IdLoc);
4469  
4470    return BuildBaseInitializer(BaseType, TInfo, Init, ClassDecl, EllipsisLoc);
4471  }
4472  
4473  MemInitResult
4474  Sema::BuildMemberInitializer(ValueDecl *Member, Expr *Init,
4475                               SourceLocation IdLoc) {
4476    FieldDecl *DirectMember = dyn_cast<FieldDecl>(Member);
4477    IndirectFieldDecl *IndirectMember = dyn_cast<IndirectFieldDecl>(Member);
4478    assert((DirectMember || IndirectMember) &&
4479           "Member must be a FieldDecl or IndirectFieldDecl");
4480  
4481    if (DiagnoseUnexpandedParameterPack(Init, UPPC_Initializer))
4482      return true;
4483  
4484    if (Member->isInvalidDecl())
4485      return true;
4486  
4487    MultiExprArg Args;
4488    if (ParenListExpr *ParenList = dyn_cast<ParenListExpr>(Init)) {
4489      Args = MultiExprArg(ParenList->getExprs(), ParenList->getNumExprs());
4490    } else if (InitListExpr *InitList = dyn_cast<InitListExpr>(Init)) {
4491      Args = MultiExprArg(InitList->getInits(), InitList->getNumInits());
4492    } else {
4493      // Template instantiation doesn't reconstruct ParenListExprs for us.
4494      Args = Init;
4495    }
4496  
4497    SourceRange InitRange = Init->getSourceRange();
4498  
4499    if (Member->getType()->isDependentType() || Init->isTypeDependent()) {
4500      // Can't check initialization for a member of dependent type or when
4501      // any of the arguments are type-dependent expressions.
4502      DiscardCleanupsInEvaluationContext();
4503    } else {
4504      bool InitList = false;
4505      if (isa<InitListExpr>(Init)) {
4506        InitList = true;
4507        Args = Init;
4508      }
4509  
4510      // Initialize the member.
4511      InitializedEntity MemberEntity =
4512        DirectMember ? InitializedEntity::InitializeMember(DirectMember, nullptr)
4513                     : InitializedEntity::InitializeMember(IndirectMember,
4514                                                           nullptr);
4515      InitializationKind Kind =
4516          InitList ? InitializationKind::CreateDirectList(
4517                         IdLoc, Init->getBeginLoc(), Init->getEndLoc())
4518                   : InitializationKind::CreateDirect(IdLoc, InitRange.getBegin(),
4519                                                      InitRange.getEnd());
4520  
4521      InitializationSequence InitSeq(*this, MemberEntity, Kind, Args);
4522      ExprResult MemberInit = InitSeq.Perform(*this, MemberEntity, Kind, Args,
4523                                              nullptr);
4524      if (!MemberInit.isInvalid()) {
4525        // C++11 [class.base.init]p7:
4526        //   The initialization of each base and member constitutes a
4527        //   full-expression.
4528        MemberInit = ActOnFinishFullExpr(MemberInit.get(), InitRange.getBegin(),
4529                                         /*DiscardedValue*/ false);
4530      }
4531  
4532      if (MemberInit.isInvalid()) {
4533        // Args were sensible expressions but we couldn't initialize the member
4534        // from them. Preserve them in a RecoveryExpr instead.
4535        Init = CreateRecoveryExpr(InitRange.getBegin(), InitRange.getEnd(), Args,
4536                                  Member->getType())
4537                   .get();
4538        if (!Init)
4539          return true;
4540      } else {
4541        Init = MemberInit.get();
4542      }
4543    }
4544  
4545    if (DirectMember) {
4546      return new (Context) CXXCtorInitializer(Context, DirectMember, IdLoc,
4547                                              InitRange.getBegin(), Init,
4548                                              InitRange.getEnd());
4549    } else {
4550      return new (Context) CXXCtorInitializer(Context, IndirectMember, IdLoc,
4551                                              InitRange.getBegin(), Init,
4552                                              InitRange.getEnd());
4553    }
4554  }
4555  
4556  MemInitResult
4557  Sema::BuildDelegatingInitializer(TypeSourceInfo *TInfo, Expr *Init,
4558                                   CXXRecordDecl *ClassDecl) {
4559    SourceLocation NameLoc = TInfo->getTypeLoc().getSourceRange().getBegin();
4560    if (!LangOpts.CPlusPlus11)
4561      return Diag(NameLoc, diag::err_delegating_ctor)
4562             << TInfo->getTypeLoc().getSourceRange();
4563    Diag(NameLoc, diag::warn_cxx98_compat_delegating_ctor);
4564  
4565    bool InitList = true;
4566    MultiExprArg Args = Init;
4567    if (ParenListExpr *ParenList = dyn_cast<ParenListExpr>(Init)) {
4568      InitList = false;
4569      Args = MultiExprArg(ParenList->getExprs(), ParenList->getNumExprs());
4570    }
4571  
4572    SourceRange InitRange = Init->getSourceRange();
4573    // Initialize the object.
4574    InitializedEntity DelegationEntity = InitializedEntity::InitializeDelegation(
4575                                       QualType(ClassDecl->getTypeForDecl(), 0));
4576    InitializationKind Kind =
4577        InitList ? InitializationKind::CreateDirectList(
4578                       NameLoc, Init->getBeginLoc(), Init->getEndLoc())
4579                 : InitializationKind::CreateDirect(NameLoc, InitRange.getBegin(),
4580                                                    InitRange.getEnd());
4581    InitializationSequence InitSeq(*this, DelegationEntity, Kind, Args);
4582    ExprResult DelegationInit = InitSeq.Perform(*this, DelegationEntity, Kind,
4583                                                Args, nullptr);
4584    if (!DelegationInit.isInvalid()) {
4585      assert((DelegationInit.get()->containsErrors() ||
4586              cast<CXXConstructExpr>(DelegationInit.get())->getConstructor()) &&
4587             "Delegating constructor with no target?");
4588  
4589      // C++11 [class.base.init]p7:
4590      //   The initialization of each base and member constitutes a
4591      //   full-expression.
4592      DelegationInit = ActOnFinishFullExpr(
4593          DelegationInit.get(), InitRange.getBegin(), /*DiscardedValue*/ false);
4594    }
4595  
4596    if (DelegationInit.isInvalid()) {
4597      DelegationInit =
4598          CreateRecoveryExpr(InitRange.getBegin(), InitRange.getEnd(), Args,
4599                             QualType(ClassDecl->getTypeForDecl(), 0));
4600      if (DelegationInit.isInvalid())
4601        return true;
4602    } else {
4603      // If we are in a dependent context, template instantiation will
4604      // perform this type-checking again. Just save the arguments that we
4605      // received in a ParenListExpr.
4606      // FIXME: This isn't quite ideal, since our ASTs don't capture all
4607      // of the information that we have about the base
4608      // initializer. However, deconstructing the ASTs is a dicey process,
4609      // and this approach is far more likely to get the corner cases right.
4610      if (CurContext->isDependentContext())
4611        DelegationInit = Init;
4612    }
4613  
4614    return new (Context) CXXCtorInitializer(Context, TInfo, InitRange.getBegin(),
4615                                            DelegationInit.getAs<Expr>(),
4616                                            InitRange.getEnd());
4617  }
4618  
4619  MemInitResult
4620  Sema::BuildBaseInitializer(QualType BaseType, TypeSourceInfo *BaseTInfo,
4621                             Expr *Init, CXXRecordDecl *ClassDecl,
4622                             SourceLocation EllipsisLoc) {
4623    SourceLocation BaseLoc = BaseTInfo->getTypeLoc().getBeginLoc();
4624  
4625    if (!BaseType->isDependentType() && !BaseType->isRecordType())
4626      return Diag(BaseLoc, diag::err_base_init_does_not_name_class)
4627             << BaseType << BaseTInfo->getTypeLoc().getSourceRange();
4628  
4629    // C++ [class.base.init]p2:
4630    //   [...] Unless the mem-initializer-id names a nonstatic data
4631    //   member of the constructor's class or a direct or virtual base
4632    //   of that class, the mem-initializer is ill-formed. A
4633    //   mem-initializer-list can initialize a base class using any
4634    //   name that denotes that base class type.
4635  
4636    // We can store the initializers in "as-written" form and delay analysis until
4637    // instantiation if the constructor is dependent. But not for dependent
4638    // (broken) code in a non-template! SetCtorInitializers does not expect this.
4639    bool Dependent = CurContext->isDependentContext() &&
4640                     (BaseType->isDependentType() || Init->isTypeDependent());
4641  
4642    SourceRange InitRange = Init->getSourceRange();
4643    if (EllipsisLoc.isValid()) {
4644      // This is a pack expansion.
4645      if (!BaseType->containsUnexpandedParameterPack())  {
4646        Diag(EllipsisLoc, diag::err_pack_expansion_without_parameter_packs)
4647          << SourceRange(BaseLoc, InitRange.getEnd());
4648  
4649        EllipsisLoc = SourceLocation();
4650      }
4651    } else {
4652      // Check for any unexpanded parameter packs.
4653      if (DiagnoseUnexpandedParameterPack(BaseLoc, BaseTInfo, UPPC_Initializer))
4654        return true;
4655  
4656      if (DiagnoseUnexpandedParameterPack(Init, UPPC_Initializer))
4657        return true;
4658    }
4659  
4660    // Check for direct and virtual base classes.
4661    const CXXBaseSpecifier *DirectBaseSpec = nullptr;
4662    const CXXBaseSpecifier *VirtualBaseSpec = nullptr;
4663    if (!Dependent) {
4664      if (Context.hasSameUnqualifiedType(QualType(ClassDecl->getTypeForDecl(),0),
4665                                         BaseType))
4666        return BuildDelegatingInitializer(BaseTInfo, Init, ClassDecl);
4667  
4668      FindBaseInitializer(*this, ClassDecl, BaseType, DirectBaseSpec,
4669                          VirtualBaseSpec);
4670  
4671      // C++ [base.class.init]p2:
4672      // Unless the mem-initializer-id names a nonstatic data member of the
4673      // constructor's class or a direct or virtual base of that class, the
4674      // mem-initializer is ill-formed.
4675      if (!DirectBaseSpec && !VirtualBaseSpec) {
4676        // If the class has any dependent bases, then it's possible that
4677        // one of those types will resolve to the same type as
4678        // BaseType. Therefore, just treat this as a dependent base
4679        // class initialization.  FIXME: Should we try to check the
4680        // initialization anyway? It seems odd.
4681        if (ClassDecl->hasAnyDependentBases())
4682          Dependent = true;
4683        else
4684          return Diag(BaseLoc, diag::err_not_direct_base_or_virtual)
4685                 << BaseType << Context.getTypeDeclType(ClassDecl)
4686                 << BaseTInfo->getTypeLoc().getSourceRange();
4687      }
4688    }
4689  
4690    if (Dependent) {
4691      DiscardCleanupsInEvaluationContext();
4692  
4693      return new (Context) CXXCtorInitializer(Context, BaseTInfo,
4694                                              /*IsVirtual=*/false,
4695                                              InitRange.getBegin(), Init,
4696                                              InitRange.getEnd(), EllipsisLoc);
4697    }
4698  
4699    // C++ [base.class.init]p2:
4700    //   If a mem-initializer-id is ambiguous because it designates both
4701    //   a direct non-virtual base class and an inherited virtual base
4702    //   class, the mem-initializer is ill-formed.
4703    if (DirectBaseSpec && VirtualBaseSpec)
4704      return Diag(BaseLoc, diag::err_base_init_direct_and_virtual)
4705        << BaseType << BaseTInfo->getTypeLoc().getLocalSourceRange();
4706  
4707    const CXXBaseSpecifier *BaseSpec = DirectBaseSpec;
4708    if (!BaseSpec)
4709      BaseSpec = VirtualBaseSpec;
4710  
4711    // Initialize the base.
4712    bool InitList = true;
4713    MultiExprArg Args = Init;
4714    if (ParenListExpr *ParenList = dyn_cast<ParenListExpr>(Init)) {
4715      InitList = false;
4716      Args = MultiExprArg(ParenList->getExprs(), ParenList->getNumExprs());
4717    }
4718  
4719    InitializedEntity BaseEntity =
4720      InitializedEntity::InitializeBase(Context, BaseSpec, VirtualBaseSpec);
4721    InitializationKind Kind =
4722        InitList ? InitializationKind::CreateDirectList(BaseLoc)
4723                 : InitializationKind::CreateDirect(BaseLoc, InitRange.getBegin(),
4724                                                    InitRange.getEnd());
4725    InitializationSequence InitSeq(*this, BaseEntity, Kind, Args);
4726    ExprResult BaseInit = InitSeq.Perform(*this, BaseEntity, Kind, Args, nullptr);
4727    if (!BaseInit.isInvalid()) {
4728      // C++11 [class.base.init]p7:
4729      //   The initialization of each base and member constitutes a
4730      //   full-expression.
4731      BaseInit = ActOnFinishFullExpr(BaseInit.get(), InitRange.getBegin(),
4732                                     /*DiscardedValue*/ false);
4733    }
4734  
4735    if (BaseInit.isInvalid()) {
4736      BaseInit = CreateRecoveryExpr(InitRange.getBegin(), InitRange.getEnd(),
4737                                    Args, BaseType);
4738      if (BaseInit.isInvalid())
4739        return true;
4740    } else {
4741      // If we are in a dependent context, template instantiation will
4742      // perform this type-checking again. Just save the arguments that we
4743      // received in a ParenListExpr.
4744      // FIXME: This isn't quite ideal, since our ASTs don't capture all
4745      // of the information that we have about the base
4746      // initializer. However, deconstructing the ASTs is a dicey process,
4747      // and this approach is far more likely to get the corner cases right.
4748      if (CurContext->isDependentContext())
4749        BaseInit = Init;
4750    }
4751  
4752    return new (Context) CXXCtorInitializer(Context, BaseTInfo,
4753                                            BaseSpec->isVirtual(),
4754                                            InitRange.getBegin(),
4755                                            BaseInit.getAs<Expr>(),
4756                                            InitRange.getEnd(), EllipsisLoc);
4757  }
4758  
4759  // Create a static_cast\<T&&>(expr).
4760  static Expr *CastForMoving(Sema &SemaRef, Expr *E) {
4761    QualType TargetType =
4762        SemaRef.BuildReferenceType(E->getType(), /*SpelledAsLValue*/ false,
4763                                   SourceLocation(), DeclarationName());
4764    SourceLocation ExprLoc = E->getBeginLoc();
4765    TypeSourceInfo *TargetLoc = SemaRef.Context.getTrivialTypeSourceInfo(
4766        TargetType, ExprLoc);
4767  
4768    return SemaRef.BuildCXXNamedCast(ExprLoc, tok::kw_static_cast, TargetLoc, E,
4769                                     SourceRange(ExprLoc, ExprLoc),
4770                                     E->getSourceRange()).get();
4771  }
4772  
4773  /// ImplicitInitializerKind - How an implicit base or member initializer should
4774  /// initialize its base or member.
4775  enum ImplicitInitializerKind {
4776    IIK_Default,
4777    IIK_Copy,
4778    IIK_Move,
4779    IIK_Inherit
4780  };
4781  
4782  static bool
4783  BuildImplicitBaseInitializer(Sema &SemaRef, CXXConstructorDecl *Constructor,
4784                               ImplicitInitializerKind ImplicitInitKind,
4785                               CXXBaseSpecifier *BaseSpec,
4786                               bool IsInheritedVirtualBase,
4787                               CXXCtorInitializer *&CXXBaseInit) {
4788    InitializedEntity InitEntity
4789      = InitializedEntity::InitializeBase(SemaRef.Context, BaseSpec,
4790                                          IsInheritedVirtualBase);
4791  
4792    ExprResult BaseInit;
4793  
4794    switch (ImplicitInitKind) {
4795    case IIK_Inherit:
4796    case IIK_Default: {
4797      InitializationKind InitKind
4798        = InitializationKind::CreateDefault(Constructor->getLocation());
4799      InitializationSequence InitSeq(SemaRef, InitEntity, InitKind, std::nullopt);
4800      BaseInit = InitSeq.Perform(SemaRef, InitEntity, InitKind, std::nullopt);
4801      break;
4802    }
4803  
4804    case IIK_Move:
4805    case IIK_Copy: {
4806      bool Moving = ImplicitInitKind == IIK_Move;
4807      ParmVarDecl *Param = Constructor->getParamDecl(0);
4808      QualType ParamType = Param->getType().getNonReferenceType();
4809  
4810      Expr *CopyCtorArg =
4811        DeclRefExpr::Create(SemaRef.Context, NestedNameSpecifierLoc(),
4812                            SourceLocation(), Param, false,
4813                            Constructor->getLocation(), ParamType,
4814                            VK_LValue, nullptr);
4815  
4816      SemaRef.MarkDeclRefReferenced(cast<DeclRefExpr>(CopyCtorArg));
4817  
4818      // Cast to the base class to avoid ambiguities.
4819      QualType ArgTy =
4820        SemaRef.Context.getQualifiedType(BaseSpec->getType().getUnqualifiedType(),
4821                                         ParamType.getQualifiers());
4822  
4823      if (Moving) {
4824        CopyCtorArg = CastForMoving(SemaRef, CopyCtorArg);
4825      }
4826  
4827      CXXCastPath BasePath;
4828      BasePath.push_back(BaseSpec);
4829      CopyCtorArg = SemaRef.ImpCastExprToType(CopyCtorArg, ArgTy,
4830                                              CK_UncheckedDerivedToBase,
4831                                              Moving ? VK_XValue : VK_LValue,
4832                                              &BasePath).get();
4833  
4834      InitializationKind InitKind
4835        = InitializationKind::CreateDirect(Constructor->getLocation(),
4836                                           SourceLocation(), SourceLocation());
4837      InitializationSequence InitSeq(SemaRef, InitEntity, InitKind, CopyCtorArg);
4838      BaseInit = InitSeq.Perform(SemaRef, InitEntity, InitKind, CopyCtorArg);
4839      break;
4840    }
4841    }
4842  
4843    BaseInit = SemaRef.MaybeCreateExprWithCleanups(BaseInit);
4844    if (BaseInit.isInvalid())
4845      return true;
4846  
4847    CXXBaseInit =
4848      new (SemaRef.Context) CXXCtorInitializer(SemaRef.Context,
4849                 SemaRef.Context.getTrivialTypeSourceInfo(BaseSpec->getType(),
4850                                                          SourceLocation()),
4851                                               BaseSpec->isVirtual(),
4852                                               SourceLocation(),
4853                                               BaseInit.getAs<Expr>(),
4854                                               SourceLocation(),
4855                                               SourceLocation());
4856  
4857    return false;
4858  }
4859  
4860  static bool RefersToRValueRef(Expr *MemRef) {
4861    ValueDecl *Referenced = cast<MemberExpr>(MemRef)->getMemberDecl();
4862    return Referenced->getType()->isRValueReferenceType();
4863  }
4864  
4865  static bool
4866  BuildImplicitMemberInitializer(Sema &SemaRef, CXXConstructorDecl *Constructor,
4867                                 ImplicitInitializerKind ImplicitInitKind,
4868                                 FieldDecl *Field, IndirectFieldDecl *Indirect,
4869                                 CXXCtorInitializer *&CXXMemberInit) {
4870    if (Field->isInvalidDecl())
4871      return true;
4872  
4873    SourceLocation Loc = Constructor->getLocation();
4874  
4875    if (ImplicitInitKind == IIK_Copy || ImplicitInitKind == IIK_Move) {
4876      bool Moving = ImplicitInitKind == IIK_Move;
4877      ParmVarDecl *Param = Constructor->getParamDecl(0);
4878      QualType ParamType = Param->getType().getNonReferenceType();
4879  
4880      // Suppress copying zero-width bitfields.
4881      if (Field->isZeroLengthBitField(SemaRef.Context))
4882        return false;
4883  
4884      Expr *MemberExprBase =
4885        DeclRefExpr::Create(SemaRef.Context, NestedNameSpecifierLoc(),
4886                            SourceLocation(), Param, false,
4887                            Loc, ParamType, VK_LValue, nullptr);
4888  
4889      SemaRef.MarkDeclRefReferenced(cast<DeclRefExpr>(MemberExprBase));
4890  
4891      if (Moving) {
4892        MemberExprBase = CastForMoving(SemaRef, MemberExprBase);
4893      }
4894  
4895      // Build a reference to this field within the parameter.
4896      CXXScopeSpec SS;
4897      LookupResult MemberLookup(SemaRef, Field->getDeclName(), Loc,
4898                                Sema::LookupMemberName);
4899      MemberLookup.addDecl(Indirect ? cast<ValueDecl>(Indirect)
4900                                    : cast<ValueDecl>(Field), AS_public);
4901      MemberLookup.resolveKind();
4902      ExprResult CtorArg
4903        = SemaRef.BuildMemberReferenceExpr(MemberExprBase,
4904                                           ParamType, Loc,
4905                                           /*IsArrow=*/false,
4906                                           SS,
4907                                           /*TemplateKWLoc=*/SourceLocation(),
4908                                           /*FirstQualifierInScope=*/nullptr,
4909                                           MemberLookup,
4910                                           /*TemplateArgs=*/nullptr,
4911                                           /*S*/nullptr);
4912      if (CtorArg.isInvalid())
4913        return true;
4914  
4915      // C++11 [class.copy]p15:
4916      //   - if a member m has rvalue reference type T&&, it is direct-initialized
4917      //     with static_cast<T&&>(x.m);
4918      if (RefersToRValueRef(CtorArg.get())) {
4919        CtorArg = CastForMoving(SemaRef, CtorArg.get());
4920      }
4921  
4922      InitializedEntity Entity =
4923          Indirect ? InitializedEntity::InitializeMember(Indirect, nullptr,
4924                                                         /*Implicit*/ true)
4925                   : InitializedEntity::InitializeMember(Field, nullptr,
4926                                                         /*Implicit*/ true);
4927  
4928      // Direct-initialize to use the copy constructor.
4929      InitializationKind InitKind =
4930        InitializationKind::CreateDirect(Loc, SourceLocation(), SourceLocation());
4931  
4932      Expr *CtorArgE = CtorArg.getAs<Expr>();
4933      InitializationSequence InitSeq(SemaRef, Entity, InitKind, CtorArgE);
4934      ExprResult MemberInit =
4935          InitSeq.Perform(SemaRef, Entity, InitKind, MultiExprArg(&CtorArgE, 1));
4936      MemberInit = SemaRef.MaybeCreateExprWithCleanups(MemberInit);
4937      if (MemberInit.isInvalid())
4938        return true;
4939  
4940      if (Indirect)
4941        CXXMemberInit = new (SemaRef.Context) CXXCtorInitializer(
4942            SemaRef.Context, Indirect, Loc, Loc, MemberInit.getAs<Expr>(), Loc);
4943      else
4944        CXXMemberInit = new (SemaRef.Context) CXXCtorInitializer(
4945            SemaRef.Context, Field, Loc, Loc, MemberInit.getAs<Expr>(), Loc);
4946      return false;
4947    }
4948  
4949    assert((ImplicitInitKind == IIK_Default || ImplicitInitKind == IIK_Inherit) &&
4950           "Unhandled implicit init kind!");
4951  
4952    QualType FieldBaseElementType =
4953      SemaRef.Context.getBaseElementType(Field->getType());
4954  
4955    if (FieldBaseElementType->isRecordType()) {
4956      InitializedEntity InitEntity =
4957          Indirect ? InitializedEntity::InitializeMember(Indirect, nullptr,
4958                                                         /*Implicit*/ true)
4959                   : InitializedEntity::InitializeMember(Field, nullptr,
4960                                                         /*Implicit*/ true);
4961      InitializationKind InitKind =
4962        InitializationKind::CreateDefault(Loc);
4963  
4964      InitializationSequence InitSeq(SemaRef, InitEntity, InitKind, std::nullopt);
4965      ExprResult MemberInit =
4966          InitSeq.Perform(SemaRef, InitEntity, InitKind, std::nullopt);
4967  
4968      MemberInit = SemaRef.MaybeCreateExprWithCleanups(MemberInit);
4969      if (MemberInit.isInvalid())
4970        return true;
4971  
4972      if (Indirect)
4973        CXXMemberInit = new (SemaRef.Context) CXXCtorInitializer(SemaRef.Context,
4974                                                                 Indirect, Loc,
4975                                                                 Loc,
4976                                                                 MemberInit.get(),
4977                                                                 Loc);
4978      else
4979        CXXMemberInit = new (SemaRef.Context) CXXCtorInitializer(SemaRef.Context,
4980                                                                 Field, Loc, Loc,
4981                                                                 MemberInit.get(),
4982                                                                 Loc);
4983      return false;
4984    }
4985  
4986    if (!Field->getParent()->isUnion()) {
4987      if (FieldBaseElementType->isReferenceType()) {
4988        SemaRef.Diag(Constructor->getLocation(),
4989                     diag::err_uninitialized_member_in_ctor)
4990        << (int)Constructor->isImplicit()
4991        << SemaRef.Context.getTagDeclType(Constructor->getParent())
4992        << 0 << Field->getDeclName();
4993        SemaRef.Diag(Field->getLocation(), diag::note_declared_at);
4994        return true;
4995      }
4996  
4997      if (FieldBaseElementType.isConstQualified()) {
4998        SemaRef.Diag(Constructor->getLocation(),
4999                     diag::err_uninitialized_member_in_ctor)
5000        << (int)Constructor->isImplicit()
5001        << SemaRef.Context.getTagDeclType(Constructor->getParent())
5002        << 1 << Field->getDeclName();
5003        SemaRef.Diag(Field->getLocation(), diag::note_declared_at);
5004        return true;
5005      }
5006    }
5007  
5008    if (FieldBaseElementType.hasNonTrivialObjCLifetime()) {
5009      // ARC and Weak:
5010      //   Default-initialize Objective-C pointers to NULL.
5011      CXXMemberInit
5012        = new (SemaRef.Context) CXXCtorInitializer(SemaRef.Context, Field,
5013                                                   Loc, Loc,
5014                   new (SemaRef.Context) ImplicitValueInitExpr(Field->getType()),
5015                                                   Loc);
5016      return false;
5017    }
5018  
5019    // Nothing to initialize.
5020    CXXMemberInit = nullptr;
5021    return false;
5022  }
5023  
5024  namespace {
5025  struct BaseAndFieldInfo {
5026    Sema &S;
5027    CXXConstructorDecl *Ctor;
5028    bool AnyErrorsInInits;
5029    ImplicitInitializerKind IIK;
5030    llvm::DenseMap<const void *, CXXCtorInitializer*> AllBaseFields;
5031    SmallVector<CXXCtorInitializer*, 8> AllToInit;
5032    llvm::DenseMap<TagDecl*, FieldDecl*> ActiveUnionMember;
5033  
5034    BaseAndFieldInfo(Sema &S, CXXConstructorDecl *Ctor, bool ErrorsInInits)
5035      : S(S), Ctor(Ctor), AnyErrorsInInits(ErrorsInInits) {
5036      bool Generated = Ctor->isImplicit() || Ctor->isDefaulted();
5037      if (Ctor->getInheritedConstructor())
5038        IIK = IIK_Inherit;
5039      else if (Generated && Ctor->isCopyConstructor())
5040        IIK = IIK_Copy;
5041      else if (Generated && Ctor->isMoveConstructor())
5042        IIK = IIK_Move;
5043      else
5044        IIK = IIK_Default;
5045    }
5046  
5047    bool isImplicitCopyOrMove() const {
5048      switch (IIK) {
5049      case IIK_Copy:
5050      case IIK_Move:
5051        return true;
5052  
5053      case IIK_Default:
5054      case IIK_Inherit:
5055        return false;
5056      }
5057  
5058      llvm_unreachable("Invalid ImplicitInitializerKind!");
5059    }
5060  
5061    bool addFieldInitializer(CXXCtorInitializer *Init) {
5062      AllToInit.push_back(Init);
5063  
5064      // Check whether this initializer makes the field "used".
5065      if (Init->getInit()->HasSideEffects(S.Context))
5066        S.UnusedPrivateFields.remove(Init->getAnyMember());
5067  
5068      return false;
5069    }
5070  
5071    bool isInactiveUnionMember(FieldDecl *Field) {
5072      RecordDecl *Record = Field->getParent();
5073      if (!Record->isUnion())
5074        return false;
5075  
5076      if (FieldDecl *Active =
5077              ActiveUnionMember.lookup(Record->getCanonicalDecl()))
5078        return Active != Field->getCanonicalDecl();
5079  
5080      // In an implicit copy or move constructor, ignore any in-class initializer.
5081      if (isImplicitCopyOrMove())
5082        return true;
5083  
5084      // If there's no explicit initialization, the field is active only if it
5085      // has an in-class initializer...
5086      if (Field->hasInClassInitializer())
5087        return false;
5088      // ... or it's an anonymous struct or union whose class has an in-class
5089      // initializer.
5090      if (!Field->isAnonymousStructOrUnion())
5091        return true;
5092      CXXRecordDecl *FieldRD = Field->getType()->getAsCXXRecordDecl();
5093      return !FieldRD->hasInClassInitializer();
5094    }
5095  
5096    /// Determine whether the given field is, or is within, a union member
5097    /// that is inactive (because there was an initializer given for a different
5098    /// member of the union, or because the union was not initialized at all).
5099    bool isWithinInactiveUnionMember(FieldDecl *Field,
5100                                     IndirectFieldDecl *Indirect) {
5101      if (!Indirect)
5102        return isInactiveUnionMember(Field);
5103  
5104      for (auto *C : Indirect->chain()) {
5105        FieldDecl *Field = dyn_cast<FieldDecl>(C);
5106        if (Field && isInactiveUnionMember(Field))
5107          return true;
5108      }
5109      return false;
5110    }
5111  };
5112  }
5113  
5114  /// Determine whether the given type is an incomplete or zero-lenfgth
5115  /// array type.
5116  static bool isIncompleteOrZeroLengthArrayType(ASTContext &Context, QualType T) {
5117    if (T->isIncompleteArrayType())
5118      return true;
5119  
5120    while (const ConstantArrayType *ArrayT = Context.getAsConstantArrayType(T)) {
5121      if (ArrayT->isZeroSize())
5122        return true;
5123  
5124      T = ArrayT->getElementType();
5125    }
5126  
5127    return false;
5128  }
5129  
5130  static bool CollectFieldInitializer(Sema &SemaRef, BaseAndFieldInfo &Info,
5131                                      FieldDecl *Field,
5132                                      IndirectFieldDecl *Indirect = nullptr) {
5133    if (Field->isInvalidDecl())
5134      return false;
5135  
5136    // Overwhelmingly common case: we have a direct initializer for this field.
5137    if (CXXCtorInitializer *Init =
5138            Info.AllBaseFields.lookup(Field->getCanonicalDecl()))
5139      return Info.addFieldInitializer(Init);
5140  
5141    // C++11 [class.base.init]p8:
5142    //   if the entity is a non-static data member that has a
5143    //   brace-or-equal-initializer and either
5144    //   -- the constructor's class is a union and no other variant member of that
5145    //      union is designated by a mem-initializer-id or
5146    //   -- the constructor's class is not a union, and, if the entity is a member
5147    //      of an anonymous union, no other member of that union is designated by
5148    //      a mem-initializer-id,
5149    //   the entity is initialized as specified in [dcl.init].
5150    //
5151    // We also apply the same rules to handle anonymous structs within anonymous
5152    // unions.
5153    if (Info.isWithinInactiveUnionMember(Field, Indirect))
5154      return false;
5155  
5156    if (Field->hasInClassInitializer() && !Info.isImplicitCopyOrMove()) {
5157      ExprResult DIE =
5158          SemaRef.BuildCXXDefaultInitExpr(Info.Ctor->getLocation(), Field);
5159      if (DIE.isInvalid())
5160        return true;
5161  
5162      auto Entity = InitializedEntity::InitializeMember(Field, nullptr, true);
5163      SemaRef.checkInitializerLifetime(Entity, DIE.get());
5164  
5165      CXXCtorInitializer *Init;
5166      if (Indirect)
5167        Init = new (SemaRef.Context)
5168            CXXCtorInitializer(SemaRef.Context, Indirect, SourceLocation(),
5169                               SourceLocation(), DIE.get(), SourceLocation());
5170      else
5171        Init = new (SemaRef.Context)
5172            CXXCtorInitializer(SemaRef.Context, Field, SourceLocation(),
5173                               SourceLocation(), DIE.get(), SourceLocation());
5174      return Info.addFieldInitializer(Init);
5175    }
5176  
5177    // Don't initialize incomplete or zero-length arrays.
5178    if (isIncompleteOrZeroLengthArrayType(SemaRef.Context, Field->getType()))
5179      return false;
5180  
5181    // Don't try to build an implicit initializer if there were semantic
5182    // errors in any of the initializers (and therefore we might be
5183    // missing some that the user actually wrote).
5184    if (Info.AnyErrorsInInits)
5185      return false;
5186  
5187    CXXCtorInitializer *Init = nullptr;
5188    if (BuildImplicitMemberInitializer(Info.S, Info.Ctor, Info.IIK, Field,
5189                                       Indirect, Init))
5190      return true;
5191  
5192    if (!Init)
5193      return false;
5194  
5195    return Info.addFieldInitializer(Init);
5196  }
5197  
5198  bool
5199  Sema::SetDelegatingInitializer(CXXConstructorDecl *Constructor,
5200                                 CXXCtorInitializer *Initializer) {
5201    assert(Initializer->isDelegatingInitializer());
5202    Constructor->setNumCtorInitializers(1);
5203    CXXCtorInitializer **initializer =
5204      new (Context) CXXCtorInitializer*[1];
5205    memcpy(initializer, &Initializer, sizeof (CXXCtorInitializer*));
5206    Constructor->setCtorInitializers(initializer);
5207  
5208    if (CXXDestructorDecl *Dtor = LookupDestructor(Constructor->getParent())) {
5209      MarkFunctionReferenced(Initializer->getSourceLocation(), Dtor);
5210      DiagnoseUseOfDecl(Dtor, Initializer->getSourceLocation());
5211    }
5212  
5213    DelegatingCtorDecls.push_back(Constructor);
5214  
5215    DiagnoseUninitializedFields(*this, Constructor);
5216  
5217    return false;
5218  }
5219  
5220  bool Sema::SetCtorInitializers(CXXConstructorDecl *Constructor, bool AnyErrors,
5221                                 ArrayRef<CXXCtorInitializer *> Initializers) {
5222    if (Constructor->isDependentContext()) {
5223      // Just store the initializers as written, they will be checked during
5224      // instantiation.
5225      if (!Initializers.empty()) {
5226        Constructor->setNumCtorInitializers(Initializers.size());
5227        CXXCtorInitializer **baseOrMemberInitializers =
5228          new (Context) CXXCtorInitializer*[Initializers.size()];
5229        memcpy(baseOrMemberInitializers, Initializers.data(),
5230               Initializers.size() * sizeof(CXXCtorInitializer*));
5231        Constructor->setCtorInitializers(baseOrMemberInitializers);
5232      }
5233  
5234      // Let template instantiation know whether we had errors.
5235      if (AnyErrors)
5236        Constructor->setInvalidDecl();
5237  
5238      return false;
5239    }
5240  
5241    BaseAndFieldInfo Info(*this, Constructor, AnyErrors);
5242  
5243    // We need to build the initializer AST according to order of construction
5244    // and not what user specified in the Initializers list.
5245    CXXRecordDecl *ClassDecl = Constructor->getParent()->getDefinition();
5246    if (!ClassDecl)
5247      return true;
5248  
5249    bool HadError = false;
5250  
5251    for (unsigned i = 0; i < Initializers.size(); i++) {
5252      CXXCtorInitializer *Member = Initializers[i];
5253  
5254      if (Member->isBaseInitializer())
5255        Info.AllBaseFields[Member->getBaseClass()->getAs<RecordType>()] = Member;
5256      else {
5257        Info.AllBaseFields[Member->getAnyMember()->getCanonicalDecl()] = Member;
5258  
5259        if (IndirectFieldDecl *F = Member->getIndirectMember()) {
5260          for (auto *C : F->chain()) {
5261            FieldDecl *FD = dyn_cast<FieldDecl>(C);
5262            if (FD && FD->getParent()->isUnion())
5263              Info.ActiveUnionMember.insert(std::make_pair(
5264                  FD->getParent()->getCanonicalDecl(), FD->getCanonicalDecl()));
5265          }
5266        } else if (FieldDecl *FD = Member->getMember()) {
5267          if (FD->getParent()->isUnion())
5268            Info.ActiveUnionMember.insert(std::make_pair(
5269                FD->getParent()->getCanonicalDecl(), FD->getCanonicalDecl()));
5270        }
5271      }
5272    }
5273  
5274    // Keep track of the direct virtual bases.
5275    llvm::SmallPtrSet<CXXBaseSpecifier *, 16> DirectVBases;
5276    for (auto &I : ClassDecl->bases()) {
5277      if (I.isVirtual())
5278        DirectVBases.insert(&I);
5279    }
5280  
5281    // Push virtual bases before others.
5282    for (auto &VBase : ClassDecl->vbases()) {
5283      if (CXXCtorInitializer *Value
5284          = Info.AllBaseFields.lookup(VBase.getType()->getAs<RecordType>())) {
5285        // [class.base.init]p7, per DR257:
5286        //   A mem-initializer where the mem-initializer-id names a virtual base
5287        //   class is ignored during execution of a constructor of any class that
5288        //   is not the most derived class.
5289        if (ClassDecl->isAbstract()) {
5290          // FIXME: Provide a fixit to remove the base specifier. This requires
5291          // tracking the location of the associated comma for a base specifier.
5292          Diag(Value->getSourceLocation(), diag::warn_abstract_vbase_init_ignored)
5293            << VBase.getType() << ClassDecl;
5294          DiagnoseAbstractType(ClassDecl);
5295        }
5296  
5297        Info.AllToInit.push_back(Value);
5298      } else if (!AnyErrors && !ClassDecl->isAbstract()) {
5299        // [class.base.init]p8, per DR257:
5300        //   If a given [...] base class is not named by a mem-initializer-id
5301        //   [...] and the entity is not a virtual base class of an abstract
5302        //   class, then [...] the entity is default-initialized.
5303        bool IsInheritedVirtualBase = !DirectVBases.count(&VBase);
5304        CXXCtorInitializer *CXXBaseInit;
5305        if (BuildImplicitBaseInitializer(*this, Constructor, Info.IIK,
5306                                         &VBase, IsInheritedVirtualBase,
5307                                         CXXBaseInit)) {
5308          HadError = true;
5309          continue;
5310        }
5311  
5312        Info.AllToInit.push_back(CXXBaseInit);
5313      }
5314    }
5315  
5316    // Non-virtual bases.
5317    for (auto &Base : ClassDecl->bases()) {
5318      // Virtuals are in the virtual base list and already constructed.
5319      if (Base.isVirtual())
5320        continue;
5321  
5322      if (CXXCtorInitializer *Value
5323            = Info.AllBaseFields.lookup(Base.getType()->getAs<RecordType>())) {
5324        Info.AllToInit.push_back(Value);
5325      } else if (!AnyErrors) {
5326        CXXCtorInitializer *CXXBaseInit;
5327        if (BuildImplicitBaseInitializer(*this, Constructor, Info.IIK,
5328                                         &Base, /*IsInheritedVirtualBase=*/false,
5329                                         CXXBaseInit)) {
5330          HadError = true;
5331          continue;
5332        }
5333  
5334        Info.AllToInit.push_back(CXXBaseInit);
5335      }
5336    }
5337  
5338    // Fields.
5339    for (auto *Mem : ClassDecl->decls()) {
5340      if (auto *F = dyn_cast<FieldDecl>(Mem)) {
5341        // C++ [class.bit]p2:
5342        //   A declaration for a bit-field that omits the identifier declares an
5343        //   unnamed bit-field. Unnamed bit-fields are not members and cannot be
5344        //   initialized.
5345        if (F->isUnnamedBitField())
5346          continue;
5347  
5348        // If we're not generating the implicit copy/move constructor, then we'll
5349        // handle anonymous struct/union fields based on their individual
5350        // indirect fields.
5351        if (F->isAnonymousStructOrUnion() && !Info.isImplicitCopyOrMove())
5352          continue;
5353  
5354        if (CollectFieldInitializer(*this, Info, F))
5355          HadError = true;
5356        continue;
5357      }
5358  
5359      // Beyond this point, we only consider default initialization.
5360      if (Info.isImplicitCopyOrMove())
5361        continue;
5362  
5363      if (auto *F = dyn_cast<IndirectFieldDecl>(Mem)) {
5364        if (F->getType()->isIncompleteArrayType()) {
5365          assert(ClassDecl->hasFlexibleArrayMember() &&
5366                 "Incomplete array type is not valid");
5367          continue;
5368        }
5369  
5370        // Initialize each field of an anonymous struct individually.
5371        if (CollectFieldInitializer(*this, Info, F->getAnonField(), F))
5372          HadError = true;
5373  
5374        continue;
5375      }
5376    }
5377  
5378    unsigned NumInitializers = Info.AllToInit.size();
5379    if (NumInitializers > 0) {
5380      Constructor->setNumCtorInitializers(NumInitializers);
5381      CXXCtorInitializer **baseOrMemberInitializers =
5382        new (Context) CXXCtorInitializer*[NumInitializers];
5383      memcpy(baseOrMemberInitializers, Info.AllToInit.data(),
5384             NumInitializers * sizeof(CXXCtorInitializer*));
5385      Constructor->setCtorInitializers(baseOrMemberInitializers);
5386  
5387      // Constructors implicitly reference the base and member
5388      // destructors.
5389      MarkBaseAndMemberDestructorsReferenced(Constructor->getLocation(),
5390                                             Constructor->getParent());
5391    }
5392  
5393    return HadError;
5394  }
5395  
5396  static void PopulateKeysForFields(FieldDecl *Field, SmallVectorImpl<const void*> &IdealInits) {
5397    if (const RecordType *RT = Field->getType()->getAs<RecordType>()) {
5398      const RecordDecl *RD = RT->getDecl();
5399      if (RD->isAnonymousStructOrUnion()) {
5400        for (auto *Field : RD->fields())
5401          PopulateKeysForFields(Field, IdealInits);
5402        return;
5403      }
5404    }
5405    IdealInits.push_back(Field->getCanonicalDecl());
5406  }
5407  
5408  static const void *GetKeyForBase(ASTContext &Context, QualType BaseType) {
5409    return Context.getCanonicalType(BaseType).getTypePtr();
5410  }
5411  
5412  static const void *GetKeyForMember(ASTContext &Context,
5413                                     CXXCtorInitializer *Member) {
5414    if (!Member->isAnyMemberInitializer())
5415      return GetKeyForBase(Context, QualType(Member->getBaseClass(), 0));
5416  
5417    return Member->getAnyMember()->getCanonicalDecl();
5418  }
5419  
5420  static void AddInitializerToDiag(const Sema::SemaDiagnosticBuilder &Diag,
5421                                   const CXXCtorInitializer *Previous,
5422                                   const CXXCtorInitializer *Current) {
5423    if (Previous->isAnyMemberInitializer())
5424      Diag << 0 << Previous->getAnyMember();
5425    else
5426      Diag << 1 << Previous->getTypeSourceInfo()->getType();
5427  
5428    if (Current->isAnyMemberInitializer())
5429      Diag << 0 << Current->getAnyMember();
5430    else
5431      Diag << 1 << Current->getTypeSourceInfo()->getType();
5432  }
5433  
5434  static void DiagnoseBaseOrMemInitializerOrder(
5435      Sema &SemaRef, const CXXConstructorDecl *Constructor,
5436      ArrayRef<CXXCtorInitializer *> Inits) {
5437    if (Constructor->getDeclContext()->isDependentContext())
5438      return;
5439  
5440    // Don't check initializers order unless the warning is enabled at the
5441    // location of at least one initializer.
5442    bool ShouldCheckOrder = false;
5443    for (unsigned InitIndex = 0; InitIndex != Inits.size(); ++InitIndex) {
5444      CXXCtorInitializer *Init = Inits[InitIndex];
5445      if (!SemaRef.Diags.isIgnored(diag::warn_initializer_out_of_order,
5446                                   Init->getSourceLocation())) {
5447        ShouldCheckOrder = true;
5448        break;
5449      }
5450    }
5451    if (!ShouldCheckOrder)
5452      return;
5453  
5454    // Build the list of bases and members in the order that they'll
5455    // actually be initialized.  The explicit initializers should be in
5456    // this same order but may be missing things.
5457    SmallVector<const void*, 32> IdealInitKeys;
5458  
5459    const CXXRecordDecl *ClassDecl = Constructor->getParent();
5460  
5461    // 1. Virtual bases.
5462    for (const auto &VBase : ClassDecl->vbases())
5463      IdealInitKeys.push_back(GetKeyForBase(SemaRef.Context, VBase.getType()));
5464  
5465    // 2. Non-virtual bases.
5466    for (const auto &Base : ClassDecl->bases()) {
5467      if (Base.isVirtual())
5468        continue;
5469      IdealInitKeys.push_back(GetKeyForBase(SemaRef.Context, Base.getType()));
5470    }
5471  
5472    // 3. Direct fields.
5473    for (auto *Field : ClassDecl->fields()) {
5474      if (Field->isUnnamedBitField())
5475        continue;
5476  
5477      PopulateKeysForFields(Field, IdealInitKeys);
5478    }
5479  
5480    unsigned NumIdealInits = IdealInitKeys.size();
5481    unsigned IdealIndex = 0;
5482  
5483    // Track initializers that are in an incorrect order for either a warning or
5484    // note if multiple ones occur.
5485    SmallVector<unsigned> WarnIndexes;
5486    // Correlates the index of an initializer in the init-list to the index of
5487    // the field/base in the class.
5488    SmallVector<std::pair<unsigned, unsigned>, 32> CorrelatedInitOrder;
5489  
5490    for (unsigned InitIndex = 0; InitIndex != Inits.size(); ++InitIndex) {
5491      const void *InitKey = GetKeyForMember(SemaRef.Context, Inits[InitIndex]);
5492  
5493      // Scan forward to try to find this initializer in the idealized
5494      // initializers list.
5495      for (; IdealIndex != NumIdealInits; ++IdealIndex)
5496        if (InitKey == IdealInitKeys[IdealIndex])
5497          break;
5498  
5499      // If we didn't find this initializer, it must be because we
5500      // scanned past it on a previous iteration.  That can only
5501      // happen if we're out of order;  emit a warning.
5502      if (IdealIndex == NumIdealInits && InitIndex) {
5503        WarnIndexes.push_back(InitIndex);
5504  
5505        // Move back to the initializer's location in the ideal list.
5506        for (IdealIndex = 0; IdealIndex != NumIdealInits; ++IdealIndex)
5507          if (InitKey == IdealInitKeys[IdealIndex])
5508            break;
5509  
5510        assert(IdealIndex < NumIdealInits &&
5511               "initializer not found in initializer list");
5512      }
5513      CorrelatedInitOrder.emplace_back(IdealIndex, InitIndex);
5514    }
5515  
5516    if (WarnIndexes.empty())
5517      return;
5518  
5519    // Sort based on the ideal order, first in the pair.
5520    llvm::sort(CorrelatedInitOrder, llvm::less_first());
5521  
5522    // Introduce a new scope as SemaDiagnosticBuilder needs to be destroyed to
5523    // emit the diagnostic before we can try adding notes.
5524    {
5525      Sema::SemaDiagnosticBuilder D = SemaRef.Diag(
5526          Inits[WarnIndexes.front() - 1]->getSourceLocation(),
5527          WarnIndexes.size() == 1 ? diag::warn_initializer_out_of_order
5528                                  : diag::warn_some_initializers_out_of_order);
5529  
5530      for (unsigned I = 0; I < CorrelatedInitOrder.size(); ++I) {
5531        if (CorrelatedInitOrder[I].second == I)
5532          continue;
5533        // Ideally we would be using InsertFromRange here, but clang doesn't
5534        // appear to handle InsertFromRange correctly when the source range is
5535        // modified by another fix-it.
5536        D << FixItHint::CreateReplacement(
5537            Inits[I]->getSourceRange(),
5538            Lexer::getSourceText(
5539                CharSourceRange::getTokenRange(
5540                    Inits[CorrelatedInitOrder[I].second]->getSourceRange()),
5541                SemaRef.getSourceManager(), SemaRef.getLangOpts()));
5542      }
5543  
5544      // If there is only 1 item out of order, the warning expects the name and
5545      // type of each being added to it.
5546      if (WarnIndexes.size() == 1) {
5547        AddInitializerToDiag(D, Inits[WarnIndexes.front() - 1],
5548                             Inits[WarnIndexes.front()]);
5549        return;
5550      }
5551    }
5552    // More than 1 item to warn, create notes letting the user know which ones
5553    // are bad.
5554    for (unsigned WarnIndex : WarnIndexes) {
5555      const clang::CXXCtorInitializer *PrevInit = Inits[WarnIndex - 1];
5556      auto D = SemaRef.Diag(PrevInit->getSourceLocation(),
5557                            diag::note_initializer_out_of_order);
5558      AddInitializerToDiag(D, PrevInit, Inits[WarnIndex]);
5559      D << PrevInit->getSourceRange();
5560    }
5561  }
5562  
5563  namespace {
5564  bool CheckRedundantInit(Sema &S,
5565                          CXXCtorInitializer *Init,
5566                          CXXCtorInitializer *&PrevInit) {
5567    if (!PrevInit) {
5568      PrevInit = Init;
5569      return false;
5570    }
5571  
5572    if (FieldDecl *Field = Init->getAnyMember())
5573      S.Diag(Init->getSourceLocation(),
5574             diag::err_multiple_mem_initialization)
5575        << Field->getDeclName()
5576        << Init->getSourceRange();
5577    else {
5578      const Type *BaseClass = Init->getBaseClass();
5579      assert(BaseClass && "neither field nor base");
5580      S.Diag(Init->getSourceLocation(),
5581             diag::err_multiple_base_initialization)
5582        << QualType(BaseClass, 0)
5583        << Init->getSourceRange();
5584    }
5585    S.Diag(PrevInit->getSourceLocation(), diag::note_previous_initializer)
5586      << 0 << PrevInit->getSourceRange();
5587  
5588    return true;
5589  }
5590  
5591  typedef std::pair<NamedDecl *, CXXCtorInitializer *> UnionEntry;
5592  typedef llvm::DenseMap<RecordDecl*, UnionEntry> RedundantUnionMap;
5593  
5594  bool CheckRedundantUnionInit(Sema &S,
5595                               CXXCtorInitializer *Init,
5596                               RedundantUnionMap &Unions) {
5597    FieldDecl *Field = Init->getAnyMember();
5598    RecordDecl *Parent = Field->getParent();
5599    NamedDecl *Child = Field;
5600  
5601    while (Parent->isAnonymousStructOrUnion() || Parent->isUnion()) {
5602      if (Parent->isUnion()) {
5603        UnionEntry &En = Unions[Parent];
5604        if (En.first && En.first != Child) {
5605          S.Diag(Init->getSourceLocation(),
5606                 diag::err_multiple_mem_union_initialization)
5607            << Field->getDeclName()
5608            << Init->getSourceRange();
5609          S.Diag(En.second->getSourceLocation(), diag::note_previous_initializer)
5610            << 0 << En.second->getSourceRange();
5611          return true;
5612        }
5613        if (!En.first) {
5614          En.first = Child;
5615          En.second = Init;
5616        }
5617        if (!Parent->isAnonymousStructOrUnion())
5618          return false;
5619      }
5620  
5621      Child = Parent;
5622      Parent = cast<RecordDecl>(Parent->getDeclContext());
5623    }
5624  
5625    return false;
5626  }
5627  } // namespace
5628  
5629  void Sema::ActOnMemInitializers(Decl *ConstructorDecl,
5630                                  SourceLocation ColonLoc,
5631                                  ArrayRef<CXXCtorInitializer*> MemInits,
5632                                  bool AnyErrors) {
5633    if (!ConstructorDecl)
5634      return;
5635  
5636    AdjustDeclIfTemplate(ConstructorDecl);
5637  
5638    CXXConstructorDecl *Constructor
5639      = dyn_cast<CXXConstructorDecl>(ConstructorDecl);
5640  
5641    if (!Constructor) {
5642      Diag(ColonLoc, diag::err_only_constructors_take_base_inits);
5643      return;
5644    }
5645  
5646    // Mapping for the duplicate initializers check.
5647    // For member initializers, this is keyed with a FieldDecl*.
5648    // For base initializers, this is keyed with a Type*.
5649    llvm::DenseMap<const void *, CXXCtorInitializer *> Members;
5650  
5651    // Mapping for the inconsistent anonymous-union initializers check.
5652    RedundantUnionMap MemberUnions;
5653  
5654    bool HadError = false;
5655    for (unsigned i = 0; i < MemInits.size(); i++) {
5656      CXXCtorInitializer *Init = MemInits[i];
5657  
5658      // Set the source order index.
5659      Init->setSourceOrder(i);
5660  
5661      if (Init->isAnyMemberInitializer()) {
5662        const void *Key = GetKeyForMember(Context, Init);
5663        if (CheckRedundantInit(*this, Init, Members[Key]) ||
5664            CheckRedundantUnionInit(*this, Init, MemberUnions))
5665          HadError = true;
5666      } else if (Init->isBaseInitializer()) {
5667        const void *Key = GetKeyForMember(Context, Init);
5668        if (CheckRedundantInit(*this, Init, Members[Key]))
5669          HadError = true;
5670      } else {
5671        assert(Init->isDelegatingInitializer());
5672        // This must be the only initializer
5673        if (MemInits.size() != 1) {
5674          Diag(Init->getSourceLocation(),
5675               diag::err_delegating_initializer_alone)
5676            << Init->getSourceRange() << MemInits[i ? 0 : 1]->getSourceRange();
5677          // We will treat this as being the only initializer.
5678        }
5679        SetDelegatingInitializer(Constructor, MemInits[i]);
5680        // Return immediately as the initializer is set.
5681        return;
5682      }
5683    }
5684  
5685    if (HadError)
5686      return;
5687  
5688    DiagnoseBaseOrMemInitializerOrder(*this, Constructor, MemInits);
5689  
5690    SetCtorInitializers(Constructor, AnyErrors, MemInits);
5691  
5692    DiagnoseUninitializedFields(*this, Constructor);
5693  }
5694  
5695  void
5696  Sema::MarkBaseAndMemberDestructorsReferenced(SourceLocation Location,
5697                                               CXXRecordDecl *ClassDecl) {
5698    // Ignore dependent contexts. Also ignore unions, since their members never
5699    // have destructors implicitly called.
5700    if (ClassDecl->isDependentContext() || ClassDecl->isUnion())
5701      return;
5702  
5703    // FIXME: all the access-control diagnostics are positioned on the
5704    // field/base declaration.  That's probably good; that said, the
5705    // user might reasonably want to know why the destructor is being
5706    // emitted, and we currently don't say.
5707  
5708    // Non-static data members.
5709    for (auto *Field : ClassDecl->fields()) {
5710      if (Field->isInvalidDecl())
5711        continue;
5712  
5713      // Don't destroy incomplete or zero-length arrays.
5714      if (isIncompleteOrZeroLengthArrayType(Context, Field->getType()))
5715        continue;
5716  
5717      QualType FieldType = Context.getBaseElementType(Field->getType());
5718  
5719      const RecordType* RT = FieldType->getAs<RecordType>();
5720      if (!RT)
5721        continue;
5722  
5723      CXXRecordDecl *FieldClassDecl = cast<CXXRecordDecl>(RT->getDecl());
5724      if (FieldClassDecl->isInvalidDecl())
5725        continue;
5726      if (FieldClassDecl->hasIrrelevantDestructor())
5727        continue;
5728      // The destructor for an implicit anonymous union member is never invoked.
5729      if (FieldClassDecl->isUnion() && FieldClassDecl->isAnonymousStructOrUnion())
5730        continue;
5731  
5732      CXXDestructorDecl *Dtor = LookupDestructor(FieldClassDecl);
5733      // Dtor might still be missing, e.g because it's invalid.
5734      if (!Dtor)
5735        continue;
5736      CheckDestructorAccess(Field->getLocation(), Dtor,
5737                            PDiag(diag::err_access_dtor_field)
5738                              << Field->getDeclName()
5739                              << FieldType);
5740  
5741      MarkFunctionReferenced(Location, Dtor);
5742      DiagnoseUseOfDecl(Dtor, Location);
5743    }
5744  
5745    // We only potentially invoke the destructors of potentially constructed
5746    // subobjects.
5747    bool VisitVirtualBases = !ClassDecl->isAbstract();
5748  
5749    // If the destructor exists and has already been marked used in the MS ABI,
5750    // then virtual base destructors have already been checked and marked used.
5751    // Skip checking them again to avoid duplicate diagnostics.
5752    if (Context.getTargetInfo().getCXXABI().isMicrosoft()) {
5753      CXXDestructorDecl *Dtor = ClassDecl->getDestructor();
5754      if (Dtor && Dtor->isUsed())
5755        VisitVirtualBases = false;
5756    }
5757  
5758    llvm::SmallPtrSet<const RecordType *, 8> DirectVirtualBases;
5759  
5760    // Bases.
5761    for (const auto &Base : ClassDecl->bases()) {
5762      const RecordType *RT = Base.getType()->getAs<RecordType>();
5763      if (!RT)
5764        continue;
5765  
5766      // Remember direct virtual bases.
5767      if (Base.isVirtual()) {
5768        if (!VisitVirtualBases)
5769          continue;
5770        DirectVirtualBases.insert(RT);
5771      }
5772  
5773      CXXRecordDecl *BaseClassDecl = cast<CXXRecordDecl>(RT->getDecl());
5774      // If our base class is invalid, we probably can't get its dtor anyway.
5775      if (BaseClassDecl->isInvalidDecl())
5776        continue;
5777      if (BaseClassDecl->hasIrrelevantDestructor())
5778        continue;
5779  
5780      CXXDestructorDecl *Dtor = LookupDestructor(BaseClassDecl);
5781      // Dtor might still be missing, e.g because it's invalid.
5782      if (!Dtor)
5783        continue;
5784  
5785      // FIXME: caret should be on the start of the class name
5786      CheckDestructorAccess(Base.getBeginLoc(), Dtor,
5787                            PDiag(diag::err_access_dtor_base)
5788                                << Base.getType() << Base.getSourceRange(),
5789                            Context.getTypeDeclType(ClassDecl));
5790  
5791      MarkFunctionReferenced(Location, Dtor);
5792      DiagnoseUseOfDecl(Dtor, Location);
5793    }
5794  
5795    if (VisitVirtualBases)
5796      MarkVirtualBaseDestructorsReferenced(Location, ClassDecl,
5797                                           &DirectVirtualBases);
5798  }
5799  
5800  void Sema::MarkVirtualBaseDestructorsReferenced(
5801      SourceLocation Location, CXXRecordDecl *ClassDecl,
5802      llvm::SmallPtrSetImpl<const RecordType *> *DirectVirtualBases) {
5803    // Virtual bases.
5804    for (const auto &VBase : ClassDecl->vbases()) {
5805      // Bases are always records in a well-formed non-dependent class.
5806      const RecordType *RT = VBase.getType()->castAs<RecordType>();
5807  
5808      // Ignore already visited direct virtual bases.
5809      if (DirectVirtualBases && DirectVirtualBases->count(RT))
5810        continue;
5811  
5812      CXXRecordDecl *BaseClassDecl = cast<CXXRecordDecl>(RT->getDecl());
5813      // If our base class is invalid, we probably can't get its dtor anyway.
5814      if (BaseClassDecl->isInvalidDecl())
5815        continue;
5816      if (BaseClassDecl->hasIrrelevantDestructor())
5817        continue;
5818  
5819      CXXDestructorDecl *Dtor = LookupDestructor(BaseClassDecl);
5820      // Dtor might still be missing, e.g because it's invalid.
5821      if (!Dtor)
5822        continue;
5823      if (CheckDestructorAccess(
5824              ClassDecl->getLocation(), Dtor,
5825              PDiag(diag::err_access_dtor_vbase)
5826                  << Context.getTypeDeclType(ClassDecl) << VBase.getType(),
5827              Context.getTypeDeclType(ClassDecl)) ==
5828          AR_accessible) {
5829        CheckDerivedToBaseConversion(
5830            Context.getTypeDeclType(ClassDecl), VBase.getType(),
5831            diag::err_access_dtor_vbase, 0, ClassDecl->getLocation(),
5832            SourceRange(), DeclarationName(), nullptr);
5833      }
5834  
5835      MarkFunctionReferenced(Location, Dtor);
5836      DiagnoseUseOfDecl(Dtor, Location);
5837    }
5838  }
5839  
5840  void Sema::ActOnDefaultCtorInitializers(Decl *CDtorDecl) {
5841    if (!CDtorDecl)
5842      return;
5843  
5844    if (CXXConstructorDecl *Constructor
5845        = dyn_cast<CXXConstructorDecl>(CDtorDecl)) {
5846      if (CXXRecordDecl *ClassDecl = Constructor->getParent();
5847          !ClassDecl || ClassDecl->isInvalidDecl()) {
5848        return;
5849      }
5850      SetCtorInitializers(Constructor, /*AnyErrors=*/false);
5851      DiagnoseUninitializedFields(*this, Constructor);
5852    }
5853  }
5854  
5855  bool Sema::isAbstractType(SourceLocation Loc, QualType T) {
5856    if (!getLangOpts().CPlusPlus)
5857      return false;
5858  
5859    const auto *RD = Context.getBaseElementType(T)->getAsCXXRecordDecl();
5860    if (!RD)
5861      return false;
5862  
5863    // FIXME: Per [temp.inst]p1, we are supposed to trigger instantiation of a
5864    // class template specialization here, but doing so breaks a lot of code.
5865  
5866    // We can't answer whether something is abstract until it has a
5867    // definition. If it's currently being defined, we'll walk back
5868    // over all the declarations when we have a full definition.
5869    const CXXRecordDecl *Def = RD->getDefinition();
5870    if (!Def || Def->isBeingDefined())
5871      return false;
5872  
5873    return RD->isAbstract();
5874  }
5875  
5876  bool Sema::RequireNonAbstractType(SourceLocation Loc, QualType T,
5877                                    TypeDiagnoser &Diagnoser) {
5878    if (!isAbstractType(Loc, T))
5879      return false;
5880  
5881    T = Context.getBaseElementType(T);
5882    Diagnoser.diagnose(*this, Loc, T);
5883    DiagnoseAbstractType(T->getAsCXXRecordDecl());
5884    return true;
5885  }
5886  
5887  void Sema::DiagnoseAbstractType(const CXXRecordDecl *RD) {
5888    // Check if we've already emitted the list of pure virtual functions
5889    // for this class.
5890    if (PureVirtualClassDiagSet && PureVirtualClassDiagSet->count(RD))
5891      return;
5892  
5893    // If the diagnostic is suppressed, don't emit the notes. We're only
5894    // going to emit them once, so try to attach them to a diagnostic we're
5895    // actually going to show.
5896    if (Diags.isLastDiagnosticIgnored())
5897      return;
5898  
5899    CXXFinalOverriderMap FinalOverriders;
5900    RD->getFinalOverriders(FinalOverriders);
5901  
5902    // Keep a set of seen pure methods so we won't diagnose the same method
5903    // more than once.
5904    llvm::SmallPtrSet<const CXXMethodDecl *, 8> SeenPureMethods;
5905  
5906    for (CXXFinalOverriderMap::iterator M = FinalOverriders.begin(),
5907                                     MEnd = FinalOverriders.end();
5908         M != MEnd;
5909         ++M) {
5910      for (OverridingMethods::iterator SO = M->second.begin(),
5911                                    SOEnd = M->second.end();
5912           SO != SOEnd; ++SO) {
5913        // C++ [class.abstract]p4:
5914        //   A class is abstract if it contains or inherits at least one
5915        //   pure virtual function for which the final overrider is pure
5916        //   virtual.
5917  
5918        //
5919        if (SO->second.size() != 1)
5920          continue;
5921  
5922        if (!SO->second.front().Method->isPureVirtual())
5923          continue;
5924  
5925        if (!SeenPureMethods.insert(SO->second.front().Method).second)
5926          continue;
5927  
5928        Diag(SO->second.front().Method->getLocation(),
5929             diag::note_pure_virtual_function)
5930          << SO->second.front().Method->getDeclName() << RD->getDeclName();
5931      }
5932    }
5933  
5934    if (!PureVirtualClassDiagSet)
5935      PureVirtualClassDiagSet.reset(new RecordDeclSetTy);
5936    PureVirtualClassDiagSet->insert(RD);
5937  }
5938  
5939  namespace {
5940  struct AbstractUsageInfo {
5941    Sema &S;
5942    CXXRecordDecl *Record;
5943    CanQualType AbstractType;
5944    bool Invalid;
5945  
5946    AbstractUsageInfo(Sema &S, CXXRecordDecl *Record)
5947      : S(S), Record(Record),
5948        AbstractType(S.Context.getCanonicalType(
5949                     S.Context.getTypeDeclType(Record))),
5950        Invalid(false) {}
5951  
5952    void DiagnoseAbstractType() {
5953      if (Invalid) return;
5954      S.DiagnoseAbstractType(Record);
5955      Invalid = true;
5956    }
5957  
5958    void CheckType(const NamedDecl *D, TypeLoc TL, Sema::AbstractDiagSelID Sel);
5959  };
5960  
5961  struct CheckAbstractUsage {
5962    AbstractUsageInfo &Info;
5963    const NamedDecl *Ctx;
5964  
5965    CheckAbstractUsage(AbstractUsageInfo &Info, const NamedDecl *Ctx)
5966      : Info(Info), Ctx(Ctx) {}
5967  
5968    void Visit(TypeLoc TL, Sema::AbstractDiagSelID Sel) {
5969      switch (TL.getTypeLocClass()) {
5970  #define ABSTRACT_TYPELOC(CLASS, PARENT)
5971  #define TYPELOC(CLASS, PARENT) \
5972      case TypeLoc::CLASS: Check(TL.castAs<CLASS##TypeLoc>(), Sel); break;
5973  #include "clang/AST/TypeLocNodes.def"
5974      }
5975    }
5976  
5977    void Check(FunctionProtoTypeLoc TL, Sema::AbstractDiagSelID Sel) {
5978      Visit(TL.getReturnLoc(), Sema::AbstractReturnType);
5979      for (unsigned I = 0, E = TL.getNumParams(); I != E; ++I) {
5980        if (!TL.getParam(I))
5981          continue;
5982  
5983        TypeSourceInfo *TSI = TL.getParam(I)->getTypeSourceInfo();
5984        if (TSI) Visit(TSI->getTypeLoc(), Sema::AbstractParamType);
5985      }
5986    }
5987  
5988    void Check(ArrayTypeLoc TL, Sema::AbstractDiagSelID Sel) {
5989      Visit(TL.getElementLoc(), Sema::AbstractArrayType);
5990    }
5991  
5992    void Check(TemplateSpecializationTypeLoc TL, Sema::AbstractDiagSelID Sel) {
5993      // Visit the type parameters from a permissive context.
5994      for (unsigned I = 0, E = TL.getNumArgs(); I != E; ++I) {
5995        TemplateArgumentLoc TAL = TL.getArgLoc(I);
5996        if (TAL.getArgument().getKind() == TemplateArgument::Type)
5997          if (TypeSourceInfo *TSI = TAL.getTypeSourceInfo())
5998            Visit(TSI->getTypeLoc(), Sema::AbstractNone);
5999        // TODO: other template argument types?
6000      }
6001    }
6002  
6003    // Visit pointee types from a permissive context.
6004  #define CheckPolymorphic(Type) \
6005    void Check(Type TL, Sema::AbstractDiagSelID Sel) { \
6006      Visit(TL.getNextTypeLoc(), Sema::AbstractNone); \
6007    }
6008    CheckPolymorphic(PointerTypeLoc)
6009    CheckPolymorphic(ReferenceTypeLoc)
6010    CheckPolymorphic(MemberPointerTypeLoc)
6011    CheckPolymorphic(BlockPointerTypeLoc)
6012    CheckPolymorphic(AtomicTypeLoc)
6013  
6014    /// Handle all the types we haven't given a more specific
6015    /// implementation for above.
6016    void Check(TypeLoc TL, Sema::AbstractDiagSelID Sel) {
6017      // Every other kind of type that we haven't called out already
6018      // that has an inner type is either (1) sugar or (2) contains that
6019      // inner type in some way as a subobject.
6020      if (TypeLoc Next = TL.getNextTypeLoc())
6021        return Visit(Next, Sel);
6022  
6023      // If there's no inner type and we're in a permissive context,
6024      // don't diagnose.
6025      if (Sel == Sema::AbstractNone) return;
6026  
6027      // Check whether the type matches the abstract type.
6028      QualType T = TL.getType();
6029      if (T->isArrayType()) {
6030        Sel = Sema::AbstractArrayType;
6031        T = Info.S.Context.getBaseElementType(T);
6032      }
6033      CanQualType CT = T->getCanonicalTypeUnqualified().getUnqualifiedType();
6034      if (CT != Info.AbstractType) return;
6035  
6036      // It matched; do some magic.
6037      // FIXME: These should be at most warnings. See P0929R2, CWG1640, CWG1646.
6038      if (Sel == Sema::AbstractArrayType) {
6039        Info.S.Diag(Ctx->getLocation(), diag::err_array_of_abstract_type)
6040          << T << TL.getSourceRange();
6041      } else {
6042        Info.S.Diag(Ctx->getLocation(), diag::err_abstract_type_in_decl)
6043          << Sel << T << TL.getSourceRange();
6044      }
6045      Info.DiagnoseAbstractType();
6046    }
6047  };
6048  
6049  void AbstractUsageInfo::CheckType(const NamedDecl *D, TypeLoc TL,
6050                                    Sema::AbstractDiagSelID Sel) {
6051    CheckAbstractUsage(*this, D).Visit(TL, Sel);
6052  }
6053  
6054  }
6055  
6056  /// Check for invalid uses of an abstract type in a function declaration.
6057  static void CheckAbstractClassUsage(AbstractUsageInfo &Info,
6058                                      FunctionDecl *FD) {
6059    // Only definitions are required to refer to complete and
6060    // non-abstract types.
6061    if (!FD->doesThisDeclarationHaveABody())
6062      return;
6063  
6064    // For safety's sake, just ignore it if we don't have type source
6065    // information.  This should never happen for non-implicit methods,
6066    // but...
6067    if (TypeSourceInfo *TSI = FD->getTypeSourceInfo())
6068      Info.CheckType(FD, TSI->getTypeLoc(), Sema::AbstractNone);
6069  }
6070  
6071  /// Check for invalid uses of an abstract type in a variable0 declaration.
6072  static void CheckAbstractClassUsage(AbstractUsageInfo &Info,
6073                                      VarDecl *VD) {
6074    // No need to do the check on definitions, which require that
6075    // the type is complete.
6076    if (VD->isThisDeclarationADefinition())
6077      return;
6078  
6079    Info.CheckType(VD, VD->getTypeSourceInfo()->getTypeLoc(),
6080                   Sema::AbstractVariableType);
6081  }
6082  
6083  /// Check for invalid uses of an abstract type within a class definition.
6084  static void CheckAbstractClassUsage(AbstractUsageInfo &Info,
6085                                      CXXRecordDecl *RD) {
6086    for (auto *D : RD->decls()) {
6087      if (D->isImplicit()) continue;
6088  
6089      // Step through friends to the befriended declaration.
6090      if (auto *FD = dyn_cast<FriendDecl>(D)) {
6091        D = FD->getFriendDecl();
6092        if (!D) continue;
6093      }
6094  
6095      // Functions and function templates.
6096      if (auto *FD = dyn_cast<FunctionDecl>(D)) {
6097        CheckAbstractClassUsage(Info, FD);
6098      } else if (auto *FTD = dyn_cast<FunctionTemplateDecl>(D)) {
6099        CheckAbstractClassUsage(Info, FTD->getTemplatedDecl());
6100  
6101      // Fields and static variables.
6102      } else if (auto *FD = dyn_cast<FieldDecl>(D)) {
6103        if (TypeSourceInfo *TSI = FD->getTypeSourceInfo())
6104          Info.CheckType(FD, TSI->getTypeLoc(), Sema::AbstractFieldType);
6105      } else if (auto *VD = dyn_cast<VarDecl>(D)) {
6106        CheckAbstractClassUsage(Info, VD);
6107      } else if (auto *VTD = dyn_cast<VarTemplateDecl>(D)) {
6108        CheckAbstractClassUsage(Info, VTD->getTemplatedDecl());
6109  
6110      // Nested classes and class templates.
6111      } else if (auto *RD = dyn_cast<CXXRecordDecl>(D)) {
6112        CheckAbstractClassUsage(Info, RD);
6113      } else if (auto *CTD = dyn_cast<ClassTemplateDecl>(D)) {
6114        CheckAbstractClassUsage(Info, CTD->getTemplatedDecl());
6115      }
6116    }
6117  }
6118  
6119  static void ReferenceDllExportedMembers(Sema &S, CXXRecordDecl *Class) {
6120    Attr *ClassAttr = getDLLAttr(Class);
6121    if (!ClassAttr)
6122      return;
6123  
6124    assert(ClassAttr->getKind() == attr::DLLExport);
6125  
6126    TemplateSpecializationKind TSK = Class->getTemplateSpecializationKind();
6127  
6128    if (TSK == TSK_ExplicitInstantiationDeclaration)
6129      // Don't go any further if this is just an explicit instantiation
6130      // declaration.
6131      return;
6132  
6133    // Add a context note to explain how we got to any diagnostics produced below.
6134    struct MarkingClassDllexported {
6135      Sema &S;
6136      MarkingClassDllexported(Sema &S, CXXRecordDecl *Class,
6137                              SourceLocation AttrLoc)
6138          : S(S) {
6139        Sema::CodeSynthesisContext Ctx;
6140        Ctx.Kind = Sema::CodeSynthesisContext::MarkingClassDllexported;
6141        Ctx.PointOfInstantiation = AttrLoc;
6142        Ctx.Entity = Class;
6143        S.pushCodeSynthesisContext(Ctx);
6144      }
6145      ~MarkingClassDllexported() {
6146        S.popCodeSynthesisContext();
6147      }
6148    } MarkingDllexportedContext(S, Class, ClassAttr->getLocation());
6149  
6150    if (S.Context.getTargetInfo().getTriple().isWindowsGNUEnvironment())
6151      S.MarkVTableUsed(Class->getLocation(), Class, true);
6152  
6153    for (Decl *Member : Class->decls()) {
6154      // Skip members that were not marked exported.
6155      if (!Member->hasAttr<DLLExportAttr>())
6156        continue;
6157  
6158      // Defined static variables that are members of an exported base
6159      // class must be marked export too.
6160      auto *VD = dyn_cast<VarDecl>(Member);
6161      if (VD && VD->getStorageClass() == SC_Static &&
6162          TSK == TSK_ImplicitInstantiation)
6163        S.MarkVariableReferenced(VD->getLocation(), VD);
6164  
6165      auto *MD = dyn_cast<CXXMethodDecl>(Member);
6166      if (!MD)
6167        continue;
6168  
6169      if (MD->isUserProvided()) {
6170        // Instantiate non-default class member functions ...
6171  
6172        // .. except for certain kinds of template specializations.
6173        if (TSK == TSK_ImplicitInstantiation && !ClassAttr->isInherited())
6174          continue;
6175  
6176        // If this is an MS ABI dllexport default constructor, instantiate any
6177        // default arguments.
6178        if (S.Context.getTargetInfo().getCXXABI().isMicrosoft()) {
6179          auto *CD = dyn_cast<CXXConstructorDecl>(MD);
6180          if (CD && CD->isDefaultConstructor() && TSK == TSK_Undeclared) {
6181            S.InstantiateDefaultCtorDefaultArgs(CD);
6182          }
6183        }
6184  
6185        S.MarkFunctionReferenced(Class->getLocation(), MD);
6186  
6187        // The function will be passed to the consumer when its definition is
6188        // encountered.
6189      } else if (MD->isExplicitlyDefaulted()) {
6190        // Synthesize and instantiate explicitly defaulted methods.
6191        S.MarkFunctionReferenced(Class->getLocation(), MD);
6192  
6193        if (TSK != TSK_ExplicitInstantiationDefinition) {
6194          // Except for explicit instantiation defs, we will not see the
6195          // definition again later, so pass it to the consumer now.
6196          S.Consumer.HandleTopLevelDecl(DeclGroupRef(MD));
6197        }
6198      } else if (!MD->isTrivial() ||
6199                 MD->isCopyAssignmentOperator() ||
6200                 MD->isMoveAssignmentOperator()) {
6201        // Synthesize and instantiate non-trivial implicit methods, and the copy
6202        // and move assignment operators. The latter are exported even if they
6203        // are trivial, because the address of an operator can be taken and
6204        // should compare equal across libraries.
6205        S.MarkFunctionReferenced(Class->getLocation(), MD);
6206  
6207        // There is no later point when we will see the definition of this
6208        // function, so pass it to the consumer now.
6209        S.Consumer.HandleTopLevelDecl(DeclGroupRef(MD));
6210      }
6211    }
6212  }
6213  
6214  static void checkForMultipleExportedDefaultConstructors(Sema &S,
6215                                                          CXXRecordDecl *Class) {
6216    // Only the MS ABI has default constructor closures, so we don't need to do
6217    // this semantic checking anywhere else.
6218    if (!S.Context.getTargetInfo().getCXXABI().isMicrosoft())
6219      return;
6220  
6221    CXXConstructorDecl *LastExportedDefaultCtor = nullptr;
6222    for (Decl *Member : Class->decls()) {
6223      // Look for exported default constructors.
6224      auto *CD = dyn_cast<CXXConstructorDecl>(Member);
6225      if (!CD || !CD->isDefaultConstructor())
6226        continue;
6227      auto *Attr = CD->getAttr<DLLExportAttr>();
6228      if (!Attr)
6229        continue;
6230  
6231      // If the class is non-dependent, mark the default arguments as ODR-used so
6232      // that we can properly codegen the constructor closure.
6233      if (!Class->isDependentContext()) {
6234        for (ParmVarDecl *PD : CD->parameters()) {
6235          (void)S.CheckCXXDefaultArgExpr(Attr->getLocation(), CD, PD);
6236          S.DiscardCleanupsInEvaluationContext();
6237        }
6238      }
6239  
6240      if (LastExportedDefaultCtor) {
6241        S.Diag(LastExportedDefaultCtor->getLocation(),
6242               diag::err_attribute_dll_ambiguous_default_ctor)
6243            << Class;
6244        S.Diag(CD->getLocation(), diag::note_entity_declared_at)
6245            << CD->getDeclName();
6246        return;
6247      }
6248      LastExportedDefaultCtor = CD;
6249    }
6250  }
6251  
6252  static void checkCUDADeviceBuiltinSurfaceClassTemplate(Sema &S,
6253                                                         CXXRecordDecl *Class) {
6254    bool ErrorReported = false;
6255    auto reportIllegalClassTemplate = [&ErrorReported](Sema &S,
6256                                                       ClassTemplateDecl *TD) {
6257      if (ErrorReported)
6258        return;
6259      S.Diag(TD->getLocation(),
6260             diag::err_cuda_device_builtin_surftex_cls_template)
6261          << /*surface*/ 0 << TD;
6262      ErrorReported = true;
6263    };
6264  
6265    ClassTemplateDecl *TD = Class->getDescribedClassTemplate();
6266    if (!TD) {
6267      auto *SD = dyn_cast<ClassTemplateSpecializationDecl>(Class);
6268      if (!SD) {
6269        S.Diag(Class->getLocation(),
6270               diag::err_cuda_device_builtin_surftex_ref_decl)
6271            << /*surface*/ 0 << Class;
6272        S.Diag(Class->getLocation(),
6273               diag::note_cuda_device_builtin_surftex_should_be_template_class)
6274            << Class;
6275        return;
6276      }
6277      TD = SD->getSpecializedTemplate();
6278    }
6279  
6280    TemplateParameterList *Params = TD->getTemplateParameters();
6281    unsigned N = Params->size();
6282  
6283    if (N != 2) {
6284      reportIllegalClassTemplate(S, TD);
6285      S.Diag(TD->getLocation(),
6286             diag::note_cuda_device_builtin_surftex_cls_should_have_n_args)
6287          << TD << 2;
6288    }
6289    if (N > 0 && !isa<TemplateTypeParmDecl>(Params->getParam(0))) {
6290      reportIllegalClassTemplate(S, TD);
6291      S.Diag(TD->getLocation(),
6292             diag::note_cuda_device_builtin_surftex_cls_should_have_match_arg)
6293          << TD << /*1st*/ 0 << /*type*/ 0;
6294    }
6295    if (N > 1) {
6296      auto *NTTP = dyn_cast<NonTypeTemplateParmDecl>(Params->getParam(1));
6297      if (!NTTP || !NTTP->getType()->isIntegralOrEnumerationType()) {
6298        reportIllegalClassTemplate(S, TD);
6299        S.Diag(TD->getLocation(),
6300               diag::note_cuda_device_builtin_surftex_cls_should_have_match_arg)
6301            << TD << /*2nd*/ 1 << /*integer*/ 1;
6302      }
6303    }
6304  }
6305  
6306  static void checkCUDADeviceBuiltinTextureClassTemplate(Sema &S,
6307                                                         CXXRecordDecl *Class) {
6308    bool ErrorReported = false;
6309    auto reportIllegalClassTemplate = [&ErrorReported](Sema &S,
6310                                                       ClassTemplateDecl *TD) {
6311      if (ErrorReported)
6312        return;
6313      S.Diag(TD->getLocation(),
6314             diag::err_cuda_device_builtin_surftex_cls_template)
6315          << /*texture*/ 1 << TD;
6316      ErrorReported = true;
6317    };
6318  
6319    ClassTemplateDecl *TD = Class->getDescribedClassTemplate();
6320    if (!TD) {
6321      auto *SD = dyn_cast<ClassTemplateSpecializationDecl>(Class);
6322      if (!SD) {
6323        S.Diag(Class->getLocation(),
6324               diag::err_cuda_device_builtin_surftex_ref_decl)
6325            << /*texture*/ 1 << Class;
6326        S.Diag(Class->getLocation(),
6327               diag::note_cuda_device_builtin_surftex_should_be_template_class)
6328            << Class;
6329        return;
6330      }
6331      TD = SD->getSpecializedTemplate();
6332    }
6333  
6334    TemplateParameterList *Params = TD->getTemplateParameters();
6335    unsigned N = Params->size();
6336  
6337    if (N != 3) {
6338      reportIllegalClassTemplate(S, TD);
6339      S.Diag(TD->getLocation(),
6340             diag::note_cuda_device_builtin_surftex_cls_should_have_n_args)
6341          << TD << 3;
6342    }
6343    if (N > 0 && !isa<TemplateTypeParmDecl>(Params->getParam(0))) {
6344      reportIllegalClassTemplate(S, TD);
6345      S.Diag(TD->getLocation(),
6346             diag::note_cuda_device_builtin_surftex_cls_should_have_match_arg)
6347          << TD << /*1st*/ 0 << /*type*/ 0;
6348    }
6349    if (N > 1) {
6350      auto *NTTP = dyn_cast<NonTypeTemplateParmDecl>(Params->getParam(1));
6351      if (!NTTP || !NTTP->getType()->isIntegralOrEnumerationType()) {
6352        reportIllegalClassTemplate(S, TD);
6353        S.Diag(TD->getLocation(),
6354               diag::note_cuda_device_builtin_surftex_cls_should_have_match_arg)
6355            << TD << /*2nd*/ 1 << /*integer*/ 1;
6356      }
6357    }
6358    if (N > 2) {
6359      auto *NTTP = dyn_cast<NonTypeTemplateParmDecl>(Params->getParam(2));
6360      if (!NTTP || !NTTP->getType()->isIntegralOrEnumerationType()) {
6361        reportIllegalClassTemplate(S, TD);
6362        S.Diag(TD->getLocation(),
6363               diag::note_cuda_device_builtin_surftex_cls_should_have_match_arg)
6364            << TD << /*3rd*/ 2 << /*integer*/ 1;
6365      }
6366    }
6367  }
6368  
6369  void Sema::checkClassLevelCodeSegAttribute(CXXRecordDecl *Class) {
6370    // Mark any compiler-generated routines with the implicit code_seg attribute.
6371    for (auto *Method : Class->methods()) {
6372      if (Method->isUserProvided())
6373        continue;
6374      if (Attr *A = getImplicitCodeSegOrSectionAttrForFunction(Method, /*IsDefinition=*/true))
6375        Method->addAttr(A);
6376    }
6377  }
6378  
6379  void Sema::checkClassLevelDLLAttribute(CXXRecordDecl *Class) {
6380    Attr *ClassAttr = getDLLAttr(Class);
6381  
6382    // MSVC inherits DLL attributes to partial class template specializations.
6383    if (Context.getTargetInfo().shouldDLLImportComdatSymbols() && !ClassAttr) {
6384      if (auto *Spec = dyn_cast<ClassTemplatePartialSpecializationDecl>(Class)) {
6385        if (Attr *TemplateAttr =
6386                getDLLAttr(Spec->getSpecializedTemplate()->getTemplatedDecl())) {
6387          auto *A = cast<InheritableAttr>(TemplateAttr->clone(getASTContext()));
6388          A->setInherited(true);
6389          ClassAttr = A;
6390        }
6391      }
6392    }
6393  
6394    if (!ClassAttr)
6395      return;
6396  
6397    // MSVC allows imported or exported template classes that have UniqueExternal
6398    // linkage. This occurs when the template class has been instantiated with
6399    // a template parameter which itself has internal linkage.
6400    // We drop the attribute to avoid exporting or importing any members.
6401    if ((Context.getTargetInfo().getCXXABI().isMicrosoft() ||
6402         Context.getTargetInfo().getTriple().isPS()) &&
6403        (!Class->isExternallyVisible() && Class->hasExternalFormalLinkage())) {
6404      Class->dropAttrs<DLLExportAttr, DLLImportAttr>();
6405      return;
6406    }
6407  
6408    if (!Class->isExternallyVisible()) {
6409      Diag(Class->getLocation(), diag::err_attribute_dll_not_extern)
6410          << Class << ClassAttr;
6411      return;
6412    }
6413  
6414    if (Context.getTargetInfo().shouldDLLImportComdatSymbols() &&
6415        !ClassAttr->isInherited()) {
6416      // Diagnose dll attributes on members of class with dll attribute.
6417      for (Decl *Member : Class->decls()) {
6418        if (!isa<VarDecl>(Member) && !isa<CXXMethodDecl>(Member))
6419          continue;
6420        InheritableAttr *MemberAttr = getDLLAttr(Member);
6421        if (!MemberAttr || MemberAttr->isInherited() || Member->isInvalidDecl())
6422          continue;
6423  
6424        Diag(MemberAttr->getLocation(),
6425               diag::err_attribute_dll_member_of_dll_class)
6426            << MemberAttr << ClassAttr;
6427        Diag(ClassAttr->getLocation(), diag::note_previous_attribute);
6428        Member->setInvalidDecl();
6429      }
6430    }
6431  
6432    if (Class->getDescribedClassTemplate())
6433      // Don't inherit dll attribute until the template is instantiated.
6434      return;
6435  
6436    // The class is either imported or exported.
6437    const bool ClassExported = ClassAttr->getKind() == attr::DLLExport;
6438  
6439    // Check if this was a dllimport attribute propagated from a derived class to
6440    // a base class template specialization. We don't apply these attributes to
6441    // static data members.
6442    const bool PropagatedImport =
6443        !ClassExported &&
6444        cast<DLLImportAttr>(ClassAttr)->wasPropagatedToBaseTemplate();
6445  
6446    TemplateSpecializationKind TSK = Class->getTemplateSpecializationKind();
6447  
6448    // Ignore explicit dllexport on explicit class template instantiation
6449    // declarations, except in MinGW mode.
6450    if (ClassExported && !ClassAttr->isInherited() &&
6451        TSK == TSK_ExplicitInstantiationDeclaration &&
6452        !Context.getTargetInfo().getTriple().isWindowsGNUEnvironment()) {
6453      Class->dropAttr<DLLExportAttr>();
6454      return;
6455    }
6456  
6457    // Force declaration of implicit members so they can inherit the attribute.
6458    ForceDeclarationOfImplicitMembers(Class);
6459  
6460    // FIXME: MSVC's docs say all bases must be exportable, but this doesn't
6461    // seem to be true in practice?
6462  
6463    for (Decl *Member : Class->decls()) {
6464      VarDecl *VD = dyn_cast<VarDecl>(Member);
6465      CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(Member);
6466  
6467      // Only methods and static fields inherit the attributes.
6468      if (!VD && !MD)
6469        continue;
6470  
6471      if (MD) {
6472        // Don't process deleted methods.
6473        if (MD->isDeleted())
6474          continue;
6475  
6476        if (MD->isInlined()) {
6477          // MinGW does not import or export inline methods. But do it for
6478          // template instantiations.
6479          if (!Context.getTargetInfo().shouldDLLImportComdatSymbols() &&
6480              TSK != TSK_ExplicitInstantiationDeclaration &&
6481              TSK != TSK_ExplicitInstantiationDefinition)
6482            continue;
6483  
6484          // MSVC versions before 2015 don't export the move assignment operators
6485          // and move constructor, so don't attempt to import/export them if
6486          // we have a definition.
6487          auto *Ctor = dyn_cast<CXXConstructorDecl>(MD);
6488          if ((MD->isMoveAssignmentOperator() ||
6489               (Ctor && Ctor->isMoveConstructor())) &&
6490              !getLangOpts().isCompatibleWithMSVC(LangOptions::MSVC2015))
6491            continue;
6492  
6493          // MSVC2015 doesn't export trivial defaulted x-tor but copy assign
6494          // operator is exported anyway.
6495          if (getLangOpts().isCompatibleWithMSVC(LangOptions::MSVC2015) &&
6496              (Ctor || isa<CXXDestructorDecl>(MD)) && MD->isTrivial())
6497            continue;
6498        }
6499      }
6500  
6501      // Don't apply dllimport attributes to static data members of class template
6502      // instantiations when the attribute is propagated from a derived class.
6503      if (VD && PropagatedImport)
6504        continue;
6505  
6506      if (!cast<NamedDecl>(Member)->isExternallyVisible())
6507        continue;
6508  
6509      if (!getDLLAttr(Member)) {
6510        InheritableAttr *NewAttr = nullptr;
6511  
6512        // Do not export/import inline function when -fno-dllexport-inlines is
6513        // passed. But add attribute for later local static var check.
6514        if (!getLangOpts().DllExportInlines && MD && MD->isInlined() &&
6515            TSK != TSK_ExplicitInstantiationDeclaration &&
6516            TSK != TSK_ExplicitInstantiationDefinition) {
6517          if (ClassExported) {
6518            NewAttr = ::new (getASTContext())
6519                DLLExportStaticLocalAttr(getASTContext(), *ClassAttr);
6520          } else {
6521            NewAttr = ::new (getASTContext())
6522                DLLImportStaticLocalAttr(getASTContext(), *ClassAttr);
6523          }
6524        } else {
6525          NewAttr = cast<InheritableAttr>(ClassAttr->clone(getASTContext()));
6526        }
6527  
6528        NewAttr->setInherited(true);
6529        Member->addAttr(NewAttr);
6530  
6531        if (MD) {
6532          // Propagate DLLAttr to friend re-declarations of MD that have already
6533          // been constructed.
6534          for (FunctionDecl *FD = MD->getMostRecentDecl(); FD;
6535               FD = FD->getPreviousDecl()) {
6536            if (FD->getFriendObjectKind() == Decl::FOK_None)
6537              continue;
6538            assert(!getDLLAttr(FD) &&
6539                   "friend re-decl should not already have a DLLAttr");
6540            NewAttr = cast<InheritableAttr>(ClassAttr->clone(getASTContext()));
6541            NewAttr->setInherited(true);
6542            FD->addAttr(NewAttr);
6543          }
6544        }
6545      }
6546    }
6547  
6548    if (ClassExported)
6549      DelayedDllExportClasses.push_back(Class);
6550  }
6551  
6552  void Sema::propagateDLLAttrToBaseClassTemplate(
6553      CXXRecordDecl *Class, Attr *ClassAttr,
6554      ClassTemplateSpecializationDecl *BaseTemplateSpec, SourceLocation BaseLoc) {
6555    if (getDLLAttr(
6556            BaseTemplateSpec->getSpecializedTemplate()->getTemplatedDecl())) {
6557      // If the base class template has a DLL attribute, don't try to change it.
6558      return;
6559    }
6560  
6561    auto TSK = BaseTemplateSpec->getSpecializationKind();
6562    if (!getDLLAttr(BaseTemplateSpec) &&
6563        (TSK == TSK_Undeclared || TSK == TSK_ExplicitInstantiationDeclaration ||
6564         TSK == TSK_ImplicitInstantiation)) {
6565      // The template hasn't been instantiated yet (or it has, but only as an
6566      // explicit instantiation declaration or implicit instantiation, which means
6567      // we haven't codegenned any members yet), so propagate the attribute.
6568      auto *NewAttr = cast<InheritableAttr>(ClassAttr->clone(getASTContext()));
6569      NewAttr->setInherited(true);
6570      BaseTemplateSpec->addAttr(NewAttr);
6571  
6572      // If this was an import, mark that we propagated it from a derived class to
6573      // a base class template specialization.
6574      if (auto *ImportAttr = dyn_cast<DLLImportAttr>(NewAttr))
6575        ImportAttr->setPropagatedToBaseTemplate();
6576  
6577      // If the template is already instantiated, checkDLLAttributeRedeclaration()
6578      // needs to be run again to work see the new attribute. Otherwise this will
6579      // get run whenever the template is instantiated.
6580      if (TSK != TSK_Undeclared)
6581        checkClassLevelDLLAttribute(BaseTemplateSpec);
6582  
6583      return;
6584    }
6585  
6586    if (getDLLAttr(BaseTemplateSpec)) {
6587      // The template has already been specialized or instantiated with an
6588      // attribute, explicitly or through propagation. We should not try to change
6589      // it.
6590      return;
6591    }
6592  
6593    // The template was previously instantiated or explicitly specialized without
6594    // a dll attribute, It's too late for us to add an attribute, so warn that
6595    // this is unsupported.
6596    Diag(BaseLoc, diag::warn_attribute_dll_instantiated_base_class)
6597        << BaseTemplateSpec->isExplicitSpecialization();
6598    Diag(ClassAttr->getLocation(), diag::note_attribute);
6599    if (BaseTemplateSpec->isExplicitSpecialization()) {
6600      Diag(BaseTemplateSpec->getLocation(),
6601             diag::note_template_class_explicit_specialization_was_here)
6602          << BaseTemplateSpec;
6603    } else {
6604      Diag(BaseTemplateSpec->getPointOfInstantiation(),
6605             diag::note_template_class_instantiation_was_here)
6606          << BaseTemplateSpec;
6607    }
6608  }
6609  
6610  Sema::DefaultedFunctionKind
6611  Sema::getDefaultedFunctionKind(const FunctionDecl *FD) {
6612    if (auto *MD = dyn_cast<CXXMethodDecl>(FD)) {
6613      if (const CXXConstructorDecl *Ctor = dyn_cast<CXXConstructorDecl>(FD)) {
6614        if (Ctor->isDefaultConstructor())
6615          return CXXSpecialMemberKind::DefaultConstructor;
6616  
6617        if (Ctor->isCopyConstructor())
6618          return CXXSpecialMemberKind::CopyConstructor;
6619  
6620        if (Ctor->isMoveConstructor())
6621          return CXXSpecialMemberKind::MoveConstructor;
6622      }
6623  
6624      if (MD->isCopyAssignmentOperator())
6625        return CXXSpecialMemberKind::CopyAssignment;
6626  
6627      if (MD->isMoveAssignmentOperator())
6628        return CXXSpecialMemberKind::MoveAssignment;
6629  
6630      if (isa<CXXDestructorDecl>(FD))
6631        return CXXSpecialMemberKind::Destructor;
6632    }
6633  
6634    switch (FD->getDeclName().getCXXOverloadedOperator()) {
6635    case OO_EqualEqual:
6636      return DefaultedComparisonKind::Equal;
6637  
6638    case OO_ExclaimEqual:
6639      return DefaultedComparisonKind::NotEqual;
6640  
6641    case OO_Spaceship:
6642      // No point allowing this if <=> doesn't exist in the current language mode.
6643      if (!getLangOpts().CPlusPlus20)
6644        break;
6645      return DefaultedComparisonKind::ThreeWay;
6646  
6647    case OO_Less:
6648    case OO_LessEqual:
6649    case OO_Greater:
6650    case OO_GreaterEqual:
6651      // No point allowing this if <=> doesn't exist in the current language mode.
6652      if (!getLangOpts().CPlusPlus20)
6653        break;
6654      return DefaultedComparisonKind::Relational;
6655  
6656    default:
6657      break;
6658    }
6659  
6660    // Not defaultable.
6661    return DefaultedFunctionKind();
6662  }
6663  
6664  static void DefineDefaultedFunction(Sema &S, FunctionDecl *FD,
6665                                      SourceLocation DefaultLoc) {
6666    Sema::DefaultedFunctionKind DFK = S.getDefaultedFunctionKind(FD);
6667    if (DFK.isComparison())
6668      return S.DefineDefaultedComparison(DefaultLoc, FD, DFK.asComparison());
6669  
6670    switch (DFK.asSpecialMember()) {
6671    case CXXSpecialMemberKind::DefaultConstructor:
6672      S.DefineImplicitDefaultConstructor(DefaultLoc,
6673                                         cast<CXXConstructorDecl>(FD));
6674      break;
6675    case CXXSpecialMemberKind::CopyConstructor:
6676      S.DefineImplicitCopyConstructor(DefaultLoc, cast<CXXConstructorDecl>(FD));
6677      break;
6678    case CXXSpecialMemberKind::CopyAssignment:
6679      S.DefineImplicitCopyAssignment(DefaultLoc, cast<CXXMethodDecl>(FD));
6680      break;
6681    case CXXSpecialMemberKind::Destructor:
6682      S.DefineImplicitDestructor(DefaultLoc, cast<CXXDestructorDecl>(FD));
6683      break;
6684    case CXXSpecialMemberKind::MoveConstructor:
6685      S.DefineImplicitMoveConstructor(DefaultLoc, cast<CXXConstructorDecl>(FD));
6686      break;
6687    case CXXSpecialMemberKind::MoveAssignment:
6688      S.DefineImplicitMoveAssignment(DefaultLoc, cast<CXXMethodDecl>(FD));
6689      break;
6690    case CXXSpecialMemberKind::Invalid:
6691      llvm_unreachable("Invalid special member.");
6692    }
6693  }
6694  
6695  /// Determine whether a type is permitted to be passed or returned in
6696  /// registers, per C++ [class.temporary]p3.
6697  static bool canPassInRegisters(Sema &S, CXXRecordDecl *D,
6698                                 TargetInfo::CallingConvKind CCK) {
6699    if (D->isDependentType() || D->isInvalidDecl())
6700      return false;
6701  
6702    // Clang <= 4 used the pre-C++11 rule, which ignores move operations.
6703    // The PS4 platform ABI follows the behavior of Clang 3.2.
6704    if (CCK == TargetInfo::CCK_ClangABI4OrPS4)
6705      return !D->hasNonTrivialDestructorForCall() &&
6706             !D->hasNonTrivialCopyConstructorForCall();
6707  
6708    if (CCK == TargetInfo::CCK_MicrosoftWin64) {
6709      bool CopyCtorIsTrivial = false, CopyCtorIsTrivialForCall = false;
6710      bool DtorIsTrivialForCall = false;
6711  
6712      // If a class has at least one eligible, trivial copy constructor, it
6713      // is passed according to the C ABI. Otherwise, it is passed indirectly.
6714      //
6715      // Note: This permits classes with non-trivial copy or move ctors to be
6716      // passed in registers, so long as they *also* have a trivial copy ctor,
6717      // which is non-conforming.
6718      if (D->needsImplicitCopyConstructor()) {
6719        if (!D->defaultedCopyConstructorIsDeleted()) {
6720          if (D->hasTrivialCopyConstructor())
6721            CopyCtorIsTrivial = true;
6722          if (D->hasTrivialCopyConstructorForCall())
6723            CopyCtorIsTrivialForCall = true;
6724        }
6725      } else {
6726        for (const CXXConstructorDecl *CD : D->ctors()) {
6727          if (CD->isCopyConstructor() && !CD->isDeleted() &&
6728              !CD->isIneligibleOrNotSelected()) {
6729            if (CD->isTrivial())
6730              CopyCtorIsTrivial = true;
6731            if (CD->isTrivialForCall())
6732              CopyCtorIsTrivialForCall = true;
6733          }
6734        }
6735      }
6736  
6737      if (D->needsImplicitDestructor()) {
6738        if (!D->defaultedDestructorIsDeleted() &&
6739            D->hasTrivialDestructorForCall())
6740          DtorIsTrivialForCall = true;
6741      } else if (const auto *DD = D->getDestructor()) {
6742        if (!DD->isDeleted() && DD->isTrivialForCall())
6743          DtorIsTrivialForCall = true;
6744      }
6745  
6746      // If the copy ctor and dtor are both trivial-for-calls, pass direct.
6747      if (CopyCtorIsTrivialForCall && DtorIsTrivialForCall)
6748        return true;
6749  
6750      // If a class has a destructor, we'd really like to pass it indirectly
6751      // because it allows us to elide copies.  Unfortunately, MSVC makes that
6752      // impossible for small types, which it will pass in a single register or
6753      // stack slot. Most objects with dtors are large-ish, so handle that early.
6754      // We can't call out all large objects as being indirect because there are
6755      // multiple x64 calling conventions and the C++ ABI code shouldn't dictate
6756      // how we pass large POD types.
6757  
6758      // Note: This permits small classes with nontrivial destructors to be
6759      // passed in registers, which is non-conforming.
6760      bool isAArch64 = S.Context.getTargetInfo().getTriple().isAArch64();
6761      uint64_t TypeSize = isAArch64 ? 128 : 64;
6762  
6763      if (CopyCtorIsTrivial &&
6764          S.getASTContext().getTypeSize(D->getTypeForDecl()) <= TypeSize)
6765        return true;
6766      return false;
6767    }
6768  
6769    // Per C++ [class.temporary]p3, the relevant condition is:
6770    //   each copy constructor, move constructor, and destructor of X is
6771    //   either trivial or deleted, and X has at least one non-deleted copy
6772    //   or move constructor
6773    bool HasNonDeletedCopyOrMove = false;
6774  
6775    if (D->needsImplicitCopyConstructor() &&
6776        !D->defaultedCopyConstructorIsDeleted()) {
6777      if (!D->hasTrivialCopyConstructorForCall())
6778        return false;
6779      HasNonDeletedCopyOrMove = true;
6780    }
6781  
6782    if (S.getLangOpts().CPlusPlus11 && D->needsImplicitMoveConstructor() &&
6783        !D->defaultedMoveConstructorIsDeleted()) {
6784      if (!D->hasTrivialMoveConstructorForCall())
6785        return false;
6786      HasNonDeletedCopyOrMove = true;
6787    }
6788  
6789    if (D->needsImplicitDestructor() && !D->defaultedDestructorIsDeleted() &&
6790        !D->hasTrivialDestructorForCall())
6791      return false;
6792  
6793    for (const CXXMethodDecl *MD : D->methods()) {
6794      if (MD->isDeleted() || MD->isIneligibleOrNotSelected())
6795        continue;
6796  
6797      auto *CD = dyn_cast<CXXConstructorDecl>(MD);
6798      if (CD && CD->isCopyOrMoveConstructor())
6799        HasNonDeletedCopyOrMove = true;
6800      else if (!isa<CXXDestructorDecl>(MD))
6801        continue;
6802  
6803      if (!MD->isTrivialForCall())
6804        return false;
6805    }
6806  
6807    return HasNonDeletedCopyOrMove;
6808  }
6809  
6810  /// Report an error regarding overriding, along with any relevant
6811  /// overridden methods.
6812  ///
6813  /// \param DiagID the primary error to report.
6814  /// \param MD the overriding method.
6815  static bool
6816  ReportOverrides(Sema &S, unsigned DiagID, const CXXMethodDecl *MD,
6817                  llvm::function_ref<bool(const CXXMethodDecl *)> Report) {
6818    bool IssuedDiagnostic = false;
6819    for (const CXXMethodDecl *O : MD->overridden_methods()) {
6820      if (Report(O)) {
6821        if (!IssuedDiagnostic) {
6822          S.Diag(MD->getLocation(), DiagID) << MD->getDeclName();
6823          IssuedDiagnostic = true;
6824        }
6825        S.Diag(O->getLocation(), diag::note_overridden_virtual_function);
6826      }
6827    }
6828    return IssuedDiagnostic;
6829  }
6830  
6831  void Sema::CheckCompletedCXXClass(Scope *S, CXXRecordDecl *Record) {
6832    if (!Record)
6833      return;
6834  
6835    if (Record->isAbstract() && !Record->isInvalidDecl()) {
6836      AbstractUsageInfo Info(*this, Record);
6837      CheckAbstractClassUsage(Info, Record);
6838    }
6839  
6840    // If this is not an aggregate type and has no user-declared constructor,
6841    // complain about any non-static data members of reference or const scalar
6842    // type, since they will never get initializers.
6843    if (!Record->isInvalidDecl() && !Record->isDependentType() &&
6844        !Record->isAggregate() && !Record->hasUserDeclaredConstructor() &&
6845        !Record->isLambda()) {
6846      bool Complained = false;
6847      for (const auto *F : Record->fields()) {
6848        if (F->hasInClassInitializer() || F->isUnnamedBitField())
6849          continue;
6850  
6851        if (F->getType()->isReferenceType() ||
6852            (F->getType().isConstQualified() && F->getType()->isScalarType())) {
6853          if (!Complained) {
6854            Diag(Record->getLocation(), diag::warn_no_constructor_for_refconst)
6855                << llvm::to_underlying(Record->getTagKind()) << Record;
6856            Complained = true;
6857          }
6858  
6859          Diag(F->getLocation(), diag::note_refconst_member_not_initialized)
6860            << F->getType()->isReferenceType()
6861            << F->getDeclName();
6862        }
6863      }
6864    }
6865  
6866    if (Record->getIdentifier()) {
6867      // C++ [class.mem]p13:
6868      //   If T is the name of a class, then each of the following shall have a
6869      //   name different from T:
6870      //     - every member of every anonymous union that is a member of class T.
6871      //
6872      // C++ [class.mem]p14:
6873      //   In addition, if class T has a user-declared constructor (12.1), every
6874      //   non-static data member of class T shall have a name different from T.
6875      DeclContext::lookup_result R = Record->lookup(Record->getDeclName());
6876      for (DeclContext::lookup_iterator I = R.begin(), E = R.end(); I != E;
6877           ++I) {
6878        NamedDecl *D = (*I)->getUnderlyingDecl();
6879        if (((isa<FieldDecl>(D) || isa<UnresolvedUsingValueDecl>(D)) &&
6880             Record->hasUserDeclaredConstructor()) ||
6881            isa<IndirectFieldDecl>(D)) {
6882          Diag((*I)->getLocation(), diag::err_member_name_of_class)
6883            << D->getDeclName();
6884          break;
6885        }
6886      }
6887    }
6888  
6889    // Warn if the class has virtual methods but non-virtual public destructor.
6890    if (Record->isPolymorphic() && !Record->isDependentType()) {
6891      CXXDestructorDecl *dtor = Record->getDestructor();
6892      if ((!dtor || (!dtor->isVirtual() && dtor->getAccess() == AS_public)) &&
6893          !Record->hasAttr<FinalAttr>())
6894        Diag(dtor ? dtor->getLocation() : Record->getLocation(),
6895             diag::warn_non_virtual_dtor) << Context.getRecordType(Record);
6896    }
6897  
6898    if (Record->isAbstract()) {
6899      if (FinalAttr *FA = Record->getAttr<FinalAttr>()) {
6900        Diag(Record->getLocation(), diag::warn_abstract_final_class)
6901          << FA->isSpelledAsSealed();
6902        DiagnoseAbstractType(Record);
6903      }
6904    }
6905  
6906    // Warn if the class has a final destructor but is not itself marked final.
6907    if (!Record->hasAttr<FinalAttr>()) {
6908      if (const CXXDestructorDecl *dtor = Record->getDestructor()) {
6909        if (const FinalAttr *FA = dtor->getAttr<FinalAttr>()) {
6910          Diag(FA->getLocation(), diag::warn_final_dtor_non_final_class)
6911              << FA->isSpelledAsSealed()
6912              << FixItHint::CreateInsertion(
6913                     getLocForEndOfToken(Record->getLocation()),
6914                     (FA->isSpelledAsSealed() ? " sealed" : " final"));
6915          Diag(Record->getLocation(),
6916               diag::note_final_dtor_non_final_class_silence)
6917              << Context.getRecordType(Record) << FA->isSpelledAsSealed();
6918        }
6919      }
6920    }
6921  
6922    // See if trivial_abi has to be dropped.
6923    if (Record->hasAttr<TrivialABIAttr>())
6924      checkIllFormedTrivialABIStruct(*Record);
6925  
6926    // Set HasTrivialSpecialMemberForCall if the record has attribute
6927    // "trivial_abi".
6928    bool HasTrivialABI = Record->hasAttr<TrivialABIAttr>();
6929  
6930    if (HasTrivialABI)
6931      Record->setHasTrivialSpecialMemberForCall();
6932  
6933    // Explicitly-defaulted secondary comparison functions (!=, <, <=, >, >=).
6934    // We check these last because they can depend on the properties of the
6935    // primary comparison functions (==, <=>).
6936    llvm::SmallVector<FunctionDecl*, 5> DefaultedSecondaryComparisons;
6937  
6938    // Perform checks that can't be done until we know all the properties of a
6939    // member function (whether it's defaulted, deleted, virtual, overriding,
6940    // ...).
6941    auto CheckCompletedMemberFunction = [&](CXXMethodDecl *MD) {
6942      // A static function cannot override anything.
6943      if (MD->getStorageClass() == SC_Static) {
6944        if (ReportOverrides(*this, diag::err_static_overrides_virtual, MD,
6945                            [](const CXXMethodDecl *) { return true; }))
6946          return;
6947      }
6948  
6949      // A deleted function cannot override a non-deleted function and vice
6950      // versa.
6951      if (ReportOverrides(*this,
6952                          MD->isDeleted() ? diag::err_deleted_override
6953                                          : diag::err_non_deleted_override,
6954                          MD, [&](const CXXMethodDecl *V) {
6955                            return MD->isDeleted() != V->isDeleted();
6956                          })) {
6957        if (MD->isDefaulted() && MD->isDeleted())
6958          // Explain why this defaulted function was deleted.
6959          DiagnoseDeletedDefaultedFunction(MD);
6960        return;
6961      }
6962  
6963      // A consteval function cannot override a non-consteval function and vice
6964      // versa.
6965      if (ReportOverrides(*this,
6966                          MD->isConsteval() ? diag::err_consteval_override
6967                                            : diag::err_non_consteval_override,
6968                          MD, [&](const CXXMethodDecl *V) {
6969                            return MD->isConsteval() != V->isConsteval();
6970                          })) {
6971        if (MD->isDefaulted() && MD->isDeleted())
6972          // Explain why this defaulted function was deleted.
6973          DiagnoseDeletedDefaultedFunction(MD);
6974        return;
6975      }
6976    };
6977  
6978    auto CheckForDefaultedFunction = [&](FunctionDecl *FD) -> bool {
6979      if (!FD || FD->isInvalidDecl() || !FD->isExplicitlyDefaulted())
6980        return false;
6981  
6982      DefaultedFunctionKind DFK = getDefaultedFunctionKind(FD);
6983      if (DFK.asComparison() == DefaultedComparisonKind::NotEqual ||
6984          DFK.asComparison() == DefaultedComparisonKind::Relational) {
6985        DefaultedSecondaryComparisons.push_back(FD);
6986        return true;
6987      }
6988  
6989      CheckExplicitlyDefaultedFunction(S, FD);
6990      return false;
6991    };
6992  
6993    if (!Record->isInvalidDecl() &&
6994        Record->hasAttr<VTablePointerAuthenticationAttr>())
6995      checkIncorrectVTablePointerAuthenticationAttribute(*Record);
6996  
6997    auto CompleteMemberFunction = [&](CXXMethodDecl *M) {
6998      // Check whether the explicitly-defaulted members are valid.
6999      bool Incomplete = CheckForDefaultedFunction(M);
7000  
7001      // Skip the rest of the checks for a member of a dependent class.
7002      if (Record->isDependentType())
7003        return;
7004  
7005      // For an explicitly defaulted or deleted special member, we defer
7006      // determining triviality until the class is complete. That time is now!
7007      CXXSpecialMemberKind CSM = getSpecialMember(M);
7008      if (!M->isImplicit() && !M->isUserProvided()) {
7009        if (CSM != CXXSpecialMemberKind::Invalid) {
7010          M->setTrivial(SpecialMemberIsTrivial(M, CSM));
7011          // Inform the class that we've finished declaring this member.
7012          Record->finishedDefaultedOrDeletedMember(M);
7013          M->setTrivialForCall(
7014              HasTrivialABI ||
7015              SpecialMemberIsTrivial(M, CSM, TAH_ConsiderTrivialABI));
7016          Record->setTrivialForCallFlags(M);
7017        }
7018      }
7019  
7020      // Set triviality for the purpose of calls if this is a user-provided
7021      // copy/move constructor or destructor.
7022      if ((CSM == CXXSpecialMemberKind::CopyConstructor ||
7023           CSM == CXXSpecialMemberKind::MoveConstructor ||
7024           CSM == CXXSpecialMemberKind::Destructor) &&
7025          M->isUserProvided()) {
7026        M->setTrivialForCall(HasTrivialABI);
7027        Record->setTrivialForCallFlags(M);
7028      }
7029  
7030      if (!M->isInvalidDecl() && M->isExplicitlyDefaulted() &&
7031          M->hasAttr<DLLExportAttr>()) {
7032        if (getLangOpts().isCompatibleWithMSVC(LangOptions::MSVC2015) &&
7033            M->isTrivial() &&
7034            (CSM == CXXSpecialMemberKind::DefaultConstructor ||
7035             CSM == CXXSpecialMemberKind::CopyConstructor ||
7036             CSM == CXXSpecialMemberKind::Destructor))
7037          M->dropAttr<DLLExportAttr>();
7038  
7039        if (M->hasAttr<DLLExportAttr>()) {
7040          // Define after any fields with in-class initializers have been parsed.
7041          DelayedDllExportMemberFunctions.push_back(M);
7042        }
7043      }
7044  
7045      bool EffectivelyConstexprDestructor = true;
7046      // Avoid triggering vtable instantiation due to a dtor that is not
7047      // "effectively constexpr" for better compatibility.
7048      // See https://github.com/llvm/llvm-project/issues/102293 for more info.
7049      if (isa<CXXDestructorDecl>(M)) {
7050        auto Check = [](QualType T, auto &&Check) -> bool {
7051          const CXXRecordDecl *RD =
7052              T->getBaseElementTypeUnsafe()->getAsCXXRecordDecl();
7053          if (!RD || !RD->isCompleteDefinition())
7054            return true;
7055  
7056          if (!RD->hasConstexprDestructor())
7057            return false;
7058  
7059          QualType CanUnqualT = T.getCanonicalType().getUnqualifiedType();
7060          for (const CXXBaseSpecifier &B : RD->bases())
7061            if (B.getType().getCanonicalType().getUnqualifiedType() !=
7062                    CanUnqualT &&
7063                !Check(B.getType(), Check))
7064              return false;
7065          for (const FieldDecl *FD : RD->fields())
7066            if (FD->getType().getCanonicalType().getUnqualifiedType() !=
7067                    CanUnqualT &&
7068                !Check(FD->getType(), Check))
7069              return false;
7070          return true;
7071        };
7072        EffectivelyConstexprDestructor =
7073            Check(QualType(Record->getTypeForDecl(), 0), Check);
7074      }
7075  
7076      // Define defaulted constexpr virtual functions that override a base class
7077      // function right away.
7078      // FIXME: We can defer doing this until the vtable is marked as used.
7079      if (CSM != CXXSpecialMemberKind::Invalid && !M->isDeleted() &&
7080          M->isDefaulted() && M->isConstexpr() && M->size_overridden_methods() &&
7081          EffectivelyConstexprDestructor)
7082        DefineDefaultedFunction(*this, M, M->getLocation());
7083  
7084      if (!Incomplete)
7085        CheckCompletedMemberFunction(M);
7086    };
7087  
7088    // Check the destructor before any other member function. We need to
7089    // determine whether it's trivial in order to determine whether the claas
7090    // type is a literal type, which is a prerequisite for determining whether
7091    // other special member functions are valid and whether they're implicitly
7092    // 'constexpr'.
7093    if (CXXDestructorDecl *Dtor = Record->getDestructor())
7094      CompleteMemberFunction(Dtor);
7095  
7096    bool HasMethodWithOverrideControl = false,
7097         HasOverridingMethodWithoutOverrideControl = false;
7098    for (auto *D : Record->decls()) {
7099      if (auto *M = dyn_cast<CXXMethodDecl>(D)) {
7100        // FIXME: We could do this check for dependent types with non-dependent
7101        // bases.
7102        if (!Record->isDependentType()) {
7103          // See if a method overloads virtual methods in a base
7104          // class without overriding any.
7105          if (!M->isStatic())
7106            DiagnoseHiddenVirtualMethods(M);
7107          if (M->hasAttr<OverrideAttr>())
7108            HasMethodWithOverrideControl = true;
7109          else if (M->size_overridden_methods() > 0)
7110            HasOverridingMethodWithoutOverrideControl = true;
7111        }
7112  
7113        if (!isa<CXXDestructorDecl>(M))
7114          CompleteMemberFunction(M);
7115      } else if (auto *F = dyn_cast<FriendDecl>(D)) {
7116        CheckForDefaultedFunction(
7117            dyn_cast_or_null<FunctionDecl>(F->getFriendDecl()));
7118      }
7119    }
7120  
7121    if (HasOverridingMethodWithoutOverrideControl) {
7122      bool HasInconsistentOverrideControl = HasMethodWithOverrideControl;
7123      for (auto *M : Record->methods())
7124        DiagnoseAbsenceOfOverrideControl(M, HasInconsistentOverrideControl);
7125    }
7126  
7127    // Check the defaulted secondary comparisons after any other member functions.
7128    for (FunctionDecl *FD : DefaultedSecondaryComparisons) {
7129      CheckExplicitlyDefaultedFunction(S, FD);
7130  
7131      // If this is a member function, we deferred checking it until now.
7132      if (auto *MD = dyn_cast<CXXMethodDecl>(FD))
7133        CheckCompletedMemberFunction(MD);
7134    }
7135  
7136    // ms_struct is a request to use the same ABI rules as MSVC.  Check
7137    // whether this class uses any C++ features that are implemented
7138    // completely differently in MSVC, and if so, emit a diagnostic.
7139    // That diagnostic defaults to an error, but we allow projects to
7140    // map it down to a warning (or ignore it).  It's a fairly common
7141    // practice among users of the ms_struct pragma to mass-annotate
7142    // headers, sweeping up a bunch of types that the project doesn't
7143    // really rely on MSVC-compatible layout for.  We must therefore
7144    // support "ms_struct except for C++ stuff" as a secondary ABI.
7145    // Don't emit this diagnostic if the feature was enabled as a
7146    // language option (as opposed to via a pragma or attribute), as
7147    // the option -mms-bitfields otherwise essentially makes it impossible
7148    // to build C++ code, unless this diagnostic is turned off.
7149    if (Record->isMsStruct(Context) && !Context.getLangOpts().MSBitfields &&
7150        (Record->isPolymorphic() || Record->getNumBases())) {
7151      Diag(Record->getLocation(), diag::warn_cxx_ms_struct);
7152    }
7153  
7154    checkClassLevelDLLAttribute(Record);
7155    checkClassLevelCodeSegAttribute(Record);
7156  
7157    bool ClangABICompat4 =
7158        Context.getLangOpts().getClangABICompat() <= LangOptions::ClangABI::Ver4;
7159    TargetInfo::CallingConvKind CCK =
7160        Context.getTargetInfo().getCallingConvKind(ClangABICompat4);
7161    bool CanPass = canPassInRegisters(*this, Record, CCK);
7162  
7163    // Do not change ArgPassingRestrictions if it has already been set to
7164    // RecordArgPassingKind::CanNeverPassInRegs.
7165    if (Record->getArgPassingRestrictions() !=
7166        RecordArgPassingKind::CanNeverPassInRegs)
7167      Record->setArgPassingRestrictions(
7168          CanPass ? RecordArgPassingKind::CanPassInRegs
7169                  : RecordArgPassingKind::CannotPassInRegs);
7170  
7171    // If canPassInRegisters returns true despite the record having a non-trivial
7172    // destructor, the record is destructed in the callee. This happens only when
7173    // the record or one of its subobjects has a field annotated with trivial_abi
7174    // or a field qualified with ObjC __strong/__weak.
7175    if (Context.getTargetInfo().getCXXABI().areArgsDestroyedLeftToRightInCallee())
7176      Record->setParamDestroyedInCallee(true);
7177    else if (Record->hasNonTrivialDestructor())
7178      Record->setParamDestroyedInCallee(CanPass);
7179  
7180    if (getLangOpts().ForceEmitVTables) {
7181      // If we want to emit all the vtables, we need to mark it as used.  This
7182      // is especially required for cases like vtable assumption loads.
7183      MarkVTableUsed(Record->getInnerLocStart(), Record);
7184    }
7185  
7186    if (getLangOpts().CUDA) {
7187      if (Record->hasAttr<CUDADeviceBuiltinSurfaceTypeAttr>())
7188        checkCUDADeviceBuiltinSurfaceClassTemplate(*this, Record);
7189      else if (Record->hasAttr<CUDADeviceBuiltinTextureTypeAttr>())
7190        checkCUDADeviceBuiltinTextureClassTemplate(*this, Record);
7191    }
7192  }
7193  
7194  /// Look up the special member function that would be called by a special
7195  /// member function for a subobject of class type.
7196  ///
7197  /// \param Class The class type of the subobject.
7198  /// \param CSM The kind of special member function.
7199  /// \param FieldQuals If the subobject is a field, its cv-qualifiers.
7200  /// \param ConstRHS True if this is a copy operation with a const object
7201  ///        on its RHS, that is, if the argument to the outer special member
7202  ///        function is 'const' and this is not a field marked 'mutable'.
7203  static Sema::SpecialMemberOverloadResult
7204  lookupCallFromSpecialMember(Sema &S, CXXRecordDecl *Class,
7205                              CXXSpecialMemberKind CSM, unsigned FieldQuals,
7206                              bool ConstRHS) {
7207    unsigned LHSQuals = 0;
7208    if (CSM == CXXSpecialMemberKind::CopyAssignment ||
7209        CSM == CXXSpecialMemberKind::MoveAssignment)
7210      LHSQuals = FieldQuals;
7211  
7212    unsigned RHSQuals = FieldQuals;
7213    if (CSM == CXXSpecialMemberKind::DefaultConstructor ||
7214        CSM == CXXSpecialMemberKind::Destructor)
7215      RHSQuals = 0;
7216    else if (ConstRHS)
7217      RHSQuals |= Qualifiers::Const;
7218  
7219    return S.LookupSpecialMember(Class, CSM,
7220                                 RHSQuals & Qualifiers::Const,
7221                                 RHSQuals & Qualifiers::Volatile,
7222                                 false,
7223                                 LHSQuals & Qualifiers::Const,
7224                                 LHSQuals & Qualifiers::Volatile);
7225  }
7226  
7227  class Sema::InheritedConstructorInfo {
7228    Sema &S;
7229    SourceLocation UseLoc;
7230  
7231    /// A mapping from the base classes through which the constructor was
7232    /// inherited to the using shadow declaration in that base class (or a null
7233    /// pointer if the constructor was declared in that base class).
7234    llvm::DenseMap<CXXRecordDecl *, ConstructorUsingShadowDecl *>
7235        InheritedFromBases;
7236  
7237  public:
7238    InheritedConstructorInfo(Sema &S, SourceLocation UseLoc,
7239                             ConstructorUsingShadowDecl *Shadow)
7240        : S(S), UseLoc(UseLoc) {
7241      bool DiagnosedMultipleConstructedBases = false;
7242      CXXRecordDecl *ConstructedBase = nullptr;
7243      BaseUsingDecl *ConstructedBaseIntroducer = nullptr;
7244  
7245      // Find the set of such base class subobjects and check that there's a
7246      // unique constructed subobject.
7247      for (auto *D : Shadow->redecls()) {
7248        auto *DShadow = cast<ConstructorUsingShadowDecl>(D);
7249        auto *DNominatedBase = DShadow->getNominatedBaseClass();
7250        auto *DConstructedBase = DShadow->getConstructedBaseClass();
7251  
7252        InheritedFromBases.insert(
7253            std::make_pair(DNominatedBase->getCanonicalDecl(),
7254                           DShadow->getNominatedBaseClassShadowDecl()));
7255        if (DShadow->constructsVirtualBase())
7256          InheritedFromBases.insert(
7257              std::make_pair(DConstructedBase->getCanonicalDecl(),
7258                             DShadow->getConstructedBaseClassShadowDecl()));
7259        else
7260          assert(DNominatedBase == DConstructedBase);
7261  
7262        // [class.inhctor.init]p2:
7263        //   If the constructor was inherited from multiple base class subobjects
7264        //   of type B, the program is ill-formed.
7265        if (!ConstructedBase) {
7266          ConstructedBase = DConstructedBase;
7267          ConstructedBaseIntroducer = D->getIntroducer();
7268        } else if (ConstructedBase != DConstructedBase &&
7269                   !Shadow->isInvalidDecl()) {
7270          if (!DiagnosedMultipleConstructedBases) {
7271            S.Diag(UseLoc, diag::err_ambiguous_inherited_constructor)
7272                << Shadow->getTargetDecl();
7273            S.Diag(ConstructedBaseIntroducer->getLocation(),
7274                   diag::note_ambiguous_inherited_constructor_using)
7275                << ConstructedBase;
7276            DiagnosedMultipleConstructedBases = true;
7277          }
7278          S.Diag(D->getIntroducer()->getLocation(),
7279                 diag::note_ambiguous_inherited_constructor_using)
7280              << DConstructedBase;
7281        }
7282      }
7283  
7284      if (DiagnosedMultipleConstructedBases)
7285        Shadow->setInvalidDecl();
7286    }
7287  
7288    /// Find the constructor to use for inherited construction of a base class,
7289    /// and whether that base class constructor inherits the constructor from a
7290    /// virtual base class (in which case it won't actually invoke it).
7291    std::pair<CXXConstructorDecl *, bool>
7292    findConstructorForBase(CXXRecordDecl *Base, CXXConstructorDecl *Ctor) const {
7293      auto It = InheritedFromBases.find(Base->getCanonicalDecl());
7294      if (It == InheritedFromBases.end())
7295        return std::make_pair(nullptr, false);
7296  
7297      // This is an intermediary class.
7298      if (It->second)
7299        return std::make_pair(
7300            S.findInheritingConstructor(UseLoc, Ctor, It->second),
7301            It->second->constructsVirtualBase());
7302  
7303      // This is the base class from which the constructor was inherited.
7304      return std::make_pair(Ctor, false);
7305    }
7306  };
7307  
7308  /// Is the special member function which would be selected to perform the
7309  /// specified operation on the specified class type a constexpr constructor?
7310  static bool specialMemberIsConstexpr(
7311      Sema &S, CXXRecordDecl *ClassDecl, CXXSpecialMemberKind CSM, unsigned Quals,
7312      bool ConstRHS, CXXConstructorDecl *InheritedCtor = nullptr,
7313      Sema::InheritedConstructorInfo *Inherited = nullptr) {
7314    // Suppress duplicate constraint checking here, in case a constraint check
7315    // caused us to decide to do this.  Any truely recursive checks will get
7316    // caught during these checks anyway.
7317    Sema::SatisfactionStackResetRAII SSRAII{S};
7318  
7319    // If we're inheriting a constructor, see if we need to call it for this base
7320    // class.
7321    if (InheritedCtor) {
7322      assert(CSM == CXXSpecialMemberKind::DefaultConstructor);
7323      auto BaseCtor =
7324          Inherited->findConstructorForBase(ClassDecl, InheritedCtor).first;
7325      if (BaseCtor)
7326        return BaseCtor->isConstexpr();
7327    }
7328  
7329    if (CSM == CXXSpecialMemberKind::DefaultConstructor)
7330      return ClassDecl->hasConstexprDefaultConstructor();
7331    if (CSM == CXXSpecialMemberKind::Destructor)
7332      return ClassDecl->hasConstexprDestructor();
7333  
7334    Sema::SpecialMemberOverloadResult SMOR =
7335        lookupCallFromSpecialMember(S, ClassDecl, CSM, Quals, ConstRHS);
7336    if (!SMOR.getMethod())
7337      // A constructor we wouldn't select can't be "involved in initializing"
7338      // anything.
7339      return true;
7340    return SMOR.getMethod()->isConstexpr();
7341  }
7342  
7343  /// Determine whether the specified special member function would be constexpr
7344  /// if it were implicitly defined.
7345  static bool defaultedSpecialMemberIsConstexpr(
7346      Sema &S, CXXRecordDecl *ClassDecl, CXXSpecialMemberKind CSM, bool ConstArg,
7347      CXXConstructorDecl *InheritedCtor = nullptr,
7348      Sema::InheritedConstructorInfo *Inherited = nullptr) {
7349    if (!S.getLangOpts().CPlusPlus11)
7350      return false;
7351  
7352    // C++11 [dcl.constexpr]p4:
7353    // In the definition of a constexpr constructor [...]
7354    bool Ctor = true;
7355    switch (CSM) {
7356    case CXXSpecialMemberKind::DefaultConstructor:
7357      if (Inherited)
7358        break;
7359      // Since default constructor lookup is essentially trivial (and cannot
7360      // involve, for instance, template instantiation), we compute whether a
7361      // defaulted default constructor is constexpr directly within CXXRecordDecl.
7362      //
7363      // This is important for performance; we need to know whether the default
7364      // constructor is constexpr to determine whether the type is a literal type.
7365      return ClassDecl->defaultedDefaultConstructorIsConstexpr();
7366  
7367    case CXXSpecialMemberKind::CopyConstructor:
7368    case CXXSpecialMemberKind::MoveConstructor:
7369      // For copy or move constructors, we need to perform overload resolution.
7370      break;
7371  
7372    case CXXSpecialMemberKind::CopyAssignment:
7373    case CXXSpecialMemberKind::MoveAssignment:
7374      if (!S.getLangOpts().CPlusPlus14)
7375        return false;
7376      // In C++1y, we need to perform overload resolution.
7377      Ctor = false;
7378      break;
7379  
7380    case CXXSpecialMemberKind::Destructor:
7381      return ClassDecl->defaultedDestructorIsConstexpr();
7382  
7383    case CXXSpecialMemberKind::Invalid:
7384      return false;
7385    }
7386  
7387    //   -- if the class is a non-empty union, or for each non-empty anonymous
7388    //      union member of a non-union class, exactly one non-static data member
7389    //      shall be initialized; [DR1359]
7390    //
7391    // If we squint, this is guaranteed, since exactly one non-static data member
7392    // will be initialized (if the constructor isn't deleted), we just don't know
7393    // which one.
7394    if (Ctor && ClassDecl->isUnion())
7395      return CSM == CXXSpecialMemberKind::DefaultConstructor
7396                 ? ClassDecl->hasInClassInitializer() ||
7397                       !ClassDecl->hasVariantMembers()
7398                 : true;
7399  
7400    //   -- the class shall not have any virtual base classes;
7401    if (Ctor && ClassDecl->getNumVBases())
7402      return false;
7403  
7404    // C++1y [class.copy]p26:
7405    //   -- [the class] is a literal type, and
7406    if (!Ctor && !ClassDecl->isLiteral() && !S.getLangOpts().CPlusPlus23)
7407      return false;
7408  
7409    //   -- every constructor involved in initializing [...] base class
7410    //      sub-objects shall be a constexpr constructor;
7411    //   -- the assignment operator selected to copy/move each direct base
7412    //      class is a constexpr function, and
7413    if (!S.getLangOpts().CPlusPlus23) {
7414      for (const auto &B : ClassDecl->bases()) {
7415        const RecordType *BaseType = B.getType()->getAs<RecordType>();
7416        if (!BaseType)
7417          continue;
7418        CXXRecordDecl *BaseClassDecl = cast<CXXRecordDecl>(BaseType->getDecl());
7419        if (!specialMemberIsConstexpr(S, BaseClassDecl, CSM, 0, ConstArg,
7420                                      InheritedCtor, Inherited))
7421          return false;
7422      }
7423    }
7424  
7425    //   -- every constructor involved in initializing non-static data members
7426    //      [...] shall be a constexpr constructor;
7427    //   -- every non-static data member and base class sub-object shall be
7428    //      initialized
7429    //   -- for each non-static data member of X that is of class type (or array
7430    //      thereof), the assignment operator selected to copy/move that member is
7431    //      a constexpr function
7432    if (!S.getLangOpts().CPlusPlus23) {
7433      for (const auto *F : ClassDecl->fields()) {
7434        if (F->isInvalidDecl())
7435          continue;
7436        if (CSM == CXXSpecialMemberKind::DefaultConstructor &&
7437            F->hasInClassInitializer())
7438          continue;
7439        QualType BaseType = S.Context.getBaseElementType(F->getType());
7440        if (const RecordType *RecordTy = BaseType->getAs<RecordType>()) {
7441          CXXRecordDecl *FieldRecDecl = cast<CXXRecordDecl>(RecordTy->getDecl());
7442          if (!specialMemberIsConstexpr(S, FieldRecDecl, CSM,
7443                                        BaseType.getCVRQualifiers(),
7444                                        ConstArg && !F->isMutable()))
7445            return false;
7446        } else if (CSM == CXXSpecialMemberKind::DefaultConstructor) {
7447          return false;
7448        }
7449      }
7450    }
7451  
7452    // All OK, it's constexpr!
7453    return true;
7454  }
7455  
7456  namespace {
7457  /// RAII object to register a defaulted function as having its exception
7458  /// specification computed.
7459  struct ComputingExceptionSpec {
7460    Sema &S;
7461  
7462    ComputingExceptionSpec(Sema &S, FunctionDecl *FD, SourceLocation Loc)
7463        : S(S) {
7464      Sema::CodeSynthesisContext Ctx;
7465      Ctx.Kind = Sema::CodeSynthesisContext::ExceptionSpecEvaluation;
7466      Ctx.PointOfInstantiation = Loc;
7467      Ctx.Entity = FD;
7468      S.pushCodeSynthesisContext(Ctx);
7469    }
7470    ~ComputingExceptionSpec() {
7471      S.popCodeSynthesisContext();
7472    }
7473  };
7474  }
7475  
7476  static Sema::ImplicitExceptionSpecification
7477  ComputeDefaultedSpecialMemberExceptionSpec(Sema &S, SourceLocation Loc,
7478                                             CXXMethodDecl *MD,
7479                                             CXXSpecialMemberKind CSM,
7480                                             Sema::InheritedConstructorInfo *ICI);
7481  
7482  static Sema::ImplicitExceptionSpecification
7483  ComputeDefaultedComparisonExceptionSpec(Sema &S, SourceLocation Loc,
7484                                          FunctionDecl *FD,
7485                                          Sema::DefaultedComparisonKind DCK);
7486  
7487  static Sema::ImplicitExceptionSpecification
7488  computeImplicitExceptionSpec(Sema &S, SourceLocation Loc, FunctionDecl *FD) {
7489    auto DFK = S.getDefaultedFunctionKind(FD);
7490    if (DFK.isSpecialMember())
7491      return ComputeDefaultedSpecialMemberExceptionSpec(
7492          S, Loc, cast<CXXMethodDecl>(FD), DFK.asSpecialMember(), nullptr);
7493    if (DFK.isComparison())
7494      return ComputeDefaultedComparisonExceptionSpec(S, Loc, FD,
7495                                                     DFK.asComparison());
7496  
7497    auto *CD = cast<CXXConstructorDecl>(FD);
7498    assert(CD->getInheritedConstructor() &&
7499           "only defaulted functions and inherited constructors have implicit "
7500           "exception specs");
7501    Sema::InheritedConstructorInfo ICI(
7502        S, Loc, CD->getInheritedConstructor().getShadowDecl());
7503    return ComputeDefaultedSpecialMemberExceptionSpec(
7504        S, Loc, CD, CXXSpecialMemberKind::DefaultConstructor, &ICI);
7505  }
7506  
7507  static FunctionProtoType::ExtProtoInfo getImplicitMethodEPI(Sema &S,
7508                                                              CXXMethodDecl *MD) {
7509    FunctionProtoType::ExtProtoInfo EPI;
7510  
7511    // Build an exception specification pointing back at this member.
7512    EPI.ExceptionSpec.Type = EST_Unevaluated;
7513    EPI.ExceptionSpec.SourceDecl = MD;
7514  
7515    // Set the calling convention to the default for C++ instance methods.
7516    EPI.ExtInfo = EPI.ExtInfo.withCallingConv(
7517        S.Context.getDefaultCallingConvention(/*IsVariadic=*/false,
7518                                              /*IsCXXMethod=*/true));
7519    return EPI;
7520  }
7521  
7522  void Sema::EvaluateImplicitExceptionSpec(SourceLocation Loc, FunctionDecl *FD) {
7523    const FunctionProtoType *FPT = FD->getType()->castAs<FunctionProtoType>();
7524    if (FPT->getExceptionSpecType() != EST_Unevaluated)
7525      return;
7526  
7527    // Evaluate the exception specification.
7528    auto IES = computeImplicitExceptionSpec(*this, Loc, FD);
7529    auto ESI = IES.getExceptionSpec();
7530  
7531    // Update the type of the special member to use it.
7532    UpdateExceptionSpec(FD, ESI);
7533  }
7534  
7535  void Sema::CheckExplicitlyDefaultedFunction(Scope *S, FunctionDecl *FD) {
7536    assert(FD->isExplicitlyDefaulted() && "not explicitly-defaulted");
7537  
7538    DefaultedFunctionKind DefKind = getDefaultedFunctionKind(FD);
7539    if (!DefKind) {
7540      assert(FD->getDeclContext()->isDependentContext());
7541      return;
7542    }
7543  
7544    if (DefKind.isComparison())
7545      UnusedPrivateFields.clear();
7546  
7547    if (DefKind.isSpecialMember()
7548            ? CheckExplicitlyDefaultedSpecialMember(cast<CXXMethodDecl>(FD),
7549                                                    DefKind.asSpecialMember(),
7550                                                    FD->getDefaultLoc())
7551            : CheckExplicitlyDefaultedComparison(S, FD, DefKind.asComparison()))
7552      FD->setInvalidDecl();
7553  }
7554  
7555  bool Sema::CheckExplicitlyDefaultedSpecialMember(CXXMethodDecl *MD,
7556                                                   CXXSpecialMemberKind CSM,
7557                                                   SourceLocation DefaultLoc) {
7558    CXXRecordDecl *RD = MD->getParent();
7559  
7560    assert(MD->isExplicitlyDefaulted() && CSM != CXXSpecialMemberKind::Invalid &&
7561           "not an explicitly-defaulted special member");
7562  
7563    // Defer all checking for special members of a dependent type.
7564    if (RD->isDependentType())
7565      return false;
7566  
7567    // Whether this was the first-declared instance of the constructor.
7568    // This affects whether we implicitly add an exception spec and constexpr.
7569    bool First = MD == MD->getCanonicalDecl();
7570  
7571    bool HadError = false;
7572  
7573    // C++11 [dcl.fct.def.default]p1:
7574    //   A function that is explicitly defaulted shall
7575    //     -- be a special member function [...] (checked elsewhere),
7576    //     -- have the same type (except for ref-qualifiers, and except that a
7577    //        copy operation can take a non-const reference) as an implicit
7578    //        declaration, and
7579    //     -- not have default arguments.
7580    // C++2a changes the second bullet to instead delete the function if it's
7581    // defaulted on its first declaration, unless it's "an assignment operator,
7582    // and its return type differs or its parameter type is not a reference".
7583    bool DeleteOnTypeMismatch = getLangOpts().CPlusPlus20 && First;
7584    bool ShouldDeleteForTypeMismatch = false;
7585    unsigned ExpectedParams = 1;
7586    if (CSM == CXXSpecialMemberKind::DefaultConstructor ||
7587        CSM == CXXSpecialMemberKind::Destructor)
7588      ExpectedParams = 0;
7589    if (MD->getNumExplicitParams() != ExpectedParams) {
7590      // This checks for default arguments: a copy or move constructor with a
7591      // default argument is classified as a default constructor, and assignment
7592      // operations and destructors can't have default arguments.
7593      Diag(MD->getLocation(), diag::err_defaulted_special_member_params)
7594          << llvm::to_underlying(CSM) << MD->getSourceRange();
7595      HadError = true;
7596    } else if (MD->isVariadic()) {
7597      if (DeleteOnTypeMismatch)
7598        ShouldDeleteForTypeMismatch = true;
7599      else {
7600        Diag(MD->getLocation(), diag::err_defaulted_special_member_variadic)
7601            << llvm::to_underlying(CSM) << MD->getSourceRange();
7602        HadError = true;
7603      }
7604    }
7605  
7606    const FunctionProtoType *Type = MD->getType()->castAs<FunctionProtoType>();
7607  
7608    bool CanHaveConstParam = false;
7609    if (CSM == CXXSpecialMemberKind::CopyConstructor)
7610      CanHaveConstParam = RD->implicitCopyConstructorHasConstParam();
7611    else if (CSM == CXXSpecialMemberKind::CopyAssignment)
7612      CanHaveConstParam = RD->implicitCopyAssignmentHasConstParam();
7613  
7614    QualType ReturnType = Context.VoidTy;
7615    if (CSM == CXXSpecialMemberKind::CopyAssignment ||
7616        CSM == CXXSpecialMemberKind::MoveAssignment) {
7617      // Check for return type matching.
7618      ReturnType = Type->getReturnType();
7619      QualType ThisType = MD->getFunctionObjectParameterType();
7620  
7621      QualType DeclType = Context.getTypeDeclType(RD);
7622      DeclType = Context.getElaboratedType(ElaboratedTypeKeyword::None, nullptr,
7623                                           DeclType, nullptr);
7624      DeclType = Context.getAddrSpaceQualType(
7625          DeclType, ThisType.getQualifiers().getAddressSpace());
7626      QualType ExpectedReturnType = Context.getLValueReferenceType(DeclType);
7627  
7628      if (!Context.hasSameType(ReturnType, ExpectedReturnType)) {
7629        Diag(MD->getLocation(), diag::err_defaulted_special_member_return_type)
7630            << (CSM == CXXSpecialMemberKind::MoveAssignment)
7631            << ExpectedReturnType;
7632        HadError = true;
7633      }
7634  
7635      // A defaulted special member cannot have cv-qualifiers.
7636      if (ThisType.isConstQualified() || ThisType.isVolatileQualified()) {
7637        if (DeleteOnTypeMismatch)
7638          ShouldDeleteForTypeMismatch = true;
7639        else {
7640          Diag(MD->getLocation(), diag::err_defaulted_special_member_quals)
7641              << (CSM == CXXSpecialMemberKind::MoveAssignment)
7642              << getLangOpts().CPlusPlus14;
7643          HadError = true;
7644        }
7645      }
7646      // [C++23][dcl.fct.def.default]/p2.2
7647      // if F2 has an implicit object parameter of type “reference to C”,
7648      // F1 may be an explicit object member function whose explicit object
7649      // parameter is of (possibly different) type “reference to C”,
7650      // in which case the type of F1 would differ from the type of F2
7651      // in that the type of F1 has an additional parameter;
7652      if (!Context.hasSameType(
7653              ThisType.getNonReferenceType().getUnqualifiedType(),
7654              Context.getRecordType(RD))) {
7655        if (DeleteOnTypeMismatch)
7656          ShouldDeleteForTypeMismatch = true;
7657        else {
7658          Diag(MD->getLocation(),
7659               diag::err_defaulted_special_member_explicit_object_mismatch)
7660              << (CSM == CXXSpecialMemberKind::MoveAssignment) << RD
7661              << MD->getSourceRange();
7662          HadError = true;
7663        }
7664      }
7665    }
7666  
7667    // Check for parameter type matching.
7668    QualType ArgType =
7669        ExpectedParams
7670            ? Type->getParamType(MD->isExplicitObjectMemberFunction() ? 1 : 0)
7671            : QualType();
7672    bool HasConstParam = false;
7673    if (ExpectedParams && ArgType->isReferenceType()) {
7674      // Argument must be reference to possibly-const T.
7675      QualType ReferentType = ArgType->getPointeeType();
7676      HasConstParam = ReferentType.isConstQualified();
7677  
7678      if (ReferentType.isVolatileQualified()) {
7679        if (DeleteOnTypeMismatch)
7680          ShouldDeleteForTypeMismatch = true;
7681        else {
7682          Diag(MD->getLocation(),
7683               diag::err_defaulted_special_member_volatile_param)
7684              << llvm::to_underlying(CSM);
7685          HadError = true;
7686        }
7687      }
7688  
7689      if (HasConstParam && !CanHaveConstParam) {
7690        if (DeleteOnTypeMismatch)
7691          ShouldDeleteForTypeMismatch = true;
7692        else if (CSM == CXXSpecialMemberKind::CopyConstructor ||
7693                 CSM == CXXSpecialMemberKind::CopyAssignment) {
7694          Diag(MD->getLocation(),
7695               diag::err_defaulted_special_member_copy_const_param)
7696              << (CSM == CXXSpecialMemberKind::CopyAssignment);
7697          // FIXME: Explain why this special member can't be const.
7698          HadError = true;
7699        } else {
7700          Diag(MD->getLocation(),
7701               diag::err_defaulted_special_member_move_const_param)
7702              << (CSM == CXXSpecialMemberKind::MoveAssignment);
7703          HadError = true;
7704        }
7705      }
7706    } else if (ExpectedParams) {
7707      // A copy assignment operator can take its argument by value, but a
7708      // defaulted one cannot.
7709      assert(CSM == CXXSpecialMemberKind::CopyAssignment &&
7710             "unexpected non-ref argument");
7711      Diag(MD->getLocation(), diag::err_defaulted_copy_assign_not_ref);
7712      HadError = true;
7713    }
7714  
7715    // C++11 [dcl.fct.def.default]p2:
7716    //   An explicitly-defaulted function may be declared constexpr only if it
7717    //   would have been implicitly declared as constexpr,
7718    // Do not apply this rule to members of class templates, since core issue 1358
7719    // makes such functions always instantiate to constexpr functions. For
7720    // functions which cannot be constexpr (for non-constructors in C++11 and for
7721    // destructors in C++14 and C++17), this is checked elsewhere.
7722    //
7723    // FIXME: This should not apply if the member is deleted.
7724    bool Constexpr = defaultedSpecialMemberIsConstexpr(*this, RD, CSM,
7725                                                       HasConstParam);
7726  
7727    // C++14 [dcl.constexpr]p6 (CWG DR647/CWG DR1358):
7728    //   If the instantiated template specialization of a constexpr function
7729    //   template or member function of a class template would fail to satisfy
7730    //   the requirements for a constexpr function or constexpr constructor, that
7731    //   specialization is still a constexpr function or constexpr constructor,
7732    //   even though a call to such a function cannot appear in a constant
7733    //   expression.
7734    if (MD->isTemplateInstantiation() && MD->isConstexpr())
7735      Constexpr = true;
7736  
7737    if ((getLangOpts().CPlusPlus20 ||
7738         (getLangOpts().CPlusPlus14 ? !isa<CXXDestructorDecl>(MD)
7739                                    : isa<CXXConstructorDecl>(MD))) &&
7740        MD->isConstexpr() && !Constexpr &&
7741        MD->getTemplatedKind() == FunctionDecl::TK_NonTemplate) {
7742          if (!MD->isConsteval() && RD->getNumVBases()) {
7743            Diag(MD->getBeginLoc(),
7744                 diag::err_incorrect_defaulted_constexpr_with_vb)
7745                << llvm::to_underlying(CSM);
7746            for (const auto &I : RD->vbases())
7747              Diag(I.getBeginLoc(), diag::note_constexpr_virtual_base_here);
7748          } else {
7749            Diag(MD->getBeginLoc(), diag::err_incorrect_defaulted_constexpr)
7750                << llvm::to_underlying(CSM) << MD->isConsteval();
7751          }
7752          HadError = true;
7753          // FIXME: Explain why the special member can't be constexpr.
7754    }
7755  
7756    if (First) {
7757      // C++2a [dcl.fct.def.default]p3:
7758      //   If a function is explicitly defaulted on its first declaration, it is
7759      //   implicitly considered to be constexpr if the implicit declaration
7760      //   would be.
7761      MD->setConstexprKind(Constexpr ? (MD->isConsteval()
7762                                            ? ConstexprSpecKind::Consteval
7763                                            : ConstexprSpecKind::Constexpr)
7764                                     : ConstexprSpecKind::Unspecified);
7765  
7766      if (!Type->hasExceptionSpec()) {
7767        // C++2a [except.spec]p3:
7768        //   If a declaration of a function does not have a noexcept-specifier
7769        //   [and] is defaulted on its first declaration, [...] the exception
7770        //   specification is as specified below
7771        FunctionProtoType::ExtProtoInfo EPI = Type->getExtProtoInfo();
7772        EPI.ExceptionSpec.Type = EST_Unevaluated;
7773        EPI.ExceptionSpec.SourceDecl = MD;
7774        MD->setType(
7775            Context.getFunctionType(ReturnType, Type->getParamTypes(), EPI));
7776      }
7777    }
7778  
7779    if (ShouldDeleteForTypeMismatch || ShouldDeleteSpecialMember(MD, CSM)) {
7780      if (First) {
7781        SetDeclDeleted(MD, MD->getLocation());
7782        if (!inTemplateInstantiation() && !HadError) {
7783          Diag(MD->getLocation(), diag::warn_defaulted_method_deleted)
7784              << llvm::to_underlying(CSM);
7785          if (ShouldDeleteForTypeMismatch) {
7786            Diag(MD->getLocation(), diag::note_deleted_type_mismatch)
7787                << llvm::to_underlying(CSM);
7788          } else if (ShouldDeleteSpecialMember(MD, CSM, nullptr,
7789                                               /*Diagnose*/ true) &&
7790                     DefaultLoc.isValid()) {
7791            Diag(DefaultLoc, diag::note_replace_equals_default_to_delete)
7792                << FixItHint::CreateReplacement(DefaultLoc, "delete");
7793          }
7794        }
7795        if (ShouldDeleteForTypeMismatch && !HadError) {
7796          Diag(MD->getLocation(),
7797               diag::warn_cxx17_compat_defaulted_method_type_mismatch)
7798              << llvm::to_underlying(CSM);
7799        }
7800      } else {
7801        // C++11 [dcl.fct.def.default]p4:
7802        //   [For a] user-provided explicitly-defaulted function [...] if such a
7803        //   function is implicitly defined as deleted, the program is ill-formed.
7804        Diag(MD->getLocation(), diag::err_out_of_line_default_deletes)
7805            << llvm::to_underlying(CSM);
7806        assert(!ShouldDeleteForTypeMismatch && "deleted non-first decl");
7807        ShouldDeleteSpecialMember(MD, CSM, nullptr, /*Diagnose*/true);
7808        HadError = true;
7809      }
7810    }
7811  
7812    return HadError;
7813  }
7814  
7815  namespace {
7816  /// Helper class for building and checking a defaulted comparison.
7817  ///
7818  /// Defaulted functions are built in two phases:
7819  ///
7820  ///  * First, the set of operations that the function will perform are
7821  ///    identified, and some of them are checked. If any of the checked
7822  ///    operations is invalid in certain ways, the comparison function is
7823  ///    defined as deleted and no body is built.
7824  ///  * Then, if the function is not defined as deleted, the body is built.
7825  ///
7826  /// This is accomplished by performing two visitation steps over the eventual
7827  /// body of the function.
7828  template<typename Derived, typename ResultList, typename Result,
7829           typename Subobject>
7830  class DefaultedComparisonVisitor {
7831  public:
7832    using DefaultedComparisonKind = Sema::DefaultedComparisonKind;
7833  
7834    DefaultedComparisonVisitor(Sema &S, CXXRecordDecl *RD, FunctionDecl *FD,
7835                               DefaultedComparisonKind DCK)
7836        : S(S), RD(RD), FD(FD), DCK(DCK) {
7837      if (auto *Info = FD->getDefalutedOrDeletedInfo()) {
7838        // FIXME: Change CreateOverloadedBinOp to take an ArrayRef instead of an
7839        // UnresolvedSet to avoid this copy.
7840        Fns.assign(Info->getUnqualifiedLookups().begin(),
7841                   Info->getUnqualifiedLookups().end());
7842      }
7843    }
7844  
7845    ResultList visit() {
7846      // The type of an lvalue naming a parameter of this function.
7847      QualType ParamLvalType =
7848          FD->getParamDecl(0)->getType().getNonReferenceType();
7849  
7850      ResultList Results;
7851  
7852      switch (DCK) {
7853      case DefaultedComparisonKind::None:
7854        llvm_unreachable("not a defaulted comparison");
7855  
7856      case DefaultedComparisonKind::Equal:
7857      case DefaultedComparisonKind::ThreeWay:
7858        getDerived().visitSubobjects(Results, RD, ParamLvalType.getQualifiers());
7859        return Results;
7860  
7861      case DefaultedComparisonKind::NotEqual:
7862      case DefaultedComparisonKind::Relational:
7863        Results.add(getDerived().visitExpandedSubobject(
7864            ParamLvalType, getDerived().getCompleteObject()));
7865        return Results;
7866      }
7867      llvm_unreachable("");
7868    }
7869  
7870  protected:
7871    Derived &getDerived() { return static_cast<Derived&>(*this); }
7872  
7873    /// Visit the expanded list of subobjects of the given type, as specified in
7874    /// C++2a [class.compare.default].
7875    ///
7876    /// \return \c true if the ResultList object said we're done, \c false if not.
7877    bool visitSubobjects(ResultList &Results, CXXRecordDecl *Record,
7878                         Qualifiers Quals) {
7879      // C++2a [class.compare.default]p4:
7880      //   The direct base class subobjects of C
7881      for (CXXBaseSpecifier &Base : Record->bases())
7882        if (Results.add(getDerived().visitSubobject(
7883                S.Context.getQualifiedType(Base.getType(), Quals),
7884                getDerived().getBase(&Base))))
7885          return true;
7886  
7887      //   followed by the non-static data members of C
7888      for (FieldDecl *Field : Record->fields()) {
7889        // C++23 [class.bit]p2:
7890        //   Unnamed bit-fields are not members ...
7891        if (Field->isUnnamedBitField())
7892          continue;
7893        // Recursively expand anonymous structs.
7894        if (Field->isAnonymousStructOrUnion()) {
7895          if (visitSubobjects(Results, Field->getType()->getAsCXXRecordDecl(),
7896                              Quals))
7897            return true;
7898          continue;
7899        }
7900  
7901        // Figure out the type of an lvalue denoting this field.
7902        Qualifiers FieldQuals = Quals;
7903        if (Field->isMutable())
7904          FieldQuals.removeConst();
7905        QualType FieldType =
7906            S.Context.getQualifiedType(Field->getType(), FieldQuals);
7907  
7908        if (Results.add(getDerived().visitSubobject(
7909                FieldType, getDerived().getField(Field))))
7910          return true;
7911      }
7912  
7913      //   form a list of subobjects.
7914      return false;
7915    }
7916  
7917    Result visitSubobject(QualType Type, Subobject Subobj) {
7918      //   In that list, any subobject of array type is recursively expanded
7919      const ArrayType *AT = S.Context.getAsArrayType(Type);
7920      if (auto *CAT = dyn_cast_or_null<ConstantArrayType>(AT))
7921        return getDerived().visitSubobjectArray(CAT->getElementType(),
7922                                                CAT->getSize(), Subobj);
7923      return getDerived().visitExpandedSubobject(Type, Subobj);
7924    }
7925  
7926    Result visitSubobjectArray(QualType Type, const llvm::APInt &Size,
7927                               Subobject Subobj) {
7928      return getDerived().visitSubobject(Type, Subobj);
7929    }
7930  
7931  protected:
7932    Sema &S;
7933    CXXRecordDecl *RD;
7934    FunctionDecl *FD;
7935    DefaultedComparisonKind DCK;
7936    UnresolvedSet<16> Fns;
7937  };
7938  
7939  /// Information about a defaulted comparison, as determined by
7940  /// DefaultedComparisonAnalyzer.
7941  struct DefaultedComparisonInfo {
7942    bool Deleted = false;
7943    bool Constexpr = true;
7944    ComparisonCategoryType Category = ComparisonCategoryType::StrongOrdering;
7945  
7946    static DefaultedComparisonInfo deleted() {
7947      DefaultedComparisonInfo Deleted;
7948      Deleted.Deleted = true;
7949      return Deleted;
7950    }
7951  
7952    bool add(const DefaultedComparisonInfo &R) {
7953      Deleted |= R.Deleted;
7954      Constexpr &= R.Constexpr;
7955      Category = commonComparisonType(Category, R.Category);
7956      return Deleted;
7957    }
7958  };
7959  
7960  /// An element in the expanded list of subobjects of a defaulted comparison, as
7961  /// specified in C++2a [class.compare.default]p4.
7962  struct DefaultedComparisonSubobject {
7963    enum { CompleteObject, Member, Base } Kind;
7964    NamedDecl *Decl;
7965    SourceLocation Loc;
7966  };
7967  
7968  /// A visitor over the notional body of a defaulted comparison that determines
7969  /// whether that body would be deleted or constexpr.
7970  class DefaultedComparisonAnalyzer
7971      : public DefaultedComparisonVisitor<DefaultedComparisonAnalyzer,
7972                                          DefaultedComparisonInfo,
7973                                          DefaultedComparisonInfo,
7974                                          DefaultedComparisonSubobject> {
7975  public:
7976    enum DiagnosticKind { NoDiagnostics, ExplainDeleted, ExplainConstexpr };
7977  
7978  private:
7979    DiagnosticKind Diagnose;
7980  
7981  public:
7982    using Base = DefaultedComparisonVisitor;
7983    using Result = DefaultedComparisonInfo;
7984    using Subobject = DefaultedComparisonSubobject;
7985  
7986    friend Base;
7987  
7988    DefaultedComparisonAnalyzer(Sema &S, CXXRecordDecl *RD, FunctionDecl *FD,
7989                                DefaultedComparisonKind DCK,
7990                                DiagnosticKind Diagnose = NoDiagnostics)
7991        : Base(S, RD, FD, DCK), Diagnose(Diagnose) {}
7992  
7993    Result visit() {
7994      if ((DCK == DefaultedComparisonKind::Equal ||
7995           DCK == DefaultedComparisonKind::ThreeWay) &&
7996          RD->hasVariantMembers()) {
7997        // C++2a [class.compare.default]p2 [P2002R0]:
7998        //   A defaulted comparison operator function for class C is defined as
7999        //   deleted if [...] C has variant members.
8000        if (Diagnose == ExplainDeleted) {
8001          S.Diag(FD->getLocation(), diag::note_defaulted_comparison_union)
8002            << FD << RD->isUnion() << RD;
8003        }
8004        return Result::deleted();
8005      }
8006  
8007      return Base::visit();
8008    }
8009  
8010  private:
8011    Subobject getCompleteObject() {
8012      return Subobject{Subobject::CompleteObject, RD, FD->getLocation()};
8013    }
8014  
8015    Subobject getBase(CXXBaseSpecifier *Base) {
8016      return Subobject{Subobject::Base, Base->getType()->getAsCXXRecordDecl(),
8017                       Base->getBaseTypeLoc()};
8018    }
8019  
8020    Subobject getField(FieldDecl *Field) {
8021      return Subobject{Subobject::Member, Field, Field->getLocation()};
8022    }
8023  
8024    Result visitExpandedSubobject(QualType Type, Subobject Subobj) {
8025      // C++2a [class.compare.default]p2 [P2002R0]:
8026      //   A defaulted <=> or == operator function for class C is defined as
8027      //   deleted if any non-static data member of C is of reference type
8028      if (Type->isReferenceType()) {
8029        if (Diagnose == ExplainDeleted) {
8030          S.Diag(Subobj.Loc, diag::note_defaulted_comparison_reference_member)
8031              << FD << RD;
8032        }
8033        return Result::deleted();
8034      }
8035  
8036      // [...] Let xi be an lvalue denoting the ith element [...]
8037      OpaqueValueExpr Xi(FD->getLocation(), Type, VK_LValue);
8038      Expr *Args[] = {&Xi, &Xi};
8039  
8040      // All operators start by trying to apply that same operator recursively.
8041      OverloadedOperatorKind OO = FD->getOverloadedOperator();
8042      assert(OO != OO_None && "not an overloaded operator!");
8043      return visitBinaryOperator(OO, Args, Subobj);
8044    }
8045  
8046    Result
8047    visitBinaryOperator(OverloadedOperatorKind OO, ArrayRef<Expr *> Args,
8048                        Subobject Subobj,
8049                        OverloadCandidateSet *SpaceshipCandidates = nullptr) {
8050      // Note that there is no need to consider rewritten candidates here if
8051      // we've already found there is no viable 'operator<=>' candidate (and are
8052      // considering synthesizing a '<=>' from '==' and '<').
8053      OverloadCandidateSet CandidateSet(
8054          FD->getLocation(), OverloadCandidateSet::CSK_Operator,
8055          OverloadCandidateSet::OperatorRewriteInfo(
8056              OO, FD->getLocation(),
8057              /*AllowRewrittenCandidates=*/!SpaceshipCandidates));
8058  
8059      /// C++2a [class.compare.default]p1 [P2002R0]:
8060      ///   [...] the defaulted function itself is never a candidate for overload
8061      ///   resolution [...]
8062      CandidateSet.exclude(FD);
8063  
8064      if (Args[0]->getType()->isOverloadableType())
8065        S.LookupOverloadedBinOp(CandidateSet, OO, Fns, Args);
8066      else
8067        // FIXME: We determine whether this is a valid expression by checking to
8068        // see if there's a viable builtin operator candidate for it. That isn't
8069        // really what the rules ask us to do, but should give the right results.
8070        S.AddBuiltinOperatorCandidates(OO, FD->getLocation(), Args, CandidateSet);
8071  
8072      Result R;
8073  
8074      OverloadCandidateSet::iterator Best;
8075      switch (CandidateSet.BestViableFunction(S, FD->getLocation(), Best)) {
8076      case OR_Success: {
8077        // C++2a [class.compare.secondary]p2 [P2002R0]:
8078        //   The operator function [...] is defined as deleted if [...] the
8079        //   candidate selected by overload resolution is not a rewritten
8080        //   candidate.
8081        if ((DCK == DefaultedComparisonKind::NotEqual ||
8082             DCK == DefaultedComparisonKind::Relational) &&
8083            !Best->RewriteKind) {
8084          if (Diagnose == ExplainDeleted) {
8085            if (Best->Function) {
8086              S.Diag(Best->Function->getLocation(),
8087                     diag::note_defaulted_comparison_not_rewritten_callee)
8088                  << FD;
8089            } else {
8090              assert(Best->Conversions.size() == 2 &&
8091                     Best->Conversions[0].isUserDefined() &&
8092                     "non-user-defined conversion from class to built-in "
8093                     "comparison");
8094              S.Diag(Best->Conversions[0]
8095                         .UserDefined.FoundConversionFunction.getDecl()
8096                         ->getLocation(),
8097                     diag::note_defaulted_comparison_not_rewritten_conversion)
8098                  << FD;
8099            }
8100          }
8101          return Result::deleted();
8102        }
8103  
8104        // Throughout C++2a [class.compare]: if overload resolution does not
8105        // result in a usable function, the candidate function is defined as
8106        // deleted. This requires that we selected an accessible function.
8107        //
8108        // Note that this only considers the access of the function when named
8109        // within the type of the subobject, and not the access path for any
8110        // derived-to-base conversion.
8111        CXXRecordDecl *ArgClass = Args[0]->getType()->getAsCXXRecordDecl();
8112        if (ArgClass && Best->FoundDecl.getDecl() &&
8113            Best->FoundDecl.getDecl()->isCXXClassMember()) {
8114          QualType ObjectType = Subobj.Kind == Subobject::Member
8115                                    ? Args[0]->getType()
8116                                    : S.Context.getRecordType(RD);
8117          if (!S.isMemberAccessibleForDeletion(
8118                  ArgClass, Best->FoundDecl, ObjectType, Subobj.Loc,
8119                  Diagnose == ExplainDeleted
8120                      ? S.PDiag(diag::note_defaulted_comparison_inaccessible)
8121                            << FD << Subobj.Kind << Subobj.Decl
8122                      : S.PDiag()))
8123            return Result::deleted();
8124        }
8125  
8126        bool NeedsDeducing =
8127            OO == OO_Spaceship && FD->getReturnType()->isUndeducedAutoType();
8128  
8129        if (FunctionDecl *BestFD = Best->Function) {
8130          // C++2a [class.compare.default]p3 [P2002R0]:
8131          //   A defaulted comparison function is constexpr-compatible if
8132          //   [...] no overlod resolution performed [...] results in a
8133          //   non-constexpr function.
8134          assert(!BestFD->isDeleted() && "wrong overload resolution result");
8135          // If it's not constexpr, explain why not.
8136          if (Diagnose == ExplainConstexpr && !BestFD->isConstexpr()) {
8137            if (Subobj.Kind != Subobject::CompleteObject)
8138              S.Diag(Subobj.Loc, diag::note_defaulted_comparison_not_constexpr)
8139                << Subobj.Kind << Subobj.Decl;
8140            S.Diag(BestFD->getLocation(),
8141                   diag::note_defaulted_comparison_not_constexpr_here);
8142            // Bail out after explaining; we don't want any more notes.
8143            return Result::deleted();
8144          }
8145          R.Constexpr &= BestFD->isConstexpr();
8146  
8147          if (NeedsDeducing) {
8148            // If any callee has an undeduced return type, deduce it now.
8149            // FIXME: It's not clear how a failure here should be handled. For
8150            // now, we produce an eager diagnostic, because that is forward
8151            // compatible with most (all?) other reasonable options.
8152            if (BestFD->getReturnType()->isUndeducedType() &&
8153                S.DeduceReturnType(BestFD, FD->getLocation(),
8154                                   /*Diagnose=*/false)) {
8155              // Don't produce a duplicate error when asked to explain why the
8156              // comparison is deleted: we diagnosed that when initially checking
8157              // the defaulted operator.
8158              if (Diagnose == NoDiagnostics) {
8159                S.Diag(
8160                    FD->getLocation(),
8161                    diag::err_defaulted_comparison_cannot_deduce_undeduced_auto)
8162                    << Subobj.Kind << Subobj.Decl;
8163                S.Diag(
8164                    Subobj.Loc,
8165                    diag::note_defaulted_comparison_cannot_deduce_undeduced_auto)
8166                    << Subobj.Kind << Subobj.Decl;
8167                S.Diag(BestFD->getLocation(),
8168                       diag::note_defaulted_comparison_cannot_deduce_callee)
8169                    << Subobj.Kind << Subobj.Decl;
8170              }
8171              return Result::deleted();
8172            }
8173            auto *Info = S.Context.CompCategories.lookupInfoForType(
8174                BestFD->getCallResultType());
8175            if (!Info) {
8176              if (Diagnose == ExplainDeleted) {
8177                S.Diag(Subobj.Loc, diag::note_defaulted_comparison_cannot_deduce)
8178                    << Subobj.Kind << Subobj.Decl
8179                    << BestFD->getCallResultType().withoutLocalFastQualifiers();
8180                S.Diag(BestFD->getLocation(),
8181                       diag::note_defaulted_comparison_cannot_deduce_callee)
8182                    << Subobj.Kind << Subobj.Decl;
8183              }
8184              return Result::deleted();
8185            }
8186            R.Category = Info->Kind;
8187          }
8188        } else {
8189          QualType T = Best->BuiltinParamTypes[0];
8190          assert(T == Best->BuiltinParamTypes[1] &&
8191                 "builtin comparison for different types?");
8192          assert(Best->BuiltinParamTypes[2].isNull() &&
8193                 "invalid builtin comparison");
8194  
8195          if (NeedsDeducing) {
8196            std::optional<ComparisonCategoryType> Cat =
8197                getComparisonCategoryForBuiltinCmp(T);
8198            assert(Cat && "no category for builtin comparison?");
8199            R.Category = *Cat;
8200          }
8201        }
8202  
8203        // Note that we might be rewriting to a different operator. That call is
8204        // not considered until we come to actually build the comparison function.
8205        break;
8206      }
8207  
8208      case OR_Ambiguous:
8209        if (Diagnose == ExplainDeleted) {
8210          unsigned Kind = 0;
8211          if (FD->getOverloadedOperator() == OO_Spaceship && OO != OO_Spaceship)
8212            Kind = OO == OO_EqualEqual ? 1 : 2;
8213          CandidateSet.NoteCandidates(
8214              PartialDiagnosticAt(
8215                  Subobj.Loc, S.PDiag(diag::note_defaulted_comparison_ambiguous)
8216                                  << FD << Kind << Subobj.Kind << Subobj.Decl),
8217              S, OCD_AmbiguousCandidates, Args);
8218        }
8219        R = Result::deleted();
8220        break;
8221  
8222      case OR_Deleted:
8223        if (Diagnose == ExplainDeleted) {
8224          if ((DCK == DefaultedComparisonKind::NotEqual ||
8225               DCK == DefaultedComparisonKind::Relational) &&
8226              !Best->RewriteKind) {
8227            S.Diag(Best->Function->getLocation(),
8228                   diag::note_defaulted_comparison_not_rewritten_callee)
8229                << FD;
8230          } else {
8231            S.Diag(Subobj.Loc,
8232                   diag::note_defaulted_comparison_calls_deleted)
8233                << FD << Subobj.Kind << Subobj.Decl;
8234            S.NoteDeletedFunction(Best->Function);
8235          }
8236        }
8237        R = Result::deleted();
8238        break;
8239  
8240      case OR_No_Viable_Function:
8241        // If there's no usable candidate, we're done unless we can rewrite a
8242        // '<=>' in terms of '==' and '<'.
8243        if (OO == OO_Spaceship &&
8244            S.Context.CompCategories.lookupInfoForType(FD->getReturnType())) {
8245          // For any kind of comparison category return type, we need a usable
8246          // '==' and a usable '<'.
8247          if (!R.add(visitBinaryOperator(OO_EqualEqual, Args, Subobj,
8248                                         &CandidateSet)))
8249            R.add(visitBinaryOperator(OO_Less, Args, Subobj, &CandidateSet));
8250          break;
8251        }
8252  
8253        if (Diagnose == ExplainDeleted) {
8254          S.Diag(Subobj.Loc, diag::note_defaulted_comparison_no_viable_function)
8255              << FD << (OO == OO_EqualEqual || OO == OO_ExclaimEqual)
8256              << Subobj.Kind << Subobj.Decl;
8257  
8258          // For a three-way comparison, list both the candidates for the
8259          // original operator and the candidates for the synthesized operator.
8260          if (SpaceshipCandidates) {
8261            SpaceshipCandidates->NoteCandidates(
8262                S, Args,
8263                SpaceshipCandidates->CompleteCandidates(S, OCD_AllCandidates,
8264                                                        Args, FD->getLocation()));
8265            S.Diag(Subobj.Loc,
8266                   diag::note_defaulted_comparison_no_viable_function_synthesized)
8267                << (OO == OO_EqualEqual ? 0 : 1);
8268          }
8269  
8270          CandidateSet.NoteCandidates(
8271              S, Args,
8272              CandidateSet.CompleteCandidates(S, OCD_AllCandidates, Args,
8273                                              FD->getLocation()));
8274        }
8275        R = Result::deleted();
8276        break;
8277      }
8278  
8279      return R;
8280    }
8281  };
8282  
8283  /// A list of statements.
8284  struct StmtListResult {
8285    bool IsInvalid = false;
8286    llvm::SmallVector<Stmt*, 16> Stmts;
8287  
8288    bool add(const StmtResult &S) {
8289      IsInvalid |= S.isInvalid();
8290      if (IsInvalid)
8291        return true;
8292      Stmts.push_back(S.get());
8293      return false;
8294    }
8295  };
8296  
8297  /// A visitor over the notional body of a defaulted comparison that synthesizes
8298  /// the actual body.
8299  class DefaultedComparisonSynthesizer
8300      : public DefaultedComparisonVisitor<DefaultedComparisonSynthesizer,
8301                                          StmtListResult, StmtResult,
8302                                          std::pair<ExprResult, ExprResult>> {
8303    SourceLocation Loc;
8304    unsigned ArrayDepth = 0;
8305  
8306  public:
8307    using Base = DefaultedComparisonVisitor;
8308    using ExprPair = std::pair<ExprResult, ExprResult>;
8309  
8310    friend Base;
8311  
8312    DefaultedComparisonSynthesizer(Sema &S, CXXRecordDecl *RD, FunctionDecl *FD,
8313                                   DefaultedComparisonKind DCK,
8314                                   SourceLocation BodyLoc)
8315        : Base(S, RD, FD, DCK), Loc(BodyLoc) {}
8316  
8317    /// Build a suitable function body for this defaulted comparison operator.
8318    StmtResult build() {
8319      Sema::CompoundScopeRAII CompoundScope(S);
8320  
8321      StmtListResult Stmts = visit();
8322      if (Stmts.IsInvalid)
8323        return StmtError();
8324  
8325      ExprResult RetVal;
8326      switch (DCK) {
8327      case DefaultedComparisonKind::None:
8328        llvm_unreachable("not a defaulted comparison");
8329  
8330      case DefaultedComparisonKind::Equal: {
8331        // C++2a [class.eq]p3:
8332        //   [...] compar[e] the corresponding elements [...] until the first
8333        //   index i where xi == yi yields [...] false. If no such index exists,
8334        //   V is true. Otherwise, V is false.
8335        //
8336        // Join the comparisons with '&&'s and return the result. Use a right
8337        // fold (traversing the conditions right-to-left), because that
8338        // short-circuits more naturally.
8339        auto OldStmts = std::move(Stmts.Stmts);
8340        Stmts.Stmts.clear();
8341        ExprResult CmpSoFar;
8342        // Finish a particular comparison chain.
8343        auto FinishCmp = [&] {
8344          if (Expr *Prior = CmpSoFar.get()) {
8345            // Convert the last expression to 'return ...;'
8346            if (RetVal.isUnset() && Stmts.Stmts.empty())
8347              RetVal = CmpSoFar;
8348            // Convert any prior comparison to 'if (!(...)) return false;'
8349            else if (Stmts.add(buildIfNotCondReturnFalse(Prior)))
8350              return true;
8351            CmpSoFar = ExprResult();
8352          }
8353          return false;
8354        };
8355        for (Stmt *EAsStmt : llvm::reverse(OldStmts)) {
8356          Expr *E = dyn_cast<Expr>(EAsStmt);
8357          if (!E) {
8358            // Found an array comparison.
8359            if (FinishCmp() || Stmts.add(EAsStmt))
8360              return StmtError();
8361            continue;
8362          }
8363  
8364          if (CmpSoFar.isUnset()) {
8365            CmpSoFar = E;
8366            continue;
8367          }
8368          CmpSoFar = S.CreateBuiltinBinOp(Loc, BO_LAnd, E, CmpSoFar.get());
8369          if (CmpSoFar.isInvalid())
8370            return StmtError();
8371        }
8372        if (FinishCmp())
8373          return StmtError();
8374        std::reverse(Stmts.Stmts.begin(), Stmts.Stmts.end());
8375        //   If no such index exists, V is true.
8376        if (RetVal.isUnset())
8377          RetVal = S.ActOnCXXBoolLiteral(Loc, tok::kw_true);
8378        break;
8379      }
8380  
8381      case DefaultedComparisonKind::ThreeWay: {
8382        // Per C++2a [class.spaceship]p3, as a fallback add:
8383        // return static_cast<R>(std::strong_ordering::equal);
8384        QualType StrongOrdering = S.CheckComparisonCategoryType(
8385            ComparisonCategoryType::StrongOrdering, Loc,
8386            Sema::ComparisonCategoryUsage::DefaultedOperator);
8387        if (StrongOrdering.isNull())
8388          return StmtError();
8389        VarDecl *EqualVD = S.Context.CompCategories.getInfoForType(StrongOrdering)
8390                               .getValueInfo(ComparisonCategoryResult::Equal)
8391                               ->VD;
8392        RetVal = getDecl(EqualVD);
8393        if (RetVal.isInvalid())
8394          return StmtError();
8395        RetVal = buildStaticCastToR(RetVal.get());
8396        break;
8397      }
8398  
8399      case DefaultedComparisonKind::NotEqual:
8400      case DefaultedComparisonKind::Relational:
8401        RetVal = cast<Expr>(Stmts.Stmts.pop_back_val());
8402        break;
8403      }
8404  
8405      // Build the final return statement.
8406      if (RetVal.isInvalid())
8407        return StmtError();
8408      StmtResult ReturnStmt = S.BuildReturnStmt(Loc, RetVal.get());
8409      if (ReturnStmt.isInvalid())
8410        return StmtError();
8411      Stmts.Stmts.push_back(ReturnStmt.get());
8412  
8413      return S.ActOnCompoundStmt(Loc, Loc, Stmts.Stmts, /*IsStmtExpr=*/false);
8414    }
8415  
8416  private:
8417    ExprResult getDecl(ValueDecl *VD) {
8418      return S.BuildDeclarationNameExpr(
8419          CXXScopeSpec(), DeclarationNameInfo(VD->getDeclName(), Loc), VD);
8420    }
8421  
8422    ExprResult getParam(unsigned I) {
8423      ParmVarDecl *PD = FD->getParamDecl(I);
8424      return getDecl(PD);
8425    }
8426  
8427    ExprPair getCompleteObject() {
8428      unsigned Param = 0;
8429      ExprResult LHS;
8430      if (const auto *MD = dyn_cast<CXXMethodDecl>(FD);
8431          MD && MD->isImplicitObjectMemberFunction()) {
8432        // LHS is '*this'.
8433        LHS = S.ActOnCXXThis(Loc);
8434        if (!LHS.isInvalid())
8435          LHS = S.CreateBuiltinUnaryOp(Loc, UO_Deref, LHS.get());
8436      } else {
8437        LHS = getParam(Param++);
8438      }
8439      ExprResult RHS = getParam(Param++);
8440      assert(Param == FD->getNumParams());
8441      return {LHS, RHS};
8442    }
8443  
8444    ExprPair getBase(CXXBaseSpecifier *Base) {
8445      ExprPair Obj = getCompleteObject();
8446      if (Obj.first.isInvalid() || Obj.second.isInvalid())
8447        return {ExprError(), ExprError()};
8448      CXXCastPath Path = {Base};
8449      return {S.ImpCastExprToType(Obj.first.get(), Base->getType(),
8450                                  CK_DerivedToBase, VK_LValue, &Path),
8451              S.ImpCastExprToType(Obj.second.get(), Base->getType(),
8452                                  CK_DerivedToBase, VK_LValue, &Path)};
8453    }
8454  
8455    ExprPair getField(FieldDecl *Field) {
8456      ExprPair Obj = getCompleteObject();
8457      if (Obj.first.isInvalid() || Obj.second.isInvalid())
8458        return {ExprError(), ExprError()};
8459  
8460      DeclAccessPair Found = DeclAccessPair::make(Field, Field->getAccess());
8461      DeclarationNameInfo NameInfo(Field->getDeclName(), Loc);
8462      return {S.BuildFieldReferenceExpr(Obj.first.get(), /*IsArrow=*/false, Loc,
8463                                        CXXScopeSpec(), Field, Found, NameInfo),
8464              S.BuildFieldReferenceExpr(Obj.second.get(), /*IsArrow=*/false, Loc,
8465                                        CXXScopeSpec(), Field, Found, NameInfo)};
8466    }
8467  
8468    // FIXME: When expanding a subobject, register a note in the code synthesis
8469    // stack to say which subobject we're comparing.
8470  
8471    StmtResult buildIfNotCondReturnFalse(ExprResult Cond) {
8472      if (Cond.isInvalid())
8473        return StmtError();
8474  
8475      ExprResult NotCond = S.CreateBuiltinUnaryOp(Loc, UO_LNot, Cond.get());
8476      if (NotCond.isInvalid())
8477        return StmtError();
8478  
8479      ExprResult False = S.ActOnCXXBoolLiteral(Loc, tok::kw_false);
8480      assert(!False.isInvalid() && "should never fail");
8481      StmtResult ReturnFalse = S.BuildReturnStmt(Loc, False.get());
8482      if (ReturnFalse.isInvalid())
8483        return StmtError();
8484  
8485      return S.ActOnIfStmt(Loc, IfStatementKind::Ordinary, Loc, nullptr,
8486                           S.ActOnCondition(nullptr, Loc, NotCond.get(),
8487                                            Sema::ConditionKind::Boolean),
8488                           Loc, ReturnFalse.get(), SourceLocation(), nullptr);
8489    }
8490  
8491    StmtResult visitSubobjectArray(QualType Type, llvm::APInt Size,
8492                                   ExprPair Subobj) {
8493      QualType SizeType = S.Context.getSizeType();
8494      Size = Size.zextOrTrunc(S.Context.getTypeSize(SizeType));
8495  
8496      // Build 'size_t i$n = 0'.
8497      IdentifierInfo *IterationVarName = nullptr;
8498      {
8499        SmallString<8> Str;
8500        llvm::raw_svector_ostream OS(Str);
8501        OS << "i" << ArrayDepth;
8502        IterationVarName = &S.Context.Idents.get(OS.str());
8503      }
8504      VarDecl *IterationVar = VarDecl::Create(
8505          S.Context, S.CurContext, Loc, Loc, IterationVarName, SizeType,
8506          S.Context.getTrivialTypeSourceInfo(SizeType, Loc), SC_None);
8507      llvm::APInt Zero(S.Context.getTypeSize(SizeType), 0);
8508      IterationVar->setInit(
8509          IntegerLiteral::Create(S.Context, Zero, SizeType, Loc));
8510      Stmt *Init = new (S.Context) DeclStmt(DeclGroupRef(IterationVar), Loc, Loc);
8511  
8512      auto IterRef = [&] {
8513        ExprResult Ref = S.BuildDeclarationNameExpr(
8514            CXXScopeSpec(), DeclarationNameInfo(IterationVarName, Loc),
8515            IterationVar);
8516        assert(!Ref.isInvalid() && "can't reference our own variable?");
8517        return Ref.get();
8518      };
8519  
8520      // Build 'i$n != Size'.
8521      ExprResult Cond = S.CreateBuiltinBinOp(
8522          Loc, BO_NE, IterRef(),
8523          IntegerLiteral::Create(S.Context, Size, SizeType, Loc));
8524      assert(!Cond.isInvalid() && "should never fail");
8525  
8526      // Build '++i$n'.
8527      ExprResult Inc = S.CreateBuiltinUnaryOp(Loc, UO_PreInc, IterRef());
8528      assert(!Inc.isInvalid() && "should never fail");
8529  
8530      // Build 'a[i$n]' and 'b[i$n]'.
8531      auto Index = [&](ExprResult E) {
8532        if (E.isInvalid())
8533          return ExprError();
8534        return S.CreateBuiltinArraySubscriptExpr(E.get(), Loc, IterRef(), Loc);
8535      };
8536      Subobj.first = Index(Subobj.first);
8537      Subobj.second = Index(Subobj.second);
8538  
8539      // Compare the array elements.
8540      ++ArrayDepth;
8541      StmtResult Substmt = visitSubobject(Type, Subobj);
8542      --ArrayDepth;
8543  
8544      if (Substmt.isInvalid())
8545        return StmtError();
8546  
8547      // For the inner level of an 'operator==', build 'if (!cmp) return false;'.
8548      // For outer levels or for an 'operator<=>' we already have a suitable
8549      // statement that returns as necessary.
8550      if (Expr *ElemCmp = dyn_cast<Expr>(Substmt.get())) {
8551        assert(DCK == DefaultedComparisonKind::Equal &&
8552               "should have non-expression statement");
8553        Substmt = buildIfNotCondReturnFalse(ElemCmp);
8554        if (Substmt.isInvalid())
8555          return StmtError();
8556      }
8557  
8558      // Build 'for (...) ...'
8559      return S.ActOnForStmt(Loc, Loc, Init,
8560                            S.ActOnCondition(nullptr, Loc, Cond.get(),
8561                                             Sema::ConditionKind::Boolean),
8562                            S.MakeFullDiscardedValueExpr(Inc.get()), Loc,
8563                            Substmt.get());
8564    }
8565  
8566    StmtResult visitExpandedSubobject(QualType Type, ExprPair Obj) {
8567      if (Obj.first.isInvalid() || Obj.second.isInvalid())
8568        return StmtError();
8569  
8570      OverloadedOperatorKind OO = FD->getOverloadedOperator();
8571      BinaryOperatorKind Opc = BinaryOperator::getOverloadedOpcode(OO);
8572      ExprResult Op;
8573      if (Type->isOverloadableType())
8574        Op = S.CreateOverloadedBinOp(Loc, Opc, Fns, Obj.first.get(),
8575                                     Obj.second.get(), /*PerformADL=*/true,
8576                                     /*AllowRewrittenCandidates=*/true, FD);
8577      else
8578        Op = S.CreateBuiltinBinOp(Loc, Opc, Obj.first.get(), Obj.second.get());
8579      if (Op.isInvalid())
8580        return StmtError();
8581  
8582      switch (DCK) {
8583      case DefaultedComparisonKind::None:
8584        llvm_unreachable("not a defaulted comparison");
8585  
8586      case DefaultedComparisonKind::Equal:
8587        // Per C++2a [class.eq]p2, each comparison is individually contextually
8588        // converted to bool.
8589        Op = S.PerformContextuallyConvertToBool(Op.get());
8590        if (Op.isInvalid())
8591          return StmtError();
8592        return Op.get();
8593  
8594      case DefaultedComparisonKind::ThreeWay: {
8595        // Per C++2a [class.spaceship]p3, form:
8596        //   if (R cmp = static_cast<R>(op); cmp != 0)
8597        //     return cmp;
8598        QualType R = FD->getReturnType();
8599        Op = buildStaticCastToR(Op.get());
8600        if (Op.isInvalid())
8601          return StmtError();
8602  
8603        // R cmp = ...;
8604        IdentifierInfo *Name = &S.Context.Idents.get("cmp");
8605        VarDecl *VD =
8606            VarDecl::Create(S.Context, S.CurContext, Loc, Loc, Name, R,
8607                            S.Context.getTrivialTypeSourceInfo(R, Loc), SC_None);
8608        S.AddInitializerToDecl(VD, Op.get(), /*DirectInit=*/false);
8609        Stmt *InitStmt = new (S.Context) DeclStmt(DeclGroupRef(VD), Loc, Loc);
8610  
8611        // cmp != 0
8612        ExprResult VDRef = getDecl(VD);
8613        if (VDRef.isInvalid())
8614          return StmtError();
8615        llvm::APInt ZeroVal(S.Context.getIntWidth(S.Context.IntTy), 0);
8616        Expr *Zero =
8617            IntegerLiteral::Create(S.Context, ZeroVal, S.Context.IntTy, Loc);
8618        ExprResult Comp;
8619        if (VDRef.get()->getType()->isOverloadableType())
8620          Comp = S.CreateOverloadedBinOp(Loc, BO_NE, Fns, VDRef.get(), Zero, true,
8621                                         true, FD);
8622        else
8623          Comp = S.CreateBuiltinBinOp(Loc, BO_NE, VDRef.get(), Zero);
8624        if (Comp.isInvalid())
8625          return StmtError();
8626        Sema::ConditionResult Cond = S.ActOnCondition(
8627            nullptr, Loc, Comp.get(), Sema::ConditionKind::Boolean);
8628        if (Cond.isInvalid())
8629          return StmtError();
8630  
8631        // return cmp;
8632        VDRef = getDecl(VD);
8633        if (VDRef.isInvalid())
8634          return StmtError();
8635        StmtResult ReturnStmt = S.BuildReturnStmt(Loc, VDRef.get());
8636        if (ReturnStmt.isInvalid())
8637          return StmtError();
8638  
8639        // if (...)
8640        return S.ActOnIfStmt(Loc, IfStatementKind::Ordinary, Loc, InitStmt, Cond,
8641                             Loc, ReturnStmt.get(),
8642                             /*ElseLoc=*/SourceLocation(), /*Else=*/nullptr);
8643      }
8644  
8645      case DefaultedComparisonKind::NotEqual:
8646      case DefaultedComparisonKind::Relational:
8647        // C++2a [class.compare.secondary]p2:
8648        //   Otherwise, the operator function yields x @ y.
8649        return Op.get();
8650      }
8651      llvm_unreachable("");
8652    }
8653  
8654    /// Build "static_cast<R>(E)".
8655    ExprResult buildStaticCastToR(Expr *E) {
8656      QualType R = FD->getReturnType();
8657      assert(!R->isUndeducedType() && "type should have been deduced already");
8658  
8659      // Don't bother forming a no-op cast in the common case.
8660      if (E->isPRValue() && S.Context.hasSameType(E->getType(), R))
8661        return E;
8662      return S.BuildCXXNamedCast(Loc, tok::kw_static_cast,
8663                                 S.Context.getTrivialTypeSourceInfo(R, Loc), E,
8664                                 SourceRange(Loc, Loc), SourceRange(Loc, Loc));
8665    }
8666  };
8667  }
8668  
8669  /// Perform the unqualified lookups that might be needed to form a defaulted
8670  /// comparison function for the given operator.
8671  static void lookupOperatorsForDefaultedComparison(Sema &Self, Scope *S,
8672                                                    UnresolvedSetImpl &Operators,
8673                                                    OverloadedOperatorKind Op) {
8674    auto Lookup = [&](OverloadedOperatorKind OO) {
8675      Self.LookupOverloadedOperatorName(OO, S, Operators);
8676    };
8677  
8678    // Every defaulted operator looks up itself.
8679    Lookup(Op);
8680    // ... and the rewritten form of itself, if any.
8681    if (OverloadedOperatorKind ExtraOp = getRewrittenOverloadedOperator(Op))
8682      Lookup(ExtraOp);
8683  
8684    // For 'operator<=>', we also form a 'cmp != 0' expression, and might
8685    // synthesize a three-way comparison from '<' and '=='. In a dependent
8686    // context, we also need to look up '==' in case we implicitly declare a
8687    // defaulted 'operator=='.
8688    if (Op == OO_Spaceship) {
8689      Lookup(OO_ExclaimEqual);
8690      Lookup(OO_Less);
8691      Lookup(OO_EqualEqual);
8692    }
8693  }
8694  
8695  bool Sema::CheckExplicitlyDefaultedComparison(Scope *S, FunctionDecl *FD,
8696                                                DefaultedComparisonKind DCK) {
8697    assert(DCK != DefaultedComparisonKind::None && "not a defaulted comparison");
8698  
8699    // Perform any unqualified lookups we're going to need to default this
8700    // function.
8701    if (S) {
8702      UnresolvedSet<32> Operators;
8703      lookupOperatorsForDefaultedComparison(*this, S, Operators,
8704                                            FD->getOverloadedOperator());
8705      FD->setDefaultedOrDeletedInfo(
8706          FunctionDecl::DefaultedOrDeletedFunctionInfo::Create(
8707              Context, Operators.pairs()));
8708    }
8709  
8710    // C++2a [class.compare.default]p1:
8711    //   A defaulted comparison operator function for some class C shall be a
8712    //   non-template function declared in the member-specification of C that is
8713    //    -- a non-static const non-volatile member of C having one parameter of
8714    //       type const C& and either no ref-qualifier or the ref-qualifier &, or
8715    //    -- a friend of C having two parameters of type const C& or two
8716    //       parameters of type C.
8717  
8718    CXXRecordDecl *RD = dyn_cast<CXXRecordDecl>(FD->getLexicalDeclContext());
8719    bool IsMethod = isa<CXXMethodDecl>(FD);
8720    if (IsMethod) {
8721      auto *MD = cast<CXXMethodDecl>(FD);
8722      assert(!MD->isStatic() && "comparison function cannot be a static member");
8723  
8724      if (MD->getRefQualifier() == RQ_RValue) {
8725        Diag(MD->getLocation(), diag::err_ref_qualifier_comparison_operator);
8726  
8727        // Remove the ref qualifier to recover.
8728        const auto *FPT = MD->getType()->castAs<FunctionProtoType>();
8729        FunctionProtoType::ExtProtoInfo EPI = FPT->getExtProtoInfo();
8730        EPI.RefQualifier = RQ_None;
8731        MD->setType(Context.getFunctionType(FPT->getReturnType(),
8732                                            FPT->getParamTypes(), EPI));
8733      }
8734  
8735      // If we're out-of-class, this is the class we're comparing.
8736      if (!RD)
8737        RD = MD->getParent();
8738      QualType T = MD->getFunctionObjectParameterType();
8739      if (!T.isConstQualified()) {
8740        SourceLocation Loc, InsertLoc;
8741        if (MD->isExplicitObjectMemberFunction()) {
8742          Loc = MD->getParamDecl(0)->getBeginLoc();
8743          InsertLoc = getLocForEndOfToken(
8744              MD->getParamDecl(0)->getExplicitObjectParamThisLoc());
8745        } else {
8746          Loc = MD->getLocation();
8747          if (FunctionTypeLoc Loc = MD->getFunctionTypeLoc())
8748            InsertLoc = Loc.getRParenLoc();
8749        }
8750        // Don't diagnose an implicit 'operator=='; we will have diagnosed the
8751        // corresponding defaulted 'operator<=>' already.
8752        if (!MD->isImplicit()) {
8753          Diag(Loc, diag::err_defaulted_comparison_non_const)
8754              << (int)DCK << FixItHint::CreateInsertion(InsertLoc, " const");
8755        }
8756  
8757        // Add the 'const' to the type to recover.
8758        const auto *FPT = MD->getType()->castAs<FunctionProtoType>();
8759        FunctionProtoType::ExtProtoInfo EPI = FPT->getExtProtoInfo();
8760        EPI.TypeQuals.addConst();
8761        MD->setType(Context.getFunctionType(FPT->getReturnType(),
8762                                            FPT->getParamTypes(), EPI));
8763      }
8764  
8765      if (MD->isVolatile()) {
8766        Diag(MD->getLocation(), diag::err_volatile_comparison_operator);
8767  
8768        // Remove the 'volatile' from the type to recover.
8769        const auto *FPT = MD->getType()->castAs<FunctionProtoType>();
8770        FunctionProtoType::ExtProtoInfo EPI = FPT->getExtProtoInfo();
8771        EPI.TypeQuals.removeVolatile();
8772        MD->setType(Context.getFunctionType(FPT->getReturnType(),
8773                                            FPT->getParamTypes(), EPI));
8774      }
8775    }
8776  
8777    if ((FD->getNumParams() -
8778         (unsigned)FD->hasCXXExplicitFunctionObjectParameter()) !=
8779        (IsMethod ? 1 : 2)) {
8780      // Let's not worry about using a variadic template pack here -- who would do
8781      // such a thing?
8782      Diag(FD->getLocation(), diag::err_defaulted_comparison_num_args)
8783          << int(IsMethod) << int(DCK);
8784      return true;
8785    }
8786  
8787    const ParmVarDecl *KnownParm = nullptr;
8788    for (const ParmVarDecl *Param : FD->parameters()) {
8789      if (Param->isExplicitObjectParameter())
8790        continue;
8791      QualType ParmTy = Param->getType();
8792  
8793      if (!KnownParm) {
8794        auto CTy = ParmTy;
8795        // Is it `T const &`?
8796        bool Ok = !IsMethod;
8797        QualType ExpectedTy;
8798        if (RD)
8799          ExpectedTy = Context.getRecordType(RD);
8800        if (auto *Ref = CTy->getAs<ReferenceType>()) {
8801          CTy = Ref->getPointeeType();
8802          if (RD)
8803            ExpectedTy.addConst();
8804          Ok = true;
8805        }
8806  
8807        // Is T a class?
8808        if (!Ok) {
8809        } else if (RD) {
8810          if (!RD->isDependentType() && !Context.hasSameType(CTy, ExpectedTy))
8811            Ok = false;
8812        } else if (auto *CRD = CTy->getAsRecordDecl()) {
8813          RD = cast<CXXRecordDecl>(CRD);
8814        } else {
8815          Ok = false;
8816        }
8817  
8818        if (Ok) {
8819          KnownParm = Param;
8820        } else {
8821          // Don't diagnose an implicit 'operator=='; we will have diagnosed the
8822          // corresponding defaulted 'operator<=>' already.
8823          if (!FD->isImplicit()) {
8824            if (RD) {
8825              QualType PlainTy = Context.getRecordType(RD);
8826              QualType RefTy =
8827                  Context.getLValueReferenceType(PlainTy.withConst());
8828              Diag(FD->getLocation(), diag::err_defaulted_comparison_param)
8829                  << int(DCK) << ParmTy << RefTy << int(!IsMethod) << PlainTy
8830                  << Param->getSourceRange();
8831            } else {
8832              assert(!IsMethod && "should know expected type for method");
8833              Diag(FD->getLocation(),
8834                   diag::err_defaulted_comparison_param_unknown)
8835                  << int(DCK) << ParmTy << Param->getSourceRange();
8836            }
8837          }
8838          return true;
8839        }
8840      } else if (!Context.hasSameType(KnownParm->getType(), ParmTy)) {
8841        Diag(FD->getLocation(), diag::err_defaulted_comparison_param_mismatch)
8842            << int(DCK) << KnownParm->getType() << KnownParm->getSourceRange()
8843            << ParmTy << Param->getSourceRange();
8844        return true;
8845      }
8846    }
8847  
8848    assert(RD && "must have determined class");
8849    if (IsMethod) {
8850    } else if (isa<CXXRecordDecl>(FD->getLexicalDeclContext())) {
8851      // In-class, must be a friend decl.
8852      assert(FD->getFriendObjectKind() && "expected a friend declaration");
8853    } else {
8854      // Out of class, require the defaulted comparison to be a friend (of a
8855      // complete type).
8856      if (RequireCompleteType(FD->getLocation(), Context.getRecordType(RD),
8857                              diag::err_defaulted_comparison_not_friend, int(DCK),
8858                              int(1)))
8859        return true;
8860  
8861      if (llvm::none_of(RD->friends(), [&](const FriendDecl *F) {
8862            return FD->getCanonicalDecl() ==
8863                   F->getFriendDecl()->getCanonicalDecl();
8864          })) {
8865        Diag(FD->getLocation(), diag::err_defaulted_comparison_not_friend)
8866            << int(DCK) << int(0) << RD;
8867        Diag(RD->getCanonicalDecl()->getLocation(), diag::note_declared_at);
8868        return true;
8869      }
8870    }
8871  
8872    // C++2a [class.eq]p1, [class.rel]p1:
8873    //   A [defaulted comparison other than <=>] shall have a declared return
8874    //   type bool.
8875    if (DCK != DefaultedComparisonKind::ThreeWay &&
8876        !FD->getDeclaredReturnType()->isDependentType() &&
8877        !Context.hasSameType(FD->getDeclaredReturnType(), Context.BoolTy)) {
8878      Diag(FD->getLocation(), diag::err_defaulted_comparison_return_type_not_bool)
8879          << (int)DCK << FD->getDeclaredReturnType() << Context.BoolTy
8880          << FD->getReturnTypeSourceRange();
8881      return true;
8882    }
8883    // C++2a [class.spaceship]p2 [P2002R0]:
8884    //   Let R be the declared return type [...]. If R is auto, [...]. Otherwise,
8885    //   R shall not contain a placeholder type.
8886    if (QualType RT = FD->getDeclaredReturnType();
8887        DCK == DefaultedComparisonKind::ThreeWay &&
8888        RT->getContainedDeducedType() &&
8889        (!Context.hasSameType(RT, Context.getAutoDeductType()) ||
8890         RT->getContainedAutoType()->isConstrained())) {
8891      Diag(FD->getLocation(),
8892           diag::err_defaulted_comparison_deduced_return_type_not_auto)
8893          << (int)DCK << FD->getDeclaredReturnType() << Context.AutoDeductTy
8894          << FD->getReturnTypeSourceRange();
8895      return true;
8896    }
8897  
8898    // For a defaulted function in a dependent class, defer all remaining checks
8899    // until instantiation.
8900    if (RD->isDependentType())
8901      return false;
8902  
8903    // Determine whether the function should be defined as deleted.
8904    DefaultedComparisonInfo Info =
8905        DefaultedComparisonAnalyzer(*this, RD, FD, DCK).visit();
8906  
8907    bool First = FD == FD->getCanonicalDecl();
8908  
8909    if (!First) {
8910      if (Info.Deleted) {
8911        // C++11 [dcl.fct.def.default]p4:
8912        //   [For a] user-provided explicitly-defaulted function [...] if such a
8913        //   function is implicitly defined as deleted, the program is ill-formed.
8914        //
8915        // This is really just a consequence of the general rule that you can
8916        // only delete a function on its first declaration.
8917        Diag(FD->getLocation(), diag::err_non_first_default_compare_deletes)
8918            << FD->isImplicit() << (int)DCK;
8919        DefaultedComparisonAnalyzer(*this, RD, FD, DCK,
8920                                    DefaultedComparisonAnalyzer::ExplainDeleted)
8921            .visit();
8922        return true;
8923      }
8924      if (isa<CXXRecordDecl>(FD->getLexicalDeclContext())) {
8925        // C++20 [class.compare.default]p1:
8926        //   [...] A definition of a comparison operator as defaulted that appears
8927        //   in a class shall be the first declaration of that function.
8928        Diag(FD->getLocation(), diag::err_non_first_default_compare_in_class)
8929            << (int)DCK;
8930        Diag(FD->getCanonicalDecl()->getLocation(),
8931             diag::note_previous_declaration);
8932        return true;
8933      }
8934    }
8935  
8936    // If we want to delete the function, then do so; there's nothing else to
8937    // check in that case.
8938    if (Info.Deleted) {
8939      SetDeclDeleted(FD, FD->getLocation());
8940      if (!inTemplateInstantiation() && !FD->isImplicit()) {
8941        Diag(FD->getLocation(), diag::warn_defaulted_comparison_deleted)
8942            << (int)DCK;
8943        DefaultedComparisonAnalyzer(*this, RD, FD, DCK,
8944                                    DefaultedComparisonAnalyzer::ExplainDeleted)
8945            .visit();
8946        if (FD->getDefaultLoc().isValid())
8947          Diag(FD->getDefaultLoc(), diag::note_replace_equals_default_to_delete)
8948              << FixItHint::CreateReplacement(FD->getDefaultLoc(), "delete");
8949      }
8950      return false;
8951    }
8952  
8953    // C++2a [class.spaceship]p2:
8954    //   The return type is deduced as the common comparison type of R0, R1, ...
8955    if (DCK == DefaultedComparisonKind::ThreeWay &&
8956        FD->getDeclaredReturnType()->isUndeducedAutoType()) {
8957      SourceLocation RetLoc = FD->getReturnTypeSourceRange().getBegin();
8958      if (RetLoc.isInvalid())
8959        RetLoc = FD->getBeginLoc();
8960      // FIXME: Should we really care whether we have the complete type and the
8961      // 'enumerator' constants here? A forward declaration seems sufficient.
8962      QualType Cat = CheckComparisonCategoryType(
8963          Info.Category, RetLoc, ComparisonCategoryUsage::DefaultedOperator);
8964      if (Cat.isNull())
8965        return true;
8966      Context.adjustDeducedFunctionResultType(
8967          FD, SubstAutoType(FD->getDeclaredReturnType(), Cat));
8968    }
8969  
8970    // C++2a [dcl.fct.def.default]p3 [P2002R0]:
8971    //   An explicitly-defaulted function that is not defined as deleted may be
8972    //   declared constexpr or consteval only if it is constexpr-compatible.
8973    // C++2a [class.compare.default]p3 [P2002R0]:
8974    //   A defaulted comparison function is constexpr-compatible if it satisfies
8975    //   the requirements for a constexpr function [...]
8976    // The only relevant requirements are that the parameter and return types are
8977    // literal types. The remaining conditions are checked by the analyzer.
8978    //
8979    // We support P2448R2 in language modes earlier than C++23 as an extension.
8980    // The concept of constexpr-compatible was removed.
8981    // C++23 [dcl.fct.def.default]p3 [P2448R2]
8982    //  A function explicitly defaulted on its first declaration is implicitly
8983    //  inline, and is implicitly constexpr if it is constexpr-suitable.
8984    // C++23 [dcl.constexpr]p3
8985    //   A function is constexpr-suitable if
8986    //    - it is not a coroutine, and
8987    //    - if the function is a constructor or destructor, its class does not
8988    //      have any virtual base classes.
8989    if (FD->isConstexpr()) {
8990      if (!getLangOpts().CPlusPlus23 &&
8991          CheckConstexprReturnType(*this, FD, CheckConstexprKind::Diagnose) &&
8992          CheckConstexprParameterTypes(*this, FD, CheckConstexprKind::Diagnose) &&
8993          !Info.Constexpr) {
8994        Diag(FD->getBeginLoc(), diag::err_defaulted_comparison_constexpr_mismatch)
8995            << FD->isImplicit() << (int)DCK << FD->isConsteval();
8996        DefaultedComparisonAnalyzer(*this, RD, FD, DCK,
8997                                    DefaultedComparisonAnalyzer::ExplainConstexpr)
8998            .visit();
8999      }
9000    }
9001  
9002    // C++2a [dcl.fct.def.default]p3 [P2002R0]:
9003    //   If a constexpr-compatible function is explicitly defaulted on its first
9004    //   declaration, it is implicitly considered to be constexpr.
9005    // FIXME: Only applying this to the first declaration seems problematic, as
9006    // simple reorderings can affect the meaning of the program.
9007    if (First && !FD->isConstexpr() && Info.Constexpr)
9008      FD->setConstexprKind(ConstexprSpecKind::Constexpr);
9009  
9010    // C++2a [except.spec]p3:
9011    //   If a declaration of a function does not have a noexcept-specifier
9012    //   [and] is defaulted on its first declaration, [...] the exception
9013    //   specification is as specified below
9014    if (FD->getExceptionSpecType() == EST_None) {
9015      auto *FPT = FD->getType()->castAs<FunctionProtoType>();
9016      FunctionProtoType::ExtProtoInfo EPI = FPT->getExtProtoInfo();
9017      EPI.ExceptionSpec.Type = EST_Unevaluated;
9018      EPI.ExceptionSpec.SourceDecl = FD;
9019      FD->setType(Context.getFunctionType(FPT->getReturnType(),
9020                                          FPT->getParamTypes(), EPI));
9021    }
9022  
9023    return false;
9024  }
9025  
9026  void Sema::DeclareImplicitEqualityComparison(CXXRecordDecl *RD,
9027                                               FunctionDecl *Spaceship) {
9028    Sema::CodeSynthesisContext Ctx;
9029    Ctx.Kind = Sema::CodeSynthesisContext::DeclaringImplicitEqualityComparison;
9030    Ctx.PointOfInstantiation = Spaceship->getEndLoc();
9031    Ctx.Entity = Spaceship;
9032    pushCodeSynthesisContext(Ctx);
9033  
9034    if (FunctionDecl *EqualEqual = SubstSpaceshipAsEqualEqual(RD, Spaceship))
9035      EqualEqual->setImplicit();
9036  
9037    popCodeSynthesisContext();
9038  }
9039  
9040  void Sema::DefineDefaultedComparison(SourceLocation UseLoc, FunctionDecl *FD,
9041                                       DefaultedComparisonKind DCK) {
9042    assert(FD->isDefaulted() && !FD->isDeleted() &&
9043           !FD->doesThisDeclarationHaveABody());
9044    if (FD->willHaveBody() || FD->isInvalidDecl())
9045      return;
9046  
9047    SynthesizedFunctionScope Scope(*this, FD);
9048  
9049    // Add a context note for diagnostics produced after this point.
9050    Scope.addContextNote(UseLoc);
9051  
9052    {
9053      // Build and set up the function body.
9054      // The first parameter has type maybe-ref-to maybe-const T, use that to get
9055      // the type of the class being compared.
9056      auto PT = FD->getParamDecl(0)->getType();
9057      CXXRecordDecl *RD = PT.getNonReferenceType()->getAsCXXRecordDecl();
9058      SourceLocation BodyLoc =
9059          FD->getEndLoc().isValid() ? FD->getEndLoc() : FD->getLocation();
9060      StmtResult Body =
9061          DefaultedComparisonSynthesizer(*this, RD, FD, DCK, BodyLoc).build();
9062      if (Body.isInvalid()) {
9063        FD->setInvalidDecl();
9064        return;
9065      }
9066      FD->setBody(Body.get());
9067      FD->markUsed(Context);
9068    }
9069  
9070    // The exception specification is needed because we are defining the
9071    // function. Note that this will reuse the body we just built.
9072    ResolveExceptionSpec(UseLoc, FD->getType()->castAs<FunctionProtoType>());
9073  
9074    if (ASTMutationListener *L = getASTMutationListener())
9075      L->CompletedImplicitDefinition(FD);
9076  }
9077  
9078  static Sema::ImplicitExceptionSpecification
9079  ComputeDefaultedComparisonExceptionSpec(Sema &S, SourceLocation Loc,
9080                                          FunctionDecl *FD,
9081                                          Sema::DefaultedComparisonKind DCK) {
9082    ComputingExceptionSpec CES(S, FD, Loc);
9083    Sema::ImplicitExceptionSpecification ExceptSpec(S);
9084  
9085    if (FD->isInvalidDecl())
9086      return ExceptSpec;
9087  
9088    // The common case is that we just defined the comparison function. In that
9089    // case, just look at whether the body can throw.
9090    if (FD->hasBody()) {
9091      ExceptSpec.CalledStmt(FD->getBody());
9092    } else {
9093      // Otherwise, build a body so we can check it. This should ideally only
9094      // happen when we're not actually marking the function referenced. (This is
9095      // only really important for efficiency: we don't want to build and throw
9096      // away bodies for comparison functions more than we strictly need to.)
9097  
9098      // Pretend to synthesize the function body in an unevaluated context.
9099      // Note that we can't actually just go ahead and define the function here:
9100      // we are not permitted to mark its callees as referenced.
9101      Sema::SynthesizedFunctionScope Scope(S, FD);
9102      EnterExpressionEvaluationContext Context(
9103          S, Sema::ExpressionEvaluationContext::Unevaluated);
9104  
9105      CXXRecordDecl *RD =
9106          cast<CXXRecordDecl>(FD->getFriendObjectKind() == Decl::FOK_None
9107                                  ? FD->getDeclContext()
9108                                  : FD->getLexicalDeclContext());
9109      SourceLocation BodyLoc =
9110          FD->getEndLoc().isValid() ? FD->getEndLoc() : FD->getLocation();
9111      StmtResult Body =
9112          DefaultedComparisonSynthesizer(S, RD, FD, DCK, BodyLoc).build();
9113      if (!Body.isInvalid())
9114        ExceptSpec.CalledStmt(Body.get());
9115  
9116      // FIXME: Can we hold onto this body and just transform it to potentially
9117      // evaluated when we're asked to define the function rather than rebuilding
9118      // it? Either that, or we should only build the bits of the body that we
9119      // need (the expressions, not the statements).
9120    }
9121  
9122    return ExceptSpec;
9123  }
9124  
9125  void Sema::CheckDelayedMemberExceptionSpecs() {
9126    decltype(DelayedOverridingExceptionSpecChecks) Overriding;
9127    decltype(DelayedEquivalentExceptionSpecChecks) Equivalent;
9128  
9129    std::swap(Overriding, DelayedOverridingExceptionSpecChecks);
9130    std::swap(Equivalent, DelayedEquivalentExceptionSpecChecks);
9131  
9132    // Perform any deferred checking of exception specifications for virtual
9133    // destructors.
9134    for (auto &Check : Overriding)
9135      CheckOverridingFunctionExceptionSpec(Check.first, Check.second);
9136  
9137    // Perform any deferred checking of exception specifications for befriended
9138    // special members.
9139    for (auto &Check : Equivalent)
9140      CheckEquivalentExceptionSpec(Check.second, Check.first);
9141  }
9142  
9143  namespace {
9144  /// CRTP base class for visiting operations performed by a special member
9145  /// function (or inherited constructor).
9146  template<typename Derived>
9147  struct SpecialMemberVisitor {
9148    Sema &S;
9149    CXXMethodDecl *MD;
9150    CXXSpecialMemberKind CSM;
9151    Sema::InheritedConstructorInfo *ICI;
9152  
9153    // Properties of the special member, computed for convenience.
9154    bool IsConstructor = false, IsAssignment = false, ConstArg = false;
9155  
9156    SpecialMemberVisitor(Sema &S, CXXMethodDecl *MD, CXXSpecialMemberKind CSM,
9157                         Sema::InheritedConstructorInfo *ICI)
9158        : S(S), MD(MD), CSM(CSM), ICI(ICI) {
9159      switch (CSM) {
9160      case CXXSpecialMemberKind::DefaultConstructor:
9161      case CXXSpecialMemberKind::CopyConstructor:
9162      case CXXSpecialMemberKind::MoveConstructor:
9163        IsConstructor = true;
9164        break;
9165      case CXXSpecialMemberKind::CopyAssignment:
9166      case CXXSpecialMemberKind::MoveAssignment:
9167        IsAssignment = true;
9168        break;
9169      case CXXSpecialMemberKind::Destructor:
9170        break;
9171      case CXXSpecialMemberKind::Invalid:
9172        llvm_unreachable("invalid special member kind");
9173      }
9174  
9175      if (MD->getNumExplicitParams()) {
9176        if (const ReferenceType *RT =
9177                MD->getNonObjectParameter(0)->getType()->getAs<ReferenceType>())
9178          ConstArg = RT->getPointeeType().isConstQualified();
9179      }
9180    }
9181  
9182    Derived &getDerived() { return static_cast<Derived&>(*this); }
9183  
9184    /// Is this a "move" special member?
9185    bool isMove() const {
9186      return CSM == CXXSpecialMemberKind::MoveConstructor ||
9187             CSM == CXXSpecialMemberKind::MoveAssignment;
9188    }
9189  
9190    /// Look up the corresponding special member in the given class.
9191    Sema::SpecialMemberOverloadResult lookupIn(CXXRecordDecl *Class,
9192                                               unsigned Quals, bool IsMutable) {
9193      return lookupCallFromSpecialMember(S, Class, CSM, Quals,
9194                                         ConstArg && !IsMutable);
9195    }
9196  
9197    /// Look up the constructor for the specified base class to see if it's
9198    /// overridden due to this being an inherited constructor.
9199    Sema::SpecialMemberOverloadResult lookupInheritedCtor(CXXRecordDecl *Class) {
9200      if (!ICI)
9201        return {};
9202      assert(CSM == CXXSpecialMemberKind::DefaultConstructor);
9203      auto *BaseCtor =
9204        cast<CXXConstructorDecl>(MD)->getInheritedConstructor().getConstructor();
9205      if (auto *MD = ICI->findConstructorForBase(Class, BaseCtor).first)
9206        return MD;
9207      return {};
9208    }
9209  
9210    /// A base or member subobject.
9211    typedef llvm::PointerUnion<CXXBaseSpecifier*, FieldDecl*> Subobject;
9212  
9213    /// Get the location to use for a subobject in diagnostics.
9214    static SourceLocation getSubobjectLoc(Subobject Subobj) {
9215      // FIXME: For an indirect virtual base, the direct base leading to
9216      // the indirect virtual base would be a more useful choice.
9217      if (auto *B = Subobj.dyn_cast<CXXBaseSpecifier*>())
9218        return B->getBaseTypeLoc();
9219      else
9220        return Subobj.get<FieldDecl*>()->getLocation();
9221    }
9222  
9223    enum BasesToVisit {
9224      /// Visit all non-virtual (direct) bases.
9225      VisitNonVirtualBases,
9226      /// Visit all direct bases, virtual or not.
9227      VisitDirectBases,
9228      /// Visit all non-virtual bases, and all virtual bases if the class
9229      /// is not abstract.
9230      VisitPotentiallyConstructedBases,
9231      /// Visit all direct or virtual bases.
9232      VisitAllBases
9233    };
9234  
9235    // Visit the bases and members of the class.
9236    bool visit(BasesToVisit Bases) {
9237      CXXRecordDecl *RD = MD->getParent();
9238  
9239      if (Bases == VisitPotentiallyConstructedBases)
9240        Bases = RD->isAbstract() ? VisitNonVirtualBases : VisitAllBases;
9241  
9242      for (auto &B : RD->bases())
9243        if ((Bases == VisitDirectBases || !B.isVirtual()) &&
9244            getDerived().visitBase(&B))
9245          return true;
9246  
9247      if (Bases == VisitAllBases)
9248        for (auto &B : RD->vbases())
9249          if (getDerived().visitBase(&B))
9250            return true;
9251  
9252      for (auto *F : RD->fields())
9253        if (!F->isInvalidDecl() && !F->isUnnamedBitField() &&
9254            getDerived().visitField(F))
9255          return true;
9256  
9257      return false;
9258    }
9259  };
9260  }
9261  
9262  namespace {
9263  struct SpecialMemberDeletionInfo
9264      : SpecialMemberVisitor<SpecialMemberDeletionInfo> {
9265    bool Diagnose;
9266  
9267    SourceLocation Loc;
9268  
9269    bool AllFieldsAreConst;
9270  
9271    SpecialMemberDeletionInfo(Sema &S, CXXMethodDecl *MD,
9272                              CXXSpecialMemberKind CSM,
9273                              Sema::InheritedConstructorInfo *ICI, bool Diagnose)
9274        : SpecialMemberVisitor(S, MD, CSM, ICI), Diagnose(Diagnose),
9275          Loc(MD->getLocation()), AllFieldsAreConst(true) {}
9276  
9277    bool inUnion() const { return MD->getParent()->isUnion(); }
9278  
9279    CXXSpecialMemberKind getEffectiveCSM() {
9280      return ICI ? CXXSpecialMemberKind::Invalid : CSM;
9281    }
9282  
9283    bool shouldDeleteForVariantObjCPtrMember(FieldDecl *FD, QualType FieldType);
9284  
9285    bool visitBase(CXXBaseSpecifier *Base) { return shouldDeleteForBase(Base); }
9286    bool visitField(FieldDecl *Field) { return shouldDeleteForField(Field); }
9287  
9288    bool shouldDeleteForBase(CXXBaseSpecifier *Base);
9289    bool shouldDeleteForField(FieldDecl *FD);
9290    bool shouldDeleteForAllConstMembers();
9291  
9292    bool shouldDeleteForClassSubobject(CXXRecordDecl *Class, Subobject Subobj,
9293                                       unsigned Quals);
9294    bool shouldDeleteForSubobjectCall(Subobject Subobj,
9295                                      Sema::SpecialMemberOverloadResult SMOR,
9296                                      bool IsDtorCallInCtor);
9297  
9298    bool isAccessible(Subobject Subobj, CXXMethodDecl *D);
9299  };
9300  }
9301  
9302  /// Is the given special member inaccessible when used on the given
9303  /// sub-object.
9304  bool SpecialMemberDeletionInfo::isAccessible(Subobject Subobj,
9305                                               CXXMethodDecl *target) {
9306    /// If we're operating on a base class, the object type is the
9307    /// type of this special member.
9308    QualType objectTy;
9309    AccessSpecifier access = target->getAccess();
9310    if (CXXBaseSpecifier *base = Subobj.dyn_cast<CXXBaseSpecifier*>()) {
9311      objectTy = S.Context.getTypeDeclType(MD->getParent());
9312      access = CXXRecordDecl::MergeAccess(base->getAccessSpecifier(), access);
9313  
9314    // If we're operating on a field, the object type is the type of the field.
9315    } else {
9316      objectTy = S.Context.getTypeDeclType(target->getParent());
9317    }
9318  
9319    return S.isMemberAccessibleForDeletion(
9320        target->getParent(), DeclAccessPair::make(target, access), objectTy);
9321  }
9322  
9323  /// Check whether we should delete a special member due to the implicit
9324  /// definition containing a call to a special member of a subobject.
9325  bool SpecialMemberDeletionInfo::shouldDeleteForSubobjectCall(
9326      Subobject Subobj, Sema::SpecialMemberOverloadResult SMOR,
9327      bool IsDtorCallInCtor) {
9328    CXXMethodDecl *Decl = SMOR.getMethod();
9329    FieldDecl *Field = Subobj.dyn_cast<FieldDecl*>();
9330  
9331    int DiagKind = -1;
9332  
9333    if (SMOR.getKind() == Sema::SpecialMemberOverloadResult::NoMemberOrDeleted)
9334      DiagKind = !Decl ? 0 : 1;
9335    else if (SMOR.getKind() == Sema::SpecialMemberOverloadResult::Ambiguous)
9336      DiagKind = 2;
9337    else if (!isAccessible(Subobj, Decl))
9338      DiagKind = 3;
9339    else if (!IsDtorCallInCtor && Field && Field->getParent()->isUnion() &&
9340             !Decl->isTrivial()) {
9341      // A member of a union must have a trivial corresponding special member.
9342      // As a weird special case, a destructor call from a union's constructor
9343      // must be accessible and non-deleted, but need not be trivial. Such a
9344      // destructor is never actually called, but is semantically checked as
9345      // if it were.
9346      if (CSM == CXXSpecialMemberKind::DefaultConstructor) {
9347        // [class.default.ctor]p2:
9348        //   A defaulted default constructor for class X is defined as deleted if
9349        //   - X is a union that has a variant member with a non-trivial default
9350        //     constructor and no variant member of X has a default member
9351        //     initializer
9352        const auto *RD = cast<CXXRecordDecl>(Field->getParent());
9353        if (!RD->hasInClassInitializer())
9354          DiagKind = 4;
9355      } else {
9356        DiagKind = 4;
9357      }
9358    }
9359  
9360    if (DiagKind == -1)
9361      return false;
9362  
9363    if (Diagnose) {
9364      if (Field) {
9365        S.Diag(Field->getLocation(),
9366               diag::note_deleted_special_member_class_subobject)
9367            << llvm::to_underlying(getEffectiveCSM()) << MD->getParent()
9368            << /*IsField*/ true << Field << DiagKind << IsDtorCallInCtor
9369            << /*IsObjCPtr*/ false;
9370      } else {
9371        CXXBaseSpecifier *Base = Subobj.get<CXXBaseSpecifier*>();
9372        S.Diag(Base->getBeginLoc(),
9373               diag::note_deleted_special_member_class_subobject)
9374            << llvm::to_underlying(getEffectiveCSM()) << MD->getParent()
9375            << /*IsField*/ false << Base->getType() << DiagKind
9376            << IsDtorCallInCtor << /*IsObjCPtr*/ false;
9377      }
9378  
9379      if (DiagKind == 1)
9380        S.NoteDeletedFunction(Decl);
9381      // FIXME: Explain inaccessibility if DiagKind == 3.
9382    }
9383  
9384    return true;
9385  }
9386  
9387  /// Check whether we should delete a special member function due to having a
9388  /// direct or virtual base class or non-static data member of class type M.
9389  bool SpecialMemberDeletionInfo::shouldDeleteForClassSubobject(
9390      CXXRecordDecl *Class, Subobject Subobj, unsigned Quals) {
9391    FieldDecl *Field = Subobj.dyn_cast<FieldDecl*>();
9392    bool IsMutable = Field && Field->isMutable();
9393  
9394    // C++11 [class.ctor]p5:
9395    // -- any direct or virtual base class, or non-static data member with no
9396    //    brace-or-equal-initializer, has class type M (or array thereof) and
9397    //    either M has no default constructor or overload resolution as applied
9398    //    to M's default constructor results in an ambiguity or in a function
9399    //    that is deleted or inaccessible
9400    // C++11 [class.copy]p11, C++11 [class.copy]p23:
9401    // -- a direct or virtual base class B that cannot be copied/moved because
9402    //    overload resolution, as applied to B's corresponding special member,
9403    //    results in an ambiguity or a function that is deleted or inaccessible
9404    //    from the defaulted special member
9405    // C++11 [class.dtor]p5:
9406    // -- any direct or virtual base class [...] has a type with a destructor
9407    //    that is deleted or inaccessible
9408    if (!(CSM == CXXSpecialMemberKind::DefaultConstructor && Field &&
9409          Field->hasInClassInitializer()) &&
9410        shouldDeleteForSubobjectCall(Subobj, lookupIn(Class, Quals, IsMutable),
9411                                     false))
9412      return true;
9413  
9414    // C++11 [class.ctor]p5, C++11 [class.copy]p11:
9415    // -- any direct or virtual base class or non-static data member has a
9416    //    type with a destructor that is deleted or inaccessible
9417    if (IsConstructor) {
9418      Sema::SpecialMemberOverloadResult SMOR =
9419          S.LookupSpecialMember(Class, CXXSpecialMemberKind::Destructor, false,
9420                                false, false, false, false);
9421      if (shouldDeleteForSubobjectCall(Subobj, SMOR, true))
9422        return true;
9423    }
9424  
9425    return false;
9426  }
9427  
9428  bool SpecialMemberDeletionInfo::shouldDeleteForVariantObjCPtrMember(
9429      FieldDecl *FD, QualType FieldType) {
9430    // The defaulted special functions are defined as deleted if this is a variant
9431    // member with a non-trivial ownership type, e.g., ObjC __strong or __weak
9432    // type under ARC.
9433    if (!FieldType.hasNonTrivialObjCLifetime())
9434      return false;
9435  
9436    // Don't make the defaulted default constructor defined as deleted if the
9437    // member has an in-class initializer.
9438    if (CSM == CXXSpecialMemberKind::DefaultConstructor &&
9439        FD->hasInClassInitializer())
9440      return false;
9441  
9442    if (Diagnose) {
9443      auto *ParentClass = cast<CXXRecordDecl>(FD->getParent());
9444      S.Diag(FD->getLocation(), diag::note_deleted_special_member_class_subobject)
9445          << llvm::to_underlying(getEffectiveCSM()) << ParentClass
9446          << /*IsField*/ true << FD << 4 << /*IsDtorCallInCtor*/ false
9447          << /*IsObjCPtr*/ true;
9448    }
9449  
9450    return true;
9451  }
9452  
9453  /// Check whether we should delete a special member function due to the class
9454  /// having a particular direct or virtual base class.
9455  bool SpecialMemberDeletionInfo::shouldDeleteForBase(CXXBaseSpecifier *Base) {
9456    CXXRecordDecl *BaseClass = Base->getType()->getAsCXXRecordDecl();
9457    // If program is correct, BaseClass cannot be null, but if it is, the error
9458    // must be reported elsewhere.
9459    if (!BaseClass)
9460      return false;
9461    // If we have an inheriting constructor, check whether we're calling an
9462    // inherited constructor instead of a default constructor.
9463    Sema::SpecialMemberOverloadResult SMOR = lookupInheritedCtor(BaseClass);
9464    if (auto *BaseCtor = SMOR.getMethod()) {
9465      // Note that we do not check access along this path; other than that,
9466      // this is the same as shouldDeleteForSubobjectCall(Base, BaseCtor, false);
9467      // FIXME: Check that the base has a usable destructor! Sink this into
9468      // shouldDeleteForClassSubobject.
9469      if (BaseCtor->isDeleted() && Diagnose) {
9470        S.Diag(Base->getBeginLoc(),
9471               diag::note_deleted_special_member_class_subobject)
9472            << llvm::to_underlying(getEffectiveCSM()) << MD->getParent()
9473            << /*IsField*/ false << Base->getType() << /*Deleted*/ 1
9474            << /*IsDtorCallInCtor*/ false << /*IsObjCPtr*/ false;
9475        S.NoteDeletedFunction(BaseCtor);
9476      }
9477      return BaseCtor->isDeleted();
9478    }
9479    return shouldDeleteForClassSubobject(BaseClass, Base, 0);
9480  }
9481  
9482  /// Check whether we should delete a special member function due to the class
9483  /// having a particular non-static data member.
9484  bool SpecialMemberDeletionInfo::shouldDeleteForField(FieldDecl *FD) {
9485    QualType FieldType = S.Context.getBaseElementType(FD->getType());
9486    CXXRecordDecl *FieldRecord = FieldType->getAsCXXRecordDecl();
9487  
9488    if (inUnion() && shouldDeleteForVariantObjCPtrMember(FD, FieldType))
9489      return true;
9490  
9491    if (CSM == CXXSpecialMemberKind::DefaultConstructor) {
9492      // For a default constructor, all references must be initialized in-class
9493      // and, if a union, it must have a non-const member.
9494      if (FieldType->isReferenceType() && !FD->hasInClassInitializer()) {
9495        if (Diagnose)
9496          S.Diag(FD->getLocation(), diag::note_deleted_default_ctor_uninit_field)
9497            << !!ICI << MD->getParent() << FD << FieldType << /*Reference*/0;
9498        return true;
9499      }
9500      // C++11 [class.ctor]p5 (modified by DR2394): any non-variant non-static
9501      // data member of const-qualified type (or array thereof) with no
9502      // brace-or-equal-initializer is not const-default-constructible.
9503      if (!inUnion() && FieldType.isConstQualified() &&
9504          !FD->hasInClassInitializer() &&
9505          (!FieldRecord || !FieldRecord->allowConstDefaultInit())) {
9506        if (Diagnose)
9507          S.Diag(FD->getLocation(), diag::note_deleted_default_ctor_uninit_field)
9508            << !!ICI << MD->getParent() << FD << FD->getType() << /*Const*/1;
9509        return true;
9510      }
9511  
9512      if (inUnion() && !FieldType.isConstQualified())
9513        AllFieldsAreConst = false;
9514    } else if (CSM == CXXSpecialMemberKind::CopyConstructor) {
9515      // For a copy constructor, data members must not be of rvalue reference
9516      // type.
9517      if (FieldType->isRValueReferenceType()) {
9518        if (Diagnose)
9519          S.Diag(FD->getLocation(), diag::note_deleted_copy_ctor_rvalue_reference)
9520            << MD->getParent() << FD << FieldType;
9521        return true;
9522      }
9523    } else if (IsAssignment) {
9524      // For an assignment operator, data members must not be of reference type.
9525      if (FieldType->isReferenceType()) {
9526        if (Diagnose)
9527          S.Diag(FD->getLocation(), diag::note_deleted_assign_field)
9528            << isMove() << MD->getParent() << FD << FieldType << /*Reference*/0;
9529        return true;
9530      }
9531      if (!FieldRecord && FieldType.isConstQualified()) {
9532        // C++11 [class.copy]p23:
9533        // -- a non-static data member of const non-class type (or array thereof)
9534        if (Diagnose)
9535          S.Diag(FD->getLocation(), diag::note_deleted_assign_field)
9536            << isMove() << MD->getParent() << FD << FD->getType() << /*Const*/1;
9537        return true;
9538      }
9539    }
9540  
9541    if (FieldRecord) {
9542      // Some additional restrictions exist on the variant members.
9543      if (!inUnion() && FieldRecord->isUnion() &&
9544          FieldRecord->isAnonymousStructOrUnion()) {
9545        bool AllVariantFieldsAreConst = true;
9546  
9547        // FIXME: Handle anonymous unions declared within anonymous unions.
9548        for (auto *UI : FieldRecord->fields()) {
9549          QualType UnionFieldType = S.Context.getBaseElementType(UI->getType());
9550  
9551          if (shouldDeleteForVariantObjCPtrMember(&*UI, UnionFieldType))
9552            return true;
9553  
9554          if (!UnionFieldType.isConstQualified())
9555            AllVariantFieldsAreConst = false;
9556  
9557          CXXRecordDecl *UnionFieldRecord = UnionFieldType->getAsCXXRecordDecl();
9558          if (UnionFieldRecord &&
9559              shouldDeleteForClassSubobject(UnionFieldRecord, UI,
9560                                            UnionFieldType.getCVRQualifiers()))
9561            return true;
9562        }
9563  
9564        // At least one member in each anonymous union must be non-const
9565        if (CSM == CXXSpecialMemberKind::DefaultConstructor &&
9566            AllVariantFieldsAreConst && !FieldRecord->field_empty()) {
9567          if (Diagnose)
9568            S.Diag(FieldRecord->getLocation(),
9569                   diag::note_deleted_default_ctor_all_const)
9570              << !!ICI << MD->getParent() << /*anonymous union*/1;
9571          return true;
9572        }
9573  
9574        // Don't check the implicit member of the anonymous union type.
9575        // This is technically non-conformant but supported, and we have a
9576        // diagnostic for this elsewhere.
9577        return false;
9578      }
9579  
9580      if (shouldDeleteForClassSubobject(FieldRecord, FD,
9581                                        FieldType.getCVRQualifiers()))
9582        return true;
9583    }
9584  
9585    return false;
9586  }
9587  
9588  /// C++11 [class.ctor] p5:
9589  ///   A defaulted default constructor for a class X is defined as deleted if
9590  /// X is a union and all of its variant members are of const-qualified type.
9591  bool SpecialMemberDeletionInfo::shouldDeleteForAllConstMembers() {
9592    // This is a silly definition, because it gives an empty union a deleted
9593    // default constructor. Don't do that.
9594    if (CSM == CXXSpecialMemberKind::DefaultConstructor && inUnion() &&
9595        AllFieldsAreConst) {
9596      bool AnyFields = false;
9597      for (auto *F : MD->getParent()->fields())
9598        if ((AnyFields = !F->isUnnamedBitField()))
9599          break;
9600      if (!AnyFields)
9601        return false;
9602      if (Diagnose)
9603        S.Diag(MD->getParent()->getLocation(),
9604               diag::note_deleted_default_ctor_all_const)
9605          << !!ICI << MD->getParent() << /*not anonymous union*/0;
9606      return true;
9607    }
9608    return false;
9609  }
9610  
9611  /// Determine whether a defaulted special member function should be defined as
9612  /// deleted, as specified in C++11 [class.ctor]p5, C++11 [class.copy]p11,
9613  /// C++11 [class.copy]p23, and C++11 [class.dtor]p5.
9614  bool Sema::ShouldDeleteSpecialMember(CXXMethodDecl *MD,
9615                                       CXXSpecialMemberKind CSM,
9616                                       InheritedConstructorInfo *ICI,
9617                                       bool Diagnose) {
9618    if (MD->isInvalidDecl())
9619      return false;
9620    CXXRecordDecl *RD = MD->getParent();
9621    assert(!RD->isDependentType() && "do deletion after instantiation");
9622    if (!LangOpts.CPlusPlus || (!LangOpts.CPlusPlus11 && !RD->isLambda()) ||
9623        RD->isInvalidDecl())
9624      return false;
9625  
9626    // C++11 [expr.lambda.prim]p19:
9627    //   The closure type associated with a lambda-expression has a
9628    //   deleted (8.4.3) default constructor and a deleted copy
9629    //   assignment operator.
9630    // C++2a adds back these operators if the lambda has no lambda-capture.
9631    if (RD->isLambda() && !RD->lambdaIsDefaultConstructibleAndAssignable() &&
9632        (CSM == CXXSpecialMemberKind::DefaultConstructor ||
9633         CSM == CXXSpecialMemberKind::CopyAssignment)) {
9634      if (Diagnose)
9635        Diag(RD->getLocation(), diag::note_lambda_decl);
9636      return true;
9637    }
9638  
9639    // For an anonymous struct or union, the copy and assignment special members
9640    // will never be used, so skip the check. For an anonymous union declared at
9641    // namespace scope, the constructor and destructor are used.
9642    if (CSM != CXXSpecialMemberKind::DefaultConstructor &&
9643        CSM != CXXSpecialMemberKind::Destructor && RD->isAnonymousStructOrUnion())
9644      return false;
9645  
9646    // C++11 [class.copy]p7, p18:
9647    //   If the class definition declares a move constructor or move assignment
9648    //   operator, an implicitly declared copy constructor or copy assignment
9649    //   operator is defined as deleted.
9650    if (MD->isImplicit() && (CSM == CXXSpecialMemberKind::CopyConstructor ||
9651                             CSM == CXXSpecialMemberKind::CopyAssignment)) {
9652      CXXMethodDecl *UserDeclaredMove = nullptr;
9653  
9654      // In Microsoft mode up to MSVC 2013, a user-declared move only causes the
9655      // deletion of the corresponding copy operation, not both copy operations.
9656      // MSVC 2015 has adopted the standards conforming behavior.
9657      bool DeletesOnlyMatchingCopy =
9658          getLangOpts().MSVCCompat &&
9659          !getLangOpts().isCompatibleWithMSVC(LangOptions::MSVC2015);
9660  
9661      if (RD->hasUserDeclaredMoveConstructor() &&
9662          (!DeletesOnlyMatchingCopy ||
9663           CSM == CXXSpecialMemberKind::CopyConstructor)) {
9664        if (!Diagnose) return true;
9665  
9666        // Find any user-declared move constructor.
9667        for (auto *I : RD->ctors()) {
9668          if (I->isMoveConstructor()) {
9669            UserDeclaredMove = I;
9670            break;
9671          }
9672        }
9673        assert(UserDeclaredMove);
9674      } else if (RD->hasUserDeclaredMoveAssignment() &&
9675                 (!DeletesOnlyMatchingCopy ||
9676                  CSM == CXXSpecialMemberKind::CopyAssignment)) {
9677        if (!Diagnose) return true;
9678  
9679        // Find any user-declared move assignment operator.
9680        for (auto *I : RD->methods()) {
9681          if (I->isMoveAssignmentOperator()) {
9682            UserDeclaredMove = I;
9683            break;
9684          }
9685        }
9686        assert(UserDeclaredMove);
9687      }
9688  
9689      if (UserDeclaredMove) {
9690        Diag(UserDeclaredMove->getLocation(),
9691             diag::note_deleted_copy_user_declared_move)
9692            << (CSM == CXXSpecialMemberKind::CopyAssignment) << RD
9693            << UserDeclaredMove->isMoveAssignmentOperator();
9694        return true;
9695      }
9696    }
9697  
9698    // Do access control from the special member function
9699    ContextRAII MethodContext(*this, MD);
9700  
9701    // C++11 [class.dtor]p5:
9702    // -- for a virtual destructor, lookup of the non-array deallocation function
9703    //    results in an ambiguity or in a function that is deleted or inaccessible
9704    if (CSM == CXXSpecialMemberKind::Destructor && MD->isVirtual()) {
9705      FunctionDecl *OperatorDelete = nullptr;
9706      DeclarationName Name =
9707        Context.DeclarationNames.getCXXOperatorName(OO_Delete);
9708      if (FindDeallocationFunction(MD->getLocation(), MD->getParent(), Name,
9709                                   OperatorDelete, /*Diagnose*/false)) {
9710        if (Diagnose)
9711          Diag(RD->getLocation(), diag::note_deleted_dtor_no_operator_delete);
9712        return true;
9713      }
9714    }
9715  
9716    SpecialMemberDeletionInfo SMI(*this, MD, CSM, ICI, Diagnose);
9717  
9718    // Per DR1611, do not consider virtual bases of constructors of abstract
9719    // classes, since we are not going to construct them.
9720    // Per DR1658, do not consider virtual bases of destructors of abstract
9721    // classes either.
9722    // Per DR2180, for assignment operators we only assign (and thus only
9723    // consider) direct bases.
9724    if (SMI.visit(SMI.IsAssignment ? SMI.VisitDirectBases
9725                                   : SMI.VisitPotentiallyConstructedBases))
9726      return true;
9727  
9728    if (SMI.shouldDeleteForAllConstMembers())
9729      return true;
9730  
9731    if (getLangOpts().CUDA) {
9732      // We should delete the special member in CUDA mode if target inference
9733      // failed.
9734      // For inherited constructors (non-null ICI), CSM may be passed so that MD
9735      // is treated as certain special member, which may not reflect what special
9736      // member MD really is. However inferTargetForImplicitSpecialMember
9737      // expects CSM to match MD, therefore recalculate CSM.
9738      assert(ICI || CSM == getSpecialMember(MD));
9739      auto RealCSM = CSM;
9740      if (ICI)
9741        RealCSM = getSpecialMember(MD);
9742  
9743      return CUDA().inferTargetForImplicitSpecialMember(RD, RealCSM, MD,
9744                                                        SMI.ConstArg, Diagnose);
9745    }
9746  
9747    return false;
9748  }
9749  
9750  void Sema::DiagnoseDeletedDefaultedFunction(FunctionDecl *FD) {
9751    DefaultedFunctionKind DFK = getDefaultedFunctionKind(FD);
9752    assert(DFK && "not a defaultable function");
9753    assert(FD->isDefaulted() && FD->isDeleted() && "not defaulted and deleted");
9754  
9755    if (DFK.isSpecialMember()) {
9756      ShouldDeleteSpecialMember(cast<CXXMethodDecl>(FD), DFK.asSpecialMember(),
9757                                nullptr, /*Diagnose=*/true);
9758    } else {
9759      DefaultedComparisonAnalyzer(
9760          *this, cast<CXXRecordDecl>(FD->getLexicalDeclContext()), FD,
9761          DFK.asComparison(), DefaultedComparisonAnalyzer::ExplainDeleted)
9762          .visit();
9763    }
9764  }
9765  
9766  /// Perform lookup for a special member of the specified kind, and determine
9767  /// whether it is trivial. If the triviality can be determined without the
9768  /// lookup, skip it. This is intended for use when determining whether a
9769  /// special member of a containing object is trivial, and thus does not ever
9770  /// perform overload resolution for default constructors.
9771  ///
9772  /// If \p Selected is not \c NULL, \c *Selected will be filled in with the
9773  /// member that was most likely to be intended to be trivial, if any.
9774  ///
9775  /// If \p ForCall is true, look at CXXRecord::HasTrivialSpecialMembersForCall to
9776  /// determine whether the special member is trivial.
9777  static bool findTrivialSpecialMember(Sema &S, CXXRecordDecl *RD,
9778                                       CXXSpecialMemberKind CSM, unsigned Quals,
9779                                       bool ConstRHS,
9780                                       Sema::TrivialABIHandling TAH,
9781                                       CXXMethodDecl **Selected) {
9782    if (Selected)
9783      *Selected = nullptr;
9784  
9785    switch (CSM) {
9786    case CXXSpecialMemberKind::Invalid:
9787      llvm_unreachable("not a special member");
9788  
9789    case CXXSpecialMemberKind::DefaultConstructor:
9790      // C++11 [class.ctor]p5:
9791      //   A default constructor is trivial if:
9792      //    - all the [direct subobjects] have trivial default constructors
9793      //
9794      // Note, no overload resolution is performed in this case.
9795      if (RD->hasTrivialDefaultConstructor())
9796        return true;
9797  
9798      if (Selected) {
9799        // If there's a default constructor which could have been trivial, dig it
9800        // out. Otherwise, if there's any user-provided default constructor, point
9801        // to that as an example of why there's not a trivial one.
9802        CXXConstructorDecl *DefCtor = nullptr;
9803        if (RD->needsImplicitDefaultConstructor())
9804          S.DeclareImplicitDefaultConstructor(RD);
9805        for (auto *CI : RD->ctors()) {
9806          if (!CI->isDefaultConstructor())
9807            continue;
9808          DefCtor = CI;
9809          if (!DefCtor->isUserProvided())
9810            break;
9811        }
9812  
9813        *Selected = DefCtor;
9814      }
9815  
9816      return false;
9817  
9818    case CXXSpecialMemberKind::Destructor:
9819      // C++11 [class.dtor]p5:
9820      //   A destructor is trivial if:
9821      //    - all the direct [subobjects] have trivial destructors
9822      if (RD->hasTrivialDestructor() ||
9823          (TAH == Sema::TAH_ConsiderTrivialABI &&
9824           RD->hasTrivialDestructorForCall()))
9825        return true;
9826  
9827      if (Selected) {
9828        if (RD->needsImplicitDestructor())
9829          S.DeclareImplicitDestructor(RD);
9830        *Selected = RD->getDestructor();
9831      }
9832  
9833      return false;
9834  
9835    case CXXSpecialMemberKind::CopyConstructor:
9836      // C++11 [class.copy]p12:
9837      //   A copy constructor is trivial if:
9838      //    - the constructor selected to copy each direct [subobject] is trivial
9839      if (RD->hasTrivialCopyConstructor() ||
9840          (TAH == Sema::TAH_ConsiderTrivialABI &&
9841           RD->hasTrivialCopyConstructorForCall())) {
9842        if (Quals == Qualifiers::Const)
9843          // We must either select the trivial copy constructor or reach an
9844          // ambiguity; no need to actually perform overload resolution.
9845          return true;
9846      } else if (!Selected) {
9847        return false;
9848      }
9849      // In C++98, we are not supposed to perform overload resolution here, but we
9850      // treat that as a language defect, as suggested on cxx-abi-dev, to treat
9851      // cases like B as having a non-trivial copy constructor:
9852      //   struct A { template<typename T> A(T&); };
9853      //   struct B { mutable A a; };
9854      goto NeedOverloadResolution;
9855  
9856    case CXXSpecialMemberKind::CopyAssignment:
9857      // C++11 [class.copy]p25:
9858      //   A copy assignment operator is trivial if:
9859      //    - the assignment operator selected to copy each direct [subobject] is
9860      //      trivial
9861      if (RD->hasTrivialCopyAssignment()) {
9862        if (Quals == Qualifiers::Const)
9863          return true;
9864      } else if (!Selected) {
9865        return false;
9866      }
9867      // In C++98, we are not supposed to perform overload resolution here, but we
9868      // treat that as a language defect.
9869      goto NeedOverloadResolution;
9870  
9871    case CXXSpecialMemberKind::MoveConstructor:
9872    case CXXSpecialMemberKind::MoveAssignment:
9873    NeedOverloadResolution:
9874      Sema::SpecialMemberOverloadResult SMOR =
9875          lookupCallFromSpecialMember(S, RD, CSM, Quals, ConstRHS);
9876  
9877      // The standard doesn't describe how to behave if the lookup is ambiguous.
9878      // We treat it as not making the member non-trivial, just like the standard
9879      // mandates for the default constructor. This should rarely matter, because
9880      // the member will also be deleted.
9881      if (SMOR.getKind() == Sema::SpecialMemberOverloadResult::Ambiguous)
9882        return true;
9883  
9884      if (!SMOR.getMethod()) {
9885        assert(SMOR.getKind() ==
9886               Sema::SpecialMemberOverloadResult::NoMemberOrDeleted);
9887        return false;
9888      }
9889  
9890      // We deliberately don't check if we found a deleted special member. We're
9891      // not supposed to!
9892      if (Selected)
9893        *Selected = SMOR.getMethod();
9894  
9895      if (TAH == Sema::TAH_ConsiderTrivialABI &&
9896          (CSM == CXXSpecialMemberKind::CopyConstructor ||
9897           CSM == CXXSpecialMemberKind::MoveConstructor))
9898        return SMOR.getMethod()->isTrivialForCall();
9899      return SMOR.getMethod()->isTrivial();
9900    }
9901  
9902    llvm_unreachable("unknown special method kind");
9903  }
9904  
9905  static CXXConstructorDecl *findUserDeclaredCtor(CXXRecordDecl *RD) {
9906    for (auto *CI : RD->ctors())
9907      if (!CI->isImplicit())
9908        return CI;
9909  
9910    // Look for constructor templates.
9911    typedef CXXRecordDecl::specific_decl_iterator<FunctionTemplateDecl> tmpl_iter;
9912    for (tmpl_iter TI(RD->decls_begin()), TE(RD->decls_end()); TI != TE; ++TI) {
9913      if (CXXConstructorDecl *CD =
9914            dyn_cast<CXXConstructorDecl>(TI->getTemplatedDecl()))
9915        return CD;
9916    }
9917  
9918    return nullptr;
9919  }
9920  
9921  /// The kind of subobject we are checking for triviality. The values of this
9922  /// enumeration are used in diagnostics.
9923  enum TrivialSubobjectKind {
9924    /// The subobject is a base class.
9925    TSK_BaseClass,
9926    /// The subobject is a non-static data member.
9927    TSK_Field,
9928    /// The object is actually the complete object.
9929    TSK_CompleteObject
9930  };
9931  
9932  /// Check whether the special member selected for a given type would be trivial.
9933  static bool checkTrivialSubobjectCall(Sema &S, SourceLocation SubobjLoc,
9934                                        QualType SubType, bool ConstRHS,
9935                                        CXXSpecialMemberKind CSM,
9936                                        TrivialSubobjectKind Kind,
9937                                        Sema::TrivialABIHandling TAH,
9938                                        bool Diagnose) {
9939    CXXRecordDecl *SubRD = SubType->getAsCXXRecordDecl();
9940    if (!SubRD)
9941      return true;
9942  
9943    CXXMethodDecl *Selected;
9944    if (findTrivialSpecialMember(S, SubRD, CSM, SubType.getCVRQualifiers(),
9945                                 ConstRHS, TAH, Diagnose ? &Selected : nullptr))
9946      return true;
9947  
9948    if (Diagnose) {
9949      if (ConstRHS)
9950        SubType.addConst();
9951  
9952      if (!Selected && CSM == CXXSpecialMemberKind::DefaultConstructor) {
9953        S.Diag(SubobjLoc, diag::note_nontrivial_no_def_ctor)
9954          << Kind << SubType.getUnqualifiedType();
9955        if (CXXConstructorDecl *CD = findUserDeclaredCtor(SubRD))
9956          S.Diag(CD->getLocation(), diag::note_user_declared_ctor);
9957      } else if (!Selected)
9958        S.Diag(SubobjLoc, diag::note_nontrivial_no_copy)
9959            << Kind << SubType.getUnqualifiedType() << llvm::to_underlying(CSM)
9960            << SubType;
9961      else if (Selected->isUserProvided()) {
9962        if (Kind == TSK_CompleteObject)
9963          S.Diag(Selected->getLocation(), diag::note_nontrivial_user_provided)
9964              << Kind << SubType.getUnqualifiedType() << llvm::to_underlying(CSM);
9965        else {
9966          S.Diag(SubobjLoc, diag::note_nontrivial_user_provided)
9967              << Kind << SubType.getUnqualifiedType() << llvm::to_underlying(CSM);
9968          S.Diag(Selected->getLocation(), diag::note_declared_at);
9969        }
9970      } else {
9971        if (Kind != TSK_CompleteObject)
9972          S.Diag(SubobjLoc, diag::note_nontrivial_subobject)
9973              << Kind << SubType.getUnqualifiedType() << llvm::to_underlying(CSM);
9974  
9975        // Explain why the defaulted or deleted special member isn't trivial.
9976        S.SpecialMemberIsTrivial(Selected, CSM, Sema::TAH_IgnoreTrivialABI,
9977                                 Diagnose);
9978      }
9979    }
9980  
9981    return false;
9982  }
9983  
9984  /// Check whether the members of a class type allow a special member to be
9985  /// trivial.
9986  static bool checkTrivialClassMembers(Sema &S, CXXRecordDecl *RD,
9987                                       CXXSpecialMemberKind CSM, bool ConstArg,
9988                                       Sema::TrivialABIHandling TAH,
9989                                       bool Diagnose) {
9990    for (const auto *FI : RD->fields()) {
9991      if (FI->isInvalidDecl() || FI->isUnnamedBitField())
9992        continue;
9993  
9994      QualType FieldType = S.Context.getBaseElementType(FI->getType());
9995  
9996      // Pretend anonymous struct or union members are members of this class.
9997      if (FI->isAnonymousStructOrUnion()) {
9998        if (!checkTrivialClassMembers(S, FieldType->getAsCXXRecordDecl(),
9999                                      CSM, ConstArg, TAH, Diagnose))
10000          return false;
10001        continue;
10002      }
10003  
10004      // C++11 [class.ctor]p5:
10005      //   A default constructor is trivial if [...]
10006      //    -- no non-static data member of its class has a
10007      //       brace-or-equal-initializer
10008      if (CSM == CXXSpecialMemberKind::DefaultConstructor &&
10009          FI->hasInClassInitializer()) {
10010        if (Diagnose)
10011          S.Diag(FI->getLocation(), diag::note_nontrivial_default_member_init)
10012              << FI;
10013        return false;
10014      }
10015  
10016      // Objective C ARC 4.3.5:
10017      //   [...] nontrivally ownership-qualified types are [...] not trivially
10018      //   default constructible, copy constructible, move constructible, copy
10019      //   assignable, move assignable, or destructible [...]
10020      if (FieldType.hasNonTrivialObjCLifetime()) {
10021        if (Diagnose)
10022          S.Diag(FI->getLocation(), diag::note_nontrivial_objc_ownership)
10023            << RD << FieldType.getObjCLifetime();
10024        return false;
10025      }
10026  
10027      bool ConstRHS = ConstArg && !FI->isMutable();
10028      if (!checkTrivialSubobjectCall(S, FI->getLocation(), FieldType, ConstRHS,
10029                                     CSM, TSK_Field, TAH, Diagnose))
10030        return false;
10031    }
10032  
10033    return true;
10034  }
10035  
10036  void Sema::DiagnoseNontrivial(const CXXRecordDecl *RD,
10037                                CXXSpecialMemberKind CSM) {
10038    QualType Ty = Context.getRecordType(RD);
10039  
10040    bool ConstArg = (CSM == CXXSpecialMemberKind::CopyConstructor ||
10041                     CSM == CXXSpecialMemberKind::CopyAssignment);
10042    checkTrivialSubobjectCall(*this, RD->getLocation(), Ty, ConstArg, CSM,
10043                              TSK_CompleteObject, TAH_IgnoreTrivialABI,
10044                              /*Diagnose*/true);
10045  }
10046  
10047  bool Sema::SpecialMemberIsTrivial(CXXMethodDecl *MD, CXXSpecialMemberKind CSM,
10048                                    TrivialABIHandling TAH, bool Diagnose) {
10049    assert(!MD->isUserProvided() && CSM != CXXSpecialMemberKind::Invalid &&
10050           "not special enough");
10051  
10052    CXXRecordDecl *RD = MD->getParent();
10053  
10054    bool ConstArg = false;
10055  
10056    // C++11 [class.copy]p12, p25: [DR1593]
10057    //   A [special member] is trivial if [...] its parameter-type-list is
10058    //   equivalent to the parameter-type-list of an implicit declaration [...]
10059    switch (CSM) {
10060    case CXXSpecialMemberKind::DefaultConstructor:
10061    case CXXSpecialMemberKind::Destructor:
10062      // Trivial default constructors and destructors cannot have parameters.
10063      break;
10064  
10065    case CXXSpecialMemberKind::CopyConstructor:
10066    case CXXSpecialMemberKind::CopyAssignment: {
10067      const ParmVarDecl *Param0 = MD->getNonObjectParameter(0);
10068      const ReferenceType *RT = Param0->getType()->getAs<ReferenceType>();
10069  
10070      // When ClangABICompat14 is true, CXX copy constructors will only be trivial
10071      // if they are not user-provided and their parameter-type-list is equivalent
10072      // to the parameter-type-list of an implicit declaration. This maintains the
10073      // behavior before dr2171 was implemented.
10074      //
10075      // Otherwise, if ClangABICompat14 is false, All copy constructors can be
10076      // trivial, if they are not user-provided, regardless of the qualifiers on
10077      // the reference type.
10078      const bool ClangABICompat14 = Context.getLangOpts().getClangABICompat() <=
10079                                    LangOptions::ClangABI::Ver14;
10080      if (!RT ||
10081          ((RT->getPointeeType().getCVRQualifiers() != Qualifiers::Const) &&
10082           ClangABICompat14)) {
10083        if (Diagnose)
10084          Diag(Param0->getLocation(), diag::note_nontrivial_param_type)
10085            << Param0->getSourceRange() << Param0->getType()
10086            << Context.getLValueReferenceType(
10087                 Context.getRecordType(RD).withConst());
10088        return false;
10089      }
10090  
10091      ConstArg = RT->getPointeeType().isConstQualified();
10092      break;
10093    }
10094  
10095    case CXXSpecialMemberKind::MoveConstructor:
10096    case CXXSpecialMemberKind::MoveAssignment: {
10097      // Trivial move operations always have non-cv-qualified parameters.
10098      const ParmVarDecl *Param0 = MD->getNonObjectParameter(0);
10099      const RValueReferenceType *RT =
10100        Param0->getType()->getAs<RValueReferenceType>();
10101      if (!RT || RT->getPointeeType().getCVRQualifiers()) {
10102        if (Diagnose)
10103          Diag(Param0->getLocation(), diag::note_nontrivial_param_type)
10104            << Param0->getSourceRange() << Param0->getType()
10105            << Context.getRValueReferenceType(Context.getRecordType(RD));
10106        return false;
10107      }
10108      break;
10109    }
10110  
10111    case CXXSpecialMemberKind::Invalid:
10112      llvm_unreachable("not a special member");
10113    }
10114  
10115    if (MD->getMinRequiredArguments() < MD->getNumParams()) {
10116      if (Diagnose)
10117        Diag(MD->getParamDecl(MD->getMinRequiredArguments())->getLocation(),
10118             diag::note_nontrivial_default_arg)
10119          << MD->getParamDecl(MD->getMinRequiredArguments())->getSourceRange();
10120      return false;
10121    }
10122    if (MD->isVariadic()) {
10123      if (Diagnose)
10124        Diag(MD->getLocation(), diag::note_nontrivial_variadic);
10125      return false;
10126    }
10127  
10128    // C++11 [class.ctor]p5, C++11 [class.dtor]p5:
10129    //   A copy/move [constructor or assignment operator] is trivial if
10130    //    -- the [member] selected to copy/move each direct base class subobject
10131    //       is trivial
10132    //
10133    // C++11 [class.copy]p12, C++11 [class.copy]p25:
10134    //   A [default constructor or destructor] is trivial if
10135    //    -- all the direct base classes have trivial [default constructors or
10136    //       destructors]
10137    for (const auto &BI : RD->bases())
10138      if (!checkTrivialSubobjectCall(*this, BI.getBeginLoc(), BI.getType(),
10139                                     ConstArg, CSM, TSK_BaseClass, TAH, Diagnose))
10140        return false;
10141  
10142    // C++11 [class.ctor]p5, C++11 [class.dtor]p5:
10143    //   A copy/move [constructor or assignment operator] for a class X is
10144    //   trivial if
10145    //    -- for each non-static data member of X that is of class type (or array
10146    //       thereof), the constructor selected to copy/move that member is
10147    //       trivial
10148    //
10149    // C++11 [class.copy]p12, C++11 [class.copy]p25:
10150    //   A [default constructor or destructor] is trivial if
10151    //    -- for all of the non-static data members of its class that are of class
10152    //       type (or array thereof), each such class has a trivial [default
10153    //       constructor or destructor]
10154    if (!checkTrivialClassMembers(*this, RD, CSM, ConstArg, TAH, Diagnose))
10155      return false;
10156  
10157    // C++11 [class.dtor]p5:
10158    //   A destructor is trivial if [...]
10159    //    -- the destructor is not virtual
10160    if (CSM == CXXSpecialMemberKind::Destructor && MD->isVirtual()) {
10161      if (Diagnose)
10162        Diag(MD->getLocation(), diag::note_nontrivial_virtual_dtor) << RD;
10163      return false;
10164    }
10165  
10166    // C++11 [class.ctor]p5, C++11 [class.copy]p12, C++11 [class.copy]p25:
10167    //   A [special member] for class X is trivial if [...]
10168    //    -- class X has no virtual functions and no virtual base classes
10169    if (CSM != CXXSpecialMemberKind::Destructor &&
10170        MD->getParent()->isDynamicClass()) {
10171      if (!Diagnose)
10172        return false;
10173  
10174      if (RD->getNumVBases()) {
10175        // Check for virtual bases. We already know that the corresponding
10176        // member in all bases is trivial, so vbases must all be direct.
10177        CXXBaseSpecifier &BS = *RD->vbases_begin();
10178        assert(BS.isVirtual());
10179        Diag(BS.getBeginLoc(), diag::note_nontrivial_has_virtual) << RD << 1;
10180        return false;
10181      }
10182  
10183      // Must have a virtual method.
10184      for (const auto *MI : RD->methods()) {
10185        if (MI->isVirtual()) {
10186          SourceLocation MLoc = MI->getBeginLoc();
10187          Diag(MLoc, diag::note_nontrivial_has_virtual) << RD << 0;
10188          return false;
10189        }
10190      }
10191  
10192      llvm_unreachable("dynamic class with no vbases and no virtual functions");
10193    }
10194  
10195    // Looks like it's trivial!
10196    return true;
10197  }
10198  
10199  namespace {
10200  struct FindHiddenVirtualMethod {
10201    Sema *S;
10202    CXXMethodDecl *Method;
10203    llvm::SmallPtrSet<const CXXMethodDecl *, 8> OverridenAndUsingBaseMethods;
10204    SmallVector<CXXMethodDecl *, 8> OverloadedMethods;
10205  
10206  private:
10207    /// Check whether any most overridden method from MD in Methods
10208    static bool CheckMostOverridenMethods(
10209        const CXXMethodDecl *MD,
10210        const llvm::SmallPtrSetImpl<const CXXMethodDecl *> &Methods) {
10211      if (MD->size_overridden_methods() == 0)
10212        return Methods.count(MD->getCanonicalDecl());
10213      for (const CXXMethodDecl *O : MD->overridden_methods())
10214        if (CheckMostOverridenMethods(O, Methods))
10215          return true;
10216      return false;
10217    }
10218  
10219  public:
10220    /// Member lookup function that determines whether a given C++
10221    /// method overloads virtual methods in a base class without overriding any,
10222    /// to be used with CXXRecordDecl::lookupInBases().
10223    bool operator()(const CXXBaseSpecifier *Specifier, CXXBasePath &Path) {
10224      RecordDecl *BaseRecord =
10225          Specifier->getType()->castAs<RecordType>()->getDecl();
10226  
10227      DeclarationName Name = Method->getDeclName();
10228      assert(Name.getNameKind() == DeclarationName::Identifier);
10229  
10230      bool foundSameNameMethod = false;
10231      SmallVector<CXXMethodDecl *, 8> overloadedMethods;
10232      for (Path.Decls = BaseRecord->lookup(Name).begin();
10233           Path.Decls != DeclContext::lookup_iterator(); ++Path.Decls) {
10234        NamedDecl *D = *Path.Decls;
10235        if (CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(D)) {
10236          MD = MD->getCanonicalDecl();
10237          foundSameNameMethod = true;
10238          // Interested only in hidden virtual methods.
10239          if (!MD->isVirtual())
10240            continue;
10241          // If the method we are checking overrides a method from its base
10242          // don't warn about the other overloaded methods. Clang deviates from
10243          // GCC by only diagnosing overloads of inherited virtual functions that
10244          // do not override any other virtual functions in the base. GCC's
10245          // -Woverloaded-virtual diagnoses any derived function hiding a virtual
10246          // function from a base class. These cases may be better served by a
10247          // warning (not specific to virtual functions) on call sites when the
10248          // call would select a different function from the base class, were it
10249          // visible.
10250          // See FIXME in test/SemaCXX/warn-overload-virtual.cpp for an example.
10251          if (!S->IsOverload(Method, MD, false))
10252            return true;
10253          // Collect the overload only if its hidden.
10254          if (!CheckMostOverridenMethods(MD, OverridenAndUsingBaseMethods))
10255            overloadedMethods.push_back(MD);
10256        }
10257      }
10258  
10259      if (foundSameNameMethod)
10260        OverloadedMethods.append(overloadedMethods.begin(),
10261                                 overloadedMethods.end());
10262      return foundSameNameMethod;
10263    }
10264  };
10265  } // end anonymous namespace
10266  
10267  /// Add the most overridden methods from MD to Methods
10268  static void AddMostOverridenMethods(const CXXMethodDecl *MD,
10269                          llvm::SmallPtrSetImpl<const CXXMethodDecl *>& Methods) {
10270    if (MD->size_overridden_methods() == 0)
10271      Methods.insert(MD->getCanonicalDecl());
10272    else
10273      for (const CXXMethodDecl *O : MD->overridden_methods())
10274        AddMostOverridenMethods(O, Methods);
10275  }
10276  
10277  void Sema::FindHiddenVirtualMethods(CXXMethodDecl *MD,
10278                            SmallVectorImpl<CXXMethodDecl*> &OverloadedMethods) {
10279    if (!MD->getDeclName().isIdentifier())
10280      return;
10281  
10282    CXXBasePaths Paths(/*FindAmbiguities=*/true, // true to look in all bases.
10283                       /*bool RecordPaths=*/false,
10284                       /*bool DetectVirtual=*/false);
10285    FindHiddenVirtualMethod FHVM;
10286    FHVM.Method = MD;
10287    FHVM.S = this;
10288  
10289    // Keep the base methods that were overridden or introduced in the subclass
10290    // by 'using' in a set. A base method not in this set is hidden.
10291    CXXRecordDecl *DC = MD->getParent();
10292    DeclContext::lookup_result R = DC->lookup(MD->getDeclName());
10293    for (DeclContext::lookup_iterator I = R.begin(), E = R.end(); I != E; ++I) {
10294      NamedDecl *ND = *I;
10295      if (UsingShadowDecl *shad = dyn_cast<UsingShadowDecl>(*I))
10296        ND = shad->getTargetDecl();
10297      if (CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(ND))
10298        AddMostOverridenMethods(MD, FHVM.OverridenAndUsingBaseMethods);
10299    }
10300  
10301    if (DC->lookupInBases(FHVM, Paths))
10302      OverloadedMethods = FHVM.OverloadedMethods;
10303  }
10304  
10305  void Sema::NoteHiddenVirtualMethods(CXXMethodDecl *MD,
10306                            SmallVectorImpl<CXXMethodDecl*> &OverloadedMethods) {
10307    for (unsigned i = 0, e = OverloadedMethods.size(); i != e; ++i) {
10308      CXXMethodDecl *overloadedMD = OverloadedMethods[i];
10309      PartialDiagnostic PD = PDiag(
10310           diag::note_hidden_overloaded_virtual_declared_here) << overloadedMD;
10311      HandleFunctionTypeMismatch(PD, MD->getType(), overloadedMD->getType());
10312      Diag(overloadedMD->getLocation(), PD);
10313    }
10314  }
10315  
10316  void Sema::DiagnoseHiddenVirtualMethods(CXXMethodDecl *MD) {
10317    if (MD->isInvalidDecl())
10318      return;
10319  
10320    if (Diags.isIgnored(diag::warn_overloaded_virtual, MD->getLocation()))
10321      return;
10322  
10323    SmallVector<CXXMethodDecl *, 8> OverloadedMethods;
10324    FindHiddenVirtualMethods(MD, OverloadedMethods);
10325    if (!OverloadedMethods.empty()) {
10326      Diag(MD->getLocation(), diag::warn_overloaded_virtual)
10327        << MD << (OverloadedMethods.size() > 1);
10328  
10329      NoteHiddenVirtualMethods(MD, OverloadedMethods);
10330    }
10331  }
10332  
10333  void Sema::checkIllFormedTrivialABIStruct(CXXRecordDecl &RD) {
10334    auto PrintDiagAndRemoveAttr = [&](unsigned N) {
10335      // No diagnostics if this is a template instantiation.
10336      if (!isTemplateInstantiation(RD.getTemplateSpecializationKind())) {
10337        Diag(RD.getAttr<TrivialABIAttr>()->getLocation(),
10338             diag::ext_cannot_use_trivial_abi) << &RD;
10339        Diag(RD.getAttr<TrivialABIAttr>()->getLocation(),
10340             diag::note_cannot_use_trivial_abi_reason) << &RD << N;
10341      }
10342      RD.dropAttr<TrivialABIAttr>();
10343    };
10344  
10345    // Ill-formed if the copy and move constructors are deleted.
10346    auto HasNonDeletedCopyOrMoveConstructor = [&]() {
10347      // If the type is dependent, then assume it might have
10348      // implicit copy or move ctor because we won't know yet at this point.
10349      if (RD.isDependentType())
10350        return true;
10351      if (RD.needsImplicitCopyConstructor() &&
10352          !RD.defaultedCopyConstructorIsDeleted())
10353        return true;
10354      if (RD.needsImplicitMoveConstructor() &&
10355          !RD.defaultedMoveConstructorIsDeleted())
10356        return true;
10357      for (const CXXConstructorDecl *CD : RD.ctors())
10358        if (CD->isCopyOrMoveConstructor() && !CD->isDeleted())
10359          return true;
10360      return false;
10361    };
10362  
10363    if (!HasNonDeletedCopyOrMoveConstructor()) {
10364      PrintDiagAndRemoveAttr(0);
10365      return;
10366    }
10367  
10368    // Ill-formed if the struct has virtual functions.
10369    if (RD.isPolymorphic()) {
10370      PrintDiagAndRemoveAttr(1);
10371      return;
10372    }
10373  
10374    for (const auto &B : RD.bases()) {
10375      // Ill-formed if the base class is non-trivial for the purpose of calls or a
10376      // virtual base.
10377      if (!B.getType()->isDependentType() &&
10378          !B.getType()->getAsCXXRecordDecl()->canPassInRegisters()) {
10379        PrintDiagAndRemoveAttr(2);
10380        return;
10381      }
10382  
10383      if (B.isVirtual()) {
10384        PrintDiagAndRemoveAttr(3);
10385        return;
10386      }
10387    }
10388  
10389    for (const auto *FD : RD.fields()) {
10390      // Ill-formed if the field is an ObjectiveC pointer or of a type that is
10391      // non-trivial for the purpose of calls.
10392      QualType FT = FD->getType();
10393      if (FT.getObjCLifetime() == Qualifiers::OCL_Weak) {
10394        PrintDiagAndRemoveAttr(4);
10395        return;
10396      }
10397  
10398      if (const auto *RT = FT->getBaseElementTypeUnsafe()->getAs<RecordType>())
10399        if (!RT->isDependentType() &&
10400            !cast<CXXRecordDecl>(RT->getDecl())->canPassInRegisters()) {
10401          PrintDiagAndRemoveAttr(5);
10402          return;
10403        }
10404    }
10405  }
10406  
10407  void Sema::checkIncorrectVTablePointerAuthenticationAttribute(
10408      CXXRecordDecl &RD) {
10409    if (RequireCompleteType(RD.getLocation(), Context.getRecordType(&RD),
10410                            diag::err_incomplete_type_vtable_pointer_auth))
10411      return;
10412  
10413    const CXXRecordDecl *PrimaryBase = &RD;
10414    if (PrimaryBase->hasAnyDependentBases())
10415      return;
10416  
10417    while (1) {
10418      assert(PrimaryBase);
10419      const CXXRecordDecl *Base = nullptr;
10420      for (auto BasePtr : PrimaryBase->bases()) {
10421        if (!BasePtr.getType()->getAsCXXRecordDecl()->isDynamicClass())
10422          continue;
10423        Base = BasePtr.getType()->getAsCXXRecordDecl();
10424        break;
10425      }
10426      if (!Base || Base == PrimaryBase || !Base->isPolymorphic())
10427        break;
10428      Diag(RD.getAttr<VTablePointerAuthenticationAttr>()->getLocation(),
10429           diag::err_non_top_level_vtable_pointer_auth)
10430          << &RD << Base;
10431      PrimaryBase = Base;
10432    }
10433  
10434    if (!RD.isPolymorphic())
10435      Diag(RD.getAttr<VTablePointerAuthenticationAttr>()->getLocation(),
10436           diag::err_non_polymorphic_vtable_pointer_auth)
10437          << &RD;
10438  }
10439  
10440  void Sema::ActOnFinishCXXMemberSpecification(
10441      Scope *S, SourceLocation RLoc, Decl *TagDecl, SourceLocation LBrac,
10442      SourceLocation RBrac, const ParsedAttributesView &AttrList) {
10443    if (!TagDecl)
10444      return;
10445  
10446    AdjustDeclIfTemplate(TagDecl);
10447  
10448    for (const ParsedAttr &AL : AttrList) {
10449      if (AL.getKind() != ParsedAttr::AT_Visibility)
10450        continue;
10451      AL.setInvalid();
10452      Diag(AL.getLoc(), diag::warn_attribute_after_definition_ignored) << AL;
10453    }
10454  
10455    ActOnFields(S, RLoc, TagDecl,
10456                llvm::ArrayRef(
10457                    // strict aliasing violation!
10458                    reinterpret_cast<Decl **>(FieldCollector->getCurFields()),
10459                    FieldCollector->getCurNumFields()),
10460                LBrac, RBrac, AttrList);
10461  
10462    CheckCompletedCXXClass(S, cast<CXXRecordDecl>(TagDecl));
10463  }
10464  
10465  /// Find the equality comparison functions that should be implicitly declared
10466  /// in a given class definition, per C++2a [class.compare.default]p3.
10467  static void findImplicitlyDeclaredEqualityComparisons(
10468      ASTContext &Ctx, CXXRecordDecl *RD,
10469      llvm::SmallVectorImpl<FunctionDecl *> &Spaceships) {
10470    DeclarationName EqEq = Ctx.DeclarationNames.getCXXOperatorName(OO_EqualEqual);
10471    if (!RD->lookup(EqEq).empty())
10472      // Member operator== explicitly declared: no implicit operator==s.
10473      return;
10474  
10475    // Traverse friends looking for an '==' or a '<=>'.
10476    for (FriendDecl *Friend : RD->friends()) {
10477      FunctionDecl *FD = dyn_cast_or_null<FunctionDecl>(Friend->getFriendDecl());
10478      if (!FD) continue;
10479  
10480      if (FD->getOverloadedOperator() == OO_EqualEqual) {
10481        // Friend operator== explicitly declared: no implicit operator==s.
10482        Spaceships.clear();
10483        return;
10484      }
10485  
10486      if (FD->getOverloadedOperator() == OO_Spaceship &&
10487          FD->isExplicitlyDefaulted())
10488        Spaceships.push_back(FD);
10489    }
10490  
10491    // Look for members named 'operator<=>'.
10492    DeclarationName Cmp = Ctx.DeclarationNames.getCXXOperatorName(OO_Spaceship);
10493    for (NamedDecl *ND : RD->lookup(Cmp)) {
10494      // Note that we could find a non-function here (either a function template
10495      // or a using-declaration). Neither case results in an implicit
10496      // 'operator=='.
10497      if (auto *FD = dyn_cast<FunctionDecl>(ND))
10498        if (FD->isExplicitlyDefaulted())
10499          Spaceships.push_back(FD);
10500    }
10501  }
10502  
10503  void Sema::AddImplicitlyDeclaredMembersToClass(CXXRecordDecl *ClassDecl) {
10504    // Don't add implicit special members to templated classes.
10505    // FIXME: This means unqualified lookups for 'operator=' within a class
10506    // template don't work properly.
10507    if (!ClassDecl->isDependentType()) {
10508      if (ClassDecl->needsImplicitDefaultConstructor()) {
10509        ++getASTContext().NumImplicitDefaultConstructors;
10510  
10511        if (ClassDecl->hasInheritedConstructor())
10512          DeclareImplicitDefaultConstructor(ClassDecl);
10513      }
10514  
10515      if (ClassDecl->needsImplicitCopyConstructor()) {
10516        ++getASTContext().NumImplicitCopyConstructors;
10517  
10518        // If the properties or semantics of the copy constructor couldn't be
10519        // determined while the class was being declared, force a declaration
10520        // of it now.
10521        if (ClassDecl->needsOverloadResolutionForCopyConstructor() ||
10522            ClassDecl->hasInheritedConstructor())
10523          DeclareImplicitCopyConstructor(ClassDecl);
10524        // For the MS ABI we need to know whether the copy ctor is deleted. A
10525        // prerequisite for deleting the implicit copy ctor is that the class has
10526        // a move ctor or move assignment that is either user-declared or whose
10527        // semantics are inherited from a subobject. FIXME: We should provide a
10528        // more direct way for CodeGen to ask whether the constructor was deleted.
10529        else if (Context.getTargetInfo().getCXXABI().isMicrosoft() &&
10530                 (ClassDecl->hasUserDeclaredMoveConstructor() ||
10531                  ClassDecl->needsOverloadResolutionForMoveConstructor() ||
10532                  ClassDecl->hasUserDeclaredMoveAssignment() ||
10533                  ClassDecl->needsOverloadResolutionForMoveAssignment()))
10534          DeclareImplicitCopyConstructor(ClassDecl);
10535      }
10536  
10537      if (getLangOpts().CPlusPlus11 &&
10538          ClassDecl->needsImplicitMoveConstructor()) {
10539        ++getASTContext().NumImplicitMoveConstructors;
10540  
10541        if (ClassDecl->needsOverloadResolutionForMoveConstructor() ||
10542            ClassDecl->hasInheritedConstructor())
10543          DeclareImplicitMoveConstructor(ClassDecl);
10544      }
10545  
10546      if (ClassDecl->needsImplicitCopyAssignment()) {
10547        ++getASTContext().NumImplicitCopyAssignmentOperators;
10548  
10549        // If we have a dynamic class, then the copy assignment operator may be
10550        // virtual, so we have to declare it immediately. This ensures that, e.g.,
10551        // it shows up in the right place in the vtable and that we diagnose
10552        // problems with the implicit exception specification.
10553        if (ClassDecl->isDynamicClass() ||
10554            ClassDecl->needsOverloadResolutionForCopyAssignment() ||
10555            ClassDecl->hasInheritedAssignment())
10556          DeclareImplicitCopyAssignment(ClassDecl);
10557      }
10558  
10559      if (getLangOpts().CPlusPlus11 && ClassDecl->needsImplicitMoveAssignment()) {
10560        ++getASTContext().NumImplicitMoveAssignmentOperators;
10561  
10562        // Likewise for the move assignment operator.
10563        if (ClassDecl->isDynamicClass() ||
10564            ClassDecl->needsOverloadResolutionForMoveAssignment() ||
10565            ClassDecl->hasInheritedAssignment())
10566          DeclareImplicitMoveAssignment(ClassDecl);
10567      }
10568  
10569      if (ClassDecl->needsImplicitDestructor()) {
10570        ++getASTContext().NumImplicitDestructors;
10571  
10572        // If we have a dynamic class, then the destructor may be virtual, so we
10573        // have to declare the destructor immediately. This ensures that, e.g., it
10574        // shows up in the right place in the vtable and that we diagnose problems
10575        // with the implicit exception specification.
10576        if (ClassDecl->isDynamicClass() ||
10577            ClassDecl->needsOverloadResolutionForDestructor())
10578          DeclareImplicitDestructor(ClassDecl);
10579      }
10580    }
10581  
10582    // C++2a [class.compare.default]p3:
10583    //   If the member-specification does not explicitly declare any member or
10584    //   friend named operator==, an == operator function is declared implicitly
10585    //   for each defaulted three-way comparison operator function defined in
10586    //   the member-specification
10587    // FIXME: Consider doing this lazily.
10588    // We do this during the initial parse for a class template, not during
10589    // instantiation, so that we can handle unqualified lookups for 'operator=='
10590    // when parsing the template.
10591    if (getLangOpts().CPlusPlus20 && !inTemplateInstantiation()) {
10592      llvm::SmallVector<FunctionDecl *, 4> DefaultedSpaceships;
10593      findImplicitlyDeclaredEqualityComparisons(Context, ClassDecl,
10594                                                DefaultedSpaceships);
10595      for (auto *FD : DefaultedSpaceships)
10596        DeclareImplicitEqualityComparison(ClassDecl, FD);
10597    }
10598  }
10599  
10600  unsigned
10601  Sema::ActOnReenterTemplateScope(Decl *D,
10602                                  llvm::function_ref<Scope *()> EnterScope) {
10603    if (!D)
10604      return 0;
10605    AdjustDeclIfTemplate(D);
10606  
10607    // In order to get name lookup right, reenter template scopes in order from
10608    // outermost to innermost.
10609    SmallVector<TemplateParameterList *, 4> ParameterLists;
10610    DeclContext *LookupDC = dyn_cast<DeclContext>(D);
10611  
10612    if (DeclaratorDecl *DD = dyn_cast<DeclaratorDecl>(D)) {
10613      for (unsigned i = 0; i < DD->getNumTemplateParameterLists(); ++i)
10614        ParameterLists.push_back(DD->getTemplateParameterList(i));
10615  
10616      if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) {
10617        if (FunctionTemplateDecl *FTD = FD->getDescribedFunctionTemplate())
10618          ParameterLists.push_back(FTD->getTemplateParameters());
10619      } else if (VarDecl *VD = dyn_cast<VarDecl>(D)) {
10620        LookupDC = VD->getDeclContext();
10621  
10622        if (VarTemplateDecl *VTD = VD->getDescribedVarTemplate())
10623          ParameterLists.push_back(VTD->getTemplateParameters());
10624        else if (auto *PSD = dyn_cast<VarTemplatePartialSpecializationDecl>(D))
10625          ParameterLists.push_back(PSD->getTemplateParameters());
10626      }
10627    } else if (TagDecl *TD = dyn_cast<TagDecl>(D)) {
10628      for (unsigned i = 0; i < TD->getNumTemplateParameterLists(); ++i)
10629        ParameterLists.push_back(TD->getTemplateParameterList(i));
10630  
10631      if (CXXRecordDecl *RD = dyn_cast<CXXRecordDecl>(TD)) {
10632        if (ClassTemplateDecl *CTD = RD->getDescribedClassTemplate())
10633          ParameterLists.push_back(CTD->getTemplateParameters());
10634        else if (auto *PSD = dyn_cast<ClassTemplatePartialSpecializationDecl>(D))
10635          ParameterLists.push_back(PSD->getTemplateParameters());
10636      }
10637    }
10638    // FIXME: Alias declarations and concepts.
10639  
10640    unsigned Count = 0;
10641    Scope *InnermostTemplateScope = nullptr;
10642    for (TemplateParameterList *Params : ParameterLists) {
10643      // Ignore explicit specializations; they don't contribute to the template
10644      // depth.
10645      if (Params->size() == 0)
10646        continue;
10647  
10648      InnermostTemplateScope = EnterScope();
10649      for (NamedDecl *Param : *Params) {
10650        if (Param->getDeclName()) {
10651          InnermostTemplateScope->AddDecl(Param);
10652          IdResolver.AddDecl(Param);
10653        }
10654      }
10655      ++Count;
10656    }
10657  
10658    // Associate the new template scopes with the corresponding entities.
10659    if (InnermostTemplateScope) {
10660      assert(LookupDC && "no enclosing DeclContext for template lookup");
10661      EnterTemplatedContext(InnermostTemplateScope, LookupDC);
10662    }
10663  
10664    return Count;
10665  }
10666  
10667  void Sema::ActOnStartDelayedMemberDeclarations(Scope *S, Decl *RecordD) {
10668    if (!RecordD) return;
10669    AdjustDeclIfTemplate(RecordD);
10670    CXXRecordDecl *Record = cast<CXXRecordDecl>(RecordD);
10671    PushDeclContext(S, Record);
10672  }
10673  
10674  void Sema::ActOnFinishDelayedMemberDeclarations(Scope *S, Decl *RecordD) {
10675    if (!RecordD) return;
10676    PopDeclContext();
10677  }
10678  
10679  void Sema::ActOnReenterCXXMethodParameter(Scope *S, ParmVarDecl *Param) {
10680    if (!Param)
10681      return;
10682  
10683    S->AddDecl(Param);
10684    if (Param->getDeclName())
10685      IdResolver.AddDecl(Param);
10686  }
10687  
10688  void Sema::ActOnStartDelayedCXXMethodDeclaration(Scope *S, Decl *MethodD) {
10689  }
10690  
10691  /// ActOnDelayedCXXMethodParameter - We've already started a delayed
10692  /// C++ method declaration. We're (re-)introducing the given
10693  /// function parameter into scope for use in parsing later parts of
10694  /// the method declaration. For example, we could see an
10695  /// ActOnParamDefaultArgument event for this parameter.
10696  void Sema::ActOnDelayedCXXMethodParameter(Scope *S, Decl *ParamD) {
10697    if (!ParamD)
10698      return;
10699  
10700    ParmVarDecl *Param = cast<ParmVarDecl>(ParamD);
10701  
10702    S->AddDecl(Param);
10703    if (Param->getDeclName())
10704      IdResolver.AddDecl(Param);
10705  }
10706  
10707  void Sema::ActOnFinishDelayedCXXMethodDeclaration(Scope *S, Decl *MethodD) {
10708    if (!MethodD)
10709      return;
10710  
10711    AdjustDeclIfTemplate(MethodD);
10712  
10713    FunctionDecl *Method = cast<FunctionDecl>(MethodD);
10714  
10715    // Now that we have our default arguments, check the constructor
10716    // again. It could produce additional diagnostics or affect whether
10717    // the class has implicitly-declared destructors, among other
10718    // things.
10719    if (CXXConstructorDecl *Constructor = dyn_cast<CXXConstructorDecl>(Method))
10720      CheckConstructor(Constructor);
10721  
10722    // Check the default arguments, which we may have added.
10723    if (!Method->isInvalidDecl())
10724      CheckCXXDefaultArguments(Method);
10725  }
10726  
10727  // Emit the given diagnostic for each non-address-space qualifier.
10728  // Common part of CheckConstructorDeclarator and CheckDestructorDeclarator.
10729  static void checkMethodTypeQualifiers(Sema &S, Declarator &D, unsigned DiagID) {
10730    const DeclaratorChunk::FunctionTypeInfo &FTI = D.getFunctionTypeInfo();
10731    if (FTI.hasMethodTypeQualifiers() && !D.isInvalidType()) {
10732      bool DiagOccured = false;
10733      FTI.MethodQualifiers->forEachQualifier(
10734          [DiagID, &S, &DiagOccured](DeclSpec::TQ, StringRef QualName,
10735                                     SourceLocation SL) {
10736            // This diagnostic should be emitted on any qualifier except an addr
10737            // space qualifier. However, forEachQualifier currently doesn't visit
10738            // addr space qualifiers, so there's no way to write this condition
10739            // right now; we just diagnose on everything.
10740            S.Diag(SL, DiagID) << QualName << SourceRange(SL);
10741            DiagOccured = true;
10742          });
10743      if (DiagOccured)
10744        D.setInvalidType();
10745    }
10746  }
10747  
10748  QualType Sema::CheckConstructorDeclarator(Declarator &D, QualType R,
10749                                            StorageClass &SC) {
10750    bool isVirtual = D.getDeclSpec().isVirtualSpecified();
10751  
10752    // C++ [class.ctor]p3:
10753    //   A constructor shall not be virtual (10.3) or static (9.4). A
10754    //   constructor can be invoked for a const, volatile or const
10755    //   volatile object. A constructor shall not be declared const,
10756    //   volatile, or const volatile (9.3.2).
10757    if (isVirtual) {
10758      if (!D.isInvalidType())
10759        Diag(D.getIdentifierLoc(), diag::err_constructor_cannot_be)
10760          << "virtual" << SourceRange(D.getDeclSpec().getVirtualSpecLoc())
10761          << SourceRange(D.getIdentifierLoc());
10762      D.setInvalidType();
10763    }
10764    if (SC == SC_Static) {
10765      if (!D.isInvalidType())
10766        Diag(D.getIdentifierLoc(), diag::err_constructor_cannot_be)
10767          << "static" << SourceRange(D.getDeclSpec().getStorageClassSpecLoc())
10768          << SourceRange(D.getIdentifierLoc());
10769      D.setInvalidType();
10770      SC = SC_None;
10771    }
10772  
10773    if (unsigned TypeQuals = D.getDeclSpec().getTypeQualifiers()) {
10774      diagnoseIgnoredQualifiers(
10775          diag::err_constructor_return_type, TypeQuals, SourceLocation(),
10776          D.getDeclSpec().getConstSpecLoc(), D.getDeclSpec().getVolatileSpecLoc(),
10777          D.getDeclSpec().getRestrictSpecLoc(),
10778          D.getDeclSpec().getAtomicSpecLoc());
10779      D.setInvalidType();
10780    }
10781  
10782    checkMethodTypeQualifiers(*this, D, diag::err_invalid_qualified_constructor);
10783  
10784    // C++0x [class.ctor]p4:
10785    //   A constructor shall not be declared with a ref-qualifier.
10786    DeclaratorChunk::FunctionTypeInfo &FTI = D.getFunctionTypeInfo();
10787    if (FTI.hasRefQualifier()) {
10788      Diag(FTI.getRefQualifierLoc(), diag::err_ref_qualifier_constructor)
10789        << FTI.RefQualifierIsLValueRef
10790        << FixItHint::CreateRemoval(FTI.getRefQualifierLoc());
10791      D.setInvalidType();
10792    }
10793  
10794    // Rebuild the function type "R" without any type qualifiers (in
10795    // case any of the errors above fired) and with "void" as the
10796    // return type, since constructors don't have return types.
10797    const FunctionProtoType *Proto = R->castAs<FunctionProtoType>();
10798    if (Proto->getReturnType() == Context.VoidTy && !D.isInvalidType())
10799      return R;
10800  
10801    FunctionProtoType::ExtProtoInfo EPI = Proto->getExtProtoInfo();
10802    EPI.TypeQuals = Qualifiers();
10803    EPI.RefQualifier = RQ_None;
10804  
10805    return Context.getFunctionType(Context.VoidTy, Proto->getParamTypes(), EPI);
10806  }
10807  
10808  void Sema::CheckConstructor(CXXConstructorDecl *Constructor) {
10809    CXXRecordDecl *ClassDecl
10810      = dyn_cast<CXXRecordDecl>(Constructor->getDeclContext());
10811    if (!ClassDecl)
10812      return Constructor->setInvalidDecl();
10813  
10814    // C++ [class.copy]p3:
10815    //   A declaration of a constructor for a class X is ill-formed if
10816    //   its first parameter is of type (optionally cv-qualified) X and
10817    //   either there are no other parameters or else all other
10818    //   parameters have default arguments.
10819    if (!Constructor->isInvalidDecl() &&
10820        Constructor->hasOneParamOrDefaultArgs() &&
10821        Constructor->getTemplateSpecializationKind() !=
10822            TSK_ImplicitInstantiation) {
10823      QualType ParamType = Constructor->getParamDecl(0)->getType();
10824      QualType ClassTy = Context.getTagDeclType(ClassDecl);
10825      if (Context.getCanonicalType(ParamType).getUnqualifiedType() == ClassTy) {
10826        SourceLocation ParamLoc = Constructor->getParamDecl(0)->getLocation();
10827        const char *ConstRef
10828          = Constructor->getParamDecl(0)->getIdentifier() ? "const &"
10829                                                          : " const &";
10830        Diag(ParamLoc, diag::err_constructor_byvalue_arg)
10831          << FixItHint::CreateInsertion(ParamLoc, ConstRef);
10832  
10833        // FIXME: Rather that making the constructor invalid, we should endeavor
10834        // to fix the type.
10835        Constructor->setInvalidDecl();
10836      }
10837    }
10838  }
10839  
10840  bool Sema::CheckDestructor(CXXDestructorDecl *Destructor) {
10841    CXXRecordDecl *RD = Destructor->getParent();
10842  
10843    if (!Destructor->getOperatorDelete() && Destructor->isVirtual()) {
10844      SourceLocation Loc;
10845  
10846      if (!Destructor->isImplicit())
10847        Loc = Destructor->getLocation();
10848      else
10849        Loc = RD->getLocation();
10850  
10851      // If we have a virtual destructor, look up the deallocation function
10852      if (FunctionDecl *OperatorDelete =
10853              FindDeallocationFunctionForDestructor(Loc, RD)) {
10854        Expr *ThisArg = nullptr;
10855  
10856        // If the notional 'delete this' expression requires a non-trivial
10857        // conversion from 'this' to the type of a destroying operator delete's
10858        // first parameter, perform that conversion now.
10859        if (OperatorDelete->isDestroyingOperatorDelete()) {
10860          QualType ParamType = OperatorDelete->getParamDecl(0)->getType();
10861          if (!declaresSameEntity(ParamType->getAsCXXRecordDecl(), RD)) {
10862            // C++ [class.dtor]p13:
10863            //   ... as if for the expression 'delete this' appearing in a
10864            //   non-virtual destructor of the destructor's class.
10865            ContextRAII SwitchContext(*this, Destructor);
10866            ExprResult This =
10867                ActOnCXXThis(OperatorDelete->getParamDecl(0)->getLocation());
10868            assert(!This.isInvalid() && "couldn't form 'this' expr in dtor?");
10869            This = PerformImplicitConversion(This.get(), ParamType, AA_Passing);
10870            if (This.isInvalid()) {
10871              // FIXME: Register this as a context note so that it comes out
10872              // in the right order.
10873              Diag(Loc, diag::note_implicit_delete_this_in_destructor_here);
10874              return true;
10875            }
10876            ThisArg = This.get();
10877          }
10878        }
10879  
10880        DiagnoseUseOfDecl(OperatorDelete, Loc);
10881        MarkFunctionReferenced(Loc, OperatorDelete);
10882        Destructor->setOperatorDelete(OperatorDelete, ThisArg);
10883      }
10884    }
10885  
10886    return false;
10887  }
10888  
10889  QualType Sema::CheckDestructorDeclarator(Declarator &D, QualType R,
10890                                           StorageClass& SC) {
10891    // C++ [class.dtor]p1:
10892    //   [...] A typedef-name that names a class is a class-name
10893    //   (7.1.3); however, a typedef-name that names a class shall not
10894    //   be used as the identifier in the declarator for a destructor
10895    //   declaration.
10896    QualType DeclaratorType = GetTypeFromParser(D.getName().DestructorName);
10897    if (const TypedefType *TT = DeclaratorType->getAs<TypedefType>())
10898      Diag(D.getIdentifierLoc(), diag::ext_destructor_typedef_name)
10899        << DeclaratorType << isa<TypeAliasDecl>(TT->getDecl());
10900    else if (const TemplateSpecializationType *TST =
10901               DeclaratorType->getAs<TemplateSpecializationType>())
10902      if (TST->isTypeAlias())
10903        Diag(D.getIdentifierLoc(), diag::ext_destructor_typedef_name)
10904          << DeclaratorType << 1;
10905  
10906    // C++ [class.dtor]p2:
10907    //   A destructor is used to destroy objects of its class type. A
10908    //   destructor takes no parameters, and no return type can be
10909    //   specified for it (not even void). The address of a destructor
10910    //   shall not be taken. A destructor shall not be static. A
10911    //   destructor can be invoked for a const, volatile or const
10912    //   volatile object. A destructor shall not be declared const,
10913    //   volatile or const volatile (9.3.2).
10914    if (SC == SC_Static) {
10915      if (!D.isInvalidType())
10916        Diag(D.getIdentifierLoc(), diag::err_destructor_cannot_be)
10917          << "static" << SourceRange(D.getDeclSpec().getStorageClassSpecLoc())
10918          << SourceRange(D.getIdentifierLoc())
10919          << FixItHint::CreateRemoval(D.getDeclSpec().getStorageClassSpecLoc());
10920  
10921      SC = SC_None;
10922    }
10923    if (!D.isInvalidType()) {
10924      // Destructors don't have return types, but the parser will
10925      // happily parse something like:
10926      //
10927      //   class X {
10928      //     float ~X();
10929      //   };
10930      //
10931      // The return type will be eliminated later.
10932      if (D.getDeclSpec().hasTypeSpecifier())
10933        Diag(D.getIdentifierLoc(), diag::err_destructor_return_type)
10934          << SourceRange(D.getDeclSpec().getTypeSpecTypeLoc())
10935          << SourceRange(D.getIdentifierLoc());
10936      else if (unsigned TypeQuals = D.getDeclSpec().getTypeQualifiers()) {
10937        diagnoseIgnoredQualifiers(diag::err_destructor_return_type, TypeQuals,
10938                                  SourceLocation(),
10939                                  D.getDeclSpec().getConstSpecLoc(),
10940                                  D.getDeclSpec().getVolatileSpecLoc(),
10941                                  D.getDeclSpec().getRestrictSpecLoc(),
10942                                  D.getDeclSpec().getAtomicSpecLoc());
10943        D.setInvalidType();
10944      }
10945    }
10946  
10947    checkMethodTypeQualifiers(*this, D, diag::err_invalid_qualified_destructor);
10948  
10949    // C++0x [class.dtor]p2:
10950    //   A destructor shall not be declared with a ref-qualifier.
10951    DeclaratorChunk::FunctionTypeInfo &FTI = D.getFunctionTypeInfo();
10952    if (FTI.hasRefQualifier()) {
10953      Diag(FTI.getRefQualifierLoc(), diag::err_ref_qualifier_destructor)
10954        << FTI.RefQualifierIsLValueRef
10955        << FixItHint::CreateRemoval(FTI.getRefQualifierLoc());
10956      D.setInvalidType();
10957    }
10958  
10959    // Make sure we don't have any parameters.
10960    if (FTIHasNonVoidParameters(FTI)) {
10961      Diag(D.getIdentifierLoc(), diag::err_destructor_with_params);
10962  
10963      // Delete the parameters.
10964      FTI.freeParams();
10965      D.setInvalidType();
10966    }
10967  
10968    // Make sure the destructor isn't variadic.
10969    if (FTI.isVariadic) {
10970      Diag(D.getIdentifierLoc(), diag::err_destructor_variadic);
10971      D.setInvalidType();
10972    }
10973  
10974    // Rebuild the function type "R" without any type qualifiers or
10975    // parameters (in case any of the errors above fired) and with
10976    // "void" as the return type, since destructors don't have return
10977    // types.
10978    if (!D.isInvalidType())
10979      return R;
10980  
10981    const FunctionProtoType *Proto = R->castAs<FunctionProtoType>();
10982    FunctionProtoType::ExtProtoInfo EPI = Proto->getExtProtoInfo();
10983    EPI.Variadic = false;
10984    EPI.TypeQuals = Qualifiers();
10985    EPI.RefQualifier = RQ_None;
10986    return Context.getFunctionType(Context.VoidTy, std::nullopt, EPI);
10987  }
10988  
10989  static void extendLeft(SourceRange &R, SourceRange Before) {
10990    if (Before.isInvalid())
10991      return;
10992    R.setBegin(Before.getBegin());
10993    if (R.getEnd().isInvalid())
10994      R.setEnd(Before.getEnd());
10995  }
10996  
10997  static void extendRight(SourceRange &R, SourceRange After) {
10998    if (After.isInvalid())
10999      return;
11000    if (R.getBegin().isInvalid())
11001      R.setBegin(After.getBegin());
11002    R.setEnd(After.getEnd());
11003  }
11004  
11005  void Sema::CheckConversionDeclarator(Declarator &D, QualType &R,
11006                                       StorageClass& SC) {
11007    // C++ [class.conv.fct]p1:
11008    //   Neither parameter types nor return type can be specified. The
11009    //   type of a conversion function (8.3.5) is "function taking no
11010    //   parameter returning conversion-type-id."
11011    if (SC == SC_Static) {
11012      if (!D.isInvalidType())
11013        Diag(D.getIdentifierLoc(), diag::err_conv_function_not_member)
11014          << SourceRange(D.getDeclSpec().getStorageClassSpecLoc())
11015          << D.getName().getSourceRange();
11016      D.setInvalidType();
11017      SC = SC_None;
11018    }
11019  
11020    TypeSourceInfo *ConvTSI = nullptr;
11021    QualType ConvType =
11022        GetTypeFromParser(D.getName().ConversionFunctionId, &ConvTSI);
11023  
11024    const DeclSpec &DS = D.getDeclSpec();
11025    if (DS.hasTypeSpecifier() && !D.isInvalidType()) {
11026      // Conversion functions don't have return types, but the parser will
11027      // happily parse something like:
11028      //
11029      //   class X {
11030      //     float operator bool();
11031      //   };
11032      //
11033      // The return type will be changed later anyway.
11034      Diag(D.getIdentifierLoc(), diag::err_conv_function_return_type)
11035        << SourceRange(DS.getTypeSpecTypeLoc())
11036        << SourceRange(D.getIdentifierLoc());
11037      D.setInvalidType();
11038    } else if (DS.getTypeQualifiers() && !D.isInvalidType()) {
11039      // It's also plausible that the user writes type qualifiers in the wrong
11040      // place, such as:
11041      //   struct S { const operator int(); };
11042      // FIXME: we could provide a fixit to move the qualifiers onto the
11043      // conversion type.
11044      Diag(D.getIdentifierLoc(), diag::err_conv_function_with_complex_decl)
11045          << SourceRange(D.getIdentifierLoc()) << 0;
11046      D.setInvalidType();
11047    }
11048    const auto *Proto = R->castAs<FunctionProtoType>();
11049    // Make sure we don't have any parameters.
11050    DeclaratorChunk::FunctionTypeInfo &FTI = D.getFunctionTypeInfo();
11051    unsigned NumParam = Proto->getNumParams();
11052  
11053    // [C++2b]
11054    // A conversion function shall have no non-object parameters.
11055    if (NumParam == 1) {
11056      DeclaratorChunk::FunctionTypeInfo &FTI = D.getFunctionTypeInfo();
11057      if (const auto *First =
11058              dyn_cast_if_present<ParmVarDecl>(FTI.Params[0].Param);
11059          First && First->isExplicitObjectParameter())
11060        NumParam--;
11061    }
11062  
11063    if (NumParam != 0) {
11064      Diag(D.getIdentifierLoc(), diag::err_conv_function_with_params);
11065      // Delete the parameters.
11066      FTI.freeParams();
11067      D.setInvalidType();
11068    } else if (Proto->isVariadic()) {
11069      Diag(D.getIdentifierLoc(), diag::err_conv_function_variadic);
11070      D.setInvalidType();
11071    }
11072  
11073    // Diagnose "&operator bool()" and other such nonsense.  This
11074    // is actually a gcc extension which we don't support.
11075    if (Proto->getReturnType() != ConvType) {
11076      bool NeedsTypedef = false;
11077      SourceRange Before, After;
11078  
11079      // Walk the chunks and extract information on them for our diagnostic.
11080      bool PastFunctionChunk = false;
11081      for (auto &Chunk : D.type_objects()) {
11082        switch (Chunk.Kind) {
11083        case DeclaratorChunk::Function:
11084          if (!PastFunctionChunk) {
11085            if (Chunk.Fun.HasTrailingReturnType) {
11086              TypeSourceInfo *TRT = nullptr;
11087              GetTypeFromParser(Chunk.Fun.getTrailingReturnType(), &TRT);
11088              if (TRT) extendRight(After, TRT->getTypeLoc().getSourceRange());
11089            }
11090            PastFunctionChunk = true;
11091            break;
11092          }
11093          [[fallthrough]];
11094        case DeclaratorChunk::Array:
11095          NeedsTypedef = true;
11096          extendRight(After, Chunk.getSourceRange());
11097          break;
11098  
11099        case DeclaratorChunk::Pointer:
11100        case DeclaratorChunk::BlockPointer:
11101        case DeclaratorChunk::Reference:
11102        case DeclaratorChunk::MemberPointer:
11103        case DeclaratorChunk::Pipe:
11104          extendLeft(Before, Chunk.getSourceRange());
11105          break;
11106  
11107        case DeclaratorChunk::Paren:
11108          extendLeft(Before, Chunk.Loc);
11109          extendRight(After, Chunk.EndLoc);
11110          break;
11111        }
11112      }
11113  
11114      SourceLocation Loc = Before.isValid() ? Before.getBegin() :
11115                           After.isValid()  ? After.getBegin() :
11116                                              D.getIdentifierLoc();
11117      auto &&DB = Diag(Loc, diag::err_conv_function_with_complex_decl);
11118      DB << Before << After;
11119  
11120      if (!NeedsTypedef) {
11121        DB << /*don't need a typedef*/0;
11122  
11123        // If we can provide a correct fix-it hint, do so.
11124        if (After.isInvalid() && ConvTSI) {
11125          SourceLocation InsertLoc =
11126              getLocForEndOfToken(ConvTSI->getTypeLoc().getEndLoc());
11127          DB << FixItHint::CreateInsertion(InsertLoc, " ")
11128             << FixItHint::CreateInsertionFromRange(
11129                    InsertLoc, CharSourceRange::getTokenRange(Before))
11130             << FixItHint::CreateRemoval(Before);
11131        }
11132      } else if (!Proto->getReturnType()->isDependentType()) {
11133        DB << /*typedef*/1 << Proto->getReturnType();
11134      } else if (getLangOpts().CPlusPlus11) {
11135        DB << /*alias template*/2 << Proto->getReturnType();
11136      } else {
11137        DB << /*might not be fixable*/3;
11138      }
11139  
11140      // Recover by incorporating the other type chunks into the result type.
11141      // Note, this does *not* change the name of the function. This is compatible
11142      // with the GCC extension:
11143      //   struct S { &operator int(); } s;
11144      //   int &r = s.operator int(); // ok in GCC
11145      //   S::operator int&() {} // error in GCC, function name is 'operator int'.
11146      ConvType = Proto->getReturnType();
11147    }
11148  
11149    // C++ [class.conv.fct]p4:
11150    //   The conversion-type-id shall not represent a function type nor
11151    //   an array type.
11152    if (ConvType->isArrayType()) {
11153      Diag(D.getIdentifierLoc(), diag::err_conv_function_to_array);
11154      ConvType = Context.getPointerType(ConvType);
11155      D.setInvalidType();
11156    } else if (ConvType->isFunctionType()) {
11157      Diag(D.getIdentifierLoc(), diag::err_conv_function_to_function);
11158      ConvType = Context.getPointerType(ConvType);
11159      D.setInvalidType();
11160    }
11161  
11162    // Rebuild the function type "R" without any parameters (in case any
11163    // of the errors above fired) and with the conversion type as the
11164    // return type.
11165    if (D.isInvalidType())
11166      R = Context.getFunctionType(ConvType, std::nullopt,
11167                                  Proto->getExtProtoInfo());
11168  
11169    // C++0x explicit conversion operators.
11170    if (DS.hasExplicitSpecifier() && !getLangOpts().CPlusPlus20)
11171      Diag(DS.getExplicitSpecLoc(),
11172           getLangOpts().CPlusPlus11
11173               ? diag::warn_cxx98_compat_explicit_conversion_functions
11174               : diag::ext_explicit_conversion_functions)
11175          << SourceRange(DS.getExplicitSpecRange());
11176  }
11177  
11178  Decl *Sema::ActOnConversionDeclarator(CXXConversionDecl *Conversion) {
11179    assert(Conversion && "Expected to receive a conversion function declaration");
11180  
11181    CXXRecordDecl *ClassDecl = cast<CXXRecordDecl>(Conversion->getDeclContext());
11182  
11183    // Make sure we aren't redeclaring the conversion function.
11184    QualType ConvType = Context.getCanonicalType(Conversion->getConversionType());
11185    // C++ [class.conv.fct]p1:
11186    //   [...] A conversion function is never used to convert a
11187    //   (possibly cv-qualified) object to the (possibly cv-qualified)
11188    //   same object type (or a reference to it), to a (possibly
11189    //   cv-qualified) base class of that type (or a reference to it),
11190    //   or to (possibly cv-qualified) void.
11191    QualType ClassType
11192      = Context.getCanonicalType(Context.getTypeDeclType(ClassDecl));
11193    if (const ReferenceType *ConvTypeRef = ConvType->getAs<ReferenceType>())
11194      ConvType = ConvTypeRef->getPointeeType();
11195    if (Conversion->getTemplateSpecializationKind() != TSK_Undeclared &&
11196        Conversion->getTemplateSpecializationKind() != TSK_ExplicitSpecialization)
11197      /* Suppress diagnostics for instantiations. */;
11198    else if (Conversion->size_overridden_methods() != 0)
11199      /* Suppress diagnostics for overriding virtual function in a base class. */;
11200    else if (ConvType->isRecordType()) {
11201      ConvType = Context.getCanonicalType(ConvType).getUnqualifiedType();
11202      if (ConvType == ClassType)
11203        Diag(Conversion->getLocation(), diag::warn_conv_to_self_not_used)
11204          << ClassType;
11205      else if (IsDerivedFrom(Conversion->getLocation(), ClassType, ConvType))
11206        Diag(Conversion->getLocation(), diag::warn_conv_to_base_not_used)
11207          <<  ClassType << ConvType;
11208    } else if (ConvType->isVoidType()) {
11209      Diag(Conversion->getLocation(), diag::warn_conv_to_void_not_used)
11210        << ClassType << ConvType;
11211    }
11212  
11213    if (FunctionTemplateDecl *ConversionTemplate =
11214            Conversion->getDescribedFunctionTemplate()) {
11215      if (const auto *ConvTypePtr = ConvType->getAs<PointerType>()) {
11216        ConvType = ConvTypePtr->getPointeeType();
11217      }
11218      if (ConvType->isUndeducedAutoType()) {
11219        Diag(Conversion->getTypeSpecStartLoc(), diag::err_auto_not_allowed)
11220            << getReturnTypeLoc(Conversion).getSourceRange()
11221            << llvm::to_underlying(ConvType->castAs<AutoType>()->getKeyword())
11222            << /* in declaration of conversion function template= */ 24;
11223      }
11224  
11225      return ConversionTemplate;
11226    }
11227  
11228    return Conversion;
11229  }
11230  
11231  void Sema::CheckExplicitObjectMemberFunction(DeclContext *DC, Declarator &D,
11232                                               DeclarationName Name, QualType R) {
11233    CheckExplicitObjectMemberFunction(D, Name, R, false, DC);
11234  }
11235  
11236  void Sema::CheckExplicitObjectLambda(Declarator &D) {
11237    CheckExplicitObjectMemberFunction(D, {}, {}, true);
11238  }
11239  
11240  void Sema::CheckExplicitObjectMemberFunction(Declarator &D,
11241                                               DeclarationName Name, QualType R,
11242                                               bool IsLambda, DeclContext *DC) {
11243    if (!D.isFunctionDeclarator())
11244      return;
11245  
11246    DeclaratorChunk::FunctionTypeInfo &FTI = D.getFunctionTypeInfo();
11247    if (FTI.NumParams == 0)
11248      return;
11249    ParmVarDecl *ExplicitObjectParam = nullptr;
11250    for (unsigned Idx = 0; Idx < FTI.NumParams; Idx++) {
11251      const auto &ParamInfo = FTI.Params[Idx];
11252      if (!ParamInfo.Param)
11253        continue;
11254      ParmVarDecl *Param = cast<ParmVarDecl>(ParamInfo.Param);
11255      if (!Param->isExplicitObjectParameter())
11256        continue;
11257      if (Idx == 0) {
11258        ExplicitObjectParam = Param;
11259        continue;
11260      } else {
11261        Diag(Param->getLocation(),
11262             diag::err_explicit_object_parameter_must_be_first)
11263            << IsLambda << Param->getSourceRange();
11264      }
11265    }
11266    if (!ExplicitObjectParam)
11267      return;
11268  
11269    if (ExplicitObjectParam->hasDefaultArg()) {
11270      Diag(ExplicitObjectParam->getLocation(),
11271           diag::err_explicit_object_default_arg)
11272          << ExplicitObjectParam->getSourceRange();
11273    }
11274  
11275    if (D.getDeclSpec().getStorageClassSpec() == DeclSpec::SCS_static ||
11276        (D.getContext() == clang::DeclaratorContext::Member &&
11277         D.isStaticMember())) {
11278      Diag(ExplicitObjectParam->getBeginLoc(),
11279           diag::err_explicit_object_parameter_nonmember)
11280          << D.getSourceRange() << /*static=*/0 << IsLambda;
11281      D.setInvalidType();
11282    }
11283  
11284    if (D.getDeclSpec().isVirtualSpecified()) {
11285      Diag(ExplicitObjectParam->getBeginLoc(),
11286           diag::err_explicit_object_parameter_nonmember)
11287          << D.getSourceRange() << /*virtual=*/1 << IsLambda;
11288      D.setInvalidType();
11289    }
11290  
11291    // Friend declarations require some care. Consider:
11292    //
11293    // namespace N {
11294    // struct A{};
11295    // int f(A);
11296    // }
11297    //
11298    // struct S {
11299    //   struct T {
11300    //     int f(this T);
11301    //   };
11302    //
11303    //   friend int T::f(this T); // Allow this.
11304    //   friend int f(this S);    // But disallow this.
11305    //   friend int N::f(this A); // And disallow this.
11306    // };
11307    //
11308    // Here, it seems to suffice to check whether the scope
11309    // specifier designates a class type.
11310    if (D.getDeclSpec().isFriendSpecified() &&
11311        !isa_and_present<CXXRecordDecl>(
11312            computeDeclContext(D.getCXXScopeSpec()))) {
11313      Diag(ExplicitObjectParam->getBeginLoc(),
11314           diag::err_explicit_object_parameter_nonmember)
11315          << D.getSourceRange() << /*non-member=*/2 << IsLambda;
11316      D.setInvalidType();
11317    }
11318  
11319    if (IsLambda && FTI.hasMutableQualifier()) {
11320      Diag(ExplicitObjectParam->getBeginLoc(),
11321           diag::err_explicit_object_parameter_mutable)
11322          << D.getSourceRange();
11323    }
11324  
11325    if (IsLambda)
11326      return;
11327  
11328    if (!DC || !DC->isRecord()) {
11329      assert(D.isInvalidType() && "Explicit object parameter in non-member "
11330                                  "should have been diagnosed already");
11331      return;
11332    }
11333  
11334    // CWG2674: constructors and destructors cannot have explicit parameters.
11335    if (Name.getNameKind() == DeclarationName::CXXConstructorName ||
11336        Name.getNameKind() == DeclarationName::CXXDestructorName) {
11337      Diag(ExplicitObjectParam->getBeginLoc(),
11338           diag::err_explicit_object_parameter_constructor)
11339          << (Name.getNameKind() == DeclarationName::CXXDestructorName)
11340          << D.getSourceRange();
11341      D.setInvalidType();
11342    }
11343  }
11344  
11345  namespace {
11346  /// Utility class to accumulate and print a diagnostic listing the invalid
11347  /// specifier(s) on a declaration.
11348  struct BadSpecifierDiagnoser {
11349    BadSpecifierDiagnoser(Sema &S, SourceLocation Loc, unsigned DiagID)
11350        : S(S), Diagnostic(S.Diag(Loc, DiagID)) {}
11351    ~BadSpecifierDiagnoser() {
11352      Diagnostic << Specifiers;
11353    }
11354  
11355    template<typename T> void check(SourceLocation SpecLoc, T Spec) {
11356      return check(SpecLoc, DeclSpec::getSpecifierName(Spec));
11357    }
11358    void check(SourceLocation SpecLoc, DeclSpec::TST Spec) {
11359      return check(SpecLoc,
11360                   DeclSpec::getSpecifierName(Spec, S.getPrintingPolicy()));
11361    }
11362    void check(SourceLocation SpecLoc, const char *Spec) {
11363      if (SpecLoc.isInvalid()) return;
11364      Diagnostic << SourceRange(SpecLoc, SpecLoc);
11365      if (!Specifiers.empty()) Specifiers += " ";
11366      Specifiers += Spec;
11367    }
11368  
11369    Sema &S;
11370    Sema::SemaDiagnosticBuilder Diagnostic;
11371    std::string Specifiers;
11372  };
11373  }
11374  
11375  bool Sema::CheckDeductionGuideDeclarator(Declarator &D, QualType &R,
11376                                           StorageClass &SC) {
11377    TemplateName GuidedTemplate = D.getName().TemplateName.get().get();
11378    TemplateDecl *GuidedTemplateDecl = GuidedTemplate.getAsTemplateDecl();
11379    assert(GuidedTemplateDecl && "missing template decl for deduction guide");
11380  
11381    // C++ [temp.deduct.guide]p3:
11382    //   A deduction-gide shall be declared in the same scope as the
11383    //   corresponding class template.
11384    if (!CurContext->getRedeclContext()->Equals(
11385            GuidedTemplateDecl->getDeclContext()->getRedeclContext())) {
11386      Diag(D.getIdentifierLoc(), diag::err_deduction_guide_wrong_scope)
11387        << GuidedTemplateDecl;
11388      NoteTemplateLocation(*GuidedTemplateDecl);
11389    }
11390  
11391    auto &DS = D.getMutableDeclSpec();
11392    // We leave 'friend' and 'virtual' to be rejected in the normal way.
11393    if (DS.hasTypeSpecifier() || DS.getTypeQualifiers() ||
11394        DS.getStorageClassSpecLoc().isValid() || DS.isInlineSpecified() ||
11395        DS.isNoreturnSpecified() || DS.hasConstexprSpecifier()) {
11396      BadSpecifierDiagnoser Diagnoser(
11397          *this, D.getIdentifierLoc(),
11398          diag::err_deduction_guide_invalid_specifier);
11399  
11400      Diagnoser.check(DS.getStorageClassSpecLoc(), DS.getStorageClassSpec());
11401      DS.ClearStorageClassSpecs();
11402      SC = SC_None;
11403  
11404      // 'explicit' is permitted.
11405      Diagnoser.check(DS.getInlineSpecLoc(), "inline");
11406      Diagnoser.check(DS.getNoreturnSpecLoc(), "_Noreturn");
11407      Diagnoser.check(DS.getConstexprSpecLoc(), "constexpr");
11408      DS.ClearConstexprSpec();
11409  
11410      Diagnoser.check(DS.getConstSpecLoc(), "const");
11411      Diagnoser.check(DS.getRestrictSpecLoc(), "__restrict");
11412      Diagnoser.check(DS.getVolatileSpecLoc(), "volatile");
11413      Diagnoser.check(DS.getAtomicSpecLoc(), "_Atomic");
11414      Diagnoser.check(DS.getUnalignedSpecLoc(), "__unaligned");
11415      DS.ClearTypeQualifiers();
11416  
11417      Diagnoser.check(DS.getTypeSpecComplexLoc(), DS.getTypeSpecComplex());
11418      Diagnoser.check(DS.getTypeSpecSignLoc(), DS.getTypeSpecSign());
11419      Diagnoser.check(DS.getTypeSpecWidthLoc(), DS.getTypeSpecWidth());
11420      Diagnoser.check(DS.getTypeSpecTypeLoc(), DS.getTypeSpecType());
11421      DS.ClearTypeSpecType();
11422    }
11423  
11424    if (D.isInvalidType())
11425      return true;
11426  
11427    // Check the declarator is simple enough.
11428    bool FoundFunction = false;
11429    for (const DeclaratorChunk &Chunk : llvm::reverse(D.type_objects())) {
11430      if (Chunk.Kind == DeclaratorChunk::Paren)
11431        continue;
11432      if (Chunk.Kind != DeclaratorChunk::Function || FoundFunction) {
11433        Diag(D.getDeclSpec().getBeginLoc(),
11434             diag::err_deduction_guide_with_complex_decl)
11435            << D.getSourceRange();
11436        break;
11437      }
11438      if (!Chunk.Fun.hasTrailingReturnType())
11439        return Diag(D.getName().getBeginLoc(),
11440                    diag::err_deduction_guide_no_trailing_return_type);
11441  
11442      // Check that the return type is written as a specialization of
11443      // the template specified as the deduction-guide's name.
11444      // The template name may not be qualified. [temp.deduct.guide]
11445      ParsedType TrailingReturnType = Chunk.Fun.getTrailingReturnType();
11446      TypeSourceInfo *TSI = nullptr;
11447      QualType RetTy = GetTypeFromParser(TrailingReturnType, &TSI);
11448      assert(TSI && "deduction guide has valid type but invalid return type?");
11449      bool AcceptableReturnType = false;
11450      bool MightInstantiateToSpecialization = false;
11451      if (auto RetTST =
11452              TSI->getTypeLoc().getAsAdjusted<TemplateSpecializationTypeLoc>()) {
11453        TemplateName SpecifiedName = RetTST.getTypePtr()->getTemplateName();
11454        bool TemplateMatches =
11455            Context.hasSameTemplateName(SpecifiedName, GuidedTemplate);
11456  
11457        const QualifiedTemplateName *Qualifiers =
11458            SpecifiedName.getAsQualifiedTemplateName();
11459        assert(Qualifiers && "expected QualifiedTemplate");
11460        bool SimplyWritten = !Qualifiers->hasTemplateKeyword() &&
11461                             Qualifiers->getQualifier() == nullptr;
11462        if (SimplyWritten && TemplateMatches)
11463          AcceptableReturnType = true;
11464        else {
11465          // This could still instantiate to the right type, unless we know it
11466          // names the wrong class template.
11467          auto *TD = SpecifiedName.getAsTemplateDecl();
11468          MightInstantiateToSpecialization = !(TD && isa<ClassTemplateDecl>(TD) &&
11469                                               !TemplateMatches);
11470        }
11471      } else if (!RetTy.hasQualifiers() && RetTy->isDependentType()) {
11472        MightInstantiateToSpecialization = true;
11473      }
11474  
11475      if (!AcceptableReturnType)
11476        return Diag(TSI->getTypeLoc().getBeginLoc(),
11477                    diag::err_deduction_guide_bad_trailing_return_type)
11478               << GuidedTemplate << TSI->getType()
11479               << MightInstantiateToSpecialization
11480               << TSI->getTypeLoc().getSourceRange();
11481  
11482      // Keep going to check that we don't have any inner declarator pieces (we
11483      // could still have a function returning a pointer to a function).
11484      FoundFunction = true;
11485    }
11486  
11487    if (D.isFunctionDefinition())
11488      // we can still create a valid deduction guide here.
11489      Diag(D.getIdentifierLoc(), diag::err_deduction_guide_defines_function);
11490    return false;
11491  }
11492  
11493  //===----------------------------------------------------------------------===//
11494  // Namespace Handling
11495  //===----------------------------------------------------------------------===//
11496  
11497  /// Diagnose a mismatch in 'inline' qualifiers when a namespace is
11498  /// reopened.
11499  static void DiagnoseNamespaceInlineMismatch(Sema &S, SourceLocation KeywordLoc,
11500                                              SourceLocation Loc,
11501                                              IdentifierInfo *II, bool *IsInline,
11502                                              NamespaceDecl *PrevNS) {
11503    assert(*IsInline != PrevNS->isInline());
11504  
11505    // 'inline' must appear on the original definition, but not necessarily
11506    // on all extension definitions, so the note should point to the first
11507    // definition to avoid confusion.
11508    PrevNS = PrevNS->getFirstDecl();
11509  
11510    if (PrevNS->isInline())
11511      // The user probably just forgot the 'inline', so suggest that it
11512      // be added back.
11513      S.Diag(Loc, diag::warn_inline_namespace_reopened_noninline)
11514        << FixItHint::CreateInsertion(KeywordLoc, "inline ");
11515    else
11516      S.Diag(Loc, diag::err_inline_namespace_mismatch);
11517  
11518    S.Diag(PrevNS->getLocation(), diag::note_previous_definition);
11519    *IsInline = PrevNS->isInline();
11520  }
11521  
11522  /// ActOnStartNamespaceDef - This is called at the start of a namespace
11523  /// definition.
11524  Decl *Sema::ActOnStartNamespaceDef(Scope *NamespcScope,
11525                                     SourceLocation InlineLoc,
11526                                     SourceLocation NamespaceLoc,
11527                                     SourceLocation IdentLoc, IdentifierInfo *II,
11528                                     SourceLocation LBrace,
11529                                     const ParsedAttributesView &AttrList,
11530                                     UsingDirectiveDecl *&UD, bool IsNested) {
11531    SourceLocation StartLoc = InlineLoc.isValid() ? InlineLoc : NamespaceLoc;
11532    // For anonymous namespace, take the location of the left brace.
11533    SourceLocation Loc = II ? IdentLoc : LBrace;
11534    bool IsInline = InlineLoc.isValid();
11535    bool IsInvalid = false;
11536    bool IsStd = false;
11537    bool AddToKnown = false;
11538    Scope *DeclRegionScope = NamespcScope->getParent();
11539  
11540    NamespaceDecl *PrevNS = nullptr;
11541    if (II) {
11542      // C++ [namespace.std]p7:
11543      //   A translation unit shall not declare namespace std to be an inline
11544      //   namespace (9.8.2).
11545      //
11546      // Precondition: the std namespace is in the file scope and is declared to
11547      // be inline
11548      auto DiagnoseInlineStdNS = [&]() {
11549        assert(IsInline && II->isStr("std") &&
11550               CurContext->getRedeclContext()->isTranslationUnit() &&
11551               "Precondition of DiagnoseInlineStdNS not met");
11552        Diag(InlineLoc, diag::err_inline_namespace_std)
11553            << SourceRange(InlineLoc, InlineLoc.getLocWithOffset(6));
11554        IsInline = false;
11555      };
11556      // C++ [namespace.def]p2:
11557      //   The identifier in an original-namespace-definition shall not
11558      //   have been previously defined in the declarative region in
11559      //   which the original-namespace-definition appears. The
11560      //   identifier in an original-namespace-definition is the name of
11561      //   the namespace. Subsequently in that declarative region, it is
11562      //   treated as an original-namespace-name.
11563      //
11564      // Since namespace names are unique in their scope, and we don't
11565      // look through using directives, just look for any ordinary names
11566      // as if by qualified name lookup.
11567      LookupResult R(*this, II, IdentLoc, LookupOrdinaryName,
11568                     RedeclarationKind::ForExternalRedeclaration);
11569      LookupQualifiedName(R, CurContext->getRedeclContext());
11570      NamedDecl *PrevDecl =
11571          R.isSingleResult() ? R.getRepresentativeDecl() : nullptr;
11572      PrevNS = dyn_cast_or_null<NamespaceDecl>(PrevDecl);
11573  
11574      if (PrevNS) {
11575        // This is an extended namespace definition.
11576        if (IsInline && II->isStr("std") &&
11577            CurContext->getRedeclContext()->isTranslationUnit())
11578          DiagnoseInlineStdNS();
11579        else if (IsInline != PrevNS->isInline())
11580          DiagnoseNamespaceInlineMismatch(*this, NamespaceLoc, Loc, II,
11581                                          &IsInline, PrevNS);
11582      } else if (PrevDecl) {
11583        // This is an invalid name redefinition.
11584        Diag(Loc, diag::err_redefinition_different_kind)
11585          << II;
11586        Diag(PrevDecl->getLocation(), diag::note_previous_definition);
11587        IsInvalid = true;
11588        // Continue on to push Namespc as current DeclContext and return it.
11589      } else if (II->isStr("std") &&
11590                 CurContext->getRedeclContext()->isTranslationUnit()) {
11591        if (IsInline)
11592          DiagnoseInlineStdNS();
11593        // This is the first "real" definition of the namespace "std", so update
11594        // our cache of the "std" namespace to point at this definition.
11595        PrevNS = getStdNamespace();
11596        IsStd = true;
11597        AddToKnown = !IsInline;
11598      } else {
11599        // We've seen this namespace for the first time.
11600        AddToKnown = !IsInline;
11601      }
11602    } else {
11603      // Anonymous namespaces.
11604  
11605      // Determine whether the parent already has an anonymous namespace.
11606      DeclContext *Parent = CurContext->getRedeclContext();
11607      if (TranslationUnitDecl *TU = dyn_cast<TranslationUnitDecl>(Parent)) {
11608        PrevNS = TU->getAnonymousNamespace();
11609      } else {
11610        NamespaceDecl *ND = cast<NamespaceDecl>(Parent);
11611        PrevNS = ND->getAnonymousNamespace();
11612      }
11613  
11614      if (PrevNS && IsInline != PrevNS->isInline())
11615        DiagnoseNamespaceInlineMismatch(*this, NamespaceLoc, NamespaceLoc, II,
11616                                        &IsInline, PrevNS);
11617    }
11618  
11619    NamespaceDecl *Namespc = NamespaceDecl::Create(
11620        Context, CurContext, IsInline, StartLoc, Loc, II, PrevNS, IsNested);
11621    if (IsInvalid)
11622      Namespc->setInvalidDecl();
11623  
11624    ProcessDeclAttributeList(DeclRegionScope, Namespc, AttrList);
11625    AddPragmaAttributes(DeclRegionScope, Namespc);
11626    ProcessAPINotes(Namespc);
11627  
11628    // FIXME: Should we be merging attributes?
11629    if (const VisibilityAttr *Attr = Namespc->getAttr<VisibilityAttr>())
11630      PushNamespaceVisibilityAttr(Attr, Loc);
11631  
11632    if (IsStd)
11633      StdNamespace = Namespc;
11634    if (AddToKnown)
11635      KnownNamespaces[Namespc] = false;
11636  
11637    if (II) {
11638      PushOnScopeChains(Namespc, DeclRegionScope);
11639    } else {
11640      // Link the anonymous namespace into its parent.
11641      DeclContext *Parent = CurContext->getRedeclContext();
11642      if (TranslationUnitDecl *TU = dyn_cast<TranslationUnitDecl>(Parent)) {
11643        TU->setAnonymousNamespace(Namespc);
11644      } else {
11645        cast<NamespaceDecl>(Parent)->setAnonymousNamespace(Namespc);
11646      }
11647  
11648      CurContext->addDecl(Namespc);
11649  
11650      // C++ [namespace.unnamed]p1.  An unnamed-namespace-definition
11651      //   behaves as if it were replaced by
11652      //     namespace unique { /* empty body */ }
11653      //     using namespace unique;
11654      //     namespace unique { namespace-body }
11655      //   where all occurrences of 'unique' in a translation unit are
11656      //   replaced by the same identifier and this identifier differs
11657      //   from all other identifiers in the entire program.
11658  
11659      // We just create the namespace with an empty name and then add an
11660      // implicit using declaration, just like the standard suggests.
11661      //
11662      // CodeGen enforces the "universally unique" aspect by giving all
11663      // declarations semantically contained within an anonymous
11664      // namespace internal linkage.
11665  
11666      if (!PrevNS) {
11667        UD = UsingDirectiveDecl::Create(Context, Parent,
11668                                        /* 'using' */ LBrace,
11669                                        /* 'namespace' */ SourceLocation(),
11670                                        /* qualifier */ NestedNameSpecifierLoc(),
11671                                        /* identifier */ SourceLocation(),
11672                                        Namespc,
11673                                        /* Ancestor */ Parent);
11674        UD->setImplicit();
11675        Parent->addDecl(UD);
11676      }
11677    }
11678  
11679    ActOnDocumentableDecl(Namespc);
11680  
11681    // Although we could have an invalid decl (i.e. the namespace name is a
11682    // redefinition), push it as current DeclContext and try to continue parsing.
11683    // FIXME: We should be able to push Namespc here, so that the each DeclContext
11684    // for the namespace has the declarations that showed up in that particular
11685    // namespace definition.
11686    PushDeclContext(NamespcScope, Namespc);
11687    return Namespc;
11688  }
11689  
11690  /// getNamespaceDecl - Returns the namespace a decl represents. If the decl
11691  /// is a namespace alias, returns the namespace it points to.
11692  static inline NamespaceDecl *getNamespaceDecl(NamedDecl *D) {
11693    if (NamespaceAliasDecl *AD = dyn_cast_or_null<NamespaceAliasDecl>(D))
11694      return AD->getNamespace();
11695    return dyn_cast_or_null<NamespaceDecl>(D);
11696  }
11697  
11698  void Sema::ActOnFinishNamespaceDef(Decl *Dcl, SourceLocation RBrace) {
11699    NamespaceDecl *Namespc = dyn_cast_or_null<NamespaceDecl>(Dcl);
11700    assert(Namespc && "Invalid parameter, expected NamespaceDecl");
11701    Namespc->setRBraceLoc(RBrace);
11702    PopDeclContext();
11703    if (Namespc->hasAttr<VisibilityAttr>())
11704      PopPragmaVisibility(true, RBrace);
11705    // If this namespace contains an export-declaration, export it now.
11706    if (DeferredExportedNamespaces.erase(Namespc))
11707      Dcl->setModuleOwnershipKind(Decl::ModuleOwnershipKind::VisibleWhenImported);
11708  }
11709  
11710  CXXRecordDecl *Sema::getStdBadAlloc() const {
11711    return cast_or_null<CXXRecordDecl>(
11712                                    StdBadAlloc.get(Context.getExternalSource()));
11713  }
11714  
11715  EnumDecl *Sema::getStdAlignValT() const {
11716    return cast_or_null<EnumDecl>(StdAlignValT.get(Context.getExternalSource()));
11717  }
11718  
11719  NamespaceDecl *Sema::getStdNamespace() const {
11720    return cast_or_null<NamespaceDecl>(
11721                                   StdNamespace.get(Context.getExternalSource()));
11722  }
11723  namespace {
11724  
11725  enum UnsupportedSTLSelect {
11726    USS_InvalidMember,
11727    USS_MissingMember,
11728    USS_NonTrivial,
11729    USS_Other
11730  };
11731  
11732  struct InvalidSTLDiagnoser {
11733    Sema &S;
11734    SourceLocation Loc;
11735    QualType TyForDiags;
11736  
11737    QualType operator()(UnsupportedSTLSelect Sel = USS_Other, StringRef Name = "",
11738                        const VarDecl *VD = nullptr) {
11739      {
11740        auto D = S.Diag(Loc, diag::err_std_compare_type_not_supported)
11741                 << TyForDiags << ((int)Sel);
11742        if (Sel == USS_InvalidMember || Sel == USS_MissingMember) {
11743          assert(!Name.empty());
11744          D << Name;
11745        }
11746      }
11747      if (Sel == USS_InvalidMember) {
11748        S.Diag(VD->getLocation(), diag::note_var_declared_here)
11749            << VD << VD->getSourceRange();
11750      }
11751      return QualType();
11752    }
11753  };
11754  } // namespace
11755  
11756  QualType Sema::CheckComparisonCategoryType(ComparisonCategoryType Kind,
11757                                             SourceLocation Loc,
11758                                             ComparisonCategoryUsage Usage) {
11759    assert(getLangOpts().CPlusPlus &&
11760           "Looking for comparison category type outside of C++.");
11761  
11762    // Use an elaborated type for diagnostics which has a name containing the
11763    // prepended 'std' namespace but not any inline namespace names.
11764    auto TyForDiags = [&](ComparisonCategoryInfo *Info) {
11765      auto *NNS =
11766          NestedNameSpecifier::Create(Context, nullptr, getStdNamespace());
11767      return Context.getElaboratedType(ElaboratedTypeKeyword::None, NNS,
11768                                       Info->getType());
11769    };
11770  
11771    // Check if we've already successfully checked the comparison category type
11772    // before. If so, skip checking it again.
11773    ComparisonCategoryInfo *Info = Context.CompCategories.lookupInfo(Kind);
11774    if (Info && FullyCheckedComparisonCategories[static_cast<unsigned>(Kind)]) {
11775      // The only thing we need to check is that the type has a reachable
11776      // definition in the current context.
11777      if (RequireCompleteType(Loc, TyForDiags(Info), diag::err_incomplete_type))
11778        return QualType();
11779  
11780      return Info->getType();
11781    }
11782  
11783    // If lookup failed
11784    if (!Info) {
11785      std::string NameForDiags = "std::";
11786      NameForDiags += ComparisonCategories::getCategoryString(Kind);
11787      Diag(Loc, diag::err_implied_comparison_category_type_not_found)
11788          << NameForDiags << (int)Usage;
11789      return QualType();
11790    }
11791  
11792    assert(Info->Kind == Kind);
11793    assert(Info->Record);
11794  
11795    // Update the Record decl in case we encountered a forward declaration on our
11796    // first pass. FIXME: This is a bit of a hack.
11797    if (Info->Record->hasDefinition())
11798      Info->Record = Info->Record->getDefinition();
11799  
11800    if (RequireCompleteType(Loc, TyForDiags(Info), diag::err_incomplete_type))
11801      return QualType();
11802  
11803    InvalidSTLDiagnoser UnsupportedSTLError{*this, Loc, TyForDiags(Info)};
11804  
11805    if (!Info->Record->isTriviallyCopyable())
11806      return UnsupportedSTLError(USS_NonTrivial);
11807  
11808    for (const CXXBaseSpecifier &BaseSpec : Info->Record->bases()) {
11809      CXXRecordDecl *Base = BaseSpec.getType()->getAsCXXRecordDecl();
11810      // Tolerate empty base classes.
11811      if (Base->isEmpty())
11812        continue;
11813      // Reject STL implementations which have at least one non-empty base.
11814      return UnsupportedSTLError();
11815    }
11816  
11817    // Check that the STL has implemented the types using a single integer field.
11818    // This expectation allows better codegen for builtin operators. We require:
11819    //   (1) The class has exactly one field.
11820    //   (2) The field is an integral or enumeration type.
11821    auto FIt = Info->Record->field_begin(), FEnd = Info->Record->field_end();
11822    if (std::distance(FIt, FEnd) != 1 ||
11823        !FIt->getType()->isIntegralOrEnumerationType()) {
11824      return UnsupportedSTLError();
11825    }
11826  
11827    // Build each of the require values and store them in Info.
11828    for (ComparisonCategoryResult CCR :
11829         ComparisonCategories::getPossibleResultsForType(Kind)) {
11830      StringRef MemName = ComparisonCategories::getResultString(CCR);
11831      ComparisonCategoryInfo::ValueInfo *ValInfo = Info->lookupValueInfo(CCR);
11832  
11833      if (!ValInfo)
11834        return UnsupportedSTLError(USS_MissingMember, MemName);
11835  
11836      VarDecl *VD = ValInfo->VD;
11837      assert(VD && "should not be null!");
11838  
11839      // Attempt to diagnose reasons why the STL definition of this type
11840      // might be foobar, including it failing to be a constant expression.
11841      // TODO Handle more ways the lookup or result can be invalid.
11842      if (!VD->isStaticDataMember() ||
11843          !VD->isUsableInConstantExpressions(Context))
11844        return UnsupportedSTLError(USS_InvalidMember, MemName, VD);
11845  
11846      // Attempt to evaluate the var decl as a constant expression and extract
11847      // the value of its first field as a ICE. If this fails, the STL
11848      // implementation is not supported.
11849      if (!ValInfo->hasValidIntValue())
11850        return UnsupportedSTLError();
11851  
11852      MarkVariableReferenced(Loc, VD);
11853    }
11854  
11855    // We've successfully built the required types and expressions. Update
11856    // the cache and return the newly cached value.
11857    FullyCheckedComparisonCategories[static_cast<unsigned>(Kind)] = true;
11858    return Info->getType();
11859  }
11860  
11861  NamespaceDecl *Sema::getOrCreateStdNamespace() {
11862    if (!StdNamespace) {
11863      // The "std" namespace has not yet been defined, so build one implicitly.
11864      StdNamespace = NamespaceDecl::Create(
11865          Context, Context.getTranslationUnitDecl(),
11866          /*Inline=*/false, SourceLocation(), SourceLocation(),
11867          &PP.getIdentifierTable().get("std"),
11868          /*PrevDecl=*/nullptr, /*Nested=*/false);
11869      getStdNamespace()->setImplicit(true);
11870      // We want the created NamespaceDecl to be available for redeclaration
11871      // lookups, but not for regular name lookups.
11872      Context.getTranslationUnitDecl()->addDecl(getStdNamespace());
11873      getStdNamespace()->clearIdentifierNamespace();
11874    }
11875  
11876    return getStdNamespace();
11877  }
11878  
11879  bool Sema::isStdInitializerList(QualType Ty, QualType *Element) {
11880    assert(getLangOpts().CPlusPlus &&
11881           "Looking for std::initializer_list outside of C++.");
11882  
11883    // We're looking for implicit instantiations of
11884    // template <typename E> class std::initializer_list.
11885  
11886    if (!StdNamespace) // If we haven't seen namespace std yet, this can't be it.
11887      return false;
11888  
11889    ClassTemplateDecl *Template = nullptr;
11890    const TemplateArgument *Arguments = nullptr;
11891  
11892    if (const RecordType *RT = Ty->getAs<RecordType>()) {
11893  
11894      ClassTemplateSpecializationDecl *Specialization =
11895          dyn_cast<ClassTemplateSpecializationDecl>(RT->getDecl());
11896      if (!Specialization)
11897        return false;
11898  
11899      Template = Specialization->getSpecializedTemplate();
11900      Arguments = Specialization->getTemplateArgs().data();
11901    } else {
11902      const TemplateSpecializationType *TST = nullptr;
11903      if (auto *ICN = Ty->getAs<InjectedClassNameType>())
11904        TST = ICN->getInjectedTST();
11905      else
11906        TST = Ty->getAs<TemplateSpecializationType>();
11907      if (TST) {
11908        Template = dyn_cast_or_null<ClassTemplateDecl>(
11909            TST->getTemplateName().getAsTemplateDecl());
11910        Arguments = TST->template_arguments().begin();
11911      }
11912    }
11913    if (!Template)
11914      return false;
11915  
11916    if (!StdInitializerList) {
11917      // Haven't recognized std::initializer_list yet, maybe this is it.
11918      CXXRecordDecl *TemplateClass = Template->getTemplatedDecl();
11919      if (TemplateClass->getIdentifier() !=
11920              &PP.getIdentifierTable().get("initializer_list") ||
11921          !getStdNamespace()->InEnclosingNamespaceSetOf(
11922              TemplateClass->getNonTransparentDeclContext()))
11923        return false;
11924      // This is a template called std::initializer_list, but is it the right
11925      // template?
11926      TemplateParameterList *Params = Template->getTemplateParameters();
11927      if (Params->getMinRequiredArguments() != 1)
11928        return false;
11929      if (!isa<TemplateTypeParmDecl>(Params->getParam(0)))
11930        return false;
11931  
11932      // It's the right template.
11933      StdInitializerList = Template;
11934    }
11935  
11936    if (Template->getCanonicalDecl() != StdInitializerList->getCanonicalDecl())
11937      return false;
11938  
11939    // This is an instance of std::initializer_list. Find the argument type.
11940    if (Element)
11941      *Element = Arguments[0].getAsType();
11942    return true;
11943  }
11944  
11945  static ClassTemplateDecl *LookupStdInitializerList(Sema &S, SourceLocation Loc){
11946    NamespaceDecl *Std = S.getStdNamespace();
11947    if (!Std) {
11948      S.Diag(Loc, diag::err_implied_std_initializer_list_not_found);
11949      return nullptr;
11950    }
11951  
11952    LookupResult Result(S, &S.PP.getIdentifierTable().get("initializer_list"),
11953                        Loc, Sema::LookupOrdinaryName);
11954    if (!S.LookupQualifiedName(Result, Std)) {
11955      S.Diag(Loc, diag::err_implied_std_initializer_list_not_found);
11956      return nullptr;
11957    }
11958    ClassTemplateDecl *Template = Result.getAsSingle<ClassTemplateDecl>();
11959    if (!Template) {
11960      Result.suppressDiagnostics();
11961      // We found something weird. Complain about the first thing we found.
11962      NamedDecl *Found = *Result.begin();
11963      S.Diag(Found->getLocation(), diag::err_malformed_std_initializer_list);
11964      return nullptr;
11965    }
11966  
11967    // We found some template called std::initializer_list. Now verify that it's
11968    // correct.
11969    TemplateParameterList *Params = Template->getTemplateParameters();
11970    if (Params->getMinRequiredArguments() != 1 ||
11971        !isa<TemplateTypeParmDecl>(Params->getParam(0))) {
11972      S.Diag(Template->getLocation(), diag::err_malformed_std_initializer_list);
11973      return nullptr;
11974    }
11975  
11976    return Template;
11977  }
11978  
11979  QualType Sema::BuildStdInitializerList(QualType Element, SourceLocation Loc) {
11980    if (!StdInitializerList) {
11981      StdInitializerList = LookupStdInitializerList(*this, Loc);
11982      if (!StdInitializerList)
11983        return QualType();
11984    }
11985  
11986    TemplateArgumentListInfo Args(Loc, Loc);
11987    Args.addArgument(TemplateArgumentLoc(TemplateArgument(Element),
11988                                         Context.getTrivialTypeSourceInfo(Element,
11989                                                                          Loc)));
11990    return Context.getElaboratedType(
11991        ElaboratedTypeKeyword::None,
11992        NestedNameSpecifier::Create(Context, nullptr, getStdNamespace()),
11993        CheckTemplateIdType(TemplateName(StdInitializerList), Loc, Args));
11994  }
11995  
11996  bool Sema::isInitListConstructor(const FunctionDecl *Ctor) {
11997    // C++ [dcl.init.list]p2:
11998    //   A constructor is an initializer-list constructor if its first parameter
11999    //   is of type std::initializer_list<E> or reference to possibly cv-qualified
12000    //   std::initializer_list<E> for some type E, and either there are no other
12001    //   parameters or else all other parameters have default arguments.
12002    if (!Ctor->hasOneParamOrDefaultArgs())
12003      return false;
12004  
12005    QualType ArgType = Ctor->getParamDecl(0)->getType();
12006    if (const ReferenceType *RT = ArgType->getAs<ReferenceType>())
12007      ArgType = RT->getPointeeType().getUnqualifiedType();
12008  
12009    return isStdInitializerList(ArgType, nullptr);
12010  }
12011  
12012  /// Determine whether a using statement is in a context where it will be
12013  /// apply in all contexts.
12014  static bool IsUsingDirectiveInToplevelContext(DeclContext *CurContext) {
12015    switch (CurContext->getDeclKind()) {
12016      case Decl::TranslationUnit:
12017        return true;
12018      case Decl::LinkageSpec:
12019        return IsUsingDirectiveInToplevelContext(CurContext->getParent());
12020      default:
12021        return false;
12022    }
12023  }
12024  
12025  namespace {
12026  
12027  // Callback to only accept typo corrections that are namespaces.
12028  class NamespaceValidatorCCC final : public CorrectionCandidateCallback {
12029  public:
12030    bool ValidateCandidate(const TypoCorrection &candidate) override {
12031      if (NamedDecl *ND = candidate.getCorrectionDecl())
12032        return isa<NamespaceDecl>(ND) || isa<NamespaceAliasDecl>(ND);
12033      return false;
12034    }
12035  
12036    std::unique_ptr<CorrectionCandidateCallback> clone() override {
12037      return std::make_unique<NamespaceValidatorCCC>(*this);
12038    }
12039  };
12040  
12041  }
12042  
12043  static void DiagnoseInvisibleNamespace(const TypoCorrection &Corrected,
12044                                         Sema &S) {
12045    auto *ND = cast<NamespaceDecl>(Corrected.getFoundDecl());
12046    Module *M = ND->getOwningModule();
12047    assert(M && "hidden namespace definition not in a module?");
12048  
12049    if (M->isExplicitGlobalModule())
12050      S.Diag(Corrected.getCorrectionRange().getBegin(),
12051             diag::err_module_unimported_use_header)
12052          << (int)Sema::MissingImportKind::Declaration << Corrected.getFoundDecl()
12053          << /*Header Name*/ false;
12054    else
12055      S.Diag(Corrected.getCorrectionRange().getBegin(),
12056             diag::err_module_unimported_use)
12057          << (int)Sema::MissingImportKind::Declaration << Corrected.getFoundDecl()
12058          << M->getTopLevelModuleName();
12059  }
12060  
12061  static bool TryNamespaceTypoCorrection(Sema &S, LookupResult &R, Scope *Sc,
12062                                         CXXScopeSpec &SS,
12063                                         SourceLocation IdentLoc,
12064                                         IdentifierInfo *Ident) {
12065    R.clear();
12066    NamespaceValidatorCCC CCC{};
12067    if (TypoCorrection Corrected =
12068            S.CorrectTypo(R.getLookupNameInfo(), R.getLookupKind(), Sc, &SS, CCC,
12069                          Sema::CTK_ErrorRecovery)) {
12070      // Generally we find it is confusing more than helpful to diagnose the
12071      // invisible namespace.
12072      // See https://github.com/llvm/llvm-project/issues/73893.
12073      //
12074      // However, we should diagnose when the users are trying to using an
12075      // invisible namespace. So we handle the case specially here.
12076      if (isa_and_nonnull<NamespaceDecl>(Corrected.getFoundDecl()) &&
12077          Corrected.requiresImport()) {
12078        DiagnoseInvisibleNamespace(Corrected, S);
12079      } else if (DeclContext *DC = S.computeDeclContext(SS, false)) {
12080        std::string CorrectedStr(Corrected.getAsString(S.getLangOpts()));
12081        bool DroppedSpecifier =
12082            Corrected.WillReplaceSpecifier() && Ident->getName() == CorrectedStr;
12083        S.diagnoseTypo(Corrected,
12084                       S.PDiag(diag::err_using_directive_member_suggest)
12085                         << Ident << DC << DroppedSpecifier << SS.getRange(),
12086                       S.PDiag(diag::note_namespace_defined_here));
12087      } else {
12088        S.diagnoseTypo(Corrected,
12089                       S.PDiag(diag::err_using_directive_suggest) << Ident,
12090                       S.PDiag(diag::note_namespace_defined_here));
12091      }
12092      R.addDecl(Corrected.getFoundDecl());
12093      return true;
12094    }
12095    return false;
12096  }
12097  
12098  Decl *Sema::ActOnUsingDirective(Scope *S, SourceLocation UsingLoc,
12099                                  SourceLocation NamespcLoc, CXXScopeSpec &SS,
12100                                  SourceLocation IdentLoc,
12101                                  IdentifierInfo *NamespcName,
12102                                  const ParsedAttributesView &AttrList) {
12103    assert(!SS.isInvalid() && "Invalid CXXScopeSpec.");
12104    assert(NamespcName && "Invalid NamespcName.");
12105    assert(IdentLoc.isValid() && "Invalid NamespceName location.");
12106  
12107    // Get the innermost enclosing declaration scope.
12108    S = S->getDeclParent();
12109  
12110    UsingDirectiveDecl *UDir = nullptr;
12111    NestedNameSpecifier *Qualifier = nullptr;
12112    if (SS.isSet())
12113      Qualifier = SS.getScopeRep();
12114  
12115    // Lookup namespace name.
12116    LookupResult R(*this, NamespcName, IdentLoc, LookupNamespaceName);
12117    LookupParsedName(R, S, &SS, /*ObjectType=*/QualType());
12118    if (R.isAmbiguous())
12119      return nullptr;
12120  
12121    if (R.empty()) {
12122      R.clear();
12123      // Allow "using namespace std;" or "using namespace ::std;" even if
12124      // "std" hasn't been defined yet, for GCC compatibility.
12125      if ((!Qualifier || Qualifier->getKind() == NestedNameSpecifier::Global) &&
12126          NamespcName->isStr("std")) {
12127        Diag(IdentLoc, diag::ext_using_undefined_std);
12128        R.addDecl(getOrCreateStdNamespace());
12129        R.resolveKind();
12130      }
12131      // Otherwise, attempt typo correction.
12132      else TryNamespaceTypoCorrection(*this, R, S, SS, IdentLoc, NamespcName);
12133    }
12134  
12135    if (!R.empty()) {
12136      NamedDecl *Named = R.getRepresentativeDecl();
12137      NamespaceDecl *NS = R.getAsSingle<NamespaceDecl>();
12138      assert(NS && "expected namespace decl");
12139  
12140      // The use of a nested name specifier may trigger deprecation warnings.
12141      DiagnoseUseOfDecl(Named, IdentLoc);
12142  
12143      // C++ [namespace.udir]p1:
12144      //   A using-directive specifies that the names in the nominated
12145      //   namespace can be used in the scope in which the
12146      //   using-directive appears after the using-directive. During
12147      //   unqualified name lookup (3.4.1), the names appear as if they
12148      //   were declared in the nearest enclosing namespace which
12149      //   contains both the using-directive and the nominated
12150      //   namespace. [Note: in this context, "contains" means "contains
12151      //   directly or indirectly". ]
12152  
12153      // Find enclosing context containing both using-directive and
12154      // nominated namespace.
12155      DeclContext *CommonAncestor = NS;
12156      while (CommonAncestor && !CommonAncestor->Encloses(CurContext))
12157        CommonAncestor = CommonAncestor->getParent();
12158  
12159      UDir = UsingDirectiveDecl::Create(Context, CurContext, UsingLoc, NamespcLoc,
12160                                        SS.getWithLocInContext(Context),
12161                                        IdentLoc, Named, CommonAncestor);
12162  
12163      if (IsUsingDirectiveInToplevelContext(CurContext) &&
12164          !SourceMgr.isInMainFile(SourceMgr.getExpansionLoc(IdentLoc))) {
12165        Diag(IdentLoc, diag::warn_using_directive_in_header);
12166      }
12167  
12168      PushUsingDirective(S, UDir);
12169    } else {
12170      Diag(IdentLoc, diag::err_expected_namespace_name) << SS.getRange();
12171    }
12172  
12173    if (UDir) {
12174      ProcessDeclAttributeList(S, UDir, AttrList);
12175      ProcessAPINotes(UDir);
12176    }
12177  
12178    return UDir;
12179  }
12180  
12181  void Sema::PushUsingDirective(Scope *S, UsingDirectiveDecl *UDir) {
12182    // If the scope has an associated entity and the using directive is at
12183    // namespace or translation unit scope, add the UsingDirectiveDecl into
12184    // its lookup structure so qualified name lookup can find it.
12185    DeclContext *Ctx = S->getEntity();
12186    if (Ctx && !Ctx->isFunctionOrMethod())
12187      Ctx->addDecl(UDir);
12188    else
12189      // Otherwise, it is at block scope. The using-directives will affect lookup
12190      // only to the end of the scope.
12191      S->PushUsingDirective(UDir);
12192  }
12193  
12194  Decl *Sema::ActOnUsingDeclaration(Scope *S, AccessSpecifier AS,
12195                                    SourceLocation UsingLoc,
12196                                    SourceLocation TypenameLoc, CXXScopeSpec &SS,
12197                                    UnqualifiedId &Name,
12198                                    SourceLocation EllipsisLoc,
12199                                    const ParsedAttributesView &AttrList) {
12200    assert(S->getFlags() & Scope::DeclScope && "Invalid Scope.");
12201  
12202    if (SS.isEmpty()) {
12203      Diag(Name.getBeginLoc(), diag::err_using_requires_qualname);
12204      return nullptr;
12205    }
12206  
12207    switch (Name.getKind()) {
12208    case UnqualifiedIdKind::IK_ImplicitSelfParam:
12209    case UnqualifiedIdKind::IK_Identifier:
12210    case UnqualifiedIdKind::IK_OperatorFunctionId:
12211    case UnqualifiedIdKind::IK_LiteralOperatorId:
12212    case UnqualifiedIdKind::IK_ConversionFunctionId:
12213      break;
12214  
12215    case UnqualifiedIdKind::IK_ConstructorName:
12216    case UnqualifiedIdKind::IK_ConstructorTemplateId:
12217      // C++11 inheriting constructors.
12218      Diag(Name.getBeginLoc(),
12219           getLangOpts().CPlusPlus11
12220               ? diag::warn_cxx98_compat_using_decl_constructor
12221               : diag::err_using_decl_constructor)
12222          << SS.getRange();
12223  
12224      if (getLangOpts().CPlusPlus11) break;
12225  
12226      return nullptr;
12227  
12228    case UnqualifiedIdKind::IK_DestructorName:
12229      Diag(Name.getBeginLoc(), diag::err_using_decl_destructor) << SS.getRange();
12230      return nullptr;
12231  
12232    case UnqualifiedIdKind::IK_TemplateId:
12233      Diag(Name.getBeginLoc(), diag::err_using_decl_template_id)
12234          << SourceRange(Name.TemplateId->LAngleLoc, Name.TemplateId->RAngleLoc);
12235      return nullptr;
12236  
12237    case UnqualifiedIdKind::IK_DeductionGuideName:
12238      llvm_unreachable("cannot parse qualified deduction guide name");
12239    }
12240  
12241    DeclarationNameInfo TargetNameInfo = GetNameFromUnqualifiedId(Name);
12242    DeclarationName TargetName = TargetNameInfo.getName();
12243    if (!TargetName)
12244      return nullptr;
12245  
12246    // Warn about access declarations.
12247    if (UsingLoc.isInvalid()) {
12248      Diag(Name.getBeginLoc(), getLangOpts().CPlusPlus11
12249                                   ? diag::err_access_decl
12250                                   : diag::warn_access_decl_deprecated)
12251          << FixItHint::CreateInsertion(SS.getRange().getBegin(), "using ");
12252    }
12253  
12254    if (EllipsisLoc.isInvalid()) {
12255      if (DiagnoseUnexpandedParameterPack(SS, UPPC_UsingDeclaration) ||
12256          DiagnoseUnexpandedParameterPack(TargetNameInfo, UPPC_UsingDeclaration))
12257        return nullptr;
12258    } else {
12259      if (!SS.getScopeRep()->containsUnexpandedParameterPack() &&
12260          !TargetNameInfo.containsUnexpandedParameterPack()) {
12261        Diag(EllipsisLoc, diag::err_pack_expansion_without_parameter_packs)
12262          << SourceRange(SS.getBeginLoc(), TargetNameInfo.getEndLoc());
12263        EllipsisLoc = SourceLocation();
12264      }
12265    }
12266  
12267    NamedDecl *UD =
12268        BuildUsingDeclaration(S, AS, UsingLoc, TypenameLoc.isValid(), TypenameLoc,
12269                              SS, TargetNameInfo, EllipsisLoc, AttrList,
12270                              /*IsInstantiation*/ false,
12271                              AttrList.hasAttribute(ParsedAttr::AT_UsingIfExists));
12272    if (UD)
12273      PushOnScopeChains(UD, S, /*AddToContext*/ false);
12274  
12275    return UD;
12276  }
12277  
12278  Decl *Sema::ActOnUsingEnumDeclaration(Scope *S, AccessSpecifier AS,
12279                                        SourceLocation UsingLoc,
12280                                        SourceLocation EnumLoc, SourceRange TyLoc,
12281                                        const IdentifierInfo &II, ParsedType Ty,
12282                                        CXXScopeSpec *SS) {
12283    assert(!SS->isInvalid() && "ScopeSpec is invalid");
12284    TypeSourceInfo *TSI = nullptr;
12285    SourceLocation IdentLoc = TyLoc.getBegin();
12286    QualType EnumTy = GetTypeFromParser(Ty, &TSI);
12287    if (EnumTy.isNull()) {
12288      Diag(IdentLoc, SS && isDependentScopeSpecifier(*SS)
12289                         ? diag::err_using_enum_is_dependent
12290                         : diag::err_unknown_typename)
12291          << II.getName()
12292          << SourceRange(SS ? SS->getBeginLoc() : IdentLoc, TyLoc.getEnd());
12293      return nullptr;
12294    }
12295  
12296    if (EnumTy->isDependentType()) {
12297      Diag(IdentLoc, diag::err_using_enum_is_dependent);
12298      return nullptr;
12299    }
12300  
12301    auto *Enum = dyn_cast_if_present<EnumDecl>(EnumTy->getAsTagDecl());
12302    if (!Enum) {
12303      Diag(IdentLoc, diag::err_using_enum_not_enum) << EnumTy;
12304      return nullptr;
12305    }
12306  
12307    if (auto *Def = Enum->getDefinition())
12308      Enum = Def;
12309  
12310    if (TSI == nullptr)
12311      TSI = Context.getTrivialTypeSourceInfo(EnumTy, IdentLoc);
12312  
12313    auto *UD =
12314        BuildUsingEnumDeclaration(S, AS, UsingLoc, EnumLoc, IdentLoc, TSI, Enum);
12315  
12316    if (UD)
12317      PushOnScopeChains(UD, S, /*AddToContext*/ false);
12318  
12319    return UD;
12320  }
12321  
12322  /// Determine whether a using declaration considers the given
12323  /// declarations as "equivalent", e.g., if they are redeclarations of
12324  /// the same entity or are both typedefs of the same type.
12325  static bool
12326  IsEquivalentForUsingDecl(ASTContext &Context, NamedDecl *D1, NamedDecl *D2) {
12327    if (D1->getCanonicalDecl() == D2->getCanonicalDecl())
12328      return true;
12329  
12330    if (TypedefNameDecl *TD1 = dyn_cast<TypedefNameDecl>(D1))
12331      if (TypedefNameDecl *TD2 = dyn_cast<TypedefNameDecl>(D2))
12332        return Context.hasSameType(TD1->getUnderlyingType(),
12333                                   TD2->getUnderlyingType());
12334  
12335    // Two using_if_exists using-declarations are equivalent if both are
12336    // unresolved.
12337    if (isa<UnresolvedUsingIfExistsDecl>(D1) &&
12338        isa<UnresolvedUsingIfExistsDecl>(D2))
12339      return true;
12340  
12341    return false;
12342  }
12343  
12344  bool Sema::CheckUsingShadowDecl(BaseUsingDecl *BUD, NamedDecl *Orig,
12345                                  const LookupResult &Previous,
12346                                  UsingShadowDecl *&PrevShadow) {
12347    // Diagnose finding a decl which is not from a base class of the
12348    // current class.  We do this now because there are cases where this
12349    // function will silently decide not to build a shadow decl, which
12350    // will pre-empt further diagnostics.
12351    //
12352    // We don't need to do this in C++11 because we do the check once on
12353    // the qualifier.
12354    //
12355    // FIXME: diagnose the following if we care enough:
12356    //   struct A { int foo; };
12357    //   struct B : A { using A::foo; };
12358    //   template <class T> struct C : A {};
12359    //   template <class T> struct D : C<T> { using B::foo; } // <---
12360    // This is invalid (during instantiation) in C++03 because B::foo
12361    // resolves to the using decl in B, which is not a base class of D<T>.
12362    // We can't diagnose it immediately because C<T> is an unknown
12363    // specialization. The UsingShadowDecl in D<T> then points directly
12364    // to A::foo, which will look well-formed when we instantiate.
12365    // The right solution is to not collapse the shadow-decl chain.
12366    if (!getLangOpts().CPlusPlus11 && CurContext->isRecord())
12367      if (auto *Using = dyn_cast<UsingDecl>(BUD)) {
12368        DeclContext *OrigDC = Orig->getDeclContext();
12369  
12370        // Handle enums and anonymous structs.
12371        if (isa<EnumDecl>(OrigDC))
12372          OrigDC = OrigDC->getParent();
12373        CXXRecordDecl *OrigRec = cast<CXXRecordDecl>(OrigDC);
12374        while (OrigRec->isAnonymousStructOrUnion())
12375          OrigRec = cast<CXXRecordDecl>(OrigRec->getDeclContext());
12376  
12377        if (cast<CXXRecordDecl>(CurContext)->isProvablyNotDerivedFrom(OrigRec)) {
12378          if (OrigDC == CurContext) {
12379            Diag(Using->getLocation(),
12380                 diag::err_using_decl_nested_name_specifier_is_current_class)
12381                << Using->getQualifierLoc().getSourceRange();
12382            Diag(Orig->getLocation(), diag::note_using_decl_target);
12383            Using->setInvalidDecl();
12384            return true;
12385          }
12386  
12387          Diag(Using->getQualifierLoc().getBeginLoc(),
12388               diag::err_using_decl_nested_name_specifier_is_not_base_class)
12389              << Using->getQualifier() << cast<CXXRecordDecl>(CurContext)
12390              << Using->getQualifierLoc().getSourceRange();
12391          Diag(Orig->getLocation(), diag::note_using_decl_target);
12392          Using->setInvalidDecl();
12393          return true;
12394        }
12395      }
12396  
12397    if (Previous.empty()) return false;
12398  
12399    NamedDecl *Target = Orig;
12400    if (isa<UsingShadowDecl>(Target))
12401      Target = cast<UsingShadowDecl>(Target)->getTargetDecl();
12402  
12403    // If the target happens to be one of the previous declarations, we
12404    // don't have a conflict.
12405    //
12406    // FIXME: but we might be increasing its access, in which case we
12407    // should redeclare it.
12408    NamedDecl *NonTag = nullptr, *Tag = nullptr;
12409    bool FoundEquivalentDecl = false;
12410    for (LookupResult::iterator I = Previous.begin(), E = Previous.end();
12411           I != E; ++I) {
12412      NamedDecl *D = (*I)->getUnderlyingDecl();
12413      // We can have UsingDecls in our Previous results because we use the same
12414      // LookupResult for checking whether the UsingDecl itself is a valid
12415      // redeclaration.
12416      if (isa<UsingDecl>(D) || isa<UsingPackDecl>(D) || isa<UsingEnumDecl>(D))
12417        continue;
12418  
12419      if (auto *RD = dyn_cast<CXXRecordDecl>(D)) {
12420        // C++ [class.mem]p19:
12421        //   If T is the name of a class, then [every named member other than
12422        //   a non-static data member] shall have a name different from T
12423        if (RD->isInjectedClassName() && !isa<FieldDecl>(Target) &&
12424            !isa<IndirectFieldDecl>(Target) &&
12425            !isa<UnresolvedUsingValueDecl>(Target) &&
12426            DiagnoseClassNameShadow(
12427                CurContext,
12428                DeclarationNameInfo(BUD->getDeclName(), BUD->getLocation())))
12429          return true;
12430      }
12431  
12432      if (IsEquivalentForUsingDecl(Context, D, Target)) {
12433        if (UsingShadowDecl *Shadow = dyn_cast<UsingShadowDecl>(*I))
12434          PrevShadow = Shadow;
12435        FoundEquivalentDecl = true;
12436      } else if (isEquivalentInternalLinkageDeclaration(D, Target)) {
12437        // We don't conflict with an existing using shadow decl of an equivalent
12438        // declaration, but we're not a redeclaration of it.
12439        FoundEquivalentDecl = true;
12440      }
12441  
12442      if (isVisible(D))
12443        (isa<TagDecl>(D) ? Tag : NonTag) = D;
12444    }
12445  
12446    if (FoundEquivalentDecl)
12447      return false;
12448  
12449    // Always emit a diagnostic for a mismatch between an unresolved
12450    // using_if_exists and a resolved using declaration in either direction.
12451    if (isa<UnresolvedUsingIfExistsDecl>(Target) !=
12452        (isa_and_nonnull<UnresolvedUsingIfExistsDecl>(NonTag))) {
12453      if (!NonTag && !Tag)
12454        return false;
12455      Diag(BUD->getLocation(), diag::err_using_decl_conflict);
12456      Diag(Target->getLocation(), diag::note_using_decl_target);
12457      Diag((NonTag ? NonTag : Tag)->getLocation(),
12458           diag::note_using_decl_conflict);
12459      BUD->setInvalidDecl();
12460      return true;
12461    }
12462  
12463    if (FunctionDecl *FD = Target->getAsFunction()) {
12464      NamedDecl *OldDecl = nullptr;
12465      switch (CheckOverload(nullptr, FD, Previous, OldDecl,
12466                            /*IsForUsingDecl*/ true)) {
12467      case Ovl_Overload:
12468        return false;
12469  
12470      case Ovl_NonFunction:
12471        Diag(BUD->getLocation(), diag::err_using_decl_conflict);
12472        break;
12473  
12474      // We found a decl with the exact signature.
12475      case Ovl_Match:
12476        // If we're in a record, we want to hide the target, so we
12477        // return true (without a diagnostic) to tell the caller not to
12478        // build a shadow decl.
12479        if (CurContext->isRecord())
12480          return true;
12481  
12482        // If we're not in a record, this is an error.
12483        Diag(BUD->getLocation(), diag::err_using_decl_conflict);
12484        break;
12485      }
12486  
12487      Diag(Target->getLocation(), diag::note_using_decl_target);
12488      Diag(OldDecl->getLocation(), diag::note_using_decl_conflict);
12489      BUD->setInvalidDecl();
12490      return true;
12491    }
12492  
12493    // Target is not a function.
12494  
12495    if (isa<TagDecl>(Target)) {
12496      // No conflict between a tag and a non-tag.
12497      if (!Tag) return false;
12498  
12499      Diag(BUD->getLocation(), diag::err_using_decl_conflict);
12500      Diag(Target->getLocation(), diag::note_using_decl_target);
12501      Diag(Tag->getLocation(), diag::note_using_decl_conflict);
12502      BUD->setInvalidDecl();
12503      return true;
12504    }
12505  
12506    // No conflict between a tag and a non-tag.
12507    if (!NonTag) return false;
12508  
12509    Diag(BUD->getLocation(), diag::err_using_decl_conflict);
12510    Diag(Target->getLocation(), diag::note_using_decl_target);
12511    Diag(NonTag->getLocation(), diag::note_using_decl_conflict);
12512    BUD->setInvalidDecl();
12513    return true;
12514  }
12515  
12516  /// Determine whether a direct base class is a virtual base class.
12517  static bool isVirtualDirectBase(CXXRecordDecl *Derived, CXXRecordDecl *Base) {
12518    if (!Derived->getNumVBases())
12519      return false;
12520    for (auto &B : Derived->bases())
12521      if (B.getType()->getAsCXXRecordDecl() == Base)
12522        return B.isVirtual();
12523    llvm_unreachable("not a direct base class");
12524  }
12525  
12526  UsingShadowDecl *Sema::BuildUsingShadowDecl(Scope *S, BaseUsingDecl *BUD,
12527                                              NamedDecl *Orig,
12528                                              UsingShadowDecl *PrevDecl) {
12529    // If we resolved to another shadow declaration, just coalesce them.
12530    NamedDecl *Target = Orig;
12531    if (isa<UsingShadowDecl>(Target)) {
12532      Target = cast<UsingShadowDecl>(Target)->getTargetDecl();
12533      assert(!isa<UsingShadowDecl>(Target) && "nested shadow declaration");
12534    }
12535  
12536    NamedDecl *NonTemplateTarget = Target;
12537    if (auto *TargetTD = dyn_cast<TemplateDecl>(Target))
12538      NonTemplateTarget = TargetTD->getTemplatedDecl();
12539  
12540    UsingShadowDecl *Shadow;
12541    if (NonTemplateTarget && isa<CXXConstructorDecl>(NonTemplateTarget)) {
12542      UsingDecl *Using = cast<UsingDecl>(BUD);
12543      bool IsVirtualBase =
12544          isVirtualDirectBase(cast<CXXRecordDecl>(CurContext),
12545                              Using->getQualifier()->getAsRecordDecl());
12546      Shadow = ConstructorUsingShadowDecl::Create(
12547          Context, CurContext, Using->getLocation(), Using, Orig, IsVirtualBase);
12548    } else {
12549      Shadow = UsingShadowDecl::Create(Context, CurContext, BUD->getLocation(),
12550                                       Target->getDeclName(), BUD, Target);
12551    }
12552    BUD->addShadowDecl(Shadow);
12553  
12554    Shadow->setAccess(BUD->getAccess());
12555    if (Orig->isInvalidDecl() || BUD->isInvalidDecl())
12556      Shadow->setInvalidDecl();
12557  
12558    Shadow->setPreviousDecl(PrevDecl);
12559  
12560    if (S)
12561      PushOnScopeChains(Shadow, S);
12562    else
12563      CurContext->addDecl(Shadow);
12564  
12565  
12566    return Shadow;
12567  }
12568  
12569  void Sema::HideUsingShadowDecl(Scope *S, UsingShadowDecl *Shadow) {
12570    if (Shadow->getDeclName().getNameKind() ==
12571          DeclarationName::CXXConversionFunctionName)
12572      cast<CXXRecordDecl>(Shadow->getDeclContext())->removeConversion(Shadow);
12573  
12574    // Remove it from the DeclContext...
12575    Shadow->getDeclContext()->removeDecl(Shadow);
12576  
12577    // ...and the scope, if applicable...
12578    if (S) {
12579      S->RemoveDecl(Shadow);
12580      IdResolver.RemoveDecl(Shadow);
12581    }
12582  
12583    // ...and the using decl.
12584    Shadow->getIntroducer()->removeShadowDecl(Shadow);
12585  
12586    // TODO: complain somehow if Shadow was used.  It shouldn't
12587    // be possible for this to happen, because...?
12588  }
12589  
12590  /// Find the base specifier for a base class with the given type.
12591  static CXXBaseSpecifier *findDirectBaseWithType(CXXRecordDecl *Derived,
12592                                                  QualType DesiredBase,
12593                                                  bool &AnyDependentBases) {
12594    // Check whether the named type is a direct base class.
12595    CanQualType CanonicalDesiredBase = DesiredBase->getCanonicalTypeUnqualified()
12596      .getUnqualifiedType();
12597    for (auto &Base : Derived->bases()) {
12598      CanQualType BaseType = Base.getType()->getCanonicalTypeUnqualified();
12599      if (CanonicalDesiredBase == BaseType)
12600        return &Base;
12601      if (BaseType->isDependentType())
12602        AnyDependentBases = true;
12603    }
12604    return nullptr;
12605  }
12606  
12607  namespace {
12608  class UsingValidatorCCC final : public CorrectionCandidateCallback {
12609  public:
12610    UsingValidatorCCC(bool HasTypenameKeyword, bool IsInstantiation,
12611                      NestedNameSpecifier *NNS, CXXRecordDecl *RequireMemberOf)
12612        : HasTypenameKeyword(HasTypenameKeyword),
12613          IsInstantiation(IsInstantiation), OldNNS(NNS),
12614          RequireMemberOf(RequireMemberOf) {}
12615  
12616    bool ValidateCandidate(const TypoCorrection &Candidate) override {
12617      NamedDecl *ND = Candidate.getCorrectionDecl();
12618  
12619      // Keywords are not valid here.
12620      if (!ND || isa<NamespaceDecl>(ND))
12621        return false;
12622  
12623      // Completely unqualified names are invalid for a 'using' declaration.
12624      if (Candidate.WillReplaceSpecifier() && !Candidate.getCorrectionSpecifier())
12625        return false;
12626  
12627      // FIXME: Don't correct to a name that CheckUsingDeclRedeclaration would
12628      // reject.
12629  
12630      if (RequireMemberOf) {
12631        auto *FoundRecord = dyn_cast<CXXRecordDecl>(ND);
12632        if (FoundRecord && FoundRecord->isInjectedClassName()) {
12633          // No-one ever wants a using-declaration to name an injected-class-name
12634          // of a base class, unless they're declaring an inheriting constructor.
12635          ASTContext &Ctx = ND->getASTContext();
12636          if (!Ctx.getLangOpts().CPlusPlus11)
12637            return false;
12638          QualType FoundType = Ctx.getRecordType(FoundRecord);
12639  
12640          // Check that the injected-class-name is named as a member of its own
12641          // type; we don't want to suggest 'using Derived::Base;', since that
12642          // means something else.
12643          NestedNameSpecifier *Specifier =
12644              Candidate.WillReplaceSpecifier()
12645                  ? Candidate.getCorrectionSpecifier()
12646                  : OldNNS;
12647          if (!Specifier->getAsType() ||
12648              !Ctx.hasSameType(QualType(Specifier->getAsType(), 0), FoundType))
12649            return false;
12650  
12651          // Check that this inheriting constructor declaration actually names a
12652          // direct base class of the current class.
12653          bool AnyDependentBases = false;
12654          if (!findDirectBaseWithType(RequireMemberOf,
12655                                      Ctx.getRecordType(FoundRecord),
12656                                      AnyDependentBases) &&
12657              !AnyDependentBases)
12658            return false;
12659        } else {
12660          auto *RD = dyn_cast<CXXRecordDecl>(ND->getDeclContext());
12661          if (!RD || RequireMemberOf->isProvablyNotDerivedFrom(RD))
12662            return false;
12663  
12664          // FIXME: Check that the base class member is accessible?
12665        }
12666      } else {
12667        auto *FoundRecord = dyn_cast<CXXRecordDecl>(ND);
12668        if (FoundRecord && FoundRecord->isInjectedClassName())
12669          return false;
12670      }
12671  
12672      if (isa<TypeDecl>(ND))
12673        return HasTypenameKeyword || !IsInstantiation;
12674  
12675      return !HasTypenameKeyword;
12676    }
12677  
12678    std::unique_ptr<CorrectionCandidateCallback> clone() override {
12679      return std::make_unique<UsingValidatorCCC>(*this);
12680    }
12681  
12682  private:
12683    bool HasTypenameKeyword;
12684    bool IsInstantiation;
12685    NestedNameSpecifier *OldNNS;
12686    CXXRecordDecl *RequireMemberOf;
12687  };
12688  } // end anonymous namespace
12689  
12690  void Sema::FilterUsingLookup(Scope *S, LookupResult &Previous) {
12691    // It is really dumb that we have to do this.
12692    LookupResult::Filter F = Previous.makeFilter();
12693    while (F.hasNext()) {
12694      NamedDecl *D = F.next();
12695      if (!isDeclInScope(D, CurContext, S))
12696        F.erase();
12697      // If we found a local extern declaration that's not ordinarily visible,
12698      // and this declaration is being added to a non-block scope, ignore it.
12699      // We're only checking for scope conflicts here, not also for violations
12700      // of the linkage rules.
12701      else if (!CurContext->isFunctionOrMethod() && D->isLocalExternDecl() &&
12702               !(D->getIdentifierNamespace() & Decl::IDNS_Ordinary))
12703        F.erase();
12704    }
12705    F.done();
12706  }
12707  
12708  NamedDecl *Sema::BuildUsingDeclaration(
12709      Scope *S, AccessSpecifier AS, SourceLocation UsingLoc,
12710      bool HasTypenameKeyword, SourceLocation TypenameLoc, CXXScopeSpec &SS,
12711      DeclarationNameInfo NameInfo, SourceLocation EllipsisLoc,
12712      const ParsedAttributesView &AttrList, bool IsInstantiation,
12713      bool IsUsingIfExists) {
12714    assert(!SS.isInvalid() && "Invalid CXXScopeSpec.");
12715    SourceLocation IdentLoc = NameInfo.getLoc();
12716    assert(IdentLoc.isValid() && "Invalid TargetName location.");
12717  
12718    // FIXME: We ignore attributes for now.
12719  
12720    // For an inheriting constructor declaration, the name of the using
12721    // declaration is the name of a constructor in this class, not in the
12722    // base class.
12723    DeclarationNameInfo UsingName = NameInfo;
12724    if (UsingName.getName().getNameKind() == DeclarationName::CXXConstructorName)
12725      if (auto *RD = dyn_cast<CXXRecordDecl>(CurContext))
12726        UsingName.setName(Context.DeclarationNames.getCXXConstructorName(
12727            Context.getCanonicalType(Context.getRecordType(RD))));
12728  
12729    // Do the redeclaration lookup in the current scope.
12730    LookupResult Previous(*this, UsingName, LookupUsingDeclName,
12731                          RedeclarationKind::ForVisibleRedeclaration);
12732    Previous.setHideTags(false);
12733    if (S) {
12734      LookupName(Previous, S);
12735  
12736      FilterUsingLookup(S, Previous);
12737    } else {
12738      assert(IsInstantiation && "no scope in non-instantiation");
12739      if (CurContext->isRecord())
12740        LookupQualifiedName(Previous, CurContext);
12741      else {
12742        // No redeclaration check is needed here; in non-member contexts we
12743        // diagnosed all possible conflicts with other using-declarations when
12744        // building the template:
12745        //
12746        // For a dependent non-type using declaration, the only valid case is
12747        // if we instantiate to a single enumerator. We check for conflicts
12748        // between shadow declarations we introduce, and we check in the template
12749        // definition for conflicts between a non-type using declaration and any
12750        // other declaration, which together covers all cases.
12751        //
12752        // A dependent typename using declaration will never successfully
12753        // instantiate, since it will always name a class member, so we reject
12754        // that in the template definition.
12755      }
12756    }
12757  
12758    // Check for invalid redeclarations.
12759    if (CheckUsingDeclRedeclaration(UsingLoc, HasTypenameKeyword,
12760                                    SS, IdentLoc, Previous))
12761      return nullptr;
12762  
12763    // 'using_if_exists' doesn't make sense on an inherited constructor.
12764    if (IsUsingIfExists && UsingName.getName().getNameKind() ==
12765                               DeclarationName::CXXConstructorName) {
12766      Diag(UsingLoc, diag::err_using_if_exists_on_ctor);
12767      return nullptr;
12768    }
12769  
12770    DeclContext *LookupContext = computeDeclContext(SS);
12771    NestedNameSpecifierLoc QualifierLoc = SS.getWithLocInContext(Context);
12772    if (!LookupContext || EllipsisLoc.isValid()) {
12773      NamedDecl *D;
12774      // Dependent scope, or an unexpanded pack
12775      if (!LookupContext && CheckUsingDeclQualifier(UsingLoc, HasTypenameKeyword,
12776                                                    SS, NameInfo, IdentLoc))
12777        return nullptr;
12778  
12779      if (HasTypenameKeyword) {
12780        // FIXME: not all declaration name kinds are legal here
12781        D = UnresolvedUsingTypenameDecl::Create(Context, CurContext,
12782                                                UsingLoc, TypenameLoc,
12783                                                QualifierLoc,
12784                                                IdentLoc, NameInfo.getName(),
12785                                                EllipsisLoc);
12786      } else {
12787        D = UnresolvedUsingValueDecl::Create(Context, CurContext, UsingLoc,
12788                                             QualifierLoc, NameInfo, EllipsisLoc);
12789      }
12790      D->setAccess(AS);
12791      CurContext->addDecl(D);
12792      ProcessDeclAttributeList(S, D, AttrList);
12793      return D;
12794    }
12795  
12796    auto Build = [&](bool Invalid) {
12797      UsingDecl *UD =
12798          UsingDecl::Create(Context, CurContext, UsingLoc, QualifierLoc,
12799                            UsingName, HasTypenameKeyword);
12800      UD->setAccess(AS);
12801      CurContext->addDecl(UD);
12802      ProcessDeclAttributeList(S, UD, AttrList);
12803      UD->setInvalidDecl(Invalid);
12804      return UD;
12805    };
12806    auto BuildInvalid = [&]{ return Build(true); };
12807    auto BuildValid = [&]{ return Build(false); };
12808  
12809    if (RequireCompleteDeclContext(SS, LookupContext))
12810      return BuildInvalid();
12811  
12812    // Look up the target name.
12813    LookupResult R(*this, NameInfo, LookupOrdinaryName);
12814  
12815    // Unlike most lookups, we don't always want to hide tag
12816    // declarations: tag names are visible through the using declaration
12817    // even if hidden by ordinary names, *except* in a dependent context
12818    // where they may be used by two-phase lookup.
12819    if (!IsInstantiation)
12820      R.setHideTags(false);
12821  
12822    // For the purposes of this lookup, we have a base object type
12823    // equal to that of the current context.
12824    if (CurContext->isRecord()) {
12825      R.setBaseObjectType(
12826                     Context.getTypeDeclType(cast<CXXRecordDecl>(CurContext)));
12827    }
12828  
12829    LookupQualifiedName(R, LookupContext);
12830  
12831    // Validate the context, now we have a lookup
12832    if (CheckUsingDeclQualifier(UsingLoc, HasTypenameKeyword, SS, NameInfo,
12833                                IdentLoc, &R))
12834      return nullptr;
12835  
12836    if (R.empty() && IsUsingIfExists)
12837      R.addDecl(UnresolvedUsingIfExistsDecl::Create(Context, CurContext, UsingLoc,
12838                                                    UsingName.getName()),
12839                AS_public);
12840  
12841    // Try to correct typos if possible. If constructor name lookup finds no
12842    // results, that means the named class has no explicit constructors, and we
12843    // suppressed declaring implicit ones (probably because it's dependent or
12844    // invalid).
12845    if (R.empty() &&
12846        NameInfo.getName().getNameKind() != DeclarationName::CXXConstructorName) {
12847      // HACK 2017-01-08: Work around an issue with libstdc++'s detection of
12848      // ::gets. Sometimes it believes that glibc provides a ::gets in cases where
12849      // it does not. The issue was fixed in libstdc++ 6.3 (2016-12-21) and later.
12850      auto *II = NameInfo.getName().getAsIdentifierInfo();
12851      if (getLangOpts().CPlusPlus14 && II && II->isStr("gets") &&
12852          CurContext->isStdNamespace() &&
12853          isa<TranslationUnitDecl>(LookupContext) &&
12854          getSourceManager().isInSystemHeader(UsingLoc))
12855        return nullptr;
12856      UsingValidatorCCC CCC(HasTypenameKeyword, IsInstantiation, SS.getScopeRep(),
12857                            dyn_cast<CXXRecordDecl>(CurContext));
12858      if (TypoCorrection Corrected =
12859              CorrectTypo(R.getLookupNameInfo(), R.getLookupKind(), S, &SS, CCC,
12860                          CTK_ErrorRecovery)) {
12861        // We reject candidates where DroppedSpecifier == true, hence the
12862        // literal '0' below.
12863        diagnoseTypo(Corrected, PDiag(diag::err_no_member_suggest)
12864                                  << NameInfo.getName() << LookupContext << 0
12865                                  << SS.getRange());
12866  
12867        // If we picked a correction with no attached Decl we can't do anything
12868        // useful with it, bail out.
12869        NamedDecl *ND = Corrected.getCorrectionDecl();
12870        if (!ND)
12871          return BuildInvalid();
12872  
12873        // If we corrected to an inheriting constructor, handle it as one.
12874        auto *RD = dyn_cast<CXXRecordDecl>(ND);
12875        if (RD && RD->isInjectedClassName()) {
12876          // The parent of the injected class name is the class itself.
12877          RD = cast<CXXRecordDecl>(RD->getParent());
12878  
12879          // Fix up the information we'll use to build the using declaration.
12880          if (Corrected.WillReplaceSpecifier()) {
12881            NestedNameSpecifierLocBuilder Builder;
12882            Builder.MakeTrivial(Context, Corrected.getCorrectionSpecifier(),
12883                                QualifierLoc.getSourceRange());
12884            QualifierLoc = Builder.getWithLocInContext(Context);
12885          }
12886  
12887          // In this case, the name we introduce is the name of a derived class
12888          // constructor.
12889          auto *CurClass = cast<CXXRecordDecl>(CurContext);
12890          UsingName.setName(Context.DeclarationNames.getCXXConstructorName(
12891              Context.getCanonicalType(Context.getRecordType(CurClass))));
12892          UsingName.setNamedTypeInfo(nullptr);
12893          for (auto *Ctor : LookupConstructors(RD))
12894            R.addDecl(Ctor);
12895          R.resolveKind();
12896        } else {
12897          // FIXME: Pick up all the declarations if we found an overloaded
12898          // function.
12899          UsingName.setName(ND->getDeclName());
12900          R.addDecl(ND);
12901        }
12902      } else {
12903        Diag(IdentLoc, diag::err_no_member)
12904          << NameInfo.getName() << LookupContext << SS.getRange();
12905        return BuildInvalid();
12906      }
12907    }
12908  
12909    if (R.isAmbiguous())
12910      return BuildInvalid();
12911  
12912    if (HasTypenameKeyword) {
12913      // If we asked for a typename and got a non-type decl, error out.
12914      if (!R.getAsSingle<TypeDecl>() &&
12915          !R.getAsSingle<UnresolvedUsingIfExistsDecl>()) {
12916        Diag(IdentLoc, diag::err_using_typename_non_type);
12917        for (LookupResult::iterator I = R.begin(), E = R.end(); I != E; ++I)
12918          Diag((*I)->getUnderlyingDecl()->getLocation(),
12919               diag::note_using_decl_target);
12920        return BuildInvalid();
12921      }
12922    } else {
12923      // If we asked for a non-typename and we got a type, error out,
12924      // but only if this is an instantiation of an unresolved using
12925      // decl.  Otherwise just silently find the type name.
12926      if (IsInstantiation && R.getAsSingle<TypeDecl>()) {
12927        Diag(IdentLoc, diag::err_using_dependent_value_is_type);
12928        Diag(R.getFoundDecl()->getLocation(), diag::note_using_decl_target);
12929        return BuildInvalid();
12930      }
12931    }
12932  
12933    // C++14 [namespace.udecl]p6:
12934    // A using-declaration shall not name a namespace.
12935    if (R.getAsSingle<NamespaceDecl>()) {
12936      Diag(IdentLoc, diag::err_using_decl_can_not_refer_to_namespace)
12937          << SS.getRange();
12938      // Suggest using 'using namespace ...' instead.
12939      Diag(SS.getBeginLoc(), diag::note_namespace_using_decl)
12940          << FixItHint::CreateInsertion(SS.getBeginLoc(), "namespace ");
12941      return BuildInvalid();
12942    }
12943  
12944    UsingDecl *UD = BuildValid();
12945  
12946    // Some additional rules apply to inheriting constructors.
12947    if (UsingName.getName().getNameKind() ==
12948          DeclarationName::CXXConstructorName) {
12949      // Suppress access diagnostics; the access check is instead performed at the
12950      // point of use for an inheriting constructor.
12951      R.suppressDiagnostics();
12952      if (CheckInheritingConstructorUsingDecl(UD))
12953        return UD;
12954    }
12955  
12956    for (LookupResult::iterator I = R.begin(), E = R.end(); I != E; ++I) {
12957      UsingShadowDecl *PrevDecl = nullptr;
12958      if (!CheckUsingShadowDecl(UD, *I, Previous, PrevDecl))
12959        BuildUsingShadowDecl(S, UD, *I, PrevDecl);
12960    }
12961  
12962    return UD;
12963  }
12964  
12965  NamedDecl *Sema::BuildUsingEnumDeclaration(Scope *S, AccessSpecifier AS,
12966                                             SourceLocation UsingLoc,
12967                                             SourceLocation EnumLoc,
12968                                             SourceLocation NameLoc,
12969                                             TypeSourceInfo *EnumType,
12970                                             EnumDecl *ED) {
12971    bool Invalid = false;
12972  
12973    if (CurContext->getRedeclContext()->isRecord()) {
12974      /// In class scope, check if this is a duplicate, for better a diagnostic.
12975      DeclarationNameInfo UsingEnumName(ED->getDeclName(), NameLoc);
12976      LookupResult Previous(*this, UsingEnumName, LookupUsingDeclName,
12977                            RedeclarationKind::ForVisibleRedeclaration);
12978  
12979      LookupName(Previous, S);
12980  
12981      for (NamedDecl *D : Previous)
12982        if (UsingEnumDecl *UED = dyn_cast<UsingEnumDecl>(D))
12983          if (UED->getEnumDecl() == ED) {
12984            Diag(UsingLoc, diag::err_using_enum_decl_redeclaration)
12985                << SourceRange(EnumLoc, NameLoc);
12986            Diag(D->getLocation(), diag::note_using_enum_decl) << 1;
12987            Invalid = true;
12988            break;
12989          }
12990    }
12991  
12992    if (RequireCompleteEnumDecl(ED, NameLoc))
12993      Invalid = true;
12994  
12995    UsingEnumDecl *UD = UsingEnumDecl::Create(Context, CurContext, UsingLoc,
12996                                              EnumLoc, NameLoc, EnumType);
12997    UD->setAccess(AS);
12998    CurContext->addDecl(UD);
12999  
13000    if (Invalid) {
13001      UD->setInvalidDecl();
13002      return UD;
13003    }
13004  
13005    // Create the shadow decls for each enumerator
13006    for (EnumConstantDecl *EC : ED->enumerators()) {
13007      UsingShadowDecl *PrevDecl = nullptr;
13008      DeclarationNameInfo DNI(EC->getDeclName(), EC->getLocation());
13009      LookupResult Previous(*this, DNI, LookupOrdinaryName,
13010                            RedeclarationKind::ForVisibleRedeclaration);
13011      LookupName(Previous, S);
13012      FilterUsingLookup(S, Previous);
13013  
13014      if (!CheckUsingShadowDecl(UD, EC, Previous, PrevDecl))
13015        BuildUsingShadowDecl(S, UD, EC, PrevDecl);
13016    }
13017  
13018    return UD;
13019  }
13020  
13021  NamedDecl *Sema::BuildUsingPackDecl(NamedDecl *InstantiatedFrom,
13022                                      ArrayRef<NamedDecl *> Expansions) {
13023    assert(isa<UnresolvedUsingValueDecl>(InstantiatedFrom) ||
13024           isa<UnresolvedUsingTypenameDecl>(InstantiatedFrom) ||
13025           isa<UsingPackDecl>(InstantiatedFrom));
13026  
13027    auto *UPD =
13028        UsingPackDecl::Create(Context, CurContext, InstantiatedFrom, Expansions);
13029    UPD->setAccess(InstantiatedFrom->getAccess());
13030    CurContext->addDecl(UPD);
13031    return UPD;
13032  }
13033  
13034  bool Sema::CheckInheritingConstructorUsingDecl(UsingDecl *UD) {
13035    assert(!UD->hasTypename() && "expecting a constructor name");
13036  
13037    const Type *SourceType = UD->getQualifier()->getAsType();
13038    assert(SourceType &&
13039           "Using decl naming constructor doesn't have type in scope spec.");
13040    CXXRecordDecl *TargetClass = cast<CXXRecordDecl>(CurContext);
13041  
13042    // Check whether the named type is a direct base class.
13043    bool AnyDependentBases = false;
13044    auto *Base = findDirectBaseWithType(TargetClass, QualType(SourceType, 0),
13045                                        AnyDependentBases);
13046    if (!Base && !AnyDependentBases) {
13047      Diag(UD->getUsingLoc(),
13048           diag::err_using_decl_constructor_not_in_direct_base)
13049        << UD->getNameInfo().getSourceRange()
13050        << QualType(SourceType, 0) << TargetClass;
13051      UD->setInvalidDecl();
13052      return true;
13053    }
13054  
13055    if (Base)
13056      Base->setInheritConstructors();
13057  
13058    return false;
13059  }
13060  
13061  bool Sema::CheckUsingDeclRedeclaration(SourceLocation UsingLoc,
13062                                         bool HasTypenameKeyword,
13063                                         const CXXScopeSpec &SS,
13064                                         SourceLocation NameLoc,
13065                                         const LookupResult &Prev) {
13066    NestedNameSpecifier *Qual = SS.getScopeRep();
13067  
13068    // C++03 [namespace.udecl]p8:
13069    // C++0x [namespace.udecl]p10:
13070    //   A using-declaration is a declaration and can therefore be used
13071    //   repeatedly where (and only where) multiple declarations are
13072    //   allowed.
13073    //
13074    // That's in non-member contexts.
13075    if (!CurContext->getRedeclContext()->isRecord()) {
13076      // A dependent qualifier outside a class can only ever resolve to an
13077      // enumeration type. Therefore it conflicts with any other non-type
13078      // declaration in the same scope.
13079      // FIXME: How should we check for dependent type-type conflicts at block
13080      // scope?
13081      if (Qual->isDependent() && !HasTypenameKeyword) {
13082        for (auto *D : Prev) {
13083          if (!isa<TypeDecl>(D) && !isa<UsingDecl>(D) && !isa<UsingPackDecl>(D)) {
13084            bool OldCouldBeEnumerator =
13085                isa<UnresolvedUsingValueDecl>(D) || isa<EnumConstantDecl>(D);
13086            Diag(NameLoc,
13087                 OldCouldBeEnumerator ? diag::err_redefinition
13088                                      : diag::err_redefinition_different_kind)
13089                << Prev.getLookupName();
13090            Diag(D->getLocation(), diag::note_previous_definition);
13091            return true;
13092          }
13093        }
13094      }
13095      return false;
13096    }
13097  
13098    const NestedNameSpecifier *CNNS =
13099        Context.getCanonicalNestedNameSpecifier(Qual);
13100    for (LookupResult::iterator I = Prev.begin(), E = Prev.end(); I != E; ++I) {
13101      NamedDecl *D = *I;
13102  
13103      bool DTypename;
13104      NestedNameSpecifier *DQual;
13105      if (UsingDecl *UD = dyn_cast<UsingDecl>(D)) {
13106        DTypename = UD->hasTypename();
13107        DQual = UD->getQualifier();
13108      } else if (UnresolvedUsingValueDecl *UD
13109                   = dyn_cast<UnresolvedUsingValueDecl>(D)) {
13110        DTypename = false;
13111        DQual = UD->getQualifier();
13112      } else if (UnresolvedUsingTypenameDecl *UD
13113                   = dyn_cast<UnresolvedUsingTypenameDecl>(D)) {
13114        DTypename = true;
13115        DQual = UD->getQualifier();
13116      } else continue;
13117  
13118      // using decls differ if one says 'typename' and the other doesn't.
13119      // FIXME: non-dependent using decls?
13120      if (HasTypenameKeyword != DTypename) continue;
13121  
13122      // using decls differ if they name different scopes (but note that
13123      // template instantiation can cause this check to trigger when it
13124      // didn't before instantiation).
13125      if (CNNS != Context.getCanonicalNestedNameSpecifier(DQual))
13126        continue;
13127  
13128      Diag(NameLoc, diag::err_using_decl_redeclaration) << SS.getRange();
13129      Diag(D->getLocation(), diag::note_using_decl) << 1;
13130      return true;
13131    }
13132  
13133    return false;
13134  }
13135  
13136  bool Sema::CheckUsingDeclQualifier(SourceLocation UsingLoc, bool HasTypename,
13137                                     const CXXScopeSpec &SS,
13138                                     const DeclarationNameInfo &NameInfo,
13139                                     SourceLocation NameLoc,
13140                                     const LookupResult *R, const UsingDecl *UD) {
13141    DeclContext *NamedContext = computeDeclContext(SS);
13142    assert(bool(NamedContext) == (R || UD) && !(R && UD) &&
13143           "resolvable context must have exactly one set of decls");
13144  
13145    // C++ 20 permits using an enumerator that does not have a class-hierarchy
13146    // relationship.
13147    bool Cxx20Enumerator = false;
13148    if (NamedContext) {
13149      EnumConstantDecl *EC = nullptr;
13150      if (R)
13151        EC = R->getAsSingle<EnumConstantDecl>();
13152      else if (UD && UD->shadow_size() == 1)
13153        EC = dyn_cast<EnumConstantDecl>(UD->shadow_begin()->getTargetDecl());
13154      if (EC)
13155        Cxx20Enumerator = getLangOpts().CPlusPlus20;
13156  
13157      if (auto *ED = dyn_cast<EnumDecl>(NamedContext)) {
13158        // C++14 [namespace.udecl]p7:
13159        // A using-declaration shall not name a scoped enumerator.
13160        // C++20 p1099 permits enumerators.
13161        if (EC && R && ED->isScoped())
13162          Diag(SS.getBeginLoc(),
13163               getLangOpts().CPlusPlus20
13164                   ? diag::warn_cxx17_compat_using_decl_scoped_enumerator
13165                   : diag::ext_using_decl_scoped_enumerator)
13166              << SS.getRange();
13167  
13168        // We want to consider the scope of the enumerator
13169        NamedContext = ED->getDeclContext();
13170      }
13171    }
13172  
13173    if (!CurContext->isRecord()) {
13174      // C++03 [namespace.udecl]p3:
13175      // C++0x [namespace.udecl]p8:
13176      //   A using-declaration for a class member shall be a member-declaration.
13177      // C++20 [namespace.udecl]p7
13178      //   ... other than an enumerator ...
13179  
13180      // If we weren't able to compute a valid scope, it might validly be a
13181      // dependent class or enumeration scope. If we have a 'typename' keyword,
13182      // the scope must resolve to a class type.
13183      if (NamedContext ? !NamedContext->getRedeclContext()->isRecord()
13184                       : !HasTypename)
13185        return false; // OK
13186  
13187      Diag(NameLoc,
13188           Cxx20Enumerator
13189               ? diag::warn_cxx17_compat_using_decl_class_member_enumerator
13190               : diag::err_using_decl_can_not_refer_to_class_member)
13191          << SS.getRange();
13192  
13193      if (Cxx20Enumerator)
13194        return false; // OK
13195  
13196      auto *RD = NamedContext
13197                     ? cast<CXXRecordDecl>(NamedContext->getRedeclContext())
13198                     : nullptr;
13199      if (RD && !RequireCompleteDeclContext(const_cast<CXXScopeSpec &>(SS), RD)) {
13200        // See if there's a helpful fixit
13201  
13202        if (!R) {
13203          // We will have already diagnosed the problem on the template
13204          // definition,  Maybe we should do so again?
13205        } else if (R->getAsSingle<TypeDecl>()) {
13206          if (getLangOpts().CPlusPlus11) {
13207            // Convert 'using X::Y;' to 'using Y = X::Y;'.
13208            Diag(SS.getBeginLoc(), diag::note_using_decl_class_member_workaround)
13209              << 0 // alias declaration
13210              << FixItHint::CreateInsertion(SS.getBeginLoc(),
13211                                            NameInfo.getName().getAsString() +
13212                                                " = ");
13213          } else {
13214            // Convert 'using X::Y;' to 'typedef X::Y Y;'.
13215            SourceLocation InsertLoc = getLocForEndOfToken(NameInfo.getEndLoc());
13216            Diag(InsertLoc, diag::note_using_decl_class_member_workaround)
13217              << 1 // typedef declaration
13218              << FixItHint::CreateReplacement(UsingLoc, "typedef")
13219              << FixItHint::CreateInsertion(
13220                     InsertLoc, " " + NameInfo.getName().getAsString());
13221          }
13222        } else if (R->getAsSingle<VarDecl>()) {
13223          // Don't provide a fixit outside C++11 mode; we don't want to suggest
13224          // repeating the type of the static data member here.
13225          FixItHint FixIt;
13226          if (getLangOpts().CPlusPlus11) {
13227            // Convert 'using X::Y;' to 'auto &Y = X::Y;'.
13228            FixIt = FixItHint::CreateReplacement(
13229                UsingLoc, "auto &" + NameInfo.getName().getAsString() + " = ");
13230          }
13231  
13232          Diag(UsingLoc, diag::note_using_decl_class_member_workaround)
13233            << 2 // reference declaration
13234            << FixIt;
13235        } else if (R->getAsSingle<EnumConstantDecl>()) {
13236          // Don't provide a fixit outside C++11 mode; we don't want to suggest
13237          // repeating the type of the enumeration here, and we can't do so if
13238          // the type is anonymous.
13239          FixItHint FixIt;
13240          if (getLangOpts().CPlusPlus11) {
13241            // Convert 'using X::Y;' to 'auto &Y = X::Y;'.
13242            FixIt = FixItHint::CreateReplacement(
13243                UsingLoc,
13244                "constexpr auto " + NameInfo.getName().getAsString() + " = ");
13245          }
13246  
13247          Diag(UsingLoc, diag::note_using_decl_class_member_workaround)
13248            << (getLangOpts().CPlusPlus11 ? 4 : 3) // const[expr] variable
13249            << FixIt;
13250        }
13251      }
13252  
13253      return true; // Fail
13254    }
13255  
13256    // If the named context is dependent, we can't decide much.
13257    if (!NamedContext) {
13258      // FIXME: in C++0x, we can diagnose if we can prove that the
13259      // nested-name-specifier does not refer to a base class, which is
13260      // still possible in some cases.
13261  
13262      // Otherwise we have to conservatively report that things might be
13263      // okay.
13264      return false;
13265    }
13266  
13267    // The current scope is a record.
13268    if (!NamedContext->isRecord()) {
13269      // Ideally this would point at the last name in the specifier,
13270      // but we don't have that level of source info.
13271      Diag(SS.getBeginLoc(),
13272           Cxx20Enumerator
13273               ? diag::warn_cxx17_compat_using_decl_non_member_enumerator
13274               : diag::err_using_decl_nested_name_specifier_is_not_class)
13275          << SS.getScopeRep() << SS.getRange();
13276  
13277      if (Cxx20Enumerator)
13278        return false; // OK
13279  
13280      return true;
13281    }
13282  
13283    if (!NamedContext->isDependentContext() &&
13284        RequireCompleteDeclContext(const_cast<CXXScopeSpec&>(SS), NamedContext))
13285      return true;
13286  
13287    if (getLangOpts().CPlusPlus11) {
13288      // C++11 [namespace.udecl]p3:
13289      //   In a using-declaration used as a member-declaration, the
13290      //   nested-name-specifier shall name a base class of the class
13291      //   being defined.
13292  
13293      if (cast<CXXRecordDecl>(CurContext)->isProvablyNotDerivedFrom(
13294                                   cast<CXXRecordDecl>(NamedContext))) {
13295  
13296        if (Cxx20Enumerator) {
13297          Diag(NameLoc, diag::warn_cxx17_compat_using_decl_non_member_enumerator)
13298              << SS.getRange();
13299          return false;
13300        }
13301  
13302        if (CurContext == NamedContext) {
13303          Diag(SS.getBeginLoc(),
13304               diag::err_using_decl_nested_name_specifier_is_current_class)
13305              << SS.getRange();
13306          return !getLangOpts().CPlusPlus20;
13307        }
13308  
13309        if (!cast<CXXRecordDecl>(NamedContext)->isInvalidDecl()) {
13310          Diag(SS.getBeginLoc(),
13311               diag::err_using_decl_nested_name_specifier_is_not_base_class)
13312              << SS.getScopeRep() << cast<CXXRecordDecl>(CurContext)
13313              << SS.getRange();
13314        }
13315        return true;
13316      }
13317  
13318      return false;
13319    }
13320  
13321    // C++03 [namespace.udecl]p4:
13322    //   A using-declaration used as a member-declaration shall refer
13323    //   to a member of a base class of the class being defined [etc.].
13324  
13325    // Salient point: SS doesn't have to name a base class as long as
13326    // lookup only finds members from base classes.  Therefore we can
13327    // diagnose here only if we can prove that can't happen,
13328    // i.e. if the class hierarchies provably don't intersect.
13329  
13330    // TODO: it would be nice if "definitely valid" results were cached
13331    // in the UsingDecl and UsingShadowDecl so that these checks didn't
13332    // need to be repeated.
13333  
13334    llvm::SmallPtrSet<const CXXRecordDecl *, 4> Bases;
13335    auto Collect = [&Bases](const CXXRecordDecl *Base) {
13336      Bases.insert(Base);
13337      return true;
13338    };
13339  
13340    // Collect all bases. Return false if we find a dependent base.
13341    if (!cast<CXXRecordDecl>(CurContext)->forallBases(Collect))
13342      return false;
13343  
13344    // Returns true if the base is dependent or is one of the accumulated base
13345    // classes.
13346    auto IsNotBase = [&Bases](const CXXRecordDecl *Base) {
13347      return !Bases.count(Base);
13348    };
13349  
13350    // Return false if the class has a dependent base or if it or one
13351    // of its bases is present in the base set of the current context.
13352    if (Bases.count(cast<CXXRecordDecl>(NamedContext)) ||
13353        !cast<CXXRecordDecl>(NamedContext)->forallBases(IsNotBase))
13354      return false;
13355  
13356    Diag(SS.getRange().getBegin(),
13357         diag::err_using_decl_nested_name_specifier_is_not_base_class)
13358      << SS.getScopeRep()
13359      << cast<CXXRecordDecl>(CurContext)
13360      << SS.getRange();
13361  
13362    return true;
13363  }
13364  
13365  Decl *Sema::ActOnAliasDeclaration(Scope *S, AccessSpecifier AS,
13366                                    MultiTemplateParamsArg TemplateParamLists,
13367                                    SourceLocation UsingLoc, UnqualifiedId &Name,
13368                                    const ParsedAttributesView &AttrList,
13369                                    TypeResult Type, Decl *DeclFromDeclSpec) {
13370    // Get the innermost enclosing declaration scope.
13371    S = S->getDeclParent();
13372  
13373    if (Type.isInvalid())
13374      return nullptr;
13375  
13376    bool Invalid = false;
13377    DeclarationNameInfo NameInfo = GetNameFromUnqualifiedId(Name);
13378    TypeSourceInfo *TInfo = nullptr;
13379    GetTypeFromParser(Type.get(), &TInfo);
13380  
13381    if (DiagnoseClassNameShadow(CurContext, NameInfo))
13382      return nullptr;
13383  
13384    if (DiagnoseUnexpandedParameterPack(Name.StartLocation, TInfo,
13385                                        UPPC_DeclarationType)) {
13386      Invalid = true;
13387      TInfo = Context.getTrivialTypeSourceInfo(Context.IntTy,
13388                                               TInfo->getTypeLoc().getBeginLoc());
13389    }
13390  
13391    LookupResult Previous(*this, NameInfo, LookupOrdinaryName,
13392                          TemplateParamLists.size()
13393                              ? forRedeclarationInCurContext()
13394                              : RedeclarationKind::ForVisibleRedeclaration);
13395    LookupName(Previous, S);
13396  
13397    // Warn about shadowing the name of a template parameter.
13398    if (Previous.isSingleResult() &&
13399        Previous.getFoundDecl()->isTemplateParameter()) {
13400      DiagnoseTemplateParameterShadow(Name.StartLocation,Previous.getFoundDecl());
13401      Previous.clear();
13402    }
13403  
13404    assert(Name.getKind() == UnqualifiedIdKind::IK_Identifier &&
13405           "name in alias declaration must be an identifier");
13406    TypeAliasDecl *NewTD = TypeAliasDecl::Create(Context, CurContext, UsingLoc,
13407                                                 Name.StartLocation,
13408                                                 Name.Identifier, TInfo);
13409  
13410    NewTD->setAccess(AS);
13411  
13412    if (Invalid)
13413      NewTD->setInvalidDecl();
13414  
13415    ProcessDeclAttributeList(S, NewTD, AttrList);
13416    AddPragmaAttributes(S, NewTD);
13417    ProcessAPINotes(NewTD);
13418  
13419    CheckTypedefForVariablyModifiedType(S, NewTD);
13420    Invalid |= NewTD->isInvalidDecl();
13421  
13422    bool Redeclaration = false;
13423  
13424    NamedDecl *NewND;
13425    if (TemplateParamLists.size()) {
13426      TypeAliasTemplateDecl *OldDecl = nullptr;
13427      TemplateParameterList *OldTemplateParams = nullptr;
13428  
13429      if (TemplateParamLists.size() != 1) {
13430        Diag(UsingLoc, diag::err_alias_template_extra_headers)
13431          << SourceRange(TemplateParamLists[1]->getTemplateLoc(),
13432           TemplateParamLists[TemplateParamLists.size()-1]->getRAngleLoc());
13433        Invalid = true;
13434      }
13435      TemplateParameterList *TemplateParams = TemplateParamLists[0];
13436  
13437      // Check that we can declare a template here.
13438      if (CheckTemplateDeclScope(S, TemplateParams))
13439        return nullptr;
13440  
13441      // Only consider previous declarations in the same scope.
13442      FilterLookupForScope(Previous, CurContext, S, /*ConsiderLinkage*/false,
13443                           /*ExplicitInstantiationOrSpecialization*/false);
13444      if (!Previous.empty()) {
13445        Redeclaration = true;
13446  
13447        OldDecl = Previous.getAsSingle<TypeAliasTemplateDecl>();
13448        if (!OldDecl && !Invalid) {
13449          Diag(UsingLoc, diag::err_redefinition_different_kind)
13450            << Name.Identifier;
13451  
13452          NamedDecl *OldD = Previous.getRepresentativeDecl();
13453          if (OldD->getLocation().isValid())
13454            Diag(OldD->getLocation(), diag::note_previous_definition);
13455  
13456          Invalid = true;
13457        }
13458  
13459        if (!Invalid && OldDecl && !OldDecl->isInvalidDecl()) {
13460          if (TemplateParameterListsAreEqual(TemplateParams,
13461                                             OldDecl->getTemplateParameters(),
13462                                             /*Complain=*/true,
13463                                             TPL_TemplateMatch))
13464            OldTemplateParams =
13465                OldDecl->getMostRecentDecl()->getTemplateParameters();
13466          else
13467            Invalid = true;
13468  
13469          TypeAliasDecl *OldTD = OldDecl->getTemplatedDecl();
13470          if (!Invalid &&
13471              !Context.hasSameType(OldTD->getUnderlyingType(),
13472                                   NewTD->getUnderlyingType())) {
13473            // FIXME: The C++0x standard does not clearly say this is ill-formed,
13474            // but we can't reasonably accept it.
13475            Diag(NewTD->getLocation(), diag::err_redefinition_different_typedef)
13476              << 2 << NewTD->getUnderlyingType() << OldTD->getUnderlyingType();
13477            if (OldTD->getLocation().isValid())
13478              Diag(OldTD->getLocation(), diag::note_previous_definition);
13479            Invalid = true;
13480          }
13481        }
13482      }
13483  
13484      // Merge any previous default template arguments into our parameters,
13485      // and check the parameter list.
13486      if (CheckTemplateParameterList(TemplateParams, OldTemplateParams,
13487                                     TPC_TypeAliasTemplate))
13488        return nullptr;
13489  
13490      TypeAliasTemplateDecl *NewDecl =
13491        TypeAliasTemplateDecl::Create(Context, CurContext, UsingLoc,
13492                                      Name.Identifier, TemplateParams,
13493                                      NewTD);
13494      NewTD->setDescribedAliasTemplate(NewDecl);
13495  
13496      NewDecl->setAccess(AS);
13497  
13498      if (Invalid)
13499        NewDecl->setInvalidDecl();
13500      else if (OldDecl) {
13501        NewDecl->setPreviousDecl(OldDecl);
13502        CheckRedeclarationInModule(NewDecl, OldDecl);
13503      }
13504  
13505      NewND = NewDecl;
13506    } else {
13507      if (auto *TD = dyn_cast_or_null<TagDecl>(DeclFromDeclSpec)) {
13508        setTagNameForLinkagePurposes(TD, NewTD);
13509        handleTagNumbering(TD, S);
13510      }
13511      ActOnTypedefNameDecl(S, CurContext, NewTD, Previous, Redeclaration);
13512      NewND = NewTD;
13513    }
13514  
13515    PushOnScopeChains(NewND, S);
13516    ActOnDocumentableDecl(NewND);
13517    return NewND;
13518  }
13519  
13520  Decl *Sema::ActOnNamespaceAliasDef(Scope *S, SourceLocation NamespaceLoc,
13521                                     SourceLocation AliasLoc,
13522                                     IdentifierInfo *Alias, CXXScopeSpec &SS,
13523                                     SourceLocation IdentLoc,
13524                                     IdentifierInfo *Ident) {
13525  
13526    // Lookup the namespace name.
13527    LookupResult R(*this, Ident, IdentLoc, LookupNamespaceName);
13528    LookupParsedName(R, S, &SS, /*ObjectType=*/QualType());
13529  
13530    if (R.isAmbiguous())
13531      return nullptr;
13532  
13533    if (R.empty()) {
13534      if (!TryNamespaceTypoCorrection(*this, R, S, SS, IdentLoc, Ident)) {
13535        Diag(IdentLoc, diag::err_expected_namespace_name) << SS.getRange();
13536        return nullptr;
13537      }
13538    }
13539    assert(!R.isAmbiguous() && !R.empty());
13540    NamedDecl *ND = R.getRepresentativeDecl();
13541  
13542    // Check if we have a previous declaration with the same name.
13543    LookupResult PrevR(*this, Alias, AliasLoc, LookupOrdinaryName,
13544                       RedeclarationKind::ForVisibleRedeclaration);
13545    LookupName(PrevR, S);
13546  
13547    // Check we're not shadowing a template parameter.
13548    if (PrevR.isSingleResult() && PrevR.getFoundDecl()->isTemplateParameter()) {
13549      DiagnoseTemplateParameterShadow(AliasLoc, PrevR.getFoundDecl());
13550      PrevR.clear();
13551    }
13552  
13553    // Filter out any other lookup result from an enclosing scope.
13554    FilterLookupForScope(PrevR, CurContext, S, /*ConsiderLinkage*/false,
13555                         /*AllowInlineNamespace*/false);
13556  
13557    // Find the previous declaration and check that we can redeclare it.
13558    NamespaceAliasDecl *Prev = nullptr;
13559    if (PrevR.isSingleResult()) {
13560      NamedDecl *PrevDecl = PrevR.getRepresentativeDecl();
13561      if (NamespaceAliasDecl *AD = dyn_cast<NamespaceAliasDecl>(PrevDecl)) {
13562        // We already have an alias with the same name that points to the same
13563        // namespace; check that it matches.
13564        if (AD->getNamespace()->Equals(getNamespaceDecl(ND))) {
13565          Prev = AD;
13566        } else if (isVisible(PrevDecl)) {
13567          Diag(AliasLoc, diag::err_redefinition_different_namespace_alias)
13568            << Alias;
13569          Diag(AD->getLocation(), diag::note_previous_namespace_alias)
13570            << AD->getNamespace();
13571          return nullptr;
13572        }
13573      } else if (isVisible(PrevDecl)) {
13574        unsigned DiagID = isa<NamespaceDecl>(PrevDecl->getUnderlyingDecl())
13575                              ? diag::err_redefinition
13576                              : diag::err_redefinition_different_kind;
13577        Diag(AliasLoc, DiagID) << Alias;
13578        Diag(PrevDecl->getLocation(), diag::note_previous_definition);
13579        return nullptr;
13580      }
13581    }
13582  
13583    // The use of a nested name specifier may trigger deprecation warnings.
13584    DiagnoseUseOfDecl(ND, IdentLoc);
13585  
13586    NamespaceAliasDecl *AliasDecl =
13587      NamespaceAliasDecl::Create(Context, CurContext, NamespaceLoc, AliasLoc,
13588                                 Alias, SS.getWithLocInContext(Context),
13589                                 IdentLoc, ND);
13590    if (Prev)
13591      AliasDecl->setPreviousDecl(Prev);
13592  
13593    PushOnScopeChains(AliasDecl, S);
13594    return AliasDecl;
13595  }
13596  
13597  namespace {
13598  struct SpecialMemberExceptionSpecInfo
13599      : SpecialMemberVisitor<SpecialMemberExceptionSpecInfo> {
13600    SourceLocation Loc;
13601    Sema::ImplicitExceptionSpecification ExceptSpec;
13602  
13603    SpecialMemberExceptionSpecInfo(Sema &S, CXXMethodDecl *MD,
13604                                   CXXSpecialMemberKind CSM,
13605                                   Sema::InheritedConstructorInfo *ICI,
13606                                   SourceLocation Loc)
13607        : SpecialMemberVisitor(S, MD, CSM, ICI), Loc(Loc), ExceptSpec(S) {}
13608  
13609    bool visitBase(CXXBaseSpecifier *Base);
13610    bool visitField(FieldDecl *FD);
13611  
13612    void visitClassSubobject(CXXRecordDecl *Class, Subobject Subobj,
13613                             unsigned Quals);
13614  
13615    void visitSubobjectCall(Subobject Subobj,
13616                            Sema::SpecialMemberOverloadResult SMOR);
13617  };
13618  }
13619  
13620  bool SpecialMemberExceptionSpecInfo::visitBase(CXXBaseSpecifier *Base) {
13621    auto *RT = Base->getType()->getAs<RecordType>();
13622    if (!RT)
13623      return false;
13624  
13625    auto *BaseClass = cast<CXXRecordDecl>(RT->getDecl());
13626    Sema::SpecialMemberOverloadResult SMOR = lookupInheritedCtor(BaseClass);
13627    if (auto *BaseCtor = SMOR.getMethod()) {
13628      visitSubobjectCall(Base, BaseCtor);
13629      return false;
13630    }
13631  
13632    visitClassSubobject(BaseClass, Base, 0);
13633    return false;
13634  }
13635  
13636  bool SpecialMemberExceptionSpecInfo::visitField(FieldDecl *FD) {
13637    if (CSM == CXXSpecialMemberKind::DefaultConstructor &&
13638        FD->hasInClassInitializer()) {
13639      Expr *E = FD->getInClassInitializer();
13640      if (!E)
13641        // FIXME: It's a little wasteful to build and throw away a
13642        // CXXDefaultInitExpr here.
13643        // FIXME: We should have a single context note pointing at Loc, and
13644        // this location should be MD->getLocation() instead, since that's
13645        // the location where we actually use the default init expression.
13646        E = S.BuildCXXDefaultInitExpr(Loc, FD).get();
13647      if (E)
13648        ExceptSpec.CalledExpr(E);
13649    } else if (auto *RT = S.Context.getBaseElementType(FD->getType())
13650                              ->getAs<RecordType>()) {
13651      visitClassSubobject(cast<CXXRecordDecl>(RT->getDecl()), FD,
13652                          FD->getType().getCVRQualifiers());
13653    }
13654    return false;
13655  }
13656  
13657  void SpecialMemberExceptionSpecInfo::visitClassSubobject(CXXRecordDecl *Class,
13658                                                           Subobject Subobj,
13659                                                           unsigned Quals) {
13660    FieldDecl *Field = Subobj.dyn_cast<FieldDecl*>();
13661    bool IsMutable = Field && Field->isMutable();
13662    visitSubobjectCall(Subobj, lookupIn(Class, Quals, IsMutable));
13663  }
13664  
13665  void SpecialMemberExceptionSpecInfo::visitSubobjectCall(
13666      Subobject Subobj, Sema::SpecialMemberOverloadResult SMOR) {
13667    // Note, if lookup fails, it doesn't matter what exception specification we
13668    // choose because the special member will be deleted.
13669    if (CXXMethodDecl *MD = SMOR.getMethod())
13670      ExceptSpec.CalledDecl(getSubobjectLoc(Subobj), MD);
13671  }
13672  
13673  bool Sema::tryResolveExplicitSpecifier(ExplicitSpecifier &ExplicitSpec) {
13674    llvm::APSInt Result;
13675    ExprResult Converted = CheckConvertedConstantExpression(
13676        ExplicitSpec.getExpr(), Context.BoolTy, Result, CCEK_ExplicitBool);
13677    ExplicitSpec.setExpr(Converted.get());
13678    if (Converted.isUsable() && !Converted.get()->isValueDependent()) {
13679      ExplicitSpec.setKind(Result.getBoolValue()
13680                               ? ExplicitSpecKind::ResolvedTrue
13681                               : ExplicitSpecKind::ResolvedFalse);
13682      return true;
13683    }
13684    ExplicitSpec.setKind(ExplicitSpecKind::Unresolved);
13685    return false;
13686  }
13687  
13688  ExplicitSpecifier Sema::ActOnExplicitBoolSpecifier(Expr *ExplicitExpr) {
13689    ExplicitSpecifier ES(ExplicitExpr, ExplicitSpecKind::Unresolved);
13690    if (!ExplicitExpr->isTypeDependent())
13691      tryResolveExplicitSpecifier(ES);
13692    return ES;
13693  }
13694  
13695  static Sema::ImplicitExceptionSpecification
13696  ComputeDefaultedSpecialMemberExceptionSpec(
13697      Sema &S, SourceLocation Loc, CXXMethodDecl *MD, CXXSpecialMemberKind CSM,
13698      Sema::InheritedConstructorInfo *ICI) {
13699    ComputingExceptionSpec CES(S, MD, Loc);
13700  
13701    CXXRecordDecl *ClassDecl = MD->getParent();
13702  
13703    // C++ [except.spec]p14:
13704    //   An implicitly declared special member function (Clause 12) shall have an
13705    //   exception-specification. [...]
13706    SpecialMemberExceptionSpecInfo Info(S, MD, CSM, ICI, MD->getLocation());
13707    if (ClassDecl->isInvalidDecl())
13708      return Info.ExceptSpec;
13709  
13710    // FIXME: If this diagnostic fires, we're probably missing a check for
13711    // attempting to resolve an exception specification before it's known
13712    // at a higher level.
13713    if (S.RequireCompleteType(MD->getLocation(),
13714                              S.Context.getRecordType(ClassDecl),
13715                              diag::err_exception_spec_incomplete_type))
13716      return Info.ExceptSpec;
13717  
13718    // C++1z [except.spec]p7:
13719    //   [Look for exceptions thrown by] a constructor selected [...] to
13720    //   initialize a potentially constructed subobject,
13721    // C++1z [except.spec]p8:
13722    //   The exception specification for an implicitly-declared destructor, or a
13723    //   destructor without a noexcept-specifier, is potentially-throwing if and
13724    //   only if any of the destructors for any of its potentially constructed
13725    //   subojects is potentially throwing.
13726    // FIXME: We respect the first rule but ignore the "potentially constructed"
13727    // in the second rule to resolve a core issue (no number yet) that would have
13728    // us reject:
13729    //   struct A { virtual void f() = 0; virtual ~A() noexcept(false) = 0; };
13730    //   struct B : A {};
13731    //   struct C : B { void f(); };
13732    // ... due to giving B::~B() a non-throwing exception specification.
13733    Info.visit(Info.IsConstructor ? Info.VisitPotentiallyConstructedBases
13734                                  : Info.VisitAllBases);
13735  
13736    return Info.ExceptSpec;
13737  }
13738  
13739  namespace {
13740  /// RAII object to register a special member as being currently declared.
13741  struct DeclaringSpecialMember {
13742    Sema &S;
13743    Sema::SpecialMemberDecl D;
13744    Sema::ContextRAII SavedContext;
13745    bool WasAlreadyBeingDeclared;
13746  
13747    DeclaringSpecialMember(Sema &S, CXXRecordDecl *RD, CXXSpecialMemberKind CSM)
13748        : S(S), D(RD, CSM), SavedContext(S, RD) {
13749      WasAlreadyBeingDeclared = !S.SpecialMembersBeingDeclared.insert(D).second;
13750      if (WasAlreadyBeingDeclared)
13751        // This almost never happens, but if it does, ensure that our cache
13752        // doesn't contain a stale result.
13753        S.SpecialMemberCache.clear();
13754      else {
13755        // Register a note to be produced if we encounter an error while
13756        // declaring the special member.
13757        Sema::CodeSynthesisContext Ctx;
13758        Ctx.Kind = Sema::CodeSynthesisContext::DeclaringSpecialMember;
13759        // FIXME: We don't have a location to use here. Using the class's
13760        // location maintains the fiction that we declare all special members
13761        // with the class, but (1) it's not clear that lying about that helps our
13762        // users understand what's going on, and (2) there may be outer contexts
13763        // on the stack (some of which are relevant) and printing them exposes
13764        // our lies.
13765        Ctx.PointOfInstantiation = RD->getLocation();
13766        Ctx.Entity = RD;
13767        Ctx.SpecialMember = CSM;
13768        S.pushCodeSynthesisContext(Ctx);
13769      }
13770    }
13771    ~DeclaringSpecialMember() {
13772      if (!WasAlreadyBeingDeclared) {
13773        S.SpecialMembersBeingDeclared.erase(D);
13774        S.popCodeSynthesisContext();
13775      }
13776    }
13777  
13778    /// Are we already trying to declare this special member?
13779    bool isAlreadyBeingDeclared() const {
13780      return WasAlreadyBeingDeclared;
13781    }
13782  };
13783  }
13784  
13785  void Sema::CheckImplicitSpecialMemberDeclaration(Scope *S, FunctionDecl *FD) {
13786    // Look up any existing declarations, but don't trigger declaration of all
13787    // implicit special members with this name.
13788    DeclarationName Name = FD->getDeclName();
13789    LookupResult R(*this, Name, SourceLocation(), LookupOrdinaryName,
13790                   RedeclarationKind::ForExternalRedeclaration);
13791    for (auto *D : FD->getParent()->lookup(Name))
13792      if (auto *Acceptable = R.getAcceptableDecl(D))
13793        R.addDecl(Acceptable);
13794    R.resolveKind();
13795    R.suppressDiagnostics();
13796  
13797    CheckFunctionDeclaration(S, FD, R, /*IsMemberSpecialization*/ false,
13798                             FD->isThisDeclarationADefinition());
13799  }
13800  
13801  void Sema::setupImplicitSpecialMemberType(CXXMethodDecl *SpecialMem,
13802                                            QualType ResultTy,
13803                                            ArrayRef<QualType> Args) {
13804    // Build an exception specification pointing back at this constructor.
13805    FunctionProtoType::ExtProtoInfo EPI = getImplicitMethodEPI(*this, SpecialMem);
13806  
13807    LangAS AS = getDefaultCXXMethodAddrSpace();
13808    if (AS != LangAS::Default) {
13809      EPI.TypeQuals.addAddressSpace(AS);
13810    }
13811  
13812    auto QT = Context.getFunctionType(ResultTy, Args, EPI);
13813    SpecialMem->setType(QT);
13814  
13815    // During template instantiation of implicit special member functions we need
13816    // a reliable TypeSourceInfo for the function prototype in order to allow
13817    // functions to be substituted.
13818    if (inTemplateInstantiation() &&
13819        cast<CXXRecordDecl>(SpecialMem->getParent())->isLambda()) {
13820      TypeSourceInfo *TSI =
13821          Context.getTrivialTypeSourceInfo(SpecialMem->getType());
13822      SpecialMem->setTypeSourceInfo(TSI);
13823    }
13824  }
13825  
13826  CXXConstructorDecl *Sema::DeclareImplicitDefaultConstructor(
13827                                                       CXXRecordDecl *ClassDecl) {
13828    // C++ [class.ctor]p5:
13829    //   A default constructor for a class X is a constructor of class X
13830    //   that can be called without an argument. If there is no
13831    //   user-declared constructor for class X, a default constructor is
13832    //   implicitly declared. An implicitly-declared default constructor
13833    //   is an inline public member of its class.
13834    assert(ClassDecl->needsImplicitDefaultConstructor() &&
13835           "Should not build implicit default constructor!");
13836  
13837    DeclaringSpecialMember DSM(*this, ClassDecl,
13838                               CXXSpecialMemberKind::DefaultConstructor);
13839    if (DSM.isAlreadyBeingDeclared())
13840      return nullptr;
13841  
13842    bool Constexpr = defaultedSpecialMemberIsConstexpr(
13843        *this, ClassDecl, CXXSpecialMemberKind::DefaultConstructor, false);
13844  
13845    // Create the actual constructor declaration.
13846    CanQualType ClassType
13847      = Context.getCanonicalType(Context.getTypeDeclType(ClassDecl));
13848    SourceLocation ClassLoc = ClassDecl->getLocation();
13849    DeclarationName Name
13850      = Context.DeclarationNames.getCXXConstructorName(ClassType);
13851    DeclarationNameInfo NameInfo(Name, ClassLoc);
13852    CXXConstructorDecl *DefaultCon = CXXConstructorDecl::Create(
13853        Context, ClassDecl, ClassLoc, NameInfo, /*Type*/ QualType(),
13854        /*TInfo=*/nullptr, ExplicitSpecifier(),
13855        getCurFPFeatures().isFPConstrained(),
13856        /*isInline=*/true, /*isImplicitlyDeclared=*/true,
13857        Constexpr ? ConstexprSpecKind::Constexpr
13858                  : ConstexprSpecKind::Unspecified);
13859    DefaultCon->setAccess(AS_public);
13860    DefaultCon->setDefaulted();
13861  
13862    setupImplicitSpecialMemberType(DefaultCon, Context.VoidTy, std::nullopt);
13863  
13864    if (getLangOpts().CUDA)
13865      CUDA().inferTargetForImplicitSpecialMember(
13866          ClassDecl, CXXSpecialMemberKind::DefaultConstructor, DefaultCon,
13867          /* ConstRHS */ false,
13868          /* Diagnose */ false);
13869  
13870    // We don't need to use SpecialMemberIsTrivial here; triviality for default
13871    // constructors is easy to compute.
13872    DefaultCon->setTrivial(ClassDecl->hasTrivialDefaultConstructor());
13873  
13874    // Note that we have declared this constructor.
13875    ++getASTContext().NumImplicitDefaultConstructorsDeclared;
13876  
13877    Scope *S = getScopeForContext(ClassDecl);
13878    CheckImplicitSpecialMemberDeclaration(S, DefaultCon);
13879  
13880    if (ShouldDeleteSpecialMember(DefaultCon,
13881                                  CXXSpecialMemberKind::DefaultConstructor))
13882      SetDeclDeleted(DefaultCon, ClassLoc);
13883  
13884    if (S)
13885      PushOnScopeChains(DefaultCon, S, false);
13886    ClassDecl->addDecl(DefaultCon);
13887  
13888    return DefaultCon;
13889  }
13890  
13891  void Sema::DefineImplicitDefaultConstructor(SourceLocation CurrentLocation,
13892                                              CXXConstructorDecl *Constructor) {
13893    assert((Constructor->isDefaulted() && Constructor->isDefaultConstructor() &&
13894            !Constructor->doesThisDeclarationHaveABody() &&
13895            !Constructor->isDeleted()) &&
13896      "DefineImplicitDefaultConstructor - call it for implicit default ctor");
13897    if (Constructor->willHaveBody() || Constructor->isInvalidDecl())
13898      return;
13899  
13900    CXXRecordDecl *ClassDecl = Constructor->getParent();
13901    assert(ClassDecl && "DefineImplicitDefaultConstructor - invalid constructor");
13902    if (ClassDecl->isInvalidDecl()) {
13903      return;
13904    }
13905  
13906    SynthesizedFunctionScope Scope(*this, Constructor);
13907  
13908    // The exception specification is needed because we are defining the
13909    // function.
13910    ResolveExceptionSpec(CurrentLocation,
13911                         Constructor->getType()->castAs<FunctionProtoType>());
13912    MarkVTableUsed(CurrentLocation, ClassDecl);
13913  
13914    // Add a context note for diagnostics produced after this point.
13915    Scope.addContextNote(CurrentLocation);
13916  
13917    if (SetCtorInitializers(Constructor, /*AnyErrors=*/false)) {
13918      Constructor->setInvalidDecl();
13919      return;
13920    }
13921  
13922    SourceLocation Loc = Constructor->getEndLoc().isValid()
13923                             ? Constructor->getEndLoc()
13924                             : Constructor->getLocation();
13925    Constructor->setBody(new (Context) CompoundStmt(Loc));
13926    Constructor->markUsed(Context);
13927  
13928    if (ASTMutationListener *L = getASTMutationListener()) {
13929      L->CompletedImplicitDefinition(Constructor);
13930    }
13931  
13932    DiagnoseUninitializedFields(*this, Constructor);
13933  }
13934  
13935  void Sema::ActOnFinishDelayedMemberInitializers(Decl *D) {
13936    // Perform any delayed checks on exception specifications.
13937    CheckDelayedMemberExceptionSpecs();
13938  }
13939  
13940  /// Find or create the fake constructor we synthesize to model constructing an
13941  /// object of a derived class via a constructor of a base class.
13942  CXXConstructorDecl *
13943  Sema::findInheritingConstructor(SourceLocation Loc,
13944                                  CXXConstructorDecl *BaseCtor,
13945                                  ConstructorUsingShadowDecl *Shadow) {
13946    CXXRecordDecl *Derived = Shadow->getParent();
13947    SourceLocation UsingLoc = Shadow->getLocation();
13948  
13949    // FIXME: Add a new kind of DeclarationName for an inherited constructor.
13950    // For now we use the name of the base class constructor as a member of the
13951    // derived class to indicate a (fake) inherited constructor name.
13952    DeclarationName Name = BaseCtor->getDeclName();
13953  
13954    // Check to see if we already have a fake constructor for this inherited
13955    // constructor call.
13956    for (NamedDecl *Ctor : Derived->lookup(Name))
13957      if (declaresSameEntity(cast<CXXConstructorDecl>(Ctor)
13958                                 ->getInheritedConstructor()
13959                                 .getConstructor(),
13960                             BaseCtor))
13961        return cast<CXXConstructorDecl>(Ctor);
13962  
13963    DeclarationNameInfo NameInfo(Name, UsingLoc);
13964    TypeSourceInfo *TInfo =
13965        Context.getTrivialTypeSourceInfo(BaseCtor->getType(), UsingLoc);
13966    FunctionProtoTypeLoc ProtoLoc =
13967        TInfo->getTypeLoc().IgnoreParens().castAs<FunctionProtoTypeLoc>();
13968  
13969    // Check the inherited constructor is valid and find the list of base classes
13970    // from which it was inherited.
13971    InheritedConstructorInfo ICI(*this, Loc, Shadow);
13972  
13973    bool Constexpr = BaseCtor->isConstexpr() &&
13974                     defaultedSpecialMemberIsConstexpr(
13975                         *this, Derived, CXXSpecialMemberKind::DefaultConstructor,
13976                         false, BaseCtor, &ICI);
13977  
13978    CXXConstructorDecl *DerivedCtor = CXXConstructorDecl::Create(
13979        Context, Derived, UsingLoc, NameInfo, TInfo->getType(), TInfo,
13980        BaseCtor->getExplicitSpecifier(), getCurFPFeatures().isFPConstrained(),
13981        /*isInline=*/true,
13982        /*isImplicitlyDeclared=*/true,
13983        Constexpr ? BaseCtor->getConstexprKind() : ConstexprSpecKind::Unspecified,
13984        InheritedConstructor(Shadow, BaseCtor),
13985        BaseCtor->getTrailingRequiresClause());
13986    if (Shadow->isInvalidDecl())
13987      DerivedCtor->setInvalidDecl();
13988  
13989    // Build an unevaluated exception specification for this fake constructor.
13990    const FunctionProtoType *FPT = TInfo->getType()->castAs<FunctionProtoType>();
13991    FunctionProtoType::ExtProtoInfo EPI = FPT->getExtProtoInfo();
13992    EPI.ExceptionSpec.Type = EST_Unevaluated;
13993    EPI.ExceptionSpec.SourceDecl = DerivedCtor;
13994    DerivedCtor->setType(Context.getFunctionType(FPT->getReturnType(),
13995                                                 FPT->getParamTypes(), EPI));
13996  
13997    // Build the parameter declarations.
13998    SmallVector<ParmVarDecl *, 16> ParamDecls;
13999    for (unsigned I = 0, N = FPT->getNumParams(); I != N; ++I) {
14000      TypeSourceInfo *TInfo =
14001          Context.getTrivialTypeSourceInfo(FPT->getParamType(I), UsingLoc);
14002      ParmVarDecl *PD = ParmVarDecl::Create(
14003          Context, DerivedCtor, UsingLoc, UsingLoc, /*IdentifierInfo=*/nullptr,
14004          FPT->getParamType(I), TInfo, SC_None, /*DefArg=*/nullptr);
14005      PD->setScopeInfo(0, I);
14006      PD->setImplicit();
14007      // Ensure attributes are propagated onto parameters (this matters for
14008      // format, pass_object_size, ...).
14009      mergeDeclAttributes(PD, BaseCtor->getParamDecl(I));
14010      ParamDecls.push_back(PD);
14011      ProtoLoc.setParam(I, PD);
14012    }
14013  
14014    // Set up the new constructor.
14015    assert(!BaseCtor->isDeleted() && "should not use deleted constructor");
14016    DerivedCtor->setAccess(BaseCtor->getAccess());
14017    DerivedCtor->setParams(ParamDecls);
14018    Derived->addDecl(DerivedCtor);
14019  
14020    if (ShouldDeleteSpecialMember(DerivedCtor,
14021                                  CXXSpecialMemberKind::DefaultConstructor, &ICI))
14022      SetDeclDeleted(DerivedCtor, UsingLoc);
14023  
14024    return DerivedCtor;
14025  }
14026  
14027  void Sema::NoteDeletedInheritingConstructor(CXXConstructorDecl *Ctor) {
14028    InheritedConstructorInfo ICI(*this, Ctor->getLocation(),
14029                                 Ctor->getInheritedConstructor().getShadowDecl());
14030    ShouldDeleteSpecialMember(Ctor, CXXSpecialMemberKind::DefaultConstructor,
14031                              &ICI,
14032                              /*Diagnose*/ true);
14033  }
14034  
14035  void Sema::DefineInheritingConstructor(SourceLocation CurrentLocation,
14036                                         CXXConstructorDecl *Constructor) {
14037    CXXRecordDecl *ClassDecl = Constructor->getParent();
14038    assert(Constructor->getInheritedConstructor() &&
14039           !Constructor->doesThisDeclarationHaveABody() &&
14040           !Constructor->isDeleted());
14041    if (Constructor->willHaveBody() || Constructor->isInvalidDecl())
14042      return;
14043  
14044    // Initializations are performed "as if by a defaulted default constructor",
14045    // so enter the appropriate scope.
14046    SynthesizedFunctionScope Scope(*this, Constructor);
14047  
14048    // The exception specification is needed because we are defining the
14049    // function.
14050    ResolveExceptionSpec(CurrentLocation,
14051                         Constructor->getType()->castAs<FunctionProtoType>());
14052    MarkVTableUsed(CurrentLocation, ClassDecl);
14053  
14054    // Add a context note for diagnostics produced after this point.
14055    Scope.addContextNote(CurrentLocation);
14056  
14057    ConstructorUsingShadowDecl *Shadow =
14058        Constructor->getInheritedConstructor().getShadowDecl();
14059    CXXConstructorDecl *InheritedCtor =
14060        Constructor->getInheritedConstructor().getConstructor();
14061  
14062    // [class.inhctor.init]p1:
14063    //   initialization proceeds as if a defaulted default constructor is used to
14064    //   initialize the D object and each base class subobject from which the
14065    //   constructor was inherited
14066  
14067    InheritedConstructorInfo ICI(*this, CurrentLocation, Shadow);
14068    CXXRecordDecl *RD = Shadow->getParent();
14069    SourceLocation InitLoc = Shadow->getLocation();
14070  
14071    // Build explicit initializers for all base classes from which the
14072    // constructor was inherited.
14073    SmallVector<CXXCtorInitializer*, 8> Inits;
14074    for (bool VBase : {false, true}) {
14075      for (CXXBaseSpecifier &B : VBase ? RD->vbases() : RD->bases()) {
14076        if (B.isVirtual() != VBase)
14077          continue;
14078  
14079        auto *BaseRD = B.getType()->getAsCXXRecordDecl();
14080        if (!BaseRD)
14081          continue;
14082  
14083        auto BaseCtor = ICI.findConstructorForBase(BaseRD, InheritedCtor);
14084        if (!BaseCtor.first)
14085          continue;
14086  
14087        MarkFunctionReferenced(CurrentLocation, BaseCtor.first);
14088        ExprResult Init = new (Context) CXXInheritedCtorInitExpr(
14089            InitLoc, B.getType(), BaseCtor.first, VBase, BaseCtor.second);
14090  
14091        auto *TInfo = Context.getTrivialTypeSourceInfo(B.getType(), InitLoc);
14092        Inits.push_back(new (Context) CXXCtorInitializer(
14093            Context, TInfo, VBase, InitLoc, Init.get(), InitLoc,
14094            SourceLocation()));
14095      }
14096    }
14097  
14098    // We now proceed as if for a defaulted default constructor, with the relevant
14099    // initializers replaced.
14100  
14101    if (SetCtorInitializers(Constructor, /*AnyErrors*/false, Inits)) {
14102      Constructor->setInvalidDecl();
14103      return;
14104    }
14105  
14106    Constructor->setBody(new (Context) CompoundStmt(InitLoc));
14107    Constructor->markUsed(Context);
14108  
14109    if (ASTMutationListener *L = getASTMutationListener()) {
14110      L->CompletedImplicitDefinition(Constructor);
14111    }
14112  
14113    DiagnoseUninitializedFields(*this, Constructor);
14114  }
14115  
14116  CXXDestructorDecl *Sema::DeclareImplicitDestructor(CXXRecordDecl *ClassDecl) {
14117    // C++ [class.dtor]p2:
14118    //   If a class has no user-declared destructor, a destructor is
14119    //   declared implicitly. An implicitly-declared destructor is an
14120    //   inline public member of its class.
14121    assert(ClassDecl->needsImplicitDestructor());
14122  
14123    DeclaringSpecialMember DSM(*this, ClassDecl,
14124                               CXXSpecialMemberKind::Destructor);
14125    if (DSM.isAlreadyBeingDeclared())
14126      return nullptr;
14127  
14128    bool Constexpr = defaultedSpecialMemberIsConstexpr(
14129        *this, ClassDecl, CXXSpecialMemberKind::Destructor, false);
14130  
14131    // Create the actual destructor declaration.
14132    CanQualType ClassType
14133      = Context.getCanonicalType(Context.getTypeDeclType(ClassDecl));
14134    SourceLocation ClassLoc = ClassDecl->getLocation();
14135    DeclarationName Name
14136      = Context.DeclarationNames.getCXXDestructorName(ClassType);
14137    DeclarationNameInfo NameInfo(Name, ClassLoc);
14138    CXXDestructorDecl *Destructor = CXXDestructorDecl::Create(
14139        Context, ClassDecl, ClassLoc, NameInfo, QualType(), nullptr,
14140        getCurFPFeatures().isFPConstrained(),
14141        /*isInline=*/true,
14142        /*isImplicitlyDeclared=*/true,
14143        Constexpr ? ConstexprSpecKind::Constexpr
14144                  : ConstexprSpecKind::Unspecified);
14145    Destructor->setAccess(AS_public);
14146    Destructor->setDefaulted();
14147  
14148    setupImplicitSpecialMemberType(Destructor, Context.VoidTy, std::nullopt);
14149  
14150    if (getLangOpts().CUDA)
14151      CUDA().inferTargetForImplicitSpecialMember(
14152          ClassDecl, CXXSpecialMemberKind::Destructor, Destructor,
14153          /* ConstRHS */ false,
14154          /* Diagnose */ false);
14155  
14156    // We don't need to use SpecialMemberIsTrivial here; triviality for
14157    // destructors is easy to compute.
14158    Destructor->setTrivial(ClassDecl->hasTrivialDestructor());
14159    Destructor->setTrivialForCall(ClassDecl->hasAttr<TrivialABIAttr>() ||
14160                                  ClassDecl->hasTrivialDestructorForCall());
14161  
14162    // Note that we have declared this destructor.
14163    ++getASTContext().NumImplicitDestructorsDeclared;
14164  
14165    Scope *S = getScopeForContext(ClassDecl);
14166    CheckImplicitSpecialMemberDeclaration(S, Destructor);
14167  
14168    // We can't check whether an implicit destructor is deleted before we complete
14169    // the definition of the class, because its validity depends on the alignment
14170    // of the class. We'll check this from ActOnFields once the class is complete.
14171    if (ClassDecl->isCompleteDefinition() &&
14172        ShouldDeleteSpecialMember(Destructor, CXXSpecialMemberKind::Destructor))
14173      SetDeclDeleted(Destructor, ClassLoc);
14174  
14175    // Introduce this destructor into its scope.
14176    if (S)
14177      PushOnScopeChains(Destructor, S, false);
14178    ClassDecl->addDecl(Destructor);
14179  
14180    return Destructor;
14181  }
14182  
14183  void Sema::DefineImplicitDestructor(SourceLocation CurrentLocation,
14184                                      CXXDestructorDecl *Destructor) {
14185    assert((Destructor->isDefaulted() &&
14186            !Destructor->doesThisDeclarationHaveABody() &&
14187            !Destructor->isDeleted()) &&
14188           "DefineImplicitDestructor - call it for implicit default dtor");
14189    if (Destructor->willHaveBody() || Destructor->isInvalidDecl())
14190      return;
14191  
14192    CXXRecordDecl *ClassDecl = Destructor->getParent();
14193    assert(ClassDecl && "DefineImplicitDestructor - invalid destructor");
14194  
14195    SynthesizedFunctionScope Scope(*this, Destructor);
14196  
14197    // The exception specification is needed because we are defining the
14198    // function.
14199    ResolveExceptionSpec(CurrentLocation,
14200                         Destructor->getType()->castAs<FunctionProtoType>());
14201    MarkVTableUsed(CurrentLocation, ClassDecl);
14202  
14203    // Add a context note for diagnostics produced after this point.
14204    Scope.addContextNote(CurrentLocation);
14205  
14206    MarkBaseAndMemberDestructorsReferenced(Destructor->getLocation(),
14207                                           Destructor->getParent());
14208  
14209    if (CheckDestructor(Destructor)) {
14210      Destructor->setInvalidDecl();
14211      return;
14212    }
14213  
14214    SourceLocation Loc = Destructor->getEndLoc().isValid()
14215                             ? Destructor->getEndLoc()
14216                             : Destructor->getLocation();
14217    Destructor->setBody(new (Context) CompoundStmt(Loc));
14218    Destructor->markUsed(Context);
14219  
14220    if (ASTMutationListener *L = getASTMutationListener()) {
14221      L->CompletedImplicitDefinition(Destructor);
14222    }
14223  }
14224  
14225  void Sema::CheckCompleteDestructorVariant(SourceLocation CurrentLocation,
14226                                            CXXDestructorDecl *Destructor) {
14227    if (Destructor->isInvalidDecl())
14228      return;
14229  
14230    CXXRecordDecl *ClassDecl = Destructor->getParent();
14231    assert(Context.getTargetInfo().getCXXABI().isMicrosoft() &&
14232           "implicit complete dtors unneeded outside MS ABI");
14233    assert(ClassDecl->getNumVBases() > 0 &&
14234           "complete dtor only exists for classes with vbases");
14235  
14236    SynthesizedFunctionScope Scope(*this, Destructor);
14237  
14238    // Add a context note for diagnostics produced after this point.
14239    Scope.addContextNote(CurrentLocation);
14240  
14241    MarkVirtualBaseDestructorsReferenced(Destructor->getLocation(), ClassDecl);
14242  }
14243  
14244  void Sema::ActOnFinishCXXMemberDecls() {
14245    // If the context is an invalid C++ class, just suppress these checks.
14246    if (CXXRecordDecl *Record = dyn_cast<CXXRecordDecl>(CurContext)) {
14247      if (Record->isInvalidDecl()) {
14248        DelayedOverridingExceptionSpecChecks.clear();
14249        DelayedEquivalentExceptionSpecChecks.clear();
14250        return;
14251      }
14252      checkForMultipleExportedDefaultConstructors(*this, Record);
14253    }
14254  }
14255  
14256  void Sema::ActOnFinishCXXNonNestedClass() {
14257    referenceDLLExportedClassMethods();
14258  
14259    if (!DelayedDllExportMemberFunctions.empty()) {
14260      SmallVector<CXXMethodDecl*, 4> WorkList;
14261      std::swap(DelayedDllExportMemberFunctions, WorkList);
14262      for (CXXMethodDecl *M : WorkList) {
14263        DefineDefaultedFunction(*this, M, M->getLocation());
14264  
14265        // Pass the method to the consumer to get emitted. This is not necessary
14266        // for explicit instantiation definitions, as they will get emitted
14267        // anyway.
14268        if (M->getParent()->getTemplateSpecializationKind() !=
14269            TSK_ExplicitInstantiationDefinition)
14270          ActOnFinishInlineFunctionDef(M);
14271      }
14272    }
14273  }
14274  
14275  void Sema::referenceDLLExportedClassMethods() {
14276    if (!DelayedDllExportClasses.empty()) {
14277      // Calling ReferenceDllExportedMembers might cause the current function to
14278      // be called again, so use a local copy of DelayedDllExportClasses.
14279      SmallVector<CXXRecordDecl *, 4> WorkList;
14280      std::swap(DelayedDllExportClasses, WorkList);
14281      for (CXXRecordDecl *Class : WorkList)
14282        ReferenceDllExportedMembers(*this, Class);
14283    }
14284  }
14285  
14286  void Sema::AdjustDestructorExceptionSpec(CXXDestructorDecl *Destructor) {
14287    assert(getLangOpts().CPlusPlus11 &&
14288           "adjusting dtor exception specs was introduced in c++11");
14289  
14290    if (Destructor->isDependentContext())
14291      return;
14292  
14293    // C++11 [class.dtor]p3:
14294    //   A declaration of a destructor that does not have an exception-
14295    //   specification is implicitly considered to have the same exception-
14296    //   specification as an implicit declaration.
14297    const auto *DtorType = Destructor->getType()->castAs<FunctionProtoType>();
14298    if (DtorType->hasExceptionSpec())
14299      return;
14300  
14301    // Replace the destructor's type, building off the existing one. Fortunately,
14302    // the only thing of interest in the destructor type is its extended info.
14303    // The return and arguments are fixed.
14304    FunctionProtoType::ExtProtoInfo EPI = DtorType->getExtProtoInfo();
14305    EPI.ExceptionSpec.Type = EST_Unevaluated;
14306    EPI.ExceptionSpec.SourceDecl = Destructor;
14307    Destructor->setType(
14308        Context.getFunctionType(Context.VoidTy, std::nullopt, EPI));
14309  
14310    // FIXME: If the destructor has a body that could throw, and the newly created
14311    // spec doesn't allow exceptions, we should emit a warning, because this
14312    // change in behavior can break conforming C++03 programs at runtime.
14313    // However, we don't have a body or an exception specification yet, so it
14314    // needs to be done somewhere else.
14315  }
14316  
14317  namespace {
14318  /// An abstract base class for all helper classes used in building the
14319  //  copy/move operators. These classes serve as factory functions and help us
14320  //  avoid using the same Expr* in the AST twice.
14321  class ExprBuilder {
14322    ExprBuilder(const ExprBuilder&) = delete;
14323    ExprBuilder &operator=(const ExprBuilder&) = delete;
14324  
14325  protected:
14326    static Expr *assertNotNull(Expr *E) {
14327      assert(E && "Expression construction must not fail.");
14328      return E;
14329    }
14330  
14331  public:
14332    ExprBuilder() {}
14333    virtual ~ExprBuilder() {}
14334  
14335    virtual Expr *build(Sema &S, SourceLocation Loc) const = 0;
14336  };
14337  
14338  class RefBuilder: public ExprBuilder {
14339    VarDecl *Var;
14340    QualType VarType;
14341  
14342  public:
14343    Expr *build(Sema &S, SourceLocation Loc) const override {
14344      return assertNotNull(S.BuildDeclRefExpr(Var, VarType, VK_LValue, Loc));
14345    }
14346  
14347    RefBuilder(VarDecl *Var, QualType VarType)
14348        : Var(Var), VarType(VarType) {}
14349  };
14350  
14351  class ThisBuilder: public ExprBuilder {
14352  public:
14353    Expr *build(Sema &S, SourceLocation Loc) const override {
14354      return assertNotNull(S.ActOnCXXThis(Loc).getAs<Expr>());
14355    }
14356  };
14357  
14358  class CastBuilder: public ExprBuilder {
14359    const ExprBuilder &Builder;
14360    QualType Type;
14361    ExprValueKind Kind;
14362    const CXXCastPath &Path;
14363  
14364  public:
14365    Expr *build(Sema &S, SourceLocation Loc) const override {
14366      return assertNotNull(S.ImpCastExprToType(Builder.build(S, Loc), Type,
14367                                               CK_UncheckedDerivedToBase, Kind,
14368                                               &Path).get());
14369    }
14370  
14371    CastBuilder(const ExprBuilder &Builder, QualType Type, ExprValueKind Kind,
14372                const CXXCastPath &Path)
14373        : Builder(Builder), Type(Type), Kind(Kind), Path(Path) {}
14374  };
14375  
14376  class DerefBuilder: public ExprBuilder {
14377    const ExprBuilder &Builder;
14378  
14379  public:
14380    Expr *build(Sema &S, SourceLocation Loc) const override {
14381      return assertNotNull(
14382          S.CreateBuiltinUnaryOp(Loc, UO_Deref, Builder.build(S, Loc)).get());
14383    }
14384  
14385    DerefBuilder(const ExprBuilder &Builder) : Builder(Builder) {}
14386  };
14387  
14388  class MemberBuilder: public ExprBuilder {
14389    const ExprBuilder &Builder;
14390    QualType Type;
14391    CXXScopeSpec SS;
14392    bool IsArrow;
14393    LookupResult &MemberLookup;
14394  
14395  public:
14396    Expr *build(Sema &S, SourceLocation Loc) const override {
14397      return assertNotNull(S.BuildMemberReferenceExpr(
14398          Builder.build(S, Loc), Type, Loc, IsArrow, SS, SourceLocation(),
14399          nullptr, MemberLookup, nullptr, nullptr).get());
14400    }
14401  
14402    MemberBuilder(const ExprBuilder &Builder, QualType Type, bool IsArrow,
14403                  LookupResult &MemberLookup)
14404        : Builder(Builder), Type(Type), IsArrow(IsArrow),
14405          MemberLookup(MemberLookup) {}
14406  };
14407  
14408  class MoveCastBuilder: public ExprBuilder {
14409    const ExprBuilder &Builder;
14410  
14411  public:
14412    Expr *build(Sema &S, SourceLocation Loc) const override {
14413      return assertNotNull(CastForMoving(S, Builder.build(S, Loc)));
14414    }
14415  
14416    MoveCastBuilder(const ExprBuilder &Builder) : Builder(Builder) {}
14417  };
14418  
14419  class LvalueConvBuilder: public ExprBuilder {
14420    const ExprBuilder &Builder;
14421  
14422  public:
14423    Expr *build(Sema &S, SourceLocation Loc) const override {
14424      return assertNotNull(
14425          S.DefaultLvalueConversion(Builder.build(S, Loc)).get());
14426    }
14427  
14428    LvalueConvBuilder(const ExprBuilder &Builder) : Builder(Builder) {}
14429  };
14430  
14431  class SubscriptBuilder: public ExprBuilder {
14432    const ExprBuilder &Base;
14433    const ExprBuilder &Index;
14434  
14435  public:
14436    Expr *build(Sema &S, SourceLocation Loc) const override {
14437      return assertNotNull(S.CreateBuiltinArraySubscriptExpr(
14438          Base.build(S, Loc), Loc, Index.build(S, Loc), Loc).get());
14439    }
14440  
14441    SubscriptBuilder(const ExprBuilder &Base, const ExprBuilder &Index)
14442        : Base(Base), Index(Index) {}
14443  };
14444  
14445  } // end anonymous namespace
14446  
14447  /// When generating a defaulted copy or move assignment operator, if a field
14448  /// should be copied with __builtin_memcpy rather than via explicit assignments,
14449  /// do so. This optimization only applies for arrays of scalars, and for arrays
14450  /// of class type where the selected copy/move-assignment operator is trivial.
14451  static StmtResult
14452  buildMemcpyForAssignmentOp(Sema &S, SourceLocation Loc, QualType T,
14453                             const ExprBuilder &ToB, const ExprBuilder &FromB) {
14454    // Compute the size of the memory buffer to be copied.
14455    QualType SizeType = S.Context.getSizeType();
14456    llvm::APInt Size(S.Context.getTypeSize(SizeType),
14457                     S.Context.getTypeSizeInChars(T).getQuantity());
14458  
14459    // Take the address of the field references for "from" and "to". We
14460    // directly construct UnaryOperators here because semantic analysis
14461    // does not permit us to take the address of an xvalue.
14462    Expr *From = FromB.build(S, Loc);
14463    From = UnaryOperator::Create(
14464        S.Context, From, UO_AddrOf, S.Context.getPointerType(From->getType()),
14465        VK_PRValue, OK_Ordinary, Loc, false, S.CurFPFeatureOverrides());
14466    Expr *To = ToB.build(S, Loc);
14467    To = UnaryOperator::Create(
14468        S.Context, To, UO_AddrOf, S.Context.getPointerType(To->getType()),
14469        VK_PRValue, OK_Ordinary, Loc, false, S.CurFPFeatureOverrides());
14470  
14471    const Type *E = T->getBaseElementTypeUnsafe();
14472    bool NeedsCollectableMemCpy =
14473        E->isRecordType() &&
14474        E->castAs<RecordType>()->getDecl()->hasObjectMember();
14475  
14476    // Create a reference to the __builtin_objc_memmove_collectable function
14477    StringRef MemCpyName = NeedsCollectableMemCpy ?
14478      "__builtin_objc_memmove_collectable" :
14479      "__builtin_memcpy";
14480    LookupResult R(S, &S.Context.Idents.get(MemCpyName), Loc,
14481                   Sema::LookupOrdinaryName);
14482    S.LookupName(R, S.TUScope, true);
14483  
14484    FunctionDecl *MemCpy = R.getAsSingle<FunctionDecl>();
14485    if (!MemCpy)
14486      // Something went horribly wrong earlier, and we will have complained
14487      // about it.
14488      return StmtError();
14489  
14490    ExprResult MemCpyRef = S.BuildDeclRefExpr(MemCpy, S.Context.BuiltinFnTy,
14491                                              VK_PRValue, Loc, nullptr);
14492    assert(MemCpyRef.isUsable() && "Builtin reference cannot fail");
14493  
14494    Expr *CallArgs[] = {
14495      To, From, IntegerLiteral::Create(S.Context, Size, SizeType, Loc)
14496    };
14497    ExprResult Call = S.BuildCallExpr(/*Scope=*/nullptr, MemCpyRef.get(),
14498                                      Loc, CallArgs, Loc);
14499  
14500    assert(!Call.isInvalid() && "Call to __builtin_memcpy cannot fail!");
14501    return Call.getAs<Stmt>();
14502  }
14503  
14504  /// Builds a statement that copies/moves the given entity from \p From to
14505  /// \c To.
14506  ///
14507  /// This routine is used to copy/move the members of a class with an
14508  /// implicitly-declared copy/move assignment operator. When the entities being
14509  /// copied are arrays, this routine builds for loops to copy them.
14510  ///
14511  /// \param S The Sema object used for type-checking.
14512  ///
14513  /// \param Loc The location where the implicit copy/move is being generated.
14514  ///
14515  /// \param T The type of the expressions being copied/moved. Both expressions
14516  /// must have this type.
14517  ///
14518  /// \param To The expression we are copying/moving to.
14519  ///
14520  /// \param From The expression we are copying/moving from.
14521  ///
14522  /// \param CopyingBaseSubobject Whether we're copying/moving a base subobject.
14523  /// Otherwise, it's a non-static member subobject.
14524  ///
14525  /// \param Copying Whether we're copying or moving.
14526  ///
14527  /// \param Depth Internal parameter recording the depth of the recursion.
14528  ///
14529  /// \returns A statement or a loop that copies the expressions, or StmtResult(0)
14530  /// if a memcpy should be used instead.
14531  static StmtResult
14532  buildSingleCopyAssignRecursively(Sema &S, SourceLocation Loc, QualType T,
14533                                   const ExprBuilder &To, const ExprBuilder &From,
14534                                   bool CopyingBaseSubobject, bool Copying,
14535                                   unsigned Depth = 0) {
14536    // C++11 [class.copy]p28:
14537    //   Each subobject is assigned in the manner appropriate to its type:
14538    //
14539    //     - if the subobject is of class type, as if by a call to operator= with
14540    //       the subobject as the object expression and the corresponding
14541    //       subobject of x as a single function argument (as if by explicit
14542    //       qualification; that is, ignoring any possible virtual overriding
14543    //       functions in more derived classes);
14544    //
14545    // C++03 [class.copy]p13:
14546    //     - if the subobject is of class type, the copy assignment operator for
14547    //       the class is used (as if by explicit qualification; that is,
14548    //       ignoring any possible virtual overriding functions in more derived
14549    //       classes);
14550    if (const RecordType *RecordTy = T->getAs<RecordType>()) {
14551      CXXRecordDecl *ClassDecl = cast<CXXRecordDecl>(RecordTy->getDecl());
14552  
14553      // Look for operator=.
14554      DeclarationName Name
14555        = S.Context.DeclarationNames.getCXXOperatorName(OO_Equal);
14556      LookupResult OpLookup(S, Name, Loc, Sema::LookupOrdinaryName);
14557      S.LookupQualifiedName(OpLookup, ClassDecl, false);
14558  
14559      // Prior to C++11, filter out any result that isn't a copy/move-assignment
14560      // operator.
14561      if (!S.getLangOpts().CPlusPlus11) {
14562        LookupResult::Filter F = OpLookup.makeFilter();
14563        while (F.hasNext()) {
14564          NamedDecl *D = F.next();
14565          if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(D))
14566            if (Method->isCopyAssignmentOperator() ||
14567                (!Copying && Method->isMoveAssignmentOperator()))
14568              continue;
14569  
14570          F.erase();
14571        }
14572        F.done();
14573      }
14574  
14575      // Suppress the protected check (C++ [class.protected]) for each of the
14576      // assignment operators we found. This strange dance is required when
14577      // we're assigning via a base classes's copy-assignment operator. To
14578      // ensure that we're getting the right base class subobject (without
14579      // ambiguities), we need to cast "this" to that subobject type; to
14580      // ensure that we don't go through the virtual call mechanism, we need
14581      // to qualify the operator= name with the base class (see below). However,
14582      // this means that if the base class has a protected copy assignment
14583      // operator, the protected member access check will fail. So, we
14584      // rewrite "protected" access to "public" access in this case, since we
14585      // know by construction that we're calling from a derived class.
14586      if (CopyingBaseSubobject) {
14587        for (LookupResult::iterator L = OpLookup.begin(), LEnd = OpLookup.end();
14588             L != LEnd; ++L) {
14589          if (L.getAccess() == AS_protected)
14590            L.setAccess(AS_public);
14591        }
14592      }
14593  
14594      // Create the nested-name-specifier that will be used to qualify the
14595      // reference to operator=; this is required to suppress the virtual
14596      // call mechanism.
14597      CXXScopeSpec SS;
14598      const Type *CanonicalT = S.Context.getCanonicalType(T.getTypePtr());
14599      SS.MakeTrivial(S.Context,
14600                     NestedNameSpecifier::Create(S.Context, nullptr, false,
14601                                                 CanonicalT),
14602                     Loc);
14603  
14604      // Create the reference to operator=.
14605      ExprResult OpEqualRef
14606        = S.BuildMemberReferenceExpr(To.build(S, Loc), T, Loc, /*IsArrow=*/false,
14607                                     SS, /*TemplateKWLoc=*/SourceLocation(),
14608                                     /*FirstQualifierInScope=*/nullptr,
14609                                     OpLookup,
14610                                     /*TemplateArgs=*/nullptr, /*S*/nullptr,
14611                                     /*SuppressQualifierCheck=*/true);
14612      if (OpEqualRef.isInvalid())
14613        return StmtError();
14614  
14615      // Build the call to the assignment operator.
14616  
14617      Expr *FromInst = From.build(S, Loc);
14618      ExprResult Call = S.BuildCallToMemberFunction(/*Scope=*/nullptr,
14619                                                    OpEqualRef.getAs<Expr>(),
14620                                                    Loc, FromInst, Loc);
14621      if (Call.isInvalid())
14622        return StmtError();
14623  
14624      // If we built a call to a trivial 'operator=' while copying an array,
14625      // bail out. We'll replace the whole shebang with a memcpy.
14626      CXXMemberCallExpr *CE = dyn_cast<CXXMemberCallExpr>(Call.get());
14627      if (CE && CE->getMethodDecl()->isTrivial() && Depth)
14628        return StmtResult((Stmt*)nullptr);
14629  
14630      // Convert to an expression-statement, and clean up any produced
14631      // temporaries.
14632      return S.ActOnExprStmt(Call);
14633    }
14634  
14635    //     - if the subobject is of scalar type, the built-in assignment
14636    //       operator is used.
14637    const ConstantArrayType *ArrayTy = S.Context.getAsConstantArrayType(T);
14638    if (!ArrayTy) {
14639      ExprResult Assignment = S.CreateBuiltinBinOp(
14640          Loc, BO_Assign, To.build(S, Loc), From.build(S, Loc));
14641      if (Assignment.isInvalid())
14642        return StmtError();
14643      return S.ActOnExprStmt(Assignment);
14644    }
14645  
14646    //     - if the subobject is an array, each element is assigned, in the
14647    //       manner appropriate to the element type;
14648  
14649    // Construct a loop over the array bounds, e.g.,
14650    //
14651    //   for (__SIZE_TYPE__ i0 = 0; i0 != array-size; ++i0)
14652    //
14653    // that will copy each of the array elements.
14654    QualType SizeType = S.Context.getSizeType();
14655  
14656    // Create the iteration variable.
14657    IdentifierInfo *IterationVarName = nullptr;
14658    {
14659      SmallString<8> Str;
14660      llvm::raw_svector_ostream OS(Str);
14661      OS << "__i" << Depth;
14662      IterationVarName = &S.Context.Idents.get(OS.str());
14663    }
14664    VarDecl *IterationVar = VarDecl::Create(S.Context, S.CurContext, Loc, Loc,
14665                                            IterationVarName, SizeType,
14666                              S.Context.getTrivialTypeSourceInfo(SizeType, Loc),
14667                                            SC_None);
14668  
14669    // Initialize the iteration variable to zero.
14670    llvm::APInt Zero(S.Context.getTypeSize(SizeType), 0);
14671    IterationVar->setInit(IntegerLiteral::Create(S.Context, Zero, SizeType, Loc));
14672  
14673    // Creates a reference to the iteration variable.
14674    RefBuilder IterationVarRef(IterationVar, SizeType);
14675    LvalueConvBuilder IterationVarRefRVal(IterationVarRef);
14676  
14677    // Create the DeclStmt that holds the iteration variable.
14678    Stmt *InitStmt = new (S.Context) DeclStmt(DeclGroupRef(IterationVar),Loc,Loc);
14679  
14680    // Subscript the "from" and "to" expressions with the iteration variable.
14681    SubscriptBuilder FromIndexCopy(From, IterationVarRefRVal);
14682    MoveCastBuilder FromIndexMove(FromIndexCopy);
14683    const ExprBuilder *FromIndex;
14684    if (Copying)
14685      FromIndex = &FromIndexCopy;
14686    else
14687      FromIndex = &FromIndexMove;
14688  
14689    SubscriptBuilder ToIndex(To, IterationVarRefRVal);
14690  
14691    // Build the copy/move for an individual element of the array.
14692    StmtResult Copy =
14693      buildSingleCopyAssignRecursively(S, Loc, ArrayTy->getElementType(),
14694                                       ToIndex, *FromIndex, CopyingBaseSubobject,
14695                                       Copying, Depth + 1);
14696    // Bail out if copying fails or if we determined that we should use memcpy.
14697    if (Copy.isInvalid() || !Copy.get())
14698      return Copy;
14699  
14700    // Create the comparison against the array bound.
14701    llvm::APInt Upper
14702      = ArrayTy->getSize().zextOrTrunc(S.Context.getTypeSize(SizeType));
14703    Expr *Comparison = BinaryOperator::Create(
14704        S.Context, IterationVarRefRVal.build(S, Loc),
14705        IntegerLiteral::Create(S.Context, Upper, SizeType, Loc), BO_NE,
14706        S.Context.BoolTy, VK_PRValue, OK_Ordinary, Loc,
14707        S.CurFPFeatureOverrides());
14708  
14709    // Create the pre-increment of the iteration variable. We can determine
14710    // whether the increment will overflow based on the value of the array
14711    // bound.
14712    Expr *Increment = UnaryOperator::Create(
14713        S.Context, IterationVarRef.build(S, Loc), UO_PreInc, SizeType, VK_LValue,
14714        OK_Ordinary, Loc, Upper.isMaxValue(), S.CurFPFeatureOverrides());
14715  
14716    // Construct the loop that copies all elements of this array.
14717    return S.ActOnForStmt(
14718        Loc, Loc, InitStmt,
14719        S.ActOnCondition(nullptr, Loc, Comparison, Sema::ConditionKind::Boolean),
14720        S.MakeFullDiscardedValueExpr(Increment), Loc, Copy.get());
14721  }
14722  
14723  static StmtResult
14724  buildSingleCopyAssign(Sema &S, SourceLocation Loc, QualType T,
14725                        const ExprBuilder &To, const ExprBuilder &From,
14726                        bool CopyingBaseSubobject, bool Copying) {
14727    // Maybe we should use a memcpy?
14728    if (T->isArrayType() && !T.isConstQualified() && !T.isVolatileQualified() &&
14729        T.isTriviallyCopyableType(S.Context))
14730      return buildMemcpyForAssignmentOp(S, Loc, T, To, From);
14731  
14732    StmtResult Result(buildSingleCopyAssignRecursively(S, Loc, T, To, From,
14733                                                       CopyingBaseSubobject,
14734                                                       Copying, 0));
14735  
14736    // If we ended up picking a trivial assignment operator for an array of a
14737    // non-trivially-copyable class type, just emit a memcpy.
14738    if (!Result.isInvalid() && !Result.get())
14739      return buildMemcpyForAssignmentOp(S, Loc, T, To, From);
14740  
14741    return Result;
14742  }
14743  
14744  CXXMethodDecl *Sema::DeclareImplicitCopyAssignment(CXXRecordDecl *ClassDecl) {
14745    // Note: The following rules are largely analoguous to the copy
14746    // constructor rules. Note that virtual bases are not taken into account
14747    // for determining the argument type of the operator. Note also that
14748    // operators taking an object instead of a reference are allowed.
14749    assert(ClassDecl->needsImplicitCopyAssignment());
14750  
14751    DeclaringSpecialMember DSM(*this, ClassDecl,
14752                               CXXSpecialMemberKind::CopyAssignment);
14753    if (DSM.isAlreadyBeingDeclared())
14754      return nullptr;
14755  
14756    QualType ArgType = Context.getTypeDeclType(ClassDecl);
14757    ArgType = Context.getElaboratedType(ElaboratedTypeKeyword::None, nullptr,
14758                                        ArgType, nullptr);
14759    LangAS AS = getDefaultCXXMethodAddrSpace();
14760    if (AS != LangAS::Default)
14761      ArgType = Context.getAddrSpaceQualType(ArgType, AS);
14762    QualType RetType = Context.getLValueReferenceType(ArgType);
14763    bool Const = ClassDecl->implicitCopyAssignmentHasConstParam();
14764    if (Const)
14765      ArgType = ArgType.withConst();
14766  
14767    ArgType = Context.getLValueReferenceType(ArgType);
14768  
14769    bool Constexpr = defaultedSpecialMemberIsConstexpr(
14770        *this, ClassDecl, CXXSpecialMemberKind::CopyAssignment, Const);
14771  
14772    //   An implicitly-declared copy assignment operator is an inline public
14773    //   member of its class.
14774    DeclarationName Name = Context.DeclarationNames.getCXXOperatorName(OO_Equal);
14775    SourceLocation ClassLoc = ClassDecl->getLocation();
14776    DeclarationNameInfo NameInfo(Name, ClassLoc);
14777    CXXMethodDecl *CopyAssignment = CXXMethodDecl::Create(
14778        Context, ClassDecl, ClassLoc, NameInfo, QualType(),
14779        /*TInfo=*/nullptr, /*StorageClass=*/SC_None,
14780        getCurFPFeatures().isFPConstrained(),
14781        /*isInline=*/true,
14782        Constexpr ? ConstexprSpecKind::Constexpr : ConstexprSpecKind::Unspecified,
14783        SourceLocation());
14784    CopyAssignment->setAccess(AS_public);
14785    CopyAssignment->setDefaulted();
14786    CopyAssignment->setImplicit();
14787  
14788    setupImplicitSpecialMemberType(CopyAssignment, RetType, ArgType);
14789  
14790    if (getLangOpts().CUDA)
14791      CUDA().inferTargetForImplicitSpecialMember(
14792          ClassDecl, CXXSpecialMemberKind::CopyAssignment, CopyAssignment,
14793          /* ConstRHS */ Const,
14794          /* Diagnose */ false);
14795  
14796    // Add the parameter to the operator.
14797    ParmVarDecl *FromParam = ParmVarDecl::Create(Context, CopyAssignment,
14798                                                 ClassLoc, ClassLoc,
14799                                                 /*Id=*/nullptr, ArgType,
14800                                                 /*TInfo=*/nullptr, SC_None,
14801                                                 nullptr);
14802    CopyAssignment->setParams(FromParam);
14803  
14804    CopyAssignment->setTrivial(
14805        ClassDecl->needsOverloadResolutionForCopyAssignment()
14806            ? SpecialMemberIsTrivial(CopyAssignment,
14807                                     CXXSpecialMemberKind::CopyAssignment)
14808            : ClassDecl->hasTrivialCopyAssignment());
14809  
14810    // Note that we have added this copy-assignment operator.
14811    ++getASTContext().NumImplicitCopyAssignmentOperatorsDeclared;
14812  
14813    Scope *S = getScopeForContext(ClassDecl);
14814    CheckImplicitSpecialMemberDeclaration(S, CopyAssignment);
14815  
14816    if (ShouldDeleteSpecialMember(CopyAssignment,
14817                                  CXXSpecialMemberKind::CopyAssignment)) {
14818      ClassDecl->setImplicitCopyAssignmentIsDeleted();
14819      SetDeclDeleted(CopyAssignment, ClassLoc);
14820    }
14821  
14822    if (S)
14823      PushOnScopeChains(CopyAssignment, S, false);
14824    ClassDecl->addDecl(CopyAssignment);
14825  
14826    return CopyAssignment;
14827  }
14828  
14829  /// Diagnose an implicit copy operation for a class which is odr-used, but
14830  /// which is deprecated because the class has a user-declared copy constructor,
14831  /// copy assignment operator, or destructor.
14832  static void diagnoseDeprecatedCopyOperation(Sema &S, CXXMethodDecl *CopyOp) {
14833    assert(CopyOp->isImplicit());
14834  
14835    CXXRecordDecl *RD = CopyOp->getParent();
14836    CXXMethodDecl *UserDeclaredOperation = nullptr;
14837  
14838    if (RD->hasUserDeclaredDestructor()) {
14839      UserDeclaredOperation = RD->getDestructor();
14840    } else if (!isa<CXXConstructorDecl>(CopyOp) &&
14841               RD->hasUserDeclaredCopyConstructor()) {
14842      // Find any user-declared copy constructor.
14843      for (auto *I : RD->ctors()) {
14844        if (I->isCopyConstructor()) {
14845          UserDeclaredOperation = I;
14846          break;
14847        }
14848      }
14849      assert(UserDeclaredOperation);
14850    } else if (isa<CXXConstructorDecl>(CopyOp) &&
14851               RD->hasUserDeclaredCopyAssignment()) {
14852      // Find any user-declared move assignment operator.
14853      for (auto *I : RD->methods()) {
14854        if (I->isCopyAssignmentOperator()) {
14855          UserDeclaredOperation = I;
14856          break;
14857        }
14858      }
14859      assert(UserDeclaredOperation);
14860    }
14861  
14862    if (UserDeclaredOperation) {
14863      bool UDOIsUserProvided = UserDeclaredOperation->isUserProvided();
14864      bool UDOIsDestructor = isa<CXXDestructorDecl>(UserDeclaredOperation);
14865      bool IsCopyAssignment = !isa<CXXConstructorDecl>(CopyOp);
14866      unsigned DiagID =
14867          (UDOIsUserProvided && UDOIsDestructor)
14868              ? diag::warn_deprecated_copy_with_user_provided_dtor
14869          : (UDOIsUserProvided && !UDOIsDestructor)
14870              ? diag::warn_deprecated_copy_with_user_provided_copy
14871          : (!UDOIsUserProvided && UDOIsDestructor)
14872              ? diag::warn_deprecated_copy_with_dtor
14873              : diag::warn_deprecated_copy;
14874      S.Diag(UserDeclaredOperation->getLocation(), DiagID)
14875          << RD << IsCopyAssignment;
14876    }
14877  }
14878  
14879  void Sema::DefineImplicitCopyAssignment(SourceLocation CurrentLocation,
14880                                          CXXMethodDecl *CopyAssignOperator) {
14881    assert((CopyAssignOperator->isDefaulted() &&
14882            CopyAssignOperator->isOverloadedOperator() &&
14883            CopyAssignOperator->getOverloadedOperator() == OO_Equal &&
14884            !CopyAssignOperator->doesThisDeclarationHaveABody() &&
14885            !CopyAssignOperator->isDeleted()) &&
14886           "DefineImplicitCopyAssignment called for wrong function");
14887    if (CopyAssignOperator->willHaveBody() || CopyAssignOperator->isInvalidDecl())
14888      return;
14889  
14890    CXXRecordDecl *ClassDecl = CopyAssignOperator->getParent();
14891    if (ClassDecl->isInvalidDecl()) {
14892      CopyAssignOperator->setInvalidDecl();
14893      return;
14894    }
14895  
14896    SynthesizedFunctionScope Scope(*this, CopyAssignOperator);
14897  
14898    // The exception specification is needed because we are defining the
14899    // function.
14900    ResolveExceptionSpec(CurrentLocation,
14901                         CopyAssignOperator->getType()->castAs<FunctionProtoType>());
14902  
14903    // Add a context note for diagnostics produced after this point.
14904    Scope.addContextNote(CurrentLocation);
14905  
14906    // C++11 [class.copy]p18:
14907    //   The [definition of an implicitly declared copy assignment operator] is
14908    //   deprecated if the class has a user-declared copy constructor or a
14909    //   user-declared destructor.
14910    if (getLangOpts().CPlusPlus11 && CopyAssignOperator->isImplicit())
14911      diagnoseDeprecatedCopyOperation(*this, CopyAssignOperator);
14912  
14913    // C++0x [class.copy]p30:
14914    //   The implicitly-defined or explicitly-defaulted copy assignment operator
14915    //   for a non-union class X performs memberwise copy assignment of its
14916    //   subobjects. The direct base classes of X are assigned first, in the
14917    //   order of their declaration in the base-specifier-list, and then the
14918    //   immediate non-static data members of X are assigned, in the order in
14919    //   which they were declared in the class definition.
14920  
14921    // The statements that form the synthesized function body.
14922    SmallVector<Stmt*, 8> Statements;
14923  
14924    // The parameter for the "other" object, which we are copying from.
14925    ParmVarDecl *Other = CopyAssignOperator->getNonObjectParameter(0);
14926    Qualifiers OtherQuals = Other->getType().getQualifiers();
14927    QualType OtherRefType = Other->getType();
14928    if (OtherRefType->isLValueReferenceType()) {
14929      OtherRefType = OtherRefType->getPointeeType();
14930      OtherQuals = OtherRefType.getQualifiers();
14931    }
14932  
14933    // Our location for everything implicitly-generated.
14934    SourceLocation Loc = CopyAssignOperator->getEndLoc().isValid()
14935                             ? CopyAssignOperator->getEndLoc()
14936                             : CopyAssignOperator->getLocation();
14937  
14938    // Builds a DeclRefExpr for the "other" object.
14939    RefBuilder OtherRef(Other, OtherRefType);
14940  
14941    // Builds the function object parameter.
14942    std::optional<ThisBuilder> This;
14943    std::optional<DerefBuilder> DerefThis;
14944    std::optional<RefBuilder> ExplicitObject;
14945    bool IsArrow = false;
14946    QualType ObjectType;
14947    if (CopyAssignOperator->isExplicitObjectMemberFunction()) {
14948      ObjectType = CopyAssignOperator->getParamDecl(0)->getType();
14949      if (ObjectType->isReferenceType())
14950        ObjectType = ObjectType->getPointeeType();
14951      ExplicitObject.emplace(CopyAssignOperator->getParamDecl(0), ObjectType);
14952    } else {
14953      ObjectType = getCurrentThisType();
14954      This.emplace();
14955      DerefThis.emplace(*This);
14956      IsArrow = !LangOpts.HLSL;
14957    }
14958    ExprBuilder &ObjectParameter =
14959        ExplicitObject ? static_cast<ExprBuilder &>(*ExplicitObject)
14960                       : static_cast<ExprBuilder &>(*This);
14961  
14962    // Assign base classes.
14963    bool Invalid = false;
14964    for (auto &Base : ClassDecl->bases()) {
14965      // Form the assignment:
14966      //   static_cast<Base*>(this)->Base::operator=(static_cast<Base&>(other));
14967      QualType BaseType = Base.getType().getUnqualifiedType();
14968      if (!BaseType->isRecordType()) {
14969        Invalid = true;
14970        continue;
14971      }
14972  
14973      CXXCastPath BasePath;
14974      BasePath.push_back(&Base);
14975  
14976      // Construct the "from" expression, which is an implicit cast to the
14977      // appropriately-qualified base type.
14978      CastBuilder From(OtherRef, Context.getQualifiedType(BaseType, OtherQuals),
14979                       VK_LValue, BasePath);
14980  
14981      // Dereference "this".
14982      CastBuilder To(
14983          ExplicitObject ? static_cast<ExprBuilder &>(*ExplicitObject)
14984                         : static_cast<ExprBuilder &>(*DerefThis),
14985          Context.getQualifiedType(BaseType, ObjectType.getQualifiers()),
14986          VK_LValue, BasePath);
14987  
14988      // Build the copy.
14989      StmtResult Copy = buildSingleCopyAssign(*this, Loc, BaseType,
14990                                              To, From,
14991                                              /*CopyingBaseSubobject=*/true,
14992                                              /*Copying=*/true);
14993      if (Copy.isInvalid()) {
14994        CopyAssignOperator->setInvalidDecl();
14995        return;
14996      }
14997  
14998      // Success! Record the copy.
14999      Statements.push_back(Copy.getAs<Expr>());
15000    }
15001  
15002    // Assign non-static members.
15003    for (auto *Field : ClassDecl->fields()) {
15004      // FIXME: We should form some kind of AST representation for the implied
15005      // memcpy in a union copy operation.
15006      if (Field->isUnnamedBitField() || Field->getParent()->isUnion())
15007        continue;
15008  
15009      if (Field->isInvalidDecl()) {
15010        Invalid = true;
15011        continue;
15012      }
15013  
15014      // Check for members of reference type; we can't copy those.
15015      if (Field->getType()->isReferenceType()) {
15016        Diag(ClassDecl->getLocation(), diag::err_uninitialized_member_for_assign)
15017          << Context.getTagDeclType(ClassDecl) << 0 << Field->getDeclName();
15018        Diag(Field->getLocation(), diag::note_declared_at);
15019        Invalid = true;
15020        continue;
15021      }
15022  
15023      // Check for members of const-qualified, non-class type.
15024      QualType BaseType = Context.getBaseElementType(Field->getType());
15025      if (!BaseType->getAs<RecordType>() && BaseType.isConstQualified()) {
15026        Diag(ClassDecl->getLocation(), diag::err_uninitialized_member_for_assign)
15027          << Context.getTagDeclType(ClassDecl) << 1 << Field->getDeclName();
15028        Diag(Field->getLocation(), diag::note_declared_at);
15029        Invalid = true;
15030        continue;
15031      }
15032  
15033      // Suppress assigning zero-width bitfields.
15034      if (Field->isZeroLengthBitField(Context))
15035        continue;
15036  
15037      QualType FieldType = Field->getType().getNonReferenceType();
15038      if (FieldType->isIncompleteArrayType()) {
15039        assert(ClassDecl->hasFlexibleArrayMember() &&
15040               "Incomplete array type is not valid");
15041        continue;
15042      }
15043  
15044      // Build references to the field in the object we're copying from and to.
15045      CXXScopeSpec SS; // Intentionally empty
15046      LookupResult MemberLookup(*this, Field->getDeclName(), Loc,
15047                                LookupMemberName);
15048      MemberLookup.addDecl(Field);
15049      MemberLookup.resolveKind();
15050  
15051      MemberBuilder From(OtherRef, OtherRefType, /*IsArrow=*/false, MemberLookup);
15052      MemberBuilder To(ObjectParameter, ObjectType, IsArrow, MemberLookup);
15053      // Build the copy of this field.
15054      StmtResult Copy = buildSingleCopyAssign(*this, Loc, FieldType,
15055                                              To, From,
15056                                              /*CopyingBaseSubobject=*/false,
15057                                              /*Copying=*/true);
15058      if (Copy.isInvalid()) {
15059        CopyAssignOperator->setInvalidDecl();
15060        return;
15061      }
15062  
15063      // Success! Record the copy.
15064      Statements.push_back(Copy.getAs<Stmt>());
15065    }
15066  
15067    if (!Invalid) {
15068      // Add a "return *this;"
15069      Expr *ThisExpr =
15070          (ExplicitObject  ? static_cast<ExprBuilder &>(*ExplicitObject)
15071           : LangOpts.HLSL ? static_cast<ExprBuilder &>(*This)
15072                           : static_cast<ExprBuilder &>(*DerefThis))
15073              .build(*this, Loc);
15074      StmtResult Return = BuildReturnStmt(Loc, ThisExpr);
15075      if (Return.isInvalid())
15076        Invalid = true;
15077      else
15078        Statements.push_back(Return.getAs<Stmt>());
15079    }
15080  
15081    if (Invalid) {
15082      CopyAssignOperator->setInvalidDecl();
15083      return;
15084    }
15085  
15086    StmtResult Body;
15087    {
15088      CompoundScopeRAII CompoundScope(*this);
15089      Body = ActOnCompoundStmt(Loc, Loc, Statements,
15090                               /*isStmtExpr=*/false);
15091      assert(!Body.isInvalid() && "Compound statement creation cannot fail");
15092    }
15093    CopyAssignOperator->setBody(Body.getAs<Stmt>());
15094    CopyAssignOperator->markUsed(Context);
15095  
15096    if (ASTMutationListener *L = getASTMutationListener()) {
15097      L->CompletedImplicitDefinition(CopyAssignOperator);
15098    }
15099  }
15100  
15101  CXXMethodDecl *Sema::DeclareImplicitMoveAssignment(CXXRecordDecl *ClassDecl) {
15102    assert(ClassDecl->needsImplicitMoveAssignment());
15103  
15104    DeclaringSpecialMember DSM(*this, ClassDecl,
15105                               CXXSpecialMemberKind::MoveAssignment);
15106    if (DSM.isAlreadyBeingDeclared())
15107      return nullptr;
15108  
15109    // Note: The following rules are largely analoguous to the move
15110    // constructor rules.
15111  
15112    QualType ArgType = Context.getTypeDeclType(ClassDecl);
15113    ArgType = Context.getElaboratedType(ElaboratedTypeKeyword::None, nullptr,
15114                                        ArgType, nullptr);
15115    LangAS AS = getDefaultCXXMethodAddrSpace();
15116    if (AS != LangAS::Default)
15117      ArgType = Context.getAddrSpaceQualType(ArgType, AS);
15118    QualType RetType = Context.getLValueReferenceType(ArgType);
15119    ArgType = Context.getRValueReferenceType(ArgType);
15120  
15121    bool Constexpr = defaultedSpecialMemberIsConstexpr(
15122        *this, ClassDecl, CXXSpecialMemberKind::MoveAssignment, false);
15123  
15124    //   An implicitly-declared move assignment operator is an inline public
15125    //   member of its class.
15126    DeclarationName Name = Context.DeclarationNames.getCXXOperatorName(OO_Equal);
15127    SourceLocation ClassLoc = ClassDecl->getLocation();
15128    DeclarationNameInfo NameInfo(Name, ClassLoc);
15129    CXXMethodDecl *MoveAssignment = CXXMethodDecl::Create(
15130        Context, ClassDecl, ClassLoc, NameInfo, QualType(),
15131        /*TInfo=*/nullptr, /*StorageClass=*/SC_None,
15132        getCurFPFeatures().isFPConstrained(),
15133        /*isInline=*/true,
15134        Constexpr ? ConstexprSpecKind::Constexpr : ConstexprSpecKind::Unspecified,
15135        SourceLocation());
15136    MoveAssignment->setAccess(AS_public);
15137    MoveAssignment->setDefaulted();
15138    MoveAssignment->setImplicit();
15139  
15140    setupImplicitSpecialMemberType(MoveAssignment, RetType, ArgType);
15141  
15142    if (getLangOpts().CUDA)
15143      CUDA().inferTargetForImplicitSpecialMember(
15144          ClassDecl, CXXSpecialMemberKind::MoveAssignment, MoveAssignment,
15145          /* ConstRHS */ false,
15146          /* Diagnose */ false);
15147  
15148    // Add the parameter to the operator.
15149    ParmVarDecl *FromParam = ParmVarDecl::Create(Context, MoveAssignment,
15150                                                 ClassLoc, ClassLoc,
15151                                                 /*Id=*/nullptr, ArgType,
15152                                                 /*TInfo=*/nullptr, SC_None,
15153                                                 nullptr);
15154    MoveAssignment->setParams(FromParam);
15155  
15156    MoveAssignment->setTrivial(
15157        ClassDecl->needsOverloadResolutionForMoveAssignment()
15158            ? SpecialMemberIsTrivial(MoveAssignment,
15159                                     CXXSpecialMemberKind::MoveAssignment)
15160            : ClassDecl->hasTrivialMoveAssignment());
15161  
15162    // Note that we have added this copy-assignment operator.
15163    ++getASTContext().NumImplicitMoveAssignmentOperatorsDeclared;
15164  
15165    Scope *S = getScopeForContext(ClassDecl);
15166    CheckImplicitSpecialMemberDeclaration(S, MoveAssignment);
15167  
15168    if (ShouldDeleteSpecialMember(MoveAssignment,
15169                                  CXXSpecialMemberKind::MoveAssignment)) {
15170      ClassDecl->setImplicitMoveAssignmentIsDeleted();
15171      SetDeclDeleted(MoveAssignment, ClassLoc);
15172    }
15173  
15174    if (S)
15175      PushOnScopeChains(MoveAssignment, S, false);
15176    ClassDecl->addDecl(MoveAssignment);
15177  
15178    return MoveAssignment;
15179  }
15180  
15181  /// Check if we're implicitly defining a move assignment operator for a class
15182  /// with virtual bases. Such a move assignment might move-assign the virtual
15183  /// base multiple times.
15184  static void checkMoveAssignmentForRepeatedMove(Sema &S, CXXRecordDecl *Class,
15185                                                 SourceLocation CurrentLocation) {
15186    assert(!Class->isDependentContext() && "should not define dependent move");
15187  
15188    // Only a virtual base could get implicitly move-assigned multiple times.
15189    // Only a non-trivial move assignment can observe this. We only want to
15190    // diagnose if we implicitly define an assignment operator that assigns
15191    // two base classes, both of which move-assign the same virtual base.
15192    if (Class->getNumVBases() == 0 || Class->hasTrivialMoveAssignment() ||
15193        Class->getNumBases() < 2)
15194      return;
15195  
15196    llvm::SmallVector<CXXBaseSpecifier *, 16> Worklist;
15197    typedef llvm::DenseMap<CXXRecordDecl*, CXXBaseSpecifier*> VBaseMap;
15198    VBaseMap VBases;
15199  
15200    for (auto &BI : Class->bases()) {
15201      Worklist.push_back(&BI);
15202      while (!Worklist.empty()) {
15203        CXXBaseSpecifier *BaseSpec = Worklist.pop_back_val();
15204        CXXRecordDecl *Base = BaseSpec->getType()->getAsCXXRecordDecl();
15205  
15206        // If the base has no non-trivial move assignment operators,
15207        // we don't care about moves from it.
15208        if (!Base->hasNonTrivialMoveAssignment())
15209          continue;
15210  
15211        // If there's nothing virtual here, skip it.
15212        if (!BaseSpec->isVirtual() && !Base->getNumVBases())
15213          continue;
15214  
15215        // If we're not actually going to call a move assignment for this base,
15216        // or the selected move assignment is trivial, skip it.
15217        Sema::SpecialMemberOverloadResult SMOR =
15218            S.LookupSpecialMember(Base, CXXSpecialMemberKind::MoveAssignment,
15219                                  /*ConstArg*/ false, /*VolatileArg*/ false,
15220                                  /*RValueThis*/ true, /*ConstThis*/ false,
15221                                  /*VolatileThis*/ false);
15222        if (!SMOR.getMethod() || SMOR.getMethod()->isTrivial() ||
15223            !SMOR.getMethod()->isMoveAssignmentOperator())
15224          continue;
15225  
15226        if (BaseSpec->isVirtual()) {
15227          // We're going to move-assign this virtual base, and its move
15228          // assignment operator is not trivial. If this can happen for
15229          // multiple distinct direct bases of Class, diagnose it. (If it
15230          // only happens in one base, we'll diagnose it when synthesizing
15231          // that base class's move assignment operator.)
15232          CXXBaseSpecifier *&Existing =
15233              VBases.insert(std::make_pair(Base->getCanonicalDecl(), &BI))
15234                  .first->second;
15235          if (Existing && Existing != &BI) {
15236            S.Diag(CurrentLocation, diag::warn_vbase_moved_multiple_times)
15237              << Class << Base;
15238            S.Diag(Existing->getBeginLoc(), diag::note_vbase_moved_here)
15239                << (Base->getCanonicalDecl() ==
15240                    Existing->getType()->getAsCXXRecordDecl()->getCanonicalDecl())
15241                << Base << Existing->getType() << Existing->getSourceRange();
15242            S.Diag(BI.getBeginLoc(), diag::note_vbase_moved_here)
15243                << (Base->getCanonicalDecl() ==
15244                    BI.getType()->getAsCXXRecordDecl()->getCanonicalDecl())
15245                << Base << BI.getType() << BaseSpec->getSourceRange();
15246  
15247            // Only diagnose each vbase once.
15248            Existing = nullptr;
15249          }
15250        } else {
15251          // Only walk over bases that have defaulted move assignment operators.
15252          // We assume that any user-provided move assignment operator handles
15253          // the multiple-moves-of-vbase case itself somehow.
15254          if (!SMOR.getMethod()->isDefaulted())
15255            continue;
15256  
15257          // We're going to move the base classes of Base. Add them to the list.
15258          llvm::append_range(Worklist, llvm::make_pointer_range(Base->bases()));
15259        }
15260      }
15261    }
15262  }
15263  
15264  void Sema::DefineImplicitMoveAssignment(SourceLocation CurrentLocation,
15265                                          CXXMethodDecl *MoveAssignOperator) {
15266    assert((MoveAssignOperator->isDefaulted() &&
15267            MoveAssignOperator->isOverloadedOperator() &&
15268            MoveAssignOperator->getOverloadedOperator() == OO_Equal &&
15269            !MoveAssignOperator->doesThisDeclarationHaveABody() &&
15270            !MoveAssignOperator->isDeleted()) &&
15271           "DefineImplicitMoveAssignment called for wrong function");
15272    if (MoveAssignOperator->willHaveBody() || MoveAssignOperator->isInvalidDecl())
15273      return;
15274  
15275    CXXRecordDecl *ClassDecl = MoveAssignOperator->getParent();
15276    if (ClassDecl->isInvalidDecl()) {
15277      MoveAssignOperator->setInvalidDecl();
15278      return;
15279    }
15280  
15281    // C++0x [class.copy]p28:
15282    //   The implicitly-defined or move assignment operator for a non-union class
15283    //   X performs memberwise move assignment of its subobjects. The direct base
15284    //   classes of X are assigned first, in the order of their declaration in the
15285    //   base-specifier-list, and then the immediate non-static data members of X
15286    //   are assigned, in the order in which they were declared in the class
15287    //   definition.
15288  
15289    // Issue a warning if our implicit move assignment operator will move
15290    // from a virtual base more than once.
15291    checkMoveAssignmentForRepeatedMove(*this, ClassDecl, CurrentLocation);
15292  
15293    SynthesizedFunctionScope Scope(*this, MoveAssignOperator);
15294  
15295    // The exception specification is needed because we are defining the
15296    // function.
15297    ResolveExceptionSpec(CurrentLocation,
15298                         MoveAssignOperator->getType()->castAs<FunctionProtoType>());
15299  
15300    // Add a context note for diagnostics produced after this point.
15301    Scope.addContextNote(CurrentLocation);
15302  
15303    // The statements that form the synthesized function body.
15304    SmallVector<Stmt*, 8> Statements;
15305  
15306    // The parameter for the "other" object, which we are move from.
15307    ParmVarDecl *Other = MoveAssignOperator->getNonObjectParameter(0);
15308    QualType OtherRefType =
15309        Other->getType()->castAs<RValueReferenceType>()->getPointeeType();
15310  
15311    // Our location for everything implicitly-generated.
15312    SourceLocation Loc = MoveAssignOperator->getEndLoc().isValid()
15313                             ? MoveAssignOperator->getEndLoc()
15314                             : MoveAssignOperator->getLocation();
15315  
15316    // Builds a reference to the "other" object.
15317    RefBuilder OtherRef(Other, OtherRefType);
15318    // Cast to rvalue.
15319    MoveCastBuilder MoveOther(OtherRef);
15320  
15321    // Builds the function object parameter.
15322    std::optional<ThisBuilder> This;
15323    std::optional<DerefBuilder> DerefThis;
15324    std::optional<RefBuilder> ExplicitObject;
15325    QualType ObjectType;
15326    if (MoveAssignOperator->isExplicitObjectMemberFunction()) {
15327      ObjectType = MoveAssignOperator->getParamDecl(0)->getType();
15328      if (ObjectType->isReferenceType())
15329        ObjectType = ObjectType->getPointeeType();
15330      ExplicitObject.emplace(MoveAssignOperator->getParamDecl(0), ObjectType);
15331    } else {
15332      ObjectType = getCurrentThisType();
15333      This.emplace();
15334      DerefThis.emplace(*This);
15335    }
15336    ExprBuilder &ObjectParameter =
15337        ExplicitObject ? *ExplicitObject : static_cast<ExprBuilder &>(*This);
15338  
15339    // Assign base classes.
15340    bool Invalid = false;
15341    for (auto &Base : ClassDecl->bases()) {
15342      // C++11 [class.copy]p28:
15343      //   It is unspecified whether subobjects representing virtual base classes
15344      //   are assigned more than once by the implicitly-defined copy assignment
15345      //   operator.
15346      // FIXME: Do not assign to a vbase that will be assigned by some other base
15347      // class. For a move-assignment, this can result in the vbase being moved
15348      // multiple times.
15349  
15350      // Form the assignment:
15351      //   static_cast<Base*>(this)->Base::operator=(static_cast<Base&&>(other));
15352      QualType BaseType = Base.getType().getUnqualifiedType();
15353      if (!BaseType->isRecordType()) {
15354        Invalid = true;
15355        continue;
15356      }
15357  
15358      CXXCastPath BasePath;
15359      BasePath.push_back(&Base);
15360  
15361      // Construct the "from" expression, which is an implicit cast to the
15362      // appropriately-qualified base type.
15363      CastBuilder From(OtherRef, BaseType, VK_XValue, BasePath);
15364  
15365      // Implicitly cast "this" to the appropriately-qualified base type.
15366      // Dereference "this".
15367      CastBuilder To(
15368          ExplicitObject ? static_cast<ExprBuilder &>(*ExplicitObject)
15369                         : static_cast<ExprBuilder &>(*DerefThis),
15370          Context.getQualifiedType(BaseType, ObjectType.getQualifiers()),
15371          VK_LValue, BasePath);
15372  
15373      // Build the move.
15374      StmtResult Move = buildSingleCopyAssign(*this, Loc, BaseType,
15375                                              To, From,
15376                                              /*CopyingBaseSubobject=*/true,
15377                                              /*Copying=*/false);
15378      if (Move.isInvalid()) {
15379        MoveAssignOperator->setInvalidDecl();
15380        return;
15381      }
15382  
15383      // Success! Record the move.
15384      Statements.push_back(Move.getAs<Expr>());
15385    }
15386  
15387    // Assign non-static members.
15388    for (auto *Field : ClassDecl->fields()) {
15389      // FIXME: We should form some kind of AST representation for the implied
15390      // memcpy in a union copy operation.
15391      if (Field->isUnnamedBitField() || Field->getParent()->isUnion())
15392        continue;
15393  
15394      if (Field->isInvalidDecl()) {
15395        Invalid = true;
15396        continue;
15397      }
15398  
15399      // Check for members of reference type; we can't move those.
15400      if (Field->getType()->isReferenceType()) {
15401        Diag(ClassDecl->getLocation(), diag::err_uninitialized_member_for_assign)
15402          << Context.getTagDeclType(ClassDecl) << 0 << Field->getDeclName();
15403        Diag(Field->getLocation(), diag::note_declared_at);
15404        Invalid = true;
15405        continue;
15406      }
15407  
15408      // Check for members of const-qualified, non-class type.
15409      QualType BaseType = Context.getBaseElementType(Field->getType());
15410      if (!BaseType->getAs<RecordType>() && BaseType.isConstQualified()) {
15411        Diag(ClassDecl->getLocation(), diag::err_uninitialized_member_for_assign)
15412          << Context.getTagDeclType(ClassDecl) << 1 << Field->getDeclName();
15413        Diag(Field->getLocation(), diag::note_declared_at);
15414        Invalid = true;
15415        continue;
15416      }
15417  
15418      // Suppress assigning zero-width bitfields.
15419      if (Field->isZeroLengthBitField(Context))
15420        continue;
15421  
15422      QualType FieldType = Field->getType().getNonReferenceType();
15423      if (FieldType->isIncompleteArrayType()) {
15424        assert(ClassDecl->hasFlexibleArrayMember() &&
15425               "Incomplete array type is not valid");
15426        continue;
15427      }
15428  
15429      // Build references to the field in the object we're copying from and to.
15430      LookupResult MemberLookup(*this, Field->getDeclName(), Loc,
15431                                LookupMemberName);
15432      MemberLookup.addDecl(Field);
15433      MemberLookup.resolveKind();
15434      MemberBuilder From(MoveOther, OtherRefType,
15435                         /*IsArrow=*/false, MemberLookup);
15436      MemberBuilder To(ObjectParameter, ObjectType, /*IsArrow=*/!ExplicitObject,
15437                       MemberLookup);
15438  
15439      assert(!From.build(*this, Loc)->isLValue() && // could be xvalue or prvalue
15440          "Member reference with rvalue base must be rvalue except for reference "
15441          "members, which aren't allowed for move assignment.");
15442  
15443      // Build the move of this field.
15444      StmtResult Move = buildSingleCopyAssign(*this, Loc, FieldType,
15445                                              To, From,
15446                                              /*CopyingBaseSubobject=*/false,
15447                                              /*Copying=*/false);
15448      if (Move.isInvalid()) {
15449        MoveAssignOperator->setInvalidDecl();
15450        return;
15451      }
15452  
15453      // Success! Record the copy.
15454      Statements.push_back(Move.getAs<Stmt>());
15455    }
15456  
15457    if (!Invalid) {
15458      // Add a "return *this;"
15459      Expr *ThisExpr =
15460          (ExplicitObject ? static_cast<ExprBuilder &>(*ExplicitObject)
15461                          : static_cast<ExprBuilder &>(*DerefThis))
15462              .build(*this, Loc);
15463  
15464      StmtResult Return = BuildReturnStmt(Loc, ThisExpr);
15465      if (Return.isInvalid())
15466        Invalid = true;
15467      else
15468        Statements.push_back(Return.getAs<Stmt>());
15469    }
15470  
15471    if (Invalid) {
15472      MoveAssignOperator->setInvalidDecl();
15473      return;
15474    }
15475  
15476    StmtResult Body;
15477    {
15478      CompoundScopeRAII CompoundScope(*this);
15479      Body = ActOnCompoundStmt(Loc, Loc, Statements,
15480                               /*isStmtExpr=*/false);
15481      assert(!Body.isInvalid() && "Compound statement creation cannot fail");
15482    }
15483    MoveAssignOperator->setBody(Body.getAs<Stmt>());
15484    MoveAssignOperator->markUsed(Context);
15485  
15486    if (ASTMutationListener *L = getASTMutationListener()) {
15487      L->CompletedImplicitDefinition(MoveAssignOperator);
15488    }
15489  }
15490  
15491  CXXConstructorDecl *Sema::DeclareImplicitCopyConstructor(
15492                                                      CXXRecordDecl *ClassDecl) {
15493    // C++ [class.copy]p4:
15494    //   If the class definition does not explicitly declare a copy
15495    //   constructor, one is declared implicitly.
15496    assert(ClassDecl->needsImplicitCopyConstructor());
15497  
15498    DeclaringSpecialMember DSM(*this, ClassDecl,
15499                               CXXSpecialMemberKind::CopyConstructor);
15500    if (DSM.isAlreadyBeingDeclared())
15501      return nullptr;
15502  
15503    QualType ClassType = Context.getTypeDeclType(ClassDecl);
15504    QualType ArgType = ClassType;
15505    ArgType = Context.getElaboratedType(ElaboratedTypeKeyword::None, nullptr,
15506                                        ArgType, nullptr);
15507    bool Const = ClassDecl->implicitCopyConstructorHasConstParam();
15508    if (Const)
15509      ArgType = ArgType.withConst();
15510  
15511    LangAS AS = getDefaultCXXMethodAddrSpace();
15512    if (AS != LangAS::Default)
15513      ArgType = Context.getAddrSpaceQualType(ArgType, AS);
15514  
15515    ArgType = Context.getLValueReferenceType(ArgType);
15516  
15517    bool Constexpr = defaultedSpecialMemberIsConstexpr(
15518        *this, ClassDecl, CXXSpecialMemberKind::CopyConstructor, Const);
15519  
15520    DeclarationName Name
15521      = Context.DeclarationNames.getCXXConstructorName(
15522                                             Context.getCanonicalType(ClassType));
15523    SourceLocation ClassLoc = ClassDecl->getLocation();
15524    DeclarationNameInfo NameInfo(Name, ClassLoc);
15525  
15526    //   An implicitly-declared copy constructor is an inline public
15527    //   member of its class.
15528    CXXConstructorDecl *CopyConstructor = CXXConstructorDecl::Create(
15529        Context, ClassDecl, ClassLoc, NameInfo, QualType(), /*TInfo=*/nullptr,
15530        ExplicitSpecifier(), getCurFPFeatures().isFPConstrained(),
15531        /*isInline=*/true,
15532        /*isImplicitlyDeclared=*/true,
15533        Constexpr ? ConstexprSpecKind::Constexpr
15534                  : ConstexprSpecKind::Unspecified);
15535    CopyConstructor->setAccess(AS_public);
15536    CopyConstructor->setDefaulted();
15537  
15538    setupImplicitSpecialMemberType(CopyConstructor, Context.VoidTy, ArgType);
15539  
15540    if (getLangOpts().CUDA)
15541      CUDA().inferTargetForImplicitSpecialMember(
15542          ClassDecl, CXXSpecialMemberKind::CopyConstructor, CopyConstructor,
15543          /* ConstRHS */ Const,
15544          /* Diagnose */ false);
15545  
15546    // During template instantiation of special member functions we need a
15547    // reliable TypeSourceInfo for the parameter types in order to allow functions
15548    // to be substituted.
15549    TypeSourceInfo *TSI = nullptr;
15550    if (inTemplateInstantiation() && ClassDecl->isLambda())
15551      TSI = Context.getTrivialTypeSourceInfo(ArgType);
15552  
15553    // Add the parameter to the constructor.
15554    ParmVarDecl *FromParam =
15555        ParmVarDecl::Create(Context, CopyConstructor, ClassLoc, ClassLoc,
15556                            /*IdentifierInfo=*/nullptr, ArgType,
15557                            /*TInfo=*/TSI, SC_None, nullptr);
15558    CopyConstructor->setParams(FromParam);
15559  
15560    CopyConstructor->setTrivial(
15561        ClassDecl->needsOverloadResolutionForCopyConstructor()
15562            ? SpecialMemberIsTrivial(CopyConstructor,
15563                                     CXXSpecialMemberKind::CopyConstructor)
15564            : ClassDecl->hasTrivialCopyConstructor());
15565  
15566    CopyConstructor->setTrivialForCall(
15567        ClassDecl->hasAttr<TrivialABIAttr>() ||
15568        (ClassDecl->needsOverloadResolutionForCopyConstructor()
15569             ? SpecialMemberIsTrivial(CopyConstructor,
15570                                      CXXSpecialMemberKind::CopyConstructor,
15571                                      TAH_ConsiderTrivialABI)
15572             : ClassDecl->hasTrivialCopyConstructorForCall()));
15573  
15574    // Note that we have declared this constructor.
15575    ++getASTContext().NumImplicitCopyConstructorsDeclared;
15576  
15577    Scope *S = getScopeForContext(ClassDecl);
15578    CheckImplicitSpecialMemberDeclaration(S, CopyConstructor);
15579  
15580    if (ShouldDeleteSpecialMember(CopyConstructor,
15581                                  CXXSpecialMemberKind::CopyConstructor)) {
15582      ClassDecl->setImplicitCopyConstructorIsDeleted();
15583      SetDeclDeleted(CopyConstructor, ClassLoc);
15584    }
15585  
15586    if (S)
15587      PushOnScopeChains(CopyConstructor, S, false);
15588    ClassDecl->addDecl(CopyConstructor);
15589  
15590    return CopyConstructor;
15591  }
15592  
15593  void Sema::DefineImplicitCopyConstructor(SourceLocation CurrentLocation,
15594                                           CXXConstructorDecl *CopyConstructor) {
15595    assert((CopyConstructor->isDefaulted() &&
15596            CopyConstructor->isCopyConstructor() &&
15597            !CopyConstructor->doesThisDeclarationHaveABody() &&
15598            !CopyConstructor->isDeleted()) &&
15599           "DefineImplicitCopyConstructor - call it for implicit copy ctor");
15600    if (CopyConstructor->willHaveBody() || CopyConstructor->isInvalidDecl())
15601      return;
15602  
15603    CXXRecordDecl *ClassDecl = CopyConstructor->getParent();
15604    assert(ClassDecl && "DefineImplicitCopyConstructor - invalid constructor");
15605  
15606    SynthesizedFunctionScope Scope(*this, CopyConstructor);
15607  
15608    // The exception specification is needed because we are defining the
15609    // function.
15610    ResolveExceptionSpec(CurrentLocation,
15611                         CopyConstructor->getType()->castAs<FunctionProtoType>());
15612    MarkVTableUsed(CurrentLocation, ClassDecl);
15613  
15614    // Add a context note for diagnostics produced after this point.
15615    Scope.addContextNote(CurrentLocation);
15616  
15617    // C++11 [class.copy]p7:
15618    //   The [definition of an implicitly declared copy constructor] is
15619    //   deprecated if the class has a user-declared copy assignment operator
15620    //   or a user-declared destructor.
15621    if (getLangOpts().CPlusPlus11 && CopyConstructor->isImplicit())
15622      diagnoseDeprecatedCopyOperation(*this, CopyConstructor);
15623  
15624    if (SetCtorInitializers(CopyConstructor, /*AnyErrors=*/false)) {
15625      CopyConstructor->setInvalidDecl();
15626    }  else {
15627      SourceLocation Loc = CopyConstructor->getEndLoc().isValid()
15628                               ? CopyConstructor->getEndLoc()
15629                               : CopyConstructor->getLocation();
15630      Sema::CompoundScopeRAII CompoundScope(*this);
15631      CopyConstructor->setBody(
15632          ActOnCompoundStmt(Loc, Loc, std::nullopt, /*isStmtExpr=*/false)
15633              .getAs<Stmt>());
15634      CopyConstructor->markUsed(Context);
15635    }
15636  
15637    if (ASTMutationListener *L = getASTMutationListener()) {
15638      L->CompletedImplicitDefinition(CopyConstructor);
15639    }
15640  }
15641  
15642  CXXConstructorDecl *Sema::DeclareImplicitMoveConstructor(
15643                                                      CXXRecordDecl *ClassDecl) {
15644    assert(ClassDecl->needsImplicitMoveConstructor());
15645  
15646    DeclaringSpecialMember DSM(*this, ClassDecl,
15647                               CXXSpecialMemberKind::MoveConstructor);
15648    if (DSM.isAlreadyBeingDeclared())
15649      return nullptr;
15650  
15651    QualType ClassType = Context.getTypeDeclType(ClassDecl);
15652  
15653    QualType ArgType = ClassType;
15654    ArgType = Context.getElaboratedType(ElaboratedTypeKeyword::None, nullptr,
15655                                        ArgType, nullptr);
15656    LangAS AS = getDefaultCXXMethodAddrSpace();
15657    if (AS != LangAS::Default)
15658      ArgType = Context.getAddrSpaceQualType(ClassType, AS);
15659    ArgType = Context.getRValueReferenceType(ArgType);
15660  
15661    bool Constexpr = defaultedSpecialMemberIsConstexpr(
15662        *this, ClassDecl, CXXSpecialMemberKind::MoveConstructor, false);
15663  
15664    DeclarationName Name
15665      = Context.DeclarationNames.getCXXConstructorName(
15666                                             Context.getCanonicalType(ClassType));
15667    SourceLocation ClassLoc = ClassDecl->getLocation();
15668    DeclarationNameInfo NameInfo(Name, ClassLoc);
15669  
15670    // C++11 [class.copy]p11:
15671    //   An implicitly-declared copy/move constructor is an inline public
15672    //   member of its class.
15673    CXXConstructorDecl *MoveConstructor = CXXConstructorDecl::Create(
15674        Context, ClassDecl, ClassLoc, NameInfo, QualType(), /*TInfo=*/nullptr,
15675        ExplicitSpecifier(), getCurFPFeatures().isFPConstrained(),
15676        /*isInline=*/true,
15677        /*isImplicitlyDeclared=*/true,
15678        Constexpr ? ConstexprSpecKind::Constexpr
15679                  : ConstexprSpecKind::Unspecified);
15680    MoveConstructor->setAccess(AS_public);
15681    MoveConstructor->setDefaulted();
15682  
15683    setupImplicitSpecialMemberType(MoveConstructor, Context.VoidTy, ArgType);
15684  
15685    if (getLangOpts().CUDA)
15686      CUDA().inferTargetForImplicitSpecialMember(
15687          ClassDecl, CXXSpecialMemberKind::MoveConstructor, MoveConstructor,
15688          /* ConstRHS */ false,
15689          /* Diagnose */ false);
15690  
15691    // Add the parameter to the constructor.
15692    ParmVarDecl *FromParam = ParmVarDecl::Create(Context, MoveConstructor,
15693                                                 ClassLoc, ClassLoc,
15694                                                 /*IdentifierInfo=*/nullptr,
15695                                                 ArgType, /*TInfo=*/nullptr,
15696                                                 SC_None, nullptr);
15697    MoveConstructor->setParams(FromParam);
15698  
15699    MoveConstructor->setTrivial(
15700        ClassDecl->needsOverloadResolutionForMoveConstructor()
15701            ? SpecialMemberIsTrivial(MoveConstructor,
15702                                     CXXSpecialMemberKind::MoveConstructor)
15703            : ClassDecl->hasTrivialMoveConstructor());
15704  
15705    MoveConstructor->setTrivialForCall(
15706        ClassDecl->hasAttr<TrivialABIAttr>() ||
15707        (ClassDecl->needsOverloadResolutionForMoveConstructor()
15708             ? SpecialMemberIsTrivial(MoveConstructor,
15709                                      CXXSpecialMemberKind::MoveConstructor,
15710                                      TAH_ConsiderTrivialABI)
15711             : ClassDecl->hasTrivialMoveConstructorForCall()));
15712  
15713    // Note that we have declared this constructor.
15714    ++getASTContext().NumImplicitMoveConstructorsDeclared;
15715  
15716    Scope *S = getScopeForContext(ClassDecl);
15717    CheckImplicitSpecialMemberDeclaration(S, MoveConstructor);
15718  
15719    if (ShouldDeleteSpecialMember(MoveConstructor,
15720                                  CXXSpecialMemberKind::MoveConstructor)) {
15721      ClassDecl->setImplicitMoveConstructorIsDeleted();
15722      SetDeclDeleted(MoveConstructor, ClassLoc);
15723    }
15724  
15725    if (S)
15726      PushOnScopeChains(MoveConstructor, S, false);
15727    ClassDecl->addDecl(MoveConstructor);
15728  
15729    return MoveConstructor;
15730  }
15731  
15732  void Sema::DefineImplicitMoveConstructor(SourceLocation CurrentLocation,
15733                                           CXXConstructorDecl *MoveConstructor) {
15734    assert((MoveConstructor->isDefaulted() &&
15735            MoveConstructor->isMoveConstructor() &&
15736            !MoveConstructor->doesThisDeclarationHaveABody() &&
15737            !MoveConstructor->isDeleted()) &&
15738           "DefineImplicitMoveConstructor - call it for implicit move ctor");
15739    if (MoveConstructor->willHaveBody() || MoveConstructor->isInvalidDecl())
15740      return;
15741  
15742    CXXRecordDecl *ClassDecl = MoveConstructor->getParent();
15743    assert(ClassDecl && "DefineImplicitMoveConstructor - invalid constructor");
15744  
15745    SynthesizedFunctionScope Scope(*this, MoveConstructor);
15746  
15747    // The exception specification is needed because we are defining the
15748    // function.
15749    ResolveExceptionSpec(CurrentLocation,
15750                         MoveConstructor->getType()->castAs<FunctionProtoType>());
15751    MarkVTableUsed(CurrentLocation, ClassDecl);
15752  
15753    // Add a context note for diagnostics produced after this point.
15754    Scope.addContextNote(CurrentLocation);
15755  
15756    if (SetCtorInitializers(MoveConstructor, /*AnyErrors=*/false)) {
15757      MoveConstructor->setInvalidDecl();
15758    } else {
15759      SourceLocation Loc = MoveConstructor->getEndLoc().isValid()
15760                               ? MoveConstructor->getEndLoc()
15761                               : MoveConstructor->getLocation();
15762      Sema::CompoundScopeRAII CompoundScope(*this);
15763      MoveConstructor->setBody(
15764          ActOnCompoundStmt(Loc, Loc, std::nullopt, /*isStmtExpr=*/false)
15765              .getAs<Stmt>());
15766      MoveConstructor->markUsed(Context);
15767    }
15768  
15769    if (ASTMutationListener *L = getASTMutationListener()) {
15770      L->CompletedImplicitDefinition(MoveConstructor);
15771    }
15772  }
15773  
15774  bool Sema::isImplicitlyDeleted(FunctionDecl *FD) {
15775    return FD->isDeleted() && FD->isDefaulted() && isa<CXXMethodDecl>(FD);
15776  }
15777  
15778  void Sema::DefineImplicitLambdaToFunctionPointerConversion(
15779                              SourceLocation CurrentLocation,
15780                              CXXConversionDecl *Conv) {
15781    SynthesizedFunctionScope Scope(*this, Conv);
15782    assert(!Conv->getReturnType()->isUndeducedType());
15783  
15784    QualType ConvRT = Conv->getType()->castAs<FunctionType>()->getReturnType();
15785    CallingConv CC =
15786        ConvRT->getPointeeType()->castAs<FunctionType>()->getCallConv();
15787  
15788    CXXRecordDecl *Lambda = Conv->getParent();
15789    FunctionDecl *CallOp = Lambda->getLambdaCallOperator();
15790    FunctionDecl *Invoker =
15791        CallOp->hasCXXExplicitFunctionObjectParameter() || CallOp->isStatic()
15792            ? CallOp
15793            : Lambda->getLambdaStaticInvoker(CC);
15794  
15795    if (auto *TemplateArgs = Conv->getTemplateSpecializationArgs()) {
15796      CallOp = InstantiateFunctionDeclaration(
15797          CallOp->getDescribedFunctionTemplate(), TemplateArgs, CurrentLocation);
15798      if (!CallOp)
15799        return;
15800  
15801      if (CallOp != Invoker) {
15802        Invoker = InstantiateFunctionDeclaration(
15803            Invoker->getDescribedFunctionTemplate(), TemplateArgs,
15804            CurrentLocation);
15805        if (!Invoker)
15806          return;
15807      }
15808    }
15809  
15810    if (CallOp->isInvalidDecl())
15811      return;
15812  
15813    // Mark the call operator referenced (and add to pending instantiations
15814    // if necessary).
15815    // For both the conversion and static-invoker template specializations
15816    // we construct their body's in this function, so no need to add them
15817    // to the PendingInstantiations.
15818    MarkFunctionReferenced(CurrentLocation, CallOp);
15819  
15820    if (Invoker != CallOp) {
15821      // Fill in the __invoke function with a dummy implementation. IR generation
15822      // will fill in the actual details. Update its type in case it contained
15823      // an 'auto'.
15824      Invoker->markUsed(Context);
15825      Invoker->setReferenced();
15826      Invoker->setType(Conv->getReturnType()->getPointeeType());
15827      Invoker->setBody(new (Context) CompoundStmt(Conv->getLocation()));
15828    }
15829  
15830    // Construct the body of the conversion function { return __invoke; }.
15831    Expr *FunctionRef = BuildDeclRefExpr(Invoker, Invoker->getType(), VK_LValue,
15832                                         Conv->getLocation());
15833    assert(FunctionRef && "Can't refer to __invoke function?");
15834    Stmt *Return = BuildReturnStmt(Conv->getLocation(), FunctionRef).get();
15835    Conv->setBody(CompoundStmt::Create(Context, Return, FPOptionsOverride(),
15836                                       Conv->getLocation(), Conv->getLocation()));
15837    Conv->markUsed(Context);
15838    Conv->setReferenced();
15839  
15840    if (ASTMutationListener *L = getASTMutationListener()) {
15841      L->CompletedImplicitDefinition(Conv);
15842      if (Invoker != CallOp)
15843        L->CompletedImplicitDefinition(Invoker);
15844    }
15845  }
15846  
15847  void Sema::DefineImplicitLambdaToBlockPointerConversion(
15848      SourceLocation CurrentLocation, CXXConversionDecl *Conv) {
15849    assert(!Conv->getParent()->isGenericLambda());
15850  
15851    SynthesizedFunctionScope Scope(*this, Conv);
15852  
15853    // Copy-initialize the lambda object as needed to capture it.
15854    Expr *This = ActOnCXXThis(CurrentLocation).get();
15855    Expr *DerefThis =CreateBuiltinUnaryOp(CurrentLocation, UO_Deref, This).get();
15856  
15857    ExprResult BuildBlock = BuildBlockForLambdaConversion(CurrentLocation,
15858                                                          Conv->getLocation(),
15859                                                          Conv, DerefThis);
15860  
15861    // If we're not under ARC, make sure we still get the _Block_copy/autorelease
15862    // behavior.  Note that only the general conversion function does this
15863    // (since it's unusable otherwise); in the case where we inline the
15864    // block literal, it has block literal lifetime semantics.
15865    if (!BuildBlock.isInvalid() && !getLangOpts().ObjCAutoRefCount)
15866      BuildBlock = ImplicitCastExpr::Create(
15867          Context, BuildBlock.get()->getType(), CK_CopyAndAutoreleaseBlockObject,
15868          BuildBlock.get(), nullptr, VK_PRValue, FPOptionsOverride());
15869  
15870    if (BuildBlock.isInvalid()) {
15871      Diag(CurrentLocation, diag::note_lambda_to_block_conv);
15872      Conv->setInvalidDecl();
15873      return;
15874    }
15875  
15876    // Create the return statement that returns the block from the conversion
15877    // function.
15878    StmtResult Return = BuildReturnStmt(Conv->getLocation(), BuildBlock.get());
15879    if (Return.isInvalid()) {
15880      Diag(CurrentLocation, diag::note_lambda_to_block_conv);
15881      Conv->setInvalidDecl();
15882      return;
15883    }
15884  
15885    // Set the body of the conversion function.
15886    Stmt *ReturnS = Return.get();
15887    Conv->setBody(CompoundStmt::Create(Context, ReturnS, FPOptionsOverride(),
15888                                       Conv->getLocation(), Conv->getLocation()));
15889    Conv->markUsed(Context);
15890  
15891    // We're done; notify the mutation listener, if any.
15892    if (ASTMutationListener *L = getASTMutationListener()) {
15893      L->CompletedImplicitDefinition(Conv);
15894    }
15895  }
15896  
15897  /// Determine whether the given list arguments contains exactly one
15898  /// "real" (non-default) argument.
15899  static bool hasOneRealArgument(MultiExprArg Args) {
15900    switch (Args.size()) {
15901    case 0:
15902      return false;
15903  
15904    default:
15905      if (!Args[1]->isDefaultArgument())
15906        return false;
15907  
15908      [[fallthrough]];
15909    case 1:
15910      return !Args[0]->isDefaultArgument();
15911    }
15912  
15913    return false;
15914  }
15915  
15916  ExprResult Sema::BuildCXXConstructExpr(
15917      SourceLocation ConstructLoc, QualType DeclInitType, NamedDecl *FoundDecl,
15918      CXXConstructorDecl *Constructor, MultiExprArg ExprArgs,
15919      bool HadMultipleCandidates, bool IsListInitialization,
15920      bool IsStdInitListInitialization, bool RequiresZeroInit,
15921      CXXConstructionKind ConstructKind, SourceRange ParenRange) {
15922    bool Elidable = false;
15923  
15924    // C++0x [class.copy]p34:
15925    //   When certain criteria are met, an implementation is allowed to
15926    //   omit the copy/move construction of a class object, even if the
15927    //   copy/move constructor and/or destructor for the object have
15928    //   side effects. [...]
15929    //     - when a temporary class object that has not been bound to a
15930    //       reference (12.2) would be copied/moved to a class object
15931    //       with the same cv-unqualified type, the copy/move operation
15932    //       can be omitted by constructing the temporary object
15933    //       directly into the target of the omitted copy/move
15934    if (ConstructKind == CXXConstructionKind::Complete && Constructor &&
15935        // FIXME: Converting constructors should also be accepted.
15936        // But to fix this, the logic that digs down into a CXXConstructExpr
15937        // to find the source object needs to handle it.
15938        // Right now it assumes the source object is passed directly as the
15939        // first argument.
15940        Constructor->isCopyOrMoveConstructor() && hasOneRealArgument(ExprArgs)) {
15941      Expr *SubExpr = ExprArgs[0];
15942      // FIXME: Per above, this is also incorrect if we want to accept
15943      //        converting constructors, as isTemporaryObject will
15944      //        reject temporaries with different type from the
15945      //        CXXRecord itself.
15946      Elidable = SubExpr->isTemporaryObject(
15947          Context, cast<CXXRecordDecl>(FoundDecl->getDeclContext()));
15948    }
15949  
15950    return BuildCXXConstructExpr(ConstructLoc, DeclInitType,
15951                                 FoundDecl, Constructor,
15952                                 Elidable, ExprArgs, HadMultipleCandidates,
15953                                 IsListInitialization,
15954                                 IsStdInitListInitialization, RequiresZeroInit,
15955                                 ConstructKind, ParenRange);
15956  }
15957  
15958  ExprResult Sema::BuildCXXConstructExpr(
15959      SourceLocation ConstructLoc, QualType DeclInitType, NamedDecl *FoundDecl,
15960      CXXConstructorDecl *Constructor, bool Elidable, MultiExprArg ExprArgs,
15961      bool HadMultipleCandidates, bool IsListInitialization,
15962      bool IsStdInitListInitialization, bool RequiresZeroInit,
15963      CXXConstructionKind ConstructKind, SourceRange ParenRange) {
15964    if (auto *Shadow = dyn_cast<ConstructorUsingShadowDecl>(FoundDecl)) {
15965      Constructor = findInheritingConstructor(ConstructLoc, Constructor, Shadow);
15966      // The only way to get here is if we did overload resolution to find the
15967      // shadow decl, so we don't need to worry about re-checking the trailing
15968      // requires clause.
15969      if (DiagnoseUseOfOverloadedDecl(Constructor, ConstructLoc))
15970        return ExprError();
15971    }
15972  
15973    return BuildCXXConstructExpr(
15974        ConstructLoc, DeclInitType, Constructor, Elidable, ExprArgs,
15975        HadMultipleCandidates, IsListInitialization, IsStdInitListInitialization,
15976        RequiresZeroInit, ConstructKind, ParenRange);
15977  }
15978  
15979  /// BuildCXXConstructExpr - Creates a complete call to a constructor,
15980  /// including handling of its default argument expressions.
15981  ExprResult Sema::BuildCXXConstructExpr(
15982      SourceLocation ConstructLoc, QualType DeclInitType,
15983      CXXConstructorDecl *Constructor, bool Elidable, MultiExprArg ExprArgs,
15984      bool HadMultipleCandidates, bool IsListInitialization,
15985      bool IsStdInitListInitialization, bool RequiresZeroInit,
15986      CXXConstructionKind ConstructKind, SourceRange ParenRange) {
15987    assert(declaresSameEntity(
15988               Constructor->getParent(),
15989               DeclInitType->getBaseElementTypeUnsafe()->getAsCXXRecordDecl()) &&
15990           "given constructor for wrong type");
15991    MarkFunctionReferenced(ConstructLoc, Constructor);
15992    if (getLangOpts().CUDA && !CUDA().CheckCall(ConstructLoc, Constructor))
15993      return ExprError();
15994  
15995    return CheckForImmediateInvocation(
15996        CXXConstructExpr::Create(
15997            Context, DeclInitType, ConstructLoc, Constructor, Elidable, ExprArgs,
15998            HadMultipleCandidates, IsListInitialization,
15999            IsStdInitListInitialization, RequiresZeroInit,
16000            static_cast<CXXConstructionKind>(ConstructKind), ParenRange),
16001        Constructor);
16002  }
16003  
16004  void Sema::FinalizeVarWithDestructor(VarDecl *VD, const RecordType *Record) {
16005    if (VD->isInvalidDecl()) return;
16006    // If initializing the variable failed, don't also diagnose problems with
16007    // the destructor, they're likely related.
16008    if (VD->getInit() && VD->getInit()->containsErrors())
16009      return;
16010  
16011    CXXRecordDecl *ClassDecl = cast<CXXRecordDecl>(Record->getDecl());
16012    if (ClassDecl->isInvalidDecl()) return;
16013    if (ClassDecl->hasIrrelevantDestructor()) return;
16014    if (ClassDecl->isDependentContext()) return;
16015  
16016    if (VD->isNoDestroy(getASTContext()))
16017      return;
16018  
16019    CXXDestructorDecl *Destructor = LookupDestructor(ClassDecl);
16020    // The result of `LookupDestructor` might be nullptr if the destructor is
16021    // invalid, in which case it is marked as `IneligibleOrNotSelected` and
16022    // will not be selected by `CXXRecordDecl::getDestructor()`.
16023    if (!Destructor)
16024      return;
16025    // If this is an array, we'll require the destructor during initialization, so
16026    // we can skip over this. We still want to emit exit-time destructor warnings
16027    // though.
16028    if (!VD->getType()->isArrayType()) {
16029      MarkFunctionReferenced(VD->getLocation(), Destructor);
16030      CheckDestructorAccess(VD->getLocation(), Destructor,
16031                            PDiag(diag::err_access_dtor_var)
16032                                << VD->getDeclName() << VD->getType());
16033      DiagnoseUseOfDecl(Destructor, VD->getLocation());
16034    }
16035  
16036    if (Destructor->isTrivial()) return;
16037  
16038    // If the destructor is constexpr, check whether the variable has constant
16039    // destruction now.
16040    if (Destructor->isConstexpr()) {
16041      bool HasConstantInit = false;
16042      if (VD->getInit() && !VD->getInit()->isValueDependent())
16043        HasConstantInit = VD->evaluateValue();
16044      SmallVector<PartialDiagnosticAt, 8> Notes;
16045      if (!VD->evaluateDestruction(Notes) && VD->isConstexpr() &&
16046          HasConstantInit) {
16047        Diag(VD->getLocation(),
16048             diag::err_constexpr_var_requires_const_destruction) << VD;
16049        for (unsigned I = 0, N = Notes.size(); I != N; ++I)
16050          Diag(Notes[I].first, Notes[I].second);
16051      }
16052    }
16053  
16054    if (!VD->hasGlobalStorage() || !VD->needsDestruction(Context))
16055      return;
16056  
16057    // Emit warning for non-trivial dtor in global scope (a real global,
16058    // class-static, function-static).
16059    if (!VD->hasAttr<AlwaysDestroyAttr>())
16060      Diag(VD->getLocation(), diag::warn_exit_time_destructor);
16061  
16062    // TODO: this should be re-enabled for static locals by !CXAAtExit
16063    if (!VD->isStaticLocal())
16064      Diag(VD->getLocation(), diag::warn_global_destructor);
16065  }
16066  
16067  bool Sema::CompleteConstructorCall(CXXConstructorDecl *Constructor,
16068                                     QualType DeclInitType, MultiExprArg ArgsPtr,
16069                                     SourceLocation Loc,
16070                                     SmallVectorImpl<Expr *> &ConvertedArgs,
16071                                     bool AllowExplicit,
16072                                     bool IsListInitialization) {
16073    // FIXME: This duplicates a lot of code from Sema::ConvertArgumentsForCall.
16074    unsigned NumArgs = ArgsPtr.size();
16075    Expr **Args = ArgsPtr.data();
16076  
16077    const auto *Proto = Constructor->getType()->castAs<FunctionProtoType>();
16078    unsigned NumParams = Proto->getNumParams();
16079  
16080    // If too few arguments are available, we'll fill in the rest with defaults.
16081    if (NumArgs < NumParams)
16082      ConvertedArgs.reserve(NumParams);
16083    else
16084      ConvertedArgs.reserve(NumArgs);
16085  
16086    VariadicCallType CallType =
16087      Proto->isVariadic() ? VariadicConstructor : VariadicDoesNotApply;
16088    SmallVector<Expr *, 8> AllArgs;
16089    bool Invalid = GatherArgumentsForCall(
16090        Loc, Constructor, Proto, 0, llvm::ArrayRef(Args, NumArgs), AllArgs,
16091        CallType, AllowExplicit, IsListInitialization);
16092    ConvertedArgs.append(AllArgs.begin(), AllArgs.end());
16093  
16094    DiagnoseSentinelCalls(Constructor, Loc, AllArgs);
16095  
16096    CheckConstructorCall(Constructor, DeclInitType,
16097                         llvm::ArrayRef(AllArgs.data(), AllArgs.size()), Proto,
16098                         Loc);
16099  
16100    return Invalid;
16101  }
16102  
16103  static inline bool
16104  CheckOperatorNewDeleteDeclarationScope(Sema &SemaRef,
16105                                         const FunctionDecl *FnDecl) {
16106    const DeclContext *DC = FnDecl->getDeclContext()->getRedeclContext();
16107    if (isa<NamespaceDecl>(DC)) {
16108      return SemaRef.Diag(FnDecl->getLocation(),
16109                          diag::err_operator_new_delete_declared_in_namespace)
16110        << FnDecl->getDeclName();
16111    }
16112  
16113    if (isa<TranslationUnitDecl>(DC) &&
16114        FnDecl->getStorageClass() == SC_Static) {
16115      return SemaRef.Diag(FnDecl->getLocation(),
16116                          diag::err_operator_new_delete_declared_static)
16117        << FnDecl->getDeclName();
16118    }
16119  
16120    return false;
16121  }
16122  
16123  static CanQualType RemoveAddressSpaceFromPtr(Sema &SemaRef,
16124                                               const PointerType *PtrTy) {
16125    auto &Ctx = SemaRef.Context;
16126    Qualifiers PtrQuals = PtrTy->getPointeeType().getQualifiers();
16127    PtrQuals.removeAddressSpace();
16128    return Ctx.getPointerType(Ctx.getCanonicalType(Ctx.getQualifiedType(
16129        PtrTy->getPointeeType().getUnqualifiedType(), PtrQuals)));
16130  }
16131  
16132  static inline bool
16133  CheckOperatorNewDeleteTypes(Sema &SemaRef, const FunctionDecl *FnDecl,
16134                              CanQualType ExpectedResultType,
16135                              CanQualType ExpectedFirstParamType,
16136                              unsigned DependentParamTypeDiag,
16137                              unsigned InvalidParamTypeDiag) {
16138    QualType ResultType =
16139        FnDecl->getType()->castAs<FunctionType>()->getReturnType();
16140  
16141    if (SemaRef.getLangOpts().OpenCLCPlusPlus) {
16142      // The operator is valid on any address space for OpenCL.
16143      // Drop address space from actual and expected result types.
16144      if (const auto *PtrTy = ResultType->getAs<PointerType>())
16145        ResultType = RemoveAddressSpaceFromPtr(SemaRef, PtrTy);
16146  
16147      if (auto ExpectedPtrTy = ExpectedResultType->getAs<PointerType>())
16148        ExpectedResultType = RemoveAddressSpaceFromPtr(SemaRef, ExpectedPtrTy);
16149    }
16150  
16151    // Check that the result type is what we expect.
16152    if (SemaRef.Context.getCanonicalType(ResultType) != ExpectedResultType) {
16153      // Reject even if the type is dependent; an operator delete function is
16154      // required to have a non-dependent result type.
16155      return SemaRef.Diag(
16156                 FnDecl->getLocation(),
16157                 ResultType->isDependentType()
16158                     ? diag::err_operator_new_delete_dependent_result_type
16159                     : diag::err_operator_new_delete_invalid_result_type)
16160             << FnDecl->getDeclName() << ExpectedResultType;
16161    }
16162  
16163    // A function template must have at least 2 parameters.
16164    if (FnDecl->getDescribedFunctionTemplate() && FnDecl->getNumParams() < 2)
16165      return SemaRef.Diag(FnDecl->getLocation(),
16166                        diag::err_operator_new_delete_template_too_few_parameters)
16167          << FnDecl->getDeclName();
16168  
16169    // The function decl must have at least 1 parameter.
16170    if (FnDecl->getNumParams() == 0)
16171      return SemaRef.Diag(FnDecl->getLocation(),
16172                          diag::err_operator_new_delete_too_few_parameters)
16173        << FnDecl->getDeclName();
16174  
16175    QualType FirstParamType = FnDecl->getParamDecl(0)->getType();
16176    if (SemaRef.getLangOpts().OpenCLCPlusPlus) {
16177      // The operator is valid on any address space for OpenCL.
16178      // Drop address space from actual and expected first parameter types.
16179      if (const auto *PtrTy =
16180              FnDecl->getParamDecl(0)->getType()->getAs<PointerType>())
16181        FirstParamType = RemoveAddressSpaceFromPtr(SemaRef, PtrTy);
16182  
16183      if (auto ExpectedPtrTy = ExpectedFirstParamType->getAs<PointerType>())
16184        ExpectedFirstParamType =
16185            RemoveAddressSpaceFromPtr(SemaRef, ExpectedPtrTy);
16186    }
16187  
16188    // Check that the first parameter type is what we expect.
16189    if (SemaRef.Context.getCanonicalType(FirstParamType).getUnqualifiedType() !=
16190        ExpectedFirstParamType) {
16191      // The first parameter type is not allowed to be dependent. As a tentative
16192      // DR resolution, we allow a dependent parameter type if it is the right
16193      // type anyway, to allow destroying operator delete in class templates.
16194      return SemaRef.Diag(FnDecl->getLocation(), FirstParamType->isDependentType()
16195                                                     ? DependentParamTypeDiag
16196                                                     : InvalidParamTypeDiag)
16197             << FnDecl->getDeclName() << ExpectedFirstParamType;
16198    }
16199  
16200    return false;
16201  }
16202  
16203  static bool
16204  CheckOperatorNewDeclaration(Sema &SemaRef, const FunctionDecl *FnDecl) {
16205    // C++ [basic.stc.dynamic.allocation]p1:
16206    //   A program is ill-formed if an allocation function is declared in a
16207    //   namespace scope other than global scope or declared static in global
16208    //   scope.
16209    if (CheckOperatorNewDeleteDeclarationScope(SemaRef, FnDecl))
16210      return true;
16211  
16212    CanQualType SizeTy =
16213      SemaRef.Context.getCanonicalType(SemaRef.Context.getSizeType());
16214  
16215    // C++ [basic.stc.dynamic.allocation]p1:
16216    //  The return type shall be void*. The first parameter shall have type
16217    //  std::size_t.
16218    if (CheckOperatorNewDeleteTypes(SemaRef, FnDecl, SemaRef.Context.VoidPtrTy,
16219                                    SizeTy,
16220                                    diag::err_operator_new_dependent_param_type,
16221                                    diag::err_operator_new_param_type))
16222      return true;
16223  
16224    // C++ [basic.stc.dynamic.allocation]p1:
16225    //  The first parameter shall not have an associated default argument.
16226    if (FnDecl->getParamDecl(0)->hasDefaultArg())
16227      return SemaRef.Diag(FnDecl->getLocation(),
16228                          diag::err_operator_new_default_arg)
16229        << FnDecl->getDeclName() << FnDecl->getParamDecl(0)->getDefaultArgRange();
16230  
16231    return false;
16232  }
16233  
16234  static bool
16235  CheckOperatorDeleteDeclaration(Sema &SemaRef, FunctionDecl *FnDecl) {
16236    // C++ [basic.stc.dynamic.deallocation]p1:
16237    //   A program is ill-formed if deallocation functions are declared in a
16238    //   namespace scope other than global scope or declared static in global
16239    //   scope.
16240    if (CheckOperatorNewDeleteDeclarationScope(SemaRef, FnDecl))
16241      return true;
16242  
16243    auto *MD = dyn_cast<CXXMethodDecl>(FnDecl);
16244  
16245    // C++ P0722:
16246    //   Within a class C, the first parameter of a destroying operator delete
16247    //   shall be of type C *. The first parameter of any other deallocation
16248    //   function shall be of type void *.
16249    CanQualType ExpectedFirstParamType =
16250        MD && MD->isDestroyingOperatorDelete()
16251            ? SemaRef.Context.getCanonicalType(SemaRef.Context.getPointerType(
16252                  SemaRef.Context.getRecordType(MD->getParent())))
16253            : SemaRef.Context.VoidPtrTy;
16254  
16255    // C++ [basic.stc.dynamic.deallocation]p2:
16256    //   Each deallocation function shall return void
16257    if (CheckOperatorNewDeleteTypes(
16258            SemaRef, FnDecl, SemaRef.Context.VoidTy, ExpectedFirstParamType,
16259            diag::err_operator_delete_dependent_param_type,
16260            diag::err_operator_delete_param_type))
16261      return true;
16262  
16263    // C++ P0722:
16264    //   A destroying operator delete shall be a usual deallocation function.
16265    if (MD && !MD->getParent()->isDependentContext() &&
16266        MD->isDestroyingOperatorDelete() &&
16267        !SemaRef.isUsualDeallocationFunction(MD)) {
16268      SemaRef.Diag(MD->getLocation(),
16269                   diag::err_destroying_operator_delete_not_usual);
16270      return true;
16271    }
16272  
16273    return false;
16274  }
16275  
16276  bool Sema::CheckOverloadedOperatorDeclaration(FunctionDecl *FnDecl) {
16277    assert(FnDecl && FnDecl->isOverloadedOperator() &&
16278           "Expected an overloaded operator declaration");
16279  
16280    OverloadedOperatorKind Op = FnDecl->getOverloadedOperator();
16281  
16282    // C++ [over.oper]p5:
16283    //   The allocation and deallocation functions, operator new,
16284    //   operator new[], operator delete and operator delete[], are
16285    //   described completely in 3.7.3. The attributes and restrictions
16286    //   found in the rest of this subclause do not apply to them unless
16287    //   explicitly stated in 3.7.3.
16288    if (Op == OO_Delete || Op == OO_Array_Delete)
16289      return CheckOperatorDeleteDeclaration(*this, FnDecl);
16290  
16291    if (Op == OO_New || Op == OO_Array_New)
16292      return CheckOperatorNewDeclaration(*this, FnDecl);
16293  
16294    // C++ [over.oper]p7:
16295    //   An operator function shall either be a member function or
16296    //   be a non-member function and have at least one parameter
16297    //   whose type is a class, a reference to a class, an enumeration,
16298    //   or a reference to an enumeration.
16299    // Note: Before C++23, a member function could not be static. The only member
16300    //       function allowed to be static is the call operator function.
16301    if (CXXMethodDecl *MethodDecl = dyn_cast<CXXMethodDecl>(FnDecl)) {
16302      if (MethodDecl->isStatic()) {
16303        if (Op == OO_Call || Op == OO_Subscript)
16304          Diag(FnDecl->getLocation(),
16305               (LangOpts.CPlusPlus23
16306                    ? diag::warn_cxx20_compat_operator_overload_static
16307                    : diag::ext_operator_overload_static))
16308              << FnDecl;
16309        else
16310          return Diag(FnDecl->getLocation(), diag::err_operator_overload_static)
16311                 << FnDecl;
16312      }
16313    } else {
16314      bool ClassOrEnumParam = false;
16315      for (auto *Param : FnDecl->parameters()) {
16316        QualType ParamType = Param->getType().getNonReferenceType();
16317        if (ParamType->isDependentType() || ParamType->isRecordType() ||
16318            ParamType->isEnumeralType()) {
16319          ClassOrEnumParam = true;
16320          break;
16321        }
16322      }
16323  
16324      if (!ClassOrEnumParam)
16325        return Diag(FnDecl->getLocation(),
16326                    diag::err_operator_overload_needs_class_or_enum)
16327          << FnDecl->getDeclName();
16328    }
16329  
16330    // C++ [over.oper]p8:
16331    //   An operator function cannot have default arguments (8.3.6),
16332    //   except where explicitly stated below.
16333    //
16334    // Only the function-call operator (C++ [over.call]p1) and the subscript
16335    // operator (CWG2507) allow default arguments.
16336    if (Op != OO_Call) {
16337      ParmVarDecl *FirstDefaultedParam = nullptr;
16338      for (auto *Param : FnDecl->parameters()) {
16339        if (Param->hasDefaultArg()) {
16340          FirstDefaultedParam = Param;
16341          break;
16342        }
16343      }
16344      if (FirstDefaultedParam) {
16345        if (Op == OO_Subscript) {
16346          Diag(FnDecl->getLocation(), LangOpts.CPlusPlus23
16347                                          ? diag::ext_subscript_overload
16348                                          : diag::error_subscript_overload)
16349              << FnDecl->getDeclName() << 1
16350              << FirstDefaultedParam->getDefaultArgRange();
16351        } else {
16352          return Diag(FirstDefaultedParam->getLocation(),
16353                      diag::err_operator_overload_default_arg)
16354                 << FnDecl->getDeclName()
16355                 << FirstDefaultedParam->getDefaultArgRange();
16356        }
16357      }
16358    }
16359  
16360    static const bool OperatorUses[NUM_OVERLOADED_OPERATORS][3] = {
16361      { false, false, false }
16362  #define OVERLOADED_OPERATOR(Name,Spelling,Token,Unary,Binary,MemberOnly) \
16363      , { Unary, Binary, MemberOnly }
16364  #include "clang/Basic/OperatorKinds.def"
16365    };
16366  
16367    bool CanBeUnaryOperator = OperatorUses[Op][0];
16368    bool CanBeBinaryOperator = OperatorUses[Op][1];
16369    bool MustBeMemberOperator = OperatorUses[Op][2];
16370  
16371    // C++ [over.oper]p8:
16372    //   [...] Operator functions cannot have more or fewer parameters
16373    //   than the number required for the corresponding operator, as
16374    //   described in the rest of this subclause.
16375    unsigned NumParams = FnDecl->getNumParams() +
16376                         (isa<CXXMethodDecl>(FnDecl) &&
16377                                  !FnDecl->hasCXXExplicitFunctionObjectParameter()
16378                              ? 1
16379                              : 0);
16380    if (Op != OO_Call && Op != OO_Subscript &&
16381        ((NumParams == 1 && !CanBeUnaryOperator) ||
16382         (NumParams == 2 && !CanBeBinaryOperator) || (NumParams < 1) ||
16383         (NumParams > 2))) {
16384      // We have the wrong number of parameters.
16385      unsigned ErrorKind;
16386      if (CanBeUnaryOperator && CanBeBinaryOperator) {
16387        ErrorKind = 2;  // 2 -> unary or binary.
16388      } else if (CanBeUnaryOperator) {
16389        ErrorKind = 0;  // 0 -> unary
16390      } else {
16391        assert(CanBeBinaryOperator &&
16392               "All non-call overloaded operators are unary or binary!");
16393        ErrorKind = 1;  // 1 -> binary
16394      }
16395      return Diag(FnDecl->getLocation(), diag::err_operator_overload_must_be)
16396        << FnDecl->getDeclName() << NumParams << ErrorKind;
16397    }
16398  
16399    if (Op == OO_Subscript && NumParams != 2) {
16400      Diag(FnDecl->getLocation(), LangOpts.CPlusPlus23
16401                                      ? diag::ext_subscript_overload
16402                                      : diag::error_subscript_overload)
16403          << FnDecl->getDeclName() << (NumParams == 1 ? 0 : 2);
16404    }
16405  
16406    // Overloaded operators other than operator() and operator[] cannot be
16407    // variadic.
16408    if (Op != OO_Call &&
16409        FnDecl->getType()->castAs<FunctionProtoType>()->isVariadic()) {
16410      return Diag(FnDecl->getLocation(), diag::err_operator_overload_variadic)
16411             << FnDecl->getDeclName();
16412    }
16413  
16414    // Some operators must be member functions.
16415    if (MustBeMemberOperator && !isa<CXXMethodDecl>(FnDecl)) {
16416      return Diag(FnDecl->getLocation(),
16417                  diag::err_operator_overload_must_be_member)
16418        << FnDecl->getDeclName();
16419    }
16420  
16421    // C++ [over.inc]p1:
16422    //   The user-defined function called operator++ implements the
16423    //   prefix and postfix ++ operator. If this function is a member
16424    //   function with no parameters, or a non-member function with one
16425    //   parameter of class or enumeration type, it defines the prefix
16426    //   increment operator ++ for objects of that type. If the function
16427    //   is a member function with one parameter (which shall be of type
16428    //   int) or a non-member function with two parameters (the second
16429    //   of which shall be of type int), it defines the postfix
16430    //   increment operator ++ for objects of that type.
16431    if ((Op == OO_PlusPlus || Op == OO_MinusMinus) && NumParams == 2) {
16432      ParmVarDecl *LastParam = FnDecl->getParamDecl(FnDecl->getNumParams() - 1);
16433      QualType ParamType = LastParam->getType();
16434  
16435      if (!ParamType->isSpecificBuiltinType(BuiltinType::Int) &&
16436          !ParamType->isDependentType())
16437        return Diag(LastParam->getLocation(),
16438                    diag::err_operator_overload_post_incdec_must_be_int)
16439          << LastParam->getType() << (Op == OO_MinusMinus);
16440    }
16441  
16442    return false;
16443  }
16444  
16445  static bool
16446  checkLiteralOperatorTemplateParameterList(Sema &SemaRef,
16447                                            FunctionTemplateDecl *TpDecl) {
16448    TemplateParameterList *TemplateParams = TpDecl->getTemplateParameters();
16449  
16450    // Must have one or two template parameters.
16451    if (TemplateParams->size() == 1) {
16452      NonTypeTemplateParmDecl *PmDecl =
16453          dyn_cast<NonTypeTemplateParmDecl>(TemplateParams->getParam(0));
16454  
16455      // The template parameter must be a char parameter pack.
16456      if (PmDecl && PmDecl->isTemplateParameterPack() &&
16457          SemaRef.Context.hasSameType(PmDecl->getType(), SemaRef.Context.CharTy))
16458        return false;
16459  
16460      // C++20 [over.literal]p5:
16461      //   A string literal operator template is a literal operator template
16462      //   whose template-parameter-list comprises a single non-type
16463      //   template-parameter of class type.
16464      //
16465      // As a DR resolution, we also allow placeholders for deduced class
16466      // template specializations.
16467      if (SemaRef.getLangOpts().CPlusPlus20 && PmDecl &&
16468          !PmDecl->isTemplateParameterPack() &&
16469          (PmDecl->getType()->isRecordType() ||
16470           PmDecl->getType()->getAs<DeducedTemplateSpecializationType>()))
16471        return false;
16472    } else if (TemplateParams->size() == 2) {
16473      TemplateTypeParmDecl *PmType =
16474          dyn_cast<TemplateTypeParmDecl>(TemplateParams->getParam(0));
16475      NonTypeTemplateParmDecl *PmArgs =
16476          dyn_cast<NonTypeTemplateParmDecl>(TemplateParams->getParam(1));
16477  
16478      // The second template parameter must be a parameter pack with the
16479      // first template parameter as its type.
16480      if (PmType && PmArgs && !PmType->isTemplateParameterPack() &&
16481          PmArgs->isTemplateParameterPack()) {
16482        const TemplateTypeParmType *TArgs =
16483            PmArgs->getType()->getAs<TemplateTypeParmType>();
16484        if (TArgs && TArgs->getDepth() == PmType->getDepth() &&
16485            TArgs->getIndex() == PmType->getIndex()) {
16486          if (!SemaRef.inTemplateInstantiation())
16487            SemaRef.Diag(TpDecl->getLocation(),
16488                         diag::ext_string_literal_operator_template);
16489          return false;
16490        }
16491      }
16492    }
16493  
16494    SemaRef.Diag(TpDecl->getTemplateParameters()->getSourceRange().getBegin(),
16495                 diag::err_literal_operator_template)
16496        << TpDecl->getTemplateParameters()->getSourceRange();
16497    return true;
16498  }
16499  
16500  bool Sema::CheckLiteralOperatorDeclaration(FunctionDecl *FnDecl) {
16501    if (isa<CXXMethodDecl>(FnDecl)) {
16502      Diag(FnDecl->getLocation(), diag::err_literal_operator_outside_namespace)
16503        << FnDecl->getDeclName();
16504      return true;
16505    }
16506  
16507    if (FnDecl->isExternC()) {
16508      Diag(FnDecl->getLocation(), diag::err_literal_operator_extern_c);
16509      if (const LinkageSpecDecl *LSD =
16510              FnDecl->getDeclContext()->getExternCContext())
16511        Diag(LSD->getExternLoc(), diag::note_extern_c_begins_here);
16512      return true;
16513    }
16514  
16515    // This might be the definition of a literal operator template.
16516    FunctionTemplateDecl *TpDecl = FnDecl->getDescribedFunctionTemplate();
16517  
16518    // This might be a specialization of a literal operator template.
16519    if (!TpDecl)
16520      TpDecl = FnDecl->getPrimaryTemplate();
16521  
16522    // template <char...> type operator "" name() and
16523    // template <class T, T...> type operator "" name() are the only valid
16524    // template signatures, and the only valid signatures with no parameters.
16525    //
16526    // C++20 also allows template <SomeClass T> type operator "" name().
16527    if (TpDecl) {
16528      if (FnDecl->param_size() != 0) {
16529        Diag(FnDecl->getLocation(),
16530             diag::err_literal_operator_template_with_params);
16531        return true;
16532      }
16533  
16534      if (checkLiteralOperatorTemplateParameterList(*this, TpDecl))
16535        return true;
16536  
16537    } else if (FnDecl->param_size() == 1) {
16538      const ParmVarDecl *Param = FnDecl->getParamDecl(0);
16539  
16540      QualType ParamType = Param->getType().getUnqualifiedType();
16541  
16542      // Only unsigned long long int, long double, any character type, and const
16543      // char * are allowed as the only parameters.
16544      if (ParamType->isSpecificBuiltinType(BuiltinType::ULongLong) ||
16545          ParamType->isSpecificBuiltinType(BuiltinType::LongDouble) ||
16546          Context.hasSameType(ParamType, Context.CharTy) ||
16547          Context.hasSameType(ParamType, Context.WideCharTy) ||
16548          Context.hasSameType(ParamType, Context.Char8Ty) ||
16549          Context.hasSameType(ParamType, Context.Char16Ty) ||
16550          Context.hasSameType(ParamType, Context.Char32Ty)) {
16551      } else if (const PointerType *Ptr = ParamType->getAs<PointerType>()) {
16552        QualType InnerType = Ptr->getPointeeType();
16553  
16554        // Pointer parameter must be a const char *.
16555        if (!(Context.hasSameType(InnerType.getUnqualifiedType(),
16556                                  Context.CharTy) &&
16557              InnerType.isConstQualified() && !InnerType.isVolatileQualified())) {
16558          Diag(Param->getSourceRange().getBegin(),
16559               diag::err_literal_operator_param)
16560              << ParamType << "'const char *'" << Param->getSourceRange();
16561          return true;
16562        }
16563  
16564      } else if (ParamType->isRealFloatingType()) {
16565        Diag(Param->getSourceRange().getBegin(), diag::err_literal_operator_param)
16566            << ParamType << Context.LongDoubleTy << Param->getSourceRange();
16567        return true;
16568  
16569      } else if (ParamType->isIntegerType()) {
16570        Diag(Param->getSourceRange().getBegin(), diag::err_literal_operator_param)
16571            << ParamType << Context.UnsignedLongLongTy << Param->getSourceRange();
16572        return true;
16573  
16574      } else {
16575        Diag(Param->getSourceRange().getBegin(),
16576             diag::err_literal_operator_invalid_param)
16577            << ParamType << Param->getSourceRange();
16578        return true;
16579      }
16580  
16581    } else if (FnDecl->param_size() == 2) {
16582      FunctionDecl::param_iterator Param = FnDecl->param_begin();
16583  
16584      // First, verify that the first parameter is correct.
16585  
16586      QualType FirstParamType = (*Param)->getType().getUnqualifiedType();
16587  
16588      // Two parameter function must have a pointer to const as a
16589      // first parameter; let's strip those qualifiers.
16590      const PointerType *PT = FirstParamType->getAs<PointerType>();
16591  
16592      if (!PT) {
16593        Diag((*Param)->getSourceRange().getBegin(),
16594             diag::err_literal_operator_param)
16595            << FirstParamType << "'const char *'" << (*Param)->getSourceRange();
16596        return true;
16597      }
16598  
16599      QualType PointeeType = PT->getPointeeType();
16600      // First parameter must be const
16601      if (!PointeeType.isConstQualified() || PointeeType.isVolatileQualified()) {
16602        Diag((*Param)->getSourceRange().getBegin(),
16603             diag::err_literal_operator_param)
16604            << FirstParamType << "'const char *'" << (*Param)->getSourceRange();
16605        return true;
16606      }
16607  
16608      QualType InnerType = PointeeType.getUnqualifiedType();
16609      // Only const char *, const wchar_t*, const char8_t*, const char16_t*, and
16610      // const char32_t* are allowed as the first parameter to a two-parameter
16611      // function
16612      if (!(Context.hasSameType(InnerType, Context.CharTy) ||
16613            Context.hasSameType(InnerType, Context.WideCharTy) ||
16614            Context.hasSameType(InnerType, Context.Char8Ty) ||
16615            Context.hasSameType(InnerType, Context.Char16Ty) ||
16616            Context.hasSameType(InnerType, Context.Char32Ty))) {
16617        Diag((*Param)->getSourceRange().getBegin(),
16618             diag::err_literal_operator_param)
16619            << FirstParamType << "'const char *'" << (*Param)->getSourceRange();
16620        return true;
16621      }
16622  
16623      // Move on to the second and final parameter.
16624      ++Param;
16625  
16626      // The second parameter must be a std::size_t.
16627      QualType SecondParamType = (*Param)->getType().getUnqualifiedType();
16628      if (!Context.hasSameType(SecondParamType, Context.getSizeType())) {
16629        Diag((*Param)->getSourceRange().getBegin(),
16630             diag::err_literal_operator_param)
16631            << SecondParamType << Context.getSizeType()
16632            << (*Param)->getSourceRange();
16633        return true;
16634      }
16635    } else {
16636      Diag(FnDecl->getLocation(), diag::err_literal_operator_bad_param_count);
16637      return true;
16638    }
16639  
16640    // Parameters are good.
16641  
16642    // A parameter-declaration-clause containing a default argument is not
16643    // equivalent to any of the permitted forms.
16644    for (auto *Param : FnDecl->parameters()) {
16645      if (Param->hasDefaultArg()) {
16646        Diag(Param->getDefaultArgRange().getBegin(),
16647             diag::err_literal_operator_default_argument)
16648          << Param->getDefaultArgRange();
16649        break;
16650      }
16651    }
16652  
16653    const IdentifierInfo *II = FnDecl->getDeclName().getCXXLiteralIdentifier();
16654    ReservedLiteralSuffixIdStatus Status = II->isReservedLiteralSuffixId();
16655    if (Status != ReservedLiteralSuffixIdStatus::NotReserved &&
16656        !getSourceManager().isInSystemHeader(FnDecl->getLocation())) {
16657      // C++23 [usrlit.suffix]p1:
16658      //   Literal suffix identifiers that do not start with an underscore are
16659      //   reserved for future standardization. Literal suffix identifiers that
16660      //   contain a double underscore __ are reserved for use by C++
16661      //   implementations.
16662      Diag(FnDecl->getLocation(), diag::warn_user_literal_reserved)
16663          << static_cast<int>(Status)
16664          << StringLiteralParser::isValidUDSuffix(getLangOpts(), II->getName());
16665    }
16666  
16667    return false;
16668  }
16669  
16670  Decl *Sema::ActOnStartLinkageSpecification(Scope *S, SourceLocation ExternLoc,
16671                                             Expr *LangStr,
16672                                             SourceLocation LBraceLoc) {
16673    StringLiteral *Lit = cast<StringLiteral>(LangStr);
16674    assert(Lit->isUnevaluated() && "Unexpected string literal kind");
16675  
16676    StringRef Lang = Lit->getString();
16677    LinkageSpecLanguageIDs Language;
16678    if (Lang == "C")
16679      Language = LinkageSpecLanguageIDs::C;
16680    else if (Lang == "C++")
16681      Language = LinkageSpecLanguageIDs::CXX;
16682    else {
16683      Diag(LangStr->getExprLoc(), diag::err_language_linkage_spec_unknown)
16684        << LangStr->getSourceRange();
16685      return nullptr;
16686    }
16687  
16688    // FIXME: Add all the various semantics of linkage specifications
16689  
16690    LinkageSpecDecl *D = LinkageSpecDecl::Create(Context, CurContext, ExternLoc,
16691                                                 LangStr->getExprLoc(), Language,
16692                                                 LBraceLoc.isValid());
16693  
16694    /// C++ [module.unit]p7.2.3
16695    /// - Otherwise, if the declaration
16696    ///   - ...
16697    ///   - ...
16698    ///   - appears within a linkage-specification,
16699    ///   it is attached to the global module.
16700    ///
16701    /// If the declaration is already in global module fragment, we don't
16702    /// need to attach it again.
16703    if (getLangOpts().CPlusPlusModules && isCurrentModulePurview()) {
16704      Module *GlobalModule = PushImplicitGlobalModuleFragment(ExternLoc);
16705      D->setLocalOwningModule(GlobalModule);
16706    }
16707  
16708    CurContext->addDecl(D);
16709    PushDeclContext(S, D);
16710    return D;
16711  }
16712  
16713  Decl *Sema::ActOnFinishLinkageSpecification(Scope *S,
16714                                              Decl *LinkageSpec,
16715                                              SourceLocation RBraceLoc) {
16716    if (RBraceLoc.isValid()) {
16717      LinkageSpecDecl* LSDecl = cast<LinkageSpecDecl>(LinkageSpec);
16718      LSDecl->setRBraceLoc(RBraceLoc);
16719    }
16720  
16721    // If the current module doesn't has Parent, it implies that the
16722    // LinkageSpec isn't in the module created by itself. So we don't
16723    // need to pop it.
16724    if (getLangOpts().CPlusPlusModules && getCurrentModule() &&
16725        getCurrentModule()->isImplicitGlobalModule() &&
16726        getCurrentModule()->Parent)
16727      PopImplicitGlobalModuleFragment();
16728  
16729    PopDeclContext();
16730    return LinkageSpec;
16731  }
16732  
16733  Decl *Sema::ActOnEmptyDeclaration(Scope *S,
16734                                    const ParsedAttributesView &AttrList,
16735                                    SourceLocation SemiLoc) {
16736    Decl *ED = EmptyDecl::Create(Context, CurContext, SemiLoc);
16737    // Attribute declarations appertain to empty declaration so we handle
16738    // them here.
16739    ProcessDeclAttributeList(S, ED, AttrList);
16740  
16741    CurContext->addDecl(ED);
16742    return ED;
16743  }
16744  
16745  VarDecl *Sema::BuildExceptionDeclaration(Scope *S, TypeSourceInfo *TInfo,
16746                                           SourceLocation StartLoc,
16747                                           SourceLocation Loc,
16748                                           const IdentifierInfo *Name) {
16749    bool Invalid = false;
16750    QualType ExDeclType = TInfo->getType();
16751  
16752    // Arrays and functions decay.
16753    if (ExDeclType->isArrayType())
16754      ExDeclType = Context.getArrayDecayedType(ExDeclType);
16755    else if (ExDeclType->isFunctionType())
16756      ExDeclType = Context.getPointerType(ExDeclType);
16757  
16758    // C++ 15.3p1: The exception-declaration shall not denote an incomplete type.
16759    // The exception-declaration shall not denote a pointer or reference to an
16760    // incomplete type, other than [cv] void*.
16761    // N2844 forbids rvalue references.
16762    if (!ExDeclType->isDependentType() && ExDeclType->isRValueReferenceType()) {
16763      Diag(Loc, diag::err_catch_rvalue_ref);
16764      Invalid = true;
16765    }
16766  
16767    if (ExDeclType->isVariablyModifiedType()) {
16768      Diag(Loc, diag::err_catch_variably_modified) << ExDeclType;
16769      Invalid = true;
16770    }
16771  
16772    QualType BaseType = ExDeclType;
16773    int Mode = 0; // 0 for direct type, 1 for pointer, 2 for reference
16774    unsigned DK = diag::err_catch_incomplete;
16775    if (const PointerType *Ptr = BaseType->getAs<PointerType>()) {
16776      BaseType = Ptr->getPointeeType();
16777      Mode = 1;
16778      DK = diag::err_catch_incomplete_ptr;
16779    } else if (const ReferenceType *Ref = BaseType->getAs<ReferenceType>()) {
16780      // For the purpose of error recovery, we treat rvalue refs like lvalue refs.
16781      BaseType = Ref->getPointeeType();
16782      Mode = 2;
16783      DK = diag::err_catch_incomplete_ref;
16784    }
16785    if (!Invalid && (Mode == 0 || !BaseType->isVoidType()) &&
16786        !BaseType->isDependentType() && RequireCompleteType(Loc, BaseType, DK))
16787      Invalid = true;
16788  
16789    if (!Invalid && BaseType.isWebAssemblyReferenceType()) {
16790      Diag(Loc, diag::err_wasm_reftype_tc) << 1;
16791      Invalid = true;
16792    }
16793  
16794    if (!Invalid && Mode != 1 && BaseType->isSizelessType()) {
16795      Diag(Loc, diag::err_catch_sizeless) << (Mode == 2 ? 1 : 0) << BaseType;
16796      Invalid = true;
16797    }
16798  
16799    if (!Invalid && !ExDeclType->isDependentType() &&
16800        RequireNonAbstractType(Loc, ExDeclType,
16801                               diag::err_abstract_type_in_decl,
16802                               AbstractVariableType))
16803      Invalid = true;
16804  
16805    // Only the non-fragile NeXT runtime currently supports C++ catches
16806    // of ObjC types, and no runtime supports catching ObjC types by value.
16807    if (!Invalid && getLangOpts().ObjC) {
16808      QualType T = ExDeclType;
16809      if (const ReferenceType *RT = T->getAs<ReferenceType>())
16810        T = RT->getPointeeType();
16811  
16812      if (T->isObjCObjectType()) {
16813        Diag(Loc, diag::err_objc_object_catch);
16814        Invalid = true;
16815      } else if (T->isObjCObjectPointerType()) {
16816        // FIXME: should this be a test for macosx-fragile specifically?
16817        if (getLangOpts().ObjCRuntime.isFragile())
16818          Diag(Loc, diag::warn_objc_pointer_cxx_catch_fragile);
16819      }
16820    }
16821  
16822    VarDecl *ExDecl = VarDecl::Create(Context, CurContext, StartLoc, Loc, Name,
16823                                      ExDeclType, TInfo, SC_None);
16824    ExDecl->setExceptionVariable(true);
16825  
16826    // In ARC, infer 'retaining' for variables of retainable type.
16827    if (getLangOpts().ObjCAutoRefCount && ObjC().inferObjCARCLifetime(ExDecl))
16828      Invalid = true;
16829  
16830    if (!Invalid && !ExDeclType->isDependentType()) {
16831      if (const RecordType *recordType = ExDeclType->getAs<RecordType>()) {
16832        // Insulate this from anything else we might currently be parsing.
16833        EnterExpressionEvaluationContext scope(
16834            *this, ExpressionEvaluationContext::PotentiallyEvaluated);
16835  
16836        // C++ [except.handle]p16:
16837        //   The object declared in an exception-declaration or, if the
16838        //   exception-declaration does not specify a name, a temporary (12.2) is
16839        //   copy-initialized (8.5) from the exception object. [...]
16840        //   The object is destroyed when the handler exits, after the destruction
16841        //   of any automatic objects initialized within the handler.
16842        //
16843        // We just pretend to initialize the object with itself, then make sure
16844        // it can be destroyed later.
16845        QualType initType = Context.getExceptionObjectType(ExDeclType);
16846  
16847        InitializedEntity entity =
16848          InitializedEntity::InitializeVariable(ExDecl);
16849        InitializationKind initKind =
16850          InitializationKind::CreateCopy(Loc, SourceLocation());
16851  
16852        Expr *opaqueValue =
16853          new (Context) OpaqueValueExpr(Loc, initType, VK_LValue, OK_Ordinary);
16854        InitializationSequence sequence(*this, entity, initKind, opaqueValue);
16855        ExprResult result = sequence.Perform(*this, entity, initKind, opaqueValue);
16856        if (result.isInvalid())
16857          Invalid = true;
16858        else {
16859          // If the constructor used was non-trivial, set this as the
16860          // "initializer".
16861          CXXConstructExpr *construct = result.getAs<CXXConstructExpr>();
16862          if (!construct->getConstructor()->isTrivial()) {
16863            Expr *init = MaybeCreateExprWithCleanups(construct);
16864            ExDecl->setInit(init);
16865          }
16866  
16867          // And make sure it's destructable.
16868          FinalizeVarWithDestructor(ExDecl, recordType);
16869        }
16870      }
16871    }
16872  
16873    if (Invalid)
16874      ExDecl->setInvalidDecl();
16875  
16876    return ExDecl;
16877  }
16878  
16879  Decl *Sema::ActOnExceptionDeclarator(Scope *S, Declarator &D) {
16880    TypeSourceInfo *TInfo = GetTypeForDeclarator(D);
16881    bool Invalid = D.isInvalidType();
16882  
16883    // Check for unexpanded parameter packs.
16884    if (DiagnoseUnexpandedParameterPack(D.getIdentifierLoc(), TInfo,
16885                                        UPPC_ExceptionType)) {
16886      TInfo = Context.getTrivialTypeSourceInfo(Context.IntTy,
16887                                               D.getIdentifierLoc());
16888      Invalid = true;
16889    }
16890  
16891    const IdentifierInfo *II = D.getIdentifier();
16892    if (NamedDecl *PrevDecl =
16893            LookupSingleName(S, II, D.getIdentifierLoc(), LookupOrdinaryName,
16894                             RedeclarationKind::ForVisibleRedeclaration)) {
16895      // The scope should be freshly made just for us. There is just no way
16896      // it contains any previous declaration, except for function parameters in
16897      // a function-try-block's catch statement.
16898      assert(!S->isDeclScope(PrevDecl));
16899      if (isDeclInScope(PrevDecl, CurContext, S)) {
16900        Diag(D.getIdentifierLoc(), diag::err_redefinition)
16901          << D.getIdentifier();
16902        Diag(PrevDecl->getLocation(), diag::note_previous_definition);
16903        Invalid = true;
16904      } else if (PrevDecl->isTemplateParameter())
16905        // Maybe we will complain about the shadowed template parameter.
16906        DiagnoseTemplateParameterShadow(D.getIdentifierLoc(), PrevDecl);
16907    }
16908  
16909    if (D.getCXXScopeSpec().isSet() && !Invalid) {
16910      Diag(D.getIdentifierLoc(), diag::err_qualified_catch_declarator)
16911        << D.getCXXScopeSpec().getRange();
16912      Invalid = true;
16913    }
16914  
16915    VarDecl *ExDecl = BuildExceptionDeclaration(
16916        S, TInfo, D.getBeginLoc(), D.getIdentifierLoc(), D.getIdentifier());
16917    if (Invalid)
16918      ExDecl->setInvalidDecl();
16919  
16920    // Add the exception declaration into this scope.
16921    if (II)
16922      PushOnScopeChains(ExDecl, S);
16923    else
16924      CurContext->addDecl(ExDecl);
16925  
16926    ProcessDeclAttributes(S, ExDecl, D);
16927    return ExDecl;
16928  }
16929  
16930  Decl *Sema::ActOnStaticAssertDeclaration(SourceLocation StaticAssertLoc,
16931                                           Expr *AssertExpr,
16932                                           Expr *AssertMessageExpr,
16933                                           SourceLocation RParenLoc) {
16934    if (DiagnoseUnexpandedParameterPack(AssertExpr, UPPC_StaticAssertExpression))
16935      return nullptr;
16936  
16937    return BuildStaticAssertDeclaration(StaticAssertLoc, AssertExpr,
16938                                        AssertMessageExpr, RParenLoc, false);
16939  }
16940  
16941  static void WriteCharTypePrefix(BuiltinType::Kind BTK, llvm::raw_ostream &OS) {
16942    switch (BTK) {
16943    case BuiltinType::Char_S:
16944    case BuiltinType::Char_U:
16945      break;
16946    case BuiltinType::Char8:
16947      OS << "u8";
16948      break;
16949    case BuiltinType::Char16:
16950      OS << 'u';
16951      break;
16952    case BuiltinType::Char32:
16953      OS << 'U';
16954      break;
16955    case BuiltinType::WChar_S:
16956    case BuiltinType::WChar_U:
16957      OS << 'L';
16958      break;
16959    default:
16960      llvm_unreachable("Non-character type");
16961    }
16962  }
16963  
16964  /// Convert character's value, interpreted as a code unit, to a string.
16965  /// The value needs to be zero-extended to 32-bits.
16966  /// FIXME: This assumes Unicode literal encodings
16967  static void WriteCharValueForDiagnostic(uint32_t Value, const BuiltinType *BTy,
16968                                          unsigned TyWidth,
16969                                          SmallVectorImpl<char> &Str) {
16970    char Arr[UNI_MAX_UTF8_BYTES_PER_CODE_POINT];
16971    char *Ptr = Arr;
16972    BuiltinType::Kind K = BTy->getKind();
16973    llvm::raw_svector_ostream OS(Str);
16974  
16975    // This should catch Char_S, Char_U, Char8, and use of escaped characters in
16976    // other types.
16977    if (K == BuiltinType::Char_S || K == BuiltinType::Char_U ||
16978        K == BuiltinType::Char8 || Value <= 0x7F) {
16979      StringRef Escaped = escapeCStyle<EscapeChar::Single>(Value);
16980      if (!Escaped.empty())
16981        EscapeStringForDiagnostic(Escaped, Str);
16982      else
16983        OS << static_cast<char>(Value);
16984      return;
16985    }
16986  
16987    switch (K) {
16988    case BuiltinType::Char16:
16989    case BuiltinType::Char32:
16990    case BuiltinType::WChar_S:
16991    case BuiltinType::WChar_U: {
16992      if (llvm::ConvertCodePointToUTF8(Value, Ptr))
16993        EscapeStringForDiagnostic(StringRef(Arr, Ptr - Arr), Str);
16994      else
16995        OS << "\\x"
16996           << llvm::format_hex_no_prefix(Value, TyWidth / 4, /*Upper=*/true);
16997      break;
16998    }
16999    default:
17000      llvm_unreachable("Non-character type is passed");
17001    }
17002  }
17003  
17004  /// Convert \V to a string we can present to the user in a diagnostic
17005  /// \T is the type of the expression that has been evaluated into \V
17006  static bool ConvertAPValueToString(const APValue &V, QualType T,
17007                                     SmallVectorImpl<char> &Str,
17008                                     ASTContext &Context) {
17009    if (!V.hasValue())
17010      return false;
17011  
17012    switch (V.getKind()) {
17013    case APValue::ValueKind::Int:
17014      if (T->isBooleanType()) {
17015        // Bools are reduced to ints during evaluation, but for
17016        // diagnostic purposes we want to print them as
17017        // true or false.
17018        int64_t BoolValue = V.getInt().getExtValue();
17019        assert((BoolValue == 0 || BoolValue == 1) &&
17020               "Bool type, but value is not 0 or 1");
17021        llvm::raw_svector_ostream OS(Str);
17022        OS << (BoolValue ? "true" : "false");
17023      } else {
17024        llvm::raw_svector_ostream OS(Str);
17025        // Same is true for chars.
17026        // We want to print the character representation for textual types
17027        const auto *BTy = T->getAs<BuiltinType>();
17028        if (BTy) {
17029          switch (BTy->getKind()) {
17030          case BuiltinType::Char_S:
17031          case BuiltinType::Char_U:
17032          case BuiltinType::Char8:
17033          case BuiltinType::Char16:
17034          case BuiltinType::Char32:
17035          case BuiltinType::WChar_S:
17036          case BuiltinType::WChar_U: {
17037            unsigned TyWidth = Context.getIntWidth(T);
17038            assert(8 <= TyWidth && TyWidth <= 32 && "Unexpected integer width");
17039            uint32_t CodeUnit = static_cast<uint32_t>(V.getInt().getZExtValue());
17040            WriteCharTypePrefix(BTy->getKind(), OS);
17041            OS << '\'';
17042            WriteCharValueForDiagnostic(CodeUnit, BTy, TyWidth, Str);
17043            OS << "' (0x"
17044               << llvm::format_hex_no_prefix(CodeUnit, /*Width=*/2,
17045                                             /*Upper=*/true)
17046               << ", " << V.getInt() << ')';
17047            return true;
17048          }
17049          default:
17050            break;
17051          }
17052        }
17053        V.getInt().toString(Str);
17054      }
17055  
17056      break;
17057  
17058    case APValue::ValueKind::Float:
17059      V.getFloat().toString(Str);
17060      break;
17061  
17062    case APValue::ValueKind::LValue:
17063      if (V.isNullPointer()) {
17064        llvm::raw_svector_ostream OS(Str);
17065        OS << "nullptr";
17066      } else
17067        return false;
17068      break;
17069  
17070    case APValue::ValueKind::ComplexFloat: {
17071      llvm::raw_svector_ostream OS(Str);
17072      OS << '(';
17073      V.getComplexFloatReal().toString(Str);
17074      OS << " + ";
17075      V.getComplexFloatImag().toString(Str);
17076      OS << "i)";
17077    } break;
17078  
17079    case APValue::ValueKind::ComplexInt: {
17080      llvm::raw_svector_ostream OS(Str);
17081      OS << '(';
17082      V.getComplexIntReal().toString(Str);
17083      OS << " + ";
17084      V.getComplexIntImag().toString(Str);
17085      OS << "i)";
17086    } break;
17087  
17088    default:
17089      return false;
17090    }
17091  
17092    return true;
17093  }
17094  
17095  /// Some Expression types are not useful to print notes about,
17096  /// e.g. literals and values that have already been expanded
17097  /// before such as int-valued template parameters.
17098  static bool UsefulToPrintExpr(const Expr *E) {
17099    E = E->IgnoreParenImpCasts();
17100    // Literals are pretty easy for humans to understand.
17101    if (isa<IntegerLiteral, FloatingLiteral, CharacterLiteral, CXXBoolLiteralExpr,
17102            CXXNullPtrLiteralExpr, FixedPointLiteral, ImaginaryLiteral>(E))
17103      return false;
17104  
17105    // These have been substituted from template parameters
17106    // and appear as literals in the static assert error.
17107    if (isa<SubstNonTypeTemplateParmExpr>(E))
17108      return false;
17109  
17110    // -5 is also simple to understand.
17111    if (const auto *UnaryOp = dyn_cast<UnaryOperator>(E))
17112      return UsefulToPrintExpr(UnaryOp->getSubExpr());
17113  
17114    // Only print nested arithmetic operators.
17115    if (const auto *BO = dyn_cast<BinaryOperator>(E))
17116      return (BO->isShiftOp() || BO->isAdditiveOp() || BO->isMultiplicativeOp() ||
17117              BO->isBitwiseOp());
17118  
17119    return true;
17120  }
17121  
17122  void Sema::DiagnoseStaticAssertDetails(const Expr *E) {
17123    if (const auto *Op = dyn_cast<BinaryOperator>(E);
17124        Op && Op->getOpcode() != BO_LOr) {
17125      const Expr *LHS = Op->getLHS()->IgnoreParenImpCasts();
17126      const Expr *RHS = Op->getRHS()->IgnoreParenImpCasts();
17127  
17128      // Ignore comparisons of boolean expressions with a boolean literal.
17129      if ((isa<CXXBoolLiteralExpr>(LHS) && RHS->getType()->isBooleanType()) ||
17130          (isa<CXXBoolLiteralExpr>(RHS) && LHS->getType()->isBooleanType()))
17131        return;
17132  
17133      // Don't print obvious expressions.
17134      if (!UsefulToPrintExpr(LHS) && !UsefulToPrintExpr(RHS))
17135        return;
17136  
17137      struct {
17138        const clang::Expr *Cond;
17139        Expr::EvalResult Result;
17140        SmallString<12> ValueString;
17141        bool Print;
17142      } DiagSide[2] = {{LHS, Expr::EvalResult(), {}, false},
17143                       {RHS, Expr::EvalResult(), {}, false}};
17144      for (unsigned I = 0; I < 2; I++) {
17145        const Expr *Side = DiagSide[I].Cond;
17146  
17147        Side->EvaluateAsRValue(DiagSide[I].Result, Context, true);
17148  
17149        DiagSide[I].Print =
17150            ConvertAPValueToString(DiagSide[I].Result.Val, Side->getType(),
17151                                   DiagSide[I].ValueString, Context);
17152      }
17153      if (DiagSide[0].Print && DiagSide[1].Print) {
17154        Diag(Op->getExprLoc(), diag::note_expr_evaluates_to)
17155            << DiagSide[0].ValueString << Op->getOpcodeStr()
17156            << DiagSide[1].ValueString << Op->getSourceRange();
17157      }
17158    }
17159  }
17160  
17161  bool Sema::EvaluateStaticAssertMessageAsString(Expr *Message,
17162                                                 std::string &Result,
17163                                                 ASTContext &Ctx,
17164                                                 bool ErrorOnInvalidMessage) {
17165    assert(Message);
17166    assert(!Message->isTypeDependent() && !Message->isValueDependent() &&
17167           "can't evaluate a dependant static assert message");
17168  
17169    if (const auto *SL = dyn_cast<StringLiteral>(Message)) {
17170      assert(SL->isUnevaluated() && "expected an unevaluated string");
17171      Result.assign(SL->getString().begin(), SL->getString().end());
17172      return true;
17173    }
17174  
17175    SourceLocation Loc = Message->getBeginLoc();
17176    QualType T = Message->getType().getNonReferenceType();
17177    auto *RD = T->getAsCXXRecordDecl();
17178    if (!RD) {
17179      Diag(Loc, diag::err_static_assert_invalid_message);
17180      return false;
17181    }
17182  
17183    auto FindMember = [&](StringRef Member, bool &Empty,
17184                          bool Diag = false) -> std::optional<LookupResult> {
17185      DeclarationName DN = PP.getIdentifierInfo(Member);
17186      LookupResult MemberLookup(*this, DN, Loc, Sema::LookupMemberName);
17187      LookupQualifiedName(MemberLookup, RD);
17188      Empty = MemberLookup.empty();
17189      OverloadCandidateSet Candidates(MemberLookup.getNameLoc(),
17190                                      OverloadCandidateSet::CSK_Normal);
17191      if (MemberLookup.empty())
17192        return std::nullopt;
17193      return std::move(MemberLookup);
17194    };
17195  
17196    bool SizeNotFound, DataNotFound;
17197    std::optional<LookupResult> SizeMember = FindMember("size", SizeNotFound);
17198    std::optional<LookupResult> DataMember = FindMember("data", DataNotFound);
17199    if (SizeNotFound || DataNotFound) {
17200      Diag(Loc, diag::err_static_assert_missing_member_function)
17201          << ((SizeNotFound && DataNotFound) ? 2
17202              : SizeNotFound                 ? 0
17203                                             : 1);
17204      return false;
17205    }
17206  
17207    if (!SizeMember || !DataMember) {
17208      if (!SizeMember)
17209        FindMember("size", SizeNotFound, /*Diag=*/true);
17210      if (!DataMember)
17211        FindMember("data", DataNotFound, /*Diag=*/true);
17212      return false;
17213    }
17214  
17215    auto BuildExpr = [&](LookupResult &LR) {
17216      ExprResult Res = BuildMemberReferenceExpr(
17217          Message, Message->getType(), Message->getBeginLoc(), false,
17218          CXXScopeSpec(), SourceLocation(), nullptr, LR, nullptr, nullptr);
17219      if (Res.isInvalid())
17220        return ExprError();
17221      Res = BuildCallExpr(nullptr, Res.get(), Loc, std::nullopt, Loc, nullptr,
17222                          false, true);
17223      if (Res.isInvalid())
17224        return ExprError();
17225      if (Res.get()->isTypeDependent() || Res.get()->isValueDependent())
17226        return ExprError();
17227      return TemporaryMaterializationConversion(Res.get());
17228    };
17229  
17230    ExprResult SizeE = BuildExpr(*SizeMember);
17231    ExprResult DataE = BuildExpr(*DataMember);
17232  
17233    QualType SizeT = Context.getSizeType();
17234    QualType ConstCharPtr =
17235        Context.getPointerType(Context.getConstType(Context.CharTy));
17236  
17237    ExprResult EvaluatedSize =
17238        SizeE.isInvalid() ? ExprError()
17239                          : BuildConvertedConstantExpression(
17240                                SizeE.get(), SizeT, CCEK_StaticAssertMessageSize);
17241    if (EvaluatedSize.isInvalid()) {
17242      Diag(Loc, diag::err_static_assert_invalid_mem_fn_ret_ty) << /*size*/ 0;
17243      return false;
17244    }
17245  
17246    ExprResult EvaluatedData =
17247        DataE.isInvalid()
17248            ? ExprError()
17249            : BuildConvertedConstantExpression(DataE.get(), ConstCharPtr,
17250                                               CCEK_StaticAssertMessageData);
17251    if (EvaluatedData.isInvalid()) {
17252      Diag(Loc, diag::err_static_assert_invalid_mem_fn_ret_ty) << /*data*/ 1;
17253      return false;
17254    }
17255  
17256    if (!ErrorOnInvalidMessage &&
17257        Diags.isIgnored(diag::warn_static_assert_message_constexpr, Loc))
17258      return true;
17259  
17260    Expr::EvalResult Status;
17261    SmallVector<PartialDiagnosticAt, 8> Notes;
17262    Status.Diag = &Notes;
17263    if (!Message->EvaluateCharRangeAsString(Result, EvaluatedSize.get(),
17264                                            EvaluatedData.get(), Ctx, Status) ||
17265        !Notes.empty()) {
17266      Diag(Message->getBeginLoc(),
17267           ErrorOnInvalidMessage ? diag::err_static_assert_message_constexpr
17268                                 : diag::warn_static_assert_message_constexpr);
17269      for (const auto &Note : Notes)
17270        Diag(Note.first, Note.second);
17271      return !ErrorOnInvalidMessage;
17272    }
17273    return true;
17274  }
17275  
17276  Decl *Sema::BuildStaticAssertDeclaration(SourceLocation StaticAssertLoc,
17277                                           Expr *AssertExpr, Expr *AssertMessage,
17278                                           SourceLocation RParenLoc,
17279                                           bool Failed) {
17280    assert(AssertExpr != nullptr && "Expected non-null condition");
17281    if (!AssertExpr->isTypeDependent() && !AssertExpr->isValueDependent() &&
17282        (!AssertMessage || (!AssertMessage->isTypeDependent() &&
17283                            !AssertMessage->isValueDependent())) &&
17284        !Failed) {
17285      // In a static_assert-declaration, the constant-expression shall be a
17286      // constant expression that can be contextually converted to bool.
17287      ExprResult Converted = PerformContextuallyConvertToBool(AssertExpr);
17288      if (Converted.isInvalid())
17289        Failed = true;
17290  
17291      ExprResult FullAssertExpr =
17292          ActOnFinishFullExpr(Converted.get(), StaticAssertLoc,
17293                              /*DiscardedValue*/ false,
17294                              /*IsConstexpr*/ true);
17295      if (FullAssertExpr.isInvalid())
17296        Failed = true;
17297      else
17298        AssertExpr = FullAssertExpr.get();
17299  
17300      llvm::APSInt Cond;
17301      Expr *BaseExpr = AssertExpr;
17302      AllowFoldKind FoldKind = NoFold;
17303  
17304      if (!getLangOpts().CPlusPlus) {
17305        // In C mode, allow folding as an extension for better compatibility with
17306        // C++ in terms of expressions like static_assert("test") or
17307        // static_assert(nullptr).
17308        FoldKind = AllowFold;
17309      }
17310  
17311      if (!Failed && VerifyIntegerConstantExpression(
17312                         BaseExpr, &Cond,
17313                         diag::err_static_assert_expression_is_not_constant,
17314                         FoldKind).isInvalid())
17315        Failed = true;
17316  
17317      // If the static_assert passes, only verify that
17318      // the message is grammatically valid without evaluating it.
17319      if (!Failed && AssertMessage && Cond.getBoolValue()) {
17320        std::string Str;
17321        EvaluateStaticAssertMessageAsString(AssertMessage, Str, Context,
17322                                            /*ErrorOnInvalidMessage=*/false);
17323      }
17324  
17325      // CWG2518
17326      // [dcl.pre]/p10  If [...] the expression is evaluated in the context of a
17327      // template definition, the declaration has no effect.
17328      bool InTemplateDefinition =
17329          getLangOpts().CPlusPlus && CurContext->isDependentContext();
17330  
17331      if (!Failed && !Cond && !InTemplateDefinition) {
17332        SmallString<256> MsgBuffer;
17333        llvm::raw_svector_ostream Msg(MsgBuffer);
17334        bool HasMessage = AssertMessage;
17335        if (AssertMessage) {
17336          std::string Str;
17337          HasMessage =
17338              EvaluateStaticAssertMessageAsString(
17339                  AssertMessage, Str, Context, /*ErrorOnInvalidMessage=*/true) ||
17340              !Str.empty();
17341          Msg << Str;
17342        }
17343        Expr *InnerCond = nullptr;
17344        std::string InnerCondDescription;
17345        std::tie(InnerCond, InnerCondDescription) =
17346          findFailedBooleanCondition(Converted.get());
17347        if (InnerCond && isa<ConceptSpecializationExpr>(InnerCond)) {
17348          // Drill down into concept specialization expressions to see why they
17349          // weren't satisfied.
17350          Diag(AssertExpr->getBeginLoc(), diag::err_static_assert_failed)
17351              << !HasMessage << Msg.str() << AssertExpr->getSourceRange();
17352          ConstraintSatisfaction Satisfaction;
17353          if (!CheckConstraintSatisfaction(InnerCond, Satisfaction))
17354            DiagnoseUnsatisfiedConstraint(Satisfaction);
17355        } else if (InnerCond && !isa<CXXBoolLiteralExpr>(InnerCond)
17356                             && !isa<IntegerLiteral>(InnerCond)) {
17357          Diag(InnerCond->getBeginLoc(),
17358               diag::err_static_assert_requirement_failed)
17359              << InnerCondDescription << !HasMessage << Msg.str()
17360              << InnerCond->getSourceRange();
17361          DiagnoseStaticAssertDetails(InnerCond);
17362        } else {
17363          Diag(AssertExpr->getBeginLoc(), diag::err_static_assert_failed)
17364              << !HasMessage << Msg.str() << AssertExpr->getSourceRange();
17365          PrintContextStack();
17366        }
17367        Failed = true;
17368      }
17369    } else {
17370      ExprResult FullAssertExpr = ActOnFinishFullExpr(AssertExpr, StaticAssertLoc,
17371                                                      /*DiscardedValue*/false,
17372                                                      /*IsConstexpr*/true);
17373      if (FullAssertExpr.isInvalid())
17374        Failed = true;
17375      else
17376        AssertExpr = FullAssertExpr.get();
17377    }
17378  
17379    Decl *Decl = StaticAssertDecl::Create(Context, CurContext, StaticAssertLoc,
17380                                          AssertExpr, AssertMessage, RParenLoc,
17381                                          Failed);
17382  
17383    CurContext->addDecl(Decl);
17384    return Decl;
17385  }
17386  
17387  DeclResult Sema::ActOnTemplatedFriendTag(
17388      Scope *S, SourceLocation FriendLoc, unsigned TagSpec, SourceLocation TagLoc,
17389      CXXScopeSpec &SS, IdentifierInfo *Name, SourceLocation NameLoc,
17390      const ParsedAttributesView &Attr, MultiTemplateParamsArg TempParamLists) {
17391    TagTypeKind Kind = TypeWithKeyword::getTagTypeKindForTypeSpec(TagSpec);
17392  
17393    bool IsMemberSpecialization = false;
17394    bool Invalid = false;
17395  
17396    if (TemplateParameterList *TemplateParams =
17397            MatchTemplateParametersToScopeSpecifier(
17398                TagLoc, NameLoc, SS, nullptr, TempParamLists, /*friend*/ true,
17399                IsMemberSpecialization, Invalid)) {
17400      if (TemplateParams->size() > 0) {
17401        // This is a declaration of a class template.
17402        if (Invalid)
17403          return true;
17404  
17405        return CheckClassTemplate(S, TagSpec, TagUseKind::Friend, TagLoc, SS,
17406                                  Name, NameLoc, Attr, TemplateParams, AS_public,
17407                                  /*ModulePrivateLoc=*/SourceLocation(),
17408                                  FriendLoc, TempParamLists.size() - 1,
17409                                  TempParamLists.data())
17410            .get();
17411      } else {
17412        // The "template<>" header is extraneous.
17413        Diag(TemplateParams->getTemplateLoc(), diag::err_template_tag_noparams)
17414          << TypeWithKeyword::getTagTypeKindName(Kind) << Name;
17415        IsMemberSpecialization = true;
17416      }
17417    }
17418  
17419    if (Invalid) return true;
17420  
17421    bool isAllExplicitSpecializations = true;
17422    for (unsigned I = TempParamLists.size(); I-- > 0; ) {
17423      if (TempParamLists[I]->size()) {
17424        isAllExplicitSpecializations = false;
17425        break;
17426      }
17427    }
17428  
17429    // FIXME: don't ignore attributes.
17430  
17431    // If it's explicit specializations all the way down, just forget
17432    // about the template header and build an appropriate non-templated
17433    // friend.  TODO: for source fidelity, remember the headers.
17434    if (isAllExplicitSpecializations) {
17435      if (SS.isEmpty()) {
17436        bool Owned = false;
17437        bool IsDependent = false;
17438        return ActOnTag(S, TagSpec, TagUseKind::Friend, TagLoc, SS, Name, NameLoc,
17439                        Attr, AS_public,
17440                        /*ModulePrivateLoc=*/SourceLocation(),
17441                        MultiTemplateParamsArg(), Owned, IsDependent,
17442                        /*ScopedEnumKWLoc=*/SourceLocation(),
17443                        /*ScopedEnumUsesClassTag=*/false,
17444                        /*UnderlyingType=*/TypeResult(),
17445                        /*IsTypeSpecifier=*/false,
17446                        /*IsTemplateParamOrArg=*/false, /*OOK=*/OOK_Outside);
17447      }
17448  
17449      NestedNameSpecifierLoc QualifierLoc = SS.getWithLocInContext(Context);
17450      ElaboratedTypeKeyword Keyword
17451        = TypeWithKeyword::getKeywordForTagTypeKind(Kind);
17452      QualType T = CheckTypenameType(Keyword, TagLoc, QualifierLoc,
17453                                     *Name, NameLoc);
17454      if (T.isNull())
17455        return true;
17456  
17457      TypeSourceInfo *TSI = Context.CreateTypeSourceInfo(T);
17458      if (isa<DependentNameType>(T)) {
17459        DependentNameTypeLoc TL =
17460            TSI->getTypeLoc().castAs<DependentNameTypeLoc>();
17461        TL.setElaboratedKeywordLoc(TagLoc);
17462        TL.setQualifierLoc(QualifierLoc);
17463        TL.setNameLoc(NameLoc);
17464      } else {
17465        ElaboratedTypeLoc TL = TSI->getTypeLoc().castAs<ElaboratedTypeLoc>();
17466        TL.setElaboratedKeywordLoc(TagLoc);
17467        TL.setQualifierLoc(QualifierLoc);
17468        TL.getNamedTypeLoc().castAs<TypeSpecTypeLoc>().setNameLoc(NameLoc);
17469      }
17470  
17471      FriendDecl *Friend = FriendDecl::Create(Context, CurContext, NameLoc,
17472                                              TSI, FriendLoc, TempParamLists);
17473      Friend->setAccess(AS_public);
17474      CurContext->addDecl(Friend);
17475      return Friend;
17476    }
17477  
17478    assert(SS.isNotEmpty() && "valid templated tag with no SS and no direct?");
17479  
17480  
17481  
17482    // Handle the case of a templated-scope friend class.  e.g.
17483    //   template <class T> class A<T>::B;
17484    // FIXME: we don't support these right now.
17485    Diag(NameLoc, diag::warn_template_qualified_friend_unsupported)
17486      << SS.getScopeRep() << SS.getRange() << cast<CXXRecordDecl>(CurContext);
17487    ElaboratedTypeKeyword ETK = TypeWithKeyword::getKeywordForTagTypeKind(Kind);
17488    QualType T = Context.getDependentNameType(ETK, SS.getScopeRep(), Name);
17489    TypeSourceInfo *TSI = Context.CreateTypeSourceInfo(T);
17490    DependentNameTypeLoc TL = TSI->getTypeLoc().castAs<DependentNameTypeLoc>();
17491    TL.setElaboratedKeywordLoc(TagLoc);
17492    TL.setQualifierLoc(SS.getWithLocInContext(Context));
17493    TL.setNameLoc(NameLoc);
17494  
17495    FriendDecl *Friend = FriendDecl::Create(Context, CurContext, NameLoc,
17496                                            TSI, FriendLoc, TempParamLists);
17497    Friend->setAccess(AS_public);
17498    Friend->setUnsupportedFriend(true);
17499    CurContext->addDecl(Friend);
17500    return Friend;
17501  }
17502  
17503  Decl *Sema::ActOnFriendTypeDecl(Scope *S, const DeclSpec &DS,
17504                                  MultiTemplateParamsArg TempParams) {
17505    SourceLocation Loc = DS.getBeginLoc();
17506    SourceLocation FriendLoc = DS.getFriendSpecLoc();
17507  
17508    assert(DS.isFriendSpecified());
17509    assert(DS.getStorageClassSpec() == DeclSpec::SCS_unspecified);
17510  
17511    // C++ [class.friend]p3:
17512    // A friend declaration that does not declare a function shall have one of
17513    // the following forms:
17514    //     friend elaborated-type-specifier ;
17515    //     friend simple-type-specifier ;
17516    //     friend typename-specifier ;
17517    //
17518    // If the friend keyword isn't first, or if the declarations has any type
17519    // qualifiers, then the declaration doesn't have that form.
17520    if (getLangOpts().CPlusPlus11 && !DS.isFriendSpecifiedFirst())
17521      Diag(FriendLoc, diag::err_friend_not_first_in_declaration);
17522    if (DS.getTypeQualifiers()) {
17523      if (DS.getTypeQualifiers() & DeclSpec::TQ_const)
17524        Diag(DS.getConstSpecLoc(), diag::err_friend_decl_spec) << "const";
17525      if (DS.getTypeQualifiers() & DeclSpec::TQ_volatile)
17526        Diag(DS.getVolatileSpecLoc(), diag::err_friend_decl_spec) << "volatile";
17527      if (DS.getTypeQualifiers() & DeclSpec::TQ_restrict)
17528        Diag(DS.getRestrictSpecLoc(), diag::err_friend_decl_spec) << "restrict";
17529      if (DS.getTypeQualifiers() & DeclSpec::TQ_atomic)
17530        Diag(DS.getAtomicSpecLoc(), diag::err_friend_decl_spec) << "_Atomic";
17531      if (DS.getTypeQualifiers() & DeclSpec::TQ_unaligned)
17532        Diag(DS.getUnalignedSpecLoc(), diag::err_friend_decl_spec) << "__unaligned";
17533    }
17534  
17535    // Try to convert the decl specifier to a type.  This works for
17536    // friend templates because ActOnTag never produces a ClassTemplateDecl
17537    // for a TagUseKind::Friend.
17538    Declarator TheDeclarator(DS, ParsedAttributesView::none(),
17539                             DeclaratorContext::Member);
17540    TypeSourceInfo *TSI = GetTypeForDeclarator(TheDeclarator);
17541    QualType T = TSI->getType();
17542    if (TheDeclarator.isInvalidType())
17543      return nullptr;
17544  
17545    if (DiagnoseUnexpandedParameterPack(Loc, TSI, UPPC_FriendDeclaration))
17546      return nullptr;
17547  
17548    if (!T->isElaboratedTypeSpecifier()) {
17549      if (TempParams.size()) {
17550        // C++23 [dcl.pre]p5:
17551        //   In a simple-declaration, the optional init-declarator-list can be
17552        //   omitted only when declaring a class or enumeration, that is, when
17553        //   the decl-specifier-seq contains either a class-specifier, an
17554        //   elaborated-type-specifier with a class-key, or an enum-specifier.
17555        //
17556        // The declaration of a template-declaration or explicit-specialization
17557        // is never a member-declaration, so this must be a simple-declaration
17558        // with no init-declarator-list. Therefore, this is ill-formed.
17559        Diag(Loc, diag::err_tagless_friend_type_template) << DS.getSourceRange();
17560        return nullptr;
17561      } else if (const RecordDecl *RD = T->getAsRecordDecl()) {
17562        SmallString<16> InsertionText(" ");
17563        InsertionText += RD->getKindName();
17564  
17565        Diag(Loc, getLangOpts().CPlusPlus11
17566                      ? diag::warn_cxx98_compat_unelaborated_friend_type
17567                      : diag::ext_unelaborated_friend_type)
17568            << (unsigned)RD->getTagKind() << T
17569            << FixItHint::CreateInsertion(getLocForEndOfToken(FriendLoc),
17570                                          InsertionText);
17571      } else {
17572        Diag(FriendLoc, getLangOpts().CPlusPlus11
17573                            ? diag::warn_cxx98_compat_nonclass_type_friend
17574                            : diag::ext_nonclass_type_friend)
17575            << T << DS.getSourceRange();
17576      }
17577    }
17578  
17579    // C++98 [class.friend]p1: A friend of a class is a function
17580    //   or class that is not a member of the class . . .
17581    // This is fixed in DR77, which just barely didn't make the C++03
17582    // deadline.  It's also a very silly restriction that seriously
17583    // affects inner classes and which nobody else seems to implement;
17584    // thus we never diagnose it, not even in -pedantic.
17585    //
17586    // But note that we could warn about it: it's always useless to
17587    // friend one of your own members (it's not, however, worthless to
17588    // friend a member of an arbitrary specialization of your template).
17589  
17590    Decl *D;
17591    if (!TempParams.empty())
17592      D = FriendTemplateDecl::Create(Context, CurContext, Loc, TempParams, TSI,
17593                                     FriendLoc);
17594    else
17595      D = FriendDecl::Create(Context, CurContext, TSI->getTypeLoc().getBeginLoc(),
17596                             TSI, FriendLoc);
17597  
17598    if (!D)
17599      return nullptr;
17600  
17601    D->setAccess(AS_public);
17602    CurContext->addDecl(D);
17603  
17604    return D;
17605  }
17606  
17607  NamedDecl *Sema::ActOnFriendFunctionDecl(Scope *S, Declarator &D,
17608                                          MultiTemplateParamsArg TemplateParams) {
17609    const DeclSpec &DS = D.getDeclSpec();
17610  
17611    assert(DS.isFriendSpecified());
17612    assert(DS.getStorageClassSpec() == DeclSpec::SCS_unspecified);
17613  
17614    SourceLocation Loc = D.getIdentifierLoc();
17615    TypeSourceInfo *TInfo = GetTypeForDeclarator(D);
17616  
17617    // C++ [class.friend]p1
17618    //   A friend of a class is a function or class....
17619    // Note that this sees through typedefs, which is intended.
17620    // It *doesn't* see through dependent types, which is correct
17621    // according to [temp.arg.type]p3:
17622    //   If a declaration acquires a function type through a
17623    //   type dependent on a template-parameter and this causes
17624    //   a declaration that does not use the syntactic form of a
17625    //   function declarator to have a function type, the program
17626    //   is ill-formed.
17627    if (!TInfo->getType()->isFunctionType()) {
17628      Diag(Loc, diag::err_unexpected_friend);
17629  
17630      // It might be worthwhile to try to recover by creating an
17631      // appropriate declaration.
17632      return nullptr;
17633    }
17634  
17635    // C++ [namespace.memdef]p3
17636    //  - If a friend declaration in a non-local class first declares a
17637    //    class or function, the friend class or function is a member
17638    //    of the innermost enclosing namespace.
17639    //  - The name of the friend is not found by simple name lookup
17640    //    until a matching declaration is provided in that namespace
17641    //    scope (either before or after the class declaration granting
17642    //    friendship).
17643    //  - If a friend function is called, its name may be found by the
17644    //    name lookup that considers functions from namespaces and
17645    //    classes associated with the types of the function arguments.
17646    //  - When looking for a prior declaration of a class or a function
17647    //    declared as a friend, scopes outside the innermost enclosing
17648    //    namespace scope are not considered.
17649  
17650    CXXScopeSpec &SS = D.getCXXScopeSpec();
17651    DeclarationNameInfo NameInfo = GetNameForDeclarator(D);
17652    assert(NameInfo.getName());
17653  
17654    // Check for unexpanded parameter packs.
17655    if (DiagnoseUnexpandedParameterPack(Loc, TInfo, UPPC_FriendDeclaration) ||
17656        DiagnoseUnexpandedParameterPack(NameInfo, UPPC_FriendDeclaration) ||
17657        DiagnoseUnexpandedParameterPack(SS, UPPC_FriendDeclaration))
17658      return nullptr;
17659  
17660    // The context we found the declaration in, or in which we should
17661    // create the declaration.
17662    DeclContext *DC;
17663    Scope *DCScope = S;
17664    LookupResult Previous(*this, NameInfo, LookupOrdinaryName,
17665                          RedeclarationKind::ForExternalRedeclaration);
17666  
17667    bool isTemplateId = D.getName().getKind() == UnqualifiedIdKind::IK_TemplateId;
17668  
17669    // There are five cases here.
17670    //   - There's no scope specifier and we're in a local class. Only look
17671    //     for functions declared in the immediately-enclosing block scope.
17672    // We recover from invalid scope qualifiers as if they just weren't there.
17673    FunctionDecl *FunctionContainingLocalClass = nullptr;
17674    if ((SS.isInvalid() || !SS.isSet()) &&
17675        (FunctionContainingLocalClass =
17676             cast<CXXRecordDecl>(CurContext)->isLocalClass())) {
17677      // C++11 [class.friend]p11:
17678      //   If a friend declaration appears in a local class and the name
17679      //   specified is an unqualified name, a prior declaration is
17680      //   looked up without considering scopes that are outside the
17681      //   innermost enclosing non-class scope. For a friend function
17682      //   declaration, if there is no prior declaration, the program is
17683      //   ill-formed.
17684  
17685      // Find the innermost enclosing non-class scope. This is the block
17686      // scope containing the local class definition (or for a nested class,
17687      // the outer local class).
17688      DCScope = S->getFnParent();
17689  
17690      // Look up the function name in the scope.
17691      Previous.clear(LookupLocalFriendName);
17692      LookupName(Previous, S, /*AllowBuiltinCreation*/false);
17693  
17694      if (!Previous.empty()) {
17695        // All possible previous declarations must have the same context:
17696        // either they were declared at block scope or they are members of
17697        // one of the enclosing local classes.
17698        DC = Previous.getRepresentativeDecl()->getDeclContext();
17699      } else {
17700        // This is ill-formed, but provide the context that we would have
17701        // declared the function in, if we were permitted to, for error recovery.
17702        DC = FunctionContainingLocalClass;
17703      }
17704      adjustContextForLocalExternDecl(DC);
17705  
17706    //   - There's no scope specifier, in which case we just go to the
17707    //     appropriate scope and look for a function or function template
17708    //     there as appropriate.
17709    } else if (SS.isInvalid() || !SS.isSet()) {
17710      // C++11 [namespace.memdef]p3:
17711      //   If the name in a friend declaration is neither qualified nor
17712      //   a template-id and the declaration is a function or an
17713      //   elaborated-type-specifier, the lookup to determine whether
17714      //   the entity has been previously declared shall not consider
17715      //   any scopes outside the innermost enclosing namespace.
17716  
17717      // Find the appropriate context according to the above.
17718      DC = CurContext;
17719  
17720      // Skip class contexts.  If someone can cite chapter and verse
17721      // for this behavior, that would be nice --- it's what GCC and
17722      // EDG do, and it seems like a reasonable intent, but the spec
17723      // really only says that checks for unqualified existing
17724      // declarations should stop at the nearest enclosing namespace,
17725      // not that they should only consider the nearest enclosing
17726      // namespace.
17727      while (DC->isRecord())
17728        DC = DC->getParent();
17729  
17730      DeclContext *LookupDC = DC->getNonTransparentContext();
17731      while (true) {
17732        LookupQualifiedName(Previous, LookupDC);
17733  
17734        if (!Previous.empty()) {
17735          DC = LookupDC;
17736          break;
17737        }
17738  
17739        if (isTemplateId) {
17740          if (isa<TranslationUnitDecl>(LookupDC)) break;
17741        } else {
17742          if (LookupDC->isFileContext()) break;
17743        }
17744        LookupDC = LookupDC->getParent();
17745      }
17746  
17747      DCScope = getScopeForDeclContext(S, DC);
17748  
17749    //   - There's a non-dependent scope specifier, in which case we
17750    //     compute it and do a previous lookup there for a function
17751    //     or function template.
17752    } else if (!SS.getScopeRep()->isDependent()) {
17753      DC = computeDeclContext(SS);
17754      if (!DC) return nullptr;
17755  
17756      if (RequireCompleteDeclContext(SS, DC)) return nullptr;
17757  
17758      LookupQualifiedName(Previous, DC);
17759  
17760      // C++ [class.friend]p1: A friend of a class is a function or
17761      //   class that is not a member of the class . . .
17762      if (DC->Equals(CurContext))
17763        Diag(DS.getFriendSpecLoc(),
17764             getLangOpts().CPlusPlus11 ?
17765               diag::warn_cxx98_compat_friend_is_member :
17766               diag::err_friend_is_member);
17767  
17768    //   - There's a scope specifier that does not match any template
17769    //     parameter lists, in which case we use some arbitrary context,
17770    //     create a method or method template, and wait for instantiation.
17771    //   - There's a scope specifier that does match some template
17772    //     parameter lists, which we don't handle right now.
17773    } else {
17774      DC = CurContext;
17775      assert(isa<CXXRecordDecl>(DC) && "friend declaration not in class?");
17776    }
17777  
17778    if (!DC->isRecord()) {
17779      int DiagArg = -1;
17780      switch (D.getName().getKind()) {
17781      case UnqualifiedIdKind::IK_ConstructorTemplateId:
17782      case UnqualifiedIdKind::IK_ConstructorName:
17783        DiagArg = 0;
17784        break;
17785      case UnqualifiedIdKind::IK_DestructorName:
17786        DiagArg = 1;
17787        break;
17788      case UnqualifiedIdKind::IK_ConversionFunctionId:
17789        DiagArg = 2;
17790        break;
17791      case UnqualifiedIdKind::IK_DeductionGuideName:
17792        DiagArg = 3;
17793        break;
17794      case UnqualifiedIdKind::IK_Identifier:
17795      case UnqualifiedIdKind::IK_ImplicitSelfParam:
17796      case UnqualifiedIdKind::IK_LiteralOperatorId:
17797      case UnqualifiedIdKind::IK_OperatorFunctionId:
17798      case UnqualifiedIdKind::IK_TemplateId:
17799        break;
17800      }
17801      // This implies that it has to be an operator or function.
17802      if (DiagArg >= 0) {
17803        Diag(Loc, diag::err_introducing_special_friend) << DiagArg;
17804        return nullptr;
17805      }
17806    }
17807  
17808    // FIXME: This is an egregious hack to cope with cases where the scope stack
17809    // does not contain the declaration context, i.e., in an out-of-line
17810    // definition of a class.
17811    Scope FakeDCScope(S, Scope::DeclScope, Diags);
17812    if (!DCScope) {
17813      FakeDCScope.setEntity(DC);
17814      DCScope = &FakeDCScope;
17815    }
17816  
17817    bool AddToScope = true;
17818    NamedDecl *ND = ActOnFunctionDeclarator(DCScope, D, DC, TInfo, Previous,
17819                                            TemplateParams, AddToScope);
17820    if (!ND) return nullptr;
17821  
17822    assert(ND->getLexicalDeclContext() == CurContext);
17823  
17824    // If we performed typo correction, we might have added a scope specifier
17825    // and changed the decl context.
17826    DC = ND->getDeclContext();
17827  
17828    // Add the function declaration to the appropriate lookup tables,
17829    // adjusting the redeclarations list as necessary.  We don't
17830    // want to do this yet if the friending class is dependent.
17831    //
17832    // Also update the scope-based lookup if the target context's
17833    // lookup context is in lexical scope.
17834    if (!CurContext->isDependentContext()) {
17835      DC = DC->getRedeclContext();
17836      DC->makeDeclVisibleInContext(ND);
17837      if (Scope *EnclosingScope = getScopeForDeclContext(S, DC))
17838        PushOnScopeChains(ND, EnclosingScope, /*AddToContext=*/ false);
17839    }
17840  
17841    FriendDecl *FrD = FriendDecl::Create(Context, CurContext,
17842                                         D.getIdentifierLoc(), ND,
17843                                         DS.getFriendSpecLoc());
17844    FrD->setAccess(AS_public);
17845    CurContext->addDecl(FrD);
17846  
17847    if (ND->isInvalidDecl()) {
17848      FrD->setInvalidDecl();
17849    } else {
17850      if (DC->isRecord()) CheckFriendAccess(ND);
17851  
17852      FunctionDecl *FD;
17853      if (FunctionTemplateDecl *FTD = dyn_cast<FunctionTemplateDecl>(ND))
17854        FD = FTD->getTemplatedDecl();
17855      else
17856        FD = cast<FunctionDecl>(ND);
17857  
17858      // C++ [class.friend]p6:
17859      //   A function may be defined in a friend declaration of a class if and
17860      //   only if the class is a non-local class, and the function name is
17861      //   unqualified.
17862      if (D.isFunctionDefinition()) {
17863        // Qualified friend function definition.
17864        if (SS.isNotEmpty()) {
17865          // FIXME: We should only do this if the scope specifier names the
17866          // innermost enclosing namespace; otherwise the fixit changes the
17867          // meaning of the code.
17868          SemaDiagnosticBuilder DB =
17869              Diag(SS.getRange().getBegin(), diag::err_qualified_friend_def);
17870  
17871          DB << SS.getScopeRep();
17872          if (DC->isFileContext())
17873            DB << FixItHint::CreateRemoval(SS.getRange());
17874  
17875          // Friend function defined in a local class.
17876        } else if (FunctionContainingLocalClass) {
17877          Diag(NameInfo.getBeginLoc(), diag::err_friend_def_in_local_class);
17878  
17879          // Per [basic.pre]p4, a template-id is not a name. Therefore, if we have
17880          // a template-id, the function name is not unqualified because these is
17881          // no name. While the wording requires some reading in-between the
17882          // lines, GCC, MSVC, and EDG all consider a friend function
17883          // specialization definitions // to be de facto explicit specialization
17884          // and diagnose them as such.
17885        } else if (isTemplateId) {
17886          Diag(NameInfo.getBeginLoc(), diag::err_friend_specialization_def);
17887        }
17888      }
17889  
17890      // C++11 [dcl.fct.default]p4: If a friend declaration specifies a
17891      // default argument expression, that declaration shall be a definition
17892      // and shall be the only declaration of the function or function
17893      // template in the translation unit.
17894      if (functionDeclHasDefaultArgument(FD)) {
17895        // We can't look at FD->getPreviousDecl() because it may not have been set
17896        // if we're in a dependent context. If the function is known to be a
17897        // redeclaration, we will have narrowed Previous down to the right decl.
17898        if (D.isRedeclaration()) {
17899          Diag(FD->getLocation(), diag::err_friend_decl_with_def_arg_redeclared);
17900          Diag(Previous.getRepresentativeDecl()->getLocation(),
17901               diag::note_previous_declaration);
17902        } else if (!D.isFunctionDefinition())
17903          Diag(FD->getLocation(), diag::err_friend_decl_with_def_arg_must_be_def);
17904      }
17905  
17906      // Mark templated-scope function declarations as unsupported.
17907      if (FD->getNumTemplateParameterLists() && SS.isValid()) {
17908        Diag(FD->getLocation(), diag::warn_template_qualified_friend_unsupported)
17909          << SS.getScopeRep() << SS.getRange()
17910          << cast<CXXRecordDecl>(CurContext);
17911        FrD->setUnsupportedFriend(true);
17912      }
17913    }
17914  
17915    warnOnReservedIdentifier(ND);
17916  
17917    return ND;
17918  }
17919  
17920  void Sema::SetDeclDeleted(Decl *Dcl, SourceLocation DelLoc,
17921                            StringLiteral *Message) {
17922    AdjustDeclIfTemplate(Dcl);
17923  
17924    FunctionDecl *Fn = dyn_cast_or_null<FunctionDecl>(Dcl);
17925    if (!Fn) {
17926      Diag(DelLoc, diag::err_deleted_non_function);
17927      return;
17928    }
17929  
17930    // Deleted function does not have a body.
17931    Fn->setWillHaveBody(false);
17932  
17933    if (const FunctionDecl *Prev = Fn->getPreviousDecl()) {
17934      // Don't consider the implicit declaration we generate for explicit
17935      // specializations. FIXME: Do not generate these implicit declarations.
17936      if ((Prev->getTemplateSpecializationKind() != TSK_ExplicitSpecialization ||
17937           Prev->getPreviousDecl()) &&
17938          !Prev->isDefined()) {
17939        Diag(DelLoc, diag::err_deleted_decl_not_first);
17940        Diag(Prev->getLocation().isInvalid() ? DelLoc : Prev->getLocation(),
17941             Prev->isImplicit() ? diag::note_previous_implicit_declaration
17942                                : diag::note_previous_declaration);
17943        // We can't recover from this; the declaration might have already
17944        // been used.
17945        Fn->setInvalidDecl();
17946        return;
17947      }
17948  
17949      // To maintain the invariant that functions are only deleted on their first
17950      // declaration, mark the implicitly-instantiated declaration of the
17951      // explicitly-specialized function as deleted instead of marking the
17952      // instantiated redeclaration.
17953      Fn = Fn->getCanonicalDecl();
17954    }
17955  
17956    // dllimport/dllexport cannot be deleted.
17957    if (const InheritableAttr *DLLAttr = getDLLAttr(Fn)) {
17958      Diag(Fn->getLocation(), diag::err_attribute_dll_deleted) << DLLAttr;
17959      Fn->setInvalidDecl();
17960    }
17961  
17962    // C++11 [basic.start.main]p3:
17963    //   A program that defines main as deleted [...] is ill-formed.
17964    if (Fn->isMain())
17965      Diag(DelLoc, diag::err_deleted_main);
17966  
17967    // C++11 [dcl.fct.def.delete]p4:
17968    //  A deleted function is implicitly inline.
17969    Fn->setImplicitlyInline();
17970    Fn->setDeletedAsWritten(true, Message);
17971  }
17972  
17973  void Sema::SetDeclDefaulted(Decl *Dcl, SourceLocation DefaultLoc) {
17974    if (!Dcl || Dcl->isInvalidDecl())
17975      return;
17976  
17977    auto *FD = dyn_cast<FunctionDecl>(Dcl);
17978    if (!FD) {
17979      if (auto *FTD = dyn_cast<FunctionTemplateDecl>(Dcl)) {
17980        if (getDefaultedFunctionKind(FTD->getTemplatedDecl()).isComparison()) {
17981          Diag(DefaultLoc, diag::err_defaulted_comparison_template);
17982          return;
17983        }
17984      }
17985  
17986      Diag(DefaultLoc, diag::err_default_special_members)
17987          << getLangOpts().CPlusPlus20;
17988      return;
17989    }
17990  
17991    // Reject if this can't possibly be a defaultable function.
17992    DefaultedFunctionKind DefKind = getDefaultedFunctionKind(FD);
17993    if (!DefKind &&
17994        // A dependent function that doesn't locally look defaultable can
17995        // still instantiate to a defaultable function if it's a constructor
17996        // or assignment operator.
17997        (!FD->isDependentContext() ||
17998         (!isa<CXXConstructorDecl>(FD) &&
17999          FD->getDeclName().getCXXOverloadedOperator() != OO_Equal))) {
18000      Diag(DefaultLoc, diag::err_default_special_members)
18001          << getLangOpts().CPlusPlus20;
18002      return;
18003    }
18004  
18005    // Issue compatibility warning. We already warned if the operator is
18006    // 'operator<=>' when parsing the '<=>' token.
18007    if (DefKind.isComparison() &&
18008        DefKind.asComparison() != DefaultedComparisonKind::ThreeWay) {
18009      Diag(DefaultLoc, getLangOpts().CPlusPlus20
18010                           ? diag::warn_cxx17_compat_defaulted_comparison
18011                           : diag::ext_defaulted_comparison);
18012    }
18013  
18014    FD->setDefaulted();
18015    FD->setExplicitlyDefaulted();
18016    FD->setDefaultLoc(DefaultLoc);
18017  
18018    // Defer checking functions that are defaulted in a dependent context.
18019    if (FD->isDependentContext())
18020      return;
18021  
18022    // Unset that we will have a body for this function. We might not,
18023    // if it turns out to be trivial, and we don't need this marking now
18024    // that we've marked it as defaulted.
18025    FD->setWillHaveBody(false);
18026  
18027    if (DefKind.isComparison()) {
18028      // If this comparison's defaulting occurs within the definition of its
18029      // lexical class context, we have to do the checking when complete.
18030      if (auto const *RD = dyn_cast<CXXRecordDecl>(FD->getLexicalDeclContext()))
18031        if (!RD->isCompleteDefinition())
18032          return;
18033    }
18034  
18035    // If this member fn was defaulted on its first declaration, we will have
18036    // already performed the checking in CheckCompletedCXXClass. Such a
18037    // declaration doesn't trigger an implicit definition.
18038    if (isa<CXXMethodDecl>(FD)) {
18039      const FunctionDecl *Primary = FD;
18040      if (const FunctionDecl *Pattern = FD->getTemplateInstantiationPattern())
18041        // Ask the template instantiation pattern that actually had the
18042        // '= default' on it.
18043        Primary = Pattern;
18044      if (Primary->getCanonicalDecl()->isDefaulted())
18045        return;
18046    }
18047  
18048    if (DefKind.isComparison()) {
18049      if (CheckExplicitlyDefaultedComparison(nullptr, FD, DefKind.asComparison()))
18050        FD->setInvalidDecl();
18051      else
18052        DefineDefaultedComparison(DefaultLoc, FD, DefKind.asComparison());
18053    } else {
18054      auto *MD = cast<CXXMethodDecl>(FD);
18055  
18056      if (CheckExplicitlyDefaultedSpecialMember(MD, DefKind.asSpecialMember(),
18057                                                DefaultLoc))
18058        MD->setInvalidDecl();
18059      else
18060        DefineDefaultedFunction(*this, MD, DefaultLoc);
18061    }
18062  }
18063  
18064  static void SearchForReturnInStmt(Sema &Self, Stmt *S) {
18065    for (Stmt *SubStmt : S->children()) {
18066      if (!SubStmt)
18067        continue;
18068      if (isa<ReturnStmt>(SubStmt))
18069        Self.Diag(SubStmt->getBeginLoc(),
18070                  diag::err_return_in_constructor_handler);
18071      if (!isa<Expr>(SubStmt))
18072        SearchForReturnInStmt(Self, SubStmt);
18073    }
18074  }
18075  
18076  void Sema::DiagnoseReturnInConstructorExceptionHandler(CXXTryStmt *TryBlock) {
18077    for (unsigned I = 0, E = TryBlock->getNumHandlers(); I != E; ++I) {
18078      CXXCatchStmt *Handler = TryBlock->getHandler(I);
18079      SearchForReturnInStmt(*this, Handler);
18080    }
18081  }
18082  
18083  void Sema::SetFunctionBodyKind(Decl *D, SourceLocation Loc, FnBodyKind BodyKind,
18084                                 StringLiteral *DeletedMessage) {
18085    switch (BodyKind) {
18086    case FnBodyKind::Delete:
18087      SetDeclDeleted(D, Loc, DeletedMessage);
18088      break;
18089    case FnBodyKind::Default:
18090      SetDeclDefaulted(D, Loc);
18091      break;
18092    case FnBodyKind::Other:
18093      llvm_unreachable(
18094          "Parsed function body should be '= delete;' or '= default;'");
18095    }
18096  }
18097  
18098  bool Sema::CheckOverridingFunctionAttributes(CXXMethodDecl *New,
18099                                               const CXXMethodDecl *Old) {
18100    const auto *NewFT = New->getType()->castAs<FunctionProtoType>();
18101    const auto *OldFT = Old->getType()->castAs<FunctionProtoType>();
18102  
18103    if (OldFT->hasExtParameterInfos()) {
18104      for (unsigned I = 0, E = OldFT->getNumParams(); I != E; ++I)
18105        // A parameter of the overriding method should be annotated with noescape
18106        // if the corresponding parameter of the overridden method is annotated.
18107        if (OldFT->getExtParameterInfo(I).isNoEscape() &&
18108            !NewFT->getExtParameterInfo(I).isNoEscape()) {
18109          Diag(New->getParamDecl(I)->getLocation(),
18110               diag::warn_overriding_method_missing_noescape);
18111          Diag(Old->getParamDecl(I)->getLocation(),
18112               diag::note_overridden_marked_noescape);
18113        }
18114    }
18115  
18116    // SME attributes must match when overriding a function declaration.
18117    if (IsInvalidSMECallConversion(Old->getType(), New->getType())) {
18118      Diag(New->getLocation(), diag::err_conflicting_overriding_attributes)
18119          << New << New->getType() << Old->getType();
18120      Diag(Old->getLocation(), diag::note_overridden_virtual_function);
18121      return true;
18122    }
18123  
18124    // Virtual overrides must have the same code_seg.
18125    const auto *OldCSA = Old->getAttr<CodeSegAttr>();
18126    const auto *NewCSA = New->getAttr<CodeSegAttr>();
18127    if ((NewCSA || OldCSA) &&
18128        (!OldCSA || !NewCSA || NewCSA->getName() != OldCSA->getName())) {
18129      Diag(New->getLocation(), diag::err_mismatched_code_seg_override);
18130      Diag(Old->getLocation(), diag::note_previous_declaration);
18131      return true;
18132    }
18133  
18134    // Virtual overrides: check for matching effects.
18135    if (Context.hasAnyFunctionEffects()) {
18136      const auto OldFX = Old->getFunctionEffects();
18137      const auto NewFXOrig = New->getFunctionEffects();
18138  
18139      if (OldFX != NewFXOrig) {
18140        FunctionEffectSet NewFX(NewFXOrig);
18141        const auto Diffs = FunctionEffectDifferences(OldFX, NewFX);
18142        FunctionEffectSet::Conflicts Errs;
18143        for (const auto &Diff : Diffs) {
18144          switch (Diff.shouldDiagnoseMethodOverride(*Old, OldFX, *New, NewFX)) {
18145          case FunctionEffectDiff::OverrideResult::NoAction:
18146            break;
18147          case FunctionEffectDiff::OverrideResult::Warn:
18148            Diag(New->getLocation(), diag::warn_mismatched_func_effect_override)
18149                << Diff.effectName();
18150            Diag(Old->getLocation(), diag::note_overridden_virtual_function)
18151                << Old->getReturnTypeSourceRange();
18152            break;
18153          case FunctionEffectDiff::OverrideResult::Merge: {
18154            NewFX.insert(Diff.Old, Errs);
18155            const auto *NewFT = New->getType()->castAs<FunctionProtoType>();
18156            FunctionProtoType::ExtProtoInfo EPI = NewFT->getExtProtoInfo();
18157            EPI.FunctionEffects = FunctionEffectsRef(NewFX);
18158            QualType ModQT = Context.getFunctionType(NewFT->getReturnType(),
18159                                                     NewFT->getParamTypes(), EPI);
18160            New->setType(ModQT);
18161            break;
18162          }
18163          }
18164        }
18165        if (!Errs.empty())
18166          diagnoseFunctionEffectMergeConflicts(Errs, New->getLocation(),
18167                                               Old->getLocation());
18168      }
18169    }
18170  
18171    CallingConv NewCC = NewFT->getCallConv(), OldCC = OldFT->getCallConv();
18172  
18173    // If the calling conventions match, everything is fine
18174    if (NewCC == OldCC)
18175      return false;
18176  
18177    // If the calling conventions mismatch because the new function is static,
18178    // suppress the calling convention mismatch error; the error about static
18179    // function override (err_static_overrides_virtual from
18180    // Sema::CheckFunctionDeclaration) is more clear.
18181    if (New->getStorageClass() == SC_Static)
18182      return false;
18183  
18184    Diag(New->getLocation(),
18185         diag::err_conflicting_overriding_cc_attributes)
18186      << New->getDeclName() << New->getType() << Old->getType();
18187    Diag(Old->getLocation(), diag::note_overridden_virtual_function);
18188    return true;
18189  }
18190  
18191  bool Sema::CheckExplicitObjectOverride(CXXMethodDecl *New,
18192                                         const CXXMethodDecl *Old) {
18193    // CWG2553
18194    // A virtual function shall not be an explicit object member function.
18195    if (!New->isExplicitObjectMemberFunction())
18196      return true;
18197    Diag(New->getParamDecl(0)->getBeginLoc(),
18198         diag::err_explicit_object_parameter_nonmember)
18199        << New->getSourceRange() << /*virtual*/ 1 << /*IsLambda*/ false;
18200    Diag(Old->getLocation(), diag::note_overridden_virtual_function);
18201    New->setInvalidDecl();
18202    return false;
18203  }
18204  
18205  bool Sema::CheckOverridingFunctionReturnType(const CXXMethodDecl *New,
18206                                               const CXXMethodDecl *Old) {
18207    QualType NewTy = New->getType()->castAs<FunctionType>()->getReturnType();
18208    QualType OldTy = Old->getType()->castAs<FunctionType>()->getReturnType();
18209  
18210    if (Context.hasSameType(NewTy, OldTy) ||
18211        NewTy->isDependentType() || OldTy->isDependentType())
18212      return false;
18213  
18214    // Check if the return types are covariant
18215    QualType NewClassTy, OldClassTy;
18216  
18217    /// Both types must be pointers or references to classes.
18218    if (const PointerType *NewPT = NewTy->getAs<PointerType>()) {
18219      if (const PointerType *OldPT = OldTy->getAs<PointerType>()) {
18220        NewClassTy = NewPT->getPointeeType();
18221        OldClassTy = OldPT->getPointeeType();
18222      }
18223    } else if (const ReferenceType *NewRT = NewTy->getAs<ReferenceType>()) {
18224      if (const ReferenceType *OldRT = OldTy->getAs<ReferenceType>()) {
18225        if (NewRT->getTypeClass() == OldRT->getTypeClass()) {
18226          NewClassTy = NewRT->getPointeeType();
18227          OldClassTy = OldRT->getPointeeType();
18228        }
18229      }
18230    }
18231  
18232    // The return types aren't either both pointers or references to a class type.
18233    if (NewClassTy.isNull()) {
18234      Diag(New->getLocation(),
18235           diag::err_different_return_type_for_overriding_virtual_function)
18236          << New->getDeclName() << NewTy << OldTy
18237          << New->getReturnTypeSourceRange();
18238      Diag(Old->getLocation(), diag::note_overridden_virtual_function)
18239          << Old->getReturnTypeSourceRange();
18240  
18241      return true;
18242    }
18243  
18244    if (!Context.hasSameUnqualifiedType(NewClassTy, OldClassTy)) {
18245      // C++14 [class.virtual]p8:
18246      //   If the class type in the covariant return type of D::f differs from
18247      //   that of B::f, the class type in the return type of D::f shall be
18248      //   complete at the point of declaration of D::f or shall be the class
18249      //   type D.
18250      if (const RecordType *RT = NewClassTy->getAs<RecordType>()) {
18251        if (!RT->isBeingDefined() &&
18252            RequireCompleteType(New->getLocation(), NewClassTy,
18253                                diag::err_covariant_return_incomplete,
18254                                New->getDeclName()))
18255          return true;
18256      }
18257  
18258      // Check if the new class derives from the old class.
18259      if (!IsDerivedFrom(New->getLocation(), NewClassTy, OldClassTy)) {
18260        Diag(New->getLocation(), diag::err_covariant_return_not_derived)
18261            << New->getDeclName() << NewTy << OldTy
18262            << New->getReturnTypeSourceRange();
18263        Diag(Old->getLocation(), diag::note_overridden_virtual_function)
18264            << Old->getReturnTypeSourceRange();
18265        return true;
18266      }
18267  
18268      // Check if we the conversion from derived to base is valid.
18269      if (CheckDerivedToBaseConversion(
18270              NewClassTy, OldClassTy,
18271              diag::err_covariant_return_inaccessible_base,
18272              diag::err_covariant_return_ambiguous_derived_to_base_conv,
18273              New->getLocation(), New->getReturnTypeSourceRange(),
18274              New->getDeclName(), nullptr)) {
18275        // FIXME: this note won't trigger for delayed access control
18276        // diagnostics, and it's impossible to get an undelayed error
18277        // here from access control during the original parse because
18278        // the ParsingDeclSpec/ParsingDeclarator are still in scope.
18279        Diag(Old->getLocation(), diag::note_overridden_virtual_function)
18280            << Old->getReturnTypeSourceRange();
18281        return true;
18282      }
18283    }
18284  
18285    // The qualifiers of the return types must be the same.
18286    if (NewTy.getLocalCVRQualifiers() != OldTy.getLocalCVRQualifiers()) {
18287      Diag(New->getLocation(),
18288           diag::err_covariant_return_type_different_qualifications)
18289          << New->getDeclName() << NewTy << OldTy
18290          << New->getReturnTypeSourceRange();
18291      Diag(Old->getLocation(), diag::note_overridden_virtual_function)
18292          << Old->getReturnTypeSourceRange();
18293      return true;
18294    }
18295  
18296  
18297    // The new class type must have the same or less qualifiers as the old type.
18298    if (NewClassTy.isMoreQualifiedThan(OldClassTy)) {
18299      Diag(New->getLocation(),
18300           diag::err_covariant_return_type_class_type_more_qualified)
18301          << New->getDeclName() << NewTy << OldTy
18302          << New->getReturnTypeSourceRange();
18303      Diag(Old->getLocation(), diag::note_overridden_virtual_function)
18304          << Old->getReturnTypeSourceRange();
18305      return true;
18306    }
18307  
18308    return false;
18309  }
18310  
18311  bool Sema::CheckPureMethod(CXXMethodDecl *Method, SourceRange InitRange) {
18312    SourceLocation EndLoc = InitRange.getEnd();
18313    if (EndLoc.isValid())
18314      Method->setRangeEnd(EndLoc);
18315  
18316    if (Method->isVirtual() || Method->getParent()->isDependentContext()) {
18317      Method->setIsPureVirtual();
18318      return false;
18319    }
18320  
18321    if (!Method->isInvalidDecl())
18322      Diag(Method->getLocation(), diag::err_non_virtual_pure)
18323        << Method->getDeclName() << InitRange;
18324    return true;
18325  }
18326  
18327  void Sema::ActOnPureSpecifier(Decl *D, SourceLocation ZeroLoc) {
18328    if (D->getFriendObjectKind())
18329      Diag(D->getLocation(), diag::err_pure_friend);
18330    else if (auto *M = dyn_cast<CXXMethodDecl>(D))
18331      CheckPureMethod(M, ZeroLoc);
18332    else
18333      Diag(D->getLocation(), diag::err_illegal_initializer);
18334  }
18335  
18336  /// Invoked when we are about to parse an initializer for the declaration
18337  /// 'Dcl'.
18338  ///
18339  /// After this method is called, according to [C++ 3.4.1p13], if 'Dcl' is a
18340  /// static data member of class X, names should be looked up in the scope of
18341  /// class X. If the declaration had a scope specifier, a scope will have
18342  /// been created and passed in for this purpose. Otherwise, S will be null.
18343  void Sema::ActOnCXXEnterDeclInitializer(Scope *S, Decl *D) {
18344    assert(D && !D->isInvalidDecl());
18345  
18346    // We will always have a nested name specifier here, but this declaration
18347    // might not be out of line if the specifier names the current namespace:
18348    //   extern int n;
18349    //   int ::n = 0;
18350    if (S && D->isOutOfLine())
18351      EnterDeclaratorContext(S, D->getDeclContext());
18352  
18353    PushExpressionEvaluationContext(
18354        ExpressionEvaluationContext::PotentiallyEvaluated, D);
18355  }
18356  
18357  void Sema::ActOnCXXExitDeclInitializer(Scope *S, Decl *D) {
18358    assert(D);
18359  
18360    if (S && D->isOutOfLine())
18361      ExitDeclaratorContext(S);
18362  
18363    if (getLangOpts().CPlusPlus23) {
18364      // An expression or conversion is 'manifestly constant-evaluated' if it is:
18365      // [...]
18366      // - the initializer of a variable that is usable in constant expressions or
18367      //   has constant initialization.
18368      if (auto *VD = dyn_cast<VarDecl>(D);
18369          VD && (VD->isUsableInConstantExpressions(Context) ||
18370                 VD->hasConstantInitialization())) {
18371        // An expression or conversion is in an 'immediate function context' if it
18372        // is potentially evaluated and either:
18373        // [...]
18374        // - it is a subexpression of a manifestly constant-evaluated expression
18375        //   or conversion.
18376        ExprEvalContexts.back().InImmediateFunctionContext = true;
18377      }
18378    }
18379  
18380    // Unless the initializer is in an immediate function context (as determined
18381    // above), this will evaluate all contained immediate function calls as
18382    // constant expressions. If the initializer IS an immediate function context,
18383    // the initializer has been determined to be a constant expression, and all
18384    // such evaluations will be elided (i.e., as if we "knew the whole time" that
18385    // it was a constant expression).
18386    PopExpressionEvaluationContext();
18387  }
18388  
18389  DeclResult Sema::ActOnCXXConditionDeclaration(Scope *S, Declarator &D) {
18390    // C++ 6.4p2:
18391    // The declarator shall not specify a function or an array.
18392    // The type-specifier-seq shall not contain typedef and shall not declare a
18393    // new class or enumeration.
18394    assert(D.getDeclSpec().getStorageClassSpec() != DeclSpec::SCS_typedef &&
18395           "Parser allowed 'typedef' as storage class of condition decl.");
18396  
18397    Decl *Dcl = ActOnDeclarator(S, D);
18398    if (!Dcl)
18399      return true;
18400  
18401    if (isa<FunctionDecl>(Dcl)) { // The declarator shall not specify a function.
18402      Diag(Dcl->getLocation(), diag::err_invalid_use_of_function_type)
18403        << D.getSourceRange();
18404      return true;
18405    }
18406  
18407    if (auto *VD = dyn_cast<VarDecl>(Dcl))
18408      VD->setCXXCondDecl();
18409  
18410    return Dcl;
18411  }
18412  
18413  void Sema::LoadExternalVTableUses() {
18414    if (!ExternalSource)
18415      return;
18416  
18417    SmallVector<ExternalVTableUse, 4> VTables;
18418    ExternalSource->ReadUsedVTables(VTables);
18419    SmallVector<VTableUse, 4> NewUses;
18420    for (unsigned I = 0, N = VTables.size(); I != N; ++I) {
18421      llvm::DenseMap<CXXRecordDecl *, bool>::iterator Pos
18422        = VTablesUsed.find(VTables[I].Record);
18423      // Even if a definition wasn't required before, it may be required now.
18424      if (Pos != VTablesUsed.end()) {
18425        if (!Pos->second && VTables[I].DefinitionRequired)
18426          Pos->second = true;
18427        continue;
18428      }
18429  
18430      VTablesUsed[VTables[I].Record] = VTables[I].DefinitionRequired;
18431      NewUses.push_back(VTableUse(VTables[I].Record, VTables[I].Location));
18432    }
18433  
18434    VTableUses.insert(VTableUses.begin(), NewUses.begin(), NewUses.end());
18435  }
18436  
18437  void Sema::MarkVTableUsed(SourceLocation Loc, CXXRecordDecl *Class,
18438                            bool DefinitionRequired) {
18439    // Ignore any vtable uses in unevaluated operands or for classes that do
18440    // not have a vtable.
18441    if (!Class->isDynamicClass() || Class->isDependentContext() ||
18442        CurContext->isDependentContext() || isUnevaluatedContext())
18443      return;
18444    // Do not mark as used if compiling for the device outside of the target
18445    // region.
18446    if (TUKind != TU_Prefix && LangOpts.OpenMP && LangOpts.OpenMPIsTargetDevice &&
18447        !OpenMP().isInOpenMPDeclareTargetContext() &&
18448        !OpenMP().isInOpenMPTargetExecutionDirective()) {
18449      if (!DefinitionRequired)
18450        MarkVirtualMembersReferenced(Loc, Class);
18451      return;
18452    }
18453  
18454    // Try to insert this class into the map.
18455    LoadExternalVTableUses();
18456    Class = Class->getCanonicalDecl();
18457    std::pair<llvm::DenseMap<CXXRecordDecl *, bool>::iterator, bool>
18458      Pos = VTablesUsed.insert(std::make_pair(Class, DefinitionRequired));
18459    if (!Pos.second) {
18460      // If we already had an entry, check to see if we are promoting this vtable
18461      // to require a definition. If so, we need to reappend to the VTableUses
18462      // list, since we may have already processed the first entry.
18463      if (DefinitionRequired && !Pos.first->second) {
18464        Pos.first->second = true;
18465      } else {
18466        // Otherwise, we can early exit.
18467        return;
18468      }
18469    } else {
18470      // The Microsoft ABI requires that we perform the destructor body
18471      // checks (i.e. operator delete() lookup) when the vtable is marked used, as
18472      // the deleting destructor is emitted with the vtable, not with the
18473      // destructor definition as in the Itanium ABI.
18474      if (Context.getTargetInfo().getCXXABI().isMicrosoft()) {
18475        CXXDestructorDecl *DD = Class->getDestructor();
18476        if (DD && DD->isVirtual() && !DD->isDeleted()) {
18477          if (Class->hasUserDeclaredDestructor() && !DD->isDefined()) {
18478            // If this is an out-of-line declaration, marking it referenced will
18479            // not do anything. Manually call CheckDestructor to look up operator
18480            // delete().
18481            ContextRAII SavedContext(*this, DD);
18482            CheckDestructor(DD);
18483          } else {
18484            MarkFunctionReferenced(Loc, Class->getDestructor());
18485          }
18486        }
18487      }
18488    }
18489  
18490    // Local classes need to have their virtual members marked
18491    // immediately. For all other classes, we mark their virtual members
18492    // at the end of the translation unit.
18493    if (Class->isLocalClass())
18494      MarkVirtualMembersReferenced(Loc, Class->getDefinition());
18495    else
18496      VTableUses.push_back(std::make_pair(Class, Loc));
18497  }
18498  
18499  bool Sema::DefineUsedVTables() {
18500    LoadExternalVTableUses();
18501    if (VTableUses.empty())
18502      return false;
18503  
18504    // Note: The VTableUses vector could grow as a result of marking
18505    // the members of a class as "used", so we check the size each
18506    // time through the loop and prefer indices (which are stable) to
18507    // iterators (which are not).
18508    bool DefinedAnything = false;
18509    for (unsigned I = 0; I != VTableUses.size(); ++I) {
18510      CXXRecordDecl *Class = VTableUses[I].first->getDefinition();
18511      if (!Class)
18512        continue;
18513      TemplateSpecializationKind ClassTSK =
18514          Class->getTemplateSpecializationKind();
18515  
18516      SourceLocation Loc = VTableUses[I].second;
18517  
18518      bool DefineVTable = true;
18519  
18520      const CXXMethodDecl *KeyFunction = Context.getCurrentKeyFunction(Class);
18521      // V-tables for non-template classes with an owning module are always
18522      // uniquely emitted in that module.
18523      if (Class->isInCurrentModuleUnit()) {
18524        DefineVTable = true;
18525      } else if (KeyFunction && !KeyFunction->hasBody()) {
18526        // If this class has a key function, but that key function is
18527        // defined in another translation unit, we don't need to emit the
18528        // vtable even though we're using it.
18529        // The key function is in another translation unit.
18530        DefineVTable = false;
18531        TemplateSpecializationKind TSK =
18532            KeyFunction->getTemplateSpecializationKind();
18533        assert(TSK != TSK_ExplicitInstantiationDefinition &&
18534               TSK != TSK_ImplicitInstantiation &&
18535               "Instantiations don't have key functions");
18536        (void)TSK;
18537      } else if (!KeyFunction) {
18538        // If we have a class with no key function that is the subject
18539        // of an explicit instantiation declaration, suppress the
18540        // vtable; it will live with the explicit instantiation
18541        // definition.
18542        bool IsExplicitInstantiationDeclaration =
18543            ClassTSK == TSK_ExplicitInstantiationDeclaration;
18544        for (auto *R : Class->redecls()) {
18545          TemplateSpecializationKind TSK
18546            = cast<CXXRecordDecl>(R)->getTemplateSpecializationKind();
18547          if (TSK == TSK_ExplicitInstantiationDeclaration)
18548            IsExplicitInstantiationDeclaration = true;
18549          else if (TSK == TSK_ExplicitInstantiationDefinition) {
18550            IsExplicitInstantiationDeclaration = false;
18551            break;
18552          }
18553        }
18554  
18555        if (IsExplicitInstantiationDeclaration)
18556          DefineVTable = false;
18557      }
18558  
18559      // The exception specifications for all virtual members may be needed even
18560      // if we are not providing an authoritative form of the vtable in this TU.
18561      // We may choose to emit it available_externally anyway.
18562      if (!DefineVTable) {
18563        MarkVirtualMemberExceptionSpecsNeeded(Loc, Class);
18564        continue;
18565      }
18566  
18567      // Mark all of the virtual members of this class as referenced, so
18568      // that we can build a vtable. Then, tell the AST consumer that a
18569      // vtable for this class is required.
18570      DefinedAnything = true;
18571      MarkVirtualMembersReferenced(Loc, Class);
18572      CXXRecordDecl *Canonical = Class->getCanonicalDecl();
18573      if (VTablesUsed[Canonical] && !Class->shouldEmitInExternalSource())
18574        Consumer.HandleVTable(Class);
18575  
18576      // Warn if we're emitting a weak vtable. The vtable will be weak if there is
18577      // no key function or the key function is inlined. Don't warn in C++ ABIs
18578      // that lack key functions, since the user won't be able to make one.
18579      if (Context.getTargetInfo().getCXXABI().hasKeyFunctions() &&
18580          Class->isExternallyVisible() && ClassTSK != TSK_ImplicitInstantiation &&
18581          ClassTSK != TSK_ExplicitInstantiationDefinition) {
18582        const FunctionDecl *KeyFunctionDef = nullptr;
18583        if (!KeyFunction || (KeyFunction->hasBody(KeyFunctionDef) &&
18584                             KeyFunctionDef->isInlined()))
18585          Diag(Class->getLocation(), diag::warn_weak_vtable) << Class;
18586      }
18587    }
18588    VTableUses.clear();
18589  
18590    return DefinedAnything;
18591  }
18592  
18593  void Sema::MarkVirtualMemberExceptionSpecsNeeded(SourceLocation Loc,
18594                                                   const CXXRecordDecl *RD) {
18595    for (const auto *I : RD->methods())
18596      if (I->isVirtual() && !I->isPureVirtual())
18597        ResolveExceptionSpec(Loc, I->getType()->castAs<FunctionProtoType>());
18598  }
18599  
18600  void Sema::MarkVirtualMembersReferenced(SourceLocation Loc,
18601                                          const CXXRecordDecl *RD,
18602                                          bool ConstexprOnly) {
18603    // Mark all functions which will appear in RD's vtable as used.
18604    CXXFinalOverriderMap FinalOverriders;
18605    RD->getFinalOverriders(FinalOverriders);
18606    for (CXXFinalOverriderMap::const_iterator I = FinalOverriders.begin(),
18607                                              E = FinalOverriders.end();
18608         I != E; ++I) {
18609      for (OverridingMethods::const_iterator OI = I->second.begin(),
18610                                             OE = I->second.end();
18611           OI != OE; ++OI) {
18612        assert(OI->second.size() > 0 && "no final overrider");
18613        CXXMethodDecl *Overrider = OI->second.front().Method;
18614  
18615        // C++ [basic.def.odr]p2:
18616        //   [...] A virtual member function is used if it is not pure. [...]
18617        if (!Overrider->isPureVirtual() &&
18618            (!ConstexprOnly || Overrider->isConstexpr()))
18619          MarkFunctionReferenced(Loc, Overrider);
18620      }
18621    }
18622  
18623    // Only classes that have virtual bases need a VTT.
18624    if (RD->getNumVBases() == 0)
18625      return;
18626  
18627    for (const auto &I : RD->bases()) {
18628      const auto *Base =
18629          cast<CXXRecordDecl>(I.getType()->castAs<RecordType>()->getDecl());
18630      if (Base->getNumVBases() == 0)
18631        continue;
18632      MarkVirtualMembersReferenced(Loc, Base);
18633    }
18634  }
18635  
18636  static
18637  void DelegatingCycleHelper(CXXConstructorDecl* Ctor,
18638                             llvm::SmallPtrSet<CXXConstructorDecl*, 4> &Valid,
18639                             llvm::SmallPtrSet<CXXConstructorDecl*, 4> &Invalid,
18640                             llvm::SmallPtrSet<CXXConstructorDecl*, 4> &Current,
18641                             Sema &S) {
18642    if (Ctor->isInvalidDecl())
18643      return;
18644  
18645    CXXConstructorDecl *Target = Ctor->getTargetConstructor();
18646  
18647    // Target may not be determinable yet, for instance if this is a dependent
18648    // call in an uninstantiated template.
18649    if (Target) {
18650      const FunctionDecl *FNTarget = nullptr;
18651      (void)Target->hasBody(FNTarget);
18652      Target = const_cast<CXXConstructorDecl*>(
18653        cast_or_null<CXXConstructorDecl>(FNTarget));
18654    }
18655  
18656    CXXConstructorDecl *Canonical = Ctor->getCanonicalDecl(),
18657                       // Avoid dereferencing a null pointer here.
18658                       *TCanonical = Target? Target->getCanonicalDecl() : nullptr;
18659  
18660    if (!Current.insert(Canonical).second)
18661      return;
18662  
18663    // We know that beyond here, we aren't chaining into a cycle.
18664    if (!Target || !Target->isDelegatingConstructor() ||
18665        Target->isInvalidDecl() || Valid.count(TCanonical)) {
18666      Valid.insert(Current.begin(), Current.end());
18667      Current.clear();
18668    // We've hit a cycle.
18669    } else if (TCanonical == Canonical || Invalid.count(TCanonical) ||
18670               Current.count(TCanonical)) {
18671      // If we haven't diagnosed this cycle yet, do so now.
18672      if (!Invalid.count(TCanonical)) {
18673        S.Diag((*Ctor->init_begin())->getSourceLocation(),
18674               diag::warn_delegating_ctor_cycle)
18675          << Ctor;
18676  
18677        // Don't add a note for a function delegating directly to itself.
18678        if (TCanonical != Canonical)
18679          S.Diag(Target->getLocation(), diag::note_it_delegates_to);
18680  
18681        CXXConstructorDecl *C = Target;
18682        while (C->getCanonicalDecl() != Canonical) {
18683          const FunctionDecl *FNTarget = nullptr;
18684          (void)C->getTargetConstructor()->hasBody(FNTarget);
18685          assert(FNTarget && "Ctor cycle through bodiless function");
18686  
18687          C = const_cast<CXXConstructorDecl*>(
18688            cast<CXXConstructorDecl>(FNTarget));
18689          S.Diag(C->getLocation(), diag::note_which_delegates_to);
18690        }
18691      }
18692  
18693      Invalid.insert(Current.begin(), Current.end());
18694      Current.clear();
18695    } else {
18696      DelegatingCycleHelper(Target, Valid, Invalid, Current, S);
18697    }
18698  }
18699  
18700  
18701  void Sema::CheckDelegatingCtorCycles() {
18702    llvm::SmallPtrSet<CXXConstructorDecl*, 4> Valid, Invalid, Current;
18703  
18704    for (DelegatingCtorDeclsType::iterator
18705             I = DelegatingCtorDecls.begin(ExternalSource.get()),
18706             E = DelegatingCtorDecls.end();
18707         I != E; ++I)
18708      DelegatingCycleHelper(*I, Valid, Invalid, Current, *this);
18709  
18710    for (auto CI = Invalid.begin(), CE = Invalid.end(); CI != CE; ++CI)
18711      (*CI)->setInvalidDecl();
18712  }
18713  
18714  namespace {
18715    /// AST visitor that finds references to the 'this' expression.
18716    class FindCXXThisExpr : public RecursiveASTVisitor<FindCXXThisExpr> {
18717      Sema &S;
18718  
18719    public:
18720      explicit FindCXXThisExpr(Sema &S) : S(S) { }
18721  
18722      bool VisitCXXThisExpr(CXXThisExpr *E) {
18723        S.Diag(E->getLocation(), diag::err_this_static_member_func)
18724          << E->isImplicit();
18725        return false;
18726      }
18727    };
18728  }
18729  
18730  bool Sema::checkThisInStaticMemberFunctionType(CXXMethodDecl *Method) {
18731    TypeSourceInfo *TSInfo = Method->getTypeSourceInfo();
18732    if (!TSInfo)
18733      return false;
18734  
18735    TypeLoc TL = TSInfo->getTypeLoc();
18736    FunctionProtoTypeLoc ProtoTL = TL.getAs<FunctionProtoTypeLoc>();
18737    if (!ProtoTL)
18738      return false;
18739  
18740    // C++11 [expr.prim.general]p3:
18741    //   [The expression this] shall not appear before the optional
18742    //   cv-qualifier-seq and it shall not appear within the declaration of a
18743    //   static member function (although its type and value category are defined
18744    //   within a static member function as they are within a non-static member
18745    //   function). [ Note: this is because declaration matching does not occur
18746    //  until the complete declarator is known. - end note ]
18747    const FunctionProtoType *Proto = ProtoTL.getTypePtr();
18748    FindCXXThisExpr Finder(*this);
18749  
18750    // If the return type came after the cv-qualifier-seq, check it now.
18751    if (Proto->hasTrailingReturn() &&
18752        !Finder.TraverseTypeLoc(ProtoTL.getReturnLoc()))
18753      return true;
18754  
18755    // Check the exception specification.
18756    if (checkThisInStaticMemberFunctionExceptionSpec(Method))
18757      return true;
18758  
18759    // Check the trailing requires clause
18760    if (Expr *E = Method->getTrailingRequiresClause())
18761      if (!Finder.TraverseStmt(E))
18762        return true;
18763  
18764    return checkThisInStaticMemberFunctionAttributes(Method);
18765  }
18766  
18767  bool Sema::checkThisInStaticMemberFunctionExceptionSpec(CXXMethodDecl *Method) {
18768    TypeSourceInfo *TSInfo = Method->getTypeSourceInfo();
18769    if (!TSInfo)
18770      return false;
18771  
18772    TypeLoc TL = TSInfo->getTypeLoc();
18773    FunctionProtoTypeLoc ProtoTL = TL.getAs<FunctionProtoTypeLoc>();
18774    if (!ProtoTL)
18775      return false;
18776  
18777    const FunctionProtoType *Proto = ProtoTL.getTypePtr();
18778    FindCXXThisExpr Finder(*this);
18779  
18780    switch (Proto->getExceptionSpecType()) {
18781    case EST_Unparsed:
18782    case EST_Uninstantiated:
18783    case EST_Unevaluated:
18784    case EST_BasicNoexcept:
18785    case EST_NoThrow:
18786    case EST_DynamicNone:
18787    case EST_MSAny:
18788    case EST_None:
18789      break;
18790  
18791    case EST_DependentNoexcept:
18792    case EST_NoexceptFalse:
18793    case EST_NoexceptTrue:
18794      if (!Finder.TraverseStmt(Proto->getNoexceptExpr()))
18795        return true;
18796      [[fallthrough]];
18797  
18798    case EST_Dynamic:
18799      for (const auto &E : Proto->exceptions()) {
18800        if (!Finder.TraverseType(E))
18801          return true;
18802      }
18803      break;
18804    }
18805  
18806    return false;
18807  }
18808  
18809  bool Sema::checkThisInStaticMemberFunctionAttributes(CXXMethodDecl *Method) {
18810    FindCXXThisExpr Finder(*this);
18811  
18812    // Check attributes.
18813    for (const auto *A : Method->attrs()) {
18814      // FIXME: This should be emitted by tblgen.
18815      Expr *Arg = nullptr;
18816      ArrayRef<Expr *> Args;
18817      if (const auto *G = dyn_cast<GuardedByAttr>(A))
18818        Arg = G->getArg();
18819      else if (const auto *G = dyn_cast<PtGuardedByAttr>(A))
18820        Arg = G->getArg();
18821      else if (const auto *AA = dyn_cast<AcquiredAfterAttr>(A))
18822        Args = llvm::ArrayRef(AA->args_begin(), AA->args_size());
18823      else if (const auto *AB = dyn_cast<AcquiredBeforeAttr>(A))
18824        Args = llvm::ArrayRef(AB->args_begin(), AB->args_size());
18825      else if (const auto *ETLF = dyn_cast<ExclusiveTrylockFunctionAttr>(A)) {
18826        Arg = ETLF->getSuccessValue();
18827        Args = llvm::ArrayRef(ETLF->args_begin(), ETLF->args_size());
18828      } else if (const auto *STLF = dyn_cast<SharedTrylockFunctionAttr>(A)) {
18829        Arg = STLF->getSuccessValue();
18830        Args = llvm::ArrayRef(STLF->args_begin(), STLF->args_size());
18831      } else if (const auto *LR = dyn_cast<LockReturnedAttr>(A))
18832        Arg = LR->getArg();
18833      else if (const auto *LE = dyn_cast<LocksExcludedAttr>(A))
18834        Args = llvm::ArrayRef(LE->args_begin(), LE->args_size());
18835      else if (const auto *RC = dyn_cast<RequiresCapabilityAttr>(A))
18836        Args = llvm::ArrayRef(RC->args_begin(), RC->args_size());
18837      else if (const auto *AC = dyn_cast<AcquireCapabilityAttr>(A))
18838        Args = llvm::ArrayRef(AC->args_begin(), AC->args_size());
18839      else if (const auto *AC = dyn_cast<TryAcquireCapabilityAttr>(A))
18840        Args = llvm::ArrayRef(AC->args_begin(), AC->args_size());
18841      else if (const auto *RC = dyn_cast<ReleaseCapabilityAttr>(A))
18842        Args = llvm::ArrayRef(RC->args_begin(), RC->args_size());
18843  
18844      if (Arg && !Finder.TraverseStmt(Arg))
18845        return true;
18846  
18847      for (unsigned I = 0, N = Args.size(); I != N; ++I) {
18848        if (!Finder.TraverseStmt(Args[I]))
18849          return true;
18850      }
18851    }
18852  
18853    return false;
18854  }
18855  
18856  void Sema::checkExceptionSpecification(
18857      bool IsTopLevel, ExceptionSpecificationType EST,
18858      ArrayRef<ParsedType> DynamicExceptions,
18859      ArrayRef<SourceRange> DynamicExceptionRanges, Expr *NoexceptExpr,
18860      SmallVectorImpl<QualType> &Exceptions,
18861      FunctionProtoType::ExceptionSpecInfo &ESI) {
18862    Exceptions.clear();
18863    ESI.Type = EST;
18864    if (EST == EST_Dynamic) {
18865      Exceptions.reserve(DynamicExceptions.size());
18866      for (unsigned ei = 0, ee = DynamicExceptions.size(); ei != ee; ++ei) {
18867        // FIXME: Preserve type source info.
18868        QualType ET = GetTypeFromParser(DynamicExceptions[ei]);
18869  
18870        if (IsTopLevel) {
18871          SmallVector<UnexpandedParameterPack, 2> Unexpanded;
18872          collectUnexpandedParameterPacks(ET, Unexpanded);
18873          if (!Unexpanded.empty()) {
18874            DiagnoseUnexpandedParameterPacks(
18875                DynamicExceptionRanges[ei].getBegin(), UPPC_ExceptionType,
18876                Unexpanded);
18877            continue;
18878          }
18879        }
18880  
18881        // Check that the type is valid for an exception spec, and
18882        // drop it if not.
18883        if (!CheckSpecifiedExceptionType(ET, DynamicExceptionRanges[ei]))
18884          Exceptions.push_back(ET);
18885      }
18886      ESI.Exceptions = Exceptions;
18887      return;
18888    }
18889  
18890    if (isComputedNoexcept(EST)) {
18891      assert((NoexceptExpr->isTypeDependent() ||
18892              NoexceptExpr->getType()->getCanonicalTypeUnqualified() ==
18893              Context.BoolTy) &&
18894             "Parser should have made sure that the expression is boolean");
18895      if (IsTopLevel && DiagnoseUnexpandedParameterPack(NoexceptExpr)) {
18896        ESI.Type = EST_BasicNoexcept;
18897        return;
18898      }
18899  
18900      ESI.NoexceptExpr = NoexceptExpr;
18901      return;
18902    }
18903  }
18904  
18905  void Sema::actOnDelayedExceptionSpecification(
18906      Decl *D, ExceptionSpecificationType EST, SourceRange SpecificationRange,
18907      ArrayRef<ParsedType> DynamicExceptions,
18908      ArrayRef<SourceRange> DynamicExceptionRanges, Expr *NoexceptExpr) {
18909    if (!D)
18910      return;
18911  
18912    // Dig out the function we're referring to.
18913    if (FunctionTemplateDecl *FTD = dyn_cast<FunctionTemplateDecl>(D))
18914      D = FTD->getTemplatedDecl();
18915  
18916    FunctionDecl *FD = dyn_cast<FunctionDecl>(D);
18917    if (!FD)
18918      return;
18919  
18920    // Check the exception specification.
18921    llvm::SmallVector<QualType, 4> Exceptions;
18922    FunctionProtoType::ExceptionSpecInfo ESI;
18923    checkExceptionSpecification(/*IsTopLevel=*/true, EST, DynamicExceptions,
18924                                DynamicExceptionRanges, NoexceptExpr, Exceptions,
18925                                ESI);
18926  
18927    // Update the exception specification on the function type.
18928    Context.adjustExceptionSpec(FD, ESI, /*AsWritten=*/true);
18929  
18930    if (CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(D)) {
18931      if (MD->isStatic())
18932        checkThisInStaticMemberFunctionExceptionSpec(MD);
18933  
18934      if (MD->isVirtual()) {
18935        // Check overrides, which we previously had to delay.
18936        for (const CXXMethodDecl *O : MD->overridden_methods())
18937          CheckOverridingFunctionExceptionSpec(MD, O);
18938      }
18939    }
18940  }
18941  
18942  /// HandleMSProperty - Analyze a __delcspec(property) field of a C++ class.
18943  ///
18944  MSPropertyDecl *Sema::HandleMSProperty(Scope *S, RecordDecl *Record,
18945                                         SourceLocation DeclStart, Declarator &D,
18946                                         Expr *BitWidth,
18947                                         InClassInitStyle InitStyle,
18948                                         AccessSpecifier AS,
18949                                         const ParsedAttr &MSPropertyAttr) {
18950    const IdentifierInfo *II = D.getIdentifier();
18951    if (!II) {
18952      Diag(DeclStart, diag::err_anonymous_property);
18953      return nullptr;
18954    }
18955    SourceLocation Loc = D.getIdentifierLoc();
18956  
18957    TypeSourceInfo *TInfo = GetTypeForDeclarator(D);
18958    QualType T = TInfo->getType();
18959    if (getLangOpts().CPlusPlus) {
18960      CheckExtraCXXDefaultArguments(D);
18961  
18962      if (DiagnoseUnexpandedParameterPack(D.getIdentifierLoc(), TInfo,
18963                                          UPPC_DataMemberType)) {
18964        D.setInvalidType();
18965        T = Context.IntTy;
18966        TInfo = Context.getTrivialTypeSourceInfo(T, Loc);
18967      }
18968    }
18969  
18970    DiagnoseFunctionSpecifiers(D.getDeclSpec());
18971  
18972    if (D.getDeclSpec().isInlineSpecified())
18973      Diag(D.getDeclSpec().getInlineSpecLoc(), diag::err_inline_non_function)
18974          << getLangOpts().CPlusPlus17;
18975    if (DeclSpec::TSCS TSCS = D.getDeclSpec().getThreadStorageClassSpec())
18976      Diag(D.getDeclSpec().getThreadStorageClassSpecLoc(),
18977           diag::err_invalid_thread)
18978        << DeclSpec::getSpecifierName(TSCS);
18979  
18980    // Check to see if this name was declared as a member previously
18981    NamedDecl *PrevDecl = nullptr;
18982    LookupResult Previous(*this, II, Loc, LookupMemberName,
18983                          RedeclarationKind::ForVisibleRedeclaration);
18984    LookupName(Previous, S);
18985    switch (Previous.getResultKind()) {
18986    case LookupResult::Found:
18987    case LookupResult::FoundUnresolvedValue:
18988      PrevDecl = Previous.getAsSingle<NamedDecl>();
18989      break;
18990  
18991    case LookupResult::FoundOverloaded:
18992      PrevDecl = Previous.getRepresentativeDecl();
18993      break;
18994  
18995    case LookupResult::NotFound:
18996    case LookupResult::NotFoundInCurrentInstantiation:
18997    case LookupResult::Ambiguous:
18998      break;
18999    }
19000  
19001    if (PrevDecl && PrevDecl->isTemplateParameter()) {
19002      // Maybe we will complain about the shadowed template parameter.
19003      DiagnoseTemplateParameterShadow(D.getIdentifierLoc(), PrevDecl);
19004      // Just pretend that we didn't see the previous declaration.
19005      PrevDecl = nullptr;
19006    }
19007  
19008    if (PrevDecl && !isDeclInScope(PrevDecl, Record, S))
19009      PrevDecl = nullptr;
19010  
19011    SourceLocation TSSL = D.getBeginLoc();
19012    MSPropertyDecl *NewPD =
19013        MSPropertyDecl::Create(Context, Record, Loc, II, T, TInfo, TSSL,
19014                               MSPropertyAttr.getPropertyDataGetter(),
19015                               MSPropertyAttr.getPropertyDataSetter());
19016    ProcessDeclAttributes(TUScope, NewPD, D);
19017    NewPD->setAccess(AS);
19018  
19019    if (NewPD->isInvalidDecl())
19020      Record->setInvalidDecl();
19021  
19022    if (D.getDeclSpec().isModulePrivateSpecified())
19023      NewPD->setModulePrivate();
19024  
19025    if (NewPD->isInvalidDecl() && PrevDecl) {
19026      // Don't introduce NewFD into scope; there's already something
19027      // with the same name in the same scope.
19028    } else if (II) {
19029      PushOnScopeChains(NewPD, S);
19030    } else
19031      Record->addDecl(NewPD);
19032  
19033    return NewPD;
19034  }
19035  
19036  void Sema::ActOnStartFunctionDeclarationDeclarator(
19037      Declarator &Declarator, unsigned TemplateParameterDepth) {
19038    auto &Info = InventedParameterInfos.emplace_back();
19039    TemplateParameterList *ExplicitParams = nullptr;
19040    ArrayRef<TemplateParameterList *> ExplicitLists =
19041        Declarator.getTemplateParameterLists();
19042    if (!ExplicitLists.empty()) {
19043      bool IsMemberSpecialization, IsInvalid;
19044      ExplicitParams = MatchTemplateParametersToScopeSpecifier(
19045          Declarator.getBeginLoc(), Declarator.getIdentifierLoc(),
19046          Declarator.getCXXScopeSpec(), /*TemplateId=*/nullptr,
19047          ExplicitLists, /*IsFriend=*/false, IsMemberSpecialization, IsInvalid,
19048          /*SuppressDiagnostic=*/true);
19049    }
19050    // C++23 [dcl.fct]p23:
19051    //   An abbreviated function template can have a template-head. The invented
19052    //   template-parameters are appended to the template-parameter-list after
19053    //   the explicitly declared template-parameters.
19054    //
19055    // A template-head must have one or more template-parameters (read:
19056    // 'template<>' is *not* a template-head). Only append the invented
19057    // template parameters if we matched the nested-name-specifier to a non-empty
19058    // TemplateParameterList.
19059    if (ExplicitParams && !ExplicitParams->empty()) {
19060      Info.AutoTemplateParameterDepth = ExplicitParams->getDepth();
19061      llvm::append_range(Info.TemplateParams, *ExplicitParams);
19062      Info.NumExplicitTemplateParams = ExplicitParams->size();
19063    } else {
19064      Info.AutoTemplateParameterDepth = TemplateParameterDepth;
19065      Info.NumExplicitTemplateParams = 0;
19066    }
19067  }
19068  
19069  void Sema::ActOnFinishFunctionDeclarationDeclarator(Declarator &Declarator) {
19070    auto &FSI = InventedParameterInfos.back();
19071    if (FSI.TemplateParams.size() > FSI.NumExplicitTemplateParams) {
19072      if (FSI.NumExplicitTemplateParams != 0) {
19073        TemplateParameterList *ExplicitParams =
19074            Declarator.getTemplateParameterLists().back();
19075        Declarator.setInventedTemplateParameterList(
19076            TemplateParameterList::Create(
19077                Context, ExplicitParams->getTemplateLoc(),
19078                ExplicitParams->getLAngleLoc(), FSI.TemplateParams,
19079                ExplicitParams->getRAngleLoc(),
19080                ExplicitParams->getRequiresClause()));
19081      } else {
19082        Declarator.setInventedTemplateParameterList(
19083            TemplateParameterList::Create(
19084                Context, SourceLocation(), SourceLocation(), FSI.TemplateParams,
19085                SourceLocation(), /*RequiresClause=*/nullptr));
19086      }
19087    }
19088    InventedParameterInfos.pop_back();
19089  }
19090