xref: /llvm-project-15.0.7/clang/lib/AST/Expr.cpp (revision 6589a291)
1 //===--- Expr.cpp - Expression AST Node Implementation --------------------===//
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 the Expr class and subclasses.
10 //
11 //===----------------------------------------------------------------------===//
12 
13 #include "clang/AST/Expr.h"
14 #include "clang/AST/APValue.h"
15 #include "clang/AST/ASTContext.h"
16 #include "clang/AST/Attr.h"
17 #include "clang/AST/DeclCXX.h"
18 #include "clang/AST/DeclObjC.h"
19 #include "clang/AST/DeclTemplate.h"
20 #include "clang/AST/EvaluatedExprVisitor.h"
21 #include "clang/AST/ExprCXX.h"
22 #include "clang/AST/Mangle.h"
23 #include "clang/AST/RecordLayout.h"
24 #include "clang/AST/StmtVisitor.h"
25 #include "clang/Basic/Builtins.h"
26 #include "clang/Basic/CharInfo.h"
27 #include "clang/Basic/SourceManager.h"
28 #include "clang/Basic/TargetInfo.h"
29 #include "clang/Lex/Lexer.h"
30 #include "clang/Lex/LiteralSupport.h"
31 #include "llvm/Support/ErrorHandling.h"
32 #include "llvm/Support/raw_ostream.h"
33 #include <algorithm>
34 #include <cstring>
35 using namespace clang;
36 
37 const Expr *Expr::getBestDynamicClassTypeExpr() const {
38   const Expr *E = this;
39   while (true) {
40     E = E->ignoreParenBaseCasts();
41 
42     // Follow the RHS of a comma operator.
43     if (auto *BO = dyn_cast<BinaryOperator>(E)) {
44       if (BO->getOpcode() == BO_Comma) {
45         E = BO->getRHS();
46         continue;
47       }
48     }
49 
50     // Step into initializer for materialized temporaries.
51     if (auto *MTE = dyn_cast<MaterializeTemporaryExpr>(E)) {
52       E = MTE->getSubExpr();
53       continue;
54     }
55 
56     break;
57   }
58 
59   return E;
60 }
61 
62 const CXXRecordDecl *Expr::getBestDynamicClassType() const {
63   const Expr *E = getBestDynamicClassTypeExpr();
64   QualType DerivedType = E->getType();
65   if (const PointerType *PTy = DerivedType->getAs<PointerType>())
66     DerivedType = PTy->getPointeeType();
67 
68   if (DerivedType->isDependentType())
69     return nullptr;
70 
71   const RecordType *Ty = DerivedType->castAs<RecordType>();
72   Decl *D = Ty->getDecl();
73   return cast<CXXRecordDecl>(D);
74 }
75 
76 const Expr *Expr::skipRValueSubobjectAdjustments(
77     SmallVectorImpl<const Expr *> &CommaLHSs,
78     SmallVectorImpl<SubobjectAdjustment> &Adjustments) const {
79   const Expr *E = this;
80   while (true) {
81     E = E->IgnoreParens();
82 
83     if (const CastExpr *CE = dyn_cast<CastExpr>(E)) {
84       if ((CE->getCastKind() == CK_DerivedToBase ||
85            CE->getCastKind() == CK_UncheckedDerivedToBase) &&
86           E->getType()->isRecordType()) {
87         E = CE->getSubExpr();
88         auto *Derived =
89             cast<CXXRecordDecl>(E->getType()->castAs<RecordType>()->getDecl());
90         Adjustments.push_back(SubobjectAdjustment(CE, Derived));
91         continue;
92       }
93 
94       if (CE->getCastKind() == CK_NoOp) {
95         E = CE->getSubExpr();
96         continue;
97       }
98     } else if (const MemberExpr *ME = dyn_cast<MemberExpr>(E)) {
99       if (!ME->isArrow()) {
100         assert(ME->getBase()->getType()->isRecordType());
101         if (FieldDecl *Field = dyn_cast<FieldDecl>(ME->getMemberDecl())) {
102           if (!Field->isBitField() && !Field->getType()->isReferenceType()) {
103             E = ME->getBase();
104             Adjustments.push_back(SubobjectAdjustment(Field));
105             continue;
106           }
107         }
108       }
109     } else if (const BinaryOperator *BO = dyn_cast<BinaryOperator>(E)) {
110       if (BO->getOpcode() == BO_PtrMemD) {
111         assert(BO->getRHS()->isRValue());
112         E = BO->getLHS();
113         const MemberPointerType *MPT =
114           BO->getRHS()->getType()->getAs<MemberPointerType>();
115         Adjustments.push_back(SubobjectAdjustment(MPT, BO->getRHS()));
116         continue;
117       } else if (BO->getOpcode() == BO_Comma) {
118         CommaLHSs.push_back(BO->getLHS());
119         E = BO->getRHS();
120         continue;
121       }
122     }
123 
124     // Nothing changed.
125     break;
126   }
127   return E;
128 }
129 
130 bool Expr::isKnownToHaveBooleanValue(bool Semantic) const {
131   const Expr *E = IgnoreParens();
132 
133   // If this value has _Bool type, it is obvious 0/1.
134   if (E->getType()->isBooleanType()) return true;
135   // If this is a non-scalar-integer type, we don't care enough to try.
136   if (!E->getType()->isIntegralOrEnumerationType()) return false;
137 
138   if (const UnaryOperator *UO = dyn_cast<UnaryOperator>(E)) {
139     switch (UO->getOpcode()) {
140     case UO_Plus:
141       return UO->getSubExpr()->isKnownToHaveBooleanValue(Semantic);
142     case UO_LNot:
143       return true;
144     default:
145       return false;
146     }
147   }
148 
149   // Only look through implicit casts.  If the user writes
150   // '(int) (a && b)' treat it as an arbitrary int.
151   // FIXME: Should we look through any cast expression in !Semantic mode?
152   if (const ImplicitCastExpr *CE = dyn_cast<ImplicitCastExpr>(E))
153     return CE->getSubExpr()->isKnownToHaveBooleanValue(Semantic);
154 
155   if (const BinaryOperator *BO = dyn_cast<BinaryOperator>(E)) {
156     switch (BO->getOpcode()) {
157     default: return false;
158     case BO_LT:   // Relational operators.
159     case BO_GT:
160     case BO_LE:
161     case BO_GE:
162     case BO_EQ:   // Equality operators.
163     case BO_NE:
164     case BO_LAnd: // AND operator.
165     case BO_LOr:  // Logical OR operator.
166       return true;
167 
168     case BO_And:  // Bitwise AND operator.
169     case BO_Xor:  // Bitwise XOR operator.
170     case BO_Or:   // Bitwise OR operator.
171       // Handle things like (x==2)|(y==12).
172       return BO->getLHS()->isKnownToHaveBooleanValue(Semantic) &&
173              BO->getRHS()->isKnownToHaveBooleanValue(Semantic);
174 
175     case BO_Comma:
176     case BO_Assign:
177       return BO->getRHS()->isKnownToHaveBooleanValue(Semantic);
178     }
179   }
180 
181   if (const ConditionalOperator *CO = dyn_cast<ConditionalOperator>(E))
182     return CO->getTrueExpr()->isKnownToHaveBooleanValue(Semantic) &&
183            CO->getFalseExpr()->isKnownToHaveBooleanValue(Semantic);
184 
185   if (isa<ObjCBoolLiteralExpr>(E))
186     return true;
187 
188   if (const auto *OVE = dyn_cast<OpaqueValueExpr>(E))
189     return OVE->getSourceExpr()->isKnownToHaveBooleanValue(Semantic);
190 
191   if (const FieldDecl *FD = E->getSourceBitField())
192     if (!Semantic && FD->getType()->isUnsignedIntegerType() &&
193         !FD->getBitWidth()->isValueDependent() &&
194         FD->getBitWidthValue(FD->getASTContext()) == 1)
195       return true;
196 
197   return false;
198 }
199 
200 // Amusing macro metaprogramming hack: check whether a class provides
201 // a more specific implementation of getExprLoc().
202 //
203 // See also Stmt.cpp:{getBeginLoc(),getEndLoc()}.
204 namespace {
205   /// This implementation is used when a class provides a custom
206   /// implementation of getExprLoc.
207   template <class E, class T>
208   SourceLocation getExprLocImpl(const Expr *expr,
209                                 SourceLocation (T::*v)() const) {
210     return static_cast<const E*>(expr)->getExprLoc();
211   }
212 
213   /// This implementation is used when a class doesn't provide
214   /// a custom implementation of getExprLoc.  Overload resolution
215   /// should pick it over the implementation above because it's
216   /// more specialized according to function template partial ordering.
217   template <class E>
218   SourceLocation getExprLocImpl(const Expr *expr,
219                                 SourceLocation (Expr::*v)() const) {
220     return static_cast<const E *>(expr)->getBeginLoc();
221   }
222 }
223 
224 SourceLocation Expr::getExprLoc() const {
225   switch (getStmtClass()) {
226   case Stmt::NoStmtClass: llvm_unreachable("statement without class");
227 #define ABSTRACT_STMT(type)
228 #define STMT(type, base) \
229   case Stmt::type##Class: break;
230 #define EXPR(type, base) \
231   case Stmt::type##Class: return getExprLocImpl<type>(this, &type::getExprLoc);
232 #include "clang/AST/StmtNodes.inc"
233   }
234   llvm_unreachable("unknown expression kind");
235 }
236 
237 //===----------------------------------------------------------------------===//
238 // Primary Expressions.
239 //===----------------------------------------------------------------------===//
240 
241 static void AssertResultStorageKind(ConstantExpr::ResultStorageKind Kind) {
242   assert((Kind == ConstantExpr::RSK_APValue ||
243           Kind == ConstantExpr::RSK_Int64 || Kind == ConstantExpr::RSK_None) &&
244          "Invalid StorageKind Value");
245 }
246 
247 ConstantExpr::ResultStorageKind
248 ConstantExpr::getStorageKind(const APValue &Value) {
249   switch (Value.getKind()) {
250   case APValue::None:
251   case APValue::Indeterminate:
252     return ConstantExpr::RSK_None;
253   case APValue::Int:
254     if (!Value.getInt().needsCleanup())
255       return ConstantExpr::RSK_Int64;
256     LLVM_FALLTHROUGH;
257   default:
258     return ConstantExpr::RSK_APValue;
259   }
260 }
261 
262 ConstantExpr::ResultStorageKind
263 ConstantExpr::getStorageKind(const Type *T, const ASTContext &Context) {
264   if (T->isIntegralOrEnumerationType() && Context.getTypeInfo(T).Width <= 64)
265     return ConstantExpr::RSK_Int64;
266   return ConstantExpr::RSK_APValue;
267 }
268 
269 void ConstantExpr::DefaultInit(ResultStorageKind StorageKind) {
270   ConstantExprBits.ResultKind = StorageKind;
271   ConstantExprBits.APValueKind = APValue::None;
272   ConstantExprBits.HasCleanup = false;
273   if (StorageKind == ConstantExpr::RSK_APValue)
274     ::new (getTrailingObjects<APValue>()) APValue();
275 }
276 
277 ConstantExpr::ConstantExpr(Expr *subexpr, ResultStorageKind StorageKind)
278     : FullExpr(ConstantExprClass, subexpr) {
279   DefaultInit(StorageKind);
280 }
281 
282 ConstantExpr *ConstantExpr::Create(const ASTContext &Context, Expr *E,
283                                    ResultStorageKind StorageKind,
284                                    bool IsImmediateInvocation) {
285   assert(!isa<ConstantExpr>(E));
286   AssertResultStorageKind(StorageKind);
287   unsigned Size = totalSizeToAlloc<APValue, uint64_t>(
288       StorageKind == ConstantExpr::RSK_APValue,
289       StorageKind == ConstantExpr::RSK_Int64);
290   void *Mem = Context.Allocate(Size, alignof(ConstantExpr));
291   ConstantExpr *Self = new (Mem) ConstantExpr(E, StorageKind);
292   Self->ConstantExprBits.IsImmediateInvocation =
293       IsImmediateInvocation;
294   return Self;
295 }
296 
297 ConstantExpr *ConstantExpr::Create(const ASTContext &Context, Expr *E,
298                                    const APValue &Result) {
299   ResultStorageKind StorageKind = getStorageKind(Result);
300   ConstantExpr *Self = Create(Context, E, StorageKind);
301   Self->SetResult(Result, Context);
302   return Self;
303 }
304 
305 ConstantExpr::ConstantExpr(ResultStorageKind StorageKind, EmptyShell Empty)
306     : FullExpr(ConstantExprClass, Empty) {
307   DefaultInit(StorageKind);
308 }
309 
310 ConstantExpr *ConstantExpr::CreateEmpty(const ASTContext &Context,
311                                         ResultStorageKind StorageKind,
312                                         EmptyShell Empty) {
313   AssertResultStorageKind(StorageKind);
314   unsigned Size = totalSizeToAlloc<APValue, uint64_t>(
315       StorageKind == ConstantExpr::RSK_APValue,
316       StorageKind == ConstantExpr::RSK_Int64);
317   void *Mem = Context.Allocate(Size, alignof(ConstantExpr));
318   ConstantExpr *Self = new (Mem) ConstantExpr(StorageKind, Empty);
319   return Self;
320 }
321 
322 void ConstantExpr::MoveIntoResult(APValue &Value, const ASTContext &Context) {
323   assert((unsigned)getStorageKind(Value) <= ConstantExprBits.ResultKind &&
324          "Invalid storage for this value kind");
325   ConstantExprBits.APValueKind = Value.getKind();
326   switch (ConstantExprBits.ResultKind) {
327   case RSK_None:
328     return;
329   case RSK_Int64:
330     Int64Result() = *Value.getInt().getRawData();
331     ConstantExprBits.BitWidth = Value.getInt().getBitWidth();
332     ConstantExprBits.IsUnsigned = Value.getInt().isUnsigned();
333     return;
334   case RSK_APValue:
335     if (!ConstantExprBits.HasCleanup && Value.needsCleanup()) {
336       ConstantExprBits.HasCleanup = true;
337       Context.addDestruction(&APValueResult());
338     }
339     APValueResult() = std::move(Value);
340     return;
341   }
342   llvm_unreachable("Invalid ResultKind Bits");
343 }
344 
345 llvm::APSInt ConstantExpr::getResultAsAPSInt() const {
346   switch (ConstantExprBits.ResultKind) {
347   case ConstantExpr::RSK_APValue:
348     return APValueResult().getInt();
349   case ConstantExpr::RSK_Int64:
350     return llvm::APSInt(llvm::APInt(ConstantExprBits.BitWidth, Int64Result()),
351                         ConstantExprBits.IsUnsigned);
352   default:
353     llvm_unreachable("invalid Accessor");
354   }
355 }
356 
357 APValue ConstantExpr::getAPValueResult() const {
358   switch (ConstantExprBits.ResultKind) {
359   case ConstantExpr::RSK_APValue:
360     return APValueResult();
361   case ConstantExpr::RSK_Int64:
362     return APValue(
363         llvm::APSInt(llvm::APInt(ConstantExprBits.BitWidth, Int64Result()),
364                      ConstantExprBits.IsUnsigned));
365   case ConstantExpr::RSK_None:
366     return APValue();
367   }
368   llvm_unreachable("invalid ResultKind");
369 }
370 
371 /// Compute the type-, value-, and instantiation-dependence of a
372 /// declaration reference
373 /// based on the declaration being referenced.
374 static void computeDeclRefDependence(const ASTContext &Ctx, NamedDecl *D,
375                                      QualType T, bool &TypeDependent,
376                                      bool &ValueDependent,
377                                      bool &InstantiationDependent) {
378   TypeDependent = false;
379   ValueDependent = false;
380   InstantiationDependent = false;
381 
382   // (TD) C++ [temp.dep.expr]p3:
383   //   An id-expression is type-dependent if it contains:
384   //
385   // and
386   //
387   // (VD) C++ [temp.dep.constexpr]p2:
388   //  An identifier is value-dependent if it is:
389 
390   //  (TD)  - an identifier that was declared with dependent type
391   //  (VD)  - a name declared with a dependent type,
392   if (T->isDependentType()) {
393     TypeDependent = true;
394     ValueDependent = true;
395     InstantiationDependent = true;
396     return;
397   } else if (T->isInstantiationDependentType()) {
398     InstantiationDependent = true;
399   }
400 
401   //  (TD)  - a conversion-function-id that specifies a dependent type
402   if (D->getDeclName().getNameKind()
403                                 == DeclarationName::CXXConversionFunctionName) {
404     QualType T = D->getDeclName().getCXXNameType();
405     if (T->isDependentType()) {
406       TypeDependent = true;
407       ValueDependent = true;
408       InstantiationDependent = true;
409       return;
410     }
411 
412     if (T->isInstantiationDependentType())
413       InstantiationDependent = true;
414   }
415 
416   //  (VD)  - the name of a non-type template parameter,
417   if (isa<NonTypeTemplateParmDecl>(D)) {
418     ValueDependent = true;
419     InstantiationDependent = true;
420     return;
421   }
422 
423   //  (VD) - a constant with integral or enumeration type and is
424   //         initialized with an expression that is value-dependent.
425   //  (VD) - a constant with literal type and is initialized with an
426   //         expression that is value-dependent [C++11].
427   //  (VD) - FIXME: Missing from the standard:
428   //       -  an entity with reference type and is initialized with an
429   //          expression that is value-dependent [C++11]
430   if (VarDecl *Var = dyn_cast<VarDecl>(D)) {
431     if ((Ctx.getLangOpts().CPlusPlus11 ?
432            Var->getType()->isLiteralType(Ctx) :
433            Var->getType()->isIntegralOrEnumerationType()) &&
434         (Var->getType().isConstQualified() ||
435          Var->getType()->isReferenceType())) {
436       if (const Expr *Init = Var->getAnyInitializer())
437         if (Init->isValueDependent()) {
438           ValueDependent = true;
439           InstantiationDependent = true;
440         }
441     }
442 
443     // (VD) - FIXME: Missing from the standard:
444     //      -  a member function or a static data member of the current
445     //         instantiation
446     if (Var->isStaticDataMember() &&
447         Var->getDeclContext()->isDependentContext()) {
448       ValueDependent = true;
449       InstantiationDependent = true;
450       TypeSourceInfo *TInfo = Var->getFirstDecl()->getTypeSourceInfo();
451       if (TInfo->getType()->isIncompleteArrayType())
452         TypeDependent = true;
453     }
454 
455     return;
456   }
457 
458   // (VD) - FIXME: Missing from the standard:
459   //      -  a member function or a static data member of the current
460   //         instantiation
461   if (isa<CXXMethodDecl>(D) && D->getDeclContext()->isDependentContext()) {
462     ValueDependent = true;
463     InstantiationDependent = true;
464   }
465 }
466 
467 void DeclRefExpr::computeDependence(const ASTContext &Ctx) {
468   bool TypeDependent = false;
469   bool ValueDependent = false;
470   bool InstantiationDependent = false;
471   computeDeclRefDependence(Ctx, getDecl(), getType(), TypeDependent,
472                            ValueDependent, InstantiationDependent);
473 
474   ExprBits.TypeDependent |= TypeDependent;
475   ExprBits.ValueDependent |= ValueDependent;
476   ExprBits.InstantiationDependent |= InstantiationDependent;
477 
478   // Is the declaration a parameter pack?
479   if (getDecl()->isParameterPack())
480     ExprBits.ContainsUnexpandedParameterPack = true;
481 }
482 
483 DeclRefExpr::DeclRefExpr(const ASTContext &Ctx, ValueDecl *D,
484                          bool RefersToEnclosingVariableOrCapture, QualType T,
485                          ExprValueKind VK, SourceLocation L,
486                          const DeclarationNameLoc &LocInfo,
487                          NonOdrUseReason NOUR)
488     : Expr(DeclRefExprClass, T, VK, OK_Ordinary, false, false, false, false),
489       D(D), DNLoc(LocInfo) {
490   DeclRefExprBits.HasQualifier = false;
491   DeclRefExprBits.HasTemplateKWAndArgsInfo = false;
492   DeclRefExprBits.HasFoundDecl = false;
493   DeclRefExprBits.HadMultipleCandidates = false;
494   DeclRefExprBits.RefersToEnclosingVariableOrCapture =
495       RefersToEnclosingVariableOrCapture;
496   DeclRefExprBits.NonOdrUseReason = NOUR;
497   DeclRefExprBits.Loc = L;
498   computeDependence(Ctx);
499 }
500 
501 DeclRefExpr::DeclRefExpr(const ASTContext &Ctx,
502                          NestedNameSpecifierLoc QualifierLoc,
503                          SourceLocation TemplateKWLoc, ValueDecl *D,
504                          bool RefersToEnclosingVariableOrCapture,
505                          const DeclarationNameInfo &NameInfo, NamedDecl *FoundD,
506                          const TemplateArgumentListInfo *TemplateArgs,
507                          QualType T, ExprValueKind VK, NonOdrUseReason NOUR)
508     : Expr(DeclRefExprClass, T, VK, OK_Ordinary, false, false, false, false),
509       D(D), DNLoc(NameInfo.getInfo()) {
510   DeclRefExprBits.Loc = NameInfo.getLoc();
511   DeclRefExprBits.HasQualifier = QualifierLoc ? 1 : 0;
512   if (QualifierLoc) {
513     new (getTrailingObjects<NestedNameSpecifierLoc>())
514         NestedNameSpecifierLoc(QualifierLoc);
515     auto *NNS = QualifierLoc.getNestedNameSpecifier();
516     if (NNS->isInstantiationDependent())
517       ExprBits.InstantiationDependent = true;
518     if (NNS->containsUnexpandedParameterPack())
519       ExprBits.ContainsUnexpandedParameterPack = true;
520   }
521   DeclRefExprBits.HasFoundDecl = FoundD ? 1 : 0;
522   if (FoundD)
523     *getTrailingObjects<NamedDecl *>() = FoundD;
524   DeclRefExprBits.HasTemplateKWAndArgsInfo
525     = (TemplateArgs || TemplateKWLoc.isValid()) ? 1 : 0;
526   DeclRefExprBits.RefersToEnclosingVariableOrCapture =
527       RefersToEnclosingVariableOrCapture;
528   DeclRefExprBits.NonOdrUseReason = NOUR;
529   if (TemplateArgs) {
530     bool Dependent = false;
531     bool InstantiationDependent = false;
532     bool ContainsUnexpandedParameterPack = false;
533     getTrailingObjects<ASTTemplateKWAndArgsInfo>()->initializeFrom(
534         TemplateKWLoc, *TemplateArgs, getTrailingObjects<TemplateArgumentLoc>(),
535         Dependent, InstantiationDependent, ContainsUnexpandedParameterPack);
536     assert(!Dependent && "built a DeclRefExpr with dependent template args");
537     ExprBits.InstantiationDependent |= InstantiationDependent;
538     ExprBits.ContainsUnexpandedParameterPack |= ContainsUnexpandedParameterPack;
539   } else if (TemplateKWLoc.isValid()) {
540     getTrailingObjects<ASTTemplateKWAndArgsInfo>()->initializeFrom(
541         TemplateKWLoc);
542   }
543   DeclRefExprBits.HadMultipleCandidates = 0;
544 
545   computeDependence(Ctx);
546 }
547 
548 DeclRefExpr *DeclRefExpr::Create(const ASTContext &Context,
549                                  NestedNameSpecifierLoc QualifierLoc,
550                                  SourceLocation TemplateKWLoc, ValueDecl *D,
551                                  bool RefersToEnclosingVariableOrCapture,
552                                  SourceLocation NameLoc, QualType T,
553                                  ExprValueKind VK, NamedDecl *FoundD,
554                                  const TemplateArgumentListInfo *TemplateArgs,
555                                  NonOdrUseReason NOUR) {
556   return Create(Context, QualifierLoc, TemplateKWLoc, D,
557                 RefersToEnclosingVariableOrCapture,
558                 DeclarationNameInfo(D->getDeclName(), NameLoc),
559                 T, VK, FoundD, TemplateArgs, NOUR);
560 }
561 
562 DeclRefExpr *DeclRefExpr::Create(const ASTContext &Context,
563                                  NestedNameSpecifierLoc QualifierLoc,
564                                  SourceLocation TemplateKWLoc, ValueDecl *D,
565                                  bool RefersToEnclosingVariableOrCapture,
566                                  const DeclarationNameInfo &NameInfo,
567                                  QualType T, ExprValueKind VK,
568                                  NamedDecl *FoundD,
569                                  const TemplateArgumentListInfo *TemplateArgs,
570                                  NonOdrUseReason NOUR) {
571   // Filter out cases where the found Decl is the same as the value refenenced.
572   if (D == FoundD)
573     FoundD = nullptr;
574 
575   bool HasTemplateKWAndArgsInfo = TemplateArgs || TemplateKWLoc.isValid();
576   std::size_t Size =
577       totalSizeToAlloc<NestedNameSpecifierLoc, NamedDecl *,
578                        ASTTemplateKWAndArgsInfo, TemplateArgumentLoc>(
579           QualifierLoc ? 1 : 0, FoundD ? 1 : 0,
580           HasTemplateKWAndArgsInfo ? 1 : 0,
581           TemplateArgs ? TemplateArgs->size() : 0);
582 
583   void *Mem = Context.Allocate(Size, alignof(DeclRefExpr));
584   return new (Mem) DeclRefExpr(Context, QualifierLoc, TemplateKWLoc, D,
585                                RefersToEnclosingVariableOrCapture, NameInfo,
586                                FoundD, TemplateArgs, T, VK, NOUR);
587 }
588 
589 DeclRefExpr *DeclRefExpr::CreateEmpty(const ASTContext &Context,
590                                       bool HasQualifier,
591                                       bool HasFoundDecl,
592                                       bool HasTemplateKWAndArgsInfo,
593                                       unsigned NumTemplateArgs) {
594   assert(NumTemplateArgs == 0 || HasTemplateKWAndArgsInfo);
595   std::size_t Size =
596       totalSizeToAlloc<NestedNameSpecifierLoc, NamedDecl *,
597                        ASTTemplateKWAndArgsInfo, TemplateArgumentLoc>(
598           HasQualifier ? 1 : 0, HasFoundDecl ? 1 : 0, HasTemplateKWAndArgsInfo,
599           NumTemplateArgs);
600   void *Mem = Context.Allocate(Size, alignof(DeclRefExpr));
601   return new (Mem) DeclRefExpr(EmptyShell());
602 }
603 
604 SourceLocation DeclRefExpr::getBeginLoc() const {
605   if (hasQualifier())
606     return getQualifierLoc().getBeginLoc();
607   return getNameInfo().getBeginLoc();
608 }
609 SourceLocation DeclRefExpr::getEndLoc() const {
610   if (hasExplicitTemplateArgs())
611     return getRAngleLoc();
612   return getNameInfo().getEndLoc();
613 }
614 
615 PredefinedExpr::PredefinedExpr(SourceLocation L, QualType FNTy, IdentKind IK,
616                                StringLiteral *SL)
617     : Expr(PredefinedExprClass, FNTy, VK_LValue, OK_Ordinary,
618            FNTy->isDependentType(), FNTy->isDependentType(),
619            FNTy->isInstantiationDependentType(),
620            /*ContainsUnexpandedParameterPack=*/false) {
621   PredefinedExprBits.Kind = IK;
622   assert((getIdentKind() == IK) &&
623          "IdentKind do not fit in PredefinedExprBitfields!");
624   bool HasFunctionName = SL != nullptr;
625   PredefinedExprBits.HasFunctionName = HasFunctionName;
626   PredefinedExprBits.Loc = L;
627   if (HasFunctionName)
628     setFunctionName(SL);
629 }
630 
631 PredefinedExpr::PredefinedExpr(EmptyShell Empty, bool HasFunctionName)
632     : Expr(PredefinedExprClass, Empty) {
633   PredefinedExprBits.HasFunctionName = HasFunctionName;
634 }
635 
636 PredefinedExpr *PredefinedExpr::Create(const ASTContext &Ctx, SourceLocation L,
637                                        QualType FNTy, IdentKind IK,
638                                        StringLiteral *SL) {
639   bool HasFunctionName = SL != nullptr;
640   void *Mem = Ctx.Allocate(totalSizeToAlloc<Stmt *>(HasFunctionName),
641                            alignof(PredefinedExpr));
642   return new (Mem) PredefinedExpr(L, FNTy, IK, SL);
643 }
644 
645 PredefinedExpr *PredefinedExpr::CreateEmpty(const ASTContext &Ctx,
646                                             bool HasFunctionName) {
647   void *Mem = Ctx.Allocate(totalSizeToAlloc<Stmt *>(HasFunctionName),
648                            alignof(PredefinedExpr));
649   return new (Mem) PredefinedExpr(EmptyShell(), HasFunctionName);
650 }
651 
652 StringRef PredefinedExpr::getIdentKindName(PredefinedExpr::IdentKind IK) {
653   switch (IK) {
654   case Func:
655     return "__func__";
656   case Function:
657     return "__FUNCTION__";
658   case FuncDName:
659     return "__FUNCDNAME__";
660   case LFunction:
661     return "L__FUNCTION__";
662   case PrettyFunction:
663     return "__PRETTY_FUNCTION__";
664   case FuncSig:
665     return "__FUNCSIG__";
666   case LFuncSig:
667     return "L__FUNCSIG__";
668   case PrettyFunctionNoVirtual:
669     break;
670   }
671   llvm_unreachable("Unknown ident kind for PredefinedExpr");
672 }
673 
674 // FIXME: Maybe this should use DeclPrinter with a special "print predefined
675 // expr" policy instead.
676 std::string PredefinedExpr::ComputeName(IdentKind IK, const Decl *CurrentDecl) {
677   ASTContext &Context = CurrentDecl->getASTContext();
678 
679   if (IK == PredefinedExpr::FuncDName) {
680     if (const NamedDecl *ND = dyn_cast<NamedDecl>(CurrentDecl)) {
681       std::unique_ptr<MangleContext> MC;
682       MC.reset(Context.createMangleContext());
683 
684       if (MC->shouldMangleDeclName(ND)) {
685         SmallString<256> Buffer;
686         llvm::raw_svector_ostream Out(Buffer);
687         if (const CXXConstructorDecl *CD = dyn_cast<CXXConstructorDecl>(ND))
688           MC->mangleCXXCtor(CD, Ctor_Base, Out);
689         else if (const CXXDestructorDecl *DD = dyn_cast<CXXDestructorDecl>(ND))
690           MC->mangleCXXDtor(DD, Dtor_Base, Out);
691         else
692           MC->mangleName(ND, Out);
693 
694         if (!Buffer.empty() && Buffer.front() == '\01')
695           return std::string(Buffer.substr(1));
696         return std::string(Buffer.str());
697       } else
698         return std::string(ND->getIdentifier()->getName());
699     }
700     return "";
701   }
702   if (isa<BlockDecl>(CurrentDecl)) {
703     // For blocks we only emit something if it is enclosed in a function
704     // For top-level block we'd like to include the name of variable, but we
705     // don't have it at this point.
706     auto DC = CurrentDecl->getDeclContext();
707     if (DC->isFileContext())
708       return "";
709 
710     SmallString<256> Buffer;
711     llvm::raw_svector_ostream Out(Buffer);
712     if (auto *DCBlock = dyn_cast<BlockDecl>(DC))
713       // For nested blocks, propagate up to the parent.
714       Out << ComputeName(IK, DCBlock);
715     else if (auto *DCDecl = dyn_cast<Decl>(DC))
716       Out << ComputeName(IK, DCDecl) << "_block_invoke";
717     return std::string(Out.str());
718   }
719   if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(CurrentDecl)) {
720     if (IK != PrettyFunction && IK != PrettyFunctionNoVirtual &&
721         IK != FuncSig && IK != LFuncSig)
722       return FD->getNameAsString();
723 
724     SmallString<256> Name;
725     llvm::raw_svector_ostream Out(Name);
726 
727     if (const CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(FD)) {
728       if (MD->isVirtual() && IK != PrettyFunctionNoVirtual)
729         Out << "virtual ";
730       if (MD->isStatic())
731         Out << "static ";
732     }
733 
734     PrintingPolicy Policy(Context.getLangOpts());
735     std::string Proto;
736     llvm::raw_string_ostream POut(Proto);
737 
738     const FunctionDecl *Decl = FD;
739     if (const FunctionDecl* Pattern = FD->getTemplateInstantiationPattern())
740       Decl = Pattern;
741     const FunctionType *AFT = Decl->getType()->getAs<FunctionType>();
742     const FunctionProtoType *FT = nullptr;
743     if (FD->hasWrittenPrototype())
744       FT = dyn_cast<FunctionProtoType>(AFT);
745 
746     if (IK == FuncSig || IK == LFuncSig) {
747       switch (AFT->getCallConv()) {
748       case CC_C: POut << "__cdecl "; break;
749       case CC_X86StdCall: POut << "__stdcall "; break;
750       case CC_X86FastCall: POut << "__fastcall "; break;
751       case CC_X86ThisCall: POut << "__thiscall "; break;
752       case CC_X86VectorCall: POut << "__vectorcall "; break;
753       case CC_X86RegCall: POut << "__regcall "; break;
754       // Only bother printing the conventions that MSVC knows about.
755       default: break;
756       }
757     }
758 
759     FD->printQualifiedName(POut, Policy);
760 
761     POut << "(";
762     if (FT) {
763       for (unsigned i = 0, e = Decl->getNumParams(); i != e; ++i) {
764         if (i) POut << ", ";
765         POut << Decl->getParamDecl(i)->getType().stream(Policy);
766       }
767 
768       if (FT->isVariadic()) {
769         if (FD->getNumParams()) POut << ", ";
770         POut << "...";
771       } else if ((IK == FuncSig || IK == LFuncSig ||
772                   !Context.getLangOpts().CPlusPlus) &&
773                  !Decl->getNumParams()) {
774         POut << "void";
775       }
776     }
777     POut << ")";
778 
779     if (const CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(FD)) {
780       assert(FT && "We must have a written prototype in this case.");
781       if (FT->isConst())
782         POut << " const";
783       if (FT->isVolatile())
784         POut << " volatile";
785       RefQualifierKind Ref = MD->getRefQualifier();
786       if (Ref == RQ_LValue)
787         POut << " &";
788       else if (Ref == RQ_RValue)
789         POut << " &&";
790     }
791 
792     typedef SmallVector<const ClassTemplateSpecializationDecl *, 8> SpecsTy;
793     SpecsTy Specs;
794     const DeclContext *Ctx = FD->getDeclContext();
795     while (Ctx && isa<NamedDecl>(Ctx)) {
796       const ClassTemplateSpecializationDecl *Spec
797                                = dyn_cast<ClassTemplateSpecializationDecl>(Ctx);
798       if (Spec && !Spec->isExplicitSpecialization())
799         Specs.push_back(Spec);
800       Ctx = Ctx->getParent();
801     }
802 
803     std::string TemplateParams;
804     llvm::raw_string_ostream TOut(TemplateParams);
805     for (SpecsTy::reverse_iterator I = Specs.rbegin(), E = Specs.rend();
806          I != E; ++I) {
807       const TemplateParameterList *Params
808                   = (*I)->getSpecializedTemplate()->getTemplateParameters();
809       const TemplateArgumentList &Args = (*I)->getTemplateArgs();
810       assert(Params->size() == Args.size());
811       for (unsigned i = 0, numParams = Params->size(); i != numParams; ++i) {
812         StringRef Param = Params->getParam(i)->getName();
813         if (Param.empty()) continue;
814         TOut << Param << " = ";
815         Args.get(i).print(Policy, TOut);
816         TOut << ", ";
817       }
818     }
819 
820     FunctionTemplateSpecializationInfo *FSI
821                                           = FD->getTemplateSpecializationInfo();
822     if (FSI && !FSI->isExplicitSpecialization()) {
823       const TemplateParameterList* Params
824                                   = FSI->getTemplate()->getTemplateParameters();
825       const TemplateArgumentList* Args = FSI->TemplateArguments;
826       assert(Params->size() == Args->size());
827       for (unsigned i = 0, e = Params->size(); i != e; ++i) {
828         StringRef Param = Params->getParam(i)->getName();
829         if (Param.empty()) continue;
830         TOut << Param << " = ";
831         Args->get(i).print(Policy, TOut);
832         TOut << ", ";
833       }
834     }
835 
836     TOut.flush();
837     if (!TemplateParams.empty()) {
838       // remove the trailing comma and space
839       TemplateParams.resize(TemplateParams.size() - 2);
840       POut << " [" << TemplateParams << "]";
841     }
842 
843     POut.flush();
844 
845     // Print "auto" for all deduced return types. This includes C++1y return
846     // type deduction and lambdas. For trailing return types resolve the
847     // decltype expression. Otherwise print the real type when this is
848     // not a constructor or destructor.
849     if (isa<CXXMethodDecl>(FD) &&
850          cast<CXXMethodDecl>(FD)->getParent()->isLambda())
851       Proto = "auto " + Proto;
852     else if (FT && FT->getReturnType()->getAs<DecltypeType>())
853       FT->getReturnType()
854           ->getAs<DecltypeType>()
855           ->getUnderlyingType()
856           .getAsStringInternal(Proto, Policy);
857     else if (!isa<CXXConstructorDecl>(FD) && !isa<CXXDestructorDecl>(FD))
858       AFT->getReturnType().getAsStringInternal(Proto, Policy);
859 
860     Out << Proto;
861 
862     return std::string(Name);
863   }
864   if (const CapturedDecl *CD = dyn_cast<CapturedDecl>(CurrentDecl)) {
865     for (const DeclContext *DC = CD->getParent(); DC; DC = DC->getParent())
866       // Skip to its enclosing function or method, but not its enclosing
867       // CapturedDecl.
868       if (DC->isFunctionOrMethod() && (DC->getDeclKind() != Decl::Captured)) {
869         const Decl *D = Decl::castFromDeclContext(DC);
870         return ComputeName(IK, D);
871       }
872     llvm_unreachable("CapturedDecl not inside a function or method");
873   }
874   if (const ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(CurrentDecl)) {
875     SmallString<256> Name;
876     llvm::raw_svector_ostream Out(Name);
877     Out << (MD->isInstanceMethod() ? '-' : '+');
878     Out << '[';
879 
880     // For incorrect code, there might not be an ObjCInterfaceDecl.  Do
881     // a null check to avoid a crash.
882     if (const ObjCInterfaceDecl *ID = MD->getClassInterface())
883       Out << *ID;
884 
885     if (const ObjCCategoryImplDecl *CID =
886         dyn_cast<ObjCCategoryImplDecl>(MD->getDeclContext()))
887       Out << '(' << *CID << ')';
888 
889     Out <<  ' ';
890     MD->getSelector().print(Out);
891     Out <<  ']';
892 
893     return std::string(Name);
894   }
895   if (isa<TranslationUnitDecl>(CurrentDecl) && IK == PrettyFunction) {
896     // __PRETTY_FUNCTION__ -> "top level", the others produce an empty string.
897     return "top level";
898   }
899   return "";
900 }
901 
902 void APNumericStorage::setIntValue(const ASTContext &C,
903                                    const llvm::APInt &Val) {
904   if (hasAllocation())
905     C.Deallocate(pVal);
906 
907   BitWidth = Val.getBitWidth();
908   unsigned NumWords = Val.getNumWords();
909   const uint64_t* Words = Val.getRawData();
910   if (NumWords > 1) {
911     pVal = new (C) uint64_t[NumWords];
912     std::copy(Words, Words + NumWords, pVal);
913   } else if (NumWords == 1)
914     VAL = Words[0];
915   else
916     VAL = 0;
917 }
918 
919 IntegerLiteral::IntegerLiteral(const ASTContext &C, const llvm::APInt &V,
920                                QualType type, SourceLocation l)
921   : Expr(IntegerLiteralClass, type, VK_RValue, OK_Ordinary, false, false,
922          false, false),
923     Loc(l) {
924   assert(type->isIntegerType() && "Illegal type in IntegerLiteral");
925   assert(V.getBitWidth() == C.getIntWidth(type) &&
926          "Integer type is not the correct size for constant.");
927   setValue(C, V);
928 }
929 
930 IntegerLiteral *
931 IntegerLiteral::Create(const ASTContext &C, const llvm::APInt &V,
932                        QualType type, SourceLocation l) {
933   return new (C) IntegerLiteral(C, V, type, l);
934 }
935 
936 IntegerLiteral *
937 IntegerLiteral::Create(const ASTContext &C, EmptyShell Empty) {
938   return new (C) IntegerLiteral(Empty);
939 }
940 
941 FixedPointLiteral::FixedPointLiteral(const ASTContext &C, const llvm::APInt &V,
942                                      QualType type, SourceLocation l,
943                                      unsigned Scale)
944     : Expr(FixedPointLiteralClass, type, VK_RValue, OK_Ordinary, false, false,
945            false, false),
946       Loc(l), Scale(Scale) {
947   assert(type->isFixedPointType() && "Illegal type in FixedPointLiteral");
948   assert(V.getBitWidth() == C.getTypeInfo(type).Width &&
949          "Fixed point type is not the correct size for constant.");
950   setValue(C, V);
951 }
952 
953 FixedPointLiteral *FixedPointLiteral::CreateFromRawInt(const ASTContext &C,
954                                                        const llvm::APInt &V,
955                                                        QualType type,
956                                                        SourceLocation l,
957                                                        unsigned Scale) {
958   return new (C) FixedPointLiteral(C, V, type, l, Scale);
959 }
960 
961 std::string FixedPointLiteral::getValueAsString(unsigned Radix) const {
962   // Currently the longest decimal number that can be printed is the max for an
963   // unsigned long _Accum: 4294967295.99999999976716935634613037109375
964   // which is 43 characters.
965   SmallString<64> S;
966   FixedPointValueToString(
967       S, llvm::APSInt::getUnsigned(getValue().getZExtValue()), Scale);
968   return std::string(S.str());
969 }
970 
971 FloatingLiteral::FloatingLiteral(const ASTContext &C, const llvm::APFloat &V,
972                                  bool isexact, QualType Type, SourceLocation L)
973   : Expr(FloatingLiteralClass, Type, VK_RValue, OK_Ordinary, false, false,
974          false, false), Loc(L) {
975   setSemantics(V.getSemantics());
976   FloatingLiteralBits.IsExact = isexact;
977   setValue(C, V);
978 }
979 
980 FloatingLiteral::FloatingLiteral(const ASTContext &C, EmptyShell Empty)
981   : Expr(FloatingLiteralClass, Empty) {
982   setRawSemantics(llvm::APFloatBase::S_IEEEhalf);
983   FloatingLiteralBits.IsExact = false;
984 }
985 
986 FloatingLiteral *
987 FloatingLiteral::Create(const ASTContext &C, const llvm::APFloat &V,
988                         bool isexact, QualType Type, SourceLocation L) {
989   return new (C) FloatingLiteral(C, V, isexact, Type, L);
990 }
991 
992 FloatingLiteral *
993 FloatingLiteral::Create(const ASTContext &C, EmptyShell Empty) {
994   return new (C) FloatingLiteral(C, Empty);
995 }
996 
997 /// getValueAsApproximateDouble - This returns the value as an inaccurate
998 /// double.  Note that this may cause loss of precision, but is useful for
999 /// debugging dumps, etc.
1000 double FloatingLiteral::getValueAsApproximateDouble() const {
1001   llvm::APFloat V = getValue();
1002   bool ignored;
1003   V.convert(llvm::APFloat::IEEEdouble(), llvm::APFloat::rmNearestTiesToEven,
1004             &ignored);
1005   return V.convertToDouble();
1006 }
1007 
1008 unsigned StringLiteral::mapCharByteWidth(TargetInfo const &Target,
1009                                          StringKind SK) {
1010   unsigned CharByteWidth = 0;
1011   switch (SK) {
1012   case Ascii:
1013   case UTF8:
1014     CharByteWidth = Target.getCharWidth();
1015     break;
1016   case Wide:
1017     CharByteWidth = Target.getWCharWidth();
1018     break;
1019   case UTF16:
1020     CharByteWidth = Target.getChar16Width();
1021     break;
1022   case UTF32:
1023     CharByteWidth = Target.getChar32Width();
1024     break;
1025   }
1026   assert((CharByteWidth & 7) == 0 && "Assumes character size is byte multiple");
1027   CharByteWidth /= 8;
1028   assert((CharByteWidth == 1 || CharByteWidth == 2 || CharByteWidth == 4) &&
1029          "The only supported character byte widths are 1,2 and 4!");
1030   return CharByteWidth;
1031 }
1032 
1033 StringLiteral::StringLiteral(const ASTContext &Ctx, StringRef Str,
1034                              StringKind Kind, bool Pascal, QualType Ty,
1035                              const SourceLocation *Loc,
1036                              unsigned NumConcatenated)
1037     : Expr(StringLiteralClass, Ty, VK_LValue, OK_Ordinary, false, false, false,
1038            false) {
1039   assert(Ctx.getAsConstantArrayType(Ty) &&
1040          "StringLiteral must be of constant array type!");
1041   unsigned CharByteWidth = mapCharByteWidth(Ctx.getTargetInfo(), Kind);
1042   unsigned ByteLength = Str.size();
1043   assert((ByteLength % CharByteWidth == 0) &&
1044          "The size of the data must be a multiple of CharByteWidth!");
1045 
1046   // Avoid the expensive division. The compiler should be able to figure it
1047   // out by itself. However as of clang 7, even with the appropriate
1048   // llvm_unreachable added just here, it is not able to do so.
1049   unsigned Length;
1050   switch (CharByteWidth) {
1051   case 1:
1052     Length = ByteLength;
1053     break;
1054   case 2:
1055     Length = ByteLength / 2;
1056     break;
1057   case 4:
1058     Length = ByteLength / 4;
1059     break;
1060   default:
1061     llvm_unreachable("Unsupported character width!");
1062   }
1063 
1064   StringLiteralBits.Kind = Kind;
1065   StringLiteralBits.CharByteWidth = CharByteWidth;
1066   StringLiteralBits.IsPascal = Pascal;
1067   StringLiteralBits.NumConcatenated = NumConcatenated;
1068   *getTrailingObjects<unsigned>() = Length;
1069 
1070   // Initialize the trailing array of SourceLocation.
1071   // This is safe since SourceLocation is POD-like.
1072   std::memcpy(getTrailingObjects<SourceLocation>(), Loc,
1073               NumConcatenated * sizeof(SourceLocation));
1074 
1075   // Initialize the trailing array of char holding the string data.
1076   std::memcpy(getTrailingObjects<char>(), Str.data(), ByteLength);
1077 }
1078 
1079 StringLiteral::StringLiteral(EmptyShell Empty, unsigned NumConcatenated,
1080                              unsigned Length, unsigned CharByteWidth)
1081     : Expr(StringLiteralClass, Empty) {
1082   StringLiteralBits.CharByteWidth = CharByteWidth;
1083   StringLiteralBits.NumConcatenated = NumConcatenated;
1084   *getTrailingObjects<unsigned>() = Length;
1085 }
1086 
1087 StringLiteral *StringLiteral::Create(const ASTContext &Ctx, StringRef Str,
1088                                      StringKind Kind, bool Pascal, QualType Ty,
1089                                      const SourceLocation *Loc,
1090                                      unsigned NumConcatenated) {
1091   void *Mem = Ctx.Allocate(totalSizeToAlloc<unsigned, SourceLocation, char>(
1092                                1, NumConcatenated, Str.size()),
1093                            alignof(StringLiteral));
1094   return new (Mem)
1095       StringLiteral(Ctx, Str, Kind, Pascal, Ty, Loc, NumConcatenated);
1096 }
1097 
1098 StringLiteral *StringLiteral::CreateEmpty(const ASTContext &Ctx,
1099                                           unsigned NumConcatenated,
1100                                           unsigned Length,
1101                                           unsigned CharByteWidth) {
1102   void *Mem = Ctx.Allocate(totalSizeToAlloc<unsigned, SourceLocation, char>(
1103                                1, NumConcatenated, Length * CharByteWidth),
1104                            alignof(StringLiteral));
1105   return new (Mem)
1106       StringLiteral(EmptyShell(), NumConcatenated, Length, CharByteWidth);
1107 }
1108 
1109 void StringLiteral::outputString(raw_ostream &OS) const {
1110   switch (getKind()) {
1111   case Ascii: break; // no prefix.
1112   case Wide:  OS << 'L'; break;
1113   case UTF8:  OS << "u8"; break;
1114   case UTF16: OS << 'u'; break;
1115   case UTF32: OS << 'U'; break;
1116   }
1117   OS << '"';
1118   static const char Hex[] = "0123456789ABCDEF";
1119 
1120   unsigned LastSlashX = getLength();
1121   for (unsigned I = 0, N = getLength(); I != N; ++I) {
1122     switch (uint32_t Char = getCodeUnit(I)) {
1123     default:
1124       // FIXME: Convert UTF-8 back to codepoints before rendering.
1125 
1126       // Convert UTF-16 surrogate pairs back to codepoints before rendering.
1127       // Leave invalid surrogates alone; we'll use \x for those.
1128       if (getKind() == UTF16 && I != N - 1 && Char >= 0xd800 &&
1129           Char <= 0xdbff) {
1130         uint32_t Trail = getCodeUnit(I + 1);
1131         if (Trail >= 0xdc00 && Trail <= 0xdfff) {
1132           Char = 0x10000 + ((Char - 0xd800) << 10) + (Trail - 0xdc00);
1133           ++I;
1134         }
1135       }
1136 
1137       if (Char > 0xff) {
1138         // If this is a wide string, output characters over 0xff using \x
1139         // escapes. Otherwise, this is a UTF-16 or UTF-32 string, and Char is a
1140         // codepoint: use \x escapes for invalid codepoints.
1141         if (getKind() == Wide ||
1142             (Char >= 0xd800 && Char <= 0xdfff) || Char >= 0x110000) {
1143           // FIXME: Is this the best way to print wchar_t?
1144           OS << "\\x";
1145           int Shift = 28;
1146           while ((Char >> Shift) == 0)
1147             Shift -= 4;
1148           for (/**/; Shift >= 0; Shift -= 4)
1149             OS << Hex[(Char >> Shift) & 15];
1150           LastSlashX = I;
1151           break;
1152         }
1153 
1154         if (Char > 0xffff)
1155           OS << "\\U00"
1156              << Hex[(Char >> 20) & 15]
1157              << Hex[(Char >> 16) & 15];
1158         else
1159           OS << "\\u";
1160         OS << Hex[(Char >> 12) & 15]
1161            << Hex[(Char >>  8) & 15]
1162            << Hex[(Char >>  4) & 15]
1163            << Hex[(Char >>  0) & 15];
1164         break;
1165       }
1166 
1167       // If we used \x... for the previous character, and this character is a
1168       // hexadecimal digit, prevent it being slurped as part of the \x.
1169       if (LastSlashX + 1 == I) {
1170         switch (Char) {
1171           case '0': case '1': case '2': case '3': case '4':
1172           case '5': case '6': case '7': case '8': case '9':
1173           case 'a': case 'b': case 'c': case 'd': case 'e': case 'f':
1174           case 'A': case 'B': case 'C': case 'D': case 'E': case 'F':
1175             OS << "\"\"";
1176         }
1177       }
1178 
1179       assert(Char <= 0xff &&
1180              "Characters above 0xff should already have been handled.");
1181 
1182       if (isPrintable(Char))
1183         OS << (char)Char;
1184       else  // Output anything hard as an octal escape.
1185         OS << '\\'
1186            << (char)('0' + ((Char >> 6) & 7))
1187            << (char)('0' + ((Char >> 3) & 7))
1188            << (char)('0' + ((Char >> 0) & 7));
1189       break;
1190     // Handle some common non-printable cases to make dumps prettier.
1191     case '\\': OS << "\\\\"; break;
1192     case '"': OS << "\\\""; break;
1193     case '\a': OS << "\\a"; break;
1194     case '\b': OS << "\\b"; break;
1195     case '\f': OS << "\\f"; break;
1196     case '\n': OS << "\\n"; break;
1197     case '\r': OS << "\\r"; break;
1198     case '\t': OS << "\\t"; break;
1199     case '\v': OS << "\\v"; break;
1200     }
1201   }
1202   OS << '"';
1203 }
1204 
1205 /// getLocationOfByte - Return a source location that points to the specified
1206 /// byte of this string literal.
1207 ///
1208 /// Strings are amazingly complex.  They can be formed from multiple tokens and
1209 /// can have escape sequences in them in addition to the usual trigraph and
1210 /// escaped newline business.  This routine handles this complexity.
1211 ///
1212 /// The *StartToken sets the first token to be searched in this function and
1213 /// the *StartTokenByteOffset is the byte offset of the first token. Before
1214 /// returning, it updates the *StartToken to the TokNo of the token being found
1215 /// and sets *StartTokenByteOffset to the byte offset of the token in the
1216 /// string.
1217 /// Using these two parameters can reduce the time complexity from O(n^2) to
1218 /// O(n) if one wants to get the location of byte for all the tokens in a
1219 /// string.
1220 ///
1221 SourceLocation
1222 StringLiteral::getLocationOfByte(unsigned ByteNo, const SourceManager &SM,
1223                                  const LangOptions &Features,
1224                                  const TargetInfo &Target, unsigned *StartToken,
1225                                  unsigned *StartTokenByteOffset) const {
1226   assert((getKind() == StringLiteral::Ascii ||
1227           getKind() == StringLiteral::UTF8) &&
1228          "Only narrow string literals are currently supported");
1229 
1230   // Loop over all of the tokens in this string until we find the one that
1231   // contains the byte we're looking for.
1232   unsigned TokNo = 0;
1233   unsigned StringOffset = 0;
1234   if (StartToken)
1235     TokNo = *StartToken;
1236   if (StartTokenByteOffset) {
1237     StringOffset = *StartTokenByteOffset;
1238     ByteNo -= StringOffset;
1239   }
1240   while (1) {
1241     assert(TokNo < getNumConcatenated() && "Invalid byte number!");
1242     SourceLocation StrTokLoc = getStrTokenLoc(TokNo);
1243 
1244     // Get the spelling of the string so that we can get the data that makes up
1245     // the string literal, not the identifier for the macro it is potentially
1246     // expanded through.
1247     SourceLocation StrTokSpellingLoc = SM.getSpellingLoc(StrTokLoc);
1248 
1249     // Re-lex the token to get its length and original spelling.
1250     std::pair<FileID, unsigned> LocInfo =
1251         SM.getDecomposedLoc(StrTokSpellingLoc);
1252     bool Invalid = false;
1253     StringRef Buffer = SM.getBufferData(LocInfo.first, &Invalid);
1254     if (Invalid) {
1255       if (StartTokenByteOffset != nullptr)
1256         *StartTokenByteOffset = StringOffset;
1257       if (StartToken != nullptr)
1258         *StartToken = TokNo;
1259       return StrTokSpellingLoc;
1260     }
1261 
1262     const char *StrData = Buffer.data()+LocInfo.second;
1263 
1264     // Create a lexer starting at the beginning of this token.
1265     Lexer TheLexer(SM.getLocForStartOfFile(LocInfo.first), Features,
1266                    Buffer.begin(), StrData, Buffer.end());
1267     Token TheTok;
1268     TheLexer.LexFromRawLexer(TheTok);
1269 
1270     // Use the StringLiteralParser to compute the length of the string in bytes.
1271     StringLiteralParser SLP(TheTok, SM, Features, Target);
1272     unsigned TokNumBytes = SLP.GetStringLength();
1273 
1274     // If the byte is in this token, return the location of the byte.
1275     if (ByteNo < TokNumBytes ||
1276         (ByteNo == TokNumBytes && TokNo == getNumConcatenated() - 1)) {
1277       unsigned Offset = SLP.getOffsetOfStringByte(TheTok, ByteNo);
1278 
1279       // Now that we know the offset of the token in the spelling, use the
1280       // preprocessor to get the offset in the original source.
1281       if (StartTokenByteOffset != nullptr)
1282         *StartTokenByteOffset = StringOffset;
1283       if (StartToken != nullptr)
1284         *StartToken = TokNo;
1285       return Lexer::AdvanceToTokenCharacter(StrTokLoc, Offset, SM, Features);
1286     }
1287 
1288     // Move to the next string token.
1289     StringOffset += TokNumBytes;
1290     ++TokNo;
1291     ByteNo -= TokNumBytes;
1292   }
1293 }
1294 
1295 /// getOpcodeStr - Turn an Opcode enum value into the punctuation char it
1296 /// corresponds to, e.g. "sizeof" or "[pre]++".
1297 StringRef UnaryOperator::getOpcodeStr(Opcode Op) {
1298   switch (Op) {
1299 #define UNARY_OPERATION(Name, Spelling) case UO_##Name: return Spelling;
1300 #include "clang/AST/OperationKinds.def"
1301   }
1302   llvm_unreachable("Unknown unary operator");
1303 }
1304 
1305 UnaryOperatorKind
1306 UnaryOperator::getOverloadedOpcode(OverloadedOperatorKind OO, bool Postfix) {
1307   switch (OO) {
1308   default: llvm_unreachable("No unary operator for overloaded function");
1309   case OO_PlusPlus:   return Postfix ? UO_PostInc : UO_PreInc;
1310   case OO_MinusMinus: return Postfix ? UO_PostDec : UO_PreDec;
1311   case OO_Amp:        return UO_AddrOf;
1312   case OO_Star:       return UO_Deref;
1313   case OO_Plus:       return UO_Plus;
1314   case OO_Minus:      return UO_Minus;
1315   case OO_Tilde:      return UO_Not;
1316   case OO_Exclaim:    return UO_LNot;
1317   case OO_Coawait:    return UO_Coawait;
1318   }
1319 }
1320 
1321 OverloadedOperatorKind UnaryOperator::getOverloadedOperator(Opcode Opc) {
1322   switch (Opc) {
1323   case UO_PostInc: case UO_PreInc: return OO_PlusPlus;
1324   case UO_PostDec: case UO_PreDec: return OO_MinusMinus;
1325   case UO_AddrOf: return OO_Amp;
1326   case UO_Deref: return OO_Star;
1327   case UO_Plus: return OO_Plus;
1328   case UO_Minus: return OO_Minus;
1329   case UO_Not: return OO_Tilde;
1330   case UO_LNot: return OO_Exclaim;
1331   case UO_Coawait: return OO_Coawait;
1332   default: return OO_None;
1333   }
1334 }
1335 
1336 
1337 //===----------------------------------------------------------------------===//
1338 // Postfix Operators.
1339 //===----------------------------------------------------------------------===//
1340 
1341 CallExpr::CallExpr(StmtClass SC, Expr *Fn, ArrayRef<Expr *> PreArgs,
1342                    ArrayRef<Expr *> Args, QualType Ty, ExprValueKind VK,
1343                    SourceLocation RParenLoc, unsigned MinNumArgs,
1344                    ADLCallKind UsesADL)
1345     : Expr(SC, Ty, VK, OK_Ordinary, Fn->isTypeDependent(),
1346            Fn->isValueDependent(), Fn->isInstantiationDependent(),
1347            Fn->containsUnexpandedParameterPack()),
1348       RParenLoc(RParenLoc) {
1349   NumArgs = std::max<unsigned>(Args.size(), MinNumArgs);
1350   unsigned NumPreArgs = PreArgs.size();
1351   CallExprBits.NumPreArgs = NumPreArgs;
1352   assert((NumPreArgs == getNumPreArgs()) && "NumPreArgs overflow!");
1353 
1354   unsigned OffsetToTrailingObjects = offsetToTrailingObjects(SC);
1355   CallExprBits.OffsetToTrailingObjects = OffsetToTrailingObjects;
1356   assert((CallExprBits.OffsetToTrailingObjects == OffsetToTrailingObjects) &&
1357          "OffsetToTrailingObjects overflow!");
1358 
1359   CallExprBits.UsesADL = static_cast<bool>(UsesADL);
1360 
1361   setCallee(Fn);
1362   for (unsigned I = 0; I != NumPreArgs; ++I) {
1363     updateDependenciesFromArg(PreArgs[I]);
1364     setPreArg(I, PreArgs[I]);
1365   }
1366   for (unsigned I = 0; I != Args.size(); ++I) {
1367     updateDependenciesFromArg(Args[I]);
1368     setArg(I, Args[I]);
1369   }
1370   for (unsigned I = Args.size(); I != NumArgs; ++I) {
1371     setArg(I, nullptr);
1372   }
1373 }
1374 
1375 CallExpr::CallExpr(StmtClass SC, unsigned NumPreArgs, unsigned NumArgs,
1376                    EmptyShell Empty)
1377     : Expr(SC, Empty), NumArgs(NumArgs) {
1378   CallExprBits.NumPreArgs = NumPreArgs;
1379   assert((NumPreArgs == getNumPreArgs()) && "NumPreArgs overflow!");
1380 
1381   unsigned OffsetToTrailingObjects = offsetToTrailingObjects(SC);
1382   CallExprBits.OffsetToTrailingObjects = OffsetToTrailingObjects;
1383   assert((CallExprBits.OffsetToTrailingObjects == OffsetToTrailingObjects) &&
1384          "OffsetToTrailingObjects overflow!");
1385 }
1386 
1387 CallExpr *CallExpr::Create(const ASTContext &Ctx, Expr *Fn,
1388                            ArrayRef<Expr *> Args, QualType Ty, ExprValueKind VK,
1389                            SourceLocation RParenLoc, unsigned MinNumArgs,
1390                            ADLCallKind UsesADL) {
1391   unsigned NumArgs = std::max<unsigned>(Args.size(), MinNumArgs);
1392   unsigned SizeOfTrailingObjects =
1393       CallExpr::sizeOfTrailingObjects(/*NumPreArgs=*/0, NumArgs);
1394   void *Mem =
1395       Ctx.Allocate(sizeof(CallExpr) + SizeOfTrailingObjects, alignof(CallExpr));
1396   return new (Mem) CallExpr(CallExprClass, Fn, /*PreArgs=*/{}, Args, Ty, VK,
1397                             RParenLoc, MinNumArgs, UsesADL);
1398 }
1399 
1400 CallExpr *CallExpr::CreateTemporary(void *Mem, Expr *Fn, QualType Ty,
1401                                     ExprValueKind VK, SourceLocation RParenLoc,
1402                                     ADLCallKind UsesADL) {
1403   assert(!(reinterpret_cast<uintptr_t>(Mem) % alignof(CallExpr)) &&
1404          "Misaligned memory in CallExpr::CreateTemporary!");
1405   return new (Mem) CallExpr(CallExprClass, Fn, /*PreArgs=*/{}, /*Args=*/{}, Ty,
1406                             VK, RParenLoc, /*MinNumArgs=*/0, UsesADL);
1407 }
1408 
1409 CallExpr *CallExpr::CreateEmpty(const ASTContext &Ctx, unsigned NumArgs,
1410                                 EmptyShell Empty) {
1411   unsigned SizeOfTrailingObjects =
1412       CallExpr::sizeOfTrailingObjects(/*NumPreArgs=*/0, NumArgs);
1413   void *Mem =
1414       Ctx.Allocate(sizeof(CallExpr) + SizeOfTrailingObjects, alignof(CallExpr));
1415   return new (Mem) CallExpr(CallExprClass, /*NumPreArgs=*/0, NumArgs, Empty);
1416 }
1417 
1418 unsigned CallExpr::offsetToTrailingObjects(StmtClass SC) {
1419   switch (SC) {
1420   case CallExprClass:
1421     return sizeof(CallExpr);
1422   case CXXOperatorCallExprClass:
1423     return sizeof(CXXOperatorCallExpr);
1424   case CXXMemberCallExprClass:
1425     return sizeof(CXXMemberCallExpr);
1426   case UserDefinedLiteralClass:
1427     return sizeof(UserDefinedLiteral);
1428   case CUDAKernelCallExprClass:
1429     return sizeof(CUDAKernelCallExpr);
1430   default:
1431     llvm_unreachable("unexpected class deriving from CallExpr!");
1432   }
1433 }
1434 
1435 void CallExpr::updateDependenciesFromArg(Expr *Arg) {
1436   if (Arg->isTypeDependent())
1437     ExprBits.TypeDependent = true;
1438   if (Arg->isValueDependent())
1439     ExprBits.ValueDependent = true;
1440   if (Arg->isInstantiationDependent())
1441     ExprBits.InstantiationDependent = true;
1442   if (Arg->containsUnexpandedParameterPack())
1443     ExprBits.ContainsUnexpandedParameterPack = true;
1444 }
1445 
1446 Decl *Expr::getReferencedDeclOfCallee() {
1447   Expr *CEE = IgnoreParenImpCasts();
1448 
1449   while (SubstNonTypeTemplateParmExpr *NTTP =
1450              dyn_cast<SubstNonTypeTemplateParmExpr>(CEE)) {
1451     CEE = NTTP->getReplacement()->IgnoreParenImpCasts();
1452   }
1453 
1454   // If we're calling a dereference, look at the pointer instead.
1455   while (true) {
1456     if (BinaryOperator *BO = dyn_cast<BinaryOperator>(CEE)) {
1457       if (BO->isPtrMemOp()) {
1458         CEE = BO->getRHS()->IgnoreParenImpCasts();
1459         continue;
1460       }
1461     } else if (UnaryOperator *UO = dyn_cast<UnaryOperator>(CEE)) {
1462       if (UO->getOpcode() == UO_Deref || UO->getOpcode() == UO_AddrOf ||
1463           UO->getOpcode() == UO_Plus) {
1464         CEE = UO->getSubExpr()->IgnoreParenImpCasts();
1465         continue;
1466       }
1467     }
1468     break;
1469   }
1470 
1471   if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(CEE))
1472     return DRE->getDecl();
1473   if (MemberExpr *ME = dyn_cast<MemberExpr>(CEE))
1474     return ME->getMemberDecl();
1475   if (auto *BE = dyn_cast<BlockExpr>(CEE))
1476     return BE->getBlockDecl();
1477 
1478   return nullptr;
1479 }
1480 
1481 /// If this is a call to a builtin, return the builtin ID. If not, return 0.
1482 unsigned CallExpr::getBuiltinCallee() const {
1483   auto *FDecl =
1484       dyn_cast_or_null<FunctionDecl>(getCallee()->getReferencedDeclOfCallee());
1485   return FDecl ? FDecl->getBuiltinID() : 0;
1486 }
1487 
1488 bool CallExpr::isUnevaluatedBuiltinCall(const ASTContext &Ctx) const {
1489   if (unsigned BI = getBuiltinCallee())
1490     return Ctx.BuiltinInfo.isUnevaluated(BI);
1491   return false;
1492 }
1493 
1494 QualType CallExpr::getCallReturnType(const ASTContext &Ctx) const {
1495   const Expr *Callee = getCallee();
1496   QualType CalleeType = Callee->getType();
1497   if (const auto *FnTypePtr = CalleeType->getAs<PointerType>()) {
1498     CalleeType = FnTypePtr->getPointeeType();
1499   } else if (const auto *BPT = CalleeType->getAs<BlockPointerType>()) {
1500     CalleeType = BPT->getPointeeType();
1501   } else if (CalleeType->isSpecificPlaceholderType(BuiltinType::BoundMember)) {
1502     if (isa<CXXPseudoDestructorExpr>(Callee->IgnoreParens()))
1503       return Ctx.VoidTy;
1504 
1505     // This should never be overloaded and so should never return null.
1506     CalleeType = Expr::findBoundMemberType(Callee);
1507   }
1508 
1509   const FunctionType *FnType = CalleeType->castAs<FunctionType>();
1510   return FnType->getReturnType();
1511 }
1512 
1513 const Attr *CallExpr::getUnusedResultAttr(const ASTContext &Ctx) const {
1514   // If the return type is a struct, union, or enum that is marked nodiscard,
1515   // then return the return type attribute.
1516   if (const TagDecl *TD = getCallReturnType(Ctx)->getAsTagDecl())
1517     if (const auto *A = TD->getAttr<WarnUnusedResultAttr>())
1518       return A;
1519 
1520   // Otherwise, see if the callee is marked nodiscard and return that attribute
1521   // instead.
1522   const Decl *D = getCalleeDecl();
1523   return D ? D->getAttr<WarnUnusedResultAttr>() : nullptr;
1524 }
1525 
1526 SourceLocation CallExpr::getBeginLoc() const {
1527   if (isa<CXXOperatorCallExpr>(this))
1528     return cast<CXXOperatorCallExpr>(this)->getBeginLoc();
1529 
1530   SourceLocation begin = getCallee()->getBeginLoc();
1531   if (begin.isInvalid() && getNumArgs() > 0 && getArg(0))
1532     begin = getArg(0)->getBeginLoc();
1533   return begin;
1534 }
1535 SourceLocation CallExpr::getEndLoc() const {
1536   if (isa<CXXOperatorCallExpr>(this))
1537     return cast<CXXOperatorCallExpr>(this)->getEndLoc();
1538 
1539   SourceLocation end = getRParenLoc();
1540   if (end.isInvalid() && getNumArgs() > 0 && getArg(getNumArgs() - 1))
1541     end = getArg(getNumArgs() - 1)->getEndLoc();
1542   return end;
1543 }
1544 
1545 OffsetOfExpr *OffsetOfExpr::Create(const ASTContext &C, QualType type,
1546                                    SourceLocation OperatorLoc,
1547                                    TypeSourceInfo *tsi,
1548                                    ArrayRef<OffsetOfNode> comps,
1549                                    ArrayRef<Expr*> exprs,
1550                                    SourceLocation RParenLoc) {
1551   void *Mem = C.Allocate(
1552       totalSizeToAlloc<OffsetOfNode, Expr *>(comps.size(), exprs.size()));
1553 
1554   return new (Mem) OffsetOfExpr(C, type, OperatorLoc, tsi, comps, exprs,
1555                                 RParenLoc);
1556 }
1557 
1558 OffsetOfExpr *OffsetOfExpr::CreateEmpty(const ASTContext &C,
1559                                         unsigned numComps, unsigned numExprs) {
1560   void *Mem =
1561       C.Allocate(totalSizeToAlloc<OffsetOfNode, Expr *>(numComps, numExprs));
1562   return new (Mem) OffsetOfExpr(numComps, numExprs);
1563 }
1564 
1565 OffsetOfExpr::OffsetOfExpr(const ASTContext &C, QualType type,
1566                            SourceLocation OperatorLoc, TypeSourceInfo *tsi,
1567                            ArrayRef<OffsetOfNode> comps, ArrayRef<Expr*> exprs,
1568                            SourceLocation RParenLoc)
1569   : Expr(OffsetOfExprClass, type, VK_RValue, OK_Ordinary,
1570          /*TypeDependent=*/false,
1571          /*ValueDependent=*/tsi->getType()->isDependentType(),
1572          tsi->getType()->isInstantiationDependentType(),
1573          tsi->getType()->containsUnexpandedParameterPack()),
1574     OperatorLoc(OperatorLoc), RParenLoc(RParenLoc), TSInfo(tsi),
1575     NumComps(comps.size()), NumExprs(exprs.size())
1576 {
1577   for (unsigned i = 0; i != comps.size(); ++i) {
1578     setComponent(i, comps[i]);
1579   }
1580 
1581   for (unsigned i = 0; i != exprs.size(); ++i) {
1582     if (exprs[i]->isTypeDependent() || exprs[i]->isValueDependent())
1583       ExprBits.ValueDependent = true;
1584     if (exprs[i]->containsUnexpandedParameterPack())
1585       ExprBits.ContainsUnexpandedParameterPack = true;
1586 
1587     setIndexExpr(i, exprs[i]);
1588   }
1589 }
1590 
1591 IdentifierInfo *OffsetOfNode::getFieldName() const {
1592   assert(getKind() == Field || getKind() == Identifier);
1593   if (getKind() == Field)
1594     return getField()->getIdentifier();
1595 
1596   return reinterpret_cast<IdentifierInfo *> (Data & ~(uintptr_t)Mask);
1597 }
1598 
1599 UnaryExprOrTypeTraitExpr::UnaryExprOrTypeTraitExpr(
1600     UnaryExprOrTypeTrait ExprKind, Expr *E, QualType resultType,
1601     SourceLocation op, SourceLocation rp)
1602     : Expr(UnaryExprOrTypeTraitExprClass, resultType, VK_RValue, OK_Ordinary,
1603            false, // Never type-dependent (C++ [temp.dep.expr]p3).
1604            // Value-dependent if the argument is type-dependent.
1605            E->isTypeDependent(), E->isInstantiationDependent(),
1606            E->containsUnexpandedParameterPack()),
1607       OpLoc(op), RParenLoc(rp) {
1608   UnaryExprOrTypeTraitExprBits.Kind = ExprKind;
1609   UnaryExprOrTypeTraitExprBits.IsType = false;
1610   Argument.Ex = E;
1611 
1612   // Check to see if we are in the situation where alignof(decl) should be
1613   // dependent because decl's alignment is dependent.
1614   if (ExprKind == UETT_AlignOf || ExprKind == UETT_PreferredAlignOf) {
1615     if (!isValueDependent() || !isInstantiationDependent()) {
1616       E = E->IgnoreParens();
1617 
1618       const ValueDecl *D = nullptr;
1619       if (const auto *DRE = dyn_cast<DeclRefExpr>(E))
1620         D = DRE->getDecl();
1621       else if (const auto *ME = dyn_cast<MemberExpr>(E))
1622         D = ME->getMemberDecl();
1623 
1624       if (D) {
1625         for (const auto *I : D->specific_attrs<AlignedAttr>()) {
1626           if (I->isAlignmentDependent()) {
1627             setValueDependent(true);
1628             setInstantiationDependent(true);
1629             break;
1630           }
1631         }
1632       }
1633     }
1634   }
1635 }
1636 
1637 MemberExpr::MemberExpr(Expr *Base, bool IsArrow, SourceLocation OperatorLoc,
1638                        ValueDecl *MemberDecl,
1639                        const DeclarationNameInfo &NameInfo, QualType T,
1640                        ExprValueKind VK, ExprObjectKind OK,
1641                        NonOdrUseReason NOUR)
1642     : Expr(MemberExprClass, T, VK, OK, Base->isTypeDependent(),
1643            Base->isValueDependent(), Base->isInstantiationDependent(),
1644            Base->containsUnexpandedParameterPack()),
1645       Base(Base), MemberDecl(MemberDecl), MemberDNLoc(NameInfo.getInfo()),
1646       MemberLoc(NameInfo.getLoc()) {
1647   assert(!NameInfo.getName() ||
1648          MemberDecl->getDeclName() == NameInfo.getName());
1649   MemberExprBits.IsArrow = IsArrow;
1650   MemberExprBits.HasQualifierOrFoundDecl = false;
1651   MemberExprBits.HasTemplateKWAndArgsInfo = false;
1652   MemberExprBits.HadMultipleCandidates = false;
1653   MemberExprBits.NonOdrUseReason = NOUR;
1654   MemberExprBits.OperatorLoc = OperatorLoc;
1655 }
1656 
1657 MemberExpr *MemberExpr::Create(
1658     const ASTContext &C, Expr *Base, bool IsArrow, SourceLocation OperatorLoc,
1659     NestedNameSpecifierLoc QualifierLoc, SourceLocation TemplateKWLoc,
1660     ValueDecl *MemberDecl, DeclAccessPair FoundDecl,
1661     DeclarationNameInfo NameInfo, const TemplateArgumentListInfo *TemplateArgs,
1662     QualType T, ExprValueKind VK, ExprObjectKind OK, NonOdrUseReason NOUR) {
1663   bool HasQualOrFound = QualifierLoc || FoundDecl.getDecl() != MemberDecl ||
1664                         FoundDecl.getAccess() != MemberDecl->getAccess();
1665   bool HasTemplateKWAndArgsInfo = TemplateArgs || TemplateKWLoc.isValid();
1666   std::size_t Size =
1667       totalSizeToAlloc<MemberExprNameQualifier, ASTTemplateKWAndArgsInfo,
1668                        TemplateArgumentLoc>(
1669           HasQualOrFound ? 1 : 0, HasTemplateKWAndArgsInfo ? 1 : 0,
1670           TemplateArgs ? TemplateArgs->size() : 0);
1671 
1672   void *Mem = C.Allocate(Size, alignof(MemberExpr));
1673   MemberExpr *E = new (Mem) MemberExpr(Base, IsArrow, OperatorLoc, MemberDecl,
1674                                        NameInfo, T, VK, OK, NOUR);
1675 
1676   if (isa<FieldDecl>(MemberDecl)) {
1677     DeclContext *DC = MemberDecl->getDeclContext();
1678     // dyn_cast_or_null is used to handle objC variables which do not
1679     // have a declaration context.
1680     CXXRecordDecl *RD = dyn_cast_or_null<CXXRecordDecl>(DC);
1681     if (RD && RD->isDependentContext() && RD->isCurrentInstantiation(DC))
1682       E->setTypeDependent(T->isDependentType());
1683   }
1684 
1685   if (HasQualOrFound) {
1686     // FIXME: Wrong. We should be looking at the member declaration we found.
1687     if (QualifierLoc && QualifierLoc.getNestedNameSpecifier()->isDependent()) {
1688       E->setValueDependent(true);
1689       E->setTypeDependent(true);
1690       E->setInstantiationDependent(true);
1691     }
1692     else if (QualifierLoc &&
1693              QualifierLoc.getNestedNameSpecifier()->isInstantiationDependent())
1694       E->setInstantiationDependent(true);
1695 
1696     E->MemberExprBits.HasQualifierOrFoundDecl = true;
1697 
1698     MemberExprNameQualifier *NQ =
1699         E->getTrailingObjects<MemberExprNameQualifier>();
1700     NQ->QualifierLoc = QualifierLoc;
1701     NQ->FoundDecl = FoundDecl;
1702   }
1703 
1704   E->MemberExprBits.HasTemplateKWAndArgsInfo =
1705       TemplateArgs || TemplateKWLoc.isValid();
1706 
1707   if (TemplateArgs) {
1708     bool Dependent = false;
1709     bool InstantiationDependent = false;
1710     bool ContainsUnexpandedParameterPack = false;
1711     E->getTrailingObjects<ASTTemplateKWAndArgsInfo>()->initializeFrom(
1712         TemplateKWLoc, *TemplateArgs,
1713         E->getTrailingObjects<TemplateArgumentLoc>(), Dependent,
1714         InstantiationDependent, ContainsUnexpandedParameterPack);
1715     if (InstantiationDependent)
1716       E->setInstantiationDependent(true);
1717   } else if (TemplateKWLoc.isValid()) {
1718     E->getTrailingObjects<ASTTemplateKWAndArgsInfo>()->initializeFrom(
1719         TemplateKWLoc);
1720   }
1721 
1722   return E;
1723 }
1724 
1725 MemberExpr *MemberExpr::CreateEmpty(const ASTContext &Context,
1726                                     bool HasQualifier, bool HasFoundDecl,
1727                                     bool HasTemplateKWAndArgsInfo,
1728                                     unsigned NumTemplateArgs) {
1729   assert((!NumTemplateArgs || HasTemplateKWAndArgsInfo) &&
1730          "template args but no template arg info?");
1731   bool HasQualOrFound = HasQualifier || HasFoundDecl;
1732   std::size_t Size =
1733       totalSizeToAlloc<MemberExprNameQualifier, ASTTemplateKWAndArgsInfo,
1734                        TemplateArgumentLoc>(HasQualOrFound ? 1 : 0,
1735                                             HasTemplateKWAndArgsInfo ? 1 : 0,
1736                                             NumTemplateArgs);
1737   void *Mem = Context.Allocate(Size, alignof(MemberExpr));
1738   return new (Mem) MemberExpr(EmptyShell());
1739 }
1740 
1741 SourceLocation MemberExpr::getBeginLoc() const {
1742   if (isImplicitAccess()) {
1743     if (hasQualifier())
1744       return getQualifierLoc().getBeginLoc();
1745     return MemberLoc;
1746   }
1747 
1748   // FIXME: We don't want this to happen. Rather, we should be able to
1749   // detect all kinds of implicit accesses more cleanly.
1750   SourceLocation BaseStartLoc = getBase()->getBeginLoc();
1751   if (BaseStartLoc.isValid())
1752     return BaseStartLoc;
1753   return MemberLoc;
1754 }
1755 SourceLocation MemberExpr::getEndLoc() const {
1756   SourceLocation EndLoc = getMemberNameInfo().getEndLoc();
1757   if (hasExplicitTemplateArgs())
1758     EndLoc = getRAngleLoc();
1759   else if (EndLoc.isInvalid())
1760     EndLoc = getBase()->getEndLoc();
1761   return EndLoc;
1762 }
1763 
1764 bool CastExpr::CastConsistency() const {
1765   switch (getCastKind()) {
1766   case CK_DerivedToBase:
1767   case CK_UncheckedDerivedToBase:
1768   case CK_DerivedToBaseMemberPointer:
1769   case CK_BaseToDerived:
1770   case CK_BaseToDerivedMemberPointer:
1771     assert(!path_empty() && "Cast kind should have a base path!");
1772     break;
1773 
1774   case CK_CPointerToObjCPointerCast:
1775     assert(getType()->isObjCObjectPointerType());
1776     assert(getSubExpr()->getType()->isPointerType());
1777     goto CheckNoBasePath;
1778 
1779   case CK_BlockPointerToObjCPointerCast:
1780     assert(getType()->isObjCObjectPointerType());
1781     assert(getSubExpr()->getType()->isBlockPointerType());
1782     goto CheckNoBasePath;
1783 
1784   case CK_ReinterpretMemberPointer:
1785     assert(getType()->isMemberPointerType());
1786     assert(getSubExpr()->getType()->isMemberPointerType());
1787     goto CheckNoBasePath;
1788 
1789   case CK_BitCast:
1790     // Arbitrary casts to C pointer types count as bitcasts.
1791     // Otherwise, we should only have block and ObjC pointer casts
1792     // here if they stay within the type kind.
1793     if (!getType()->isPointerType()) {
1794       assert(getType()->isObjCObjectPointerType() ==
1795              getSubExpr()->getType()->isObjCObjectPointerType());
1796       assert(getType()->isBlockPointerType() ==
1797              getSubExpr()->getType()->isBlockPointerType());
1798     }
1799     goto CheckNoBasePath;
1800 
1801   case CK_AnyPointerToBlockPointerCast:
1802     assert(getType()->isBlockPointerType());
1803     assert(getSubExpr()->getType()->isAnyPointerType() &&
1804            !getSubExpr()->getType()->isBlockPointerType());
1805     goto CheckNoBasePath;
1806 
1807   case CK_CopyAndAutoreleaseBlockObject:
1808     assert(getType()->isBlockPointerType());
1809     assert(getSubExpr()->getType()->isBlockPointerType());
1810     goto CheckNoBasePath;
1811 
1812   case CK_FunctionToPointerDecay:
1813     assert(getType()->isPointerType());
1814     assert(getSubExpr()->getType()->isFunctionType());
1815     goto CheckNoBasePath;
1816 
1817   case CK_AddressSpaceConversion: {
1818     auto Ty = getType();
1819     auto SETy = getSubExpr()->getType();
1820     assert(getValueKindForType(Ty) == Expr::getValueKindForType(SETy));
1821     if (isRValue()) {
1822       Ty = Ty->getPointeeType();
1823       SETy = SETy->getPointeeType();
1824     }
1825     assert(!Ty.isNull() && !SETy.isNull() &&
1826            Ty.getAddressSpace() != SETy.getAddressSpace());
1827     goto CheckNoBasePath;
1828   }
1829   // These should not have an inheritance path.
1830   case CK_Dynamic:
1831   case CK_ToUnion:
1832   case CK_ArrayToPointerDecay:
1833   case CK_NullToMemberPointer:
1834   case CK_NullToPointer:
1835   case CK_ConstructorConversion:
1836   case CK_IntegralToPointer:
1837   case CK_PointerToIntegral:
1838   case CK_ToVoid:
1839   case CK_VectorSplat:
1840   case CK_IntegralCast:
1841   case CK_BooleanToSignedIntegral:
1842   case CK_IntegralToFloating:
1843   case CK_FloatingToIntegral:
1844   case CK_FloatingCast:
1845   case CK_ObjCObjectLValueCast:
1846   case CK_FloatingRealToComplex:
1847   case CK_FloatingComplexToReal:
1848   case CK_FloatingComplexCast:
1849   case CK_FloatingComplexToIntegralComplex:
1850   case CK_IntegralRealToComplex:
1851   case CK_IntegralComplexToReal:
1852   case CK_IntegralComplexCast:
1853   case CK_IntegralComplexToFloatingComplex:
1854   case CK_ARCProduceObject:
1855   case CK_ARCConsumeObject:
1856   case CK_ARCReclaimReturnedObject:
1857   case CK_ARCExtendBlockObject:
1858   case CK_ZeroToOCLOpaqueType:
1859   case CK_IntToOCLSampler:
1860   case CK_FixedPointCast:
1861   case CK_FixedPointToIntegral:
1862   case CK_IntegralToFixedPoint:
1863     assert(!getType()->isBooleanType() && "unheralded conversion to bool");
1864     goto CheckNoBasePath;
1865 
1866   case CK_Dependent:
1867   case CK_LValueToRValue:
1868   case CK_NoOp:
1869   case CK_AtomicToNonAtomic:
1870   case CK_NonAtomicToAtomic:
1871   case CK_PointerToBoolean:
1872   case CK_IntegralToBoolean:
1873   case CK_FloatingToBoolean:
1874   case CK_MemberPointerToBoolean:
1875   case CK_FloatingComplexToBoolean:
1876   case CK_IntegralComplexToBoolean:
1877   case CK_LValueBitCast:            // -> bool&
1878   case CK_LValueToRValueBitCast:
1879   case CK_UserDefinedConversion:    // operator bool()
1880   case CK_BuiltinFnToFnPtr:
1881   case CK_FixedPointToBoolean:
1882   CheckNoBasePath:
1883     assert(path_empty() && "Cast kind should not have a base path!");
1884     break;
1885   }
1886   return true;
1887 }
1888 
1889 const char *CastExpr::getCastKindName(CastKind CK) {
1890   switch (CK) {
1891 #define CAST_OPERATION(Name) case CK_##Name: return #Name;
1892 #include "clang/AST/OperationKinds.def"
1893   }
1894   llvm_unreachable("Unhandled cast kind!");
1895 }
1896 
1897 namespace {
1898   const Expr *skipImplicitTemporary(const Expr *E) {
1899     // Skip through reference binding to temporary.
1900     if (auto *Materialize = dyn_cast<MaterializeTemporaryExpr>(E))
1901       E = Materialize->getSubExpr();
1902 
1903     // Skip any temporary bindings; they're implicit.
1904     if (auto *Binder = dyn_cast<CXXBindTemporaryExpr>(E))
1905       E = Binder->getSubExpr();
1906 
1907     return E;
1908   }
1909 }
1910 
1911 Expr *CastExpr::getSubExprAsWritten() {
1912   const Expr *SubExpr = nullptr;
1913   const CastExpr *E = this;
1914   do {
1915     SubExpr = skipImplicitTemporary(E->getSubExpr());
1916 
1917     // Conversions by constructor and conversion functions have a
1918     // subexpression describing the call; strip it off.
1919     if (E->getCastKind() == CK_ConstructorConversion)
1920       SubExpr =
1921         skipImplicitTemporary(cast<CXXConstructExpr>(SubExpr)->getArg(0));
1922     else if (E->getCastKind() == CK_UserDefinedConversion) {
1923       assert((isa<CXXMemberCallExpr>(SubExpr) ||
1924               isa<BlockExpr>(SubExpr)) &&
1925              "Unexpected SubExpr for CK_UserDefinedConversion.");
1926       if (auto *MCE = dyn_cast<CXXMemberCallExpr>(SubExpr))
1927         SubExpr = MCE->getImplicitObjectArgument();
1928     }
1929 
1930     // If the subexpression we're left with is an implicit cast, look
1931     // through that, too.
1932   } while ((E = dyn_cast<ImplicitCastExpr>(SubExpr)));
1933 
1934   return const_cast<Expr*>(SubExpr);
1935 }
1936 
1937 NamedDecl *CastExpr::getConversionFunction() const {
1938   const Expr *SubExpr = nullptr;
1939 
1940   for (const CastExpr *E = this; E; E = dyn_cast<ImplicitCastExpr>(SubExpr)) {
1941     SubExpr = skipImplicitTemporary(E->getSubExpr());
1942 
1943     if (E->getCastKind() == CK_ConstructorConversion)
1944       return cast<CXXConstructExpr>(SubExpr)->getConstructor();
1945 
1946     if (E->getCastKind() == CK_UserDefinedConversion) {
1947       if (auto *MCE = dyn_cast<CXXMemberCallExpr>(SubExpr))
1948         return MCE->getMethodDecl();
1949     }
1950   }
1951 
1952   return nullptr;
1953 }
1954 
1955 CXXBaseSpecifier **CastExpr::path_buffer() {
1956   switch (getStmtClass()) {
1957 #define ABSTRACT_STMT(x)
1958 #define CASTEXPR(Type, Base)                                                   \
1959   case Stmt::Type##Class:                                                      \
1960     return static_cast<Type *>(this)->getTrailingObjects<CXXBaseSpecifier *>();
1961 #define STMT(Type, Base)
1962 #include "clang/AST/StmtNodes.inc"
1963   default:
1964     llvm_unreachable("non-cast expressions not possible here");
1965   }
1966 }
1967 
1968 const FieldDecl *CastExpr::getTargetFieldForToUnionCast(QualType unionType,
1969                                                         QualType opType) {
1970   auto RD = unionType->castAs<RecordType>()->getDecl();
1971   return getTargetFieldForToUnionCast(RD, opType);
1972 }
1973 
1974 const FieldDecl *CastExpr::getTargetFieldForToUnionCast(const RecordDecl *RD,
1975                                                         QualType OpType) {
1976   auto &Ctx = RD->getASTContext();
1977   RecordDecl::field_iterator Field, FieldEnd;
1978   for (Field = RD->field_begin(), FieldEnd = RD->field_end();
1979        Field != FieldEnd; ++Field) {
1980     if (Ctx.hasSameUnqualifiedType(Field->getType(), OpType) &&
1981         !Field->isUnnamedBitfield()) {
1982       return *Field;
1983     }
1984   }
1985   return nullptr;
1986 }
1987 
1988 ImplicitCastExpr *ImplicitCastExpr::Create(const ASTContext &C, QualType T,
1989                                            CastKind Kind, Expr *Operand,
1990                                            const CXXCastPath *BasePath,
1991                                            ExprValueKind VK) {
1992   unsigned PathSize = (BasePath ? BasePath->size() : 0);
1993   void *Buffer = C.Allocate(totalSizeToAlloc<CXXBaseSpecifier *>(PathSize));
1994   // Per C++ [conv.lval]p3, lvalue-to-rvalue conversions on class and
1995   // std::nullptr_t have special semantics not captured by CK_LValueToRValue.
1996   assert((Kind != CK_LValueToRValue ||
1997           !(T->isNullPtrType() || T->getAsCXXRecordDecl())) &&
1998          "invalid type for lvalue-to-rvalue conversion");
1999   ImplicitCastExpr *E =
2000     new (Buffer) ImplicitCastExpr(T, Kind, Operand, PathSize, VK);
2001   if (PathSize)
2002     std::uninitialized_copy_n(BasePath->data(), BasePath->size(),
2003                               E->getTrailingObjects<CXXBaseSpecifier *>());
2004   return E;
2005 }
2006 
2007 ImplicitCastExpr *ImplicitCastExpr::CreateEmpty(const ASTContext &C,
2008                                                 unsigned PathSize) {
2009   void *Buffer = C.Allocate(totalSizeToAlloc<CXXBaseSpecifier *>(PathSize));
2010   return new (Buffer) ImplicitCastExpr(EmptyShell(), PathSize);
2011 }
2012 
2013 
2014 CStyleCastExpr *CStyleCastExpr::Create(const ASTContext &C, QualType T,
2015                                        ExprValueKind VK, CastKind K, Expr *Op,
2016                                        const CXXCastPath *BasePath,
2017                                        TypeSourceInfo *WrittenTy,
2018                                        SourceLocation L, SourceLocation R) {
2019   unsigned PathSize = (BasePath ? BasePath->size() : 0);
2020   void *Buffer = C.Allocate(totalSizeToAlloc<CXXBaseSpecifier *>(PathSize));
2021   CStyleCastExpr *E =
2022     new (Buffer) CStyleCastExpr(T, VK, K, Op, PathSize, WrittenTy, L, R);
2023   if (PathSize)
2024     std::uninitialized_copy_n(BasePath->data(), BasePath->size(),
2025                               E->getTrailingObjects<CXXBaseSpecifier *>());
2026   return E;
2027 }
2028 
2029 CStyleCastExpr *CStyleCastExpr::CreateEmpty(const ASTContext &C,
2030                                             unsigned PathSize) {
2031   void *Buffer = C.Allocate(totalSizeToAlloc<CXXBaseSpecifier *>(PathSize));
2032   return new (Buffer) CStyleCastExpr(EmptyShell(), PathSize);
2033 }
2034 
2035 /// getOpcodeStr - Turn an Opcode enum value into the punctuation char it
2036 /// corresponds to, e.g. "<<=".
2037 StringRef BinaryOperator::getOpcodeStr(Opcode Op) {
2038   switch (Op) {
2039 #define BINARY_OPERATION(Name, Spelling) case BO_##Name: return Spelling;
2040 #include "clang/AST/OperationKinds.def"
2041   }
2042   llvm_unreachable("Invalid OpCode!");
2043 }
2044 
2045 BinaryOperatorKind
2046 BinaryOperator::getOverloadedOpcode(OverloadedOperatorKind OO) {
2047   switch (OO) {
2048   default: llvm_unreachable("Not an overloadable binary operator");
2049   case OO_Plus: return BO_Add;
2050   case OO_Minus: return BO_Sub;
2051   case OO_Star: return BO_Mul;
2052   case OO_Slash: return BO_Div;
2053   case OO_Percent: return BO_Rem;
2054   case OO_Caret: return BO_Xor;
2055   case OO_Amp: return BO_And;
2056   case OO_Pipe: return BO_Or;
2057   case OO_Equal: return BO_Assign;
2058   case OO_Spaceship: return BO_Cmp;
2059   case OO_Less: return BO_LT;
2060   case OO_Greater: return BO_GT;
2061   case OO_PlusEqual: return BO_AddAssign;
2062   case OO_MinusEqual: return BO_SubAssign;
2063   case OO_StarEqual: return BO_MulAssign;
2064   case OO_SlashEqual: return BO_DivAssign;
2065   case OO_PercentEqual: return BO_RemAssign;
2066   case OO_CaretEqual: return BO_XorAssign;
2067   case OO_AmpEqual: return BO_AndAssign;
2068   case OO_PipeEqual: return BO_OrAssign;
2069   case OO_LessLess: return BO_Shl;
2070   case OO_GreaterGreater: return BO_Shr;
2071   case OO_LessLessEqual: return BO_ShlAssign;
2072   case OO_GreaterGreaterEqual: return BO_ShrAssign;
2073   case OO_EqualEqual: return BO_EQ;
2074   case OO_ExclaimEqual: return BO_NE;
2075   case OO_LessEqual: return BO_LE;
2076   case OO_GreaterEqual: return BO_GE;
2077   case OO_AmpAmp: return BO_LAnd;
2078   case OO_PipePipe: return BO_LOr;
2079   case OO_Comma: return BO_Comma;
2080   case OO_ArrowStar: return BO_PtrMemI;
2081   }
2082 }
2083 
2084 OverloadedOperatorKind BinaryOperator::getOverloadedOperator(Opcode Opc) {
2085   static const OverloadedOperatorKind OverOps[] = {
2086     /* .* Cannot be overloaded */OO_None, OO_ArrowStar,
2087     OO_Star, OO_Slash, OO_Percent,
2088     OO_Plus, OO_Minus,
2089     OO_LessLess, OO_GreaterGreater,
2090     OO_Spaceship,
2091     OO_Less, OO_Greater, OO_LessEqual, OO_GreaterEqual,
2092     OO_EqualEqual, OO_ExclaimEqual,
2093     OO_Amp,
2094     OO_Caret,
2095     OO_Pipe,
2096     OO_AmpAmp,
2097     OO_PipePipe,
2098     OO_Equal, OO_StarEqual,
2099     OO_SlashEqual, OO_PercentEqual,
2100     OO_PlusEqual, OO_MinusEqual,
2101     OO_LessLessEqual, OO_GreaterGreaterEqual,
2102     OO_AmpEqual, OO_CaretEqual,
2103     OO_PipeEqual,
2104     OO_Comma
2105   };
2106   return OverOps[Opc];
2107 }
2108 
2109 bool BinaryOperator::isNullPointerArithmeticExtension(ASTContext &Ctx,
2110                                                       Opcode Opc,
2111                                                       Expr *LHS, Expr *RHS) {
2112   if (Opc != BO_Add)
2113     return false;
2114 
2115   // Check that we have one pointer and one integer operand.
2116   Expr *PExp;
2117   if (LHS->getType()->isPointerType()) {
2118     if (!RHS->getType()->isIntegerType())
2119       return false;
2120     PExp = LHS;
2121   } else if (RHS->getType()->isPointerType()) {
2122     if (!LHS->getType()->isIntegerType())
2123       return false;
2124     PExp = RHS;
2125   } else {
2126     return false;
2127   }
2128 
2129   // Check that the pointer is a nullptr.
2130   if (!PExp->IgnoreParenCasts()
2131           ->isNullPointerConstant(Ctx, Expr::NPC_ValueDependentIsNotNull))
2132     return false;
2133 
2134   // Check that the pointee type is char-sized.
2135   const PointerType *PTy = PExp->getType()->getAs<PointerType>();
2136   if (!PTy || !PTy->getPointeeType()->isCharType())
2137     return false;
2138 
2139   return true;
2140 }
2141 
2142 static QualType getDecayedSourceLocExprType(const ASTContext &Ctx,
2143                                             SourceLocExpr::IdentKind Kind) {
2144   switch (Kind) {
2145   case SourceLocExpr::File:
2146   case SourceLocExpr::Function: {
2147     QualType ArrTy = Ctx.getStringLiteralArrayType(Ctx.CharTy, 0);
2148     return Ctx.getPointerType(ArrTy->getAsArrayTypeUnsafe()->getElementType());
2149   }
2150   case SourceLocExpr::Line:
2151   case SourceLocExpr::Column:
2152     return Ctx.UnsignedIntTy;
2153   }
2154   llvm_unreachable("unhandled case");
2155 }
2156 
2157 SourceLocExpr::SourceLocExpr(const ASTContext &Ctx, IdentKind Kind,
2158                              SourceLocation BLoc, SourceLocation RParenLoc,
2159                              DeclContext *ParentContext)
2160     : Expr(SourceLocExprClass, getDecayedSourceLocExprType(Ctx, Kind),
2161            VK_RValue, OK_Ordinary, false, false, false, false),
2162       BuiltinLoc(BLoc), RParenLoc(RParenLoc), ParentContext(ParentContext) {
2163   SourceLocExprBits.Kind = Kind;
2164 }
2165 
2166 StringRef SourceLocExpr::getBuiltinStr() const {
2167   switch (getIdentKind()) {
2168   case File:
2169     return "__builtin_FILE";
2170   case Function:
2171     return "__builtin_FUNCTION";
2172   case Line:
2173     return "__builtin_LINE";
2174   case Column:
2175     return "__builtin_COLUMN";
2176   }
2177   llvm_unreachable("unexpected IdentKind!");
2178 }
2179 
2180 APValue SourceLocExpr::EvaluateInContext(const ASTContext &Ctx,
2181                                          const Expr *DefaultExpr) const {
2182   SourceLocation Loc;
2183   const DeclContext *Context;
2184 
2185   std::tie(Loc,
2186            Context) = [&]() -> std::pair<SourceLocation, const DeclContext *> {
2187     if (auto *DIE = dyn_cast_or_null<CXXDefaultInitExpr>(DefaultExpr))
2188       return {DIE->getUsedLocation(), DIE->getUsedContext()};
2189     if (auto *DAE = dyn_cast_or_null<CXXDefaultArgExpr>(DefaultExpr))
2190       return {DAE->getUsedLocation(), DAE->getUsedContext()};
2191     return {this->getLocation(), this->getParentContext()};
2192   }();
2193 
2194   PresumedLoc PLoc = Ctx.getSourceManager().getPresumedLoc(
2195       Ctx.getSourceManager().getExpansionRange(Loc).getEnd());
2196 
2197   auto MakeStringLiteral = [&](StringRef Tmp) {
2198     using LValuePathEntry = APValue::LValuePathEntry;
2199     StringLiteral *Res = Ctx.getPredefinedStringLiteralFromCache(Tmp);
2200     // Decay the string to a pointer to the first character.
2201     LValuePathEntry Path[1] = {LValuePathEntry::ArrayIndex(0)};
2202     return APValue(Res, CharUnits::Zero(), Path, /*OnePastTheEnd=*/false);
2203   };
2204 
2205   switch (getIdentKind()) {
2206   case SourceLocExpr::File:
2207     return MakeStringLiteral(PLoc.getFilename());
2208   case SourceLocExpr::Function: {
2209     const Decl *CurDecl = dyn_cast_or_null<Decl>(Context);
2210     return MakeStringLiteral(
2211         CurDecl ? PredefinedExpr::ComputeName(PredefinedExpr::Function, CurDecl)
2212                 : std::string(""));
2213   }
2214   case SourceLocExpr::Line:
2215   case SourceLocExpr::Column: {
2216     llvm::APSInt IntVal(Ctx.getIntWidth(Ctx.UnsignedIntTy),
2217                         /*isUnsigned=*/true);
2218     IntVal = getIdentKind() == SourceLocExpr::Line ? PLoc.getLine()
2219                                                    : PLoc.getColumn();
2220     return APValue(IntVal);
2221   }
2222   }
2223   llvm_unreachable("unhandled case");
2224 }
2225 
2226 InitListExpr::InitListExpr(const ASTContext &C, SourceLocation lbraceloc,
2227                            ArrayRef<Expr*> initExprs, SourceLocation rbraceloc)
2228   : Expr(InitListExprClass, QualType(), VK_RValue, OK_Ordinary, false, false,
2229          false, false),
2230     InitExprs(C, initExprs.size()),
2231     LBraceLoc(lbraceloc), RBraceLoc(rbraceloc), AltForm(nullptr, true)
2232 {
2233   sawArrayRangeDesignator(false);
2234   for (unsigned I = 0; I != initExprs.size(); ++I) {
2235     if (initExprs[I]->isTypeDependent())
2236       ExprBits.TypeDependent = true;
2237     if (initExprs[I]->isValueDependent())
2238       ExprBits.ValueDependent = true;
2239     if (initExprs[I]->isInstantiationDependent())
2240       ExprBits.InstantiationDependent = true;
2241     if (initExprs[I]->containsUnexpandedParameterPack())
2242       ExprBits.ContainsUnexpandedParameterPack = true;
2243   }
2244 
2245   InitExprs.insert(C, InitExprs.end(), initExprs.begin(), initExprs.end());
2246 }
2247 
2248 void InitListExpr::reserveInits(const ASTContext &C, unsigned NumInits) {
2249   if (NumInits > InitExprs.size())
2250     InitExprs.reserve(C, NumInits);
2251 }
2252 
2253 void InitListExpr::resizeInits(const ASTContext &C, unsigned NumInits) {
2254   InitExprs.resize(C, NumInits, nullptr);
2255 }
2256 
2257 Expr *InitListExpr::updateInit(const ASTContext &C, unsigned Init, Expr *expr) {
2258   if (Init >= InitExprs.size()) {
2259     InitExprs.insert(C, InitExprs.end(), Init - InitExprs.size() + 1, nullptr);
2260     setInit(Init, expr);
2261     return nullptr;
2262   }
2263 
2264   Expr *Result = cast_or_null<Expr>(InitExprs[Init]);
2265   setInit(Init, expr);
2266   return Result;
2267 }
2268 
2269 void InitListExpr::setArrayFiller(Expr *filler) {
2270   assert(!hasArrayFiller() && "Filler already set!");
2271   ArrayFillerOrUnionFieldInit = filler;
2272   // Fill out any "holes" in the array due to designated initializers.
2273   Expr **inits = getInits();
2274   for (unsigned i = 0, e = getNumInits(); i != e; ++i)
2275     if (inits[i] == nullptr)
2276       inits[i] = filler;
2277 }
2278 
2279 bool InitListExpr::isStringLiteralInit() const {
2280   if (getNumInits() != 1)
2281     return false;
2282   const ArrayType *AT = getType()->getAsArrayTypeUnsafe();
2283   if (!AT || !AT->getElementType()->isIntegerType())
2284     return false;
2285   // It is possible for getInit() to return null.
2286   const Expr *Init = getInit(0);
2287   if (!Init)
2288     return false;
2289   Init = Init->IgnoreParens();
2290   return isa<StringLiteral>(Init) || isa<ObjCEncodeExpr>(Init);
2291 }
2292 
2293 bool InitListExpr::isTransparent() const {
2294   assert(isSemanticForm() && "syntactic form never semantically transparent");
2295 
2296   // A glvalue InitListExpr is always just sugar.
2297   if (isGLValue()) {
2298     assert(getNumInits() == 1 && "multiple inits in glvalue init list");
2299     return true;
2300   }
2301 
2302   // Otherwise, we're sugar if and only if we have exactly one initializer that
2303   // is of the same type.
2304   if (getNumInits() != 1 || !getInit(0))
2305     return false;
2306 
2307   // Don't confuse aggregate initialization of a struct X { X &x; }; with a
2308   // transparent struct copy.
2309   if (!getInit(0)->isRValue() && getType()->isRecordType())
2310     return false;
2311 
2312   return getType().getCanonicalType() ==
2313          getInit(0)->getType().getCanonicalType();
2314 }
2315 
2316 bool InitListExpr::isIdiomaticZeroInitializer(const LangOptions &LangOpts) const {
2317   assert(isSyntacticForm() && "only test syntactic form as zero initializer");
2318 
2319   if (LangOpts.CPlusPlus || getNumInits() != 1 || !getInit(0)) {
2320     return false;
2321   }
2322 
2323   const IntegerLiteral *Lit = dyn_cast<IntegerLiteral>(getInit(0)->IgnoreImplicit());
2324   return Lit && Lit->getValue() == 0;
2325 }
2326 
2327 SourceLocation InitListExpr::getBeginLoc() const {
2328   if (InitListExpr *SyntacticForm = getSyntacticForm())
2329     return SyntacticForm->getBeginLoc();
2330   SourceLocation Beg = LBraceLoc;
2331   if (Beg.isInvalid()) {
2332     // Find the first non-null initializer.
2333     for (InitExprsTy::const_iterator I = InitExprs.begin(),
2334                                      E = InitExprs.end();
2335       I != E; ++I) {
2336       if (Stmt *S = *I) {
2337         Beg = S->getBeginLoc();
2338         break;
2339       }
2340     }
2341   }
2342   return Beg;
2343 }
2344 
2345 SourceLocation InitListExpr::getEndLoc() const {
2346   if (InitListExpr *SyntacticForm = getSyntacticForm())
2347     return SyntacticForm->getEndLoc();
2348   SourceLocation End = RBraceLoc;
2349   if (End.isInvalid()) {
2350     // Find the first non-null initializer from the end.
2351     for (InitExprsTy::const_reverse_iterator I = InitExprs.rbegin(),
2352          E = InitExprs.rend();
2353          I != E; ++I) {
2354       if (Stmt *S = *I) {
2355         End = S->getEndLoc();
2356         break;
2357       }
2358     }
2359   }
2360   return End;
2361 }
2362 
2363 /// getFunctionType - Return the underlying function type for this block.
2364 ///
2365 const FunctionProtoType *BlockExpr::getFunctionType() const {
2366   // The block pointer is never sugared, but the function type might be.
2367   return cast<BlockPointerType>(getType())
2368            ->getPointeeType()->castAs<FunctionProtoType>();
2369 }
2370 
2371 SourceLocation BlockExpr::getCaretLocation() const {
2372   return TheBlock->getCaretLocation();
2373 }
2374 const Stmt *BlockExpr::getBody() const {
2375   return TheBlock->getBody();
2376 }
2377 Stmt *BlockExpr::getBody() {
2378   return TheBlock->getBody();
2379 }
2380 
2381 
2382 //===----------------------------------------------------------------------===//
2383 // Generic Expression Routines
2384 //===----------------------------------------------------------------------===//
2385 
2386 /// isUnusedResultAWarning - Return true if this immediate expression should
2387 /// be warned about if the result is unused.  If so, fill in Loc and Ranges
2388 /// with location to warn on and the source range[s] to report with the
2389 /// warning.
2390 bool Expr::isUnusedResultAWarning(const Expr *&WarnE, SourceLocation &Loc,
2391                                   SourceRange &R1, SourceRange &R2,
2392                                   ASTContext &Ctx) const {
2393   // Don't warn if the expr is type dependent. The type could end up
2394   // instantiating to void.
2395   if (isTypeDependent())
2396     return false;
2397 
2398   switch (getStmtClass()) {
2399   default:
2400     if (getType()->isVoidType())
2401       return false;
2402     WarnE = this;
2403     Loc = getExprLoc();
2404     R1 = getSourceRange();
2405     return true;
2406   case ParenExprClass:
2407     return cast<ParenExpr>(this)->getSubExpr()->
2408       isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx);
2409   case GenericSelectionExprClass:
2410     return cast<GenericSelectionExpr>(this)->getResultExpr()->
2411       isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx);
2412   case CoawaitExprClass:
2413   case CoyieldExprClass:
2414     return cast<CoroutineSuspendExpr>(this)->getResumeExpr()->
2415       isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx);
2416   case ChooseExprClass:
2417     return cast<ChooseExpr>(this)->getChosenSubExpr()->
2418       isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx);
2419   case UnaryOperatorClass: {
2420     const UnaryOperator *UO = cast<UnaryOperator>(this);
2421 
2422     switch (UO->getOpcode()) {
2423     case UO_Plus:
2424     case UO_Minus:
2425     case UO_AddrOf:
2426     case UO_Not:
2427     case UO_LNot:
2428     case UO_Deref:
2429       break;
2430     case UO_Coawait:
2431       // This is just the 'operator co_await' call inside the guts of a
2432       // dependent co_await call.
2433     case UO_PostInc:
2434     case UO_PostDec:
2435     case UO_PreInc:
2436     case UO_PreDec:                 // ++/--
2437       return false;  // Not a warning.
2438     case UO_Real:
2439     case UO_Imag:
2440       // accessing a piece of a volatile complex is a side-effect.
2441       if (Ctx.getCanonicalType(UO->getSubExpr()->getType())
2442           .isVolatileQualified())
2443         return false;
2444       break;
2445     case UO_Extension:
2446       return UO->getSubExpr()->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx);
2447     }
2448     WarnE = this;
2449     Loc = UO->getOperatorLoc();
2450     R1 = UO->getSubExpr()->getSourceRange();
2451     return true;
2452   }
2453   case BinaryOperatorClass: {
2454     const BinaryOperator *BO = cast<BinaryOperator>(this);
2455     switch (BO->getOpcode()) {
2456       default:
2457         break;
2458       // Consider the RHS of comma for side effects. LHS was checked by
2459       // Sema::CheckCommaOperands.
2460       case BO_Comma:
2461         // ((foo = <blah>), 0) is an idiom for hiding the result (and
2462         // lvalue-ness) of an assignment written in a macro.
2463         if (IntegerLiteral *IE =
2464               dyn_cast<IntegerLiteral>(BO->getRHS()->IgnoreParens()))
2465           if (IE->getValue() == 0)
2466             return false;
2467         return BO->getRHS()->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx);
2468       // Consider '||', '&&' to have side effects if the LHS or RHS does.
2469       case BO_LAnd:
2470       case BO_LOr:
2471         if (!BO->getLHS()->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx) ||
2472             !BO->getRHS()->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx))
2473           return false;
2474         break;
2475     }
2476     if (BO->isAssignmentOp())
2477       return false;
2478     WarnE = this;
2479     Loc = BO->getOperatorLoc();
2480     R1 = BO->getLHS()->getSourceRange();
2481     R2 = BO->getRHS()->getSourceRange();
2482     return true;
2483   }
2484   case CompoundAssignOperatorClass:
2485   case VAArgExprClass:
2486   case AtomicExprClass:
2487     return false;
2488 
2489   case ConditionalOperatorClass: {
2490     // If only one of the LHS or RHS is a warning, the operator might
2491     // be being used for control flow. Only warn if both the LHS and
2492     // RHS are warnings.
2493     const auto *Exp = cast<ConditionalOperator>(this);
2494     return Exp->getLHS()->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx) &&
2495            Exp->getRHS()->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx);
2496   }
2497   case BinaryConditionalOperatorClass: {
2498     const auto *Exp = cast<BinaryConditionalOperator>(this);
2499     return Exp->getFalseExpr()->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx);
2500   }
2501 
2502   case MemberExprClass:
2503     WarnE = this;
2504     Loc = cast<MemberExpr>(this)->getMemberLoc();
2505     R1 = SourceRange(Loc, Loc);
2506     R2 = cast<MemberExpr>(this)->getBase()->getSourceRange();
2507     return true;
2508 
2509   case ArraySubscriptExprClass:
2510     WarnE = this;
2511     Loc = cast<ArraySubscriptExpr>(this)->getRBracketLoc();
2512     R1 = cast<ArraySubscriptExpr>(this)->getLHS()->getSourceRange();
2513     R2 = cast<ArraySubscriptExpr>(this)->getRHS()->getSourceRange();
2514     return true;
2515 
2516   case CXXOperatorCallExprClass: {
2517     // Warn about operator ==,!=,<,>,<=, and >= even when user-defined operator
2518     // overloads as there is no reasonable way to define these such that they
2519     // have non-trivial, desirable side-effects. See the -Wunused-comparison
2520     // warning: operators == and != are commonly typo'ed, and so warning on them
2521     // provides additional value as well. If this list is updated,
2522     // DiagnoseUnusedComparison should be as well.
2523     const CXXOperatorCallExpr *Op = cast<CXXOperatorCallExpr>(this);
2524     switch (Op->getOperator()) {
2525     default:
2526       break;
2527     case OO_EqualEqual:
2528     case OO_ExclaimEqual:
2529     case OO_Less:
2530     case OO_Greater:
2531     case OO_GreaterEqual:
2532     case OO_LessEqual:
2533       if (Op->getCallReturnType(Ctx)->isReferenceType() ||
2534           Op->getCallReturnType(Ctx)->isVoidType())
2535         break;
2536       WarnE = this;
2537       Loc = Op->getOperatorLoc();
2538       R1 = Op->getSourceRange();
2539       return true;
2540     }
2541 
2542     // Fallthrough for generic call handling.
2543     LLVM_FALLTHROUGH;
2544   }
2545   case CallExprClass:
2546   case CXXMemberCallExprClass:
2547   case UserDefinedLiteralClass: {
2548     // If this is a direct call, get the callee.
2549     const CallExpr *CE = cast<CallExpr>(this);
2550     if (const Decl *FD = CE->getCalleeDecl()) {
2551       // If the callee has attribute pure, const, or warn_unused_result, warn
2552       // about it. void foo() { strlen("bar"); } should warn.
2553       //
2554       // Note: If new cases are added here, DiagnoseUnusedExprResult should be
2555       // updated to match for QoI.
2556       if (CE->hasUnusedResultAttr(Ctx) ||
2557           FD->hasAttr<PureAttr>() || FD->hasAttr<ConstAttr>()) {
2558         WarnE = this;
2559         Loc = CE->getCallee()->getBeginLoc();
2560         R1 = CE->getCallee()->getSourceRange();
2561 
2562         if (unsigned NumArgs = CE->getNumArgs())
2563           R2 = SourceRange(CE->getArg(0)->getBeginLoc(),
2564                            CE->getArg(NumArgs - 1)->getEndLoc());
2565         return true;
2566       }
2567     }
2568     return false;
2569   }
2570 
2571   // If we don't know precisely what we're looking at, let's not warn.
2572   case UnresolvedLookupExprClass:
2573   case CXXUnresolvedConstructExprClass:
2574     return false;
2575 
2576   case CXXTemporaryObjectExprClass:
2577   case CXXConstructExprClass: {
2578     if (const CXXRecordDecl *Type = getType()->getAsCXXRecordDecl()) {
2579       const auto *WarnURAttr = Type->getAttr<WarnUnusedResultAttr>();
2580       if (Type->hasAttr<WarnUnusedAttr>() ||
2581           (WarnURAttr && WarnURAttr->IsCXX11NoDiscard())) {
2582         WarnE = this;
2583         Loc = getBeginLoc();
2584         R1 = getSourceRange();
2585         return true;
2586       }
2587     }
2588 
2589     const auto *CE = cast<CXXConstructExpr>(this);
2590     if (const CXXConstructorDecl *Ctor = CE->getConstructor()) {
2591       const auto *WarnURAttr = Ctor->getAttr<WarnUnusedResultAttr>();
2592       if (WarnURAttr && WarnURAttr->IsCXX11NoDiscard()) {
2593         WarnE = this;
2594         Loc = getBeginLoc();
2595         R1 = getSourceRange();
2596 
2597         if (unsigned NumArgs = CE->getNumArgs())
2598           R2 = SourceRange(CE->getArg(0)->getBeginLoc(),
2599                            CE->getArg(NumArgs - 1)->getEndLoc());
2600         return true;
2601       }
2602     }
2603 
2604     return false;
2605   }
2606 
2607   case ObjCMessageExprClass: {
2608     const ObjCMessageExpr *ME = cast<ObjCMessageExpr>(this);
2609     if (Ctx.getLangOpts().ObjCAutoRefCount &&
2610         ME->isInstanceMessage() &&
2611         !ME->getType()->isVoidType() &&
2612         ME->getMethodFamily() == OMF_init) {
2613       WarnE = this;
2614       Loc = getExprLoc();
2615       R1 = ME->getSourceRange();
2616       return true;
2617     }
2618 
2619     if (const ObjCMethodDecl *MD = ME->getMethodDecl())
2620       if (MD->hasAttr<WarnUnusedResultAttr>()) {
2621         WarnE = this;
2622         Loc = getExprLoc();
2623         return true;
2624       }
2625 
2626     return false;
2627   }
2628 
2629   case ObjCPropertyRefExprClass:
2630     WarnE = this;
2631     Loc = getExprLoc();
2632     R1 = getSourceRange();
2633     return true;
2634 
2635   case PseudoObjectExprClass: {
2636     const PseudoObjectExpr *PO = cast<PseudoObjectExpr>(this);
2637 
2638     // Only complain about things that have the form of a getter.
2639     if (isa<UnaryOperator>(PO->getSyntacticForm()) ||
2640         isa<BinaryOperator>(PO->getSyntacticForm()))
2641       return false;
2642 
2643     WarnE = this;
2644     Loc = getExprLoc();
2645     R1 = getSourceRange();
2646     return true;
2647   }
2648 
2649   case StmtExprClass: {
2650     // Statement exprs don't logically have side effects themselves, but are
2651     // sometimes used in macros in ways that give them a type that is unused.
2652     // For example ({ blah; foo(); }) will end up with a type if foo has a type.
2653     // however, if the result of the stmt expr is dead, we don't want to emit a
2654     // warning.
2655     const CompoundStmt *CS = cast<StmtExpr>(this)->getSubStmt();
2656     if (!CS->body_empty()) {
2657       if (const Expr *E = dyn_cast<Expr>(CS->body_back()))
2658         return E->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx);
2659       if (const LabelStmt *Label = dyn_cast<LabelStmt>(CS->body_back()))
2660         if (const Expr *E = dyn_cast<Expr>(Label->getSubStmt()))
2661           return E->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx);
2662     }
2663 
2664     if (getType()->isVoidType())
2665       return false;
2666     WarnE = this;
2667     Loc = cast<StmtExpr>(this)->getLParenLoc();
2668     R1 = getSourceRange();
2669     return true;
2670   }
2671   case CXXFunctionalCastExprClass:
2672   case CStyleCastExprClass: {
2673     // Ignore an explicit cast to void unless the operand is a non-trivial
2674     // volatile lvalue.
2675     const CastExpr *CE = cast<CastExpr>(this);
2676     if (CE->getCastKind() == CK_ToVoid) {
2677       if (CE->getSubExpr()->isGLValue() &&
2678           CE->getSubExpr()->getType().isVolatileQualified()) {
2679         const DeclRefExpr *DRE =
2680             dyn_cast<DeclRefExpr>(CE->getSubExpr()->IgnoreParens());
2681         if (!(DRE && isa<VarDecl>(DRE->getDecl()) &&
2682               cast<VarDecl>(DRE->getDecl())->hasLocalStorage()) &&
2683             !isa<CallExpr>(CE->getSubExpr()->IgnoreParens())) {
2684           return CE->getSubExpr()->isUnusedResultAWarning(WarnE, Loc,
2685                                                           R1, R2, Ctx);
2686         }
2687       }
2688       return false;
2689     }
2690 
2691     // If this is a cast to a constructor conversion, check the operand.
2692     // Otherwise, the result of the cast is unused.
2693     if (CE->getCastKind() == CK_ConstructorConversion)
2694       return CE->getSubExpr()->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx);
2695 
2696     WarnE = this;
2697     if (const CXXFunctionalCastExpr *CXXCE =
2698             dyn_cast<CXXFunctionalCastExpr>(this)) {
2699       Loc = CXXCE->getBeginLoc();
2700       R1 = CXXCE->getSubExpr()->getSourceRange();
2701     } else {
2702       const CStyleCastExpr *CStyleCE = cast<CStyleCastExpr>(this);
2703       Loc = CStyleCE->getLParenLoc();
2704       R1 = CStyleCE->getSubExpr()->getSourceRange();
2705     }
2706     return true;
2707   }
2708   case ImplicitCastExprClass: {
2709     const CastExpr *ICE = cast<ImplicitCastExpr>(this);
2710 
2711     // lvalue-to-rvalue conversion on a volatile lvalue is a side-effect.
2712     if (ICE->getCastKind() == CK_LValueToRValue &&
2713         ICE->getSubExpr()->getType().isVolatileQualified())
2714       return false;
2715 
2716     return ICE->getSubExpr()->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx);
2717   }
2718   case CXXDefaultArgExprClass:
2719     return (cast<CXXDefaultArgExpr>(this)
2720             ->getExpr()->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx));
2721   case CXXDefaultInitExprClass:
2722     return (cast<CXXDefaultInitExpr>(this)
2723             ->getExpr()->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx));
2724 
2725   case CXXNewExprClass:
2726     // FIXME: In theory, there might be new expressions that don't have side
2727     // effects (e.g. a placement new with an uninitialized POD).
2728   case CXXDeleteExprClass:
2729     return false;
2730   case MaterializeTemporaryExprClass:
2731     return cast<MaterializeTemporaryExpr>(this)
2732         ->getSubExpr()
2733         ->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx);
2734   case CXXBindTemporaryExprClass:
2735     return cast<CXXBindTemporaryExpr>(this)->getSubExpr()
2736                ->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx);
2737   case ExprWithCleanupsClass:
2738     return cast<ExprWithCleanups>(this)->getSubExpr()
2739                ->isUnusedResultAWarning(WarnE, Loc, R1, R2, Ctx);
2740   }
2741 }
2742 
2743 /// isOBJCGCCandidate - Check if an expression is objc gc'able.
2744 /// returns true, if it is; false otherwise.
2745 bool Expr::isOBJCGCCandidate(ASTContext &Ctx) const {
2746   const Expr *E = IgnoreParens();
2747   switch (E->getStmtClass()) {
2748   default:
2749     return false;
2750   case ObjCIvarRefExprClass:
2751     return true;
2752   case Expr::UnaryOperatorClass:
2753     return cast<UnaryOperator>(E)->getSubExpr()->isOBJCGCCandidate(Ctx);
2754   case ImplicitCastExprClass:
2755     return cast<ImplicitCastExpr>(E)->getSubExpr()->isOBJCGCCandidate(Ctx);
2756   case MaterializeTemporaryExprClass:
2757     return cast<MaterializeTemporaryExpr>(E)->getSubExpr()->isOBJCGCCandidate(
2758         Ctx);
2759   case CStyleCastExprClass:
2760     return cast<CStyleCastExpr>(E)->getSubExpr()->isOBJCGCCandidate(Ctx);
2761   case DeclRefExprClass: {
2762     const Decl *D = cast<DeclRefExpr>(E)->getDecl();
2763 
2764     if (const VarDecl *VD = dyn_cast<VarDecl>(D)) {
2765       if (VD->hasGlobalStorage())
2766         return true;
2767       QualType T = VD->getType();
2768       // dereferencing to a  pointer is always a gc'able candidate,
2769       // unless it is __weak.
2770       return T->isPointerType() &&
2771              (Ctx.getObjCGCAttrKind(T) != Qualifiers::Weak);
2772     }
2773     return false;
2774   }
2775   case MemberExprClass: {
2776     const MemberExpr *M = cast<MemberExpr>(E);
2777     return M->getBase()->isOBJCGCCandidate(Ctx);
2778   }
2779   case ArraySubscriptExprClass:
2780     return cast<ArraySubscriptExpr>(E)->getBase()->isOBJCGCCandidate(Ctx);
2781   }
2782 }
2783 
2784 bool Expr::isBoundMemberFunction(ASTContext &Ctx) const {
2785   if (isTypeDependent())
2786     return false;
2787   return ClassifyLValue(Ctx) == Expr::LV_MemberFunction;
2788 }
2789 
2790 QualType Expr::findBoundMemberType(const Expr *expr) {
2791   assert(expr->hasPlaceholderType(BuiltinType::BoundMember));
2792 
2793   // Bound member expressions are always one of these possibilities:
2794   //   x->m      x.m      x->*y      x.*y
2795   // (possibly parenthesized)
2796 
2797   expr = expr->IgnoreParens();
2798   if (const MemberExpr *mem = dyn_cast<MemberExpr>(expr)) {
2799     assert(isa<CXXMethodDecl>(mem->getMemberDecl()));
2800     return mem->getMemberDecl()->getType();
2801   }
2802 
2803   if (const BinaryOperator *op = dyn_cast<BinaryOperator>(expr)) {
2804     QualType type = op->getRHS()->getType()->castAs<MemberPointerType>()
2805                       ->getPointeeType();
2806     assert(type->isFunctionType());
2807     return type;
2808   }
2809 
2810   assert(isa<UnresolvedMemberExpr>(expr) || isa<CXXPseudoDestructorExpr>(expr));
2811   return QualType();
2812 }
2813 
2814 static Expr *IgnoreImpCastsSingleStep(Expr *E) {
2815   if (auto *ICE = dyn_cast<ImplicitCastExpr>(E))
2816     return ICE->getSubExpr();
2817 
2818   if (auto *FE = dyn_cast<FullExpr>(E))
2819     return FE->getSubExpr();
2820 
2821   return E;
2822 }
2823 
2824 static Expr *IgnoreImpCastsExtraSingleStep(Expr *E) {
2825   // FIXME: Skip MaterializeTemporaryExpr and SubstNonTypeTemplateParmExpr in
2826   // addition to what IgnoreImpCasts() skips to account for the current
2827   // behaviour of IgnoreParenImpCasts().
2828   Expr *SubE = IgnoreImpCastsSingleStep(E);
2829   if (SubE != E)
2830     return SubE;
2831 
2832   if (auto *MTE = dyn_cast<MaterializeTemporaryExpr>(E))
2833     return MTE->getSubExpr();
2834 
2835   if (auto *NTTP = dyn_cast<SubstNonTypeTemplateParmExpr>(E))
2836     return NTTP->getReplacement();
2837 
2838   return E;
2839 }
2840 
2841 static Expr *IgnoreCastsSingleStep(Expr *E) {
2842   if (auto *CE = dyn_cast<CastExpr>(E))
2843     return CE->getSubExpr();
2844 
2845   if (auto *FE = dyn_cast<FullExpr>(E))
2846     return FE->getSubExpr();
2847 
2848   if (auto *MTE = dyn_cast<MaterializeTemporaryExpr>(E))
2849     return MTE->getSubExpr();
2850 
2851   if (auto *NTTP = dyn_cast<SubstNonTypeTemplateParmExpr>(E))
2852     return NTTP->getReplacement();
2853 
2854   return E;
2855 }
2856 
2857 static Expr *IgnoreLValueCastsSingleStep(Expr *E) {
2858   // Skip what IgnoreCastsSingleStep skips, except that only
2859   // lvalue-to-rvalue casts are skipped.
2860   if (auto *CE = dyn_cast<CastExpr>(E))
2861     if (CE->getCastKind() != CK_LValueToRValue)
2862       return E;
2863 
2864   return IgnoreCastsSingleStep(E);
2865 }
2866 
2867 static Expr *IgnoreBaseCastsSingleStep(Expr *E) {
2868   if (auto *CE = dyn_cast<CastExpr>(E))
2869     if (CE->getCastKind() == CK_DerivedToBase ||
2870         CE->getCastKind() == CK_UncheckedDerivedToBase ||
2871         CE->getCastKind() == CK_NoOp)
2872       return CE->getSubExpr();
2873 
2874   return E;
2875 }
2876 
2877 static Expr *IgnoreImplicitSingleStep(Expr *E) {
2878   Expr *SubE = IgnoreImpCastsSingleStep(E);
2879   if (SubE != E)
2880     return SubE;
2881 
2882   if (auto *MTE = dyn_cast<MaterializeTemporaryExpr>(E))
2883     return MTE->getSubExpr();
2884 
2885   if (auto *BTE = dyn_cast<CXXBindTemporaryExpr>(E))
2886     return BTE->getSubExpr();
2887 
2888   return E;
2889 }
2890 
2891 static Expr *IgnoreImplicitAsWrittenSingleStep(Expr *E) {
2892   if (auto *ICE = dyn_cast<ImplicitCastExpr>(E))
2893     return ICE->getSubExprAsWritten();
2894 
2895   return IgnoreImplicitSingleStep(E);
2896 }
2897 
2898 static Expr *IgnoreParensOnlySingleStep(Expr *E) {
2899   if (auto *PE = dyn_cast<ParenExpr>(E))
2900     return PE->getSubExpr();
2901   return E;
2902 }
2903 
2904 static Expr *IgnoreParensSingleStep(Expr *E) {
2905   if (auto *PE = dyn_cast<ParenExpr>(E))
2906     return PE->getSubExpr();
2907 
2908   if (auto *UO = dyn_cast<UnaryOperator>(E)) {
2909     if (UO->getOpcode() == UO_Extension)
2910       return UO->getSubExpr();
2911   }
2912 
2913   else if (auto *GSE = dyn_cast<GenericSelectionExpr>(E)) {
2914     if (!GSE->isResultDependent())
2915       return GSE->getResultExpr();
2916   }
2917 
2918   else if (auto *CE = dyn_cast<ChooseExpr>(E)) {
2919     if (!CE->isConditionDependent())
2920       return CE->getChosenSubExpr();
2921   }
2922 
2923   else if (auto *CE = dyn_cast<ConstantExpr>(E))
2924     return CE->getSubExpr();
2925 
2926   return E;
2927 }
2928 
2929 static Expr *IgnoreNoopCastsSingleStep(const ASTContext &Ctx, Expr *E) {
2930   if (auto *CE = dyn_cast<CastExpr>(E)) {
2931     // We ignore integer <-> casts that are of the same width, ptr<->ptr and
2932     // ptr<->int casts of the same width. We also ignore all identity casts.
2933     Expr *SubExpr = CE->getSubExpr();
2934     bool IsIdentityCast =
2935         Ctx.hasSameUnqualifiedType(E->getType(), SubExpr->getType());
2936     bool IsSameWidthCast =
2937         (E->getType()->isPointerType() || E->getType()->isIntegralType(Ctx)) &&
2938         (SubExpr->getType()->isPointerType() ||
2939          SubExpr->getType()->isIntegralType(Ctx)) &&
2940         (Ctx.getTypeSize(E->getType()) == Ctx.getTypeSize(SubExpr->getType()));
2941 
2942     if (IsIdentityCast || IsSameWidthCast)
2943       return SubExpr;
2944   }
2945 
2946   else if (auto *NTTP = dyn_cast<SubstNonTypeTemplateParmExpr>(E))
2947     return NTTP->getReplacement();
2948 
2949   return E;
2950 }
2951 
2952 static Expr *IgnoreExprNodesImpl(Expr *E) { return E; }
2953 template <typename FnTy, typename... FnTys>
2954 static Expr *IgnoreExprNodesImpl(Expr *E, FnTy &&Fn, FnTys &&... Fns) {
2955   return IgnoreExprNodesImpl(Fn(E), std::forward<FnTys>(Fns)...);
2956 }
2957 
2958 /// Given an expression E and functions Fn_1,...,Fn_n : Expr * -> Expr *,
2959 /// Recursively apply each of the functions to E until reaching a fixed point.
2960 /// Note that a null E is valid; in this case nothing is done.
2961 template <typename... FnTys>
2962 static Expr *IgnoreExprNodes(Expr *E, FnTys &&... Fns) {
2963   Expr *LastE = nullptr;
2964   while (E != LastE) {
2965     LastE = E;
2966     E = IgnoreExprNodesImpl(E, std::forward<FnTys>(Fns)...);
2967   }
2968   return E;
2969 }
2970 
2971 Expr *Expr::IgnoreImpCasts() {
2972   return IgnoreExprNodes(this, IgnoreImpCastsSingleStep);
2973 }
2974 
2975 Expr *Expr::IgnoreCasts() {
2976   return IgnoreExprNodes(this, IgnoreCastsSingleStep);
2977 }
2978 
2979 Expr *Expr::IgnoreImplicit() {
2980   return IgnoreExprNodes(this, IgnoreImplicitSingleStep);
2981 }
2982 
2983 Expr *Expr::IgnoreImplicitAsWritten() {
2984   return IgnoreExprNodes(this, IgnoreImplicitAsWrittenSingleStep);
2985 }
2986 
2987 Expr *Expr::IgnoreParens() {
2988   return IgnoreExprNodes(this, IgnoreParensSingleStep);
2989 }
2990 
2991 Expr *Expr::IgnoreParenImpCasts() {
2992   return IgnoreExprNodes(this, IgnoreParensSingleStep,
2993                          IgnoreImpCastsExtraSingleStep);
2994 }
2995 
2996 Expr *Expr::IgnoreParenCasts() {
2997   return IgnoreExprNodes(this, IgnoreParensSingleStep, IgnoreCastsSingleStep);
2998 }
2999 
3000 Expr *Expr::IgnoreConversionOperator() {
3001   if (auto *MCE = dyn_cast<CXXMemberCallExpr>(this)) {
3002     if (MCE->getMethodDecl() && isa<CXXConversionDecl>(MCE->getMethodDecl()))
3003       return MCE->getImplicitObjectArgument();
3004   }
3005   return this;
3006 }
3007 
3008 Expr *Expr::IgnoreParenLValueCasts() {
3009   return IgnoreExprNodes(this, IgnoreParensSingleStep,
3010                          IgnoreLValueCastsSingleStep);
3011 }
3012 
3013 Expr *Expr::ignoreParenBaseCasts() {
3014   return IgnoreExprNodes(this, IgnoreParensSingleStep,
3015                          IgnoreBaseCastsSingleStep);
3016 }
3017 
3018 Expr *Expr::IgnoreParenNoopCasts(const ASTContext &Ctx) {
3019   return IgnoreExprNodes(this, IgnoreParensSingleStep, [&Ctx](Expr *E) {
3020     return IgnoreNoopCastsSingleStep(Ctx, E);
3021   });
3022 }
3023 
3024 Expr *Expr::IgnoreUnlessSpelledInSource() {
3025   Expr *E = this;
3026 
3027   Expr *LastE = nullptr;
3028   while (E != LastE) {
3029     LastE = E;
3030     E = IgnoreExprNodes(E, IgnoreImplicitSingleStep, IgnoreImpCastsSingleStep,
3031                         IgnoreParensOnlySingleStep);
3032 
3033     auto SR = E->getSourceRange();
3034 
3035     if (auto *C = dyn_cast<CXXConstructExpr>(E)) {
3036       if (C->getNumArgs() == 1) {
3037         Expr *A = C->getArg(0);
3038         if (A->getSourceRange() == SR || !isa<CXXTemporaryObjectExpr>(C))
3039           E = A;
3040       }
3041     }
3042 
3043     if (auto *C = dyn_cast<CXXMemberCallExpr>(E)) {
3044       Expr *ExprNode = C->getImplicitObjectArgument()->IgnoreParenImpCasts();
3045       if (ExprNode->getSourceRange() == SR)
3046         E = ExprNode;
3047     }
3048   }
3049 
3050   return E;
3051 }
3052 
3053 bool Expr::isDefaultArgument() const {
3054   const Expr *E = this;
3055   if (const MaterializeTemporaryExpr *M = dyn_cast<MaterializeTemporaryExpr>(E))
3056     E = M->getSubExpr();
3057 
3058   while (const ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(E))
3059     E = ICE->getSubExprAsWritten();
3060 
3061   return isa<CXXDefaultArgExpr>(E);
3062 }
3063 
3064 /// Skip over any no-op casts and any temporary-binding
3065 /// expressions.
3066 static const Expr *skipTemporaryBindingsNoOpCastsAndParens(const Expr *E) {
3067   if (const MaterializeTemporaryExpr *M = dyn_cast<MaterializeTemporaryExpr>(E))
3068     E = M->getSubExpr();
3069 
3070   while (const ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(E)) {
3071     if (ICE->getCastKind() == CK_NoOp)
3072       E = ICE->getSubExpr();
3073     else
3074       break;
3075   }
3076 
3077   while (const CXXBindTemporaryExpr *BE = dyn_cast<CXXBindTemporaryExpr>(E))
3078     E = BE->getSubExpr();
3079 
3080   while (const ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(E)) {
3081     if (ICE->getCastKind() == CK_NoOp)
3082       E = ICE->getSubExpr();
3083     else
3084       break;
3085   }
3086 
3087   return E->IgnoreParens();
3088 }
3089 
3090 /// isTemporaryObject - Determines if this expression produces a
3091 /// temporary of the given class type.
3092 bool Expr::isTemporaryObject(ASTContext &C, const CXXRecordDecl *TempTy) const {
3093   if (!C.hasSameUnqualifiedType(getType(), C.getTypeDeclType(TempTy)))
3094     return false;
3095 
3096   const Expr *E = skipTemporaryBindingsNoOpCastsAndParens(this);
3097 
3098   // Temporaries are by definition pr-values of class type.
3099   if (!E->Classify(C).isPRValue()) {
3100     // In this context, property reference is a message call and is pr-value.
3101     if (!isa<ObjCPropertyRefExpr>(E))
3102       return false;
3103   }
3104 
3105   // Black-list a few cases which yield pr-values of class type that don't
3106   // refer to temporaries of that type:
3107 
3108   // - implicit derived-to-base conversions
3109   if (isa<ImplicitCastExpr>(E)) {
3110     switch (cast<ImplicitCastExpr>(E)->getCastKind()) {
3111     case CK_DerivedToBase:
3112     case CK_UncheckedDerivedToBase:
3113       return false;
3114     default:
3115       break;
3116     }
3117   }
3118 
3119   // - member expressions (all)
3120   if (isa<MemberExpr>(E))
3121     return false;
3122 
3123   if (const BinaryOperator *BO = dyn_cast<BinaryOperator>(E))
3124     if (BO->isPtrMemOp())
3125       return false;
3126 
3127   // - opaque values (all)
3128   if (isa<OpaqueValueExpr>(E))
3129     return false;
3130 
3131   return true;
3132 }
3133 
3134 bool Expr::isImplicitCXXThis() const {
3135   const Expr *E = this;
3136 
3137   // Strip away parentheses and casts we don't care about.
3138   while (true) {
3139     if (const ParenExpr *Paren = dyn_cast<ParenExpr>(E)) {
3140       E = Paren->getSubExpr();
3141       continue;
3142     }
3143 
3144     if (const ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(E)) {
3145       if (ICE->getCastKind() == CK_NoOp ||
3146           ICE->getCastKind() == CK_LValueToRValue ||
3147           ICE->getCastKind() == CK_DerivedToBase ||
3148           ICE->getCastKind() == CK_UncheckedDerivedToBase) {
3149         E = ICE->getSubExpr();
3150         continue;
3151       }
3152     }
3153 
3154     if (const UnaryOperator* UnOp = dyn_cast<UnaryOperator>(E)) {
3155       if (UnOp->getOpcode() == UO_Extension) {
3156         E = UnOp->getSubExpr();
3157         continue;
3158       }
3159     }
3160 
3161     if (const MaterializeTemporaryExpr *M
3162                                       = dyn_cast<MaterializeTemporaryExpr>(E)) {
3163       E = M->getSubExpr();
3164       continue;
3165     }
3166 
3167     break;
3168   }
3169 
3170   if (const CXXThisExpr *This = dyn_cast<CXXThisExpr>(E))
3171     return This->isImplicit();
3172 
3173   return false;
3174 }
3175 
3176 /// hasAnyTypeDependentArguments - Determines if any of the expressions
3177 /// in Exprs is type-dependent.
3178 bool Expr::hasAnyTypeDependentArguments(ArrayRef<Expr *> Exprs) {
3179   for (unsigned I = 0; I < Exprs.size(); ++I)
3180     if (Exprs[I]->isTypeDependent())
3181       return true;
3182 
3183   return false;
3184 }
3185 
3186 bool Expr::isConstantInitializer(ASTContext &Ctx, bool IsForRef,
3187                                  const Expr **Culprit) const {
3188   assert(!isValueDependent() &&
3189          "Expression evaluator can't be called on a dependent expression.");
3190 
3191   // This function is attempting whether an expression is an initializer
3192   // which can be evaluated at compile-time. It very closely parallels
3193   // ConstExprEmitter in CGExprConstant.cpp; if they don't match, it
3194   // will lead to unexpected results.  Like ConstExprEmitter, it falls back
3195   // to isEvaluatable most of the time.
3196   //
3197   // If we ever capture reference-binding directly in the AST, we can
3198   // kill the second parameter.
3199 
3200   if (IsForRef) {
3201     EvalResult Result;
3202     if (EvaluateAsLValue(Result, Ctx) && !Result.HasSideEffects)
3203       return true;
3204     if (Culprit)
3205       *Culprit = this;
3206     return false;
3207   }
3208 
3209   switch (getStmtClass()) {
3210   default: break;
3211   case StringLiteralClass:
3212   case ObjCEncodeExprClass:
3213     return true;
3214   case CXXTemporaryObjectExprClass:
3215   case CXXConstructExprClass: {
3216     const CXXConstructExpr *CE = cast<CXXConstructExpr>(this);
3217 
3218     if (CE->getConstructor()->isTrivial() &&
3219         CE->getConstructor()->getParent()->hasTrivialDestructor()) {
3220       // Trivial default constructor
3221       if (!CE->getNumArgs()) return true;
3222 
3223       // Trivial copy constructor
3224       assert(CE->getNumArgs() == 1 && "trivial ctor with > 1 argument");
3225       return CE->getArg(0)->isConstantInitializer(Ctx, false, Culprit);
3226     }
3227 
3228     break;
3229   }
3230   case ConstantExprClass: {
3231     // FIXME: We should be able to return "true" here, but it can lead to extra
3232     // error messages. E.g. in Sema/array-init.c.
3233     const Expr *Exp = cast<ConstantExpr>(this)->getSubExpr();
3234     return Exp->isConstantInitializer(Ctx, false, Culprit);
3235   }
3236   case CompoundLiteralExprClass: {
3237     // This handles gcc's extension that allows global initializers like
3238     // "struct x {int x;} x = (struct x) {};".
3239     // FIXME: This accepts other cases it shouldn't!
3240     const Expr *Exp = cast<CompoundLiteralExpr>(this)->getInitializer();
3241     return Exp->isConstantInitializer(Ctx, false, Culprit);
3242   }
3243   case DesignatedInitUpdateExprClass: {
3244     const DesignatedInitUpdateExpr *DIUE = cast<DesignatedInitUpdateExpr>(this);
3245     return DIUE->getBase()->isConstantInitializer(Ctx, false, Culprit) &&
3246            DIUE->getUpdater()->isConstantInitializer(Ctx, false, Culprit);
3247   }
3248   case InitListExprClass: {
3249     const InitListExpr *ILE = cast<InitListExpr>(this);
3250     assert(ILE->isSemanticForm() && "InitListExpr must be in semantic form");
3251     if (ILE->getType()->isArrayType()) {
3252       unsigned numInits = ILE->getNumInits();
3253       for (unsigned i = 0; i < numInits; i++) {
3254         if (!ILE->getInit(i)->isConstantInitializer(Ctx, false, Culprit))
3255           return false;
3256       }
3257       return true;
3258     }
3259 
3260     if (ILE->getType()->isRecordType()) {
3261       unsigned ElementNo = 0;
3262       RecordDecl *RD = ILE->getType()->castAs<RecordType>()->getDecl();
3263       for (const auto *Field : RD->fields()) {
3264         // If this is a union, skip all the fields that aren't being initialized.
3265         if (RD->isUnion() && ILE->getInitializedFieldInUnion() != Field)
3266           continue;
3267 
3268         // Don't emit anonymous bitfields, they just affect layout.
3269         if (Field->isUnnamedBitfield())
3270           continue;
3271 
3272         if (ElementNo < ILE->getNumInits()) {
3273           const Expr *Elt = ILE->getInit(ElementNo++);
3274           if (Field->isBitField()) {
3275             // Bitfields have to evaluate to an integer.
3276             EvalResult Result;
3277             if (!Elt->EvaluateAsInt(Result, Ctx)) {
3278               if (Culprit)
3279                 *Culprit = Elt;
3280               return false;
3281             }
3282           } else {
3283             bool RefType = Field->getType()->isReferenceType();
3284             if (!Elt->isConstantInitializer(Ctx, RefType, Culprit))
3285               return false;
3286           }
3287         }
3288       }
3289       return true;
3290     }
3291 
3292     break;
3293   }
3294   case ImplicitValueInitExprClass:
3295   case NoInitExprClass:
3296     return true;
3297   case ParenExprClass:
3298     return cast<ParenExpr>(this)->getSubExpr()
3299       ->isConstantInitializer(Ctx, IsForRef, Culprit);
3300   case GenericSelectionExprClass:
3301     return cast<GenericSelectionExpr>(this)->getResultExpr()
3302       ->isConstantInitializer(Ctx, IsForRef, Culprit);
3303   case ChooseExprClass:
3304     if (cast<ChooseExpr>(this)->isConditionDependent()) {
3305       if (Culprit)
3306         *Culprit = this;
3307       return false;
3308     }
3309     return cast<ChooseExpr>(this)->getChosenSubExpr()
3310       ->isConstantInitializer(Ctx, IsForRef, Culprit);
3311   case UnaryOperatorClass: {
3312     const UnaryOperator* Exp = cast<UnaryOperator>(this);
3313     if (Exp->getOpcode() == UO_Extension)
3314       return Exp->getSubExpr()->isConstantInitializer(Ctx, false, Culprit);
3315     break;
3316   }
3317   case CXXFunctionalCastExprClass:
3318   case CXXStaticCastExprClass:
3319   case ImplicitCastExprClass:
3320   case CStyleCastExprClass:
3321   case ObjCBridgedCastExprClass:
3322   case CXXDynamicCastExprClass:
3323   case CXXReinterpretCastExprClass:
3324   case CXXConstCastExprClass: {
3325     const CastExpr *CE = cast<CastExpr>(this);
3326 
3327     // Handle misc casts we want to ignore.
3328     if (CE->getCastKind() == CK_NoOp ||
3329         CE->getCastKind() == CK_LValueToRValue ||
3330         CE->getCastKind() == CK_ToUnion ||
3331         CE->getCastKind() == CK_ConstructorConversion ||
3332         CE->getCastKind() == CK_NonAtomicToAtomic ||
3333         CE->getCastKind() == CK_AtomicToNonAtomic ||
3334         CE->getCastKind() == CK_IntToOCLSampler)
3335       return CE->getSubExpr()->isConstantInitializer(Ctx, false, Culprit);
3336 
3337     break;
3338   }
3339   case MaterializeTemporaryExprClass:
3340     return cast<MaterializeTemporaryExpr>(this)
3341         ->getSubExpr()
3342         ->isConstantInitializer(Ctx, false, Culprit);
3343 
3344   case SubstNonTypeTemplateParmExprClass:
3345     return cast<SubstNonTypeTemplateParmExpr>(this)->getReplacement()
3346       ->isConstantInitializer(Ctx, false, Culprit);
3347   case CXXDefaultArgExprClass:
3348     return cast<CXXDefaultArgExpr>(this)->getExpr()
3349       ->isConstantInitializer(Ctx, false, Culprit);
3350   case CXXDefaultInitExprClass:
3351     return cast<CXXDefaultInitExpr>(this)->getExpr()
3352       ->isConstantInitializer(Ctx, false, Culprit);
3353   }
3354   // Allow certain forms of UB in constant initializers: signed integer
3355   // overflow and floating-point division by zero. We'll give a warning on
3356   // these, but they're common enough that we have to accept them.
3357   if (isEvaluatable(Ctx, SE_AllowUndefinedBehavior))
3358     return true;
3359   if (Culprit)
3360     *Culprit = this;
3361   return false;
3362 }
3363 
3364 bool CallExpr::isBuiltinAssumeFalse(const ASTContext &Ctx) const {
3365   const FunctionDecl* FD = getDirectCallee();
3366   if (!FD || (FD->getBuiltinID() != Builtin::BI__assume &&
3367               FD->getBuiltinID() != Builtin::BI__builtin_assume))
3368     return false;
3369 
3370   const Expr* Arg = getArg(0);
3371   bool ArgVal;
3372   return !Arg->isValueDependent() &&
3373          Arg->EvaluateAsBooleanCondition(ArgVal, Ctx) && !ArgVal;
3374 }
3375 
3376 namespace {
3377   /// Look for any side effects within a Stmt.
3378   class SideEffectFinder : public ConstEvaluatedExprVisitor<SideEffectFinder> {
3379     typedef ConstEvaluatedExprVisitor<SideEffectFinder> Inherited;
3380     const bool IncludePossibleEffects;
3381     bool HasSideEffects;
3382 
3383   public:
3384     explicit SideEffectFinder(const ASTContext &Context, bool IncludePossible)
3385       : Inherited(Context),
3386         IncludePossibleEffects(IncludePossible), HasSideEffects(false) { }
3387 
3388     bool hasSideEffects() const { return HasSideEffects; }
3389 
3390     void VisitExpr(const Expr *E) {
3391       if (!HasSideEffects &&
3392           E->HasSideEffects(Context, IncludePossibleEffects))
3393         HasSideEffects = true;
3394     }
3395   };
3396 }
3397 
3398 bool Expr::HasSideEffects(const ASTContext &Ctx,
3399                           bool IncludePossibleEffects) const {
3400   // In circumstances where we care about definite side effects instead of
3401   // potential side effects, we want to ignore expressions that are part of a
3402   // macro expansion as a potential side effect.
3403   if (!IncludePossibleEffects && getExprLoc().isMacroID())
3404     return false;
3405 
3406   if (isInstantiationDependent())
3407     return IncludePossibleEffects;
3408 
3409   switch (getStmtClass()) {
3410   case NoStmtClass:
3411   #define ABSTRACT_STMT(Type)
3412   #define STMT(Type, Base) case Type##Class:
3413   #define EXPR(Type, Base)
3414   #include "clang/AST/StmtNodes.inc"
3415     llvm_unreachable("unexpected Expr kind");
3416 
3417   case DependentScopeDeclRefExprClass:
3418   case CXXUnresolvedConstructExprClass:
3419   case CXXDependentScopeMemberExprClass:
3420   case UnresolvedLookupExprClass:
3421   case UnresolvedMemberExprClass:
3422   case PackExpansionExprClass:
3423   case SubstNonTypeTemplateParmPackExprClass:
3424   case FunctionParmPackExprClass:
3425   case TypoExprClass:
3426   case CXXFoldExprClass:
3427     llvm_unreachable("shouldn't see dependent / unresolved nodes here");
3428 
3429   case DeclRefExprClass:
3430   case ObjCIvarRefExprClass:
3431   case PredefinedExprClass:
3432   case IntegerLiteralClass:
3433   case FixedPointLiteralClass:
3434   case FloatingLiteralClass:
3435   case ImaginaryLiteralClass:
3436   case StringLiteralClass:
3437   case CharacterLiteralClass:
3438   case OffsetOfExprClass:
3439   case ImplicitValueInitExprClass:
3440   case UnaryExprOrTypeTraitExprClass:
3441   case AddrLabelExprClass:
3442   case GNUNullExprClass:
3443   case ArrayInitIndexExprClass:
3444   case NoInitExprClass:
3445   case CXXBoolLiteralExprClass:
3446   case CXXNullPtrLiteralExprClass:
3447   case CXXThisExprClass:
3448   case CXXScalarValueInitExprClass:
3449   case TypeTraitExprClass:
3450   case ArrayTypeTraitExprClass:
3451   case ExpressionTraitExprClass:
3452   case CXXNoexceptExprClass:
3453   case SizeOfPackExprClass:
3454   case ObjCStringLiteralClass:
3455   case ObjCEncodeExprClass:
3456   case ObjCBoolLiteralExprClass:
3457   case ObjCAvailabilityCheckExprClass:
3458   case CXXUuidofExprClass:
3459   case OpaqueValueExprClass:
3460   case SourceLocExprClass:
3461   case ConceptSpecializationExprClass:
3462   case RequiresExprClass:
3463     // These never have a side-effect.
3464     return false;
3465 
3466   case ConstantExprClass:
3467     // FIXME: Move this into the "return false;" block above.
3468     return cast<ConstantExpr>(this)->getSubExpr()->HasSideEffects(
3469         Ctx, IncludePossibleEffects);
3470 
3471   case CallExprClass:
3472   case CXXOperatorCallExprClass:
3473   case CXXMemberCallExprClass:
3474   case CUDAKernelCallExprClass:
3475   case UserDefinedLiteralClass: {
3476     // We don't know a call definitely has side effects, except for calls
3477     // to pure/const functions that definitely don't.
3478     // If the call itself is considered side-effect free, check the operands.
3479     const Decl *FD = cast<CallExpr>(this)->getCalleeDecl();
3480     bool IsPure = FD && (FD->hasAttr<ConstAttr>() || FD->hasAttr<PureAttr>());
3481     if (IsPure || !IncludePossibleEffects)
3482       break;
3483     return true;
3484   }
3485 
3486   case BlockExprClass:
3487   case CXXBindTemporaryExprClass:
3488     if (!IncludePossibleEffects)
3489       break;
3490     return true;
3491 
3492   case MSPropertyRefExprClass:
3493   case MSPropertySubscriptExprClass:
3494   case CompoundAssignOperatorClass:
3495   case VAArgExprClass:
3496   case AtomicExprClass:
3497   case CXXThrowExprClass:
3498   case CXXNewExprClass:
3499   case CXXDeleteExprClass:
3500   case CoawaitExprClass:
3501   case DependentCoawaitExprClass:
3502   case CoyieldExprClass:
3503     // These always have a side-effect.
3504     return true;
3505 
3506   case StmtExprClass: {
3507     // StmtExprs have a side-effect if any substatement does.
3508     SideEffectFinder Finder(Ctx, IncludePossibleEffects);
3509     Finder.Visit(cast<StmtExpr>(this)->getSubStmt());
3510     return Finder.hasSideEffects();
3511   }
3512 
3513   case ExprWithCleanupsClass:
3514     if (IncludePossibleEffects)
3515       if (cast<ExprWithCleanups>(this)->cleanupsHaveSideEffects())
3516         return true;
3517     break;
3518 
3519   case ParenExprClass:
3520   case ArraySubscriptExprClass:
3521   case OMPArraySectionExprClass:
3522   case MemberExprClass:
3523   case ConditionalOperatorClass:
3524   case BinaryConditionalOperatorClass:
3525   case CompoundLiteralExprClass:
3526   case ExtVectorElementExprClass:
3527   case DesignatedInitExprClass:
3528   case DesignatedInitUpdateExprClass:
3529   case ArrayInitLoopExprClass:
3530   case ParenListExprClass:
3531   case CXXPseudoDestructorExprClass:
3532   case CXXRewrittenBinaryOperatorClass:
3533   case CXXStdInitializerListExprClass:
3534   case SubstNonTypeTemplateParmExprClass:
3535   case MaterializeTemporaryExprClass:
3536   case ShuffleVectorExprClass:
3537   case ConvertVectorExprClass:
3538   case AsTypeExprClass:
3539     // These have a side-effect if any subexpression does.
3540     break;
3541 
3542   case UnaryOperatorClass:
3543     if (cast<UnaryOperator>(this)->isIncrementDecrementOp())
3544       return true;
3545     break;
3546 
3547   case BinaryOperatorClass:
3548     if (cast<BinaryOperator>(this)->isAssignmentOp())
3549       return true;
3550     break;
3551 
3552   case InitListExprClass:
3553     // FIXME: The children for an InitListExpr doesn't include the array filler.
3554     if (const Expr *E = cast<InitListExpr>(this)->getArrayFiller())
3555       if (E->HasSideEffects(Ctx, IncludePossibleEffects))
3556         return true;
3557     break;
3558 
3559   case GenericSelectionExprClass:
3560     return cast<GenericSelectionExpr>(this)->getResultExpr()->
3561         HasSideEffects(Ctx, IncludePossibleEffects);
3562 
3563   case ChooseExprClass:
3564     return cast<ChooseExpr>(this)->getChosenSubExpr()->HasSideEffects(
3565         Ctx, IncludePossibleEffects);
3566 
3567   case CXXDefaultArgExprClass:
3568     return cast<CXXDefaultArgExpr>(this)->getExpr()->HasSideEffects(
3569         Ctx, IncludePossibleEffects);
3570 
3571   case CXXDefaultInitExprClass: {
3572     const FieldDecl *FD = cast<CXXDefaultInitExpr>(this)->getField();
3573     if (const Expr *E = FD->getInClassInitializer())
3574       return E->HasSideEffects(Ctx, IncludePossibleEffects);
3575     // If we've not yet parsed the initializer, assume it has side-effects.
3576     return true;
3577   }
3578 
3579   case CXXDynamicCastExprClass: {
3580     // A dynamic_cast expression has side-effects if it can throw.
3581     const CXXDynamicCastExpr *DCE = cast<CXXDynamicCastExpr>(this);
3582     if (DCE->getTypeAsWritten()->isReferenceType() &&
3583         DCE->getCastKind() == CK_Dynamic)
3584       return true;
3585     }
3586     LLVM_FALLTHROUGH;
3587   case ImplicitCastExprClass:
3588   case CStyleCastExprClass:
3589   case CXXStaticCastExprClass:
3590   case CXXReinterpretCastExprClass:
3591   case CXXConstCastExprClass:
3592   case CXXFunctionalCastExprClass:
3593   case BuiltinBitCastExprClass: {
3594     // While volatile reads are side-effecting in both C and C++, we treat them
3595     // as having possible (not definite) side-effects. This allows idiomatic
3596     // code to behave without warning, such as sizeof(*v) for a volatile-
3597     // qualified pointer.
3598     if (!IncludePossibleEffects)
3599       break;
3600 
3601     const CastExpr *CE = cast<CastExpr>(this);
3602     if (CE->getCastKind() == CK_LValueToRValue &&
3603         CE->getSubExpr()->getType().isVolatileQualified())
3604       return true;
3605     break;
3606   }
3607 
3608   case CXXTypeidExprClass:
3609     // typeid might throw if its subexpression is potentially-evaluated, so has
3610     // side-effects in that case whether or not its subexpression does.
3611     return cast<CXXTypeidExpr>(this)->isPotentiallyEvaluated();
3612 
3613   case CXXConstructExprClass:
3614   case CXXTemporaryObjectExprClass: {
3615     const CXXConstructExpr *CE = cast<CXXConstructExpr>(this);
3616     if (!CE->getConstructor()->isTrivial() && IncludePossibleEffects)
3617       return true;
3618     // A trivial constructor does not add any side-effects of its own. Just look
3619     // at its arguments.
3620     break;
3621   }
3622 
3623   case CXXInheritedCtorInitExprClass: {
3624     const auto *ICIE = cast<CXXInheritedCtorInitExpr>(this);
3625     if (!ICIE->getConstructor()->isTrivial() && IncludePossibleEffects)
3626       return true;
3627     break;
3628   }
3629 
3630   case LambdaExprClass: {
3631     const LambdaExpr *LE = cast<LambdaExpr>(this);
3632     for (Expr *E : LE->capture_inits())
3633       if (E->HasSideEffects(Ctx, IncludePossibleEffects))
3634         return true;
3635     return false;
3636   }
3637 
3638   case PseudoObjectExprClass: {
3639     // Only look for side-effects in the semantic form, and look past
3640     // OpaqueValueExpr bindings in that form.
3641     const PseudoObjectExpr *PO = cast<PseudoObjectExpr>(this);
3642     for (PseudoObjectExpr::const_semantics_iterator I = PO->semantics_begin(),
3643                                                     E = PO->semantics_end();
3644          I != E; ++I) {
3645       const Expr *Subexpr = *I;
3646       if (const OpaqueValueExpr *OVE = dyn_cast<OpaqueValueExpr>(Subexpr))
3647         Subexpr = OVE->getSourceExpr();
3648       if (Subexpr->HasSideEffects(Ctx, IncludePossibleEffects))
3649         return true;
3650     }
3651     return false;
3652   }
3653 
3654   case ObjCBoxedExprClass:
3655   case ObjCArrayLiteralClass:
3656   case ObjCDictionaryLiteralClass:
3657   case ObjCSelectorExprClass:
3658   case ObjCProtocolExprClass:
3659   case ObjCIsaExprClass:
3660   case ObjCIndirectCopyRestoreExprClass:
3661   case ObjCSubscriptRefExprClass:
3662   case ObjCBridgedCastExprClass:
3663   case ObjCMessageExprClass:
3664   case ObjCPropertyRefExprClass:
3665   // FIXME: Classify these cases better.
3666     if (IncludePossibleEffects)
3667       return true;
3668     break;
3669   }
3670 
3671   // Recurse to children.
3672   for (const Stmt *SubStmt : children())
3673     if (SubStmt &&
3674         cast<Expr>(SubStmt)->HasSideEffects(Ctx, IncludePossibleEffects))
3675       return true;
3676 
3677   return false;
3678 }
3679 
3680 namespace {
3681   /// Look for a call to a non-trivial function within an expression.
3682   class NonTrivialCallFinder : public ConstEvaluatedExprVisitor<NonTrivialCallFinder>
3683   {
3684     typedef ConstEvaluatedExprVisitor<NonTrivialCallFinder> Inherited;
3685 
3686     bool NonTrivial;
3687 
3688   public:
3689     explicit NonTrivialCallFinder(const ASTContext &Context)
3690       : Inherited(Context), NonTrivial(false) { }
3691 
3692     bool hasNonTrivialCall() const { return NonTrivial; }
3693 
3694     void VisitCallExpr(const CallExpr *E) {
3695       if (const CXXMethodDecl *Method
3696           = dyn_cast_or_null<const CXXMethodDecl>(E->getCalleeDecl())) {
3697         if (Method->isTrivial()) {
3698           // Recurse to children of the call.
3699           Inherited::VisitStmt(E);
3700           return;
3701         }
3702       }
3703 
3704       NonTrivial = true;
3705     }
3706 
3707     void VisitCXXConstructExpr(const CXXConstructExpr *E) {
3708       if (E->getConstructor()->isTrivial()) {
3709         // Recurse to children of the call.
3710         Inherited::VisitStmt(E);
3711         return;
3712       }
3713 
3714       NonTrivial = true;
3715     }
3716 
3717     void VisitCXXBindTemporaryExpr(const CXXBindTemporaryExpr *E) {
3718       if (E->getTemporary()->getDestructor()->isTrivial()) {
3719         Inherited::VisitStmt(E);
3720         return;
3721       }
3722 
3723       NonTrivial = true;
3724     }
3725   };
3726 }
3727 
3728 bool Expr::hasNonTrivialCall(const ASTContext &Ctx) const {
3729   NonTrivialCallFinder Finder(Ctx);
3730   Finder.Visit(this);
3731   return Finder.hasNonTrivialCall();
3732 }
3733 
3734 /// isNullPointerConstant - C99 6.3.2.3p3 - Return whether this is a null
3735 /// pointer constant or not, as well as the specific kind of constant detected.
3736 /// Null pointer constants can be integer constant expressions with the
3737 /// value zero, casts of zero to void*, nullptr (C++0X), or __null
3738 /// (a GNU extension).
3739 Expr::NullPointerConstantKind
3740 Expr::isNullPointerConstant(ASTContext &Ctx,
3741                             NullPointerConstantValueDependence NPC) const {
3742   if (isValueDependent() &&
3743       (!Ctx.getLangOpts().CPlusPlus11 || Ctx.getLangOpts().MSVCCompat)) {
3744     switch (NPC) {
3745     case NPC_NeverValueDependent:
3746       llvm_unreachable("Unexpected value dependent expression!");
3747     case NPC_ValueDependentIsNull:
3748       if (isTypeDependent() || getType()->isIntegralType(Ctx))
3749         return NPCK_ZeroExpression;
3750       else
3751         return NPCK_NotNull;
3752 
3753     case NPC_ValueDependentIsNotNull:
3754       return NPCK_NotNull;
3755     }
3756   }
3757 
3758   // Strip off a cast to void*, if it exists. Except in C++.
3759   if (const ExplicitCastExpr *CE = dyn_cast<ExplicitCastExpr>(this)) {
3760     if (!Ctx.getLangOpts().CPlusPlus) {
3761       // Check that it is a cast to void*.
3762       if (const PointerType *PT = CE->getType()->getAs<PointerType>()) {
3763         QualType Pointee = PT->getPointeeType();
3764         Qualifiers Qs = Pointee.getQualifiers();
3765         // Only (void*)0 or equivalent are treated as nullptr. If pointee type
3766         // has non-default address space it is not treated as nullptr.
3767         // (__generic void*)0 in OpenCL 2.0 should not be treated as nullptr
3768         // since it cannot be assigned to a pointer to constant address space.
3769         if ((Ctx.getLangOpts().OpenCLVersion >= 200 &&
3770              Pointee.getAddressSpace() == LangAS::opencl_generic) ||
3771             (Ctx.getLangOpts().OpenCL &&
3772              Ctx.getLangOpts().OpenCLVersion < 200 &&
3773              Pointee.getAddressSpace() == LangAS::opencl_private))
3774           Qs.removeAddressSpace();
3775 
3776         if (Pointee->isVoidType() && Qs.empty() && // to void*
3777             CE->getSubExpr()->getType()->isIntegerType()) // from int
3778           return CE->getSubExpr()->isNullPointerConstant(Ctx, NPC);
3779       }
3780     }
3781   } else if (const ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(this)) {
3782     // Ignore the ImplicitCastExpr type entirely.
3783     return ICE->getSubExpr()->isNullPointerConstant(Ctx, NPC);
3784   } else if (const ParenExpr *PE = dyn_cast<ParenExpr>(this)) {
3785     // Accept ((void*)0) as a null pointer constant, as many other
3786     // implementations do.
3787     return PE->getSubExpr()->isNullPointerConstant(Ctx, NPC);
3788   } else if (const GenericSelectionExpr *GE =
3789                dyn_cast<GenericSelectionExpr>(this)) {
3790     if (GE->isResultDependent())
3791       return NPCK_NotNull;
3792     return GE->getResultExpr()->isNullPointerConstant(Ctx, NPC);
3793   } else if (const ChooseExpr *CE = dyn_cast<ChooseExpr>(this)) {
3794     if (CE->isConditionDependent())
3795       return NPCK_NotNull;
3796     return CE->getChosenSubExpr()->isNullPointerConstant(Ctx, NPC);
3797   } else if (const CXXDefaultArgExpr *DefaultArg
3798                = dyn_cast<CXXDefaultArgExpr>(this)) {
3799     // See through default argument expressions.
3800     return DefaultArg->getExpr()->isNullPointerConstant(Ctx, NPC);
3801   } else if (const CXXDefaultInitExpr *DefaultInit
3802                = dyn_cast<CXXDefaultInitExpr>(this)) {
3803     // See through default initializer expressions.
3804     return DefaultInit->getExpr()->isNullPointerConstant(Ctx, NPC);
3805   } else if (isa<GNUNullExpr>(this)) {
3806     // The GNU __null extension is always a null pointer constant.
3807     return NPCK_GNUNull;
3808   } else if (const MaterializeTemporaryExpr *M
3809                                    = dyn_cast<MaterializeTemporaryExpr>(this)) {
3810     return M->getSubExpr()->isNullPointerConstant(Ctx, NPC);
3811   } else if (const OpaqueValueExpr *OVE = dyn_cast<OpaqueValueExpr>(this)) {
3812     if (const Expr *Source = OVE->getSourceExpr())
3813       return Source->isNullPointerConstant(Ctx, NPC);
3814   }
3815 
3816   // C++11 nullptr_t is always a null pointer constant.
3817   if (getType()->isNullPtrType())
3818     return NPCK_CXX11_nullptr;
3819 
3820   if (const RecordType *UT = getType()->getAsUnionType())
3821     if (!Ctx.getLangOpts().CPlusPlus11 &&
3822         UT && UT->getDecl()->hasAttr<TransparentUnionAttr>())
3823       if (const CompoundLiteralExpr *CLE = dyn_cast<CompoundLiteralExpr>(this)){
3824         const Expr *InitExpr = CLE->getInitializer();
3825         if (const InitListExpr *ILE = dyn_cast<InitListExpr>(InitExpr))
3826           return ILE->getInit(0)->isNullPointerConstant(Ctx, NPC);
3827       }
3828   // This expression must be an integer type.
3829   if (!getType()->isIntegerType() ||
3830       (Ctx.getLangOpts().CPlusPlus && getType()->isEnumeralType()))
3831     return NPCK_NotNull;
3832 
3833   if (Ctx.getLangOpts().CPlusPlus11) {
3834     // C++11 [conv.ptr]p1: A null pointer constant is an integer literal with
3835     // value zero or a prvalue of type std::nullptr_t.
3836     // Microsoft mode permits C++98 rules reflecting MSVC behavior.
3837     const IntegerLiteral *Lit = dyn_cast<IntegerLiteral>(this);
3838     if (Lit && !Lit->getValue())
3839       return NPCK_ZeroLiteral;
3840     else if (!Ctx.getLangOpts().MSVCCompat || !isCXX98IntegralConstantExpr(Ctx))
3841       return NPCK_NotNull;
3842   } else {
3843     // If we have an integer constant expression, we need to *evaluate* it and
3844     // test for the value 0.
3845     if (!isIntegerConstantExpr(Ctx))
3846       return NPCK_NotNull;
3847   }
3848 
3849   if (EvaluateKnownConstInt(Ctx) != 0)
3850     return NPCK_NotNull;
3851 
3852   if (isa<IntegerLiteral>(this))
3853     return NPCK_ZeroLiteral;
3854   return NPCK_ZeroExpression;
3855 }
3856 
3857 /// If this expression is an l-value for an Objective C
3858 /// property, find the underlying property reference expression.
3859 const ObjCPropertyRefExpr *Expr::getObjCProperty() const {
3860   const Expr *E = this;
3861   while (true) {
3862     assert((E->getValueKind() == VK_LValue &&
3863             E->getObjectKind() == OK_ObjCProperty) &&
3864            "expression is not a property reference");
3865     E = E->IgnoreParenCasts();
3866     if (const BinaryOperator *BO = dyn_cast<BinaryOperator>(E)) {
3867       if (BO->getOpcode() == BO_Comma) {
3868         E = BO->getRHS();
3869         continue;
3870       }
3871     }
3872 
3873     break;
3874   }
3875 
3876   return cast<ObjCPropertyRefExpr>(E);
3877 }
3878 
3879 bool Expr::isObjCSelfExpr() const {
3880   const Expr *E = IgnoreParenImpCasts();
3881 
3882   const DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E);
3883   if (!DRE)
3884     return false;
3885 
3886   const ImplicitParamDecl *Param = dyn_cast<ImplicitParamDecl>(DRE->getDecl());
3887   if (!Param)
3888     return false;
3889 
3890   const ObjCMethodDecl *M = dyn_cast<ObjCMethodDecl>(Param->getDeclContext());
3891   if (!M)
3892     return false;
3893 
3894   return M->getSelfDecl() == Param;
3895 }
3896 
3897 FieldDecl *Expr::getSourceBitField() {
3898   Expr *E = this->IgnoreParens();
3899 
3900   while (ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(E)) {
3901     if (ICE->getCastKind() == CK_LValueToRValue ||
3902         (ICE->getValueKind() != VK_RValue && ICE->getCastKind() == CK_NoOp))
3903       E = ICE->getSubExpr()->IgnoreParens();
3904     else
3905       break;
3906   }
3907 
3908   if (MemberExpr *MemRef = dyn_cast<MemberExpr>(E))
3909     if (FieldDecl *Field = dyn_cast<FieldDecl>(MemRef->getMemberDecl()))
3910       if (Field->isBitField())
3911         return Field;
3912 
3913   if (ObjCIvarRefExpr *IvarRef = dyn_cast<ObjCIvarRefExpr>(E)) {
3914     FieldDecl *Ivar = IvarRef->getDecl();
3915     if (Ivar->isBitField())
3916       return Ivar;
3917   }
3918 
3919   if (DeclRefExpr *DeclRef = dyn_cast<DeclRefExpr>(E)) {
3920     if (FieldDecl *Field = dyn_cast<FieldDecl>(DeclRef->getDecl()))
3921       if (Field->isBitField())
3922         return Field;
3923 
3924     if (BindingDecl *BD = dyn_cast<BindingDecl>(DeclRef->getDecl()))
3925       if (Expr *E = BD->getBinding())
3926         return E->getSourceBitField();
3927   }
3928 
3929   if (BinaryOperator *BinOp = dyn_cast<BinaryOperator>(E)) {
3930     if (BinOp->isAssignmentOp() && BinOp->getLHS())
3931       return BinOp->getLHS()->getSourceBitField();
3932 
3933     if (BinOp->getOpcode() == BO_Comma && BinOp->getRHS())
3934       return BinOp->getRHS()->getSourceBitField();
3935   }
3936 
3937   if (UnaryOperator *UnOp = dyn_cast<UnaryOperator>(E))
3938     if (UnOp->isPrefix() && UnOp->isIncrementDecrementOp())
3939       return UnOp->getSubExpr()->getSourceBitField();
3940 
3941   return nullptr;
3942 }
3943 
3944 bool Expr::refersToVectorElement() const {
3945   // FIXME: Why do we not just look at the ObjectKind here?
3946   const Expr *E = this->IgnoreParens();
3947 
3948   while (const ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(E)) {
3949     if (ICE->getValueKind() != VK_RValue &&
3950         ICE->getCastKind() == CK_NoOp)
3951       E = ICE->getSubExpr()->IgnoreParens();
3952     else
3953       break;
3954   }
3955 
3956   if (const ArraySubscriptExpr *ASE = dyn_cast<ArraySubscriptExpr>(E))
3957     return ASE->getBase()->getType()->isVectorType();
3958 
3959   if (isa<ExtVectorElementExpr>(E))
3960     return true;
3961 
3962   if (auto *DRE = dyn_cast<DeclRefExpr>(E))
3963     if (auto *BD = dyn_cast<BindingDecl>(DRE->getDecl()))
3964       if (auto *E = BD->getBinding())
3965         return E->refersToVectorElement();
3966 
3967   return false;
3968 }
3969 
3970 bool Expr::refersToGlobalRegisterVar() const {
3971   const Expr *E = this->IgnoreParenImpCasts();
3972 
3973   if (const DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E))
3974     if (const auto *VD = dyn_cast<VarDecl>(DRE->getDecl()))
3975       if (VD->getStorageClass() == SC_Register &&
3976           VD->hasAttr<AsmLabelAttr>() && !VD->isLocalVarDecl())
3977         return true;
3978 
3979   return false;
3980 }
3981 
3982 bool Expr::isSameComparisonOperand(const Expr* E1, const Expr* E2) {
3983   E1 = E1->IgnoreParens();
3984   E2 = E2->IgnoreParens();
3985 
3986   if (E1->getStmtClass() != E2->getStmtClass())
3987     return false;
3988 
3989   switch (E1->getStmtClass()) {
3990     default:
3991       return false;
3992     case CXXThisExprClass:
3993       return true;
3994     case DeclRefExprClass: {
3995       // DeclRefExpr without an ImplicitCastExpr can happen for integral
3996       // template parameters.
3997       const auto *DRE1 = cast<DeclRefExpr>(E1);
3998       const auto *DRE2 = cast<DeclRefExpr>(E2);
3999       return DRE1->isRValue() && DRE2->isRValue() &&
4000              DRE1->getDecl() == DRE2->getDecl();
4001     }
4002     case ImplicitCastExprClass: {
4003       // Peel off implicit casts.
4004       while (true) {
4005         const auto *ICE1 = dyn_cast<ImplicitCastExpr>(E1);
4006         const auto *ICE2 = dyn_cast<ImplicitCastExpr>(E2);
4007         if (!ICE1 || !ICE2)
4008           return false;
4009         if (ICE1->getCastKind() != ICE2->getCastKind())
4010           return false;
4011         E1 = ICE1->getSubExpr()->IgnoreParens();
4012         E2 = ICE2->getSubExpr()->IgnoreParens();
4013         // The final cast must be one of these types.
4014         if (ICE1->getCastKind() == CK_LValueToRValue ||
4015             ICE1->getCastKind() == CK_ArrayToPointerDecay ||
4016             ICE1->getCastKind() == CK_FunctionToPointerDecay) {
4017           break;
4018         }
4019       }
4020 
4021       const auto *DRE1 = dyn_cast<DeclRefExpr>(E1);
4022       const auto *DRE2 = dyn_cast<DeclRefExpr>(E2);
4023       if (DRE1 && DRE2)
4024         return declaresSameEntity(DRE1->getDecl(), DRE2->getDecl());
4025 
4026       const auto *Ivar1 = dyn_cast<ObjCIvarRefExpr>(E1);
4027       const auto *Ivar2 = dyn_cast<ObjCIvarRefExpr>(E2);
4028       if (Ivar1 && Ivar2) {
4029         return Ivar1->isFreeIvar() && Ivar2->isFreeIvar() &&
4030                declaresSameEntity(Ivar1->getDecl(), Ivar2->getDecl());
4031       }
4032 
4033       const auto *Array1 = dyn_cast<ArraySubscriptExpr>(E1);
4034       const auto *Array2 = dyn_cast<ArraySubscriptExpr>(E2);
4035       if (Array1 && Array2) {
4036         if (!isSameComparisonOperand(Array1->getBase(), Array2->getBase()))
4037           return false;
4038 
4039         auto Idx1 = Array1->getIdx();
4040         auto Idx2 = Array2->getIdx();
4041         const auto Integer1 = dyn_cast<IntegerLiteral>(Idx1);
4042         const auto Integer2 = dyn_cast<IntegerLiteral>(Idx2);
4043         if (Integer1 && Integer2) {
4044           if (!llvm::APInt::isSameValue(Integer1->getValue(),
4045                                         Integer2->getValue()))
4046             return false;
4047         } else {
4048           if (!isSameComparisonOperand(Idx1, Idx2))
4049             return false;
4050         }
4051 
4052         return true;
4053       }
4054 
4055       // Walk the MemberExpr chain.
4056       while (isa<MemberExpr>(E1) && isa<MemberExpr>(E2)) {
4057         const auto *ME1 = cast<MemberExpr>(E1);
4058         const auto *ME2 = cast<MemberExpr>(E2);
4059         if (!declaresSameEntity(ME1->getMemberDecl(), ME2->getMemberDecl()))
4060           return false;
4061         if (const auto *D = dyn_cast<VarDecl>(ME1->getMemberDecl()))
4062           if (D->isStaticDataMember())
4063             return true;
4064         E1 = ME1->getBase()->IgnoreParenImpCasts();
4065         E2 = ME2->getBase()->IgnoreParenImpCasts();
4066       }
4067 
4068       if (isa<CXXThisExpr>(E1) && isa<CXXThisExpr>(E2))
4069         return true;
4070 
4071       // A static member variable can end the MemberExpr chain with either
4072       // a MemberExpr or a DeclRefExpr.
4073       auto getAnyDecl = [](const Expr *E) -> const ValueDecl * {
4074         if (const auto *DRE = dyn_cast<DeclRefExpr>(E))
4075           return DRE->getDecl();
4076         if (const auto *ME = dyn_cast<MemberExpr>(E))
4077           return ME->getMemberDecl();
4078         return nullptr;
4079       };
4080 
4081       const ValueDecl *VD1 = getAnyDecl(E1);
4082       const ValueDecl *VD2 = getAnyDecl(E2);
4083       return declaresSameEntity(VD1, VD2);
4084     }
4085   }
4086 }
4087 
4088 /// isArrow - Return true if the base expression is a pointer to vector,
4089 /// return false if the base expression is a vector.
4090 bool ExtVectorElementExpr::isArrow() const {
4091   return getBase()->getType()->isPointerType();
4092 }
4093 
4094 unsigned ExtVectorElementExpr::getNumElements() const {
4095   if (const VectorType *VT = getType()->getAs<VectorType>())
4096     return VT->getNumElements();
4097   return 1;
4098 }
4099 
4100 /// containsDuplicateElements - Return true if any element access is repeated.
4101 bool ExtVectorElementExpr::containsDuplicateElements() const {
4102   // FIXME: Refactor this code to an accessor on the AST node which returns the
4103   // "type" of component access, and share with code below and in Sema.
4104   StringRef Comp = Accessor->getName();
4105 
4106   // Halving swizzles do not contain duplicate elements.
4107   if (Comp == "hi" || Comp == "lo" || Comp == "even" || Comp == "odd")
4108     return false;
4109 
4110   // Advance past s-char prefix on hex swizzles.
4111   if (Comp[0] == 's' || Comp[0] == 'S')
4112     Comp = Comp.substr(1);
4113 
4114   for (unsigned i = 0, e = Comp.size(); i != e; ++i)
4115     if (Comp.substr(i + 1).find(Comp[i]) != StringRef::npos)
4116         return true;
4117 
4118   return false;
4119 }
4120 
4121 /// getEncodedElementAccess - We encode the fields as a llvm ConstantArray.
4122 void ExtVectorElementExpr::getEncodedElementAccess(
4123     SmallVectorImpl<uint32_t> &Elts) const {
4124   StringRef Comp = Accessor->getName();
4125   bool isNumericAccessor = false;
4126   if (Comp[0] == 's' || Comp[0] == 'S') {
4127     Comp = Comp.substr(1);
4128     isNumericAccessor = true;
4129   }
4130 
4131   bool isHi =   Comp == "hi";
4132   bool isLo =   Comp == "lo";
4133   bool isEven = Comp == "even";
4134   bool isOdd  = Comp == "odd";
4135 
4136   for (unsigned i = 0, e = getNumElements(); i != e; ++i) {
4137     uint64_t Index;
4138 
4139     if (isHi)
4140       Index = e + i;
4141     else if (isLo)
4142       Index = i;
4143     else if (isEven)
4144       Index = 2 * i;
4145     else if (isOdd)
4146       Index = 2 * i + 1;
4147     else
4148       Index = ExtVectorType::getAccessorIdx(Comp[i], isNumericAccessor);
4149 
4150     Elts.push_back(Index);
4151   }
4152 }
4153 
4154 ShuffleVectorExpr::ShuffleVectorExpr(const ASTContext &C, ArrayRef<Expr*> args,
4155                                      QualType Type, SourceLocation BLoc,
4156                                      SourceLocation RP)
4157    : Expr(ShuffleVectorExprClass, Type, VK_RValue, OK_Ordinary,
4158           Type->isDependentType(), Type->isDependentType(),
4159           Type->isInstantiationDependentType(),
4160           Type->containsUnexpandedParameterPack()),
4161      BuiltinLoc(BLoc), RParenLoc(RP), NumExprs(args.size())
4162 {
4163   SubExprs = new (C) Stmt*[args.size()];
4164   for (unsigned i = 0; i != args.size(); i++) {
4165     if (args[i]->isTypeDependent())
4166       ExprBits.TypeDependent = true;
4167     if (args[i]->isValueDependent())
4168       ExprBits.ValueDependent = true;
4169     if (args[i]->isInstantiationDependent())
4170       ExprBits.InstantiationDependent = true;
4171     if (args[i]->containsUnexpandedParameterPack())
4172       ExprBits.ContainsUnexpandedParameterPack = true;
4173 
4174     SubExprs[i] = args[i];
4175   }
4176 }
4177 
4178 void ShuffleVectorExpr::setExprs(const ASTContext &C, ArrayRef<Expr *> Exprs) {
4179   if (SubExprs) C.Deallocate(SubExprs);
4180 
4181   this->NumExprs = Exprs.size();
4182   SubExprs = new (C) Stmt*[NumExprs];
4183   memcpy(SubExprs, Exprs.data(), sizeof(Expr *) * Exprs.size());
4184 }
4185 
4186 GenericSelectionExpr::GenericSelectionExpr(
4187     const ASTContext &, SourceLocation GenericLoc, Expr *ControllingExpr,
4188     ArrayRef<TypeSourceInfo *> AssocTypes, ArrayRef<Expr *> AssocExprs,
4189     SourceLocation DefaultLoc, SourceLocation RParenLoc,
4190     bool ContainsUnexpandedParameterPack, unsigned ResultIndex)
4191     : Expr(GenericSelectionExprClass, AssocExprs[ResultIndex]->getType(),
4192            AssocExprs[ResultIndex]->getValueKind(),
4193            AssocExprs[ResultIndex]->getObjectKind(),
4194            AssocExprs[ResultIndex]->isTypeDependent(),
4195            AssocExprs[ResultIndex]->isValueDependent(),
4196            AssocExprs[ResultIndex]->isInstantiationDependent(),
4197            ContainsUnexpandedParameterPack),
4198       NumAssocs(AssocExprs.size()), ResultIndex(ResultIndex),
4199       DefaultLoc(DefaultLoc), RParenLoc(RParenLoc) {
4200   assert(AssocTypes.size() == AssocExprs.size() &&
4201          "Must have the same number of association expressions"
4202          " and TypeSourceInfo!");
4203   assert(ResultIndex < NumAssocs && "ResultIndex is out-of-bounds!");
4204 
4205   GenericSelectionExprBits.GenericLoc = GenericLoc;
4206   getTrailingObjects<Stmt *>()[ControllingIndex] = ControllingExpr;
4207   std::copy(AssocExprs.begin(), AssocExprs.end(),
4208             getTrailingObjects<Stmt *>() + AssocExprStartIndex);
4209   std::copy(AssocTypes.begin(), AssocTypes.end(),
4210             getTrailingObjects<TypeSourceInfo *>());
4211 }
4212 
4213 GenericSelectionExpr::GenericSelectionExpr(
4214     const ASTContext &Context, SourceLocation GenericLoc, Expr *ControllingExpr,
4215     ArrayRef<TypeSourceInfo *> AssocTypes, ArrayRef<Expr *> AssocExprs,
4216     SourceLocation DefaultLoc, SourceLocation RParenLoc,
4217     bool ContainsUnexpandedParameterPack)
4218     : Expr(GenericSelectionExprClass, Context.DependentTy, VK_RValue,
4219            OK_Ordinary,
4220            /*isTypeDependent=*/true,
4221            /*isValueDependent=*/true,
4222            /*isInstantiationDependent=*/true, ContainsUnexpandedParameterPack),
4223       NumAssocs(AssocExprs.size()), ResultIndex(ResultDependentIndex),
4224       DefaultLoc(DefaultLoc), RParenLoc(RParenLoc) {
4225   assert(AssocTypes.size() == AssocExprs.size() &&
4226          "Must have the same number of association expressions"
4227          " and TypeSourceInfo!");
4228 
4229   GenericSelectionExprBits.GenericLoc = GenericLoc;
4230   getTrailingObjects<Stmt *>()[ControllingIndex] = ControllingExpr;
4231   std::copy(AssocExprs.begin(), AssocExprs.end(),
4232             getTrailingObjects<Stmt *>() + AssocExprStartIndex);
4233   std::copy(AssocTypes.begin(), AssocTypes.end(),
4234             getTrailingObjects<TypeSourceInfo *>());
4235 }
4236 
4237 GenericSelectionExpr::GenericSelectionExpr(EmptyShell Empty, unsigned NumAssocs)
4238     : Expr(GenericSelectionExprClass, Empty), NumAssocs(NumAssocs) {}
4239 
4240 GenericSelectionExpr *GenericSelectionExpr::Create(
4241     const ASTContext &Context, SourceLocation GenericLoc, Expr *ControllingExpr,
4242     ArrayRef<TypeSourceInfo *> AssocTypes, ArrayRef<Expr *> AssocExprs,
4243     SourceLocation DefaultLoc, SourceLocation RParenLoc,
4244     bool ContainsUnexpandedParameterPack, unsigned ResultIndex) {
4245   unsigned NumAssocs = AssocExprs.size();
4246   void *Mem = Context.Allocate(
4247       totalSizeToAlloc<Stmt *, TypeSourceInfo *>(1 + NumAssocs, NumAssocs),
4248       alignof(GenericSelectionExpr));
4249   return new (Mem) GenericSelectionExpr(
4250       Context, GenericLoc, ControllingExpr, AssocTypes, AssocExprs, DefaultLoc,
4251       RParenLoc, ContainsUnexpandedParameterPack, ResultIndex);
4252 }
4253 
4254 GenericSelectionExpr *GenericSelectionExpr::Create(
4255     const ASTContext &Context, SourceLocation GenericLoc, Expr *ControllingExpr,
4256     ArrayRef<TypeSourceInfo *> AssocTypes, ArrayRef<Expr *> AssocExprs,
4257     SourceLocation DefaultLoc, SourceLocation RParenLoc,
4258     bool ContainsUnexpandedParameterPack) {
4259   unsigned NumAssocs = AssocExprs.size();
4260   void *Mem = Context.Allocate(
4261       totalSizeToAlloc<Stmt *, TypeSourceInfo *>(1 + NumAssocs, NumAssocs),
4262       alignof(GenericSelectionExpr));
4263   return new (Mem) GenericSelectionExpr(
4264       Context, GenericLoc, ControllingExpr, AssocTypes, AssocExprs, DefaultLoc,
4265       RParenLoc, ContainsUnexpandedParameterPack);
4266 }
4267 
4268 GenericSelectionExpr *
4269 GenericSelectionExpr::CreateEmpty(const ASTContext &Context,
4270                                   unsigned NumAssocs) {
4271   void *Mem = Context.Allocate(
4272       totalSizeToAlloc<Stmt *, TypeSourceInfo *>(1 + NumAssocs, NumAssocs),
4273       alignof(GenericSelectionExpr));
4274   return new (Mem) GenericSelectionExpr(EmptyShell(), NumAssocs);
4275 }
4276 
4277 //===----------------------------------------------------------------------===//
4278 //  DesignatedInitExpr
4279 //===----------------------------------------------------------------------===//
4280 
4281 IdentifierInfo *DesignatedInitExpr::Designator::getFieldName() const {
4282   assert(Kind == FieldDesignator && "Only valid on a field designator");
4283   if (Field.NameOrField & 0x01)
4284     return reinterpret_cast<IdentifierInfo *>(Field.NameOrField&~0x01);
4285   else
4286     return getField()->getIdentifier();
4287 }
4288 
4289 DesignatedInitExpr::DesignatedInitExpr(const ASTContext &C, QualType Ty,
4290                                        llvm::ArrayRef<Designator> Designators,
4291                                        SourceLocation EqualOrColonLoc,
4292                                        bool GNUSyntax,
4293                                        ArrayRef<Expr*> IndexExprs,
4294                                        Expr *Init)
4295   : Expr(DesignatedInitExprClass, Ty,
4296          Init->getValueKind(), Init->getObjectKind(),
4297          Init->isTypeDependent(), Init->isValueDependent(),
4298          Init->isInstantiationDependent(),
4299          Init->containsUnexpandedParameterPack()),
4300     EqualOrColonLoc(EqualOrColonLoc), GNUSyntax(GNUSyntax),
4301     NumDesignators(Designators.size()), NumSubExprs(IndexExprs.size() + 1) {
4302   this->Designators = new (C) Designator[NumDesignators];
4303 
4304   // Record the initializer itself.
4305   child_iterator Child = child_begin();
4306   *Child++ = Init;
4307 
4308   // Copy the designators and their subexpressions, computing
4309   // value-dependence along the way.
4310   unsigned IndexIdx = 0;
4311   for (unsigned I = 0; I != NumDesignators; ++I) {
4312     this->Designators[I] = Designators[I];
4313 
4314     if (this->Designators[I].isArrayDesignator()) {
4315       // Compute type- and value-dependence.
4316       Expr *Index = IndexExprs[IndexIdx];
4317       if (Index->isTypeDependent() || Index->isValueDependent())
4318         ExprBits.TypeDependent = ExprBits.ValueDependent = true;
4319       if (Index->isInstantiationDependent())
4320         ExprBits.InstantiationDependent = true;
4321       // Propagate unexpanded parameter packs.
4322       if (Index->containsUnexpandedParameterPack())
4323         ExprBits.ContainsUnexpandedParameterPack = true;
4324 
4325       // Copy the index expressions into permanent storage.
4326       *Child++ = IndexExprs[IndexIdx++];
4327     } else if (this->Designators[I].isArrayRangeDesignator()) {
4328       // Compute type- and value-dependence.
4329       Expr *Start = IndexExprs[IndexIdx];
4330       Expr *End = IndexExprs[IndexIdx + 1];
4331       if (Start->isTypeDependent() || Start->isValueDependent() ||
4332           End->isTypeDependent() || End->isValueDependent()) {
4333         ExprBits.TypeDependent = ExprBits.ValueDependent = true;
4334         ExprBits.InstantiationDependent = true;
4335       } else if (Start->isInstantiationDependent() ||
4336                  End->isInstantiationDependent()) {
4337         ExprBits.InstantiationDependent = true;
4338       }
4339 
4340       // Propagate unexpanded parameter packs.
4341       if (Start->containsUnexpandedParameterPack() ||
4342           End->containsUnexpandedParameterPack())
4343         ExprBits.ContainsUnexpandedParameterPack = true;
4344 
4345       // Copy the start/end expressions into permanent storage.
4346       *Child++ = IndexExprs[IndexIdx++];
4347       *Child++ = IndexExprs[IndexIdx++];
4348     }
4349   }
4350 
4351   assert(IndexIdx == IndexExprs.size() && "Wrong number of index expressions");
4352 }
4353 
4354 DesignatedInitExpr *
4355 DesignatedInitExpr::Create(const ASTContext &C,
4356                            llvm::ArrayRef<Designator> Designators,
4357                            ArrayRef<Expr*> IndexExprs,
4358                            SourceLocation ColonOrEqualLoc,
4359                            bool UsesColonSyntax, Expr *Init) {
4360   void *Mem = C.Allocate(totalSizeToAlloc<Stmt *>(IndexExprs.size() + 1),
4361                          alignof(DesignatedInitExpr));
4362   return new (Mem) DesignatedInitExpr(C, C.VoidTy, Designators,
4363                                       ColonOrEqualLoc, UsesColonSyntax,
4364                                       IndexExprs, Init);
4365 }
4366 
4367 DesignatedInitExpr *DesignatedInitExpr::CreateEmpty(const ASTContext &C,
4368                                                     unsigned NumIndexExprs) {
4369   void *Mem = C.Allocate(totalSizeToAlloc<Stmt *>(NumIndexExprs + 1),
4370                          alignof(DesignatedInitExpr));
4371   return new (Mem) DesignatedInitExpr(NumIndexExprs + 1);
4372 }
4373 
4374 void DesignatedInitExpr::setDesignators(const ASTContext &C,
4375                                         const Designator *Desigs,
4376                                         unsigned NumDesigs) {
4377   Designators = new (C) Designator[NumDesigs];
4378   NumDesignators = NumDesigs;
4379   for (unsigned I = 0; I != NumDesigs; ++I)
4380     Designators[I] = Desigs[I];
4381 }
4382 
4383 SourceRange DesignatedInitExpr::getDesignatorsSourceRange() const {
4384   DesignatedInitExpr *DIE = const_cast<DesignatedInitExpr*>(this);
4385   if (size() == 1)
4386     return DIE->getDesignator(0)->getSourceRange();
4387   return SourceRange(DIE->getDesignator(0)->getBeginLoc(),
4388                      DIE->getDesignator(size() - 1)->getEndLoc());
4389 }
4390 
4391 SourceLocation DesignatedInitExpr::getBeginLoc() const {
4392   SourceLocation StartLoc;
4393   auto *DIE = const_cast<DesignatedInitExpr *>(this);
4394   Designator &First = *DIE->getDesignator(0);
4395   if (First.isFieldDesignator()) {
4396     if (GNUSyntax)
4397       StartLoc = SourceLocation::getFromRawEncoding(First.Field.FieldLoc);
4398     else
4399       StartLoc = SourceLocation::getFromRawEncoding(First.Field.DotLoc);
4400   } else
4401     StartLoc =
4402       SourceLocation::getFromRawEncoding(First.ArrayOrRange.LBracketLoc);
4403   return StartLoc;
4404 }
4405 
4406 SourceLocation DesignatedInitExpr::getEndLoc() const {
4407   return getInit()->getEndLoc();
4408 }
4409 
4410 Expr *DesignatedInitExpr::getArrayIndex(const Designator& D) const {
4411   assert(D.Kind == Designator::ArrayDesignator && "Requires array designator");
4412   return getSubExpr(D.ArrayOrRange.Index + 1);
4413 }
4414 
4415 Expr *DesignatedInitExpr::getArrayRangeStart(const Designator &D) const {
4416   assert(D.Kind == Designator::ArrayRangeDesignator &&
4417          "Requires array range designator");
4418   return getSubExpr(D.ArrayOrRange.Index + 1);
4419 }
4420 
4421 Expr *DesignatedInitExpr::getArrayRangeEnd(const Designator &D) const {
4422   assert(D.Kind == Designator::ArrayRangeDesignator &&
4423          "Requires array range designator");
4424   return getSubExpr(D.ArrayOrRange.Index + 2);
4425 }
4426 
4427 /// Replaces the designator at index @p Idx with the series
4428 /// of designators in [First, Last).
4429 void DesignatedInitExpr::ExpandDesignator(const ASTContext &C, unsigned Idx,
4430                                           const Designator *First,
4431                                           const Designator *Last) {
4432   unsigned NumNewDesignators = Last - First;
4433   if (NumNewDesignators == 0) {
4434     std::copy_backward(Designators + Idx + 1,
4435                        Designators + NumDesignators,
4436                        Designators + Idx);
4437     --NumNewDesignators;
4438     return;
4439   } else if (NumNewDesignators == 1) {
4440     Designators[Idx] = *First;
4441     return;
4442   }
4443 
4444   Designator *NewDesignators
4445     = new (C) Designator[NumDesignators - 1 + NumNewDesignators];
4446   std::copy(Designators, Designators + Idx, NewDesignators);
4447   std::copy(First, Last, NewDesignators + Idx);
4448   std::copy(Designators + Idx + 1, Designators + NumDesignators,
4449             NewDesignators + Idx + NumNewDesignators);
4450   Designators = NewDesignators;
4451   NumDesignators = NumDesignators - 1 + NumNewDesignators;
4452 }
4453 
4454 DesignatedInitUpdateExpr::DesignatedInitUpdateExpr(const ASTContext &C,
4455     SourceLocation lBraceLoc, Expr *baseExpr, SourceLocation rBraceLoc)
4456   : Expr(DesignatedInitUpdateExprClass, baseExpr->getType(), VK_RValue,
4457          OK_Ordinary, false, false, false, false) {
4458   BaseAndUpdaterExprs[0] = baseExpr;
4459 
4460   InitListExpr *ILE = new (C) InitListExpr(C, lBraceLoc, None, rBraceLoc);
4461   ILE->setType(baseExpr->getType());
4462   BaseAndUpdaterExprs[1] = ILE;
4463 }
4464 
4465 SourceLocation DesignatedInitUpdateExpr::getBeginLoc() const {
4466   return getBase()->getBeginLoc();
4467 }
4468 
4469 SourceLocation DesignatedInitUpdateExpr::getEndLoc() const {
4470   return getBase()->getEndLoc();
4471 }
4472 
4473 ParenListExpr::ParenListExpr(SourceLocation LParenLoc, ArrayRef<Expr *> Exprs,
4474                              SourceLocation RParenLoc)
4475     : Expr(ParenListExprClass, QualType(), VK_RValue, OK_Ordinary, false, false,
4476            false, false),
4477       LParenLoc(LParenLoc), RParenLoc(RParenLoc) {
4478   ParenListExprBits.NumExprs = Exprs.size();
4479 
4480   for (unsigned I = 0, N = Exprs.size(); I != N; ++I) {
4481     if (Exprs[I]->isTypeDependent())
4482       ExprBits.TypeDependent = true;
4483     if (Exprs[I]->isValueDependent())
4484       ExprBits.ValueDependent = true;
4485     if (Exprs[I]->isInstantiationDependent())
4486       ExprBits.InstantiationDependent = true;
4487     if (Exprs[I]->containsUnexpandedParameterPack())
4488       ExprBits.ContainsUnexpandedParameterPack = true;
4489 
4490     getTrailingObjects<Stmt *>()[I] = Exprs[I];
4491   }
4492 }
4493 
4494 ParenListExpr::ParenListExpr(EmptyShell Empty, unsigned NumExprs)
4495     : Expr(ParenListExprClass, Empty) {
4496   ParenListExprBits.NumExprs = NumExprs;
4497 }
4498 
4499 ParenListExpr *ParenListExpr::Create(const ASTContext &Ctx,
4500                                      SourceLocation LParenLoc,
4501                                      ArrayRef<Expr *> Exprs,
4502                                      SourceLocation RParenLoc) {
4503   void *Mem = Ctx.Allocate(totalSizeToAlloc<Stmt *>(Exprs.size()),
4504                            alignof(ParenListExpr));
4505   return new (Mem) ParenListExpr(LParenLoc, Exprs, RParenLoc);
4506 }
4507 
4508 ParenListExpr *ParenListExpr::CreateEmpty(const ASTContext &Ctx,
4509                                           unsigned NumExprs) {
4510   void *Mem =
4511       Ctx.Allocate(totalSizeToAlloc<Stmt *>(NumExprs), alignof(ParenListExpr));
4512   return new (Mem) ParenListExpr(EmptyShell(), NumExprs);
4513 }
4514 
4515 const OpaqueValueExpr *OpaqueValueExpr::findInCopyConstruct(const Expr *e) {
4516   if (const ExprWithCleanups *ewc = dyn_cast<ExprWithCleanups>(e))
4517     e = ewc->getSubExpr();
4518   if (const MaterializeTemporaryExpr *m = dyn_cast<MaterializeTemporaryExpr>(e))
4519     e = m->getSubExpr();
4520   e = cast<CXXConstructExpr>(e)->getArg(0);
4521   while (const ImplicitCastExpr *ice = dyn_cast<ImplicitCastExpr>(e))
4522     e = ice->getSubExpr();
4523   return cast<OpaqueValueExpr>(e);
4524 }
4525 
4526 PseudoObjectExpr *PseudoObjectExpr::Create(const ASTContext &Context,
4527                                            EmptyShell sh,
4528                                            unsigned numSemanticExprs) {
4529   void *buffer =
4530       Context.Allocate(totalSizeToAlloc<Expr *>(1 + numSemanticExprs),
4531                        alignof(PseudoObjectExpr));
4532   return new(buffer) PseudoObjectExpr(sh, numSemanticExprs);
4533 }
4534 
4535 PseudoObjectExpr::PseudoObjectExpr(EmptyShell shell, unsigned numSemanticExprs)
4536   : Expr(PseudoObjectExprClass, shell) {
4537   PseudoObjectExprBits.NumSubExprs = numSemanticExprs + 1;
4538 }
4539 
4540 PseudoObjectExpr *PseudoObjectExpr::Create(const ASTContext &C, Expr *syntax,
4541                                            ArrayRef<Expr*> semantics,
4542                                            unsigned resultIndex) {
4543   assert(syntax && "no syntactic expression!");
4544   assert(semantics.size() && "no semantic expressions!");
4545 
4546   QualType type;
4547   ExprValueKind VK;
4548   if (resultIndex == NoResult) {
4549     type = C.VoidTy;
4550     VK = VK_RValue;
4551   } else {
4552     assert(resultIndex < semantics.size());
4553     type = semantics[resultIndex]->getType();
4554     VK = semantics[resultIndex]->getValueKind();
4555     assert(semantics[resultIndex]->getObjectKind() == OK_Ordinary);
4556   }
4557 
4558   void *buffer = C.Allocate(totalSizeToAlloc<Expr *>(semantics.size() + 1),
4559                             alignof(PseudoObjectExpr));
4560   return new(buffer) PseudoObjectExpr(type, VK, syntax, semantics,
4561                                       resultIndex);
4562 }
4563 
4564 PseudoObjectExpr::PseudoObjectExpr(QualType type, ExprValueKind VK,
4565                                    Expr *syntax, ArrayRef<Expr*> semantics,
4566                                    unsigned resultIndex)
4567   : Expr(PseudoObjectExprClass, type, VK, OK_Ordinary,
4568          /*filled in at end of ctor*/ false, false, false, false) {
4569   PseudoObjectExprBits.NumSubExprs = semantics.size() + 1;
4570   PseudoObjectExprBits.ResultIndex = resultIndex + 1;
4571 
4572   for (unsigned i = 0, e = semantics.size() + 1; i != e; ++i) {
4573     Expr *E = (i == 0 ? syntax : semantics[i-1]);
4574     getSubExprsBuffer()[i] = E;
4575 
4576     if (E->isTypeDependent())
4577       ExprBits.TypeDependent = true;
4578     if (E->isValueDependent())
4579       ExprBits.ValueDependent = true;
4580     if (E->isInstantiationDependent())
4581       ExprBits.InstantiationDependent = true;
4582     if (E->containsUnexpandedParameterPack())
4583       ExprBits.ContainsUnexpandedParameterPack = true;
4584 
4585     if (isa<OpaqueValueExpr>(E))
4586       assert(cast<OpaqueValueExpr>(E)->getSourceExpr() != nullptr &&
4587              "opaque-value semantic expressions for pseudo-object "
4588              "operations must have sources");
4589   }
4590 }
4591 
4592 //===----------------------------------------------------------------------===//
4593 //  Child Iterators for iterating over subexpressions/substatements
4594 //===----------------------------------------------------------------------===//
4595 
4596 // UnaryExprOrTypeTraitExpr
4597 Stmt::child_range UnaryExprOrTypeTraitExpr::children() {
4598   const_child_range CCR =
4599       const_cast<const UnaryExprOrTypeTraitExpr *>(this)->children();
4600   return child_range(cast_away_const(CCR.begin()), cast_away_const(CCR.end()));
4601 }
4602 
4603 Stmt::const_child_range UnaryExprOrTypeTraitExpr::children() const {
4604   // If this is of a type and the type is a VLA type (and not a typedef), the
4605   // size expression of the VLA needs to be treated as an executable expression.
4606   // Why isn't this weirdness documented better in StmtIterator?
4607   if (isArgumentType()) {
4608     if (const VariableArrayType *T =
4609             dyn_cast<VariableArrayType>(getArgumentType().getTypePtr()))
4610       return const_child_range(const_child_iterator(T), const_child_iterator());
4611     return const_child_range(const_child_iterator(), const_child_iterator());
4612   }
4613   return const_child_range(&Argument.Ex, &Argument.Ex + 1);
4614 }
4615 
4616 AtomicExpr::AtomicExpr(SourceLocation BLoc, ArrayRef<Expr*> args,
4617                        QualType t, AtomicOp op, SourceLocation RP)
4618   : Expr(AtomicExprClass, t, VK_RValue, OK_Ordinary,
4619          false, false, false, false),
4620     NumSubExprs(args.size()), BuiltinLoc(BLoc), RParenLoc(RP), Op(op)
4621 {
4622   assert(args.size() == getNumSubExprs(op) && "wrong number of subexpressions");
4623   for (unsigned i = 0; i != args.size(); i++) {
4624     if (args[i]->isTypeDependent())
4625       ExprBits.TypeDependent = true;
4626     if (args[i]->isValueDependent())
4627       ExprBits.ValueDependent = true;
4628     if (args[i]->isInstantiationDependent())
4629       ExprBits.InstantiationDependent = true;
4630     if (args[i]->containsUnexpandedParameterPack())
4631       ExprBits.ContainsUnexpandedParameterPack = true;
4632 
4633     SubExprs[i] = args[i];
4634   }
4635 }
4636 
4637 unsigned AtomicExpr::getNumSubExprs(AtomicOp Op) {
4638   switch (Op) {
4639   case AO__c11_atomic_init:
4640   case AO__opencl_atomic_init:
4641   case AO__c11_atomic_load:
4642   case AO__atomic_load_n:
4643     return 2;
4644 
4645   case AO__opencl_atomic_load:
4646   case AO__c11_atomic_store:
4647   case AO__c11_atomic_exchange:
4648   case AO__atomic_load:
4649   case AO__atomic_store:
4650   case AO__atomic_store_n:
4651   case AO__atomic_exchange_n:
4652   case AO__c11_atomic_fetch_add:
4653   case AO__c11_atomic_fetch_sub:
4654   case AO__c11_atomic_fetch_and:
4655   case AO__c11_atomic_fetch_or:
4656   case AO__c11_atomic_fetch_xor:
4657   case AO__c11_atomic_fetch_max:
4658   case AO__c11_atomic_fetch_min:
4659   case AO__atomic_fetch_add:
4660   case AO__atomic_fetch_sub:
4661   case AO__atomic_fetch_and:
4662   case AO__atomic_fetch_or:
4663   case AO__atomic_fetch_xor:
4664   case AO__atomic_fetch_nand:
4665   case AO__atomic_add_fetch:
4666   case AO__atomic_sub_fetch:
4667   case AO__atomic_and_fetch:
4668   case AO__atomic_or_fetch:
4669   case AO__atomic_xor_fetch:
4670   case AO__atomic_nand_fetch:
4671   case AO__atomic_min_fetch:
4672   case AO__atomic_max_fetch:
4673   case AO__atomic_fetch_min:
4674   case AO__atomic_fetch_max:
4675     return 3;
4676 
4677   case AO__opencl_atomic_store:
4678   case AO__opencl_atomic_exchange:
4679   case AO__opencl_atomic_fetch_add:
4680   case AO__opencl_atomic_fetch_sub:
4681   case AO__opencl_atomic_fetch_and:
4682   case AO__opencl_atomic_fetch_or:
4683   case AO__opencl_atomic_fetch_xor:
4684   case AO__opencl_atomic_fetch_min:
4685   case AO__opencl_atomic_fetch_max:
4686   case AO__atomic_exchange:
4687     return 4;
4688 
4689   case AO__c11_atomic_compare_exchange_strong:
4690   case AO__c11_atomic_compare_exchange_weak:
4691     return 5;
4692 
4693   case AO__opencl_atomic_compare_exchange_strong:
4694   case AO__opencl_atomic_compare_exchange_weak:
4695   case AO__atomic_compare_exchange:
4696   case AO__atomic_compare_exchange_n:
4697     return 6;
4698   }
4699   llvm_unreachable("unknown atomic op");
4700 }
4701 
4702 QualType AtomicExpr::getValueType() const {
4703   auto T = getPtr()->getType()->castAs<PointerType>()->getPointeeType();
4704   if (auto AT = T->getAs<AtomicType>())
4705     return AT->getValueType();
4706   return T;
4707 }
4708 
4709 QualType OMPArraySectionExpr::getBaseOriginalType(const Expr *Base) {
4710   unsigned ArraySectionCount = 0;
4711   while (auto *OASE = dyn_cast<OMPArraySectionExpr>(Base->IgnoreParens())) {
4712     Base = OASE->getBase();
4713     ++ArraySectionCount;
4714   }
4715   while (auto *ASE =
4716              dyn_cast<ArraySubscriptExpr>(Base->IgnoreParenImpCasts())) {
4717     Base = ASE->getBase();
4718     ++ArraySectionCount;
4719   }
4720   Base = Base->IgnoreParenImpCasts();
4721   auto OriginalTy = Base->getType();
4722   if (auto *DRE = dyn_cast<DeclRefExpr>(Base))
4723     if (auto *PVD = dyn_cast<ParmVarDecl>(DRE->getDecl()))
4724       OriginalTy = PVD->getOriginalType().getNonReferenceType();
4725 
4726   for (unsigned Cnt = 0; Cnt < ArraySectionCount; ++Cnt) {
4727     if (OriginalTy->isAnyPointerType())
4728       OriginalTy = OriginalTy->getPointeeType();
4729     else {
4730       assert (OriginalTy->isArrayType());
4731       OriginalTy = OriginalTy->castAsArrayTypeUnsafe()->getElementType();
4732     }
4733   }
4734   return OriginalTy;
4735 }
4736