35#include "llvm/Support/ErrorHandling.h"
36#include "llvm/Support/Format.h"
37#include "llvm/Support/raw_ostream.h"
49 if (
auto *BO = dyn_cast<BinaryOperator>(
E)) {
50 if (BO->getOpcode() == BO_Comma) {
57 if (
auto *MTE = dyn_cast<MaterializeTemporaryExpr>(
E)) {
58 E = MTE->getSubExpr();
79 return cast<CXXRecordDecl>(
D);
89 if (
const auto *CE = dyn_cast<CastExpr>(
E)) {
90 if ((CE->getCastKind() == CK_DerivedToBase ||
91 CE->getCastKind() == CK_UncheckedDerivedToBase) &&
100 if (CE->getCastKind() == CK_NoOp) {
101 E = CE->getSubExpr();
104 }
else if (
const auto *ME = dyn_cast<MemberExpr>(
E)) {
105 if (!ME->isArrow()) {
106 assert(ME->getBase()->getType()->getAsRecordDecl());
107 if (
const auto *Field = dyn_cast<FieldDecl>(ME->getMemberDecl())) {
108 if (!Field->isBitField() && !Field->getType()->isReferenceType()) {
115 }
else if (
const auto *BO = dyn_cast<BinaryOperator>(
E)) {
116 if (BO->getOpcode() == BO_PtrMemD) {
117 assert(BO->getRHS()->isPRValue());
123 if (BO->getOpcode() == BO_Comma) {
124 CommaLHSs.push_back(BO->getLHS());
145 switch (UO->getOpcode()) {
147 return UO->getSubExpr()->isKnownToHaveBooleanValue(Semantic);
159 return CE->getSubExpr()->isKnownToHaveBooleanValue(Semantic);
162 switch (BO->getOpcode()) {
163 default:
return false;
178 return BO->getLHS()->isKnownToHaveBooleanValue(Semantic) &&
179 BO->getRHS()->isKnownToHaveBooleanValue(Semantic);
183 return BO->getRHS()->isKnownToHaveBooleanValue(Semantic);
188 return CO->getTrueExpr()->isKnownToHaveBooleanValue(Semantic) &&
189 CO->getFalseExpr()->isKnownToHaveBooleanValue(Semantic);
191 if (isa<ObjCBoolLiteralExpr>(
E))
194 if (
const auto *OVE = dyn_cast<OpaqueValueExpr>(
E))
195 return OVE->getSourceExpr()->isKnownToHaveBooleanValue(Semantic);
198 if (!Semantic && FD->getType()->isUnsignedIntegerType() &&
199 !FD->getBitWidth()->isValueDependent() &&
200 FD->getBitWidthValue(FD->getASTContext()) == 1)
209 bool IgnoreTemplateOrMacroSubstitution)
const {
211 const Decl *
D =
nullptr;
213 if (
const auto *ME = dyn_cast<MemberExpr>(
E))
214 D = ME->getMemberDecl();
215 else if (
const auto *DRE = dyn_cast<DeclRefExpr>(
E))
217 else if (
const auto *IRE = dyn_cast<ObjCIvarRefExpr>(
E))
221 StrictFlexArraysLevel,
222 IgnoreTemplateOrMacroSubstitution);
232 if (
Value.isMemberPointer())
233 return Value.getMemberPointerDecl();
235 if (
Value.isLValue() &&
Value.getLValueOffset().isZero())
249 template <
class E,
class T>
252 return static_cast<const E*
>(
expr)->getExprLoc();
262 return static_cast<const E *
>(
expr)->getBeginLoc();
270 const auto *ED = cast<EnumDecl>(ECD->getDeclContext());
271 if (ED->isCompleteDefinition())
280#define ABSTRACT_STMT(type)
281#define STMT(type, base) \
282 case Stmt::type##Class: break;
283#define EXPR(type, base) \
284 case Stmt::type##Class: return getExprLocImpl<type>(this, &type::getExprLoc);
285#include "clang/AST/StmtNodes.inc"
287 llvm_unreachable(
"unknown expression kind");
298 "Invalid StorageKind Value");
308 if (!
Value.getInt().needsCleanup())
324 bool IsImmediateInvocation)
325 :
FullExpr(ConstantExprClass, SubExpr) {
334 ::new (getTrailingObjects<APValue>())
APValue();
339 bool IsImmediateInvocation) {
340 assert(!isa<ConstantExpr>(
E));
343 unsigned Size = totalSizeToAlloc<APValue, uint64_t>(
347 return new (Mem)
ConstantExpr(
E, StorageKind, IsImmediateInvocation);
358ConstantExpr::ConstantExpr(EmptyShell
Empty,
364 ::new (getTrailingObjects<APValue>())
APValue();
371 unsigned Size = totalSizeToAlloc<APValue, uint64_t>(
380 "Invalid storage for this value kind");
386 Int64Result() = *
Value.getInt().getRawData();
395 APValueResult() = std::move(
Value);
398 llvm_unreachable(
"Invalid ResultKind Bits");
404 return APValueResult().
getInt();
409 llvm_unreachable(
"invalid Accessor");
417 return APValueResult();
427 llvm_unreachable(
"invalid ResultKind");
431 bool RefersToEnclosingVariableOrCapture,
QualType T,
441 RefersToEnclosingVariableOrCapture;
442 DeclRefExprBits.CapturedByCopyInLambdaWithExplicitObjectParameter =
false;
449DeclRefExpr::DeclRefExpr(
const ASTContext &Ctx,
452 bool RefersToEnclosingVariableOrCapture,
461 new (getTrailingObjects<NestedNameSpecifierLoc>())
465 *getTrailingObjects<NamedDecl *>() = FoundD;
467 = (TemplateArgs || TemplateKWLoc.
isValid()) ? 1 : 0;
469 RefersToEnclosingVariableOrCapture;
470 DeclRefExprBits.CapturedByCopyInLambdaWithExplicitObjectParameter =
false;
473 auto Deps = TemplateArgumentDependence::None;
474 getTrailingObjects<ASTTemplateKWAndArgsInfo>()->initializeFrom(
475 TemplateKWLoc, *TemplateArgs, getTrailingObjects<TemplateArgumentLoc>(),
477 assert(!(Deps & TemplateArgumentDependence::Dependent) &&
478 "built a DeclRefExpr with dependent template args");
479 }
else if (TemplateKWLoc.
isValid()) {
480 getTrailingObjects<ASTTemplateKWAndArgsInfo>()->initializeFrom(
491 bool RefersToEnclosingVariableOrCapture,
496 return Create(Context, QualifierLoc, TemplateKWLoc,
D,
497 RefersToEnclosingVariableOrCapture,
499 T, VK, FoundD, TemplateArgs, NOUR);
505 bool RefersToEnclosingVariableOrCapture,
515 bool HasTemplateKWAndArgsInfo = TemplateArgs || TemplateKWLoc.
isValid();
519 QualifierLoc ? 1 : 0, FoundD ? 1 : 0,
520 HasTemplateKWAndArgsInfo ? 1 : 0,
521 TemplateArgs ? TemplateArgs->
size() : 0);
524 return new (Mem)
DeclRefExpr(Context, QualifierLoc, TemplateKWLoc,
D,
525 RefersToEnclosingVariableOrCapture, NameInfo,
526 FoundD, TemplateArgs,
T, VK, NOUR);
532 bool HasTemplateKWAndArgsInfo,
533 unsigned NumTemplateArgs) {
534 assert(NumTemplateArgs == 0 || HasTemplateKWAndArgsInfo);
538 HasQualifier ? 1 : 0, HasFoundDecl ? 1 : 0, HasTemplateKWAndArgsInfo,
546 if (
getType()->isUndeducedType())
562SYCLUniqueStableNameExpr::SYCLUniqueStableNameExpr(
SourceLocation OpLoc,
568 OpLoc(OpLoc), LParen(LParen), RParen(RParen) {
569 setTypeSourceInfo(TSI);
573SYCLUniqueStableNameExpr::SYCLUniqueStableNameExpr(EmptyShell
Empty,
600 const NamedDecl *ND) -> std::optional<unsigned> {
601 if (
const auto *RD = dyn_cast<CXXRecordDecl>(ND))
602 return RD->getDeviceLambdaManglingNumber();
611 llvm::raw_string_ostream Out(Buffer);
612 Ctx->mangleCanonicalTypeName(Ty, Out);
622 assert((getIdentKind() == IK) &&
623 "IdentKind do not fit in PredefinedExprBitfields!");
624 bool HasFunctionName = SL !=
nullptr;
633PredefinedExpr::PredefinedExpr(EmptyShell
Empty,
bool HasFunctionName)
641 bool HasFunctionName = SL !=
nullptr;
642 void *Mem = Ctx.
Allocate(totalSizeToAlloc<Stmt *>(HasFunctionName),
648 bool HasFunctionName) {
649 void *Mem = Ctx.
Allocate(totalSizeToAlloc<Stmt *>(HasFunctionName),
659 return "__FUNCTION__";
661 return "__FUNCDNAME__";
663 return "L__FUNCTION__";
665 return "__PRETTY_FUNCTION__";
667 return "__FUNCSIG__";
669 return "L__FUNCSIG__";
673 llvm_unreachable(
"Unknown ident kind for PredefinedExpr");
679 const Decl *CurrentDecl,
680 bool ForceElaboratedPrinting) {
684 if (
const NamedDecl *ND = dyn_cast<NamedDecl>(CurrentDecl)) {
685 std::unique_ptr<MangleContext> MC;
688 if (MC->shouldMangleDeclName(ND)) {
690 llvm::raw_svector_ostream Out(Buffer);
696 else if (ND->hasAttr<CUDAGlobalAttr>())
700 MC->mangleName(GD, Out);
702 if (!Buffer.empty() && Buffer.front() ==
'\01')
703 return std::string(Buffer.substr(1));
704 return std::string(Buffer);
706 return std::string(ND->getIdentifier()->getName());
710 if (isa<BlockDecl>(CurrentDecl)) {
715 if (DC->isFileContext())
719 llvm::raw_svector_ostream Out(Buffer);
720 if (
auto *DCBlock = dyn_cast<BlockDecl>(DC))
723 else if (
auto *DCDecl = dyn_cast<Decl>(DC))
725 return std::string(Out.str());
727 if (
const FunctionDecl *FD = dyn_cast<FunctionDecl>(CurrentDecl)) {
729 bool IsFuncOrFunctionInNonMSVCCompatEnv =
731 IK == PredefinedIdentKind ::Function) &&
733 bool IsLFunctionInMSVCCommpatEnv =
735 bool IsFuncOrFunctionOrLFunctionOrFuncDName =
740 if ((ForceElaboratedPrinting &&
741 (IsFuncOrFunctionInNonMSVCCompatEnv || IsLFunctionInMSVCCommpatEnv)) ||
742 (!ForceElaboratedPrinting && IsFuncOrFunctionOrLFunctionOrFuncDName))
743 return FD->getNameAsString();
746 llvm::raw_svector_ostream Out(Name);
758 std::string remapPath(StringRef
Path)
const override {
761 return std::string(p);
773 llvm::raw_string_ostream POut(Proto);
780 if (FD->hasWrittenPrototype())
781 FT = dyn_cast<FunctionProtoType>(AFT);
786 case CC_C: POut <<
"__cdecl ";
break;
797 FD->printQualifiedName(POut, Policy);
801 return std::string(Name);
806 for (
unsigned i = 0, e =
Decl->getNumParams(); i != e; ++i) {
808 POut <<
Decl->getParamDecl(i)->getType().stream(Policy);
811 if (FT->isVariadic()) {
812 if (FD->getNumParams()) POut <<
", ";
817 !
Decl->getNumParams()) {
824 assert(FT &&
"We must have a written prototype in this case.");
827 if (FT->isVolatile())
839 while (isa_and_nonnull<NamedDecl>(Ctx)) {
841 = dyn_cast<ClassTemplateSpecializationDecl>(Ctx);
843 Specs.push_back(Spec);
847 std::string TemplateParams;
848 llvm::raw_string_ostream TOut(TemplateParams);
851 D->getSpecializedTemplate()->getTemplateParameters();
853 assert(Params->
size() == Args.
size());
854 for (
unsigned i = 0, numParams = Params->
size(); i != numParams; ++i) {
856 if (Param.empty())
continue;
857 TOut << Param <<
" = ";
866 = FD->getTemplateSpecializationInfo();
871 assert(Params->
size() == Args->
size());
872 for (
unsigned i = 0, e = Params->
size(); i != e; ++i) {
874 if (Param.empty())
continue;
875 TOut << Param <<
" = ";
876 Args->
get(i).
print(Policy, TOut,
true);
881 if (!TemplateParams.empty()) {
883 TemplateParams.resize(TemplateParams.size() - 2);
884 POut <<
" [" << TemplateParams <<
"]";
891 if (isa<CXXMethodDecl>(FD) &&
892 cast<CXXMethodDecl>(FD)->getParent()->isLambda())
893 Proto =
"auto " + Proto;
894 else if (FT && FT->getReturnType()->getAs<
DecltypeType>())
899 else if (!isa<CXXConstructorDecl>(FD) && !isa<CXXDestructorDecl>(FD))
904 return std::string(Name);
906 if (
const CapturedDecl *CD = dyn_cast<CapturedDecl>(CurrentDecl)) {
910 if (DC->isFunctionOrMethod() && (DC->getDeclKind() != Decl::Captured)) {
914 llvm_unreachable(
"CapturedDecl not inside a function or method");
916 if (
const ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(CurrentDecl)) {
918 llvm::raw_svector_ostream Out(Name);
919 Out << (MD->isInstanceMethod() ?
'-' :
'+');
928 dyn_cast<ObjCCategoryImplDecl>(MD->getDeclContext()))
929 Out <<
'(' << *CID <<
')';
932 MD->getSelector().print(Out);
935 return std::string(Name);
937 if (isa<TranslationUnitDecl>(CurrentDecl) &&
946 const llvm::APInt &Val) {
950 BitWidth = Val.getBitWidth();
951 unsigned NumWords = Val.getNumWords();
952 const uint64_t* Words = Val.getRawData();
954 pVal =
new (
C) uint64_t[NumWords];
955 std::copy(Words, Words + NumWords,
pVal);
956 }
else if (NumWords == 1)
962IntegerLiteral::IntegerLiteral(
const ASTContext &
C,
const llvm::APInt &
V,
965 assert(
type->isIntegerType() &&
"Illegal type in IntegerLiteral");
966 assert(
V.getBitWidth() ==
C.getIntWidth(
type) &&
967 "Integer type is not the correct size for constant.");
983FixedPointLiteral::FixedPointLiteral(
const ASTContext &
C,
const llvm::APInt &
V,
988 assert(
type->isFixedPointType() &&
"Illegal type in FixedPointLiteral");
989 assert(
V.getBitWidth() ==
C.getTypeInfo(
type).Width &&
990 "Fixed point type is not the correct size for constant.");
996 const llvm::APInt &
V,
1014 S, llvm::APSInt::getUnsigned(
getValue().getZExtValue()), Scale);
1015 return std::string(S);
1037 StringRef Escaped = escapeCStyle<EscapeChar::Single>(Val);
1038 if (!Escaped.empty()) {
1039 OS <<
"'" << Escaped <<
"'";
1048 OS <<
"'" << (char)Val <<
"'";
1050 OS <<
"'\\x" << llvm::format(
"%02x", Val) <<
"'";
1051 else if (Val <= 0xFFFF)
1052 OS <<
"'\\u" << llvm::format(
"%04x", Val) <<
"'";
1054 OS <<
"'\\U" << llvm::format(
"%08x", Val) <<
"'";
1058FloatingLiteral::FloatingLiteral(
const ASTContext &
C,
const llvm::APFloat &
V,
1061 setSemantics(
V.getSemantics());
1069 setRawSemantics(llvm::APFloatBase::S_IEEEhalf);
1090 V.convert(llvm::APFloat::IEEEdouble(), llvm::APFloat::rmNearestTiesToEven,
1092 return V.convertToDouble();
1097 unsigned CharByteWidth = 0;
1101 CharByteWidth =
Target.getCharWidth();
1104 CharByteWidth =
Target.getWCharWidth();
1107 CharByteWidth =
Target.getChar16Width();
1110 CharByteWidth =
Target.getChar32Width();
1113 return sizeof(char);
1115 assert((CharByteWidth & 7) == 0 &&
"Assumes character size is byte multiple");
1117 assert((CharByteWidth == 1 || CharByteWidth == 2 || CharByteWidth == 4) &&
1118 "The only supported character byte widths are 1,2 and 4!");
1119 return CharByteWidth;
1122StringLiteral::StringLiteral(
const ASTContext &Ctx, StringRef Str,
1125 unsigned NumConcatenated)
1128 unsigned Length = Str.size();
1135 "StringLiteral must be of constant array type!");
1136 unsigned CharByteWidth = mapCharByteWidth(Ctx.
getTargetInfo(), Kind);
1137 unsigned ByteLength = Str.size();
1138 assert((ByteLength % CharByteWidth == 0) &&
1139 "The size of the data must be a multiple of CharByteWidth!");
1144 switch (CharByteWidth) {
1146 Length = ByteLength;
1149 Length = ByteLength / 2;
1152 Length = ByteLength / 4;
1155 llvm_unreachable(
"Unsupported character width!");
1161 assert(!Pascal &&
"Can't make an unevaluated Pascal string");
1166 *getTrailingObjects<unsigned>() = Length;
1170 std::memcpy(getTrailingObjects<SourceLocation>(), Loc,
1174 std::memcpy(getTrailingObjects<char>(), Str.data(), Str.size());
1179StringLiteral::StringLiteral(EmptyShell
Empty,
unsigned NumConcatenated,
1180 unsigned Length,
unsigned CharByteWidth)
1184 *getTrailingObjects<unsigned>() = Length;
1190 unsigned NumConcatenated) {
1191 void *Mem = Ctx.
Allocate(totalSizeToAlloc<unsigned, SourceLocation, char>(
1192 1, NumConcatenated, Str.size()),
1199 unsigned NumConcatenated,
1201 unsigned CharByteWidth) {
1202 void *Mem = Ctx.
Allocate(totalSizeToAlloc<unsigned, SourceLocation, char>(
1203 1, NumConcatenated, Length * CharByteWidth),
1228 static const char Hex[] =
"0123456789ABCDEF";
1231 for (
unsigned I = 0, N =
getLength(); I != N; ++I) {
1233 StringRef Escaped = escapeCStyle<EscapeChar::Double>(Char);
1234 if (Escaped.empty()) {
1240 Char >= 0xd800 && Char <= 0xdbff) {
1242 if (Trail >= 0xdc00 && Trail <= 0xdfff) {
1243 Char = 0x10000 + ((Char - 0xd800) << 10) + (Trail - 0xdc00);
1253 (Char >= 0xd800 && Char <= 0xdfff) || Char >= 0x110000) {
1257 while ((Char >> Shift) == 0)
1259 for (; Shift >= 0; Shift -= 4)
1260 OS << Hex[(Char >> Shift) & 15];
1267 << Hex[(Char >> 20) & 15]
1268 << Hex[(Char >> 16) & 15];
1271 OS << Hex[(Char >> 12) & 15]
1272 << Hex[(Char >> 8) & 15]
1273 << Hex[(Char >> 4) & 15]
1274 << Hex[(Char >> 0) & 15];
1280 if (LastSlashX + 1 == I) {
1282 case '0':
case '1':
case '2':
case '3':
case '4':
1283 case '5':
case '6':
case '7':
case '8':
case '9':
1284 case 'a':
case 'b':
case 'c':
case 'd':
case 'e':
case 'f':
1285 case 'A':
case 'B':
case 'C':
case 'D':
case 'E':
case 'F':
1290 assert(Char <= 0xff &&
1291 "Characters above 0xff should already have been handled.");
1297 << (char)(
'0' + ((Char >> 6) & 7))
1298 << (char)(
'0' + ((Char >> 3) & 7))
1299 << (char)(
'0' + ((Char >> 0) & 7));
1328 unsigned *StartTokenByteOffset)
const {
1332 "Only narrow string literals are currently supported");
1337 unsigned StringOffset = 0;
1339 TokNo = *StartToken;
1340 if (StartTokenByteOffset) {
1341 StringOffset = *StartTokenByteOffset;
1342 ByteNo -= StringOffset;
1354 std::pair<FileID, unsigned> LocInfo =
1355 SM.getDecomposedLoc(StrTokSpellingLoc);
1357 StringRef Buffer =
SM.getBufferData(LocInfo.first, &
Invalid);
1359 if (StartTokenByteOffset !=
nullptr)
1360 *StartTokenByteOffset = StringOffset;
1361 if (StartToken !=
nullptr)
1362 *StartToken = TokNo;
1363 return StrTokSpellingLoc;
1366 const char *StrData = Buffer.data()+LocInfo.second;
1369 Lexer TheLexer(
SM.getLocForStartOfFile(LocInfo.first), Features,
1370 Buffer.begin(), StrData, Buffer.end());
1379 if (ByteNo < TokNumBytes ||
1385 if (StartTokenByteOffset !=
nullptr)
1386 *StartTokenByteOffset = StringOffset;
1387 if (StartToken !=
nullptr)
1388 *StartToken = TokNo;
1393 StringOffset += TokNumBytes;
1395 ByteNo -= TokNumBytes;
1403#define UNARY_OPERATION(Name, Spelling) case UO_##Name: return Spelling;
1404#include "clang/AST/OperationKinds.def"
1406 llvm_unreachable(
"Unknown unary operator");
1412 default: llvm_unreachable(
"No unary operator for overloaded function");
1413 case OO_PlusPlus:
return Postfix ? UO_PostInc : UO_PreInc;
1414 case OO_MinusMinus:
return Postfix ? UO_PostDec : UO_PreDec;
1415 case OO_Amp:
return UO_AddrOf;
1416 case OO_Star:
return UO_Deref;
1417 case OO_Plus:
return UO_Plus;
1418 case OO_Minus:
return UO_Minus;
1419 case OO_Tilde:
return UO_Not;
1420 case OO_Exclaim:
return UO_LNot;
1421 case OO_Coawait:
return UO_Coawait;
1427 case UO_PostInc:
case UO_PreInc:
return OO_PlusPlus;
1428 case UO_PostDec:
case UO_PreDec:
return OO_MinusMinus;
1429 case UO_AddrOf:
return OO_Amp;
1430 case UO_Deref:
return OO_Star;
1431 case UO_Plus:
return OO_Plus;
1432 case UO_Minus:
return OO_Minus;
1433 case UO_Not:
return OO_Tilde;
1434 case UO_LNot:
return OO_Exclaim;
1435 case UO_Coawait:
return OO_Coawait;
1450 NumArgs = std::max<unsigned>(Args.size(), MinNumArgs);
1451 unsigned NumPreArgs = PreArgs.size();
1453 assert((NumPreArgs ==
getNumPreArgs()) &&
"NumPreArgs overflow!");
1455 unsigned OffsetToTrailingObjects = offsetToTrailingObjects(SC);
1456 CallExprBits.OffsetToTrailingObjects = OffsetToTrailingObjects;
1457 assert((
CallExprBits.OffsetToTrailingObjects == OffsetToTrailingObjects) &&
1458 "OffsetToTrailingObjects overflow!");
1463 for (
unsigned I = 0; I != NumPreArgs; ++I)
1465 for (
unsigned I = 0; I != Args.size(); ++I)
1467 for (
unsigned I = Args.size(); I != NumArgs; ++I)
1482 assert((NumPreArgs ==
getNumPreArgs()) &&
"NumPreArgs overflow!");
1484 unsigned OffsetToTrailingObjects = offsetToTrailingObjects(SC);
1485 CallExprBits.OffsetToTrailingObjects = OffsetToTrailingObjects;
1486 assert((
CallExprBits.OffsetToTrailingObjects == OffsetToTrailingObjects) &&
1487 "OffsetToTrailingObjects overflow!");
1497 unsigned NumArgs = std::max<unsigned>(Args.size(), MinNumArgs);
1502 return new (Mem)
CallExpr(CallExprClass, Fn, {}, Args, Ty, VK,
1503 RParenLoc, FPFeatures, MinNumArgs,
UsesADL);
1510 "Misaligned memory in CallExpr::CreateTemporary!");
1511 return new (Mem)
CallExpr(CallExprClass, Fn, {}, {}, Ty,
1518 unsigned SizeOfTrailingObjects =
1526unsigned CallExpr::offsetToTrailingObjects(StmtClass SC) {
1530 case CXXOperatorCallExprClass:
1532 case CXXMemberCallExprClass:
1534 case UserDefinedLiteralClass:
1536 case CUDAKernelCallExprClass:
1539 llvm_unreachable(
"unexpected class deriving from CallExpr!");
1546 while (
auto *NTTP = dyn_cast<SubstNonTypeTemplateParmExpr>(CEE))
1551 if (
auto *BO = dyn_cast<BinaryOperator>(CEE)) {
1552 if (BO->isPtrMemOp()) {
1556 }
else if (
auto *UO = dyn_cast<UnaryOperator>(CEE)) {
1557 if (UO->getOpcode() == UO_Deref || UO->getOpcode() == UO_AddrOf ||
1558 UO->getOpcode() == UO_Plus) {
1566 if (
auto *DRE = dyn_cast<DeclRefExpr>(CEE))
1567 return DRE->getDecl();
1568 if (
auto *ME = dyn_cast<MemberExpr>(CEE))
1569 return ME->getMemberDecl();
1570 if (
auto *BE = dyn_cast<BlockExpr>(CEE))
1571 return BE->getBlockDecl();
1579 return FDecl ? FDecl->getBuiltinID() : 0;
1590 QualType CalleeType = Callee->getType();
1596 if (isa<CXXPseudoDestructorExpr>(Callee->IgnoreParens()))
1599 if (isa<UnresolvedMemberExpr>(Callee->IgnoreParens()))
1604 assert(!CalleeType.
isNull());
1618std::pair<const NamedDecl *, const Attr *>
1622 if (
const auto *A =
D->
getAttr<WarnUnusedResultAttr>())
1623 return {
nullptr, A};
1628 if (
const auto *A = TD->getAttr<WarnUnusedResultAttr>())
1632 TD = TD->desugar()->getAs<TypedefType>())
1633 if (
const auto *A = TD->getDecl()->getAttr<WarnUnusedResultAttr>())
1634 return {TD->getDecl(), A};
1635 return {
nullptr,
nullptr};
1639 if (
const auto *OCE = dyn_cast<CXXOperatorCallExpr>(
this))
1640 return OCE->getBeginLoc();
1642 if (
const auto *Method =
1644 Method && Method->isExplicitObjectMemberFunction()) {
1656 if (
const auto *OCE = dyn_cast<CXXOperatorCallExpr>(
this))
1657 return OCE->getEndLoc();
1671 void *Mem =
C.Allocate(
1672 totalSizeToAlloc<OffsetOfNode, Expr *>(comps.size(), exprs.size()));
1679 unsigned numComps,
unsigned numExprs) {
1681 C.Allocate(totalSizeToAlloc<OffsetOfNode, Expr *>(numComps, numExprs));
1690 OperatorLoc(OperatorLoc), RParenLoc(RParenLoc), TSInfo(tsi),
1691 NumComps(comps.size()), NumExprs(exprs.size()) {
1692 for (
unsigned i = 0; i != comps.size(); ++i)
1694 for (
unsigned i = 0; i != exprs.size(); ++i)
1712 OpLoc(op), RParenLoc(rp) {
1713 assert(ExprKind <=
UETT_Last &&
"invalid enum value!");
1716 "UnaryExprOrTypeTraitExprBits.Kind overflow!");
1730 :
Expr(MemberExprClass,
T, VK, OK),
Base(
Base), MemberDecl(MemberDecl),
1731 MemberDNLoc(NameInfo.
getInfo()), MemberLoc(NameInfo.getLoc()) {
1737 FoundDecl.getDecl() != MemberDecl ||
1740 TemplateArgs || TemplateKWLoc.
isValid();
1746 new (getTrailingObjects<NestedNameSpecifierLoc>())
1749 *getTrailingObjects<DeclAccessPair>() = FoundDecl;
1751 auto Deps = TemplateArgumentDependence::None;
1752 getTrailingObjects<ASTTemplateKWAndArgsInfo>()->initializeFrom(
1753 TemplateKWLoc, *TemplateArgs, getTrailingObjects<TemplateArgumentLoc>(),
1755 }
else if (TemplateKWLoc.
isValid()) {
1756 getTrailingObjects<ASTTemplateKWAndArgsInfo>()->initializeFrom(
1769 bool HasFoundDecl = FoundDecl.getDecl() != MemberDecl ||
1771 bool HasTemplateKWAndArgsInfo = TemplateArgs || TemplateKWLoc.
isValid();
1775 HasQualifier, HasFoundDecl, HasTemplateKWAndArgsInfo,
1776 TemplateArgs ? TemplateArgs->
size() : 0);
1778 void *Mem =
C.Allocate(Size,
alignof(
MemberExpr));
1779 return new (Mem)
MemberExpr(
Base, IsArrow, OperatorLoc, QualifierLoc,
1780 TemplateKWLoc, MemberDecl, FoundDecl, NameInfo,
1781 TemplateArgs,
T, VK, OK, NOUR);
1785 bool HasQualifier,
bool HasFoundDecl,
1786 bool HasTemplateKWAndArgsInfo,
1787 unsigned NumTemplateArgs) {
1788 assert((!NumTemplateArgs || HasTemplateKWAndArgsInfo) &&
1789 "template args but no template arg info?");
1793 HasQualifier, HasFoundDecl, HasTemplateKWAndArgsInfo,
1801 if (
getType()->isUndeducedType())
1817 return BaseStartLoc;
1829bool CastExpr::CastConsistency()
const {
1831 case CK_DerivedToBase:
1832 case CK_UncheckedDerivedToBase:
1833 case CK_DerivedToBaseMemberPointer:
1834 case CK_BaseToDerived:
1835 case CK_BaseToDerivedMemberPointer:
1836 assert(!
path_empty() &&
"Cast kind should have a base path!");
1839 case CK_CPointerToObjCPointerCast:
1840 assert(
getType()->isObjCObjectPointerType());
1842 goto CheckNoBasePath;
1844 case CK_BlockPointerToObjCPointerCast:
1845 assert(
getType()->isObjCObjectPointerType());
1847 goto CheckNoBasePath;
1849 case CK_ReinterpretMemberPointer:
1850 assert(
getType()->isMemberPointerType());
1852 goto CheckNoBasePath;
1858 if (!
getType()->isPointerType()) {
1859 assert(
getType()->isObjCObjectPointerType() ==
1861 assert(
getType()->isBlockPointerType() ==
1864 goto CheckNoBasePath;
1866 case CK_AnyPointerToBlockPointerCast:
1867 assert(
getType()->isBlockPointerType());
1870 goto CheckNoBasePath;
1872 case CK_CopyAndAutoreleaseBlockObject:
1873 assert(
getType()->isBlockPointerType());
1875 goto CheckNoBasePath;
1877 case CK_FunctionToPointerDecay:
1878 assert(
getType()->isPointerType());
1880 goto CheckNoBasePath;
1882 case CK_AddressSpaceConversion: {
1891 (!Ty.
isNull() && !SETy.isNull() &&
1893 goto CheckNoBasePath;
1898 case CK_ArrayToPointerDecay:
1899 case CK_NullToMemberPointer:
1900 case CK_NullToPointer:
1901 case CK_ConstructorConversion:
1902 case CK_IntegralToPointer:
1903 case CK_PointerToIntegral:
1905 case CK_VectorSplat:
1906 case CK_IntegralCast:
1907 case CK_BooleanToSignedIntegral:
1908 case CK_IntegralToFloating:
1909 case CK_FloatingToIntegral:
1910 case CK_FloatingCast:
1911 case CK_ObjCObjectLValueCast:
1912 case CK_FloatingRealToComplex:
1913 case CK_FloatingComplexToReal:
1914 case CK_FloatingComplexCast:
1915 case CK_FloatingComplexToIntegralComplex:
1916 case CK_IntegralRealToComplex:
1917 case CK_IntegralComplexToReal:
1918 case CK_IntegralComplexCast:
1919 case CK_IntegralComplexToFloatingComplex:
1920 case CK_ARCProduceObject:
1921 case CK_ARCConsumeObject:
1922 case CK_ARCReclaimReturnedObject:
1923 case CK_ARCExtendBlockObject:
1924 case CK_ZeroToOCLOpaqueType:
1925 case CK_IntToOCLSampler:
1926 case CK_FloatingToFixedPoint:
1927 case CK_FixedPointToFloating:
1928 case CK_FixedPointCast:
1929 case CK_FixedPointToIntegral:
1930 case CK_IntegralToFixedPoint:
1933 goto CheckNoBasePath;
1936 case CK_LValueToRValue:
1938 case CK_AtomicToNonAtomic:
1939 case CK_NonAtomicToAtomic:
1940 case CK_PointerToBoolean:
1941 case CK_IntegralToBoolean:
1942 case CK_FloatingToBoolean:
1943 case CK_MemberPointerToBoolean:
1944 case CK_FloatingComplexToBoolean:
1945 case CK_IntegralComplexToBoolean:
1946 case CK_LValueBitCast:
1947 case CK_LValueToRValueBitCast:
1948 case CK_UserDefinedConversion:
1949 case CK_BuiltinFnToFnPtr:
1950 case CK_FixedPointToBoolean:
1951 case CK_HLSLArrayRValue:
1952 case CK_HLSLVectorTruncation:
1954 assert(
path_empty() &&
"Cast kind should not have a base path!");
1962#define CAST_OPERATION(Name) case CK_##Name: return #Name;
1963#include "clang/AST/OperationKinds.def"
1965 llvm_unreachable(
"Unhandled cast kind!");
1971static Expr *ignoreImplicitSemaNodes(
Expr *
E) {
1972 if (
auto *Materialize = dyn_cast<MaterializeTemporaryExpr>(
E))
1973 return Materialize->getSubExpr();
1975 if (
auto *Binder = dyn_cast<CXXBindTemporaryExpr>(
E))
1976 return Binder->getSubExpr();
1978 if (
auto *Full = dyn_cast<FullExpr>(
E))
1979 return Full->getSubExpr();
1981 if (
auto *CPLIE = dyn_cast<CXXParenListInitExpr>(
E);
1982 CPLIE && CPLIE->getInitExprs().size() == 1)
1983 return CPLIE->getInitExprs()[0];
1990 const Expr *SubExpr =
nullptr;
1992 for (
const CastExpr *
E =
this;
E;
E = dyn_cast<ImplicitCastExpr>(SubExpr)) {
1997 if (
E->getCastKind() == CK_ConstructorConversion) {
1999 ignoreImplicitSemaNodes);
2000 }
else if (
E->getCastKind() == CK_UserDefinedConversion) {
2001 assert((isa<CallExpr, BlockExpr>(SubExpr)) &&
2002 "Unexpected SubExpr for CK_UserDefinedConversion.");
2003 if (
auto *MCE = dyn_cast<CXXMemberCallExpr>(SubExpr))
2004 SubExpr = MCE->getImplicitObjectArgument();
2008 return const_cast<Expr *
>(SubExpr);
2012 const Expr *SubExpr =
nullptr;
2014 for (
const CastExpr *
E =
this;
E;
E = dyn_cast<ImplicitCastExpr>(SubExpr)) {
2017 if (
E->getCastKind() == CK_ConstructorConversion)
2018 return cast<CXXConstructExpr>(SubExpr)->getConstructor();
2020 if (
E->getCastKind() == CK_UserDefinedConversion) {
2021 if (
auto *MCE = dyn_cast<CXXMemberCallExpr>(SubExpr))
2022 return MCE->getMethodDecl();
2031#define ABSTRACT_STMT(x)
2032#define CASTEXPR(Type, Base) \
2033 case Stmt::Type##Class: \
2034 return static_cast<Type *>(this)->getTrailingObjects<CXXBaseSpecifier *>();
2035#define STMT(Type, Base)
2036#include "clang/AST/StmtNodes.inc"
2038 llvm_unreachable(
"non-cast expressions not possible here");
2053 Field != FieldEnd; ++Field) {
2055 !Field->isUnnamedBitField()) {
2065 case ImplicitCastExprClass:
2067 ->getTrailingObjects<FPOptionsOverride>();
2068 case CStyleCastExprClass:
2070 ->getTrailingObjects<FPOptionsOverride>();
2071 case CXXFunctionalCastExprClass:
2073 ->getTrailingObjects<FPOptionsOverride>();
2074 case CXXStaticCastExprClass:
2076 ->getTrailingObjects<FPOptionsOverride>();
2078 llvm_unreachable(
"Cast does not have FPFeatures");
2087 unsigned PathSize = (BasePath ? BasePath->size() : 0);
2089 C.Allocate(totalSizeToAlloc<CXXBaseSpecifier *, FPOptionsOverride>(
2093 assert((Kind != CK_LValueToRValue ||
2095 "invalid type for lvalue-to-rvalue conversion");
2099 std::uninitialized_copy_n(BasePath->data(), BasePath->size(),
2106 bool HasFPFeatures) {
2108 C.Allocate(totalSizeToAlloc<CXXBaseSpecifier *, FPOptionsOverride>(
2109 PathSize, HasFPFeatures));
2119 unsigned PathSize = (BasePath ? BasePath->size() : 0);
2121 C.Allocate(totalSizeToAlloc<CXXBaseSpecifier *, FPOptionsOverride>(
2124 new (Buffer)
CStyleCastExpr(
T, VK, K, Op, PathSize, FPO, WrittenTy, L, R);
2126 std::uninitialized_copy_n(BasePath->data(), BasePath->size(),
2133 bool HasFPFeatures) {
2135 C.Allocate(totalSizeToAlloc<CXXBaseSpecifier *, FPOptionsOverride>(
2136 PathSize, HasFPFeatures));
2144#define BINARY_OPERATION(Name, Spelling) case BO_##Name: return Spelling;
2145#include "clang/AST/OperationKinds.def"
2147 llvm_unreachable(
"Invalid OpCode!");
2153 default: llvm_unreachable(
"Not an overloadable binary operator");
2154 case OO_Plus:
return BO_Add;
2155 case OO_Minus:
return BO_Sub;
2156 case OO_Star:
return BO_Mul;
2157 case OO_Slash:
return BO_Div;
2158 case OO_Percent:
return BO_Rem;
2159 case OO_Caret:
return BO_Xor;
2160 case OO_Amp:
return BO_And;
2161 case OO_Pipe:
return BO_Or;
2162 case OO_Equal:
return BO_Assign;
2163 case OO_Spaceship:
return BO_Cmp;
2164 case OO_Less:
return BO_LT;
2165 case OO_Greater:
return BO_GT;
2166 case OO_PlusEqual:
return BO_AddAssign;
2167 case OO_MinusEqual:
return BO_SubAssign;
2168 case OO_StarEqual:
return BO_MulAssign;
2169 case OO_SlashEqual:
return BO_DivAssign;
2170 case OO_PercentEqual:
return BO_RemAssign;
2171 case OO_CaretEqual:
return BO_XorAssign;
2172 case OO_AmpEqual:
return BO_AndAssign;
2173 case OO_PipeEqual:
return BO_OrAssign;
2174 case OO_LessLess:
return BO_Shl;
2175 case OO_GreaterGreater:
return BO_Shr;
2176 case OO_LessLessEqual:
return BO_ShlAssign;
2177 case OO_GreaterGreaterEqual:
return BO_ShrAssign;
2178 case OO_EqualEqual:
return BO_EQ;
2179 case OO_ExclaimEqual:
return BO_NE;
2180 case OO_LessEqual:
return BO_LE;
2181 case OO_GreaterEqual:
return BO_GE;
2182 case OO_AmpAmp:
return BO_LAnd;
2183 case OO_PipePipe:
return BO_LOr;
2184 case OO_Comma:
return BO_Comma;
2185 case OO_ArrowStar:
return BO_PtrMemI;
2192 OO_Star, OO_Slash, OO_Percent,
2194 OO_LessLess, OO_GreaterGreater,
2196 OO_Less, OO_Greater, OO_LessEqual, OO_GreaterEqual,
2197 OO_EqualEqual, OO_ExclaimEqual,
2203 OO_Equal, OO_StarEqual,
2204 OO_SlashEqual, OO_PercentEqual,
2205 OO_PlusEqual, OO_MinusEqual,
2206 OO_LessLessEqual, OO_GreaterGreaterEqual,
2207 OO_AmpEqual, OO_CaretEqual,
2211 return OverOps[Opc];
2253 BuiltinLoc(BLoc), RParenLoc(RParenLoc), ParentContext(ParentContext) {
2257 ? ExprDependence::Value
2258 : ExprDependence::None);
2264 return "__builtin_FILE";
2266 return "__builtin_FILE_NAME";
2268 return "__builtin_FUNCTION";
2270 return "__builtin_FUNCSIG";
2272 return "__builtin_LINE";
2274 return "__builtin_COLUMN";
2276 return "__builtin_source_location";
2278 llvm_unreachable(
"unexpected IdentKind!");
2282 const Expr *DefaultExpr)
const {
2286 if (
const auto *DIE = dyn_cast_if_present<CXXDefaultInitExpr>(DefaultExpr)) {
2287 Loc = DIE->getUsedLocation();
2288 Context = DIE->getUsedContext();
2289 }
else if (
const auto *DAE =
2290 dyn_cast_if_present<CXXDefaultArgExpr>(DefaultExpr)) {
2291 Loc = DAE->getUsedLocation();
2292 Context = DAE->getUsedContext();
2303 if (
const auto *
D = dyn_cast<CXXMethodDecl>(Context);
2305 Context =
D->getParent()->getParent();
2310 auto MakeStringLiteral = [&](StringRef Tmp) {
2314 LValuePathEntry
Path[1] = {LValuePathEntry::ArrayIndex(0)};
2325 return MakeStringLiteral(
FileName);
2331 return MakeStringLiteral(
Path);
2335 const auto *CurDecl = dyn_cast<Decl>(Context);
2339 return MakeStringLiteral(
2359 StringRef Name = F->getName();
2360 if (Name ==
"_M_file_name") {
2364 Value.getStructField(F->getFieldIndex()) = MakeStringLiteral(
Path);
2365 }
else if (Name ==
"_M_function_name") {
2368 const auto *CurDecl = dyn_cast<Decl>(Context);
2369 Value.getStructField(F->getFieldIndex()) = MakeStringLiteral(
2370 CurDecl && !isa<TranslationUnitDecl>(CurDecl)
2374 }
else if (Name ==
"_M_line") {
2376 Value.getStructField(F->getFieldIndex()) =
APValue(IntVal);
2377 }
else if (Name ==
"_M_column") {
2379 Value.getStructField(F->getFieldIndex()) =
APValue(IntVal);
2390 llvm_unreachable(
"unhandled case");
2395 unsigned NumOfElements)
2398 NumOfElements(NumOfElements) {
2407 InitExprs(
C, initExprs.size()), LBraceLoc(lbraceloc),
2408 RBraceLoc(rbraceloc), AltForm(nullptr,
true) {
2410 InitExprs.
insert(
C, InitExprs.
end(), initExprs.begin(), initExprs.end());
2416 if (NumInits > InitExprs.
size())
2421 InitExprs.
resize(
C, NumInits,
nullptr);
2438 ArrayFillerOrUnionFieldInit = filler;
2441 for (
unsigned i = 0, e =
getNumInits(); i != e; ++i)
2442 if (
inits[i] ==
nullptr)
2456 Init =
Init->IgnoreParenImpCasts();
2457 return isa<StringLiteral>(
Init) || isa<ObjCEncodeExpr>(
Init);
2461 assert(
isSemanticForm() &&
"syntactic form never semantically transparent");
2465 assert(
getNumInits() == 1 &&
"multiple inits in glvalue init list");
2484 assert(
isSyntacticForm() &&
"only test syntactic form as zero initializer");
2491 return Lit && Lit->
getValue() == 0;
2496 return SyntacticForm->getBeginLoc();
2501 E = InitExprs.
end();
2504 Beg = S->getBeginLoc();
2514 return SyntacticForm->getEndLoc();
2516 if (End.isInvalid()) {
2518 for (
Stmt *S : llvm::reverse(InitExprs)) {
2520 End = S->getEndLoc();
2532 return cast<BlockPointerType>(
getType())
2563 if (isa<DeclRefExpr>(
E))
2567 if (isa<ArraySubscriptExpr>(
E))
2571 if (isa<MemberExpr>(
E))
2575 if (
auto *UO = dyn_cast<UnaryOperator>(
E))
2576 if (UO->getOpcode() == UO_Deref)
2579 if (
auto *BO = dyn_cast<BinaryOperator>(
E)) {
2581 if (BO->isPtrMemOp())
2585 if (BO->getOpcode() == BO_Comma)
2586 return BO->getRHS()->isReadIfDiscardedInCPlusPlus11();
2591 if (
auto *CO = dyn_cast<ConditionalOperator>(
E))
2592 return CO->getTrueExpr()->isReadIfDiscardedInCPlusPlus11() &&
2593 CO->getFalseExpr()->isReadIfDiscardedInCPlusPlus11();
2596 dyn_cast<BinaryConditionalOperator>(
E)) {
2597 if (
auto *OVE = dyn_cast<OpaqueValueExpr>(BCO->getTrueExpr()))
2598 return OVE->getSourceExpr()->isReadIfDiscardedInCPlusPlus11() &&
2599 BCO->getFalseExpr()->isReadIfDiscardedInCPlusPlus11();
2603 if (isa<ObjCIvarRefExpr>(
E))
2605 if (
const auto *POE = dyn_cast<PseudoObjectExpr>(
E)) {
2606 if (isa<ObjCPropertyRefExpr, ObjCSubscriptRefExpr>(POE->getSyntacticForm()))
2633 case ParenExprClass:
2634 return cast<ParenExpr>(
this)->getSubExpr()->
2636 case GenericSelectionExprClass:
2637 return cast<GenericSelectionExpr>(
this)->getResultExpr()->
2639 case CoawaitExprClass:
2640 case CoyieldExprClass:
2641 return cast<CoroutineSuspendExpr>(
this)->getResumeExpr()->
2643 case ChooseExprClass:
2644 return cast<ChooseExpr>(
this)->getChosenSubExpr()->
2646 case UnaryOperatorClass: {
2680 case BinaryOperatorClass: {
2692 if (IE->getValue() == 0)
2711 case CompoundAssignOperatorClass:
2712 case VAArgExprClass:
2713 case AtomicExprClass:
2716 case ConditionalOperatorClass: {
2720 const auto *Exp = cast<ConditionalOperator>(
this);
2721 return Exp->getLHS()->isUnusedResultAWarning(WarnE,
Loc, R1, R2, Ctx) &&
2722 Exp->getRHS()->isUnusedResultAWarning(WarnE,
Loc, R1, R2, Ctx);
2724 case BinaryConditionalOperatorClass: {
2725 const auto *Exp = cast<BinaryConditionalOperator>(
this);
2726 return Exp->getFalseExpr()->isUnusedResultAWarning(WarnE,
Loc, R1, R2, Ctx);
2729 case MemberExprClass:
2731 Loc = cast<MemberExpr>(
this)->getMemberLoc();
2733 R2 = cast<MemberExpr>(
this)->getBase()->getSourceRange();
2736 case ArraySubscriptExprClass:
2738 Loc = cast<ArraySubscriptExpr>(
this)->getRBracketLoc();
2739 R1 = cast<ArraySubscriptExpr>(
this)->getLHS()->getSourceRange();
2740 R2 = cast<ArraySubscriptExpr>(
this)->getRHS()->getSourceRange();
2743 case CXXOperatorCallExprClass: {
2755 case OO_ExclaimEqual:
2758 case OO_GreaterEqual:
2773 case CXXMemberCallExprClass:
2774 case UserDefinedLiteralClass: {
2776 const CallExpr *CE = cast<CallExpr>(
this);
2784 FD->hasAttr<PureAttr>() || FD->hasAttr<ConstAttr>()) {
2799 case UnresolvedLookupExprClass:
2800 case CXXUnresolvedConstructExprClass:
2801 case RecoveryExprClass:
2804 case CXXTemporaryObjectExprClass:
2805 case CXXConstructExprClass: {
2807 const auto *WarnURAttr =
Type->getAttr<WarnUnusedResultAttr>();
2809 (WarnURAttr && WarnURAttr->IsCXX11NoDiscard())) {
2817 const auto *CE = cast<CXXConstructExpr>(
this);
2819 const auto *WarnURAttr = Ctor->getAttr<WarnUnusedResultAttr>();
2820 if (WarnURAttr && WarnURAttr->IsCXX11NoDiscard()) {
2825 if (
unsigned NumArgs = CE->getNumArgs())
2827 CE->getArg(NumArgs - 1)->getEndLoc());
2835 case ObjCMessageExprClass: {
2848 if (MD->hasAttr<WarnUnusedResultAttr>()) {
2857 case ObjCPropertyRefExprClass:
2858 case ObjCSubscriptRefExprClass:
2864 case PseudoObjectExprClass: {
2865 const auto *POE = cast<PseudoObjectExpr>(
this);
2868 if (isa<ObjCPropertyRefExpr, ObjCSubscriptRefExpr>(
2869 POE->getSyntacticForm())) {
2877 if (
auto *BO = dyn_cast<BinaryOperator>(POE->getSyntacticForm()))
2878 if (BO->isAssignmentOp())
2880 if (
auto *UO = dyn_cast<UnaryOperator>(POE->getSyntacticForm()))
2881 if (UO->isIncrementDecrementOp())
2886 return Result &&
Result->isUnusedResultAWarning(WarnE,
Loc, R1, R2, Ctx);
2889 case StmtExprClass: {
2895 const CompoundStmt *CS = cast<StmtExpr>(
this)->getSubStmt();
2900 if (
const Expr *
E = dyn_cast<Expr>(
Label->getSubStmt()))
2907 Loc = cast<StmtExpr>(
this)->getLParenLoc();
2911 case CXXFunctionalCastExprClass:
2912 case CStyleCastExprClass: {
2919 const CastExpr *CE = cast<CastExpr>(
this);
2926 if (
auto *DRE = dyn_cast<DeclRefExpr>(SubE))
2927 if (
auto *VD = dyn_cast<VarDecl>(DRE->getDecl()))
2928 if (!VD->isExternallyVisible())
2944 if (CE->
getCastKind() == CK_ConstructorConversion)
2951 dyn_cast<CXXFunctionalCastExpr>(
this)) {
2952 Loc = CXXCE->getBeginLoc();
2953 R1 = CXXCE->getSubExpr()->getSourceRange();
2961 case ImplicitCastExprClass: {
2962 const CastExpr *ICE = cast<ImplicitCastExpr>(
this);
2971 case CXXDefaultArgExprClass:
2972 return (cast<CXXDefaultArgExpr>(
this)
2974 case CXXDefaultInitExprClass:
2975 return (cast<CXXDefaultInitExpr>(
this)
2978 case CXXNewExprClass:
2981 case CXXDeleteExprClass:
2983 case MaterializeTemporaryExprClass:
2984 return cast<MaterializeTemporaryExpr>(
this)
2986 ->isUnusedResultAWarning(WarnE,
Loc, R1, R2, Ctx);
2987 case CXXBindTemporaryExprClass:
2988 return cast<CXXBindTemporaryExpr>(
this)->getSubExpr()
2989 ->isUnusedResultAWarning(WarnE,
Loc, R1, R2, Ctx);
2990 case ExprWithCleanupsClass:
2991 return cast<ExprWithCleanups>(
this)->getSubExpr()
2992 ->isUnusedResultAWarning(WarnE,
Loc, R1, R2, Ctx);
2993 case OpaqueValueExprClass:
2994 return cast<OpaqueValueExpr>(
this)->getSourceExpr()->isUnusedResultAWarning(
2995 WarnE,
Loc, R1, R2, Ctx);
3006 case ObjCIvarRefExprClass:
3008 case Expr::UnaryOperatorClass:
3009 return cast<UnaryOperator>(
E)->getSubExpr()->isOBJCGCCandidate(Ctx);
3010 case ImplicitCastExprClass:
3011 return cast<ImplicitCastExpr>(
E)->getSubExpr()->isOBJCGCCandidate(Ctx);
3012 case MaterializeTemporaryExprClass:
3013 return cast<MaterializeTemporaryExpr>(
E)->getSubExpr()->isOBJCGCCandidate(
3015 case CStyleCastExprClass:
3016 return cast<CStyleCastExpr>(
E)->getSubExpr()->isOBJCGCCandidate(Ctx);
3017 case DeclRefExprClass: {
3018 const Decl *
D = cast<DeclRefExpr>(
E)->getDecl();
3020 if (
const VarDecl *VD = dyn_cast<VarDecl>(
D)) {
3021 if (VD->hasGlobalStorage())
3031 case MemberExprClass: {
3035 case ArraySubscriptExprClass:
3036 return cast<ArraySubscriptExpr>(
E)->getBase()->isOBJCGCCandidate(Ctx);
3047 assert(
expr->hasPlaceholderType(BuiltinType::BoundMember));
3055 assert(isa<CXXMethodDecl>(mem->getMemberDecl()));
3056 return mem->getMemberDecl()->getType();
3062 assert(
type->isFunctionType());
3066 assert(isa<UnresolvedMemberExpr>(
expr) || isa<CXXPseudoDestructorExpr>(
expr));
3100 if (
auto *MCE = dyn_cast<CXXMemberCallExpr>(
this)) {
3101 if (isa_and_nonnull<CXXConversionDecl>(MCE->getMethodDecl()))
3102 return MCE->getImplicitObjectArgument();
3118 auto IgnoreNoopCastsSingleStep = [&Ctx](
Expr *
E) {
3119 if (
auto *CE = dyn_cast<CastExpr>(
E)) {
3122 Expr *SubExpr = CE->getSubExpr();
3123 bool IsIdentityCast =
3132 if (IsIdentityCast || IsSameWidthCast)
3134 }
else if (
auto *NTTP = dyn_cast<SubstNonTypeTemplateParmExpr>(
E))
3135 return NTTP->getReplacement();
3140 IgnoreNoopCastsSingleStep);
3145 if (
auto *Cast = dyn_cast<CXXFunctionalCastExpr>(
E)) {
3146 auto *SE = Cast->getSubExpr();
3151 if (
auto *
C = dyn_cast<CXXConstructExpr>(
E)) {
3152 auto NumArgs =
C->getNumArgs();
3154 (NumArgs > 1 && isa<CXXDefaultArgExpr>(
C->getArg(1)))) {
3155 Expr *A =
C->getArg(0);
3162 auto IgnoreImplicitMemberCallSingleStep = [](
Expr *
E) {
3163 if (
auto *
C = dyn_cast<CXXMemberCallExpr>(
E)) {
3164 Expr *ExprNode =
C->getImplicitObjectArgument();
3168 if (
auto *PE = dyn_cast<ParenExpr>(ExprNode)) {
3169 if (PE->getSourceRange() ==
C->getSourceRange()) {
3170 return cast<Expr>(PE);
3182 IgnoreImplicitMemberCallSingleStep);
3186 const Expr *
E =
this;
3188 E = M->getSubExpr();
3191 E = ICE->getSubExprAsWritten();
3193 return isa<CXXDefaultArgExpr>(
E);
3200 E = M->getSubExpr();
3203 if (ICE->getCastKind() == CK_NoOp)
3204 E = ICE->getSubExpr();
3210 E = BE->getSubExpr();
3213 if (ICE->getCastKind() == CK_NoOp)
3214 E = ICE->getSubExpr();
3225 if (!
C.hasSameUnqualifiedType(
getType(),
C.getTypeDeclType(TempTy)))
3233 if (!isa<ObjCPropertyRefExpr>(
E))
3241 if (isa<ImplicitCastExpr>(
E)) {
3242 switch (cast<ImplicitCastExpr>(
E)->getCastKind()) {
3243 case CK_DerivedToBase:
3244 case CK_UncheckedDerivedToBase:
3252 if (isa<MemberExpr>(
E))
3256 if (BO->isPtrMemOp())
3260 if (isa<OpaqueValueExpr>(
E))
3267 const Expr *
E =
this;
3277 if (ICE->getCastKind() == CK_NoOp ||
3278 ICE->getCastKind() == CK_LValueToRValue ||
3279 ICE->getCastKind() == CK_DerivedToBase ||
3280 ICE->getCastKind() == CK_UncheckedDerivedToBase) {
3281 E = ICE->getSubExpr();
3287 if (UnOp->getOpcode() == UO_Extension) {
3288 E = UnOp->getSubExpr();
3294 = dyn_cast<MaterializeTemporaryExpr>(
E)) {
3295 E = M->getSubExpr();
3302 if (
const CXXThisExpr *This = dyn_cast<CXXThisExpr>(
E))
3303 return This->isImplicit();
3311 for (
unsigned I = 0; I < Exprs.size(); ++I)
3319 const Expr **Culprit)
const {
3321 "Expression evaluator can't be called on a dependent expression.");
3333 if (
auto *EWC = dyn_cast<ExprWithCleanups>(
this))
3334 return EWC->getSubExpr()->isConstantInitializer(Ctx,
true, Culprit);
3335 if (
auto *MTE = dyn_cast<MaterializeTemporaryExpr>(
this))
3336 return MTE->getSubExpr()->isConstantInitializer(Ctx,
false, Culprit);
3347 case Stmt::ExprWithCleanupsClass:
3349 Ctx, IsForRef, Culprit);
3350 case StringLiteralClass:
3351 case ObjCEncodeExprClass:
3353 case CXXTemporaryObjectExprClass:
3354 case CXXConstructExprClass: {
3363 assert(CE->
getNumArgs() == 1 &&
"trivial ctor with > 1 argument");
3369 case ConstantExprClass: {
3372 const Expr *Exp = cast<ConstantExpr>(
this)->getSubExpr();
3375 case CompoundLiteralExprClass: {
3379 const Expr *Exp = cast<CompoundLiteralExpr>(
this)->getInitializer();
3382 case DesignatedInitUpdateExprClass: {
3387 case InitListExprClass: {
3395 assert(ILE->
isSemanticForm() &&
"InitListExpr must be in semantic form");
3398 for (
unsigned i = 0; i < numInits; i++) {
3406 unsigned ElementNo = 0;
3411 if (
const auto *CXXRD = dyn_cast<CXXRecordDecl>(RD)) {
3412 for (
unsigned i = 0, e = CXXRD->getNumBases(); i < e; i++) {
3413 if (ElementNo < ILE->getNumInits()) {
3421 for (
const auto *Field : RD->
fields()) {
3427 if (Field->isUnnamedBitField())
3430 if (ElementNo < ILE->getNumInits()) {
3432 if (Field->isBitField()) {
3441 bool RefType = Field->getType()->isReferenceType();
3452 case ImplicitValueInitExprClass:
3453 case NoInitExprClass:
3455 case ParenExprClass:
3456 return cast<ParenExpr>(
this)->getSubExpr()
3457 ->isConstantInitializer(Ctx, IsForRef, Culprit);
3458 case GenericSelectionExprClass:
3459 return cast<GenericSelectionExpr>(
this)->getResultExpr()
3460 ->isConstantInitializer(Ctx, IsForRef, Culprit);
3461 case ChooseExprClass:
3462 if (cast<ChooseExpr>(
this)->isConditionDependent()) {
3467 return cast<ChooseExpr>(
this)->getChosenSubExpr()
3469 case UnaryOperatorClass: {
3475 case PackIndexingExprClass: {
3476 return cast<PackIndexingExpr>(
this)
3478 ->isConstantInitializer(Ctx,
false, Culprit);
3480 case CXXFunctionalCastExprClass:
3481 case CXXStaticCastExprClass:
3482 case ImplicitCastExprClass:
3483 case CStyleCastExprClass:
3484 case ObjCBridgedCastExprClass:
3485 case CXXDynamicCastExprClass:
3486 case CXXReinterpretCastExprClass:
3487 case CXXAddrspaceCastExprClass:
3488 case CXXConstCastExprClass: {
3489 const CastExpr *CE = cast<CastExpr>(
this);
3504 case MaterializeTemporaryExprClass:
3505 return cast<MaterializeTemporaryExpr>(
this)
3507 ->isConstantInitializer(Ctx,
false, Culprit);
3509 case SubstNonTypeTemplateParmExprClass:
3510 return cast<SubstNonTypeTemplateParmExpr>(
this)->getReplacement()
3511 ->isConstantInitializer(Ctx,
false, Culprit);
3512 case CXXDefaultArgExprClass:
3513 return cast<CXXDefaultArgExpr>(
this)->getExpr()
3514 ->isConstantInitializer(Ctx,
false, Culprit);
3515 case CXXDefaultInitExprClass:
3516 return cast<CXXDefaultInitExpr>(
this)->getExpr()
3517 ->isConstantInitializer(Ctx,
false, Culprit);
3531 if (BuiltinID != Builtin::BI__assume &&
3532 BuiltinID != Builtin::BI__builtin_assume)
3549 const bool IncludePossibleEffects;
3550 bool HasSideEffects;
3553 explicit SideEffectFinder(
const ASTContext &Context,
bool IncludePossible)
3554 : Inherited(Context),
3555 IncludePossibleEffects(IncludePossible), HasSideEffects(
false) { }
3557 bool hasSideEffects()
const {
return HasSideEffects; }
3559 void VisitDecl(
const Decl *
D) {
3565 if (
auto *VD = dyn_cast<VarDecl>(
D)) {
3567 if (IncludePossibleEffects && VD->isThisDeclarationADefinition() &&
3568 VD->needsDestruction(Context))
3569 HasSideEffects =
true;
3573 void VisitDeclStmt(
const DeclStmt *DS) {
3574 for (
auto *
D : DS->
decls())
3576 Inherited::VisitDeclStmt(DS);
3579 void VisitExpr(
const Expr *
E) {
3580 if (!HasSideEffects &&
3582 HasSideEffects =
true;
3588 bool IncludePossibleEffects)
const {
3592 if (!IncludePossibleEffects &&
getExprLoc().isMacroID())
3597 #define ABSTRACT_STMT(Type)
3598 #define STMT(Type, Base) case Type##Class:
3599 #define EXPR(Type, Base)
3600 #include "clang/AST/StmtNodes.inc"
3601 llvm_unreachable(
"unexpected Expr kind");
3603 case DependentScopeDeclRefExprClass:
3604 case CXXUnresolvedConstructExprClass:
3605 case CXXDependentScopeMemberExprClass:
3606 case UnresolvedLookupExprClass:
3607 case UnresolvedMemberExprClass:
3608 case PackExpansionExprClass:
3609 case SubstNonTypeTemplateParmPackExprClass:
3610 case FunctionParmPackExprClass:
3612 case RecoveryExprClass:
3613 case CXXFoldExprClass:
3615 return IncludePossibleEffects;
3617 case DeclRefExprClass:
3618 case ObjCIvarRefExprClass:
3619 case PredefinedExprClass:
3620 case IntegerLiteralClass:
3621 case FixedPointLiteralClass:
3622 case FloatingLiteralClass:
3623 case ImaginaryLiteralClass:
3624 case StringLiteralClass:
3625 case CharacterLiteralClass:
3626 case OffsetOfExprClass:
3627 case ImplicitValueInitExprClass:
3628 case UnaryExprOrTypeTraitExprClass:
3629 case AddrLabelExprClass:
3630 case GNUNullExprClass:
3631 case ArrayInitIndexExprClass:
3632 case NoInitExprClass:
3633 case CXXBoolLiteralExprClass:
3634 case CXXNullPtrLiteralExprClass:
3635 case CXXThisExprClass:
3636 case CXXScalarValueInitExprClass:
3637 case TypeTraitExprClass:
3638 case ArrayTypeTraitExprClass:
3639 case ExpressionTraitExprClass:
3640 case CXXNoexceptExprClass:
3641 case SizeOfPackExprClass:
3642 case ObjCStringLiteralClass:
3643 case ObjCEncodeExprClass:
3644 case ObjCBoolLiteralExprClass:
3645 case ObjCAvailabilityCheckExprClass:
3646 case CXXUuidofExprClass:
3647 case OpaqueValueExprClass:
3648 case SourceLocExprClass:
3649 case EmbedExprClass:
3650 case ConceptSpecializationExprClass:
3651 case RequiresExprClass:
3652 case SYCLUniqueStableNameExprClass:
3653 case PackIndexingExprClass:
3654 case HLSLOutArgExprClass:
3655 case OpenACCAsteriskSizeExprClass:
3659 case ConstantExprClass:
3661 return cast<ConstantExpr>(
this)->getSubExpr()->HasSideEffects(
3662 Ctx, IncludePossibleEffects);
3665 case CXXOperatorCallExprClass:
3666 case CXXMemberCallExprClass:
3667 case CUDAKernelCallExprClass:
3668 case UserDefinedLiteralClass: {
3672 const Decl *FD = cast<CallExpr>(
this)->getCalleeDecl();
3673 bool IsPure = FD && (FD->
hasAttr<ConstAttr>() || FD->
hasAttr<PureAttr>());
3674 if (IsPure || !IncludePossibleEffects)
3679 case BlockExprClass:
3680 case CXXBindTemporaryExprClass:
3681 if (!IncludePossibleEffects)
3685 case MSPropertyRefExprClass:
3686 case MSPropertySubscriptExprClass:
3687 case CompoundAssignOperatorClass:
3688 case VAArgExprClass:
3689 case AtomicExprClass:
3690 case CXXThrowExprClass:
3691 case CXXNewExprClass:
3692 case CXXDeleteExprClass:
3693 case CoawaitExprClass:
3694 case DependentCoawaitExprClass:
3695 case CoyieldExprClass:
3699 case StmtExprClass: {
3701 SideEffectFinder Finder(Ctx, IncludePossibleEffects);
3702 Finder.Visit(cast<StmtExpr>(
this)->getSubStmt());
3703 return Finder.hasSideEffects();
3706 case ExprWithCleanupsClass:
3707 if (IncludePossibleEffects)
3708 if (cast<ExprWithCleanups>(
this)->cleanupsHaveSideEffects())
3712 case ParenExprClass:
3713 case ArraySubscriptExprClass:
3714 case MatrixSubscriptExprClass:
3715 case ArraySectionExprClass:
3716 case OMPArrayShapingExprClass:
3717 case OMPIteratorExprClass:
3718 case MemberExprClass:
3719 case ConditionalOperatorClass:
3720 case BinaryConditionalOperatorClass:
3721 case CompoundLiteralExprClass:
3722 case ExtVectorElementExprClass:
3723 case DesignatedInitExprClass:
3724 case DesignatedInitUpdateExprClass:
3725 case ArrayInitLoopExprClass:
3726 case ParenListExprClass:
3727 case CXXPseudoDestructorExprClass:
3728 case CXXRewrittenBinaryOperatorClass:
3729 case CXXStdInitializerListExprClass:
3730 case SubstNonTypeTemplateParmExprClass:
3731 case MaterializeTemporaryExprClass:
3732 case ShuffleVectorExprClass:
3733 case ConvertVectorExprClass:
3734 case AsTypeExprClass:
3735 case CXXParenListInitExprClass:
3739 case UnaryOperatorClass:
3740 if (cast<UnaryOperator>(
this)->isIncrementDecrementOp())
3744 case BinaryOperatorClass:
3745 if (cast<BinaryOperator>(
this)->isAssignmentOp())
3749 case InitListExprClass:
3751 if (
const Expr *
E = cast<InitListExpr>(
this)->getArrayFiller())
3756 case GenericSelectionExprClass:
3757 return cast<GenericSelectionExpr>(
this)->getResultExpr()->
3760 case ChooseExprClass:
3761 return cast<ChooseExpr>(
this)->getChosenSubExpr()->HasSideEffects(
3762 Ctx, IncludePossibleEffects);
3764 case CXXDefaultArgExprClass:
3765 return cast<CXXDefaultArgExpr>(
this)->getExpr()->HasSideEffects(
3766 Ctx, IncludePossibleEffects);
3768 case CXXDefaultInitExprClass: {
3769 const FieldDecl *FD = cast<CXXDefaultInitExpr>(
this)->getField();
3776 case CXXDynamicCastExprClass: {
3784 case ImplicitCastExprClass:
3785 case CStyleCastExprClass:
3786 case CXXStaticCastExprClass:
3787 case CXXReinterpretCastExprClass:
3788 case CXXConstCastExprClass:
3789 case CXXAddrspaceCastExprClass:
3790 case CXXFunctionalCastExprClass:
3791 case BuiltinBitCastExprClass: {
3796 if (!IncludePossibleEffects)
3799 const CastExpr *CE = cast<CastExpr>(
this);
3806 case CXXTypeidExprClass: {
3807 const auto *TE = cast<CXXTypeidExpr>(
this);
3808 if (!TE->isPotentiallyEvaluated())
3813 if (IncludePossibleEffects && TE->hasNullCheck())
3819 case CXXConstructExprClass:
3820 case CXXTemporaryObjectExprClass: {
3829 case CXXInheritedCtorInitExprClass: {
3830 const auto *ICIE = cast<CXXInheritedCtorInitExpr>(
this);
3831 if (!ICIE->getConstructor()->isTrivial() && IncludePossibleEffects)
3836 case LambdaExprClass: {
3837 const LambdaExpr *LE = cast<LambdaExpr>(
this);
3838 for (
Expr *
E : LE->capture_inits())
3844 case PseudoObjectExprClass: {
3851 const Expr *Subexpr = *I;
3853 Subexpr = OVE->getSourceExpr();
3860 case ObjCBoxedExprClass:
3861 case ObjCArrayLiteralClass:
3862 case ObjCDictionaryLiteralClass:
3863 case ObjCSelectorExprClass:
3864 case ObjCProtocolExprClass:
3865 case ObjCIsaExprClass:
3866 case ObjCIndirectCopyRestoreExprClass:
3867 case ObjCSubscriptRefExprClass:
3868 case ObjCBridgedCastExprClass:
3869 case ObjCMessageExprClass:
3870 case ObjCPropertyRefExprClass:
3872 if (IncludePossibleEffects)
3880 cast<Expr>(SubStmt)->
HasSideEffects(Ctx, IncludePossibleEffects))
3887 if (
auto Call = dyn_cast<CallExpr>(
this))
3888 return Call->getFPFeaturesInEffect(LO);
3889 if (
auto UO = dyn_cast<UnaryOperator>(
this))
3890 return UO->getFPFeaturesInEffect(LO);
3891 if (
auto BO = dyn_cast<BinaryOperator>(
this))
3892 return BO->getFPFeaturesInEffect(LO);
3893 if (
auto Cast = dyn_cast<CastExpr>(
this))
3894 return Cast->getFPFeaturesInEffect(LO);
3907 explicit NonTrivialCallFinder(
const ASTContext &Context)
3908 : Inherited(Context), NonTrivial(
false) { }
3910 bool hasNonTrivialCall()
const {
return NonTrivial; }
3914 = dyn_cast_or_null<const CXXMethodDecl>(
E->getCalleeDecl())) {
3915 if (Method->isTrivial()) {
3917 Inherited::VisitStmt(
E);
3926 if (
E->getConstructor()->isTrivial()) {
3928 Inherited::VisitStmt(
E);
3939 E->getTemporary()->getDestructor()) {
3940 if (DtorDecl->isTrivial()) {
3941 Inherited::VisitStmt(
E);
3952 NonTrivialCallFinder Finder(Ctx);
3954 return Finder.hasNonTrivialCall();
3972 llvm_unreachable(
"Unexpected value dependent expression!");
4000 CE->getSubExpr()->getType()->isIntegerType())
4001 return CE->getSubExpr()->isNullPointerConstant(Ctx, NPC);
4004 }
else if (
const ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(
this)) {
4006 return ICE->getSubExpr()->isNullPointerConstant(Ctx, NPC);
4007 }
else if (
const ParenExpr *PE = dyn_cast<ParenExpr>(
this)) {
4010 return PE->getSubExpr()->isNullPointerConstant(Ctx, NPC);
4012 dyn_cast<GenericSelectionExpr>(
this)) {
4013 if (GE->isResultDependent())
4015 return GE->getResultExpr()->isNullPointerConstant(Ctx, NPC);
4016 }
else if (
const ChooseExpr *CE = dyn_cast<ChooseExpr>(
this)) {
4017 if (CE->isConditionDependent())
4019 return CE->getChosenSubExpr()->isNullPointerConstant(Ctx, NPC);
4021 = dyn_cast<CXXDefaultArgExpr>(
this)) {
4023 return DefaultArg->getExpr()->isNullPointerConstant(Ctx, NPC);
4025 = dyn_cast<CXXDefaultInitExpr>(
this)) {
4027 return DefaultInit->getExpr()->isNullPointerConstant(Ctx, NPC);
4028 }
else if (isa<GNUNullExpr>(
this)) {
4032 = dyn_cast<MaterializeTemporaryExpr>(
this)) {
4033 return M->getSubExpr()->isNullPointerConstant(Ctx, NPC);
4034 }
else if (
const OpaqueValueExpr *OVE = dyn_cast<OpaqueValueExpr>(
this)) {
4035 if (
const Expr *Source = OVE->getSourceExpr())
4036 return Source->isNullPointerConstant(Ctx, NPC);
4045 if (
getType()->isNullPtrType())
4050 UT && UT->getDecl()->hasAttr<TransparentUnionAttr>())
4052 const Expr *InitExpr = CLE->getInitializer();
4053 if (
const InitListExpr *ILE = dyn_cast<InitListExpr>(InitExpr))
4057 if (!
getType()->isIntegerType() ||
4080 if (isa<IntegerLiteral>(
this))
4088 const Expr *
E =
this;
4091 "expression is not a property reference");
4094 if (BO->getOpcode() == BO_Comma) {
4103 return cast<ObjCPropertyRefExpr>(
E);
4128 if (ICE->getCastKind() == CK_LValueToRValue ||
4129 (ICE->isGLValue() && ICE->getCastKind() == CK_NoOp))
4136 if (
FieldDecl *Field = dyn_cast<FieldDecl>(MemRef->getMemberDecl()))
4137 if (Field->isBitField())
4147 if (
FieldDecl *Field = dyn_cast<FieldDecl>(DeclRef->getDecl()))
4148 if (Field->isBitField())
4151 if (
BindingDecl *BD = dyn_cast<BindingDecl>(DeclRef->getDecl()))
4152 if (
Expr *
E = BD->getBinding())
4157 if (BinOp->isAssignmentOp() && BinOp->getLHS())
4158 return BinOp->getLHS()->getSourceBitField();
4160 if (BinOp->getOpcode() == BO_Comma && BinOp->getRHS())
4161 return BinOp->getRHS()->getSourceBitField();
4165 if (UnOp->isPrefix() && UnOp->isIncrementDecrementOp())
4166 return UnOp->getSubExpr()->getSourceBitField();
4173 if (
auto *DRE = dyn_cast<DeclRefExpr>(
E))
4174 return dyn_cast<EnumConstantDecl>(DRE->getDecl());
4183 if (ICE->isGLValue() && ICE->getCastKind() == CK_NoOp)
4192 if (isa<ExtVectorElementExpr>(
E))
4195 if (
auto *DRE = dyn_cast<DeclRefExpr>(
E))
4196 if (
auto *BD = dyn_cast<BindingDecl>(DRE->getDecl()))
4197 if (
auto *
E = BD->getBinding())
4207 if (
const auto *VD = dyn_cast<VarDecl>(DRE->getDecl()))
4209 VD->hasAttr<AsmLabelAttr>() && !VD->isLocalVarDecl())
4225 case CXXThisExprClass:
4227 case DeclRefExprClass: {
4230 const auto *DRE1 = cast<DeclRefExpr>(E1);
4231 const auto *DRE2 = cast<DeclRefExpr>(E2);
4232 return DRE1->isPRValue() && DRE2->isPRValue() &&
4233 DRE1->getDecl() == DRE2->getDecl();
4235 case ImplicitCastExprClass: {
4238 const auto *ICE1 = dyn_cast<ImplicitCastExpr>(E1);
4239 const auto *ICE2 = dyn_cast<ImplicitCastExpr>(E2);
4242 if (ICE1->getCastKind() != ICE2->getCastKind())
4247 if (ICE1->getCastKind() == CK_LValueToRValue ||
4248 ICE1->getCastKind() == CK_ArrayToPointerDecay ||
4249 ICE1->getCastKind() == CK_FunctionToPointerDecay) {
4254 const auto *DRE1 = dyn_cast<DeclRefExpr>(E1);
4255 const auto *DRE2 = dyn_cast<DeclRefExpr>(E2);
4259 const auto *Ivar1 = dyn_cast<ObjCIvarRefExpr>(E1);
4260 const auto *Ivar2 = dyn_cast<ObjCIvarRefExpr>(E2);
4261 if (Ivar1 && Ivar2) {
4262 return Ivar1->isFreeIvar() && Ivar2->isFreeIvar() &&
4266 const auto *Array1 = dyn_cast<ArraySubscriptExpr>(E1);
4267 const auto *Array2 = dyn_cast<ArraySubscriptExpr>(E2);
4268 if (Array1 && Array2) {
4272 auto Idx1 = Array1->getIdx();
4273 auto Idx2 = Array2->getIdx();
4274 const auto Integer1 = dyn_cast<IntegerLiteral>(Idx1);
4275 const auto Integer2 = dyn_cast<IntegerLiteral>(Idx2);
4276 if (Integer1 && Integer2) {
4277 if (!llvm::APInt::isSameValue(Integer1->getValue(),
4278 Integer2->getValue()))
4289 while (isa<MemberExpr>(E1) && isa<MemberExpr>(E2)) {
4290 const auto *ME1 = cast<MemberExpr>(E1);
4291 const auto *ME2 = cast<MemberExpr>(E2);
4294 if (
const auto *
D = dyn_cast<VarDecl>(ME1->getMemberDecl()))
4295 if (
D->isStaticDataMember())
4301 if (isa<CXXThisExpr>(E1) && isa<CXXThisExpr>(E2))
4307 if (
const auto *DRE = dyn_cast<DeclRefExpr>(
E))
4308 return DRE->getDecl();
4309 if (
const auto *ME = dyn_cast<MemberExpr>(
E))
4310 return ME->getMemberDecl();
4329 return VT->getNumElements();
4337 StringRef Comp = Accessor->
getName();
4340 if (Comp ==
"hi" || Comp ==
"lo" || Comp ==
"even" || Comp ==
"odd")
4344 if (Comp[0] ==
's' || Comp[0] ==
'S')
4345 Comp = Comp.substr(1);
4347 for (
unsigned i = 0, e = Comp.size(); i != e; ++i)
4348 if (Comp.substr(i + 1).contains(Comp[i]))
4357 StringRef Comp = Accessor->
getName();
4358 bool isNumericAccessor =
false;
4359 if (Comp[0] ==
's' || Comp[0] ==
'S') {
4360 Comp = Comp.substr(1);
4361 isNumericAccessor =
true;
4364 bool isHi = Comp ==
"hi";
4365 bool isLo = Comp ==
"lo";
4366 bool isEven = Comp ==
"even";
4367 bool isOdd = Comp ==
"odd";
4383 Elts.push_back(Index);
4391 BuiltinLoc(BLoc), RParenLoc(RP), NumExprs(args.size()) {
4392 SubExprs =
new (
C)
Stmt*[args.size()];
4393 for (
unsigned i = 0; i != args.size(); i++)
4394 SubExprs[i] = args[i];
4400 if (SubExprs)
C.Deallocate(SubExprs);
4402 this->NumExprs = Exprs.size();
4403 SubExprs =
new (
C)
Stmt*[NumExprs];
4404 memcpy(SubExprs, Exprs.data(),
sizeof(
Expr *) * Exprs.size());
4407GenericSelectionExpr::GenericSelectionExpr(
4411 bool ContainsUnexpandedParameterPack,
unsigned ResultIndex)
4412 :
Expr(GenericSelectionExprClass, AssocExprs[ResultIndex]->getType(),
4413 AssocExprs[ResultIndex]->getValueKind(),
4414 AssocExprs[ResultIndex]->getObjectKind()),
4415 NumAssocs(AssocExprs.size()), ResultIndex(ResultIndex),
4416 IsExprPredicate(
true), DefaultLoc(DefaultLoc), RParenLoc(RParenLoc) {
4417 assert(AssocTypes.size() == AssocExprs.size() &&
4418 "Must have the same number of association expressions"
4419 " and TypeSourceInfo!");
4420 assert(ResultIndex < NumAssocs &&
"ResultIndex is out-of-bounds!");
4423 getTrailingObjects<Stmt *>()[getIndexOfControllingExpression()] =
4425 std::copy(AssocExprs.begin(), AssocExprs.end(),
4426 getTrailingObjects<Stmt *>() + getIndexOfStartOfAssociatedExprs());
4427 std::copy(AssocTypes.begin(), AssocTypes.end(),
4428 getTrailingObjects<TypeSourceInfo *>() +
4429 getIndexOfStartOfAssociatedTypes());
4434GenericSelectionExpr::GenericSelectionExpr(
4439 unsigned ResultIndex)
4440 :
Expr(GenericSelectionExprClass, AssocExprs[ResultIndex]->getType(),
4441 AssocExprs[ResultIndex]->getValueKind(),
4442 AssocExprs[ResultIndex]->getObjectKind()),
4443 NumAssocs(AssocExprs.size()), ResultIndex(ResultIndex),
4444 IsExprPredicate(
false), DefaultLoc(DefaultLoc), RParenLoc(RParenLoc) {
4445 assert(AssocTypes.size() == AssocExprs.size() &&
4446 "Must have the same number of association expressions"
4447 " and TypeSourceInfo!");
4448 assert(ResultIndex < NumAssocs &&
"ResultIndex is out-of-bounds!");
4451 getTrailingObjects<TypeSourceInfo *>()[getIndexOfControllingType()] =
4453 std::copy(AssocExprs.begin(), AssocExprs.end(),
4454 getTrailingObjects<Stmt *>() + getIndexOfStartOfAssociatedExprs());
4455 std::copy(AssocTypes.begin(), AssocTypes.end(),
4456 getTrailingObjects<TypeSourceInfo *>() +
4457 getIndexOfStartOfAssociatedTypes());
4462GenericSelectionExpr::GenericSelectionExpr(
4466 bool ContainsUnexpandedParameterPack)
4467 :
Expr(GenericSelectionExprClass, Context.DependentTy,
VK_PRValue,
4469 NumAssocs(AssocExprs.size()), ResultIndex(ResultDependentIndex),
4470 IsExprPredicate(
true), DefaultLoc(DefaultLoc), RParenLoc(RParenLoc) {
4471 assert(AssocTypes.size() == AssocExprs.size() &&
4472 "Must have the same number of association expressions"
4473 " and TypeSourceInfo!");
4476 getTrailingObjects<Stmt *>()[getIndexOfControllingExpression()] =
4478 std::copy(AssocExprs.begin(), AssocExprs.end(),
4479 getTrailingObjects<Stmt *>() + getIndexOfStartOfAssociatedExprs());
4480 std::copy(AssocTypes.begin(), AssocTypes.end(),
4481 getTrailingObjects<TypeSourceInfo *>() +
4482 getIndexOfStartOfAssociatedTypes());
4487GenericSelectionExpr::GenericSelectionExpr(
4492 :
Expr(GenericSelectionExprClass, Context.DependentTy,
VK_PRValue,
4494 NumAssocs(AssocExprs.size()), ResultIndex(ResultDependentIndex),
4495 IsExprPredicate(
false), DefaultLoc(DefaultLoc), RParenLoc(RParenLoc) {
4496 assert(AssocTypes.size() == AssocExprs.size() &&
4497 "Must have the same number of association expressions"
4498 " and TypeSourceInfo!");
4501 getTrailingObjects<TypeSourceInfo *>()[getIndexOfControllingType()] =
4503 std::copy(AssocExprs.begin(), AssocExprs.end(),
4504 getTrailingObjects<Stmt *>() + getIndexOfStartOfAssociatedExprs());
4505 std::copy(AssocTypes.begin(), AssocTypes.end(),
4506 getTrailingObjects<TypeSourceInfo *>() +
4507 getIndexOfStartOfAssociatedTypes());
4512GenericSelectionExpr::GenericSelectionExpr(EmptyShell
Empty,
unsigned NumAssocs)
4513 :
Expr(GenericSelectionExprClass,
Empty), NumAssocs(NumAssocs) {}
4519 bool ContainsUnexpandedParameterPack,
unsigned ResultIndex) {
4520 unsigned NumAssocs = AssocExprs.size();
4522 totalSizeToAlloc<Stmt *, TypeSourceInfo *>(1 + NumAssocs, NumAssocs),
4525 Context, GenericLoc, ControllingExpr, AssocTypes, AssocExprs, DefaultLoc,
4526 RParenLoc, ContainsUnexpandedParameterPack, ResultIndex);
4533 bool ContainsUnexpandedParameterPack) {
4534 unsigned NumAssocs = AssocExprs.size();
4536 totalSizeToAlloc<Stmt *, TypeSourceInfo *>(1 + NumAssocs, NumAssocs),
4539 Context, GenericLoc, ControllingExpr, AssocTypes, AssocExprs, DefaultLoc,
4540 RParenLoc, ContainsUnexpandedParameterPack);
4548 unsigned ResultIndex) {
4549 unsigned NumAssocs = AssocExprs.size();
4551 totalSizeToAlloc<Stmt *, TypeSourceInfo *>(1 + NumAssocs, NumAssocs),
4554 Context, GenericLoc, ControllingType, AssocTypes, AssocExprs, DefaultLoc,
4555 RParenLoc, ContainsUnexpandedParameterPack, ResultIndex);
4562 SourceLocation RParenLoc,
bool ContainsUnexpandedParameterPack) {
4563 unsigned NumAssocs = AssocExprs.size();
4565 totalSizeToAlloc<Stmt *, TypeSourceInfo *>(1 + NumAssocs, NumAssocs),
4568 Context, GenericLoc, ControllingType, AssocTypes, AssocExprs, DefaultLoc,
4569 RParenLoc, ContainsUnexpandedParameterPack);
4574 unsigned NumAssocs) {
4576 totalSizeToAlloc<Stmt *, TypeSourceInfo *>(1 + NumAssocs, NumAssocs),
4599 EqualOrColonLoc(EqualOrColonLoc), GNUSyntax(GNUSyntax),
4600 NumDesignators(Designators.
size()), NumSubExprs(IndexExprs.
size() + 1) {
4601 this->Designators =
new (
C)
Designator[NumDesignators];
4609 unsigned IndexIdx = 0;
4610 for (
unsigned I = 0; I != NumDesignators; ++I) {
4611 this->Designators[I] = Designators[I];
4614 *Child++ = IndexExprs[IndexIdx++];
4617 *Child++ = IndexExprs[IndexIdx++];
4618 *Child++ = IndexExprs[IndexIdx++];
4622 assert(IndexIdx == IndexExprs.size() &&
"Wrong number of index expressions");
4631 bool UsesColonSyntax,
Expr *
Init) {
4632 void *Mem =
C.Allocate(totalSizeToAlloc<Stmt *>(IndexExprs.size() + 1),
4635 ColonOrEqualLoc, UsesColonSyntax,
4640 unsigned NumIndexExprs) {
4641 void *Mem =
C.Allocate(totalSizeToAlloc<Stmt *>(NumIndexExprs + 1),
4648 unsigned NumDesigs) {
4650 NumDesignators = NumDesigs;
4651 for (
unsigned I = 0; I != NumDesigs; ++I)
4652 Designators[I] = Desigs[I];
4666 if (
First.isFieldDesignator()) {
4669 for (
unsigned int i = 0; i < DIE->size(); i++) {
4677 return First.getLBracketLoc();
4685 assert(
D.isArrayDesignator() &&
"Requires array designator");
4690 assert(
D.isArrayRangeDesignator() &&
"Requires array range designator");
4695 assert(
D.isArrayRangeDesignator() &&
"Requires array range designator");
4704 unsigned NumNewDesignators =
Last -
First;
4705 if (NumNewDesignators == 0) {
4706 std::copy_backward(Designators + Idx + 1,
4707 Designators + NumDesignators,
4709 --NumNewDesignators;
4712 if (NumNewDesignators == 1) {
4713 Designators[Idx] = *
First;
4718 =
new (
C)
Designator[NumDesignators - 1 + NumNewDesignators];
4719 std::copy(Designators, Designators + Idx, NewDesignators);
4720 std::copy(
First,
Last, NewDesignators + Idx);
4721 std::copy(Designators + Idx + 1, Designators + NumDesignators,
4722 NewDesignators + Idx + NumNewDesignators);
4723 Designators = NewDesignators;
4724 NumDesignators = NumDesignators - 1 + NumNewDesignators;
4733 BaseAndUpdaterExprs[0] = baseExpr;
4737 BaseAndUpdaterExprs[1] = ILE;
4754 LParenLoc(LParenLoc), RParenLoc(RParenLoc) {
4757 for (
unsigned I = 0, N = Exprs.size(); I != N; ++I)
4758 getTrailingObjects<Stmt *>()[I] = Exprs[I];
4762ParenListExpr::ParenListExpr(EmptyShell
Empty,
unsigned NumExprs)
4771 void *Mem = Ctx.
Allocate(totalSizeToAlloc<Stmt *>(Exprs.size()),
4773 return new (Mem)
ParenListExpr(LParenLoc, Exprs, RParenLoc);
4777 unsigned NumExprs) {
4787static std::optional<BinaryOperator *>
4790 if (
E->getOpcode() == BO_LT) {
4792 ComparedTo =
E->getRHS();
4793 }
else if (
E->getOpcode() == BO_GT) {
4795 ComparedTo =
E->getLHS();
4800 const Expr *AddLHS =
nullptr, *AddRHS =
nullptr;
4803 if (BO && BO->
getOpcode() == clang::BO_Add) {
4809 if (!AddLHS || !AddRHS)
4812 const Decl *LHSDecl, *RHSDecl, *OtherDecl;
4815 RHSDecl = AddRHS->IgnoreParenImpCasts()->getReferencedDeclOfCallee();
4821 if (!LHSDecl && !RHSDecl)
4824 if ((LHSDecl && LHSDecl == OtherDecl && LHSDecl != RHSDecl) ||
4825 (RHSDecl && RHSDecl == OtherDecl && RHSDecl != LHSDecl))
4847 Result.value()->setExcludedOverflowPattern(
true);
4854 :
Expr(BinaryOperatorClass, ResTy, VK, OK) {
4857 "Use CompoundAssignOperator for compound assignments");
4860 SubExprs[LHS] = lhs;
4861 SubExprs[RHS] = rhs;
4873 :
Expr(CompoundAssignOperatorClass, ResTy, VK, OK) {
4877 "Use CompoundAssignOperator for compound assignments");
4879 SubExprs[LHS] = lhs;
4880 SubExprs[RHS] = rhs;
4888 bool HasFPFeatures) {