1 //===--- SemaExpr.cpp - Semantic Analysis for Expressions -----------------===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is distributed under the University of Illinois Open Source 6 // License. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 // 10 // This file implements semantic analysis for expressions. 11 // 12 //===----------------------------------------------------------------------===// 13 14 #include "clang/Sema/SemaInternal.h" 15 #include "TreeTransform.h" 16 #include "clang/AST/ASTConsumer.h" 17 #include "clang/AST/ASTContext.h" 18 #include "clang/AST/ASTLambda.h" 19 #include "clang/AST/ASTMutationListener.h" 20 #include "clang/AST/CXXInheritance.h" 21 #include "clang/AST/DeclObjC.h" 22 #include "clang/AST/DeclTemplate.h" 23 #include "clang/AST/EvaluatedExprVisitor.h" 24 #include "clang/AST/Expr.h" 25 #include "clang/AST/ExprCXX.h" 26 #include "clang/AST/ExprObjC.h" 27 #include "clang/AST/RecursiveASTVisitor.h" 28 #include "clang/AST/TypeLoc.h" 29 #include "clang/Basic/PartialDiagnostic.h" 30 #include "clang/Basic/SourceManager.h" 31 #include "clang/Basic/TargetInfo.h" 32 #include "clang/Lex/LiteralSupport.h" 33 #include "clang/Lex/Preprocessor.h" 34 #include "clang/Sema/AnalysisBasedWarnings.h" 35 #include "clang/Sema/DeclSpec.h" 36 #include "clang/Sema/DelayedDiagnostic.h" 37 #include "clang/Sema/Designator.h" 38 #include "clang/Sema/Initialization.h" 39 #include "clang/Sema/Lookup.h" 40 #include "clang/Sema/ParsedTemplate.h" 41 #include "clang/Sema/Scope.h" 42 #include "clang/Sema/ScopeInfo.h" 43 #include "clang/Sema/SemaFixItUtils.h" 44 #include "clang/Sema/Template.h" 45 #include "llvm/Support/ConvertUTF.h" 46 using namespace clang; 47 using namespace sema; 48 49 /// \brief Determine whether the use of this declaration is valid, without 50 /// emitting diagnostics. 51 bool Sema::CanUseDecl(NamedDecl *D) { 52 // See if this is an auto-typed variable whose initializer we are parsing. 53 if (ParsingInitForAutoVars.count(D)) 54 return false; 55 56 // See if this is a deleted function. 57 if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) { 58 if (FD->isDeleted()) 59 return false; 60 61 // If the function has a deduced return type, and we can't deduce it, 62 // then we can't use it either. 63 if (getLangOpts().CPlusPlus14 && FD->getReturnType()->isUndeducedType() && 64 DeduceReturnType(FD, SourceLocation(), /*Diagnose*/ false)) 65 return false; 66 } 67 68 // See if this function is unavailable. 69 if (D->getAvailability() == AR_Unavailable && 70 cast<Decl>(CurContext)->getAvailability() != AR_Unavailable) 71 return false; 72 73 return true; 74 } 75 76 static void DiagnoseUnusedOfDecl(Sema &S, NamedDecl *D, SourceLocation Loc) { 77 // Warn if this is used but marked unused. 78 if (D->hasAttr<UnusedAttr>()) { 79 const Decl *DC = cast_or_null<Decl>(S.getCurObjCLexicalContext()); 80 if (DC && !DC->hasAttr<UnusedAttr>()) 81 S.Diag(Loc, diag::warn_used_but_marked_unused) << D->getDeclName(); 82 } 83 } 84 85 static AvailabilityResult DiagnoseAvailabilityOfDecl(Sema &S, 86 NamedDecl *D, SourceLocation Loc, 87 const ObjCInterfaceDecl *UnknownObjCClass, 88 bool ObjCPropertyAccess) { 89 // See if this declaration is unavailable or deprecated. 90 std::string Message; 91 92 // Forward class declarations get their attributes from their definition. 93 if (ObjCInterfaceDecl *IDecl = dyn_cast<ObjCInterfaceDecl>(D)) { 94 if (IDecl->getDefinition()) 95 D = IDecl->getDefinition(); 96 } 97 AvailabilityResult Result = D->getAvailability(&Message); 98 if (const EnumConstantDecl *ECD = dyn_cast<EnumConstantDecl>(D)) 99 if (Result == AR_Available) { 100 const DeclContext *DC = ECD->getDeclContext(); 101 if (const EnumDecl *TheEnumDecl = dyn_cast<EnumDecl>(DC)) 102 Result = TheEnumDecl->getAvailability(&Message); 103 } 104 105 const ObjCPropertyDecl *ObjCPDecl = nullptr; 106 if (Result == AR_Deprecated || Result == AR_Unavailable) { 107 if (const ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(D)) { 108 if (const ObjCPropertyDecl *PD = MD->findPropertyDecl()) { 109 AvailabilityResult PDeclResult = PD->getAvailability(nullptr); 110 if (PDeclResult == Result) 111 ObjCPDecl = PD; 112 } 113 } 114 } 115 116 switch (Result) { 117 case AR_Available: 118 case AR_NotYetIntroduced: 119 break; 120 121 case AR_Deprecated: 122 if (S.getCurContextAvailability() != AR_Deprecated) 123 S.EmitAvailabilityWarning(Sema::AD_Deprecation, 124 D, Message, Loc, UnknownObjCClass, ObjCPDecl, 125 ObjCPropertyAccess); 126 break; 127 128 case AR_Unavailable: 129 if (S.getCurContextAvailability() != AR_Unavailable) 130 S.EmitAvailabilityWarning(Sema::AD_Unavailable, 131 D, Message, Loc, UnknownObjCClass, ObjCPDecl, 132 ObjCPropertyAccess); 133 break; 134 135 } 136 return Result; 137 } 138 139 /// \brief Emit a note explaining that this function is deleted. 140 void Sema::NoteDeletedFunction(FunctionDecl *Decl) { 141 assert(Decl->isDeleted()); 142 143 CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(Decl); 144 145 if (Method && Method->isDeleted() && Method->isDefaulted()) { 146 // If the method was explicitly defaulted, point at that declaration. 147 if (!Method->isImplicit()) 148 Diag(Decl->getLocation(), diag::note_implicitly_deleted); 149 150 // Try to diagnose why this special member function was implicitly 151 // deleted. This might fail, if that reason no longer applies. 152 CXXSpecialMember CSM = getSpecialMember(Method); 153 if (CSM != CXXInvalid) 154 ShouldDeleteSpecialMember(Method, CSM, /*Diagnose=*/true); 155 156 return; 157 } 158 159 if (CXXConstructorDecl *CD = dyn_cast<CXXConstructorDecl>(Decl)) { 160 if (CXXConstructorDecl *BaseCD = 161 const_cast<CXXConstructorDecl*>(CD->getInheritedConstructor())) { 162 Diag(Decl->getLocation(), diag::note_inherited_deleted_here); 163 if (BaseCD->isDeleted()) { 164 NoteDeletedFunction(BaseCD); 165 } else { 166 // FIXME: An explanation of why exactly it can't be inherited 167 // would be nice. 168 Diag(BaseCD->getLocation(), diag::note_cannot_inherit); 169 } 170 return; 171 } 172 } 173 174 Diag(Decl->getLocation(), diag::note_availability_specified_here) 175 << Decl << true; 176 } 177 178 /// \brief Determine whether a FunctionDecl was ever declared with an 179 /// explicit storage class. 180 static bool hasAnyExplicitStorageClass(const FunctionDecl *D) { 181 for (auto I : D->redecls()) { 182 if (I->getStorageClass() != SC_None) 183 return true; 184 } 185 return false; 186 } 187 188 /// \brief Check whether we're in an extern inline function and referring to a 189 /// variable or function with internal linkage (C11 6.7.4p3). 190 /// 191 /// This is only a warning because we used to silently accept this code, but 192 /// in many cases it will not behave correctly. This is not enabled in C++ mode 193 /// because the restriction language is a bit weaker (C++11 [basic.def.odr]p6) 194 /// and so while there may still be user mistakes, most of the time we can't 195 /// prove that there are errors. 196 static void diagnoseUseOfInternalDeclInInlineFunction(Sema &S, 197 const NamedDecl *D, 198 SourceLocation Loc) { 199 // This is disabled under C++; there are too many ways for this to fire in 200 // contexts where the warning is a false positive, or where it is technically 201 // correct but benign. 202 if (S.getLangOpts().CPlusPlus) 203 return; 204 205 // Check if this is an inlined function or method. 206 FunctionDecl *Current = S.getCurFunctionDecl(); 207 if (!Current) 208 return; 209 if (!Current->isInlined()) 210 return; 211 if (!Current->isExternallyVisible()) 212 return; 213 214 // Check if the decl has internal linkage. 215 if (D->getFormalLinkage() != InternalLinkage) 216 return; 217 218 // Downgrade from ExtWarn to Extension if 219 // (1) the supposedly external inline function is in the main file, 220 // and probably won't be included anywhere else. 221 // (2) the thing we're referencing is a pure function. 222 // (3) the thing we're referencing is another inline function. 223 // This last can give us false negatives, but it's better than warning on 224 // wrappers for simple C library functions. 225 const FunctionDecl *UsedFn = dyn_cast<FunctionDecl>(D); 226 bool DowngradeWarning = S.getSourceManager().isInMainFile(Loc); 227 if (!DowngradeWarning && UsedFn) 228 DowngradeWarning = UsedFn->isInlined() || UsedFn->hasAttr<ConstAttr>(); 229 230 S.Diag(Loc, DowngradeWarning ? diag::ext_internal_in_extern_inline_quiet 231 : diag::ext_internal_in_extern_inline) 232 << /*IsVar=*/!UsedFn << D; 233 234 S.MaybeSuggestAddingStaticToDecl(Current); 235 236 S.Diag(D->getCanonicalDecl()->getLocation(), diag::note_entity_declared_at) 237 << D; 238 } 239 240 void Sema::MaybeSuggestAddingStaticToDecl(const FunctionDecl *Cur) { 241 const FunctionDecl *First = Cur->getFirstDecl(); 242 243 // Suggest "static" on the function, if possible. 244 if (!hasAnyExplicitStorageClass(First)) { 245 SourceLocation DeclBegin = First->getSourceRange().getBegin(); 246 Diag(DeclBegin, diag::note_convert_inline_to_static) 247 << Cur << FixItHint::CreateInsertion(DeclBegin, "static "); 248 } 249 } 250 251 /// \brief Determine whether the use of this declaration is valid, and 252 /// emit any corresponding diagnostics. 253 /// 254 /// This routine diagnoses various problems with referencing 255 /// declarations that can occur when using a declaration. For example, 256 /// it might warn if a deprecated or unavailable declaration is being 257 /// used, or produce an error (and return true) if a C++0x deleted 258 /// function is being used. 259 /// 260 /// \returns true if there was an error (this declaration cannot be 261 /// referenced), false otherwise. 262 /// 263 bool Sema::DiagnoseUseOfDecl(NamedDecl *D, SourceLocation Loc, 264 const ObjCInterfaceDecl *UnknownObjCClass, 265 bool ObjCPropertyAccess) { 266 if (getLangOpts().CPlusPlus && isa<FunctionDecl>(D)) { 267 // If there were any diagnostics suppressed by template argument deduction, 268 // emit them now. 269 SuppressedDiagnosticsMap::iterator 270 Pos = SuppressedDiagnostics.find(D->getCanonicalDecl()); 271 if (Pos != SuppressedDiagnostics.end()) { 272 SmallVectorImpl<PartialDiagnosticAt> &Suppressed = Pos->second; 273 for (unsigned I = 0, N = Suppressed.size(); I != N; ++I) 274 Diag(Suppressed[I].first, Suppressed[I].second); 275 276 // Clear out the list of suppressed diagnostics, so that we don't emit 277 // them again for this specialization. However, we don't obsolete this 278 // entry from the table, because we want to avoid ever emitting these 279 // diagnostics again. 280 Suppressed.clear(); 281 } 282 283 // C++ [basic.start.main]p3: 284 // The function 'main' shall not be used within a program. 285 if (cast<FunctionDecl>(D)->isMain()) 286 Diag(Loc, diag::ext_main_used); 287 } 288 289 // See if this is an auto-typed variable whose initializer we are parsing. 290 if (ParsingInitForAutoVars.count(D)) { 291 Diag(Loc, diag::err_auto_variable_cannot_appear_in_own_initializer) 292 << D->getDeclName(); 293 return true; 294 } 295 296 // See if this is a deleted function. 297 if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) { 298 if (FD->isDeleted()) { 299 Diag(Loc, diag::err_deleted_function_use); 300 NoteDeletedFunction(FD); 301 return true; 302 } 303 304 // If the function has a deduced return type, and we can't deduce it, 305 // then we can't use it either. 306 if (getLangOpts().CPlusPlus14 && FD->getReturnType()->isUndeducedType() && 307 DeduceReturnType(FD, Loc)) 308 return true; 309 } 310 DiagnoseAvailabilityOfDecl(*this, D, Loc, UnknownObjCClass, ObjCPropertyAccess); 311 312 DiagnoseUnusedOfDecl(*this, D, Loc); 313 314 diagnoseUseOfInternalDeclInInlineFunction(*this, D, Loc); 315 316 return false; 317 } 318 319 /// \brief Retrieve the message suffix that should be added to a 320 /// diagnostic complaining about the given function being deleted or 321 /// unavailable. 322 std::string Sema::getDeletedOrUnavailableSuffix(const FunctionDecl *FD) { 323 std::string Message; 324 if (FD->getAvailability(&Message)) 325 return ": " + Message; 326 327 return std::string(); 328 } 329 330 /// DiagnoseSentinelCalls - This routine checks whether a call or 331 /// message-send is to a declaration with the sentinel attribute, and 332 /// if so, it checks that the requirements of the sentinel are 333 /// satisfied. 334 void Sema::DiagnoseSentinelCalls(NamedDecl *D, SourceLocation Loc, 335 ArrayRef<Expr *> Args) { 336 const SentinelAttr *attr = D->getAttr<SentinelAttr>(); 337 if (!attr) 338 return; 339 340 // The number of formal parameters of the declaration. 341 unsigned numFormalParams; 342 343 // The kind of declaration. This is also an index into a %select in 344 // the diagnostic. 345 enum CalleeType { CT_Function, CT_Method, CT_Block } calleeType; 346 347 if (ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(D)) { 348 numFormalParams = MD->param_size(); 349 calleeType = CT_Method; 350 } else if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) { 351 numFormalParams = FD->param_size(); 352 calleeType = CT_Function; 353 } else if (isa<VarDecl>(D)) { 354 QualType type = cast<ValueDecl>(D)->getType(); 355 const FunctionType *fn = nullptr; 356 if (const PointerType *ptr = type->getAs<PointerType>()) { 357 fn = ptr->getPointeeType()->getAs<FunctionType>(); 358 if (!fn) return; 359 calleeType = CT_Function; 360 } else if (const BlockPointerType *ptr = type->getAs<BlockPointerType>()) { 361 fn = ptr->getPointeeType()->castAs<FunctionType>(); 362 calleeType = CT_Block; 363 } else { 364 return; 365 } 366 367 if (const FunctionProtoType *proto = dyn_cast<FunctionProtoType>(fn)) { 368 numFormalParams = proto->getNumParams(); 369 } else { 370 numFormalParams = 0; 371 } 372 } else { 373 return; 374 } 375 376 // "nullPos" is the number of formal parameters at the end which 377 // effectively count as part of the variadic arguments. This is 378 // useful if you would prefer to not have *any* formal parameters, 379 // but the language forces you to have at least one. 380 unsigned nullPos = attr->getNullPos(); 381 assert((nullPos == 0 || nullPos == 1) && "invalid null position on sentinel"); 382 numFormalParams = (nullPos > numFormalParams ? 0 : numFormalParams - nullPos); 383 384 // The number of arguments which should follow the sentinel. 385 unsigned numArgsAfterSentinel = attr->getSentinel(); 386 387 // If there aren't enough arguments for all the formal parameters, 388 // the sentinel, and the args after the sentinel, complain. 389 if (Args.size() < numFormalParams + numArgsAfterSentinel + 1) { 390 Diag(Loc, diag::warn_not_enough_argument) << D->getDeclName(); 391 Diag(D->getLocation(), diag::note_sentinel_here) << int(calleeType); 392 return; 393 } 394 395 // Otherwise, find the sentinel expression. 396 Expr *sentinelExpr = Args[Args.size() - numArgsAfterSentinel - 1]; 397 if (!sentinelExpr) return; 398 if (sentinelExpr->isValueDependent()) return; 399 if (Context.isSentinelNullExpr(sentinelExpr)) return; 400 401 // Pick a reasonable string to insert. Optimistically use 'nil', 'nullptr', 402 // or 'NULL' if those are actually defined in the context. Only use 403 // 'nil' for ObjC methods, where it's much more likely that the 404 // variadic arguments form a list of object pointers. 405 SourceLocation MissingNilLoc 406 = PP.getLocForEndOfToken(sentinelExpr->getLocEnd()); 407 std::string NullValue; 408 if (calleeType == CT_Method && 409 PP.getIdentifierInfo("nil")->hasMacroDefinition()) 410 NullValue = "nil"; 411 else if (getLangOpts().CPlusPlus11) 412 NullValue = "nullptr"; 413 else if (PP.getIdentifierInfo("NULL")->hasMacroDefinition()) 414 NullValue = "NULL"; 415 else 416 NullValue = "(void*) 0"; 417 418 if (MissingNilLoc.isInvalid()) 419 Diag(Loc, diag::warn_missing_sentinel) << int(calleeType); 420 else 421 Diag(MissingNilLoc, diag::warn_missing_sentinel) 422 << int(calleeType) 423 << FixItHint::CreateInsertion(MissingNilLoc, ", " + NullValue); 424 Diag(D->getLocation(), diag::note_sentinel_here) << int(calleeType); 425 } 426 427 SourceRange Sema::getExprRange(Expr *E) const { 428 return E ? E->getSourceRange() : SourceRange(); 429 } 430 431 //===----------------------------------------------------------------------===// 432 // Standard Promotions and Conversions 433 //===----------------------------------------------------------------------===// 434 435 /// DefaultFunctionArrayConversion (C99 6.3.2.1p3, C99 6.3.2.1p4). 436 ExprResult Sema::DefaultFunctionArrayConversion(Expr *E) { 437 // Handle any placeholder expressions which made it here. 438 if (E->getType()->isPlaceholderType()) { 439 ExprResult result = CheckPlaceholderExpr(E); 440 if (result.isInvalid()) return ExprError(); 441 E = result.get(); 442 } 443 444 QualType Ty = E->getType(); 445 assert(!Ty.isNull() && "DefaultFunctionArrayConversion - missing type"); 446 447 if (Ty->isFunctionType()) { 448 // If we are here, we are not calling a function but taking 449 // its address (which is not allowed in OpenCL v1.0 s6.8.a.3). 450 if (getLangOpts().OpenCL) { 451 Diag(E->getExprLoc(), diag::err_opencl_taking_function_address); 452 return ExprError(); 453 } 454 E = ImpCastExprToType(E, Context.getPointerType(Ty), 455 CK_FunctionToPointerDecay).get(); 456 } else if (Ty->isArrayType()) { 457 // In C90 mode, arrays only promote to pointers if the array expression is 458 // an lvalue. The relevant legalese is C90 6.2.2.1p3: "an lvalue that has 459 // type 'array of type' is converted to an expression that has type 'pointer 460 // to type'...". In C99 this was changed to: C99 6.3.2.1p3: "an expression 461 // that has type 'array of type' ...". The relevant change is "an lvalue" 462 // (C90) to "an expression" (C99). 463 // 464 // C++ 4.2p1: 465 // An lvalue or rvalue of type "array of N T" or "array of unknown bound of 466 // T" can be converted to an rvalue of type "pointer to T". 467 // 468 if (getLangOpts().C99 || getLangOpts().CPlusPlus || E->isLValue()) 469 E = ImpCastExprToType(E, Context.getArrayDecayedType(Ty), 470 CK_ArrayToPointerDecay).get(); 471 } 472 return E; 473 } 474 475 static void CheckForNullPointerDereference(Sema &S, Expr *E) { 476 // Check to see if we are dereferencing a null pointer. If so, 477 // and if not volatile-qualified, this is undefined behavior that the 478 // optimizer will delete, so warn about it. People sometimes try to use this 479 // to get a deterministic trap and are surprised by clang's behavior. This 480 // only handles the pattern "*null", which is a very syntactic check. 481 if (UnaryOperator *UO = dyn_cast<UnaryOperator>(E->IgnoreParenCasts())) 482 if (UO->getOpcode() == UO_Deref && 483 UO->getSubExpr()->IgnoreParenCasts()-> 484 isNullPointerConstant(S.Context, Expr::NPC_ValueDependentIsNotNull) && 485 !UO->getType().isVolatileQualified()) { 486 S.DiagRuntimeBehavior(UO->getOperatorLoc(), UO, 487 S.PDiag(diag::warn_indirection_through_null) 488 << UO->getSubExpr()->getSourceRange()); 489 S.DiagRuntimeBehavior(UO->getOperatorLoc(), UO, 490 S.PDiag(diag::note_indirection_through_null)); 491 } 492 } 493 494 static void DiagnoseDirectIsaAccess(Sema &S, const ObjCIvarRefExpr *OIRE, 495 SourceLocation AssignLoc, 496 const Expr* RHS) { 497 const ObjCIvarDecl *IV = OIRE->getDecl(); 498 if (!IV) 499 return; 500 501 DeclarationName MemberName = IV->getDeclName(); 502 IdentifierInfo *Member = MemberName.getAsIdentifierInfo(); 503 if (!Member || !Member->isStr("isa")) 504 return; 505 506 const Expr *Base = OIRE->getBase(); 507 QualType BaseType = Base->getType(); 508 if (OIRE->isArrow()) 509 BaseType = BaseType->getPointeeType(); 510 if (const ObjCObjectType *OTy = BaseType->getAs<ObjCObjectType>()) 511 if (ObjCInterfaceDecl *IDecl = OTy->getInterface()) { 512 ObjCInterfaceDecl *ClassDeclared = nullptr; 513 ObjCIvarDecl *IV = IDecl->lookupInstanceVariable(Member, ClassDeclared); 514 if (!ClassDeclared->getSuperClass() 515 && (*ClassDeclared->ivar_begin()) == IV) { 516 if (RHS) { 517 NamedDecl *ObjectSetClass = 518 S.LookupSingleName(S.TUScope, 519 &S.Context.Idents.get("object_setClass"), 520 SourceLocation(), S.LookupOrdinaryName); 521 if (ObjectSetClass) { 522 SourceLocation RHSLocEnd = S.PP.getLocForEndOfToken(RHS->getLocEnd()); 523 S.Diag(OIRE->getExprLoc(), diag::warn_objc_isa_assign) << 524 FixItHint::CreateInsertion(OIRE->getLocStart(), "object_setClass(") << 525 FixItHint::CreateReplacement(SourceRange(OIRE->getOpLoc(), 526 AssignLoc), ",") << 527 FixItHint::CreateInsertion(RHSLocEnd, ")"); 528 } 529 else 530 S.Diag(OIRE->getLocation(), diag::warn_objc_isa_assign); 531 } else { 532 NamedDecl *ObjectGetClass = 533 S.LookupSingleName(S.TUScope, 534 &S.Context.Idents.get("object_getClass"), 535 SourceLocation(), S.LookupOrdinaryName); 536 if (ObjectGetClass) 537 S.Diag(OIRE->getExprLoc(), diag::warn_objc_isa_use) << 538 FixItHint::CreateInsertion(OIRE->getLocStart(), "object_getClass(") << 539 FixItHint::CreateReplacement( 540 SourceRange(OIRE->getOpLoc(), 541 OIRE->getLocEnd()), ")"); 542 else 543 S.Diag(OIRE->getLocation(), diag::warn_objc_isa_use); 544 } 545 S.Diag(IV->getLocation(), diag::note_ivar_decl); 546 } 547 } 548 } 549 550 ExprResult Sema::DefaultLvalueConversion(Expr *E) { 551 // Handle any placeholder expressions which made it here. 552 if (E->getType()->isPlaceholderType()) { 553 ExprResult result = CheckPlaceholderExpr(E); 554 if (result.isInvalid()) return ExprError(); 555 E = result.get(); 556 } 557 558 // C++ [conv.lval]p1: 559 // A glvalue of a non-function, non-array type T can be 560 // converted to a prvalue. 561 if (!E->isGLValue()) return E; 562 563 QualType T = E->getType(); 564 assert(!T.isNull() && "r-value conversion on typeless expression?"); 565 566 // We don't want to throw lvalue-to-rvalue casts on top of 567 // expressions of certain types in C++. 568 if (getLangOpts().CPlusPlus && 569 (E->getType() == Context.OverloadTy || 570 T->isDependentType() || 571 T->isRecordType())) 572 return E; 573 574 // The C standard is actually really unclear on this point, and 575 // DR106 tells us what the result should be but not why. It's 576 // generally best to say that void types just doesn't undergo 577 // lvalue-to-rvalue at all. Note that expressions of unqualified 578 // 'void' type are never l-values, but qualified void can be. 579 if (T->isVoidType()) 580 return E; 581 582 // OpenCL usually rejects direct accesses to values of 'half' type. 583 if (getLangOpts().OpenCL && !getOpenCLOptions().cl_khr_fp16 && 584 T->isHalfType()) { 585 Diag(E->getExprLoc(), diag::err_opencl_half_load_store) 586 << 0 << T; 587 return ExprError(); 588 } 589 590 CheckForNullPointerDereference(*this, E); 591 if (const ObjCIsaExpr *OISA = dyn_cast<ObjCIsaExpr>(E->IgnoreParenCasts())) { 592 NamedDecl *ObjectGetClass = LookupSingleName(TUScope, 593 &Context.Idents.get("object_getClass"), 594 SourceLocation(), LookupOrdinaryName); 595 if (ObjectGetClass) 596 Diag(E->getExprLoc(), diag::warn_objc_isa_use) << 597 FixItHint::CreateInsertion(OISA->getLocStart(), "object_getClass(") << 598 FixItHint::CreateReplacement( 599 SourceRange(OISA->getOpLoc(), OISA->getIsaMemberLoc()), ")"); 600 else 601 Diag(E->getExprLoc(), diag::warn_objc_isa_use); 602 } 603 else if (const ObjCIvarRefExpr *OIRE = 604 dyn_cast<ObjCIvarRefExpr>(E->IgnoreParenCasts())) 605 DiagnoseDirectIsaAccess(*this, OIRE, SourceLocation(), /* Expr*/nullptr); 606 607 // C++ [conv.lval]p1: 608 // [...] If T is a non-class type, the type of the prvalue is the 609 // cv-unqualified version of T. Otherwise, the type of the 610 // rvalue is T. 611 // 612 // C99 6.3.2.1p2: 613 // If the lvalue has qualified type, the value has the unqualified 614 // version of the type of the lvalue; otherwise, the value has the 615 // type of the lvalue. 616 if (T.hasQualifiers()) 617 T = T.getUnqualifiedType(); 618 619 UpdateMarkingForLValueToRValue(E); 620 621 // Loading a __weak object implicitly retains the value, so we need a cleanup to 622 // balance that. 623 if (getLangOpts().ObjCAutoRefCount && 624 E->getType().getObjCLifetime() == Qualifiers::OCL_Weak) 625 ExprNeedsCleanups = true; 626 627 ExprResult Res = ImplicitCastExpr::Create(Context, T, CK_LValueToRValue, E, 628 nullptr, VK_RValue); 629 630 // C11 6.3.2.1p2: 631 // ... if the lvalue has atomic type, the value has the non-atomic version 632 // of the type of the lvalue ... 633 if (const AtomicType *Atomic = T->getAs<AtomicType>()) { 634 T = Atomic->getValueType().getUnqualifiedType(); 635 Res = ImplicitCastExpr::Create(Context, T, CK_AtomicToNonAtomic, Res.get(), 636 nullptr, VK_RValue); 637 } 638 639 return Res; 640 } 641 642 ExprResult Sema::DefaultFunctionArrayLvalueConversion(Expr *E) { 643 ExprResult Res = DefaultFunctionArrayConversion(E); 644 if (Res.isInvalid()) 645 return ExprError(); 646 Res = DefaultLvalueConversion(Res.get()); 647 if (Res.isInvalid()) 648 return ExprError(); 649 return Res; 650 } 651 652 /// CallExprUnaryConversions - a special case of an unary conversion 653 /// performed on a function designator of a call expression. 654 ExprResult Sema::CallExprUnaryConversions(Expr *E) { 655 QualType Ty = E->getType(); 656 ExprResult Res = E; 657 // Only do implicit cast for a function type, but not for a pointer 658 // to function type. 659 if (Ty->isFunctionType()) { 660 Res = ImpCastExprToType(E, Context.getPointerType(Ty), 661 CK_FunctionToPointerDecay).get(); 662 if (Res.isInvalid()) 663 return ExprError(); 664 } 665 Res = DefaultLvalueConversion(Res.get()); 666 if (Res.isInvalid()) 667 return ExprError(); 668 return Res.get(); 669 } 670 671 /// UsualUnaryConversions - Performs various conversions that are common to most 672 /// operators (C99 6.3). The conversions of array and function types are 673 /// sometimes suppressed. For example, the array->pointer conversion doesn't 674 /// apply if the array is an argument to the sizeof or address (&) operators. 675 /// In these instances, this routine should *not* be called. 676 ExprResult Sema::UsualUnaryConversions(Expr *E) { 677 // First, convert to an r-value. 678 ExprResult Res = DefaultFunctionArrayLvalueConversion(E); 679 if (Res.isInvalid()) 680 return ExprError(); 681 E = Res.get(); 682 683 QualType Ty = E->getType(); 684 assert(!Ty.isNull() && "UsualUnaryConversions - missing type"); 685 686 // Half FP have to be promoted to float unless it is natively supported 687 if (Ty->isHalfType() && !getLangOpts().NativeHalfType) 688 return ImpCastExprToType(Res.get(), Context.FloatTy, CK_FloatingCast); 689 690 // Try to perform integral promotions if the object has a theoretically 691 // promotable type. 692 if (Ty->isIntegralOrUnscopedEnumerationType()) { 693 // C99 6.3.1.1p2: 694 // 695 // The following may be used in an expression wherever an int or 696 // unsigned int may be used: 697 // - an object or expression with an integer type whose integer 698 // conversion rank is less than or equal to the rank of int 699 // and unsigned int. 700 // - A bit-field of type _Bool, int, signed int, or unsigned int. 701 // 702 // If an int can represent all values of the original type, the 703 // value is converted to an int; otherwise, it is converted to an 704 // unsigned int. These are called the integer promotions. All 705 // other types are unchanged by the integer promotions. 706 707 QualType PTy = Context.isPromotableBitField(E); 708 if (!PTy.isNull()) { 709 E = ImpCastExprToType(E, PTy, CK_IntegralCast).get(); 710 return E; 711 } 712 if (Ty->isPromotableIntegerType()) { 713 QualType PT = Context.getPromotedIntegerType(Ty); 714 E = ImpCastExprToType(E, PT, CK_IntegralCast).get(); 715 return E; 716 } 717 } 718 return E; 719 } 720 721 /// DefaultArgumentPromotion (C99 6.5.2.2p6). Used for function calls that 722 /// do not have a prototype. Arguments that have type float or __fp16 723 /// are promoted to double. All other argument types are converted by 724 /// UsualUnaryConversions(). 725 ExprResult Sema::DefaultArgumentPromotion(Expr *E) { 726 QualType Ty = E->getType(); 727 assert(!Ty.isNull() && "DefaultArgumentPromotion - missing type"); 728 729 ExprResult Res = UsualUnaryConversions(E); 730 if (Res.isInvalid()) 731 return ExprError(); 732 E = Res.get(); 733 734 // If this is a 'float' or '__fp16' (CVR qualified or typedef) promote to 735 // double. 736 const BuiltinType *BTy = Ty->getAs<BuiltinType>(); 737 if (BTy && (BTy->getKind() == BuiltinType::Half || 738 BTy->getKind() == BuiltinType::Float)) 739 E = ImpCastExprToType(E, Context.DoubleTy, CK_FloatingCast).get(); 740 741 // C++ performs lvalue-to-rvalue conversion as a default argument 742 // promotion, even on class types, but note: 743 // C++11 [conv.lval]p2: 744 // When an lvalue-to-rvalue conversion occurs in an unevaluated 745 // operand or a subexpression thereof the value contained in the 746 // referenced object is not accessed. Otherwise, if the glvalue 747 // has a class type, the conversion copy-initializes a temporary 748 // of type T from the glvalue and the result of the conversion 749 // is a prvalue for the temporary. 750 // FIXME: add some way to gate this entire thing for correctness in 751 // potentially potentially evaluated contexts. 752 if (getLangOpts().CPlusPlus && E->isGLValue() && !isUnevaluatedContext()) { 753 ExprResult Temp = PerformCopyInitialization( 754 InitializedEntity::InitializeTemporary(E->getType()), 755 E->getExprLoc(), E); 756 if (Temp.isInvalid()) 757 return ExprError(); 758 E = Temp.get(); 759 } 760 761 return E; 762 } 763 764 /// Determine the degree of POD-ness for an expression. 765 /// Incomplete types are considered POD, since this check can be performed 766 /// when we're in an unevaluated context. 767 Sema::VarArgKind Sema::isValidVarArgType(const QualType &Ty) { 768 if (Ty->isIncompleteType()) { 769 // C++11 [expr.call]p7: 770 // After these conversions, if the argument does not have arithmetic, 771 // enumeration, pointer, pointer to member, or class type, the program 772 // is ill-formed. 773 // 774 // Since we've already performed array-to-pointer and function-to-pointer 775 // decay, the only such type in C++ is cv void. This also handles 776 // initializer lists as variadic arguments. 777 if (Ty->isVoidType()) 778 return VAK_Invalid; 779 780 if (Ty->isObjCObjectType()) 781 return VAK_Invalid; 782 return VAK_Valid; 783 } 784 785 if (Ty.isCXX98PODType(Context)) 786 return VAK_Valid; 787 788 // C++11 [expr.call]p7: 789 // Passing a potentially-evaluated argument of class type (Clause 9) 790 // having a non-trivial copy constructor, a non-trivial move constructor, 791 // or a non-trivial destructor, with no corresponding parameter, 792 // is conditionally-supported with implementation-defined semantics. 793 if (getLangOpts().CPlusPlus11 && !Ty->isDependentType()) 794 if (CXXRecordDecl *Record = Ty->getAsCXXRecordDecl()) 795 if (!Record->hasNonTrivialCopyConstructor() && 796 !Record->hasNonTrivialMoveConstructor() && 797 !Record->hasNonTrivialDestructor()) 798 return VAK_ValidInCXX11; 799 800 if (getLangOpts().ObjCAutoRefCount && Ty->isObjCLifetimeType()) 801 return VAK_Valid; 802 803 if (Ty->isObjCObjectType()) 804 return VAK_Invalid; 805 806 if (getLangOpts().MSVCCompat) 807 return VAK_MSVCUndefined; 808 809 // FIXME: In C++11, these cases are conditionally-supported, meaning we're 810 // permitted to reject them. We should consider doing so. 811 return VAK_Undefined; 812 } 813 814 void Sema::checkVariadicArgument(const Expr *E, VariadicCallType CT) { 815 // Don't allow one to pass an Objective-C interface to a vararg. 816 const QualType &Ty = E->getType(); 817 VarArgKind VAK = isValidVarArgType(Ty); 818 819 // Complain about passing non-POD types through varargs. 820 switch (VAK) { 821 case VAK_ValidInCXX11: 822 DiagRuntimeBehavior( 823 E->getLocStart(), nullptr, 824 PDiag(diag::warn_cxx98_compat_pass_non_pod_arg_to_vararg) 825 << Ty << CT); 826 // Fall through. 827 case VAK_Valid: 828 if (Ty->isRecordType()) { 829 // This is unlikely to be what the user intended. If the class has a 830 // 'c_str' member function, the user probably meant to call that. 831 DiagRuntimeBehavior(E->getLocStart(), nullptr, 832 PDiag(diag::warn_pass_class_arg_to_vararg) 833 << Ty << CT << hasCStrMethod(E) << ".c_str()"); 834 } 835 break; 836 837 case VAK_Undefined: 838 case VAK_MSVCUndefined: 839 DiagRuntimeBehavior( 840 E->getLocStart(), nullptr, 841 PDiag(diag::warn_cannot_pass_non_pod_arg_to_vararg) 842 << getLangOpts().CPlusPlus11 << Ty << CT); 843 break; 844 845 case VAK_Invalid: 846 if (Ty->isObjCObjectType()) 847 DiagRuntimeBehavior( 848 E->getLocStart(), nullptr, 849 PDiag(diag::err_cannot_pass_objc_interface_to_vararg) 850 << Ty << CT); 851 else 852 Diag(E->getLocStart(), diag::err_cannot_pass_to_vararg) 853 << isa<InitListExpr>(E) << Ty << CT; 854 break; 855 } 856 } 857 858 /// DefaultVariadicArgumentPromotion - Like DefaultArgumentPromotion, but 859 /// will create a trap if the resulting type is not a POD type. 860 ExprResult Sema::DefaultVariadicArgumentPromotion(Expr *E, VariadicCallType CT, 861 FunctionDecl *FDecl) { 862 if (const BuiltinType *PlaceholderTy = E->getType()->getAsPlaceholderType()) { 863 // Strip the unbridged-cast placeholder expression off, if applicable. 864 if (PlaceholderTy->getKind() == BuiltinType::ARCUnbridgedCast && 865 (CT == VariadicMethod || 866 (FDecl && FDecl->hasAttr<CFAuditedTransferAttr>()))) { 867 E = stripARCUnbridgedCast(E); 868 869 // Otherwise, do normal placeholder checking. 870 } else { 871 ExprResult ExprRes = CheckPlaceholderExpr(E); 872 if (ExprRes.isInvalid()) 873 return ExprError(); 874 E = ExprRes.get(); 875 } 876 } 877 878 ExprResult ExprRes = DefaultArgumentPromotion(E); 879 if (ExprRes.isInvalid()) 880 return ExprError(); 881 E = ExprRes.get(); 882 883 // Diagnostics regarding non-POD argument types are 884 // emitted along with format string checking in Sema::CheckFunctionCall(). 885 if (isValidVarArgType(E->getType()) == VAK_Undefined) { 886 // Turn this into a trap. 887 CXXScopeSpec SS; 888 SourceLocation TemplateKWLoc; 889 UnqualifiedId Name; 890 Name.setIdentifier(PP.getIdentifierInfo("__builtin_trap"), 891 E->getLocStart()); 892 ExprResult TrapFn = ActOnIdExpression(TUScope, SS, TemplateKWLoc, 893 Name, true, false); 894 if (TrapFn.isInvalid()) 895 return ExprError(); 896 897 ExprResult Call = ActOnCallExpr(TUScope, TrapFn.get(), 898 E->getLocStart(), None, 899 E->getLocEnd()); 900 if (Call.isInvalid()) 901 return ExprError(); 902 903 ExprResult Comma = ActOnBinOp(TUScope, E->getLocStart(), tok::comma, 904 Call.get(), E); 905 if (Comma.isInvalid()) 906 return ExprError(); 907 return Comma.get(); 908 } 909 910 if (!getLangOpts().CPlusPlus && 911 RequireCompleteType(E->getExprLoc(), E->getType(), 912 diag::err_call_incomplete_argument)) 913 return ExprError(); 914 915 return E; 916 } 917 918 /// \brief Converts an integer to complex float type. Helper function of 919 /// UsualArithmeticConversions() 920 /// 921 /// \return false if the integer expression is an integer type and is 922 /// successfully converted to the complex type. 923 static bool handleIntegerToComplexFloatConversion(Sema &S, ExprResult &IntExpr, 924 ExprResult &ComplexExpr, 925 QualType IntTy, 926 QualType ComplexTy, 927 bool SkipCast) { 928 if (IntTy->isComplexType() || IntTy->isRealFloatingType()) return true; 929 if (SkipCast) return false; 930 if (IntTy->isIntegerType()) { 931 QualType fpTy = cast<ComplexType>(ComplexTy)->getElementType(); 932 IntExpr = S.ImpCastExprToType(IntExpr.get(), fpTy, CK_IntegralToFloating); 933 IntExpr = S.ImpCastExprToType(IntExpr.get(), ComplexTy, 934 CK_FloatingRealToComplex); 935 } else { 936 assert(IntTy->isComplexIntegerType()); 937 IntExpr = S.ImpCastExprToType(IntExpr.get(), ComplexTy, 938 CK_IntegralComplexToFloatingComplex); 939 } 940 return false; 941 } 942 943 /// \brief Handle arithmetic conversion with complex types. Helper function of 944 /// UsualArithmeticConversions() 945 static QualType handleComplexFloatConversion(Sema &S, ExprResult &LHS, 946 ExprResult &RHS, QualType LHSType, 947 QualType RHSType, 948 bool IsCompAssign) { 949 // if we have an integer operand, the result is the complex type. 950 if (!handleIntegerToComplexFloatConversion(S, RHS, LHS, RHSType, LHSType, 951 /*skipCast*/false)) 952 return LHSType; 953 if (!handleIntegerToComplexFloatConversion(S, LHS, RHS, LHSType, RHSType, 954 /*skipCast*/IsCompAssign)) 955 return RHSType; 956 957 // This handles complex/complex, complex/float, or float/complex. 958 // When both operands are complex, the shorter operand is converted to the 959 // type of the longer, and that is the type of the result. This corresponds 960 // to what is done when combining two real floating-point operands. 961 // The fun begins when size promotion occur across type domains. 962 // From H&S 6.3.4: When one operand is complex and the other is a real 963 // floating-point type, the less precise type is converted, within it's 964 // real or complex domain, to the precision of the other type. For example, 965 // when combining a "long double" with a "double _Complex", the 966 // "double _Complex" is promoted to "long double _Complex". 967 968 // Compute the rank of the two types, regardless of whether they are complex. 969 int Order = S.Context.getFloatingTypeOrder(LHSType, RHSType); 970 971 auto *LHSComplexType = dyn_cast<ComplexType>(LHSType); 972 auto *RHSComplexType = dyn_cast<ComplexType>(RHSType); 973 QualType LHSElementType = 974 LHSComplexType ? LHSComplexType->getElementType() : LHSType; 975 QualType RHSElementType = 976 RHSComplexType ? RHSComplexType->getElementType() : RHSType; 977 978 QualType ResultType = S.Context.getComplexType(LHSElementType); 979 if (Order < 0) { 980 // Promote the precision of the LHS if not an assignment. 981 ResultType = S.Context.getComplexType(RHSElementType); 982 if (!IsCompAssign) { 983 if (LHSComplexType) 984 LHS = 985 S.ImpCastExprToType(LHS.get(), ResultType, CK_FloatingComplexCast); 986 else 987 LHS = S.ImpCastExprToType(LHS.get(), RHSElementType, CK_FloatingCast); 988 } 989 } else if (Order > 0) { 990 // Promote the precision of the RHS. 991 if (RHSComplexType) 992 RHS = S.ImpCastExprToType(RHS.get(), ResultType, CK_FloatingComplexCast); 993 else 994 RHS = S.ImpCastExprToType(RHS.get(), LHSElementType, CK_FloatingCast); 995 } 996 return ResultType; 997 } 998 999 /// \brief Hande arithmetic conversion from integer to float. Helper function 1000 /// of UsualArithmeticConversions() 1001 static QualType handleIntToFloatConversion(Sema &S, ExprResult &FloatExpr, 1002 ExprResult &IntExpr, 1003 QualType FloatTy, QualType IntTy, 1004 bool ConvertFloat, bool ConvertInt) { 1005 if (IntTy->isIntegerType()) { 1006 if (ConvertInt) 1007 // Convert intExpr to the lhs floating point type. 1008 IntExpr = S.ImpCastExprToType(IntExpr.get(), FloatTy, 1009 CK_IntegralToFloating); 1010 return FloatTy; 1011 } 1012 1013 // Convert both sides to the appropriate complex float. 1014 assert(IntTy->isComplexIntegerType()); 1015 QualType result = S.Context.getComplexType(FloatTy); 1016 1017 // _Complex int -> _Complex float 1018 if (ConvertInt) 1019 IntExpr = S.ImpCastExprToType(IntExpr.get(), result, 1020 CK_IntegralComplexToFloatingComplex); 1021 1022 // float -> _Complex float 1023 if (ConvertFloat) 1024 FloatExpr = S.ImpCastExprToType(FloatExpr.get(), result, 1025 CK_FloatingRealToComplex); 1026 1027 return result; 1028 } 1029 1030 /// \brief Handle arithmethic conversion with floating point types. Helper 1031 /// function of UsualArithmeticConversions() 1032 static QualType handleFloatConversion(Sema &S, ExprResult &LHS, 1033 ExprResult &RHS, QualType LHSType, 1034 QualType RHSType, bool IsCompAssign) { 1035 bool LHSFloat = LHSType->isRealFloatingType(); 1036 bool RHSFloat = RHSType->isRealFloatingType(); 1037 1038 // If we have two real floating types, convert the smaller operand 1039 // to the bigger result. 1040 if (LHSFloat && RHSFloat) { 1041 int order = S.Context.getFloatingTypeOrder(LHSType, RHSType); 1042 if (order > 0) { 1043 RHS = S.ImpCastExprToType(RHS.get(), LHSType, CK_FloatingCast); 1044 return LHSType; 1045 } 1046 1047 assert(order < 0 && "illegal float comparison"); 1048 if (!IsCompAssign) 1049 LHS = S.ImpCastExprToType(LHS.get(), RHSType, CK_FloatingCast); 1050 return RHSType; 1051 } 1052 1053 if (LHSFloat) 1054 return handleIntToFloatConversion(S, LHS, RHS, LHSType, RHSType, 1055 /*convertFloat=*/!IsCompAssign, 1056 /*convertInt=*/ true); 1057 assert(RHSFloat); 1058 return handleIntToFloatConversion(S, RHS, LHS, RHSType, LHSType, 1059 /*convertInt=*/ true, 1060 /*convertFloat=*/!IsCompAssign); 1061 } 1062 1063 typedef ExprResult PerformCastFn(Sema &S, Expr *operand, QualType toType); 1064 1065 namespace { 1066 /// These helper callbacks are placed in an anonymous namespace to 1067 /// permit their use as function template parameters. 1068 ExprResult doIntegralCast(Sema &S, Expr *op, QualType toType) { 1069 return S.ImpCastExprToType(op, toType, CK_IntegralCast); 1070 } 1071 1072 ExprResult doComplexIntegralCast(Sema &S, Expr *op, QualType toType) { 1073 return S.ImpCastExprToType(op, S.Context.getComplexType(toType), 1074 CK_IntegralComplexCast); 1075 } 1076 } 1077 1078 /// \brief Handle integer arithmetic conversions. Helper function of 1079 /// UsualArithmeticConversions() 1080 template <PerformCastFn doLHSCast, PerformCastFn doRHSCast> 1081 static QualType handleIntegerConversion(Sema &S, ExprResult &LHS, 1082 ExprResult &RHS, QualType LHSType, 1083 QualType RHSType, bool IsCompAssign) { 1084 // The rules for this case are in C99 6.3.1.8 1085 int order = S.Context.getIntegerTypeOrder(LHSType, RHSType); 1086 bool LHSSigned = LHSType->hasSignedIntegerRepresentation(); 1087 bool RHSSigned = RHSType->hasSignedIntegerRepresentation(); 1088 if (LHSSigned == RHSSigned) { 1089 // Same signedness; use the higher-ranked type 1090 if (order >= 0) { 1091 RHS = (*doRHSCast)(S, RHS.get(), LHSType); 1092 return LHSType; 1093 } else if (!IsCompAssign) 1094 LHS = (*doLHSCast)(S, LHS.get(), RHSType); 1095 return RHSType; 1096 } else if (order != (LHSSigned ? 1 : -1)) { 1097 // The unsigned type has greater than or equal rank to the 1098 // signed type, so use the unsigned type 1099 if (RHSSigned) { 1100 RHS = (*doRHSCast)(S, RHS.get(), LHSType); 1101 return LHSType; 1102 } else if (!IsCompAssign) 1103 LHS = (*doLHSCast)(S, LHS.get(), RHSType); 1104 return RHSType; 1105 } else if (S.Context.getIntWidth(LHSType) != S.Context.getIntWidth(RHSType)) { 1106 // The two types are different widths; if we are here, that 1107 // means the signed type is larger than the unsigned type, so 1108 // use the signed type. 1109 if (LHSSigned) { 1110 RHS = (*doRHSCast)(S, RHS.get(), LHSType); 1111 return LHSType; 1112 } else if (!IsCompAssign) 1113 LHS = (*doLHSCast)(S, LHS.get(), RHSType); 1114 return RHSType; 1115 } else { 1116 // The signed type is higher-ranked than the unsigned type, 1117 // but isn't actually any bigger (like unsigned int and long 1118 // on most 32-bit systems). Use the unsigned type corresponding 1119 // to the signed type. 1120 QualType result = 1121 S.Context.getCorrespondingUnsignedType(LHSSigned ? LHSType : RHSType); 1122 RHS = (*doRHSCast)(S, RHS.get(), result); 1123 if (!IsCompAssign) 1124 LHS = (*doLHSCast)(S, LHS.get(), result); 1125 return result; 1126 } 1127 } 1128 1129 /// \brief Handle conversions with GCC complex int extension. Helper function 1130 /// of UsualArithmeticConversions() 1131 static QualType handleComplexIntConversion(Sema &S, ExprResult &LHS, 1132 ExprResult &RHS, QualType LHSType, 1133 QualType RHSType, 1134 bool IsCompAssign) { 1135 const ComplexType *LHSComplexInt = LHSType->getAsComplexIntegerType(); 1136 const ComplexType *RHSComplexInt = RHSType->getAsComplexIntegerType(); 1137 1138 if (LHSComplexInt && RHSComplexInt) { 1139 QualType LHSEltType = LHSComplexInt->getElementType(); 1140 QualType RHSEltType = RHSComplexInt->getElementType(); 1141 QualType ScalarType = 1142 handleIntegerConversion<doComplexIntegralCast, doComplexIntegralCast> 1143 (S, LHS, RHS, LHSEltType, RHSEltType, IsCompAssign); 1144 1145 return S.Context.getComplexType(ScalarType); 1146 } 1147 1148 if (LHSComplexInt) { 1149 QualType LHSEltType = LHSComplexInt->getElementType(); 1150 QualType ScalarType = 1151 handleIntegerConversion<doComplexIntegralCast, doIntegralCast> 1152 (S, LHS, RHS, LHSEltType, RHSType, IsCompAssign); 1153 QualType ComplexType = S.Context.getComplexType(ScalarType); 1154 RHS = S.ImpCastExprToType(RHS.get(), ComplexType, 1155 CK_IntegralRealToComplex); 1156 1157 return ComplexType; 1158 } 1159 1160 assert(RHSComplexInt); 1161 1162 QualType RHSEltType = RHSComplexInt->getElementType(); 1163 QualType ScalarType = 1164 handleIntegerConversion<doIntegralCast, doComplexIntegralCast> 1165 (S, LHS, RHS, LHSType, RHSEltType, IsCompAssign); 1166 QualType ComplexType = S.Context.getComplexType(ScalarType); 1167 1168 if (!IsCompAssign) 1169 LHS = S.ImpCastExprToType(LHS.get(), ComplexType, 1170 CK_IntegralRealToComplex); 1171 return ComplexType; 1172 } 1173 1174 /// UsualArithmeticConversions - Performs various conversions that are common to 1175 /// binary operators (C99 6.3.1.8). If both operands aren't arithmetic, this 1176 /// routine returns the first non-arithmetic type found. The client is 1177 /// responsible for emitting appropriate error diagnostics. 1178 QualType Sema::UsualArithmeticConversions(ExprResult &LHS, ExprResult &RHS, 1179 bool IsCompAssign) { 1180 if (!IsCompAssign) { 1181 LHS = UsualUnaryConversions(LHS.get()); 1182 if (LHS.isInvalid()) 1183 return QualType(); 1184 } 1185 1186 RHS = UsualUnaryConversions(RHS.get()); 1187 if (RHS.isInvalid()) 1188 return QualType(); 1189 1190 // For conversion purposes, we ignore any qualifiers. 1191 // For example, "const float" and "float" are equivalent. 1192 QualType LHSType = 1193 Context.getCanonicalType(LHS.get()->getType()).getUnqualifiedType(); 1194 QualType RHSType = 1195 Context.getCanonicalType(RHS.get()->getType()).getUnqualifiedType(); 1196 1197 // For conversion purposes, we ignore any atomic qualifier on the LHS. 1198 if (const AtomicType *AtomicLHS = LHSType->getAs<AtomicType>()) 1199 LHSType = AtomicLHS->getValueType(); 1200 1201 // If both types are identical, no conversion is needed. 1202 if (LHSType == RHSType) 1203 return LHSType; 1204 1205 // If either side is a non-arithmetic type (e.g. a pointer), we are done. 1206 // The caller can deal with this (e.g. pointer + int). 1207 if (!LHSType->isArithmeticType() || !RHSType->isArithmeticType()) 1208 return QualType(); 1209 1210 // Apply unary and bitfield promotions to the LHS's type. 1211 QualType LHSUnpromotedType = LHSType; 1212 if (LHSType->isPromotableIntegerType()) 1213 LHSType = Context.getPromotedIntegerType(LHSType); 1214 QualType LHSBitfieldPromoteTy = Context.isPromotableBitField(LHS.get()); 1215 if (!LHSBitfieldPromoteTy.isNull()) 1216 LHSType = LHSBitfieldPromoteTy; 1217 if (LHSType != LHSUnpromotedType && !IsCompAssign) 1218 LHS = ImpCastExprToType(LHS.get(), LHSType, CK_IntegralCast); 1219 1220 // If both types are identical, no conversion is needed. 1221 if (LHSType == RHSType) 1222 return LHSType; 1223 1224 // At this point, we have two different arithmetic types. 1225 1226 // Handle complex types first (C99 6.3.1.8p1). 1227 if (LHSType->isComplexType() || RHSType->isComplexType()) 1228 return handleComplexFloatConversion(*this, LHS, RHS, LHSType, RHSType, 1229 IsCompAssign); 1230 1231 // Now handle "real" floating types (i.e. float, double, long double). 1232 if (LHSType->isRealFloatingType() || RHSType->isRealFloatingType()) 1233 return handleFloatConversion(*this, LHS, RHS, LHSType, RHSType, 1234 IsCompAssign); 1235 1236 // Handle GCC complex int extension. 1237 if (LHSType->isComplexIntegerType() || RHSType->isComplexIntegerType()) 1238 return handleComplexIntConversion(*this, LHS, RHS, LHSType, RHSType, 1239 IsCompAssign); 1240 1241 // Finally, we have two differing integer types. 1242 return handleIntegerConversion<doIntegralCast, doIntegralCast> 1243 (*this, LHS, RHS, LHSType, RHSType, IsCompAssign); 1244 } 1245 1246 1247 //===----------------------------------------------------------------------===// 1248 // Semantic Analysis for various Expression Types 1249 //===----------------------------------------------------------------------===// 1250 1251 1252 ExprResult 1253 Sema::ActOnGenericSelectionExpr(SourceLocation KeyLoc, 1254 SourceLocation DefaultLoc, 1255 SourceLocation RParenLoc, 1256 Expr *ControllingExpr, 1257 ArrayRef<ParsedType> ArgTypes, 1258 ArrayRef<Expr *> ArgExprs) { 1259 unsigned NumAssocs = ArgTypes.size(); 1260 assert(NumAssocs == ArgExprs.size()); 1261 1262 TypeSourceInfo **Types = new TypeSourceInfo*[NumAssocs]; 1263 for (unsigned i = 0; i < NumAssocs; ++i) { 1264 if (ArgTypes[i]) 1265 (void) GetTypeFromParser(ArgTypes[i], &Types[i]); 1266 else 1267 Types[i] = nullptr; 1268 } 1269 1270 ExprResult ER = CreateGenericSelectionExpr(KeyLoc, DefaultLoc, RParenLoc, 1271 ControllingExpr, 1272 llvm::makeArrayRef(Types, NumAssocs), 1273 ArgExprs); 1274 delete [] Types; 1275 return ER; 1276 } 1277 1278 ExprResult 1279 Sema::CreateGenericSelectionExpr(SourceLocation KeyLoc, 1280 SourceLocation DefaultLoc, 1281 SourceLocation RParenLoc, 1282 Expr *ControllingExpr, 1283 ArrayRef<TypeSourceInfo *> Types, 1284 ArrayRef<Expr *> Exprs) { 1285 unsigned NumAssocs = Types.size(); 1286 assert(NumAssocs == Exprs.size()); 1287 if (ControllingExpr->getType()->isPlaceholderType()) { 1288 ExprResult result = CheckPlaceholderExpr(ControllingExpr); 1289 if (result.isInvalid()) return ExprError(); 1290 ControllingExpr = result.get(); 1291 } 1292 1293 // The controlling expression is an unevaluated operand, so side effects are 1294 // likely unintended. 1295 if (ActiveTemplateInstantiations.empty() && 1296 ControllingExpr->HasSideEffects(Context, false)) 1297 Diag(ControllingExpr->getExprLoc(), 1298 diag::warn_side_effects_unevaluated_context); 1299 1300 bool TypeErrorFound = false, 1301 IsResultDependent = ControllingExpr->isTypeDependent(), 1302 ContainsUnexpandedParameterPack 1303 = ControllingExpr->containsUnexpandedParameterPack(); 1304 1305 for (unsigned i = 0; i < NumAssocs; ++i) { 1306 if (Exprs[i]->containsUnexpandedParameterPack()) 1307 ContainsUnexpandedParameterPack = true; 1308 1309 if (Types[i]) { 1310 if (Types[i]->getType()->containsUnexpandedParameterPack()) 1311 ContainsUnexpandedParameterPack = true; 1312 1313 if (Types[i]->getType()->isDependentType()) { 1314 IsResultDependent = true; 1315 } else { 1316 // C11 6.5.1.1p2 "The type name in a generic association shall specify a 1317 // complete object type other than a variably modified type." 1318 unsigned D = 0; 1319 if (Types[i]->getType()->isIncompleteType()) 1320 D = diag::err_assoc_type_incomplete; 1321 else if (!Types[i]->getType()->isObjectType()) 1322 D = diag::err_assoc_type_nonobject; 1323 else if (Types[i]->getType()->isVariablyModifiedType()) 1324 D = diag::err_assoc_type_variably_modified; 1325 1326 if (D != 0) { 1327 Diag(Types[i]->getTypeLoc().getBeginLoc(), D) 1328 << Types[i]->getTypeLoc().getSourceRange() 1329 << Types[i]->getType(); 1330 TypeErrorFound = true; 1331 } 1332 1333 // C11 6.5.1.1p2 "No two generic associations in the same generic 1334 // selection shall specify compatible types." 1335 for (unsigned j = i+1; j < NumAssocs; ++j) 1336 if (Types[j] && !Types[j]->getType()->isDependentType() && 1337 Context.typesAreCompatible(Types[i]->getType(), 1338 Types[j]->getType())) { 1339 Diag(Types[j]->getTypeLoc().getBeginLoc(), 1340 diag::err_assoc_compatible_types) 1341 << Types[j]->getTypeLoc().getSourceRange() 1342 << Types[j]->getType() 1343 << Types[i]->getType(); 1344 Diag(Types[i]->getTypeLoc().getBeginLoc(), 1345 diag::note_compat_assoc) 1346 << Types[i]->getTypeLoc().getSourceRange() 1347 << Types[i]->getType(); 1348 TypeErrorFound = true; 1349 } 1350 } 1351 } 1352 } 1353 if (TypeErrorFound) 1354 return ExprError(); 1355 1356 // If we determined that the generic selection is result-dependent, don't 1357 // try to compute the result expression. 1358 if (IsResultDependent) 1359 return new (Context) GenericSelectionExpr( 1360 Context, KeyLoc, ControllingExpr, Types, Exprs, DefaultLoc, RParenLoc, 1361 ContainsUnexpandedParameterPack); 1362 1363 SmallVector<unsigned, 1> CompatIndices; 1364 unsigned DefaultIndex = -1U; 1365 for (unsigned i = 0; i < NumAssocs; ++i) { 1366 if (!Types[i]) 1367 DefaultIndex = i; 1368 else if (Context.typesAreCompatible(ControllingExpr->getType(), 1369 Types[i]->getType())) 1370 CompatIndices.push_back(i); 1371 } 1372 1373 // C11 6.5.1.1p2 "The controlling expression of a generic selection shall have 1374 // type compatible with at most one of the types named in its generic 1375 // association list." 1376 if (CompatIndices.size() > 1) { 1377 // We strip parens here because the controlling expression is typically 1378 // parenthesized in macro definitions. 1379 ControllingExpr = ControllingExpr->IgnoreParens(); 1380 Diag(ControllingExpr->getLocStart(), diag::err_generic_sel_multi_match) 1381 << ControllingExpr->getSourceRange() << ControllingExpr->getType() 1382 << (unsigned) CompatIndices.size(); 1383 for (SmallVectorImpl<unsigned>::iterator I = CompatIndices.begin(), 1384 E = CompatIndices.end(); I != E; ++I) { 1385 Diag(Types[*I]->getTypeLoc().getBeginLoc(), 1386 diag::note_compat_assoc) 1387 << Types[*I]->getTypeLoc().getSourceRange() 1388 << Types[*I]->getType(); 1389 } 1390 return ExprError(); 1391 } 1392 1393 // C11 6.5.1.1p2 "If a generic selection has no default generic association, 1394 // its controlling expression shall have type compatible with exactly one of 1395 // the types named in its generic association list." 1396 if (DefaultIndex == -1U && CompatIndices.size() == 0) { 1397 // We strip parens here because the controlling expression is typically 1398 // parenthesized in macro definitions. 1399 ControllingExpr = ControllingExpr->IgnoreParens(); 1400 Diag(ControllingExpr->getLocStart(), diag::err_generic_sel_no_match) 1401 << ControllingExpr->getSourceRange() << ControllingExpr->getType(); 1402 return ExprError(); 1403 } 1404 1405 // C11 6.5.1.1p3 "If a generic selection has a generic association with a 1406 // type name that is compatible with the type of the controlling expression, 1407 // then the result expression of the generic selection is the expression 1408 // in that generic association. Otherwise, the result expression of the 1409 // generic selection is the expression in the default generic association." 1410 unsigned ResultIndex = 1411 CompatIndices.size() ? CompatIndices[0] : DefaultIndex; 1412 1413 return new (Context) GenericSelectionExpr( 1414 Context, KeyLoc, ControllingExpr, Types, Exprs, DefaultLoc, RParenLoc, 1415 ContainsUnexpandedParameterPack, ResultIndex); 1416 } 1417 1418 /// getUDSuffixLoc - Create a SourceLocation for a ud-suffix, given the 1419 /// location of the token and the offset of the ud-suffix within it. 1420 static SourceLocation getUDSuffixLoc(Sema &S, SourceLocation TokLoc, 1421 unsigned Offset) { 1422 return Lexer::AdvanceToTokenCharacter(TokLoc, Offset, S.getSourceManager(), 1423 S.getLangOpts()); 1424 } 1425 1426 /// BuildCookedLiteralOperatorCall - A user-defined literal was found. Look up 1427 /// the corresponding cooked (non-raw) literal operator, and build a call to it. 1428 static ExprResult BuildCookedLiteralOperatorCall(Sema &S, Scope *Scope, 1429 IdentifierInfo *UDSuffix, 1430 SourceLocation UDSuffixLoc, 1431 ArrayRef<Expr*> Args, 1432 SourceLocation LitEndLoc) { 1433 assert(Args.size() <= 2 && "too many arguments for literal operator"); 1434 1435 QualType ArgTy[2]; 1436 for (unsigned ArgIdx = 0; ArgIdx != Args.size(); ++ArgIdx) { 1437 ArgTy[ArgIdx] = Args[ArgIdx]->getType(); 1438 if (ArgTy[ArgIdx]->isArrayType()) 1439 ArgTy[ArgIdx] = S.Context.getArrayDecayedType(ArgTy[ArgIdx]); 1440 } 1441 1442 DeclarationName OpName = 1443 S.Context.DeclarationNames.getCXXLiteralOperatorName(UDSuffix); 1444 DeclarationNameInfo OpNameInfo(OpName, UDSuffixLoc); 1445 OpNameInfo.setCXXLiteralOperatorNameLoc(UDSuffixLoc); 1446 1447 LookupResult R(S, OpName, UDSuffixLoc, Sema::LookupOrdinaryName); 1448 if (S.LookupLiteralOperator(Scope, R, llvm::makeArrayRef(ArgTy, Args.size()), 1449 /*AllowRaw*/false, /*AllowTemplate*/false, 1450 /*AllowStringTemplate*/false) == Sema::LOLR_Error) 1451 return ExprError(); 1452 1453 return S.BuildLiteralOperatorCall(R, OpNameInfo, Args, LitEndLoc); 1454 } 1455 1456 /// ActOnStringLiteral - The specified tokens were lexed as pasted string 1457 /// fragments (e.g. "foo" "bar" L"baz"). The result string has to handle string 1458 /// concatenation ([C99 5.1.1.2, translation phase #6]), so it may come from 1459 /// multiple tokens. However, the common case is that StringToks points to one 1460 /// string. 1461 /// 1462 ExprResult 1463 Sema::ActOnStringLiteral(ArrayRef<Token> StringToks, Scope *UDLScope) { 1464 assert(!StringToks.empty() && "Must have at least one string!"); 1465 1466 StringLiteralParser Literal(StringToks, PP); 1467 if (Literal.hadError) 1468 return ExprError(); 1469 1470 SmallVector<SourceLocation, 4> StringTokLocs; 1471 for (unsigned i = 0; i != StringToks.size(); ++i) 1472 StringTokLocs.push_back(StringToks[i].getLocation()); 1473 1474 QualType CharTy = Context.CharTy; 1475 StringLiteral::StringKind Kind = StringLiteral::Ascii; 1476 if (Literal.isWide()) { 1477 CharTy = Context.getWideCharType(); 1478 Kind = StringLiteral::Wide; 1479 } else if (Literal.isUTF8()) { 1480 Kind = StringLiteral::UTF8; 1481 } else if (Literal.isUTF16()) { 1482 CharTy = Context.Char16Ty; 1483 Kind = StringLiteral::UTF16; 1484 } else if (Literal.isUTF32()) { 1485 CharTy = Context.Char32Ty; 1486 Kind = StringLiteral::UTF32; 1487 } else if (Literal.isPascal()) { 1488 CharTy = Context.UnsignedCharTy; 1489 } 1490 1491 QualType CharTyConst = CharTy; 1492 // A C++ string literal has a const-qualified element type (C++ 2.13.4p1). 1493 if (getLangOpts().CPlusPlus || getLangOpts().ConstStrings) 1494 CharTyConst.addConst(); 1495 1496 // Get an array type for the string, according to C99 6.4.5. This includes 1497 // the nul terminator character as well as the string length for pascal 1498 // strings. 1499 QualType StrTy = Context.getConstantArrayType(CharTyConst, 1500 llvm::APInt(32, Literal.GetNumStringChars()+1), 1501 ArrayType::Normal, 0); 1502 1503 // OpenCL v1.1 s6.5.3: a string literal is in the constant address space. 1504 if (getLangOpts().OpenCL) { 1505 StrTy = Context.getAddrSpaceQualType(StrTy, LangAS::opencl_constant); 1506 } 1507 1508 // Pass &StringTokLocs[0], StringTokLocs.size() to factory! 1509 StringLiteral *Lit = StringLiteral::Create(Context, Literal.GetString(), 1510 Kind, Literal.Pascal, StrTy, 1511 &StringTokLocs[0], 1512 StringTokLocs.size()); 1513 if (Literal.getUDSuffix().empty()) 1514 return Lit; 1515 1516 // We're building a user-defined literal. 1517 IdentifierInfo *UDSuffix = &Context.Idents.get(Literal.getUDSuffix()); 1518 SourceLocation UDSuffixLoc = 1519 getUDSuffixLoc(*this, StringTokLocs[Literal.getUDSuffixToken()], 1520 Literal.getUDSuffixOffset()); 1521 1522 // Make sure we're allowed user-defined literals here. 1523 if (!UDLScope) 1524 return ExprError(Diag(UDSuffixLoc, diag::err_invalid_string_udl)); 1525 1526 // C++11 [lex.ext]p5: The literal L is treated as a call of the form 1527 // operator "" X (str, len) 1528 QualType SizeType = Context.getSizeType(); 1529 1530 DeclarationName OpName = 1531 Context.DeclarationNames.getCXXLiteralOperatorName(UDSuffix); 1532 DeclarationNameInfo OpNameInfo(OpName, UDSuffixLoc); 1533 OpNameInfo.setCXXLiteralOperatorNameLoc(UDSuffixLoc); 1534 1535 QualType ArgTy[] = { 1536 Context.getArrayDecayedType(StrTy), SizeType 1537 }; 1538 1539 LookupResult R(*this, OpName, UDSuffixLoc, LookupOrdinaryName); 1540 switch (LookupLiteralOperator(UDLScope, R, ArgTy, 1541 /*AllowRaw*/false, /*AllowTemplate*/false, 1542 /*AllowStringTemplate*/true)) { 1543 1544 case LOLR_Cooked: { 1545 llvm::APInt Len(Context.getIntWidth(SizeType), Literal.GetNumStringChars()); 1546 IntegerLiteral *LenArg = IntegerLiteral::Create(Context, Len, SizeType, 1547 StringTokLocs[0]); 1548 Expr *Args[] = { Lit, LenArg }; 1549 1550 return BuildLiteralOperatorCall(R, OpNameInfo, Args, StringTokLocs.back()); 1551 } 1552 1553 case LOLR_StringTemplate: { 1554 TemplateArgumentListInfo ExplicitArgs; 1555 1556 unsigned CharBits = Context.getIntWidth(CharTy); 1557 bool CharIsUnsigned = CharTy->isUnsignedIntegerType(); 1558 llvm::APSInt Value(CharBits, CharIsUnsigned); 1559 1560 TemplateArgument TypeArg(CharTy); 1561 TemplateArgumentLocInfo TypeArgInfo(Context.getTrivialTypeSourceInfo(CharTy)); 1562 ExplicitArgs.addArgument(TemplateArgumentLoc(TypeArg, TypeArgInfo)); 1563 1564 for (unsigned I = 0, N = Lit->getLength(); I != N; ++I) { 1565 Value = Lit->getCodeUnit(I); 1566 TemplateArgument Arg(Context, Value, CharTy); 1567 TemplateArgumentLocInfo ArgInfo; 1568 ExplicitArgs.addArgument(TemplateArgumentLoc(Arg, ArgInfo)); 1569 } 1570 return BuildLiteralOperatorCall(R, OpNameInfo, None, StringTokLocs.back(), 1571 &ExplicitArgs); 1572 } 1573 case LOLR_Raw: 1574 case LOLR_Template: 1575 llvm_unreachable("unexpected literal operator lookup result"); 1576 case LOLR_Error: 1577 return ExprError(); 1578 } 1579 llvm_unreachable("unexpected literal operator lookup result"); 1580 } 1581 1582 ExprResult 1583 Sema::BuildDeclRefExpr(ValueDecl *D, QualType Ty, ExprValueKind VK, 1584 SourceLocation Loc, 1585 const CXXScopeSpec *SS) { 1586 DeclarationNameInfo NameInfo(D->getDeclName(), Loc); 1587 return BuildDeclRefExpr(D, Ty, VK, NameInfo, SS); 1588 } 1589 1590 /// BuildDeclRefExpr - Build an expression that references a 1591 /// declaration that does not require a closure capture. 1592 ExprResult 1593 Sema::BuildDeclRefExpr(ValueDecl *D, QualType Ty, ExprValueKind VK, 1594 const DeclarationNameInfo &NameInfo, 1595 const CXXScopeSpec *SS, NamedDecl *FoundD, 1596 const TemplateArgumentListInfo *TemplateArgs) { 1597 if (getLangOpts().CUDA) 1598 if (const FunctionDecl *Caller = dyn_cast<FunctionDecl>(CurContext)) 1599 if (const FunctionDecl *Callee = dyn_cast<FunctionDecl>(D)) { 1600 if (CheckCUDATarget(Caller, Callee)) { 1601 Diag(NameInfo.getLoc(), diag::err_ref_bad_target) 1602 << IdentifyCUDATarget(Callee) << D->getIdentifier() 1603 << IdentifyCUDATarget(Caller); 1604 Diag(D->getLocation(), diag::note_previous_decl) 1605 << D->getIdentifier(); 1606 return ExprError(); 1607 } 1608 } 1609 1610 bool RefersToCapturedVariable = 1611 isa<VarDecl>(D) && 1612 NeedToCaptureVariable(cast<VarDecl>(D), NameInfo.getLoc()); 1613 1614 DeclRefExpr *E; 1615 if (isa<VarTemplateSpecializationDecl>(D)) { 1616 VarTemplateSpecializationDecl *VarSpec = 1617 cast<VarTemplateSpecializationDecl>(D); 1618 1619 E = DeclRefExpr::Create(Context, SS ? SS->getWithLocInContext(Context) 1620 : NestedNameSpecifierLoc(), 1621 VarSpec->getTemplateKeywordLoc(), D, 1622 RefersToCapturedVariable, NameInfo.getLoc(), Ty, VK, 1623 FoundD, TemplateArgs); 1624 } else { 1625 assert(!TemplateArgs && "No template arguments for non-variable" 1626 " template specialization references"); 1627 E = DeclRefExpr::Create(Context, SS ? SS->getWithLocInContext(Context) 1628 : NestedNameSpecifierLoc(), 1629 SourceLocation(), D, RefersToCapturedVariable, 1630 NameInfo, Ty, VK, FoundD); 1631 } 1632 1633 MarkDeclRefReferenced(E); 1634 1635 if (getLangOpts().ObjCARCWeak && isa<VarDecl>(D) && 1636 Ty.getObjCLifetime() == Qualifiers::OCL_Weak && 1637 !Diags.isIgnored(diag::warn_arc_repeated_use_of_weak, E->getLocStart())) 1638 recordUseOfEvaluatedWeak(E); 1639 1640 // Just in case we're building an illegal pointer-to-member. 1641 FieldDecl *FD = dyn_cast<FieldDecl>(D); 1642 if (FD && FD->isBitField()) 1643 E->setObjectKind(OK_BitField); 1644 1645 return E; 1646 } 1647 1648 /// Decomposes the given name into a DeclarationNameInfo, its location, and 1649 /// possibly a list of template arguments. 1650 /// 1651 /// If this produces template arguments, it is permitted to call 1652 /// DecomposeTemplateName. 1653 /// 1654 /// This actually loses a lot of source location information for 1655 /// non-standard name kinds; we should consider preserving that in 1656 /// some way. 1657 void 1658 Sema::DecomposeUnqualifiedId(const UnqualifiedId &Id, 1659 TemplateArgumentListInfo &Buffer, 1660 DeclarationNameInfo &NameInfo, 1661 const TemplateArgumentListInfo *&TemplateArgs) { 1662 if (Id.getKind() == UnqualifiedId::IK_TemplateId) { 1663 Buffer.setLAngleLoc(Id.TemplateId->LAngleLoc); 1664 Buffer.setRAngleLoc(Id.TemplateId->RAngleLoc); 1665 1666 ASTTemplateArgsPtr TemplateArgsPtr(Id.TemplateId->getTemplateArgs(), 1667 Id.TemplateId->NumArgs); 1668 translateTemplateArguments(TemplateArgsPtr, Buffer); 1669 1670 TemplateName TName = Id.TemplateId->Template.get(); 1671 SourceLocation TNameLoc = Id.TemplateId->TemplateNameLoc; 1672 NameInfo = Context.getNameForTemplate(TName, TNameLoc); 1673 TemplateArgs = &Buffer; 1674 } else { 1675 NameInfo = GetNameFromUnqualifiedId(Id); 1676 TemplateArgs = nullptr; 1677 } 1678 } 1679 1680 static void emitEmptyLookupTypoDiagnostic( 1681 const TypoCorrection &TC, Sema &SemaRef, const CXXScopeSpec &SS, 1682 DeclarationName Typo, SourceLocation TypoLoc, ArrayRef<Expr *> Args, 1683 unsigned DiagnosticID, unsigned DiagnosticSuggestID) { 1684 DeclContext *Ctx = 1685 SS.isEmpty() ? nullptr : SemaRef.computeDeclContext(SS, false); 1686 if (!TC) { 1687 // Emit a special diagnostic for failed member lookups. 1688 // FIXME: computing the declaration context might fail here (?) 1689 if (Ctx) 1690 SemaRef.Diag(TypoLoc, diag::err_no_member) << Typo << Ctx 1691 << SS.getRange(); 1692 else 1693 SemaRef.Diag(TypoLoc, DiagnosticID) << Typo; 1694 return; 1695 } 1696 1697 std::string CorrectedStr = TC.getAsString(SemaRef.getLangOpts()); 1698 bool DroppedSpecifier = 1699 TC.WillReplaceSpecifier() && Typo.getAsString() == CorrectedStr; 1700 unsigned NoteID = 1701 (TC.getCorrectionDecl() && isa<ImplicitParamDecl>(TC.getCorrectionDecl())) 1702 ? diag::note_implicit_param_decl 1703 : diag::note_previous_decl; 1704 if (!Ctx) 1705 SemaRef.diagnoseTypo(TC, SemaRef.PDiag(DiagnosticSuggestID) << Typo, 1706 SemaRef.PDiag(NoteID)); 1707 else 1708 SemaRef.diagnoseTypo(TC, SemaRef.PDiag(diag::err_no_member_suggest) 1709 << Typo << Ctx << DroppedSpecifier 1710 << SS.getRange(), 1711 SemaRef.PDiag(NoteID)); 1712 } 1713 1714 /// Diagnose an empty lookup. 1715 /// 1716 /// \return false if new lookup candidates were found 1717 bool 1718 Sema::DiagnoseEmptyLookup(Scope *S, CXXScopeSpec &SS, LookupResult &R, 1719 std::unique_ptr<CorrectionCandidateCallback> CCC, 1720 TemplateArgumentListInfo *ExplicitTemplateArgs, 1721 ArrayRef<Expr *> Args, TypoExpr **Out) { 1722 DeclarationName Name = R.getLookupName(); 1723 1724 unsigned diagnostic = diag::err_undeclared_var_use; 1725 unsigned diagnostic_suggest = diag::err_undeclared_var_use_suggest; 1726 if (Name.getNameKind() == DeclarationName::CXXOperatorName || 1727 Name.getNameKind() == DeclarationName::CXXLiteralOperatorName || 1728 Name.getNameKind() == DeclarationName::CXXConversionFunctionName) { 1729 diagnostic = diag::err_undeclared_use; 1730 diagnostic_suggest = diag::err_undeclared_use_suggest; 1731 } 1732 1733 // If the original lookup was an unqualified lookup, fake an 1734 // unqualified lookup. This is useful when (for example) the 1735 // original lookup would not have found something because it was a 1736 // dependent name. 1737 DeclContext *DC = (SS.isEmpty() && !CallsUndergoingInstantiation.empty()) 1738 ? CurContext : nullptr; 1739 while (DC) { 1740 if (isa<CXXRecordDecl>(DC)) { 1741 LookupQualifiedName(R, DC); 1742 1743 if (!R.empty()) { 1744 // Don't give errors about ambiguities in this lookup. 1745 R.suppressDiagnostics(); 1746 1747 // During a default argument instantiation the CurContext points 1748 // to a CXXMethodDecl; but we can't apply a this-> fixit inside a 1749 // function parameter list, hence add an explicit check. 1750 bool isDefaultArgument = !ActiveTemplateInstantiations.empty() && 1751 ActiveTemplateInstantiations.back().Kind == 1752 ActiveTemplateInstantiation::DefaultFunctionArgumentInstantiation; 1753 CXXMethodDecl *CurMethod = dyn_cast<CXXMethodDecl>(CurContext); 1754 bool isInstance = CurMethod && 1755 CurMethod->isInstance() && 1756 DC == CurMethod->getParent() && !isDefaultArgument; 1757 1758 1759 // Give a code modification hint to insert 'this->'. 1760 // TODO: fixit for inserting 'Base<T>::' in the other cases. 1761 // Actually quite difficult! 1762 if (getLangOpts().MSVCCompat) 1763 diagnostic = diag::ext_found_via_dependent_bases_lookup; 1764 if (isInstance) { 1765 Diag(R.getNameLoc(), diagnostic) << Name 1766 << FixItHint::CreateInsertion(R.getNameLoc(), "this->"); 1767 UnresolvedLookupExpr *ULE = cast<UnresolvedLookupExpr>( 1768 CallsUndergoingInstantiation.back()->getCallee()); 1769 1770 CXXMethodDecl *DepMethod; 1771 if (CurMethod->isDependentContext()) 1772 DepMethod = CurMethod; 1773 else if (CurMethod->getTemplatedKind() == 1774 FunctionDecl::TK_FunctionTemplateSpecialization) 1775 DepMethod = cast<CXXMethodDecl>(CurMethod->getPrimaryTemplate()-> 1776 getInstantiatedFromMemberTemplate()->getTemplatedDecl()); 1777 else 1778 DepMethod = cast<CXXMethodDecl>( 1779 CurMethod->getInstantiatedFromMemberFunction()); 1780 assert(DepMethod && "No template pattern found"); 1781 1782 QualType DepThisType = DepMethod->getThisType(Context); 1783 CheckCXXThisCapture(R.getNameLoc()); 1784 CXXThisExpr *DepThis = new (Context) CXXThisExpr( 1785 R.getNameLoc(), DepThisType, false); 1786 TemplateArgumentListInfo TList; 1787 if (ULE->hasExplicitTemplateArgs()) 1788 ULE->copyTemplateArgumentsInto(TList); 1789 1790 CXXScopeSpec SS; 1791 SS.Adopt(ULE->getQualifierLoc()); 1792 CXXDependentScopeMemberExpr *DepExpr = 1793 CXXDependentScopeMemberExpr::Create( 1794 Context, DepThis, DepThisType, true, SourceLocation(), 1795 SS.getWithLocInContext(Context), 1796 ULE->getTemplateKeywordLoc(), nullptr, 1797 R.getLookupNameInfo(), 1798 ULE->hasExplicitTemplateArgs() ? &TList : nullptr); 1799 CallsUndergoingInstantiation.back()->setCallee(DepExpr); 1800 } else { 1801 Diag(R.getNameLoc(), diagnostic) << Name; 1802 } 1803 1804 // Do we really want to note all of these? 1805 for (LookupResult::iterator I = R.begin(), E = R.end(); I != E; ++I) 1806 Diag((*I)->getLocation(), diag::note_dependent_var_use); 1807 1808 // Return true if we are inside a default argument instantiation 1809 // and the found name refers to an instance member function, otherwise 1810 // the function calling DiagnoseEmptyLookup will try to create an 1811 // implicit member call and this is wrong for default argument. 1812 if (isDefaultArgument && ((*R.begin())->isCXXInstanceMember())) { 1813 Diag(R.getNameLoc(), diag::err_member_call_without_object); 1814 return true; 1815 } 1816 1817 // Tell the callee to try to recover. 1818 return false; 1819 } 1820 1821 R.clear(); 1822 } 1823 1824 // In Microsoft mode, if we are performing lookup from within a friend 1825 // function definition declared at class scope then we must set 1826 // DC to the lexical parent to be able to search into the parent 1827 // class. 1828 if (getLangOpts().MSVCCompat && isa<FunctionDecl>(DC) && 1829 cast<FunctionDecl>(DC)->getFriendObjectKind() && 1830 DC->getLexicalParent()->isRecord()) 1831 DC = DC->getLexicalParent(); 1832 else 1833 DC = DC->getParent(); 1834 } 1835 1836 // We didn't find anything, so try to correct for a typo. 1837 TypoCorrection Corrected; 1838 if (S && Out) { 1839 SourceLocation TypoLoc = R.getNameLoc(); 1840 assert(!ExplicitTemplateArgs && 1841 "Diagnosing an empty lookup with explicit template args!"); 1842 *Out = CorrectTypoDelayed( 1843 R.getLookupNameInfo(), R.getLookupKind(), S, &SS, std::move(CCC), 1844 [=](const TypoCorrection &TC) { 1845 emitEmptyLookupTypoDiagnostic(TC, *this, SS, Name, TypoLoc, Args, 1846 diagnostic, diagnostic_suggest); 1847 }, 1848 nullptr, CTK_ErrorRecovery); 1849 if (*Out) 1850 return true; 1851 } else if (S && (Corrected = 1852 CorrectTypo(R.getLookupNameInfo(), R.getLookupKind(), S, 1853 &SS, std::move(CCC), CTK_ErrorRecovery))) { 1854 std::string CorrectedStr(Corrected.getAsString(getLangOpts())); 1855 bool DroppedSpecifier = 1856 Corrected.WillReplaceSpecifier() && Name.getAsString() == CorrectedStr; 1857 R.setLookupName(Corrected.getCorrection()); 1858 1859 bool AcceptableWithRecovery = false; 1860 bool AcceptableWithoutRecovery = false; 1861 NamedDecl *ND = Corrected.getCorrectionDecl(); 1862 if (ND) { 1863 if (Corrected.isOverloaded()) { 1864 OverloadCandidateSet OCS(R.getNameLoc(), 1865 OverloadCandidateSet::CSK_Normal); 1866 OverloadCandidateSet::iterator Best; 1867 for (TypoCorrection::decl_iterator CD = Corrected.begin(), 1868 CDEnd = Corrected.end(); 1869 CD != CDEnd; ++CD) { 1870 if (FunctionTemplateDecl *FTD = 1871 dyn_cast<FunctionTemplateDecl>(*CD)) 1872 AddTemplateOverloadCandidate( 1873 FTD, DeclAccessPair::make(FTD, AS_none), ExplicitTemplateArgs, 1874 Args, OCS); 1875 else if (FunctionDecl *FD = dyn_cast<FunctionDecl>(*CD)) 1876 if (!ExplicitTemplateArgs || ExplicitTemplateArgs->size() == 0) 1877 AddOverloadCandidate(FD, DeclAccessPair::make(FD, AS_none), 1878 Args, OCS); 1879 } 1880 switch (OCS.BestViableFunction(*this, R.getNameLoc(), Best)) { 1881 case OR_Success: 1882 ND = Best->Function; 1883 Corrected.setCorrectionDecl(ND); 1884 break; 1885 default: 1886 // FIXME: Arbitrarily pick the first declaration for the note. 1887 Corrected.setCorrectionDecl(ND); 1888 break; 1889 } 1890 } 1891 R.addDecl(ND); 1892 if (getLangOpts().CPlusPlus && ND->isCXXClassMember()) { 1893 CXXRecordDecl *Record = nullptr; 1894 if (Corrected.getCorrectionSpecifier()) { 1895 const Type *Ty = Corrected.getCorrectionSpecifier()->getAsType(); 1896 Record = Ty->getAsCXXRecordDecl(); 1897 } 1898 if (!Record) 1899 Record = cast<CXXRecordDecl>( 1900 ND->getDeclContext()->getRedeclContext()); 1901 R.setNamingClass(Record); 1902 } 1903 1904 AcceptableWithRecovery = 1905 isa<ValueDecl>(ND) || isa<FunctionTemplateDecl>(ND); 1906 // FIXME: If we ended up with a typo for a type name or 1907 // Objective-C class name, we're in trouble because the parser 1908 // is in the wrong place to recover. Suggest the typo 1909 // correction, but don't make it a fix-it since we're not going 1910 // to recover well anyway. 1911 AcceptableWithoutRecovery = 1912 isa<TypeDecl>(ND) || isa<ObjCInterfaceDecl>(ND); 1913 } else { 1914 // FIXME: We found a keyword. Suggest it, but don't provide a fix-it 1915 // because we aren't able to recover. 1916 AcceptableWithoutRecovery = true; 1917 } 1918 1919 if (AcceptableWithRecovery || AcceptableWithoutRecovery) { 1920 unsigned NoteID = (Corrected.getCorrectionDecl() && 1921 isa<ImplicitParamDecl>(Corrected.getCorrectionDecl())) 1922 ? diag::note_implicit_param_decl 1923 : diag::note_previous_decl; 1924 if (SS.isEmpty()) 1925 diagnoseTypo(Corrected, PDiag(diagnostic_suggest) << Name, 1926 PDiag(NoteID), AcceptableWithRecovery); 1927 else 1928 diagnoseTypo(Corrected, PDiag(diag::err_no_member_suggest) 1929 << Name << computeDeclContext(SS, false) 1930 << DroppedSpecifier << SS.getRange(), 1931 PDiag(NoteID), AcceptableWithRecovery); 1932 1933 // Tell the callee whether to try to recover. 1934 return !AcceptableWithRecovery; 1935 } 1936 } 1937 R.clear(); 1938 1939 // Emit a special diagnostic for failed member lookups. 1940 // FIXME: computing the declaration context might fail here (?) 1941 if (!SS.isEmpty()) { 1942 Diag(R.getNameLoc(), diag::err_no_member) 1943 << Name << computeDeclContext(SS, false) 1944 << SS.getRange(); 1945 return true; 1946 } 1947 1948 // Give up, we can't recover. 1949 Diag(R.getNameLoc(), diagnostic) << Name; 1950 return true; 1951 } 1952 1953 /// In Microsoft mode, if we are inside a template class whose parent class has 1954 /// dependent base classes, and we can't resolve an unqualified identifier, then 1955 /// assume the identifier is a member of a dependent base class. We can only 1956 /// recover successfully in static methods, instance methods, and other contexts 1957 /// where 'this' is available. This doesn't precisely match MSVC's 1958 /// instantiation model, but it's close enough. 1959 static Expr * 1960 recoverFromMSUnqualifiedLookup(Sema &S, ASTContext &Context, 1961 DeclarationNameInfo &NameInfo, 1962 SourceLocation TemplateKWLoc, 1963 const TemplateArgumentListInfo *TemplateArgs) { 1964 // Only try to recover from lookup into dependent bases in static methods or 1965 // contexts where 'this' is available. 1966 QualType ThisType = S.getCurrentThisType(); 1967 const CXXRecordDecl *RD = nullptr; 1968 if (!ThisType.isNull()) 1969 RD = ThisType->getPointeeType()->getAsCXXRecordDecl(); 1970 else if (auto *MD = dyn_cast<CXXMethodDecl>(S.CurContext)) 1971 RD = MD->getParent(); 1972 if (!RD || !RD->hasAnyDependentBases()) 1973 return nullptr; 1974 1975 // Diagnose this as unqualified lookup into a dependent base class. If 'this' 1976 // is available, suggest inserting 'this->' as a fixit. 1977 SourceLocation Loc = NameInfo.getLoc(); 1978 auto DB = S.Diag(Loc, diag::ext_undeclared_unqual_id_with_dependent_base); 1979 DB << NameInfo.getName() << RD; 1980 1981 if (!ThisType.isNull()) { 1982 DB << FixItHint::CreateInsertion(Loc, "this->"); 1983 return CXXDependentScopeMemberExpr::Create( 1984 Context, /*This=*/nullptr, ThisType, /*IsArrow=*/true, 1985 /*Op=*/SourceLocation(), NestedNameSpecifierLoc(), TemplateKWLoc, 1986 /*FirstQualifierInScope=*/nullptr, NameInfo, TemplateArgs); 1987 } 1988 1989 // Synthesize a fake NNS that points to the derived class. This will 1990 // perform name lookup during template instantiation. 1991 CXXScopeSpec SS; 1992 auto *NNS = 1993 NestedNameSpecifier::Create(Context, nullptr, true, RD->getTypeForDecl()); 1994 SS.MakeTrivial(Context, NNS, SourceRange(Loc, Loc)); 1995 return DependentScopeDeclRefExpr::Create( 1996 Context, SS.getWithLocInContext(Context), TemplateKWLoc, NameInfo, 1997 TemplateArgs); 1998 } 1999 2000 ExprResult 2001 Sema::ActOnIdExpression(Scope *S, CXXScopeSpec &SS, 2002 SourceLocation TemplateKWLoc, UnqualifiedId &Id, 2003 bool HasTrailingLParen, bool IsAddressOfOperand, 2004 std::unique_ptr<CorrectionCandidateCallback> CCC, 2005 bool IsInlineAsmIdentifier, Token *KeywordReplacement) { 2006 assert(!(IsAddressOfOperand && HasTrailingLParen) && 2007 "cannot be direct & operand and have a trailing lparen"); 2008 if (SS.isInvalid()) 2009 return ExprError(); 2010 2011 TemplateArgumentListInfo TemplateArgsBuffer; 2012 2013 // Decompose the UnqualifiedId into the following data. 2014 DeclarationNameInfo NameInfo; 2015 const TemplateArgumentListInfo *TemplateArgs; 2016 DecomposeUnqualifiedId(Id, TemplateArgsBuffer, NameInfo, TemplateArgs); 2017 2018 DeclarationName Name = NameInfo.getName(); 2019 IdentifierInfo *II = Name.getAsIdentifierInfo(); 2020 SourceLocation NameLoc = NameInfo.getLoc(); 2021 2022 // C++ [temp.dep.expr]p3: 2023 // An id-expression is type-dependent if it contains: 2024 // -- an identifier that was declared with a dependent type, 2025 // (note: handled after lookup) 2026 // -- a template-id that is dependent, 2027 // (note: handled in BuildTemplateIdExpr) 2028 // -- a conversion-function-id that specifies a dependent type, 2029 // -- a nested-name-specifier that contains a class-name that 2030 // names a dependent type. 2031 // Determine whether this is a member of an unknown specialization; 2032 // we need to handle these differently. 2033 bool DependentID = false; 2034 if (Name.getNameKind() == DeclarationName::CXXConversionFunctionName && 2035 Name.getCXXNameType()->isDependentType()) { 2036 DependentID = true; 2037 } else if (SS.isSet()) { 2038 if (DeclContext *DC = computeDeclContext(SS, false)) { 2039 if (RequireCompleteDeclContext(SS, DC)) 2040 return ExprError(); 2041 } else { 2042 DependentID = true; 2043 } 2044 } 2045 2046 if (DependentID) 2047 return ActOnDependentIdExpression(SS, TemplateKWLoc, NameInfo, 2048 IsAddressOfOperand, TemplateArgs); 2049 2050 // Perform the required lookup. 2051 LookupResult R(*this, NameInfo, 2052 (Id.getKind() == UnqualifiedId::IK_ImplicitSelfParam) 2053 ? LookupObjCImplicitSelfParam : LookupOrdinaryName); 2054 if (TemplateArgs) { 2055 // Lookup the template name again to correctly establish the context in 2056 // which it was found. This is really unfortunate as we already did the 2057 // lookup to determine that it was a template name in the first place. If 2058 // this becomes a performance hit, we can work harder to preserve those 2059 // results until we get here but it's likely not worth it. 2060 bool MemberOfUnknownSpecialization; 2061 LookupTemplateName(R, S, SS, QualType(), /*EnteringContext=*/false, 2062 MemberOfUnknownSpecialization); 2063 2064 if (MemberOfUnknownSpecialization || 2065 (R.getResultKind() == LookupResult::NotFoundInCurrentInstantiation)) 2066 return ActOnDependentIdExpression(SS, TemplateKWLoc, NameInfo, 2067 IsAddressOfOperand, TemplateArgs); 2068 } else { 2069 bool IvarLookupFollowUp = II && !SS.isSet() && getCurMethodDecl(); 2070 LookupParsedName(R, S, &SS, !IvarLookupFollowUp); 2071 2072 // If the result might be in a dependent base class, this is a dependent 2073 // id-expression. 2074 if (R.getResultKind() == LookupResult::NotFoundInCurrentInstantiation) 2075 return ActOnDependentIdExpression(SS, TemplateKWLoc, NameInfo, 2076 IsAddressOfOperand, TemplateArgs); 2077 2078 // If this reference is in an Objective-C method, then we need to do 2079 // some special Objective-C lookup, too. 2080 if (IvarLookupFollowUp) { 2081 ExprResult E(LookupInObjCMethod(R, S, II, true)); 2082 if (E.isInvalid()) 2083 return ExprError(); 2084 2085 if (Expr *Ex = E.getAs<Expr>()) 2086 return Ex; 2087 } 2088 } 2089 2090 if (R.isAmbiguous()) 2091 return ExprError(); 2092 2093 // This could be an implicitly declared function reference (legal in C90, 2094 // extension in C99, forbidden in C++). 2095 if (R.empty() && HasTrailingLParen && II && !getLangOpts().CPlusPlus) { 2096 NamedDecl *D = ImplicitlyDefineFunction(NameLoc, *II, S); 2097 if (D) R.addDecl(D); 2098 } 2099 2100 // Determine whether this name might be a candidate for 2101 // argument-dependent lookup. 2102 bool ADL = UseArgumentDependentLookup(SS, R, HasTrailingLParen); 2103 2104 if (R.empty() && !ADL) { 2105 if (SS.isEmpty() && getLangOpts().MSVCCompat) { 2106 if (Expr *E = recoverFromMSUnqualifiedLookup(*this, Context, NameInfo, 2107 TemplateKWLoc, TemplateArgs)) 2108 return E; 2109 } 2110 2111 // Don't diagnose an empty lookup for inline assembly. 2112 if (IsInlineAsmIdentifier) 2113 return ExprError(); 2114 2115 // If this name wasn't predeclared and if this is not a function 2116 // call, diagnose the problem. 2117 TypoExpr *TE = nullptr; 2118 auto DefaultValidator = llvm::make_unique<CorrectionCandidateCallback>( 2119 II, SS.isValid() ? SS.getScopeRep() : nullptr); 2120 DefaultValidator->IsAddressOfOperand = IsAddressOfOperand; 2121 assert((!CCC || CCC->IsAddressOfOperand == IsAddressOfOperand) && 2122 "Typo correction callback misconfigured"); 2123 if (CCC) { 2124 // Make sure the callback knows what the typo being diagnosed is. 2125 CCC->setTypoName(II); 2126 if (SS.isValid()) 2127 CCC->setTypoNNS(SS.getScopeRep()); 2128 } 2129 if (DiagnoseEmptyLookup(S, SS, R, 2130 CCC ? std::move(CCC) : std::move(DefaultValidator), 2131 nullptr, None, &TE)) { 2132 if (TE && KeywordReplacement) { 2133 auto &State = getTypoExprState(TE); 2134 auto BestTC = State.Consumer->getNextCorrection(); 2135 if (BestTC.isKeyword()) { 2136 auto *II = BestTC.getCorrectionAsIdentifierInfo(); 2137 if (State.DiagHandler) 2138 State.DiagHandler(BestTC); 2139 KeywordReplacement->startToken(); 2140 KeywordReplacement->setKind(II->getTokenID()); 2141 KeywordReplacement->setIdentifierInfo(II); 2142 KeywordReplacement->setLocation(BestTC.getCorrectionRange().getBegin()); 2143 // Clean up the state associated with the TypoExpr, since it has 2144 // now been diagnosed (without a call to CorrectDelayedTyposInExpr). 2145 clearDelayedTypo(TE); 2146 // Signal that a correction to a keyword was performed by returning a 2147 // valid-but-null ExprResult. 2148 return (Expr*)nullptr; 2149 } 2150 State.Consumer->resetCorrectionStream(); 2151 } 2152 return TE ? TE : ExprError(); 2153 } 2154 2155 assert(!R.empty() && 2156 "DiagnoseEmptyLookup returned false but added no results"); 2157 2158 // If we found an Objective-C instance variable, let 2159 // LookupInObjCMethod build the appropriate expression to 2160 // reference the ivar. 2161 if (ObjCIvarDecl *Ivar = R.getAsSingle<ObjCIvarDecl>()) { 2162 R.clear(); 2163 ExprResult E(LookupInObjCMethod(R, S, Ivar->getIdentifier())); 2164 // In a hopelessly buggy code, Objective-C instance variable 2165 // lookup fails and no expression will be built to reference it. 2166 if (!E.isInvalid() && !E.get()) 2167 return ExprError(); 2168 return E; 2169 } 2170 } 2171 2172 // This is guaranteed from this point on. 2173 assert(!R.empty() || ADL); 2174 2175 // Check whether this might be a C++ implicit instance member access. 2176 // C++ [class.mfct.non-static]p3: 2177 // When an id-expression that is not part of a class member access 2178 // syntax and not used to form a pointer to member is used in the 2179 // body of a non-static member function of class X, if name lookup 2180 // resolves the name in the id-expression to a non-static non-type 2181 // member of some class C, the id-expression is transformed into a 2182 // class member access expression using (*this) as the 2183 // postfix-expression to the left of the . operator. 2184 // 2185 // But we don't actually need to do this for '&' operands if R 2186 // resolved to a function or overloaded function set, because the 2187 // expression is ill-formed if it actually works out to be a 2188 // non-static member function: 2189 // 2190 // C++ [expr.ref]p4: 2191 // Otherwise, if E1.E2 refers to a non-static member function. . . 2192 // [t]he expression can be used only as the left-hand operand of a 2193 // member function call. 2194 // 2195 // There are other safeguards against such uses, but it's important 2196 // to get this right here so that we don't end up making a 2197 // spuriously dependent expression if we're inside a dependent 2198 // instance method. 2199 if (!R.empty() && (*R.begin())->isCXXClassMember()) { 2200 bool MightBeImplicitMember; 2201 if (!IsAddressOfOperand) 2202 MightBeImplicitMember = true; 2203 else if (!SS.isEmpty()) 2204 MightBeImplicitMember = false; 2205 else if (R.isOverloadedResult()) 2206 MightBeImplicitMember = false; 2207 else if (R.isUnresolvableResult()) 2208 MightBeImplicitMember = true; 2209 else 2210 MightBeImplicitMember = isa<FieldDecl>(R.getFoundDecl()) || 2211 isa<IndirectFieldDecl>(R.getFoundDecl()) || 2212 isa<MSPropertyDecl>(R.getFoundDecl()); 2213 2214 if (MightBeImplicitMember) 2215 return BuildPossibleImplicitMemberExpr(SS, TemplateKWLoc, 2216 R, TemplateArgs); 2217 } 2218 2219 if (TemplateArgs || TemplateKWLoc.isValid()) { 2220 2221 // In C++1y, if this is a variable template id, then check it 2222 // in BuildTemplateIdExpr(). 2223 // The single lookup result must be a variable template declaration. 2224 if (Id.getKind() == UnqualifiedId::IK_TemplateId && Id.TemplateId && 2225 Id.TemplateId->Kind == TNK_Var_template) { 2226 assert(R.getAsSingle<VarTemplateDecl>() && 2227 "There should only be one declaration found."); 2228 } 2229 2230 return BuildTemplateIdExpr(SS, TemplateKWLoc, R, ADL, TemplateArgs); 2231 } 2232 2233 return BuildDeclarationNameExpr(SS, R, ADL); 2234 } 2235 2236 /// BuildQualifiedDeclarationNameExpr - Build a C++ qualified 2237 /// declaration name, generally during template instantiation. 2238 /// There's a large number of things which don't need to be done along 2239 /// this path. 2240 ExprResult 2241 Sema::BuildQualifiedDeclarationNameExpr(CXXScopeSpec &SS, 2242 const DeclarationNameInfo &NameInfo, 2243 bool IsAddressOfOperand, 2244 TypeSourceInfo **RecoveryTSI) { 2245 DeclContext *DC = computeDeclContext(SS, false); 2246 if (!DC) 2247 return BuildDependentDeclRefExpr(SS, /*TemplateKWLoc=*/SourceLocation(), 2248 NameInfo, /*TemplateArgs=*/nullptr); 2249 2250 if (RequireCompleteDeclContext(SS, DC)) 2251 return ExprError(); 2252 2253 LookupResult R(*this, NameInfo, LookupOrdinaryName); 2254 LookupQualifiedName(R, DC); 2255 2256 if (R.isAmbiguous()) 2257 return ExprError(); 2258 2259 if (R.getResultKind() == LookupResult::NotFoundInCurrentInstantiation) 2260 return BuildDependentDeclRefExpr(SS, /*TemplateKWLoc=*/SourceLocation(), 2261 NameInfo, /*TemplateArgs=*/nullptr); 2262 2263 if (R.empty()) { 2264 Diag(NameInfo.getLoc(), diag::err_no_member) 2265 << NameInfo.getName() << DC << SS.getRange(); 2266 return ExprError(); 2267 } 2268 2269 if (const TypeDecl *TD = R.getAsSingle<TypeDecl>()) { 2270 // Diagnose a missing typename if this resolved unambiguously to a type in 2271 // a dependent context. If we can recover with a type, downgrade this to 2272 // a warning in Microsoft compatibility mode. 2273 unsigned DiagID = diag::err_typename_missing; 2274 if (RecoveryTSI && getLangOpts().MSVCCompat) 2275 DiagID = diag::ext_typename_missing; 2276 SourceLocation Loc = SS.getBeginLoc(); 2277 auto D = Diag(Loc, DiagID); 2278 D << SS.getScopeRep() << NameInfo.getName().getAsString() 2279 << SourceRange(Loc, NameInfo.getEndLoc()); 2280 2281 // Don't recover if the caller isn't expecting us to or if we're in a SFINAE 2282 // context. 2283 if (!RecoveryTSI) 2284 return ExprError(); 2285 2286 // Only issue the fixit if we're prepared to recover. 2287 D << FixItHint::CreateInsertion(Loc, "typename "); 2288 2289 // Recover by pretending this was an elaborated type. 2290 QualType Ty = Context.getTypeDeclType(TD); 2291 TypeLocBuilder TLB; 2292 TLB.pushTypeSpec(Ty).setNameLoc(NameInfo.getLoc()); 2293 2294 QualType ET = getElaboratedType(ETK_None, SS, Ty); 2295 ElaboratedTypeLoc QTL = TLB.push<ElaboratedTypeLoc>(ET); 2296 QTL.setElaboratedKeywordLoc(SourceLocation()); 2297 QTL.setQualifierLoc(SS.getWithLocInContext(Context)); 2298 2299 *RecoveryTSI = TLB.getTypeSourceInfo(Context, ET); 2300 2301 return ExprEmpty(); 2302 } 2303 2304 // Defend against this resolving to an implicit member access. We usually 2305 // won't get here if this might be a legitimate a class member (we end up in 2306 // BuildMemberReferenceExpr instead), but this can be valid if we're forming 2307 // a pointer-to-member or in an unevaluated context in C++11. 2308 if (!R.empty() && (*R.begin())->isCXXClassMember() && !IsAddressOfOperand) 2309 return BuildPossibleImplicitMemberExpr(SS, 2310 /*TemplateKWLoc=*/SourceLocation(), 2311 R, /*TemplateArgs=*/nullptr); 2312 2313 return BuildDeclarationNameExpr(SS, R, /* ADL */ false); 2314 } 2315 2316 /// LookupInObjCMethod - The parser has read a name in, and Sema has 2317 /// detected that we're currently inside an ObjC method. Perform some 2318 /// additional lookup. 2319 /// 2320 /// Ideally, most of this would be done by lookup, but there's 2321 /// actually quite a lot of extra work involved. 2322 /// 2323 /// Returns a null sentinel to indicate trivial success. 2324 ExprResult 2325 Sema::LookupInObjCMethod(LookupResult &Lookup, Scope *S, 2326 IdentifierInfo *II, bool AllowBuiltinCreation) { 2327 SourceLocation Loc = Lookup.getNameLoc(); 2328 ObjCMethodDecl *CurMethod = getCurMethodDecl(); 2329 2330 // Check for error condition which is already reported. 2331 if (!CurMethod) 2332 return ExprError(); 2333 2334 // There are two cases to handle here. 1) scoped lookup could have failed, 2335 // in which case we should look for an ivar. 2) scoped lookup could have 2336 // found a decl, but that decl is outside the current instance method (i.e. 2337 // a global variable). In these two cases, we do a lookup for an ivar with 2338 // this name, if the lookup sucedes, we replace it our current decl. 2339 2340 // If we're in a class method, we don't normally want to look for 2341 // ivars. But if we don't find anything else, and there's an 2342 // ivar, that's an error. 2343 bool IsClassMethod = CurMethod->isClassMethod(); 2344 2345 bool LookForIvars; 2346 if (Lookup.empty()) 2347 LookForIvars = true; 2348 else if (IsClassMethod) 2349 LookForIvars = false; 2350 else 2351 LookForIvars = (Lookup.isSingleResult() && 2352 Lookup.getFoundDecl()->isDefinedOutsideFunctionOrMethod()); 2353 ObjCInterfaceDecl *IFace = nullptr; 2354 if (LookForIvars) { 2355 IFace = CurMethod->getClassInterface(); 2356 ObjCInterfaceDecl *ClassDeclared; 2357 ObjCIvarDecl *IV = nullptr; 2358 if (IFace && (IV = IFace->lookupInstanceVariable(II, ClassDeclared))) { 2359 // Diagnose using an ivar in a class method. 2360 if (IsClassMethod) 2361 return ExprError(Diag(Loc, diag::error_ivar_use_in_class_method) 2362 << IV->getDeclName()); 2363 2364 // If we're referencing an invalid decl, just return this as a silent 2365 // error node. The error diagnostic was already emitted on the decl. 2366 if (IV->isInvalidDecl()) 2367 return ExprError(); 2368 2369 // Check if referencing a field with __attribute__((deprecated)). 2370 if (DiagnoseUseOfDecl(IV, Loc)) 2371 return ExprError(); 2372 2373 // Diagnose the use of an ivar outside of the declaring class. 2374 if (IV->getAccessControl() == ObjCIvarDecl::Private && 2375 !declaresSameEntity(ClassDeclared, IFace) && 2376 !getLangOpts().DebuggerSupport) 2377 Diag(Loc, diag::error_private_ivar_access) << IV->getDeclName(); 2378 2379 // FIXME: This should use a new expr for a direct reference, don't 2380 // turn this into Self->ivar, just return a BareIVarExpr or something. 2381 IdentifierInfo &II = Context.Idents.get("self"); 2382 UnqualifiedId SelfName; 2383 SelfName.setIdentifier(&II, SourceLocation()); 2384 SelfName.setKind(UnqualifiedId::IK_ImplicitSelfParam); 2385 CXXScopeSpec SelfScopeSpec; 2386 SourceLocation TemplateKWLoc; 2387 ExprResult SelfExpr = ActOnIdExpression(S, SelfScopeSpec, TemplateKWLoc, 2388 SelfName, false, false); 2389 if (SelfExpr.isInvalid()) 2390 return ExprError(); 2391 2392 SelfExpr = DefaultLvalueConversion(SelfExpr.get()); 2393 if (SelfExpr.isInvalid()) 2394 return ExprError(); 2395 2396 MarkAnyDeclReferenced(Loc, IV, true); 2397 2398 ObjCMethodFamily MF = CurMethod->getMethodFamily(); 2399 if (MF != OMF_init && MF != OMF_dealloc && MF != OMF_finalize && 2400 !IvarBacksCurrentMethodAccessor(IFace, CurMethod, IV)) 2401 Diag(Loc, diag::warn_direct_ivar_access) << IV->getDeclName(); 2402 2403 ObjCIvarRefExpr *Result = new (Context) 2404 ObjCIvarRefExpr(IV, IV->getType(), Loc, IV->getLocation(), 2405 SelfExpr.get(), true, true); 2406 2407 if (getLangOpts().ObjCAutoRefCount) { 2408 if (IV->getType().getObjCLifetime() == Qualifiers::OCL_Weak) { 2409 if (!Diags.isIgnored(diag::warn_arc_repeated_use_of_weak, Loc)) 2410 recordUseOfEvaluatedWeak(Result); 2411 } 2412 if (CurContext->isClosure()) 2413 Diag(Loc, diag::warn_implicitly_retains_self) 2414 << FixItHint::CreateInsertion(Loc, "self->"); 2415 } 2416 2417 return Result; 2418 } 2419 } else if (CurMethod->isInstanceMethod()) { 2420 // We should warn if a local variable hides an ivar. 2421 if (ObjCInterfaceDecl *IFace = CurMethod->getClassInterface()) { 2422 ObjCInterfaceDecl *ClassDeclared; 2423 if (ObjCIvarDecl *IV = IFace->lookupInstanceVariable(II, ClassDeclared)) { 2424 if (IV->getAccessControl() != ObjCIvarDecl::Private || 2425 declaresSameEntity(IFace, ClassDeclared)) 2426 Diag(Loc, diag::warn_ivar_use_hidden) << IV->getDeclName(); 2427 } 2428 } 2429 } else if (Lookup.isSingleResult() && 2430 Lookup.getFoundDecl()->isDefinedOutsideFunctionOrMethod()) { 2431 // If accessing a stand-alone ivar in a class method, this is an error. 2432 if (const ObjCIvarDecl *IV = dyn_cast<ObjCIvarDecl>(Lookup.getFoundDecl())) 2433 return ExprError(Diag(Loc, diag::error_ivar_use_in_class_method) 2434 << IV->getDeclName()); 2435 } 2436 2437 if (Lookup.empty() && II && AllowBuiltinCreation) { 2438 // FIXME. Consolidate this with similar code in LookupName. 2439 if (unsigned BuiltinID = II->getBuiltinID()) { 2440 if (!(getLangOpts().CPlusPlus && 2441 Context.BuiltinInfo.isPredefinedLibFunction(BuiltinID))) { 2442 NamedDecl *D = LazilyCreateBuiltin((IdentifierInfo *)II, BuiltinID, 2443 S, Lookup.isForRedeclaration(), 2444 Lookup.getNameLoc()); 2445 if (D) Lookup.addDecl(D); 2446 } 2447 } 2448 } 2449 // Sentinel value saying that we didn't do anything special. 2450 return ExprResult((Expr *)nullptr); 2451 } 2452 2453 /// \brief Cast a base object to a member's actual type. 2454 /// 2455 /// Logically this happens in three phases: 2456 /// 2457 /// * First we cast from the base type to the naming class. 2458 /// The naming class is the class into which we were looking 2459 /// when we found the member; it's the qualifier type if a 2460 /// qualifier was provided, and otherwise it's the base type. 2461 /// 2462 /// * Next we cast from the naming class to the declaring class. 2463 /// If the member we found was brought into a class's scope by 2464 /// a using declaration, this is that class; otherwise it's 2465 /// the class declaring the member. 2466 /// 2467 /// * Finally we cast from the declaring class to the "true" 2468 /// declaring class of the member. This conversion does not 2469 /// obey access control. 2470 ExprResult 2471 Sema::PerformObjectMemberConversion(Expr *From, 2472 NestedNameSpecifier *Qualifier, 2473 NamedDecl *FoundDecl, 2474 NamedDecl *Member) { 2475 CXXRecordDecl *RD = dyn_cast<CXXRecordDecl>(Member->getDeclContext()); 2476 if (!RD) 2477 return From; 2478 2479 QualType DestRecordType; 2480 QualType DestType; 2481 QualType FromRecordType; 2482 QualType FromType = From->getType(); 2483 bool PointerConversions = false; 2484 if (isa<FieldDecl>(Member)) { 2485 DestRecordType = Context.getCanonicalType(Context.getTypeDeclType(RD)); 2486 2487 if (FromType->getAs<PointerType>()) { 2488 DestType = Context.getPointerType(DestRecordType); 2489 FromRecordType = FromType->getPointeeType(); 2490 PointerConversions = true; 2491 } else { 2492 DestType = DestRecordType; 2493 FromRecordType = FromType; 2494 } 2495 } else if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(Member)) { 2496 if (Method->isStatic()) 2497 return From; 2498 2499 DestType = Method->getThisType(Context); 2500 DestRecordType = DestType->getPointeeType(); 2501 2502 if (FromType->getAs<PointerType>()) { 2503 FromRecordType = FromType->getPointeeType(); 2504 PointerConversions = true; 2505 } else { 2506 FromRecordType = FromType; 2507 DestType = DestRecordType; 2508 } 2509 } else { 2510 // No conversion necessary. 2511 return From; 2512 } 2513 2514 if (DestType->isDependentType() || FromType->isDependentType()) 2515 return From; 2516 2517 // If the unqualified types are the same, no conversion is necessary. 2518 if (Context.hasSameUnqualifiedType(FromRecordType, DestRecordType)) 2519 return From; 2520 2521 SourceRange FromRange = From->getSourceRange(); 2522 SourceLocation FromLoc = FromRange.getBegin(); 2523 2524 ExprValueKind VK = From->getValueKind(); 2525 2526 // C++ [class.member.lookup]p8: 2527 // [...] Ambiguities can often be resolved by qualifying a name with its 2528 // class name. 2529 // 2530 // If the member was a qualified name and the qualified referred to a 2531 // specific base subobject type, we'll cast to that intermediate type 2532 // first and then to the object in which the member is declared. That allows 2533 // one to resolve ambiguities in, e.g., a diamond-shaped hierarchy such as: 2534 // 2535 // class Base { public: int x; }; 2536 // class Derived1 : public Base { }; 2537 // class Derived2 : public Base { }; 2538 // class VeryDerived : public Derived1, public Derived2 { void f(); }; 2539 // 2540 // void VeryDerived::f() { 2541 // x = 17; // error: ambiguous base subobjects 2542 // Derived1::x = 17; // okay, pick the Base subobject of Derived1 2543 // } 2544 if (Qualifier && Qualifier->getAsType()) { 2545 QualType QType = QualType(Qualifier->getAsType(), 0); 2546 assert(QType->isRecordType() && "lookup done with non-record type"); 2547 2548 QualType QRecordType = QualType(QType->getAs<RecordType>(), 0); 2549 2550 // In C++98, the qualifier type doesn't actually have to be a base 2551 // type of the object type, in which case we just ignore it. 2552 // Otherwise build the appropriate casts. 2553 if (IsDerivedFrom(FromRecordType, QRecordType)) { 2554 CXXCastPath BasePath; 2555 if (CheckDerivedToBaseConversion(FromRecordType, QRecordType, 2556 FromLoc, FromRange, &BasePath)) 2557 return ExprError(); 2558 2559 if (PointerConversions) 2560 QType = Context.getPointerType(QType); 2561 From = ImpCastExprToType(From, QType, CK_UncheckedDerivedToBase, 2562 VK, &BasePath).get(); 2563 2564 FromType = QType; 2565 FromRecordType = QRecordType; 2566 2567 // If the qualifier type was the same as the destination type, 2568 // we're done. 2569 if (Context.hasSameUnqualifiedType(FromRecordType, DestRecordType)) 2570 return From; 2571 } 2572 } 2573 2574 bool IgnoreAccess = false; 2575 2576 // If we actually found the member through a using declaration, cast 2577 // down to the using declaration's type. 2578 // 2579 // Pointer equality is fine here because only one declaration of a 2580 // class ever has member declarations. 2581 if (FoundDecl->getDeclContext() != Member->getDeclContext()) { 2582 assert(isa<UsingShadowDecl>(FoundDecl)); 2583 QualType URecordType = Context.getTypeDeclType( 2584 cast<CXXRecordDecl>(FoundDecl->getDeclContext())); 2585 2586 // We only need to do this if the naming-class to declaring-class 2587 // conversion is non-trivial. 2588 if (!Context.hasSameUnqualifiedType(FromRecordType, URecordType)) { 2589 assert(IsDerivedFrom(FromRecordType, URecordType)); 2590 CXXCastPath BasePath; 2591 if (CheckDerivedToBaseConversion(FromRecordType, URecordType, 2592 FromLoc, FromRange, &BasePath)) 2593 return ExprError(); 2594 2595 QualType UType = URecordType; 2596 if (PointerConversions) 2597 UType = Context.getPointerType(UType); 2598 From = ImpCastExprToType(From, UType, CK_UncheckedDerivedToBase, 2599 VK, &BasePath).get(); 2600 FromType = UType; 2601 FromRecordType = URecordType; 2602 } 2603 2604 // We don't do access control for the conversion from the 2605 // declaring class to the true declaring class. 2606 IgnoreAccess = true; 2607 } 2608 2609 CXXCastPath BasePath; 2610 if (CheckDerivedToBaseConversion(FromRecordType, DestRecordType, 2611 FromLoc, FromRange, &BasePath, 2612 IgnoreAccess)) 2613 return ExprError(); 2614 2615 return ImpCastExprToType(From, DestType, CK_UncheckedDerivedToBase, 2616 VK, &BasePath); 2617 } 2618 2619 bool Sema::UseArgumentDependentLookup(const CXXScopeSpec &SS, 2620 const LookupResult &R, 2621 bool HasTrailingLParen) { 2622 // Only when used directly as the postfix-expression of a call. 2623 if (!HasTrailingLParen) 2624 return false; 2625 2626 // Never if a scope specifier was provided. 2627 if (SS.isSet()) 2628 return false; 2629 2630 // Only in C++ or ObjC++. 2631 if (!getLangOpts().CPlusPlus) 2632 return false; 2633 2634 // Turn off ADL when we find certain kinds of declarations during 2635 // normal lookup: 2636 for (LookupResult::iterator I = R.begin(), E = R.end(); I != E; ++I) { 2637 NamedDecl *D = *I; 2638 2639 // C++0x [basic.lookup.argdep]p3: 2640 // -- a declaration of a class member 2641 // Since using decls preserve this property, we check this on the 2642 // original decl. 2643 if (D->isCXXClassMember()) 2644 return false; 2645 2646 // C++0x [basic.lookup.argdep]p3: 2647 // -- a block-scope function declaration that is not a 2648 // using-declaration 2649 // NOTE: we also trigger this for function templates (in fact, we 2650 // don't check the decl type at all, since all other decl types 2651 // turn off ADL anyway). 2652 if (isa<UsingShadowDecl>(D)) 2653 D = cast<UsingShadowDecl>(D)->getTargetDecl(); 2654 else if (D->getLexicalDeclContext()->isFunctionOrMethod()) 2655 return false; 2656 2657 // C++0x [basic.lookup.argdep]p3: 2658 // -- a declaration that is neither a function or a function 2659 // template 2660 // And also for builtin functions. 2661 if (isa<FunctionDecl>(D)) { 2662 FunctionDecl *FDecl = cast<FunctionDecl>(D); 2663 2664 // But also builtin functions. 2665 if (FDecl->getBuiltinID() && FDecl->isImplicit()) 2666 return false; 2667 } else if (!isa<FunctionTemplateDecl>(D)) 2668 return false; 2669 } 2670 2671 return true; 2672 } 2673 2674 2675 /// Diagnoses obvious problems with the use of the given declaration 2676 /// as an expression. This is only actually called for lookups that 2677 /// were not overloaded, and it doesn't promise that the declaration 2678 /// will in fact be used. 2679 static bool CheckDeclInExpr(Sema &S, SourceLocation Loc, NamedDecl *D) { 2680 if (isa<TypedefNameDecl>(D)) { 2681 S.Diag(Loc, diag::err_unexpected_typedef) << D->getDeclName(); 2682 return true; 2683 } 2684 2685 if (isa<ObjCInterfaceDecl>(D)) { 2686 S.Diag(Loc, diag::err_unexpected_interface) << D->getDeclName(); 2687 return true; 2688 } 2689 2690 if (isa<NamespaceDecl>(D)) { 2691 S.Diag(Loc, diag::err_unexpected_namespace) << D->getDeclName(); 2692 return true; 2693 } 2694 2695 return false; 2696 } 2697 2698 ExprResult Sema::BuildDeclarationNameExpr(const CXXScopeSpec &SS, 2699 LookupResult &R, bool NeedsADL, 2700 bool AcceptInvalidDecl) { 2701 // If this is a single, fully-resolved result and we don't need ADL, 2702 // just build an ordinary singleton decl ref. 2703 if (!NeedsADL && R.isSingleResult() && !R.getAsSingle<FunctionTemplateDecl>()) 2704 return BuildDeclarationNameExpr(SS, R.getLookupNameInfo(), R.getFoundDecl(), 2705 R.getRepresentativeDecl(), nullptr, 2706 AcceptInvalidDecl); 2707 2708 // We only need to check the declaration if there's exactly one 2709 // result, because in the overloaded case the results can only be 2710 // functions and function templates. 2711 if (R.isSingleResult() && 2712 CheckDeclInExpr(*this, R.getNameLoc(), R.getFoundDecl())) 2713 return ExprError(); 2714 2715 // Otherwise, just build an unresolved lookup expression. Suppress 2716 // any lookup-related diagnostics; we'll hash these out later, when 2717 // we've picked a target. 2718 R.suppressDiagnostics(); 2719 2720 UnresolvedLookupExpr *ULE 2721 = UnresolvedLookupExpr::Create(Context, R.getNamingClass(), 2722 SS.getWithLocInContext(Context), 2723 R.getLookupNameInfo(), 2724 NeedsADL, R.isOverloadedResult(), 2725 R.begin(), R.end()); 2726 2727 return ULE; 2728 } 2729 2730 /// \brief Complete semantic analysis for a reference to the given declaration. 2731 ExprResult Sema::BuildDeclarationNameExpr( 2732 const CXXScopeSpec &SS, const DeclarationNameInfo &NameInfo, NamedDecl *D, 2733 NamedDecl *FoundD, const TemplateArgumentListInfo *TemplateArgs, 2734 bool AcceptInvalidDecl) { 2735 assert(D && "Cannot refer to a NULL declaration"); 2736 assert(!isa<FunctionTemplateDecl>(D) && 2737 "Cannot refer unambiguously to a function template"); 2738 2739 SourceLocation Loc = NameInfo.getLoc(); 2740 if (CheckDeclInExpr(*this, Loc, D)) 2741 return ExprError(); 2742 2743 if (TemplateDecl *Template = dyn_cast<TemplateDecl>(D)) { 2744 // Specifically diagnose references to class templates that are missing 2745 // a template argument list. 2746 Diag(Loc, diag::err_template_decl_ref) << (isa<VarTemplateDecl>(D) ? 1 : 0) 2747 << Template << SS.getRange(); 2748 Diag(Template->getLocation(), diag::note_template_decl_here); 2749 return ExprError(); 2750 } 2751 2752 // Make sure that we're referring to a value. 2753 ValueDecl *VD = dyn_cast<ValueDecl>(D); 2754 if (!VD) { 2755 Diag(Loc, diag::err_ref_non_value) 2756 << D << SS.getRange(); 2757 Diag(D->getLocation(), diag::note_declared_at); 2758 return ExprError(); 2759 } 2760 2761 // Check whether this declaration can be used. Note that we suppress 2762 // this check when we're going to perform argument-dependent lookup 2763 // on this function name, because this might not be the function 2764 // that overload resolution actually selects. 2765 if (DiagnoseUseOfDecl(VD, Loc)) 2766 return ExprError(); 2767 2768 // Only create DeclRefExpr's for valid Decl's. 2769 if (VD->isInvalidDecl() && !AcceptInvalidDecl) 2770 return ExprError(); 2771 2772 // Handle members of anonymous structs and unions. If we got here, 2773 // and the reference is to a class member indirect field, then this 2774 // must be the subject of a pointer-to-member expression. 2775 if (IndirectFieldDecl *indirectField = dyn_cast<IndirectFieldDecl>(VD)) 2776 if (!indirectField->isCXXClassMember()) 2777 return BuildAnonymousStructUnionMemberReference(SS, NameInfo.getLoc(), 2778 indirectField); 2779 2780 { 2781 QualType type = VD->getType(); 2782 ExprValueKind valueKind = VK_RValue; 2783 2784 switch (D->getKind()) { 2785 // Ignore all the non-ValueDecl kinds. 2786 #define ABSTRACT_DECL(kind) 2787 #define VALUE(type, base) 2788 #define DECL(type, base) \ 2789 case Decl::type: 2790 #include "clang/AST/DeclNodes.inc" 2791 llvm_unreachable("invalid value decl kind"); 2792 2793 // These shouldn't make it here. 2794 case Decl::ObjCAtDefsField: 2795 case Decl::ObjCIvar: 2796 llvm_unreachable("forming non-member reference to ivar?"); 2797 2798 // Enum constants are always r-values and never references. 2799 // Unresolved using declarations are dependent. 2800 case Decl::EnumConstant: 2801 case Decl::UnresolvedUsingValue: 2802 valueKind = VK_RValue; 2803 break; 2804 2805 // Fields and indirect fields that got here must be for 2806 // pointer-to-member expressions; we just call them l-values for 2807 // internal consistency, because this subexpression doesn't really 2808 // exist in the high-level semantics. 2809 case Decl::Field: 2810 case Decl::IndirectField: 2811 assert(getLangOpts().CPlusPlus && 2812 "building reference to field in C?"); 2813 2814 // These can't have reference type in well-formed programs, but 2815 // for internal consistency we do this anyway. 2816 type = type.getNonReferenceType(); 2817 valueKind = VK_LValue; 2818 break; 2819 2820 // Non-type template parameters are either l-values or r-values 2821 // depending on the type. 2822 case Decl::NonTypeTemplateParm: { 2823 if (const ReferenceType *reftype = type->getAs<ReferenceType>()) { 2824 type = reftype->getPointeeType(); 2825 valueKind = VK_LValue; // even if the parameter is an r-value reference 2826 break; 2827 } 2828 2829 // For non-references, we need to strip qualifiers just in case 2830 // the template parameter was declared as 'const int' or whatever. 2831 valueKind = VK_RValue; 2832 type = type.getUnqualifiedType(); 2833 break; 2834 } 2835 2836 case Decl::Var: 2837 case Decl::VarTemplateSpecialization: 2838 case Decl::VarTemplatePartialSpecialization: 2839 // In C, "extern void blah;" is valid and is an r-value. 2840 if (!getLangOpts().CPlusPlus && 2841 !type.hasQualifiers() && 2842 type->isVoidType()) { 2843 valueKind = VK_RValue; 2844 break; 2845 } 2846 // fallthrough 2847 2848 case Decl::ImplicitParam: 2849 case Decl::ParmVar: { 2850 // These are always l-values. 2851 valueKind = VK_LValue; 2852 type = type.getNonReferenceType(); 2853 2854 // FIXME: Does the addition of const really only apply in 2855 // potentially-evaluated contexts? Since the variable isn't actually 2856 // captured in an unevaluated context, it seems that the answer is no. 2857 if (!isUnevaluatedContext()) { 2858 QualType CapturedType = getCapturedDeclRefType(cast<VarDecl>(VD), Loc); 2859 if (!CapturedType.isNull()) 2860 type = CapturedType; 2861 } 2862 2863 break; 2864 } 2865 2866 case Decl::Function: { 2867 if (unsigned BID = cast<FunctionDecl>(VD)->getBuiltinID()) { 2868 if (!Context.BuiltinInfo.isPredefinedLibFunction(BID)) { 2869 type = Context.BuiltinFnTy; 2870 valueKind = VK_RValue; 2871 break; 2872 } 2873 } 2874 2875 const FunctionType *fty = type->castAs<FunctionType>(); 2876 2877 // If we're referring to a function with an __unknown_anytype 2878 // result type, make the entire expression __unknown_anytype. 2879 if (fty->getReturnType() == Context.UnknownAnyTy) { 2880 type = Context.UnknownAnyTy; 2881 valueKind = VK_RValue; 2882 break; 2883 } 2884 2885 // Functions are l-values in C++. 2886 if (getLangOpts().CPlusPlus) { 2887 valueKind = VK_LValue; 2888 break; 2889 } 2890 2891 // C99 DR 316 says that, if a function type comes from a 2892 // function definition (without a prototype), that type is only 2893 // used for checking compatibility. Therefore, when referencing 2894 // the function, we pretend that we don't have the full function 2895 // type. 2896 if (!cast<FunctionDecl>(VD)->hasPrototype() && 2897 isa<FunctionProtoType>(fty)) 2898 type = Context.getFunctionNoProtoType(fty->getReturnType(), 2899 fty->getExtInfo()); 2900 2901 // Functions are r-values in C. 2902 valueKind = VK_RValue; 2903 break; 2904 } 2905 2906 case Decl::MSProperty: 2907 valueKind = VK_LValue; 2908 break; 2909 2910 case Decl::CXXMethod: 2911 // If we're referring to a method with an __unknown_anytype 2912 // result type, make the entire expression __unknown_anytype. 2913 // This should only be possible with a type written directly. 2914 if (const FunctionProtoType *proto 2915 = dyn_cast<FunctionProtoType>(VD->getType())) 2916 if (proto->getReturnType() == Context.UnknownAnyTy) { 2917 type = Context.UnknownAnyTy; 2918 valueKind = VK_RValue; 2919 break; 2920 } 2921 2922 // C++ methods are l-values if static, r-values if non-static. 2923 if (cast<CXXMethodDecl>(VD)->isStatic()) { 2924 valueKind = VK_LValue; 2925 break; 2926 } 2927 // fallthrough 2928 2929 case Decl::CXXConversion: 2930 case Decl::CXXDestructor: 2931 case Decl::CXXConstructor: 2932 valueKind = VK_RValue; 2933 break; 2934 } 2935 2936 return BuildDeclRefExpr(VD, type, valueKind, NameInfo, &SS, FoundD, 2937 TemplateArgs); 2938 } 2939 } 2940 2941 static void ConvertUTF8ToWideString(unsigned CharByteWidth, StringRef Source, 2942 SmallString<32> &Target) { 2943 Target.resize(CharByteWidth * (Source.size() + 1)); 2944 char *ResultPtr = &Target[0]; 2945 const UTF8 *ErrorPtr; 2946 bool success = ConvertUTF8toWide(CharByteWidth, Source, ResultPtr, ErrorPtr); 2947 (void)success; 2948 assert(success); 2949 Target.resize(ResultPtr - &Target[0]); 2950 } 2951 2952 ExprResult Sema::BuildPredefinedExpr(SourceLocation Loc, 2953 PredefinedExpr::IdentType IT) { 2954 // Pick the current block, lambda, captured statement or function. 2955 Decl *currentDecl = nullptr; 2956 if (const BlockScopeInfo *BSI = getCurBlock()) 2957 currentDecl = BSI->TheDecl; 2958 else if (const LambdaScopeInfo *LSI = getCurLambda()) 2959 currentDecl = LSI->CallOperator; 2960 else if (const CapturedRegionScopeInfo *CSI = getCurCapturedRegion()) 2961 currentDecl = CSI->TheCapturedDecl; 2962 else 2963 currentDecl = getCurFunctionOrMethodDecl(); 2964 2965 if (!currentDecl) { 2966 Diag(Loc, diag::ext_predef_outside_function); 2967 currentDecl = Context.getTranslationUnitDecl(); 2968 } 2969 2970 QualType ResTy; 2971 StringLiteral *SL = nullptr; 2972 if (cast<DeclContext>(currentDecl)->isDependentContext()) 2973 ResTy = Context.DependentTy; 2974 else { 2975 // Pre-defined identifiers are of type char[x], where x is the length of 2976 // the string. 2977 auto Str = PredefinedExpr::ComputeName(IT, currentDecl); 2978 unsigned Length = Str.length(); 2979 2980 llvm::APInt LengthI(32, Length + 1); 2981 if (IT == PredefinedExpr::LFunction) { 2982 ResTy = Context.WideCharTy.withConst(); 2983 SmallString<32> RawChars; 2984 ConvertUTF8ToWideString(Context.getTypeSizeInChars(ResTy).getQuantity(), 2985 Str, RawChars); 2986 ResTy = Context.getConstantArrayType(ResTy, LengthI, ArrayType::Normal, 2987 /*IndexTypeQuals*/ 0); 2988 SL = StringLiteral::Create(Context, RawChars, StringLiteral::Wide, 2989 /*Pascal*/ false, ResTy, Loc); 2990 } else { 2991 ResTy = Context.CharTy.withConst(); 2992 ResTy = Context.getConstantArrayType(ResTy, LengthI, ArrayType::Normal, 2993 /*IndexTypeQuals*/ 0); 2994 SL = StringLiteral::Create(Context, Str, StringLiteral::Ascii, 2995 /*Pascal*/ false, ResTy, Loc); 2996 } 2997 } 2998 2999 return new (Context) PredefinedExpr(Loc, ResTy, IT, SL); 3000 } 3001 3002 ExprResult Sema::ActOnPredefinedExpr(SourceLocation Loc, tok::TokenKind Kind) { 3003 PredefinedExpr::IdentType IT; 3004 3005 switch (Kind) { 3006 default: llvm_unreachable("Unknown simple primary expr!"); 3007 case tok::kw___func__: IT = PredefinedExpr::Func; break; // [C99 6.4.2.2] 3008 case tok::kw___FUNCTION__: IT = PredefinedExpr::Function; break; 3009 case tok::kw___FUNCDNAME__: IT = PredefinedExpr::FuncDName; break; // [MS] 3010 case tok::kw___FUNCSIG__: IT = PredefinedExpr::FuncSig; break; // [MS] 3011 case tok::kw_L__FUNCTION__: IT = PredefinedExpr::LFunction; break; 3012 case tok::kw___PRETTY_FUNCTION__: IT = PredefinedExpr::PrettyFunction; break; 3013 } 3014 3015 return BuildPredefinedExpr(Loc, IT); 3016 } 3017 3018 ExprResult Sema::ActOnCharacterConstant(const Token &Tok, Scope *UDLScope) { 3019 SmallString<16> CharBuffer; 3020 bool Invalid = false; 3021 StringRef ThisTok = PP.getSpelling(Tok, CharBuffer, &Invalid); 3022 if (Invalid) 3023 return ExprError(); 3024 3025 CharLiteralParser Literal(ThisTok.begin(), ThisTok.end(), Tok.getLocation(), 3026 PP, Tok.getKind()); 3027 if (Literal.hadError()) 3028 return ExprError(); 3029 3030 QualType Ty; 3031 if (Literal.isWide()) 3032 Ty = Context.WideCharTy; // L'x' -> wchar_t in C and C++. 3033 else if (Literal.isUTF16()) 3034 Ty = Context.Char16Ty; // u'x' -> char16_t in C11 and C++11. 3035 else if (Literal.isUTF32()) 3036 Ty = Context.Char32Ty; // U'x' -> char32_t in C11 and C++11. 3037 else if (!getLangOpts().CPlusPlus || Literal.isMultiChar()) 3038 Ty = Context.IntTy; // 'x' -> int in C, 'wxyz' -> int in C++. 3039 else 3040 Ty = Context.CharTy; // 'x' -> char in C++ 3041 3042 CharacterLiteral::CharacterKind Kind = CharacterLiteral::Ascii; 3043 if (Literal.isWide()) 3044 Kind = CharacterLiteral::Wide; 3045 else if (Literal.isUTF16()) 3046 Kind = CharacterLiteral::UTF16; 3047 else if (Literal.isUTF32()) 3048 Kind = CharacterLiteral::UTF32; 3049 3050 Expr *Lit = new (Context) CharacterLiteral(Literal.getValue(), Kind, Ty, 3051 Tok.getLocation()); 3052 3053 if (Literal.getUDSuffix().empty()) 3054 return Lit; 3055 3056 // We're building a user-defined literal. 3057 IdentifierInfo *UDSuffix = &Context.Idents.get(Literal.getUDSuffix()); 3058 SourceLocation UDSuffixLoc = 3059 getUDSuffixLoc(*this, Tok.getLocation(), Literal.getUDSuffixOffset()); 3060 3061 // Make sure we're allowed user-defined literals here. 3062 if (!UDLScope) 3063 return ExprError(Diag(UDSuffixLoc, diag::err_invalid_character_udl)); 3064 3065 // C++11 [lex.ext]p6: The literal L is treated as a call of the form 3066 // operator "" X (ch) 3067 return BuildCookedLiteralOperatorCall(*this, UDLScope, UDSuffix, UDSuffixLoc, 3068 Lit, Tok.getLocation()); 3069 } 3070 3071 ExprResult Sema::ActOnIntegerConstant(SourceLocation Loc, uint64_t Val) { 3072 unsigned IntSize = Context.getTargetInfo().getIntWidth(); 3073 return IntegerLiteral::Create(Context, llvm::APInt(IntSize, Val), 3074 Context.IntTy, Loc); 3075 } 3076 3077 static Expr *BuildFloatingLiteral(Sema &S, NumericLiteralParser &Literal, 3078 QualType Ty, SourceLocation Loc) { 3079 const llvm::fltSemantics &Format = S.Context.getFloatTypeSemantics(Ty); 3080 3081 using llvm::APFloat; 3082 APFloat Val(Format); 3083 3084 APFloat::opStatus result = Literal.GetFloatValue(Val); 3085 3086 // Overflow is always an error, but underflow is only an error if 3087 // we underflowed to zero (APFloat reports denormals as underflow). 3088 if ((result & APFloat::opOverflow) || 3089 ((result & APFloat::opUnderflow) && Val.isZero())) { 3090 unsigned diagnostic; 3091 SmallString<20> buffer; 3092 if (result & APFloat::opOverflow) { 3093 diagnostic = diag::warn_float_overflow; 3094 APFloat::getLargest(Format).toString(buffer); 3095 } else { 3096 diagnostic = diag::warn_float_underflow; 3097 APFloat::getSmallest(Format).toString(buffer); 3098 } 3099 3100 S.Diag(Loc, diagnostic) 3101 << Ty 3102 << StringRef(buffer.data(), buffer.size()); 3103 } 3104 3105 bool isExact = (result == APFloat::opOK); 3106 return FloatingLiteral::Create(S.Context, Val, isExact, Ty, Loc); 3107 } 3108 3109 bool Sema::CheckLoopHintExpr(Expr *E, SourceLocation Loc) { 3110 assert(E && "Invalid expression"); 3111 3112 if (E->isValueDependent()) 3113 return false; 3114 3115 QualType QT = E->getType(); 3116 if (!QT->isIntegerType() || QT->isBooleanType() || QT->isCharType()) { 3117 Diag(E->getExprLoc(), diag::err_pragma_loop_invalid_argument_type) << QT; 3118 return true; 3119 } 3120 3121 llvm::APSInt ValueAPS; 3122 ExprResult R = VerifyIntegerConstantExpression(E, &ValueAPS); 3123 3124 if (R.isInvalid()) 3125 return true; 3126 3127 bool ValueIsPositive = ValueAPS.isStrictlyPositive(); 3128 if (!ValueIsPositive || ValueAPS.getActiveBits() > 31) { 3129 Diag(E->getExprLoc(), diag::err_pragma_loop_invalid_argument_value) 3130 << ValueAPS.toString(10) << ValueIsPositive; 3131 return true; 3132 } 3133 3134 return false; 3135 } 3136 3137 ExprResult Sema::ActOnNumericConstant(const Token &Tok, Scope *UDLScope) { 3138 // Fast path for a single digit (which is quite common). A single digit 3139 // cannot have a trigraph, escaped newline, radix prefix, or suffix. 3140 if (Tok.getLength() == 1) { 3141 const char Val = PP.getSpellingOfSingleCharacterNumericConstant(Tok); 3142 return ActOnIntegerConstant(Tok.getLocation(), Val-'0'); 3143 } 3144 3145 SmallString<128> SpellingBuffer; 3146 // NumericLiteralParser wants to overread by one character. Add padding to 3147 // the buffer in case the token is copied to the buffer. If getSpelling() 3148 // returns a StringRef to the memory buffer, it should have a null char at 3149 // the EOF, so it is also safe. 3150 SpellingBuffer.resize(Tok.getLength() + 1); 3151 3152 // Get the spelling of the token, which eliminates trigraphs, etc. 3153 bool Invalid = false; 3154 StringRef TokSpelling = PP.getSpelling(Tok, SpellingBuffer, &Invalid); 3155 if (Invalid) 3156 return ExprError(); 3157 3158 NumericLiteralParser Literal(TokSpelling, Tok.getLocation(), PP); 3159 if (Literal.hadError) 3160 return ExprError(); 3161 3162 if (Literal.hasUDSuffix()) { 3163 // We're building a user-defined literal. 3164 IdentifierInfo *UDSuffix = &Context.Idents.get(Literal.getUDSuffix()); 3165 SourceLocation UDSuffixLoc = 3166 getUDSuffixLoc(*this, Tok.getLocation(), Literal.getUDSuffixOffset()); 3167 3168 // Make sure we're allowed user-defined literals here. 3169 if (!UDLScope) 3170 return ExprError(Diag(UDSuffixLoc, diag::err_invalid_numeric_udl)); 3171 3172 QualType CookedTy; 3173 if (Literal.isFloatingLiteral()) { 3174 // C++11 [lex.ext]p4: If S contains a literal operator with parameter type 3175 // long double, the literal is treated as a call of the form 3176 // operator "" X (f L) 3177 CookedTy = Context.LongDoubleTy; 3178 } else { 3179 // C++11 [lex.ext]p3: If S contains a literal operator with parameter type 3180 // unsigned long long, the literal is treated as a call of the form 3181 // operator "" X (n ULL) 3182 CookedTy = Context.UnsignedLongLongTy; 3183 } 3184 3185 DeclarationName OpName = 3186 Context.DeclarationNames.getCXXLiteralOperatorName(UDSuffix); 3187 DeclarationNameInfo OpNameInfo(OpName, UDSuffixLoc); 3188 OpNameInfo.setCXXLiteralOperatorNameLoc(UDSuffixLoc); 3189 3190 SourceLocation TokLoc = Tok.getLocation(); 3191 3192 // Perform literal operator lookup to determine if we're building a raw 3193 // literal or a cooked one. 3194 LookupResult R(*this, OpName, UDSuffixLoc, LookupOrdinaryName); 3195 switch (LookupLiteralOperator(UDLScope, R, CookedTy, 3196 /*AllowRaw*/true, /*AllowTemplate*/true, 3197 /*AllowStringTemplate*/false)) { 3198 case LOLR_Error: 3199 return ExprError(); 3200 3201 case LOLR_Cooked: { 3202 Expr *Lit; 3203 if (Literal.isFloatingLiteral()) { 3204 Lit = BuildFloatingLiteral(*this, Literal, CookedTy, Tok.getLocation()); 3205 } else { 3206 llvm::APInt ResultVal(Context.getTargetInfo().getLongLongWidth(), 0); 3207 if (Literal.GetIntegerValue(ResultVal)) 3208 Diag(Tok.getLocation(), diag::err_integer_literal_too_large) 3209 << /* Unsigned */ 1; 3210 Lit = IntegerLiteral::Create(Context, ResultVal, CookedTy, 3211 Tok.getLocation()); 3212 } 3213 return BuildLiteralOperatorCall(R, OpNameInfo, Lit, TokLoc); 3214 } 3215 3216 case LOLR_Raw: { 3217 // C++11 [lit.ext]p3, p4: If S contains a raw literal operator, the 3218 // literal is treated as a call of the form 3219 // operator "" X ("n") 3220 unsigned Length = Literal.getUDSuffixOffset(); 3221 QualType StrTy = Context.getConstantArrayType( 3222 Context.CharTy.withConst(), llvm::APInt(32, Length + 1), 3223 ArrayType::Normal, 0); 3224 Expr *Lit = StringLiteral::Create( 3225 Context, StringRef(TokSpelling.data(), Length), StringLiteral::Ascii, 3226 /*Pascal*/false, StrTy, &TokLoc, 1); 3227 return BuildLiteralOperatorCall(R, OpNameInfo, Lit, TokLoc); 3228 } 3229 3230 case LOLR_Template: { 3231 // C++11 [lit.ext]p3, p4: Otherwise (S contains a literal operator 3232 // template), L is treated as a call fo the form 3233 // operator "" X <'c1', 'c2', ... 'ck'>() 3234 // where n is the source character sequence c1 c2 ... ck. 3235 TemplateArgumentListInfo ExplicitArgs; 3236 unsigned CharBits = Context.getIntWidth(Context.CharTy); 3237 bool CharIsUnsigned = Context.CharTy->isUnsignedIntegerType(); 3238 llvm::APSInt Value(CharBits, CharIsUnsigned); 3239 for (unsigned I = 0, N = Literal.getUDSuffixOffset(); I != N; ++I) { 3240 Value = TokSpelling[I]; 3241 TemplateArgument Arg(Context, Value, Context.CharTy); 3242 TemplateArgumentLocInfo ArgInfo; 3243 ExplicitArgs.addArgument(TemplateArgumentLoc(Arg, ArgInfo)); 3244 } 3245 return BuildLiteralOperatorCall(R, OpNameInfo, None, TokLoc, 3246 &ExplicitArgs); 3247 } 3248 case LOLR_StringTemplate: 3249 llvm_unreachable("unexpected literal operator lookup result"); 3250 } 3251 } 3252 3253 Expr *Res; 3254 3255 if (Literal.isFloatingLiteral()) { 3256 QualType Ty; 3257 if (Literal.isFloat) 3258 Ty = Context.FloatTy; 3259 else if (!Literal.isLong) 3260 Ty = Context.DoubleTy; 3261 else 3262 Ty = Context.LongDoubleTy; 3263 3264 Res = BuildFloatingLiteral(*this, Literal, Ty, Tok.getLocation()); 3265 3266 if (Ty == Context.DoubleTy) { 3267 if (getLangOpts().SinglePrecisionConstants) { 3268 Res = ImpCastExprToType(Res, Context.FloatTy, CK_FloatingCast).get(); 3269 } else if (getLangOpts().OpenCL && !getOpenCLOptions().cl_khr_fp64) { 3270 Diag(Tok.getLocation(), diag::warn_double_const_requires_fp64); 3271 Res = ImpCastExprToType(Res, Context.FloatTy, CK_FloatingCast).get(); 3272 } 3273 } 3274 } else if (!Literal.isIntegerLiteral()) { 3275 return ExprError(); 3276 } else { 3277 QualType Ty; 3278 3279 // 'long long' is a C99 or C++11 feature. 3280 if (!getLangOpts().C99 && Literal.isLongLong) { 3281 if (getLangOpts().CPlusPlus) 3282 Diag(Tok.getLocation(), 3283 getLangOpts().CPlusPlus11 ? 3284 diag::warn_cxx98_compat_longlong : diag::ext_cxx11_longlong); 3285 else 3286 Diag(Tok.getLocation(), diag::ext_c99_longlong); 3287 } 3288 3289 // Get the value in the widest-possible width. 3290 unsigned MaxWidth = Context.getTargetInfo().getIntMaxTWidth(); 3291 // The microsoft literal suffix extensions support 128-bit literals, which 3292 // may be wider than [u]intmax_t. 3293 // FIXME: Actually, they don't. We seem to have accidentally invented the 3294 // i128 suffix. 3295 if (Literal.MicrosoftInteger == 128 && MaxWidth < 128 && 3296 Context.getTargetInfo().hasInt128Type()) 3297 MaxWidth = 128; 3298 llvm::APInt ResultVal(MaxWidth, 0); 3299 3300 if (Literal.GetIntegerValue(ResultVal)) { 3301 // If this value didn't fit into uintmax_t, error and force to ull. 3302 Diag(Tok.getLocation(), diag::err_integer_literal_too_large) 3303 << /* Unsigned */ 1; 3304 Ty = Context.UnsignedLongLongTy; 3305 assert(Context.getTypeSize(Ty) == ResultVal.getBitWidth() && 3306 "long long is not intmax_t?"); 3307 } else { 3308 // If this value fits into a ULL, try to figure out what else it fits into 3309 // according to the rules of C99 6.4.4.1p5. 3310 3311 // Octal, Hexadecimal, and integers with a U suffix are allowed to 3312 // be an unsigned int. 3313 bool AllowUnsigned = Literal.isUnsigned || Literal.getRadix() != 10; 3314 3315 // Check from smallest to largest, picking the smallest type we can. 3316 unsigned Width = 0; 3317 3318 // Microsoft specific integer suffixes are explicitly sized. 3319 if (Literal.MicrosoftInteger) { 3320 if (Literal.MicrosoftInteger > MaxWidth) { 3321 // If this target doesn't support __int128, error and force to ull. 3322 Diag(Tok.getLocation(), diag::err_int128_unsupported); 3323 Width = MaxWidth; 3324 Ty = Context.getIntMaxType(); 3325 } else { 3326 Width = Literal.MicrosoftInteger; 3327 Ty = Context.getIntTypeForBitwidth(Width, 3328 /*Signed=*/!Literal.isUnsigned); 3329 } 3330 } 3331 3332 if (Ty.isNull() && !Literal.isLong && !Literal.isLongLong) { 3333 // Are int/unsigned possibilities? 3334 unsigned IntSize = Context.getTargetInfo().getIntWidth(); 3335 3336 // Does it fit in a unsigned int? 3337 if (ResultVal.isIntN(IntSize)) { 3338 // Does it fit in a signed int? 3339 if (!Literal.isUnsigned && ResultVal[IntSize-1] == 0) 3340 Ty = Context.IntTy; 3341 else if (AllowUnsigned) 3342 Ty = Context.UnsignedIntTy; 3343 Width = IntSize; 3344 } 3345 } 3346 3347 // Are long/unsigned long possibilities? 3348 if (Ty.isNull() && !Literal.isLongLong) { 3349 unsigned LongSize = Context.getTargetInfo().getLongWidth(); 3350 3351 // Does it fit in a unsigned long? 3352 if (ResultVal.isIntN(LongSize)) { 3353 // Does it fit in a signed long? 3354 if (!Literal.isUnsigned && ResultVal[LongSize-1] == 0) 3355 Ty = Context.LongTy; 3356 else if (AllowUnsigned) 3357 Ty = Context.UnsignedLongTy; 3358 Width = LongSize; 3359 } 3360 } 3361 3362 // Check long long if needed. 3363 if (Ty.isNull()) { 3364 unsigned LongLongSize = Context.getTargetInfo().getLongLongWidth(); 3365 3366 // Does it fit in a unsigned long long? 3367 if (ResultVal.isIntN(LongLongSize)) { 3368 // Does it fit in a signed long long? 3369 // To be compatible with MSVC, hex integer literals ending with the 3370 // LL or i64 suffix are always signed in Microsoft mode. 3371 if (!Literal.isUnsigned && (ResultVal[LongLongSize-1] == 0 || 3372 (getLangOpts().MicrosoftExt && Literal.isLongLong))) 3373 Ty = Context.LongLongTy; 3374 else if (AllowUnsigned) 3375 Ty = Context.UnsignedLongLongTy; 3376 Width = LongLongSize; 3377 } 3378 } 3379 3380 // If we still couldn't decide a type, we probably have something that 3381 // does not fit in a signed long long, but has no U suffix. 3382 if (Ty.isNull()) { 3383 Diag(Tok.getLocation(), diag::ext_integer_literal_too_large_for_signed); 3384 Ty = Context.UnsignedLongLongTy; 3385 Width = Context.getTargetInfo().getLongLongWidth(); 3386 } 3387 3388 if (ResultVal.getBitWidth() != Width) 3389 ResultVal = ResultVal.trunc(Width); 3390 } 3391 Res = IntegerLiteral::Create(Context, ResultVal, Ty, Tok.getLocation()); 3392 } 3393 3394 // If this is an imaginary literal, create the ImaginaryLiteral wrapper. 3395 if (Literal.isImaginary) 3396 Res = new (Context) ImaginaryLiteral(Res, 3397 Context.getComplexType(Res->getType())); 3398 3399 return Res; 3400 } 3401 3402 ExprResult Sema::ActOnParenExpr(SourceLocation L, SourceLocation R, Expr *E) { 3403 assert(E && "ActOnParenExpr() missing expr"); 3404 return new (Context) ParenExpr(L, R, E); 3405 } 3406 3407 static bool CheckVecStepTraitOperandType(Sema &S, QualType T, 3408 SourceLocation Loc, 3409 SourceRange ArgRange) { 3410 // [OpenCL 1.1 6.11.12] "The vec_step built-in function takes a built-in 3411 // scalar or vector data type argument..." 3412 // Every built-in scalar type (OpenCL 1.1 6.1.1) is either an arithmetic 3413 // type (C99 6.2.5p18) or void. 3414 if (!(T->isArithmeticType() || T->isVoidType() || T->isVectorType())) { 3415 S.Diag(Loc, diag::err_vecstep_non_scalar_vector_type) 3416 << T << ArgRange; 3417 return true; 3418 } 3419 3420 assert((T->isVoidType() || !T->isIncompleteType()) && 3421 "Scalar types should always be complete"); 3422 return false; 3423 } 3424 3425 static bool CheckExtensionTraitOperandType(Sema &S, QualType T, 3426 SourceLocation Loc, 3427 SourceRange ArgRange, 3428 UnaryExprOrTypeTrait TraitKind) { 3429 // Invalid types must be hard errors for SFINAE in C++. 3430 if (S.LangOpts.CPlusPlus) 3431 return true; 3432 3433 // C99 6.5.3.4p1: 3434 if (T->isFunctionType() && 3435 (TraitKind == UETT_SizeOf || TraitKind == UETT_AlignOf)) { 3436 // sizeof(function)/alignof(function) is allowed as an extension. 3437 S.Diag(Loc, diag::ext_sizeof_alignof_function_type) 3438 << TraitKind << ArgRange; 3439 return false; 3440 } 3441 3442 // Allow sizeof(void)/alignof(void) as an extension, unless in OpenCL where 3443 // this is an error (OpenCL v1.1 s6.3.k) 3444 if (T->isVoidType()) { 3445 unsigned DiagID = S.LangOpts.OpenCL ? diag::err_opencl_sizeof_alignof_type 3446 : diag::ext_sizeof_alignof_void_type; 3447 S.Diag(Loc, DiagID) << TraitKind << ArgRange; 3448 return false; 3449 } 3450 3451 return true; 3452 } 3453 3454 static bool CheckObjCTraitOperandConstraints(Sema &S, QualType T, 3455 SourceLocation Loc, 3456 SourceRange ArgRange, 3457 UnaryExprOrTypeTrait TraitKind) { 3458 // Reject sizeof(interface) and sizeof(interface<proto>) if the 3459 // runtime doesn't allow it. 3460 if (!S.LangOpts.ObjCRuntime.allowsSizeofAlignof() && T->isObjCObjectType()) { 3461 S.Diag(Loc, diag::err_sizeof_nonfragile_interface) 3462 << T << (TraitKind == UETT_SizeOf) 3463 << ArgRange; 3464 return true; 3465 } 3466 3467 return false; 3468 } 3469 3470 /// \brief Check whether E is a pointer from a decayed array type (the decayed 3471 /// pointer type is equal to T) and emit a warning if it is. 3472 static void warnOnSizeofOnArrayDecay(Sema &S, SourceLocation Loc, QualType T, 3473 Expr *E) { 3474 // Don't warn if the operation changed the type. 3475 if (T != E->getType()) 3476 return; 3477 3478 // Now look for array decays. 3479 ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(E); 3480 if (!ICE || ICE->getCastKind() != CK_ArrayToPointerDecay) 3481 return; 3482 3483 S.Diag(Loc, diag::warn_sizeof_array_decay) << ICE->getSourceRange() 3484 << ICE->getType() 3485 << ICE->getSubExpr()->getType(); 3486 } 3487 3488 /// \brief Check the constraints on expression operands to unary type expression 3489 /// and type traits. 3490 /// 3491 /// Completes any types necessary and validates the constraints on the operand 3492 /// expression. The logic mostly mirrors the type-based overload, but may modify 3493 /// the expression as it completes the type for that expression through template 3494 /// instantiation, etc. 3495 bool Sema::CheckUnaryExprOrTypeTraitOperand(Expr *E, 3496 UnaryExprOrTypeTrait ExprKind) { 3497 QualType ExprTy = E->getType(); 3498 assert(!ExprTy->isReferenceType()); 3499 3500 if (ExprKind == UETT_VecStep) 3501 return CheckVecStepTraitOperandType(*this, ExprTy, E->getExprLoc(), 3502 E->getSourceRange()); 3503 3504 // Whitelist some types as extensions 3505 if (!CheckExtensionTraitOperandType(*this, ExprTy, E->getExprLoc(), 3506 E->getSourceRange(), ExprKind)) 3507 return false; 3508 3509 // 'alignof' applied to an expression only requires the base element type of 3510 // the expression to be complete. 'sizeof' requires the expression's type to 3511 // be complete (and will attempt to complete it if it's an array of unknown 3512 // bound). 3513 if (ExprKind == UETT_AlignOf) { 3514 if (RequireCompleteType(E->getExprLoc(), 3515 Context.getBaseElementType(E->getType()), 3516 diag::err_sizeof_alignof_incomplete_type, ExprKind, 3517 E->getSourceRange())) 3518 return true; 3519 } else { 3520 if (RequireCompleteExprType(E, diag::err_sizeof_alignof_incomplete_type, 3521 ExprKind, E->getSourceRange())) 3522 return true; 3523 } 3524 3525 // Completing the expression's type may have changed it. 3526 ExprTy = E->getType(); 3527 assert(!ExprTy->isReferenceType()); 3528 3529 if (ExprTy->isFunctionType()) { 3530 Diag(E->getExprLoc(), diag::err_sizeof_alignof_function_type) 3531 << ExprKind << E->getSourceRange(); 3532 return true; 3533 } 3534 3535 // The operand for sizeof and alignof is in an unevaluated expression context, 3536 // so side effects could result in unintended consequences. 3537 if ((ExprKind == UETT_SizeOf || ExprKind == UETT_AlignOf) && 3538 ActiveTemplateInstantiations.empty() && E->HasSideEffects(Context, false)) 3539 Diag(E->getExprLoc(), diag::warn_side_effects_unevaluated_context); 3540 3541 if (CheckObjCTraitOperandConstraints(*this, ExprTy, E->getExprLoc(), 3542 E->getSourceRange(), ExprKind)) 3543 return true; 3544 3545 if (ExprKind == UETT_SizeOf) { 3546 if (DeclRefExpr *DeclRef = dyn_cast<DeclRefExpr>(E->IgnoreParens())) { 3547 if (ParmVarDecl *PVD = dyn_cast<ParmVarDecl>(DeclRef->getFoundDecl())) { 3548 QualType OType = PVD->getOriginalType(); 3549 QualType Type = PVD->getType(); 3550 if (Type->isPointerType() && OType->isArrayType()) { 3551 Diag(E->getExprLoc(), diag::warn_sizeof_array_param) 3552 << Type << OType; 3553 Diag(PVD->getLocation(), diag::note_declared_at); 3554 } 3555 } 3556 } 3557 3558 // Warn on "sizeof(array op x)" and "sizeof(x op array)", where the array 3559 // decays into a pointer and returns an unintended result. This is most 3560 // likely a typo for "sizeof(array) op x". 3561 if (BinaryOperator *BO = dyn_cast<BinaryOperator>(E->IgnoreParens())) { 3562 warnOnSizeofOnArrayDecay(*this, BO->getOperatorLoc(), BO->getType(), 3563 BO->getLHS()); 3564 warnOnSizeofOnArrayDecay(*this, BO->getOperatorLoc(), BO->getType(), 3565 BO->getRHS()); 3566 } 3567 } 3568 3569 return false; 3570 } 3571 3572 /// \brief Check the constraints on operands to unary expression and type 3573 /// traits. 3574 /// 3575 /// This will complete any types necessary, and validate the various constraints 3576 /// on those operands. 3577 /// 3578 /// The UsualUnaryConversions() function is *not* called by this routine. 3579 /// C99 6.3.2.1p[2-4] all state: 3580 /// Except when it is the operand of the sizeof operator ... 3581 /// 3582 /// C++ [expr.sizeof]p4 3583 /// The lvalue-to-rvalue, array-to-pointer, and function-to-pointer 3584 /// standard conversions are not applied to the operand of sizeof. 3585 /// 3586 /// This policy is followed for all of the unary trait expressions. 3587 bool Sema::CheckUnaryExprOrTypeTraitOperand(QualType ExprType, 3588 SourceLocation OpLoc, 3589 SourceRange ExprRange, 3590 UnaryExprOrTypeTrait ExprKind) { 3591 if (ExprType->isDependentType()) 3592 return false; 3593 3594 // C++ [expr.sizeof]p2: 3595 // When applied to a reference or a reference type, the result 3596 // is the size of the referenced type. 3597 // C++11 [expr.alignof]p3: 3598 // When alignof is applied to a reference type, the result 3599 // shall be the alignment of the referenced type. 3600 if (const ReferenceType *Ref = ExprType->getAs<ReferenceType>()) 3601 ExprType = Ref->getPointeeType(); 3602 3603 // C11 6.5.3.4/3, C++11 [expr.alignof]p3: 3604 // When alignof or _Alignof is applied to an array type, the result 3605 // is the alignment of the element type. 3606 if (ExprKind == UETT_AlignOf) 3607 ExprType = Context.getBaseElementType(ExprType); 3608 3609 if (ExprKind == UETT_VecStep) 3610 return CheckVecStepTraitOperandType(*this, ExprType, OpLoc, ExprRange); 3611 3612 // Whitelist some types as extensions 3613 if (!CheckExtensionTraitOperandType(*this, ExprType, OpLoc, ExprRange, 3614 ExprKind)) 3615 return false; 3616 3617 if (RequireCompleteType(OpLoc, ExprType, 3618 diag::err_sizeof_alignof_incomplete_type, 3619 ExprKind, ExprRange)) 3620 return true; 3621 3622 if (ExprType->isFunctionType()) { 3623 Diag(OpLoc, diag::err_sizeof_alignof_function_type) 3624 << ExprKind << ExprRange; 3625 return true; 3626 } 3627 3628 if (CheckObjCTraitOperandConstraints(*this, ExprType, OpLoc, ExprRange, 3629 ExprKind)) 3630 return true; 3631 3632 return false; 3633 } 3634 3635 static bool CheckAlignOfExpr(Sema &S, Expr *E) { 3636 E = E->IgnoreParens(); 3637 3638 // Cannot know anything else if the expression is dependent. 3639 if (E->isTypeDependent()) 3640 return false; 3641 3642 if (E->getObjectKind() == OK_BitField) { 3643 S.Diag(E->getExprLoc(), diag::err_sizeof_alignof_bitfield) 3644 << 1 << E->getSourceRange(); 3645 return true; 3646 } 3647 3648 ValueDecl *D = nullptr; 3649 if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E)) { 3650 D = DRE->getDecl(); 3651 } else if (MemberExpr *ME = dyn_cast<MemberExpr>(E)) { 3652 D = ME->getMemberDecl(); 3653 } 3654 3655 // If it's a field, require the containing struct to have a 3656 // complete definition so that we can compute the layout. 3657 // 3658 // This can happen in C++11 onwards, either by naming the member 3659 // in a way that is not transformed into a member access expression 3660 // (in an unevaluated operand, for instance), or by naming the member 3661 // in a trailing-return-type. 3662 // 3663 // For the record, since __alignof__ on expressions is a GCC 3664 // extension, GCC seems to permit this but always gives the 3665 // nonsensical answer 0. 3666 // 3667 // We don't really need the layout here --- we could instead just 3668 // directly check for all the appropriate alignment-lowing 3669 // attributes --- but that would require duplicating a lot of 3670 // logic that just isn't worth duplicating for such a marginal 3671 // use-case. 3672 if (FieldDecl *FD = dyn_cast_or_null<FieldDecl>(D)) { 3673 // Fast path this check, since we at least know the record has a 3674 // definition if we can find a member of it. 3675 if (!FD->getParent()->isCompleteDefinition()) { 3676 S.Diag(E->getExprLoc(), diag::err_alignof_member_of_incomplete_type) 3677 << E->getSourceRange(); 3678 return true; 3679 } 3680 3681 // Otherwise, if it's a field, and the field doesn't have 3682 // reference type, then it must have a complete type (or be a 3683 // flexible array member, which we explicitly want to 3684 // white-list anyway), which makes the following checks trivial. 3685 if (!FD->getType()->isReferenceType()) 3686 return false; 3687 } 3688 3689 return S.CheckUnaryExprOrTypeTraitOperand(E, UETT_AlignOf); 3690 } 3691 3692 bool Sema::CheckVecStepExpr(Expr *E) { 3693 E = E->IgnoreParens(); 3694 3695 // Cannot know anything else if the expression is dependent. 3696 if (E->isTypeDependent()) 3697 return false; 3698 3699 return CheckUnaryExprOrTypeTraitOperand(E, UETT_VecStep); 3700 } 3701 3702 /// \brief Build a sizeof or alignof expression given a type operand. 3703 ExprResult 3704 Sema::CreateUnaryExprOrTypeTraitExpr(TypeSourceInfo *TInfo, 3705 SourceLocation OpLoc, 3706 UnaryExprOrTypeTrait ExprKind, 3707 SourceRange R) { 3708 if (!TInfo) 3709 return ExprError(); 3710 3711 QualType T = TInfo->getType(); 3712 3713 if (!T->isDependentType() && 3714 CheckUnaryExprOrTypeTraitOperand(T, OpLoc, R, ExprKind)) 3715 return ExprError(); 3716 3717 // C99 6.5.3.4p4: the type (an unsigned integer type) is size_t. 3718 return new (Context) UnaryExprOrTypeTraitExpr( 3719 ExprKind, TInfo, Context.getSizeType(), OpLoc, R.getEnd()); 3720 } 3721 3722 /// \brief Build a sizeof or alignof expression given an expression 3723 /// operand. 3724 ExprResult 3725 Sema::CreateUnaryExprOrTypeTraitExpr(Expr *E, SourceLocation OpLoc, 3726 UnaryExprOrTypeTrait ExprKind) { 3727 ExprResult PE = CheckPlaceholderExpr(E); 3728 if (PE.isInvalid()) 3729 return ExprError(); 3730 3731 E = PE.get(); 3732 3733 // Verify that the operand is valid. 3734 bool isInvalid = false; 3735 if (E->isTypeDependent()) { 3736 // Delay type-checking for type-dependent expressions. 3737 } else if (ExprKind == UETT_AlignOf) { 3738 isInvalid = CheckAlignOfExpr(*this, E); 3739 } else if (ExprKind == UETT_VecStep) { 3740 isInvalid = CheckVecStepExpr(E); 3741 } else if (E->refersToBitField()) { // C99 6.5.3.4p1. 3742 Diag(E->getExprLoc(), diag::err_sizeof_alignof_bitfield) << 0; 3743 isInvalid = true; 3744 } else { 3745 isInvalid = CheckUnaryExprOrTypeTraitOperand(E, UETT_SizeOf); 3746 } 3747 3748 if (isInvalid) 3749 return ExprError(); 3750 3751 if (ExprKind == UETT_SizeOf && E->getType()->isVariableArrayType()) { 3752 PE = TransformToPotentiallyEvaluated(E); 3753 if (PE.isInvalid()) return ExprError(); 3754 E = PE.get(); 3755 } 3756 3757 // C99 6.5.3.4p4: the type (an unsigned integer type) is size_t. 3758 return new (Context) UnaryExprOrTypeTraitExpr( 3759 ExprKind, E, Context.getSizeType(), OpLoc, E->getSourceRange().getEnd()); 3760 } 3761 3762 /// ActOnUnaryExprOrTypeTraitExpr - Handle @c sizeof(type) and @c sizeof @c 3763 /// expr and the same for @c alignof and @c __alignof 3764 /// Note that the ArgRange is invalid if isType is false. 3765 ExprResult 3766 Sema::ActOnUnaryExprOrTypeTraitExpr(SourceLocation OpLoc, 3767 UnaryExprOrTypeTrait ExprKind, bool IsType, 3768 void *TyOrEx, const SourceRange &ArgRange) { 3769 // If error parsing type, ignore. 3770 if (!TyOrEx) return ExprError(); 3771 3772 if (IsType) { 3773 TypeSourceInfo *TInfo; 3774 (void) GetTypeFromParser(ParsedType::getFromOpaquePtr(TyOrEx), &TInfo); 3775 return CreateUnaryExprOrTypeTraitExpr(TInfo, OpLoc, ExprKind, ArgRange); 3776 } 3777 3778 Expr *ArgEx = (Expr *)TyOrEx; 3779 ExprResult Result = CreateUnaryExprOrTypeTraitExpr(ArgEx, OpLoc, ExprKind); 3780 return Result; 3781 } 3782 3783 static QualType CheckRealImagOperand(Sema &S, ExprResult &V, SourceLocation Loc, 3784 bool IsReal) { 3785 if (V.get()->isTypeDependent()) 3786 return S.Context.DependentTy; 3787 3788 // _Real and _Imag are only l-values for normal l-values. 3789 if (V.get()->getObjectKind() != OK_Ordinary) { 3790 V = S.DefaultLvalueConversion(V.get()); 3791 if (V.isInvalid()) 3792 return QualType(); 3793 } 3794 3795 // These operators return the element type of a complex type. 3796 if (const ComplexType *CT = V.get()->getType()->getAs<ComplexType>()) 3797 return CT->getElementType(); 3798 3799 // Otherwise they pass through real integer and floating point types here. 3800 if (V.get()->getType()->isArithmeticType()) 3801 return V.get()->getType(); 3802 3803 // Test for placeholders. 3804 ExprResult PR = S.CheckPlaceholderExpr(V.get()); 3805 if (PR.isInvalid()) return QualType(); 3806 if (PR.get() != V.get()) { 3807 V = PR; 3808 return CheckRealImagOperand(S, V, Loc, IsReal); 3809 } 3810 3811 // Reject anything else. 3812 S.Diag(Loc, diag::err_realimag_invalid_type) << V.get()->getType() 3813 << (IsReal ? "__real" : "__imag"); 3814 return QualType(); 3815 } 3816 3817 3818 3819 ExprResult 3820 Sema::ActOnPostfixUnaryOp(Scope *S, SourceLocation OpLoc, 3821 tok::TokenKind Kind, Expr *Input) { 3822 UnaryOperatorKind Opc; 3823 switch (Kind) { 3824 default: llvm_unreachable("Unknown unary op!"); 3825 case tok::plusplus: Opc = UO_PostInc; break; 3826 case tok::minusminus: Opc = UO_PostDec; break; 3827 } 3828 3829 // Since this might is a postfix expression, get rid of ParenListExprs. 3830 ExprResult Result = MaybeConvertParenListExprToParenExpr(S, Input); 3831 if (Result.isInvalid()) return ExprError(); 3832 Input = Result.get(); 3833 3834 return BuildUnaryOp(S, OpLoc, Opc, Input); 3835 } 3836 3837 /// \brief Diagnose if arithmetic on the given ObjC pointer is illegal. 3838 /// 3839 /// \return true on error 3840 static bool checkArithmeticOnObjCPointer(Sema &S, 3841 SourceLocation opLoc, 3842 Expr *op) { 3843 assert(op->getType()->isObjCObjectPointerType()); 3844 if (S.LangOpts.ObjCRuntime.allowsPointerArithmetic() && 3845 !S.LangOpts.ObjCSubscriptingLegacyRuntime) 3846 return false; 3847 3848 S.Diag(opLoc, diag::err_arithmetic_nonfragile_interface) 3849 << op->getType()->castAs<ObjCObjectPointerType>()->getPointeeType() 3850 << op->getSourceRange(); 3851 return true; 3852 } 3853 3854 ExprResult 3855 Sema::ActOnArraySubscriptExpr(Scope *S, Expr *base, SourceLocation lbLoc, 3856 Expr *idx, SourceLocation rbLoc) { 3857 // Since this might be a postfix expression, get rid of ParenListExprs. 3858 if (isa<ParenListExpr>(base)) { 3859 ExprResult result = MaybeConvertParenListExprToParenExpr(S, base); 3860 if (result.isInvalid()) return ExprError(); 3861 base = result.get(); 3862 } 3863 3864 // Handle any non-overload placeholder types in the base and index 3865 // expressions. We can't handle overloads here because the other 3866 // operand might be an overloadable type, in which case the overload 3867 // resolution for the operator overload should get the first crack 3868 // at the overload. 3869 if (base->getType()->isNonOverloadPlaceholderType()) { 3870 ExprResult result = CheckPlaceholderExpr(base); 3871 if (result.isInvalid()) return ExprError(); 3872 base = result.get(); 3873 } 3874 if (idx->getType()->isNonOverloadPlaceholderType()) { 3875 ExprResult result = CheckPlaceholderExpr(idx); 3876 if (result.isInvalid()) return ExprError(); 3877 idx = result.get(); 3878 } 3879 3880 // Build an unanalyzed expression if either operand is type-dependent. 3881 if (getLangOpts().CPlusPlus && 3882 (base->isTypeDependent() || idx->isTypeDependent())) { 3883 return new (Context) ArraySubscriptExpr(base, idx, Context.DependentTy, 3884 VK_LValue, OK_Ordinary, rbLoc); 3885 } 3886 3887 // Use C++ overloaded-operator rules if either operand has record 3888 // type. The spec says to do this if either type is *overloadable*, 3889 // but enum types can't declare subscript operators or conversion 3890 // operators, so there's nothing interesting for overload resolution 3891 // to do if there aren't any record types involved. 3892 // 3893 // ObjC pointers have their own subscripting logic that is not tied 3894 // to overload resolution and so should not take this path. 3895 if (getLangOpts().CPlusPlus && 3896 (base->getType()->isRecordType() || 3897 (!base->getType()->isObjCObjectPointerType() && 3898 idx->getType()->isRecordType()))) { 3899 return CreateOverloadedArraySubscriptExpr(lbLoc, rbLoc, base, idx); 3900 } 3901 3902 return CreateBuiltinArraySubscriptExpr(base, lbLoc, idx, rbLoc); 3903 } 3904 3905 ExprResult 3906 Sema::CreateBuiltinArraySubscriptExpr(Expr *Base, SourceLocation LLoc, 3907 Expr *Idx, SourceLocation RLoc) { 3908 Expr *LHSExp = Base; 3909 Expr *RHSExp = Idx; 3910 3911 // Perform default conversions. 3912 if (!LHSExp->getType()->getAs<VectorType>()) { 3913 ExprResult Result = DefaultFunctionArrayLvalueConversion(LHSExp); 3914 if (Result.isInvalid()) 3915 return ExprError(); 3916 LHSExp = Result.get(); 3917 } 3918 ExprResult Result = DefaultFunctionArrayLvalueConversion(RHSExp); 3919 if (Result.isInvalid()) 3920 return ExprError(); 3921 RHSExp = Result.get(); 3922 3923 QualType LHSTy = LHSExp->getType(), RHSTy = RHSExp->getType(); 3924 ExprValueKind VK = VK_LValue; 3925 ExprObjectKind OK = OK_Ordinary; 3926 3927 // C99 6.5.2.1p2: the expression e1[e2] is by definition precisely equivalent 3928 // to the expression *((e1)+(e2)). This means the array "Base" may actually be 3929 // in the subscript position. As a result, we need to derive the array base 3930 // and index from the expression types. 3931 Expr *BaseExpr, *IndexExpr; 3932 QualType ResultType; 3933 if (LHSTy->isDependentType() || RHSTy->isDependentType()) { 3934 BaseExpr = LHSExp; 3935 IndexExpr = RHSExp; 3936 ResultType = Context.DependentTy; 3937 } else if (const PointerType *PTy = LHSTy->getAs<PointerType>()) { 3938 BaseExpr = LHSExp; 3939 IndexExpr = RHSExp; 3940 ResultType = PTy->getPointeeType(); 3941 } else if (const ObjCObjectPointerType *PTy = 3942 LHSTy->getAs<ObjCObjectPointerType>()) { 3943 BaseExpr = LHSExp; 3944 IndexExpr = RHSExp; 3945 3946 // Use custom logic if this should be the pseudo-object subscript 3947 // expression. 3948 if (!LangOpts.isSubscriptPointerArithmetic()) 3949 return BuildObjCSubscriptExpression(RLoc, BaseExpr, IndexExpr, nullptr, 3950 nullptr); 3951 3952 ResultType = PTy->getPointeeType(); 3953 } else if (const PointerType *PTy = RHSTy->getAs<PointerType>()) { 3954 // Handle the uncommon case of "123[Ptr]". 3955 BaseExpr = RHSExp; 3956 IndexExpr = LHSExp; 3957 ResultType = PTy->getPointeeType(); 3958 } else if (const ObjCObjectPointerType *PTy = 3959 RHSTy->getAs<ObjCObjectPointerType>()) { 3960 // Handle the uncommon case of "123[Ptr]". 3961 BaseExpr = RHSExp; 3962 IndexExpr = LHSExp; 3963 ResultType = PTy->getPointeeType(); 3964 if (!LangOpts.isSubscriptPointerArithmetic()) { 3965 Diag(LLoc, diag::err_subscript_nonfragile_interface) 3966 << ResultType << BaseExpr->getSourceRange(); 3967 return ExprError(); 3968 } 3969 } else if (const VectorType *VTy = LHSTy->getAs<VectorType>()) { 3970 BaseExpr = LHSExp; // vectors: V[123] 3971 IndexExpr = RHSExp; 3972 VK = LHSExp->getValueKind(); 3973 if (VK != VK_RValue) 3974 OK = OK_VectorComponent; 3975 3976 // FIXME: need to deal with const... 3977 ResultType = VTy->getElementType(); 3978 } else if (LHSTy->isArrayType()) { 3979 // If we see an array that wasn't promoted by 3980 // DefaultFunctionArrayLvalueConversion, it must be an array that 3981 // wasn't promoted because of the C90 rule that doesn't 3982 // allow promoting non-lvalue arrays. Warn, then 3983 // force the promotion here. 3984 Diag(LHSExp->getLocStart(), diag::ext_subscript_non_lvalue) << 3985 LHSExp->getSourceRange(); 3986 LHSExp = ImpCastExprToType(LHSExp, Context.getArrayDecayedType(LHSTy), 3987 CK_ArrayToPointerDecay).get(); 3988 LHSTy = LHSExp->getType(); 3989 3990 BaseExpr = LHSExp; 3991 IndexExpr = RHSExp; 3992 ResultType = LHSTy->getAs<PointerType>()->getPointeeType(); 3993 } else if (RHSTy->isArrayType()) { 3994 // Same as previous, except for 123[f().a] case 3995 Diag(RHSExp->getLocStart(), diag::ext_subscript_non_lvalue) << 3996 RHSExp->getSourceRange(); 3997 RHSExp = ImpCastExprToType(RHSExp, Context.getArrayDecayedType(RHSTy), 3998 CK_ArrayToPointerDecay).get(); 3999 RHSTy = RHSExp->getType(); 4000 4001 BaseExpr = RHSExp; 4002 IndexExpr = LHSExp; 4003 ResultType = RHSTy->getAs<PointerType>()->getPointeeType(); 4004 } else { 4005 return ExprError(Diag(LLoc, diag::err_typecheck_subscript_value) 4006 << LHSExp->getSourceRange() << RHSExp->getSourceRange()); 4007 } 4008 // C99 6.5.2.1p1 4009 if (!IndexExpr->getType()->isIntegerType() && !IndexExpr->isTypeDependent()) 4010 return ExprError(Diag(LLoc, diag::err_typecheck_subscript_not_integer) 4011 << IndexExpr->getSourceRange()); 4012 4013 if ((IndexExpr->getType()->isSpecificBuiltinType(BuiltinType::Char_S) || 4014 IndexExpr->getType()->isSpecificBuiltinType(BuiltinType::Char_U)) 4015 && !IndexExpr->isTypeDependent()) 4016 Diag(LLoc, diag::warn_subscript_is_char) << IndexExpr->getSourceRange(); 4017 4018 // C99 6.5.2.1p1: "shall have type "pointer to *object* type". Similarly, 4019 // C++ [expr.sub]p1: The type "T" shall be a completely-defined object 4020 // type. Note that Functions are not objects, and that (in C99 parlance) 4021 // incomplete types are not object types. 4022 if (ResultType->isFunctionType()) { 4023 Diag(BaseExpr->getLocStart(), diag::err_subscript_function_type) 4024 << ResultType << BaseExpr->getSourceRange(); 4025 return ExprError(); 4026 } 4027 4028 if (ResultType->isVoidType() && !getLangOpts().CPlusPlus) { 4029 // GNU extension: subscripting on pointer to void 4030 Diag(LLoc, diag::ext_gnu_subscript_void_type) 4031 << BaseExpr->getSourceRange(); 4032 4033 // C forbids expressions of unqualified void type from being l-values. 4034 // See IsCForbiddenLValueType. 4035 if (!ResultType.hasQualifiers()) VK = VK_RValue; 4036 } else if (!ResultType->isDependentType() && 4037 RequireCompleteType(LLoc, ResultType, 4038 diag::err_subscript_incomplete_type, BaseExpr)) 4039 return ExprError(); 4040 4041 assert(VK == VK_RValue || LangOpts.CPlusPlus || 4042 !ResultType.isCForbiddenLValueType()); 4043 4044 return new (Context) 4045 ArraySubscriptExpr(LHSExp, RHSExp, ResultType, VK, OK, RLoc); 4046 } 4047 4048 ExprResult Sema::BuildCXXDefaultArgExpr(SourceLocation CallLoc, 4049 FunctionDecl *FD, 4050 ParmVarDecl *Param) { 4051 if (Param->hasUnparsedDefaultArg()) { 4052 Diag(CallLoc, 4053 diag::err_use_of_default_argument_to_function_declared_later) << 4054 FD << cast<CXXRecordDecl>(FD->getDeclContext())->getDeclName(); 4055 Diag(UnparsedDefaultArgLocs[Param], 4056 diag::note_default_argument_declared_here); 4057 return ExprError(); 4058 } 4059 4060 if (Param->hasUninstantiatedDefaultArg()) { 4061 Expr *UninstExpr = Param->getUninstantiatedDefaultArg(); 4062 4063 EnterExpressionEvaluationContext EvalContext(*this, PotentiallyEvaluated, 4064 Param); 4065 4066 // Instantiate the expression. 4067 MultiLevelTemplateArgumentList MutiLevelArgList 4068 = getTemplateInstantiationArgs(FD, nullptr, /*RelativeToPrimary=*/true); 4069 4070 InstantiatingTemplate Inst(*this, CallLoc, Param, 4071 MutiLevelArgList.getInnermost()); 4072 if (Inst.isInvalid()) 4073 return ExprError(); 4074 4075 ExprResult Result; 4076 { 4077 // C++ [dcl.fct.default]p5: 4078 // The names in the [default argument] expression are bound, and 4079 // the semantic constraints are checked, at the point where the 4080 // default argument expression appears. 4081 ContextRAII SavedContext(*this, FD); 4082 LocalInstantiationScope Local(*this); 4083 Result = SubstExpr(UninstExpr, MutiLevelArgList); 4084 } 4085 if (Result.isInvalid()) 4086 return ExprError(); 4087 4088 // Check the expression as an initializer for the parameter. 4089 InitializedEntity Entity 4090 = InitializedEntity::InitializeParameter(Context, Param); 4091 InitializationKind Kind 4092 = InitializationKind::CreateCopy(Param->getLocation(), 4093 /*FIXME:EqualLoc*/UninstExpr->getLocStart()); 4094 Expr *ResultE = Result.getAs<Expr>(); 4095 4096 InitializationSequence InitSeq(*this, Entity, Kind, ResultE); 4097 Result = InitSeq.Perform(*this, Entity, Kind, ResultE); 4098 if (Result.isInvalid()) 4099 return ExprError(); 4100 4101 Expr *Arg = Result.getAs<Expr>(); 4102 CheckCompletedExpr(Arg, Param->getOuterLocStart()); 4103 // Build the default argument expression. 4104 return CXXDefaultArgExpr::Create(Context, CallLoc, Param, Arg); 4105 } 4106 4107 // If the default expression creates temporaries, we need to 4108 // push them to the current stack of expression temporaries so they'll 4109 // be properly destroyed. 4110 // FIXME: We should really be rebuilding the default argument with new 4111 // bound temporaries; see the comment in PR5810. 4112 // We don't need to do that with block decls, though, because 4113 // blocks in default argument expression can never capture anything. 4114 if (isa<ExprWithCleanups>(Param->getInit())) { 4115 // Set the "needs cleanups" bit regardless of whether there are 4116 // any explicit objects. 4117 ExprNeedsCleanups = true; 4118 4119 // Append all the objects to the cleanup list. Right now, this 4120 // should always be a no-op, because blocks in default argument 4121 // expressions should never be able to capture anything. 4122 assert(!cast<ExprWithCleanups>(Param->getInit())->getNumObjects() && 4123 "default argument expression has capturing blocks?"); 4124 } 4125 4126 // We already type-checked the argument, so we know it works. 4127 // Just mark all of the declarations in this potentially-evaluated expression 4128 // as being "referenced". 4129 MarkDeclarationsReferencedInExpr(Param->getDefaultArg(), 4130 /*SkipLocalVariables=*/true); 4131 return CXXDefaultArgExpr::Create(Context, CallLoc, Param); 4132 } 4133 4134 4135 Sema::VariadicCallType 4136 Sema::getVariadicCallType(FunctionDecl *FDecl, const FunctionProtoType *Proto, 4137 Expr *Fn) { 4138 if (Proto && Proto->isVariadic()) { 4139 if (dyn_cast_or_null<CXXConstructorDecl>(FDecl)) 4140 return VariadicConstructor; 4141 else if (Fn && Fn->getType()->isBlockPointerType()) 4142 return VariadicBlock; 4143 else if (FDecl) { 4144 if (CXXMethodDecl *Method = dyn_cast_or_null<CXXMethodDecl>(FDecl)) 4145 if (Method->isInstance()) 4146 return VariadicMethod; 4147 } else if (Fn && Fn->getType() == Context.BoundMemberTy) 4148 return VariadicMethod; 4149 return VariadicFunction; 4150 } 4151 return VariadicDoesNotApply; 4152 } 4153 4154 namespace { 4155 class FunctionCallCCC : public FunctionCallFilterCCC { 4156 public: 4157 FunctionCallCCC(Sema &SemaRef, const IdentifierInfo *FuncName, 4158 unsigned NumArgs, MemberExpr *ME) 4159 : FunctionCallFilterCCC(SemaRef, NumArgs, false, ME), 4160 FunctionName(FuncName) {} 4161 4162 bool ValidateCandidate(const TypoCorrection &candidate) override { 4163 if (!candidate.getCorrectionSpecifier() || 4164 candidate.getCorrectionAsIdentifierInfo() != FunctionName) { 4165 return false; 4166 } 4167 4168 return FunctionCallFilterCCC::ValidateCandidate(candidate); 4169 } 4170 4171 private: 4172 const IdentifierInfo *const FunctionName; 4173 }; 4174 } 4175 4176 static TypoCorrection TryTypoCorrectionForCall(Sema &S, Expr *Fn, 4177 FunctionDecl *FDecl, 4178 ArrayRef<Expr *> Args) { 4179 MemberExpr *ME = dyn_cast<MemberExpr>(Fn); 4180 DeclarationName FuncName = FDecl->getDeclName(); 4181 SourceLocation NameLoc = ME ? ME->getMemberLoc() : Fn->getLocStart(); 4182 4183 if (TypoCorrection Corrected = S.CorrectTypo( 4184 DeclarationNameInfo(FuncName, NameLoc), Sema::LookupOrdinaryName, 4185 S.getScopeForContext(S.CurContext), nullptr, 4186 llvm::make_unique<FunctionCallCCC>(S, FuncName.getAsIdentifierInfo(), 4187 Args.size(), ME), 4188 Sema::CTK_ErrorRecovery)) { 4189 if (NamedDecl *ND = Corrected.getCorrectionDecl()) { 4190 if (Corrected.isOverloaded()) { 4191 OverloadCandidateSet OCS(NameLoc, OverloadCandidateSet::CSK_Normal); 4192 OverloadCandidateSet::iterator Best; 4193 for (TypoCorrection::decl_iterator CD = Corrected.begin(), 4194 CDEnd = Corrected.end(); 4195 CD != CDEnd; ++CD) { 4196 if (FunctionDecl *FD = dyn_cast<FunctionDecl>(*CD)) 4197 S.AddOverloadCandidate(FD, DeclAccessPair::make(FD, AS_none), Args, 4198 OCS); 4199 } 4200 switch (OCS.BestViableFunction(S, NameLoc, Best)) { 4201 case OR_Success: 4202 ND = Best->Function; 4203 Corrected.setCorrectionDecl(ND); 4204 break; 4205 default: 4206 break; 4207 } 4208 } 4209 if (isa<ValueDecl>(ND) || isa<FunctionTemplateDecl>(ND)) { 4210 return Corrected; 4211 } 4212 } 4213 } 4214 return TypoCorrection(); 4215 } 4216 4217 /// ConvertArgumentsForCall - Converts the arguments specified in 4218 /// Args/NumArgs to the parameter types of the function FDecl with 4219 /// function prototype Proto. Call is the call expression itself, and 4220 /// Fn is the function expression. For a C++ member function, this 4221 /// routine does not attempt to convert the object argument. Returns 4222 /// true if the call is ill-formed. 4223 bool 4224 Sema::ConvertArgumentsForCall(CallExpr *Call, Expr *Fn, 4225 FunctionDecl *FDecl, 4226 const FunctionProtoType *Proto, 4227 ArrayRef<Expr *> Args, 4228 SourceLocation RParenLoc, 4229 bool IsExecConfig) { 4230 // Bail out early if calling a builtin with custom typechecking. 4231 // We don't need to do this in the 4232 if (FDecl) 4233 if (unsigned ID = FDecl->getBuiltinID()) 4234 if (Context.BuiltinInfo.hasCustomTypechecking(ID)) 4235 return false; 4236 4237 // C99 6.5.2.2p7 - the arguments are implicitly converted, as if by 4238 // assignment, to the types of the corresponding parameter, ... 4239 unsigned NumParams = Proto->getNumParams(); 4240 bool Invalid = false; 4241 unsigned MinArgs = FDecl ? FDecl->getMinRequiredArguments() : NumParams; 4242 unsigned FnKind = Fn->getType()->isBlockPointerType() 4243 ? 1 /* block */ 4244 : (IsExecConfig ? 3 /* kernel function (exec config) */ 4245 : 0 /* function */); 4246 4247 // If too few arguments are available (and we don't have default 4248 // arguments for the remaining parameters), don't make the call. 4249 if (Args.size() < NumParams) { 4250 if (Args.size() < MinArgs) { 4251 TypoCorrection TC; 4252 if (FDecl && (TC = TryTypoCorrectionForCall(*this, Fn, FDecl, Args))) { 4253 unsigned diag_id = 4254 MinArgs == NumParams && !Proto->isVariadic() 4255 ? diag::err_typecheck_call_too_few_args_suggest 4256 : diag::err_typecheck_call_too_few_args_at_least_suggest; 4257 diagnoseTypo(TC, PDiag(diag_id) << FnKind << MinArgs 4258 << static_cast<unsigned>(Args.size()) 4259 << TC.getCorrectionRange()); 4260 } else if (MinArgs == 1 && FDecl && FDecl->getParamDecl(0)->getDeclName()) 4261 Diag(RParenLoc, 4262 MinArgs == NumParams && !Proto->isVariadic() 4263 ? diag::err_typecheck_call_too_few_args_one 4264 : diag::err_typecheck_call_too_few_args_at_least_one) 4265 << FnKind << FDecl->getParamDecl(0) << Fn->getSourceRange(); 4266 else 4267 Diag(RParenLoc, MinArgs == NumParams && !Proto->isVariadic() 4268 ? diag::err_typecheck_call_too_few_args 4269 : diag::err_typecheck_call_too_few_args_at_least) 4270 << FnKind << MinArgs << static_cast<unsigned>(Args.size()) 4271 << Fn->getSourceRange(); 4272 4273 // Emit the location of the prototype. 4274 if (!TC && FDecl && !FDecl->getBuiltinID() && !IsExecConfig) 4275 Diag(FDecl->getLocStart(), diag::note_callee_decl) 4276 << FDecl; 4277 4278 return true; 4279 } 4280 Call->setNumArgs(Context, NumParams); 4281 } 4282 4283 // If too many are passed and not variadic, error on the extras and drop 4284 // them. 4285 if (Args.size() > NumParams) { 4286 if (!Proto->isVariadic()) { 4287 TypoCorrection TC; 4288 if (FDecl && (TC = TryTypoCorrectionForCall(*this, Fn, FDecl, Args))) { 4289 unsigned diag_id = 4290 MinArgs == NumParams && !Proto->isVariadic() 4291 ? diag::err_typecheck_call_too_many_args_suggest 4292 : diag::err_typecheck_call_too_many_args_at_most_suggest; 4293 diagnoseTypo(TC, PDiag(diag_id) << FnKind << NumParams 4294 << static_cast<unsigned>(Args.size()) 4295 << TC.getCorrectionRange()); 4296 } else if (NumParams == 1 && FDecl && 4297 FDecl->getParamDecl(0)->getDeclName()) 4298 Diag(Args[NumParams]->getLocStart(), 4299 MinArgs == NumParams 4300 ? diag::err_typecheck_call_too_many_args_one 4301 : diag::err_typecheck_call_too_many_args_at_most_one) 4302 << FnKind << FDecl->getParamDecl(0) 4303 << static_cast<unsigned>(Args.size()) << Fn->getSourceRange() 4304 << SourceRange(Args[NumParams]->getLocStart(), 4305 Args.back()->getLocEnd()); 4306 else 4307 Diag(Args[NumParams]->getLocStart(), 4308 MinArgs == NumParams 4309 ? diag::err_typecheck_call_too_many_args 4310 : diag::err_typecheck_call_too_many_args_at_most) 4311 << FnKind << NumParams << static_cast<unsigned>(Args.size()) 4312 << Fn->getSourceRange() 4313 << SourceRange(Args[NumParams]->getLocStart(), 4314 Args.back()->getLocEnd()); 4315 4316 // Emit the location of the prototype. 4317 if (!TC && FDecl && !FDecl->getBuiltinID() && !IsExecConfig) 4318 Diag(FDecl->getLocStart(), diag::note_callee_decl) 4319 << FDecl; 4320 4321 // This deletes the extra arguments. 4322 Call->setNumArgs(Context, NumParams); 4323 return true; 4324 } 4325 } 4326 SmallVector<Expr *, 8> AllArgs; 4327 VariadicCallType CallType = getVariadicCallType(FDecl, Proto, Fn); 4328 4329 Invalid = GatherArgumentsForCall(Call->getLocStart(), FDecl, 4330 Proto, 0, Args, AllArgs, CallType); 4331 if (Invalid) 4332 return true; 4333 unsigned TotalNumArgs = AllArgs.size(); 4334 for (unsigned i = 0; i < TotalNumArgs; ++i) 4335 Call->setArg(i, AllArgs[i]); 4336 4337 return false; 4338 } 4339 4340 bool Sema::GatherArgumentsForCall(SourceLocation CallLoc, FunctionDecl *FDecl, 4341 const FunctionProtoType *Proto, 4342 unsigned FirstParam, ArrayRef<Expr *> Args, 4343 SmallVectorImpl<Expr *> &AllArgs, 4344 VariadicCallType CallType, bool AllowExplicit, 4345 bool IsListInitialization) { 4346 unsigned NumParams = Proto->getNumParams(); 4347 bool Invalid = false; 4348 unsigned ArgIx = 0; 4349 // Continue to check argument types (even if we have too few/many args). 4350 for (unsigned i = FirstParam; i < NumParams; i++) { 4351 QualType ProtoArgType = Proto->getParamType(i); 4352 4353 Expr *Arg; 4354 ParmVarDecl *Param = FDecl ? FDecl->getParamDecl(i) : nullptr; 4355 if (ArgIx < Args.size()) { 4356 Arg = Args[ArgIx++]; 4357 4358 if (RequireCompleteType(Arg->getLocStart(), 4359 ProtoArgType, 4360 diag::err_call_incomplete_argument, Arg)) 4361 return true; 4362 4363 // Strip the unbridged-cast placeholder expression off, if applicable. 4364 bool CFAudited = false; 4365 if (Arg->getType() == Context.ARCUnbridgedCastTy && 4366 FDecl && FDecl->hasAttr<CFAuditedTransferAttr>() && 4367 (!Param || !Param->hasAttr<CFConsumedAttr>())) 4368 Arg = stripARCUnbridgedCast(Arg); 4369 else if (getLangOpts().ObjCAutoRefCount && 4370 FDecl && FDecl->hasAttr<CFAuditedTransferAttr>() && 4371 (!Param || !Param->hasAttr<CFConsumedAttr>())) 4372 CFAudited = true; 4373 4374 InitializedEntity Entity = 4375 Param ? InitializedEntity::InitializeParameter(Context, Param, 4376 ProtoArgType) 4377 : InitializedEntity::InitializeParameter( 4378 Context, ProtoArgType, Proto->isParamConsumed(i)); 4379 4380 // Remember that parameter belongs to a CF audited API. 4381 if (CFAudited) 4382 Entity.setParameterCFAudited(); 4383 4384 ExprResult ArgE = PerformCopyInitialization( 4385 Entity, SourceLocation(), Arg, IsListInitialization, AllowExplicit); 4386 if (ArgE.isInvalid()) 4387 return true; 4388 4389 Arg = ArgE.getAs<Expr>(); 4390 } else { 4391 assert(Param && "can't use default arguments without a known callee"); 4392 4393 ExprResult ArgExpr = 4394 BuildCXXDefaultArgExpr(CallLoc, FDecl, Param); 4395 if (ArgExpr.isInvalid()) 4396 return true; 4397 4398 Arg = ArgExpr.getAs<Expr>(); 4399 } 4400 4401 // Check for array bounds violations for each argument to the call. This 4402 // check only triggers warnings when the argument isn't a more complex Expr 4403 // with its own checking, such as a BinaryOperator. 4404 CheckArrayAccess(Arg); 4405 4406 // Check for violations of C99 static array rules (C99 6.7.5.3p7). 4407 CheckStaticArrayArgument(CallLoc, Param, Arg); 4408 4409 AllArgs.push_back(Arg); 4410 } 4411 4412 // If this is a variadic call, handle args passed through "...". 4413 if (CallType != VariadicDoesNotApply) { 4414 // Assume that extern "C" functions with variadic arguments that 4415 // return __unknown_anytype aren't *really* variadic. 4416 if (Proto->getReturnType() == Context.UnknownAnyTy && FDecl && 4417 FDecl->isExternC()) { 4418 for (unsigned i = ArgIx, e = Args.size(); i != e; ++i) { 4419 QualType paramType; // ignored 4420 ExprResult arg = checkUnknownAnyArg(CallLoc, Args[i], paramType); 4421 Invalid |= arg.isInvalid(); 4422 AllArgs.push_back(arg.get()); 4423 } 4424 4425 // Otherwise do argument promotion, (C99 6.5.2.2p7). 4426 } else { 4427 for (unsigned i = ArgIx, e = Args.size(); i != e; ++i) { 4428 ExprResult Arg = DefaultVariadicArgumentPromotion(Args[i], CallType, 4429 FDecl); 4430 Invalid |= Arg.isInvalid(); 4431 AllArgs.push_back(Arg.get()); 4432 } 4433 } 4434 4435 // Check for array bounds violations. 4436 for (unsigned i = ArgIx, e = Args.size(); i != e; ++i) 4437 CheckArrayAccess(Args[i]); 4438 } 4439 return Invalid; 4440 } 4441 4442 static void DiagnoseCalleeStaticArrayParam(Sema &S, ParmVarDecl *PVD) { 4443 TypeLoc TL = PVD->getTypeSourceInfo()->getTypeLoc(); 4444 if (DecayedTypeLoc DTL = TL.getAs<DecayedTypeLoc>()) 4445 TL = DTL.getOriginalLoc(); 4446 if (ArrayTypeLoc ATL = TL.getAs<ArrayTypeLoc>()) 4447 S.Diag(PVD->getLocation(), diag::note_callee_static_array) 4448 << ATL.getLocalSourceRange(); 4449 } 4450 4451 /// CheckStaticArrayArgument - If the given argument corresponds to a static 4452 /// array parameter, check that it is non-null, and that if it is formed by 4453 /// array-to-pointer decay, the underlying array is sufficiently large. 4454 /// 4455 /// C99 6.7.5.3p7: If the keyword static also appears within the [ and ] of the 4456 /// array type derivation, then for each call to the function, the value of the 4457 /// corresponding actual argument shall provide access to the first element of 4458 /// an array with at least as many elements as specified by the size expression. 4459 void 4460 Sema::CheckStaticArrayArgument(SourceLocation CallLoc, 4461 ParmVarDecl *Param, 4462 const Expr *ArgExpr) { 4463 // Static array parameters are not supported in C++. 4464 if (!Param || getLangOpts().CPlusPlus) 4465 return; 4466 4467 QualType OrigTy = Param->getOriginalType(); 4468 4469 const ArrayType *AT = Context.getAsArrayType(OrigTy); 4470 if (!AT || AT->getSizeModifier() != ArrayType::Static) 4471 return; 4472 4473 if (ArgExpr->isNullPointerConstant(Context, 4474 Expr::NPC_NeverValueDependent)) { 4475 Diag(CallLoc, diag::warn_null_arg) << ArgExpr->getSourceRange(); 4476 DiagnoseCalleeStaticArrayParam(*this, Param); 4477 return; 4478 } 4479 4480 const ConstantArrayType *CAT = dyn_cast<ConstantArrayType>(AT); 4481 if (!CAT) 4482 return; 4483 4484 const ConstantArrayType *ArgCAT = 4485 Context.getAsConstantArrayType(ArgExpr->IgnoreParenImpCasts()->getType()); 4486 if (!ArgCAT) 4487 return; 4488 4489 if (ArgCAT->getSize().ult(CAT->getSize())) { 4490 Diag(CallLoc, diag::warn_static_array_too_small) 4491 << ArgExpr->getSourceRange() 4492 << (unsigned) ArgCAT->getSize().getZExtValue() 4493 << (unsigned) CAT->getSize().getZExtValue(); 4494 DiagnoseCalleeStaticArrayParam(*this, Param); 4495 } 4496 } 4497 4498 /// Given a function expression of unknown-any type, try to rebuild it 4499 /// to have a function type. 4500 static ExprResult rebuildUnknownAnyFunction(Sema &S, Expr *fn); 4501 4502 /// Is the given type a placeholder that we need to lower out 4503 /// immediately during argument processing? 4504 static bool isPlaceholderToRemoveAsArg(QualType type) { 4505 // Placeholders are never sugared. 4506 const BuiltinType *placeholder = dyn_cast<BuiltinType>(type); 4507 if (!placeholder) return false; 4508 4509 switch (placeholder->getKind()) { 4510 // Ignore all the non-placeholder types. 4511 #define PLACEHOLDER_TYPE(ID, SINGLETON_ID) 4512 #define BUILTIN_TYPE(ID, SINGLETON_ID) case BuiltinType::ID: 4513 #include "clang/AST/BuiltinTypes.def" 4514 return false; 4515 4516 // We cannot lower out overload sets; they might validly be resolved 4517 // by the call machinery. 4518 case BuiltinType::Overload: 4519 return false; 4520 4521 // Unbridged casts in ARC can be handled in some call positions and 4522 // should be left in place. 4523 case BuiltinType::ARCUnbridgedCast: 4524 return false; 4525 4526 // Pseudo-objects should be converted as soon as possible. 4527 case BuiltinType::PseudoObject: 4528 return true; 4529 4530 // The debugger mode could theoretically but currently does not try 4531 // to resolve unknown-typed arguments based on known parameter types. 4532 case BuiltinType::UnknownAny: 4533 return true; 4534 4535 // These are always invalid as call arguments and should be reported. 4536 case BuiltinType::BoundMember: 4537 case BuiltinType::BuiltinFn: 4538 return true; 4539 } 4540 llvm_unreachable("bad builtin type kind"); 4541 } 4542 4543 /// Check an argument list for placeholders that we won't try to 4544 /// handle later. 4545 static bool checkArgsForPlaceholders(Sema &S, MultiExprArg args) { 4546 // Apply this processing to all the arguments at once instead of 4547 // dying at the first failure. 4548 bool hasInvalid = false; 4549 for (size_t i = 0, e = args.size(); i != e; i++) { 4550 if (isPlaceholderToRemoveAsArg(args[i]->getType())) { 4551 ExprResult result = S.CheckPlaceholderExpr(args[i]); 4552 if (result.isInvalid()) hasInvalid = true; 4553 else args[i] = result.get(); 4554 } else if (hasInvalid) { 4555 (void)S.CorrectDelayedTyposInExpr(args[i]); 4556 } 4557 } 4558 return hasInvalid; 4559 } 4560 4561 /// ActOnCallExpr - Handle a call to Fn with the specified array of arguments. 4562 /// This provides the location of the left/right parens and a list of comma 4563 /// locations. 4564 ExprResult 4565 Sema::ActOnCallExpr(Scope *S, Expr *Fn, SourceLocation LParenLoc, 4566 MultiExprArg ArgExprs, SourceLocation RParenLoc, 4567 Expr *ExecConfig, bool IsExecConfig) { 4568 // Since this might be a postfix expression, get rid of ParenListExprs. 4569 ExprResult Result = MaybeConvertParenListExprToParenExpr(S, Fn); 4570 if (Result.isInvalid()) return ExprError(); 4571 Fn = Result.get(); 4572 4573 if (checkArgsForPlaceholders(*this, ArgExprs)) 4574 return ExprError(); 4575 4576 if (getLangOpts().CPlusPlus) { 4577 // If this is a pseudo-destructor expression, build the call immediately. 4578 if (isa<CXXPseudoDestructorExpr>(Fn)) { 4579 if (!ArgExprs.empty()) { 4580 // Pseudo-destructor calls should not have any arguments. 4581 Diag(Fn->getLocStart(), diag::err_pseudo_dtor_call_with_args) 4582 << FixItHint::CreateRemoval( 4583 SourceRange(ArgExprs[0]->getLocStart(), 4584 ArgExprs.back()->getLocEnd())); 4585 } 4586 4587 return new (Context) 4588 CallExpr(Context, Fn, None, Context.VoidTy, VK_RValue, RParenLoc); 4589 } 4590 if (Fn->getType() == Context.PseudoObjectTy) { 4591 ExprResult result = CheckPlaceholderExpr(Fn); 4592 if (result.isInvalid()) return ExprError(); 4593 Fn = result.get(); 4594 } 4595 4596 // Determine whether this is a dependent call inside a C++ template, 4597 // in which case we won't do any semantic analysis now. 4598 // FIXME: Will need to cache the results of name lookup (including ADL) in 4599 // Fn. 4600 bool Dependent = false; 4601 if (Fn->isTypeDependent()) 4602 Dependent = true; 4603 else if (Expr::hasAnyTypeDependentArguments(ArgExprs)) 4604 Dependent = true; 4605 4606 if (Dependent) { 4607 if (ExecConfig) { 4608 return new (Context) CUDAKernelCallExpr( 4609 Context, Fn, cast<CallExpr>(ExecConfig), ArgExprs, 4610 Context.DependentTy, VK_RValue, RParenLoc); 4611 } else { 4612 return new (Context) CallExpr( 4613 Context, Fn, ArgExprs, Context.DependentTy, VK_RValue, RParenLoc); 4614 } 4615 } 4616 4617 // Determine whether this is a call to an object (C++ [over.call.object]). 4618 if (Fn->getType()->isRecordType()) 4619 return BuildCallToObjectOfClassType(S, Fn, LParenLoc, ArgExprs, 4620 RParenLoc); 4621 4622 if (Fn->getType() == Context.UnknownAnyTy) { 4623 ExprResult result = rebuildUnknownAnyFunction(*this, Fn); 4624 if (result.isInvalid()) return ExprError(); 4625 Fn = result.get(); 4626 } 4627 4628 if (Fn->getType() == Context.BoundMemberTy) { 4629 return BuildCallToMemberFunction(S, Fn, LParenLoc, ArgExprs, RParenLoc); 4630 } 4631 } 4632 4633 // Check for overloaded calls. This can happen even in C due to extensions. 4634 if (Fn->getType() == Context.OverloadTy) { 4635 OverloadExpr::FindResult find = OverloadExpr::find(Fn); 4636 4637 // We aren't supposed to apply this logic for if there's an '&' involved. 4638 if (!find.HasFormOfMemberPointer) { 4639 OverloadExpr *ovl = find.Expression; 4640 if (isa<UnresolvedLookupExpr>(ovl)) { 4641 UnresolvedLookupExpr *ULE = cast<UnresolvedLookupExpr>(ovl); 4642 return BuildOverloadedCallExpr(S, Fn, ULE, LParenLoc, ArgExprs, 4643 RParenLoc, ExecConfig); 4644 } else { 4645 return BuildCallToMemberFunction(S, Fn, LParenLoc, ArgExprs, 4646 RParenLoc); 4647 } 4648 } 4649 } 4650 4651 // If we're directly calling a function, get the appropriate declaration. 4652 if (Fn->getType() == Context.UnknownAnyTy) { 4653 ExprResult result = rebuildUnknownAnyFunction(*this, Fn); 4654 if (result.isInvalid()) return ExprError(); 4655 Fn = result.get(); 4656 } 4657 4658 Expr *NakedFn = Fn->IgnoreParens(); 4659 4660 NamedDecl *NDecl = nullptr; 4661 if (UnaryOperator *UnOp = dyn_cast<UnaryOperator>(NakedFn)) 4662 if (UnOp->getOpcode() == UO_AddrOf) 4663 NakedFn = UnOp->getSubExpr()->IgnoreParens(); 4664 4665 if (isa<DeclRefExpr>(NakedFn)) 4666 NDecl = cast<DeclRefExpr>(NakedFn)->getDecl(); 4667 else if (isa<MemberExpr>(NakedFn)) 4668 NDecl = cast<MemberExpr>(NakedFn)->getMemberDecl(); 4669 4670 if (FunctionDecl *FD = dyn_cast_or_null<FunctionDecl>(NDecl)) { 4671 if (FD->hasAttr<EnableIfAttr>()) { 4672 if (const EnableIfAttr *Attr = CheckEnableIf(FD, ArgExprs, true)) { 4673 Diag(Fn->getLocStart(), 4674 isa<CXXMethodDecl>(FD) ? 4675 diag::err_ovl_no_viable_member_function_in_call : 4676 diag::err_ovl_no_viable_function_in_call) 4677 << FD << FD->getSourceRange(); 4678 Diag(FD->getLocation(), 4679 diag::note_ovl_candidate_disabled_by_enable_if_attr) 4680 << Attr->getCond()->getSourceRange() << Attr->getMessage(); 4681 } 4682 } 4683 } 4684 4685 return BuildResolvedCallExpr(Fn, NDecl, LParenLoc, ArgExprs, RParenLoc, 4686 ExecConfig, IsExecConfig); 4687 } 4688 4689 /// ActOnAsTypeExpr - create a new asType (bitcast) from the arguments. 4690 /// 4691 /// __builtin_astype( value, dst type ) 4692 /// 4693 ExprResult Sema::ActOnAsTypeExpr(Expr *E, ParsedType ParsedDestTy, 4694 SourceLocation BuiltinLoc, 4695 SourceLocation RParenLoc) { 4696 ExprValueKind VK = VK_RValue; 4697 ExprObjectKind OK = OK_Ordinary; 4698 QualType DstTy = GetTypeFromParser(ParsedDestTy); 4699 QualType SrcTy = E->getType(); 4700 if (Context.getTypeSize(DstTy) != Context.getTypeSize(SrcTy)) 4701 return ExprError(Diag(BuiltinLoc, 4702 diag::err_invalid_astype_of_different_size) 4703 << DstTy 4704 << SrcTy 4705 << E->getSourceRange()); 4706 return new (Context) AsTypeExpr(E, DstTy, VK, OK, BuiltinLoc, RParenLoc); 4707 } 4708 4709 /// ActOnConvertVectorExpr - create a new convert-vector expression from the 4710 /// provided arguments. 4711 /// 4712 /// __builtin_convertvector( value, dst type ) 4713 /// 4714 ExprResult Sema::ActOnConvertVectorExpr(Expr *E, ParsedType ParsedDestTy, 4715 SourceLocation BuiltinLoc, 4716 SourceLocation RParenLoc) { 4717 TypeSourceInfo *TInfo; 4718 GetTypeFromParser(ParsedDestTy, &TInfo); 4719 return SemaConvertVectorExpr(E, TInfo, BuiltinLoc, RParenLoc); 4720 } 4721 4722 /// BuildResolvedCallExpr - Build a call to a resolved expression, 4723 /// i.e. an expression not of \p OverloadTy. The expression should 4724 /// unary-convert to an expression of function-pointer or 4725 /// block-pointer type. 4726 /// 4727 /// \param NDecl the declaration being called, if available 4728 ExprResult 4729 Sema::BuildResolvedCallExpr(Expr *Fn, NamedDecl *NDecl, 4730 SourceLocation LParenLoc, 4731 ArrayRef<Expr *> Args, 4732 SourceLocation RParenLoc, 4733 Expr *Config, bool IsExecConfig) { 4734 FunctionDecl *FDecl = dyn_cast_or_null<FunctionDecl>(NDecl); 4735 unsigned BuiltinID = (FDecl ? FDecl->getBuiltinID() : 0); 4736 4737 // Promote the function operand. 4738 // We special-case function promotion here because we only allow promoting 4739 // builtin functions to function pointers in the callee of a call. 4740 ExprResult Result; 4741 if (BuiltinID && 4742 Fn->getType()->isSpecificBuiltinType(BuiltinType::BuiltinFn)) { 4743 Result = ImpCastExprToType(Fn, Context.getPointerType(FDecl->getType()), 4744 CK_BuiltinFnToFnPtr).get(); 4745 } else { 4746 Result = CallExprUnaryConversions(Fn); 4747 } 4748 if (Result.isInvalid()) 4749 return ExprError(); 4750 Fn = Result.get(); 4751 4752 // Make the call expr early, before semantic checks. This guarantees cleanup 4753 // of arguments and function on error. 4754 CallExpr *TheCall; 4755 if (Config) 4756 TheCall = new (Context) CUDAKernelCallExpr(Context, Fn, 4757 cast<CallExpr>(Config), Args, 4758 Context.BoolTy, VK_RValue, 4759 RParenLoc); 4760 else 4761 TheCall = new (Context) CallExpr(Context, Fn, Args, Context.BoolTy, 4762 VK_RValue, RParenLoc); 4763 4764 // Bail out early if calling a builtin with custom typechecking. 4765 if (BuiltinID && Context.BuiltinInfo.hasCustomTypechecking(BuiltinID)) { 4766 ExprResult Res = CorrectDelayedTyposInExpr(TheCall); 4767 if (!Res.isUsable() || !isa<CallExpr>(Res.get())) 4768 return Res; 4769 return CheckBuiltinFunctionCall(FDecl, BuiltinID, cast<CallExpr>(Res.get())); 4770 } 4771 4772 retry: 4773 const FunctionType *FuncT; 4774 if (const PointerType *PT = Fn->getType()->getAs<PointerType>()) { 4775 // C99 6.5.2.2p1 - "The expression that denotes the called function shall 4776 // have type pointer to function". 4777 FuncT = PT->getPointeeType()->getAs<FunctionType>(); 4778 if (!FuncT) 4779 return ExprError(Diag(LParenLoc, diag::err_typecheck_call_not_function) 4780 << Fn->getType() << Fn->getSourceRange()); 4781 } else if (const BlockPointerType *BPT = 4782 Fn->getType()->getAs<BlockPointerType>()) { 4783 FuncT = BPT->getPointeeType()->castAs<FunctionType>(); 4784 } else { 4785 // Handle calls to expressions of unknown-any type. 4786 if (Fn->getType() == Context.UnknownAnyTy) { 4787 ExprResult rewrite = rebuildUnknownAnyFunction(*this, Fn); 4788 if (rewrite.isInvalid()) return ExprError(); 4789 Fn = rewrite.get(); 4790 TheCall->setCallee(Fn); 4791 goto retry; 4792 } 4793 4794 return ExprError(Diag(LParenLoc, diag::err_typecheck_call_not_function) 4795 << Fn->getType() << Fn->getSourceRange()); 4796 } 4797 4798 if (getLangOpts().CUDA) { 4799 if (Config) { 4800 // CUDA: Kernel calls must be to global functions 4801 if (FDecl && !FDecl->hasAttr<CUDAGlobalAttr>()) 4802 return ExprError(Diag(LParenLoc,diag::err_kern_call_not_global_function) 4803 << FDecl->getName() << Fn->getSourceRange()); 4804 4805 // CUDA: Kernel function must have 'void' return type 4806 if (!FuncT->getReturnType()->isVoidType()) 4807 return ExprError(Diag(LParenLoc, diag::err_kern_type_not_void_return) 4808 << Fn->getType() << Fn->getSourceRange()); 4809 } else { 4810 // CUDA: Calls to global functions must be configured 4811 if (FDecl && FDecl->hasAttr<CUDAGlobalAttr>()) 4812 return ExprError(Diag(LParenLoc, diag::err_global_call_not_config) 4813 << FDecl->getName() << Fn->getSourceRange()); 4814 } 4815 } 4816 4817 // Check for a valid return type 4818 if (CheckCallReturnType(FuncT->getReturnType(), Fn->getLocStart(), TheCall, 4819 FDecl)) 4820 return ExprError(); 4821 4822 // We know the result type of the call, set it. 4823 TheCall->setType(FuncT->getCallResultType(Context)); 4824 TheCall->setValueKind(Expr::getValueKindForType(FuncT->getReturnType())); 4825 4826 const FunctionProtoType *Proto = dyn_cast<FunctionProtoType>(FuncT); 4827 if (Proto) { 4828 if (ConvertArgumentsForCall(TheCall, Fn, FDecl, Proto, Args, RParenLoc, 4829 IsExecConfig)) 4830 return ExprError(); 4831 } else { 4832 assert(isa<FunctionNoProtoType>(FuncT) && "Unknown FunctionType!"); 4833 4834 if (FDecl) { 4835 // Check if we have too few/too many template arguments, based 4836 // on our knowledge of the function definition. 4837 const FunctionDecl *Def = nullptr; 4838 if (FDecl->hasBody(Def) && Args.size() != Def->param_size()) { 4839 Proto = Def->getType()->getAs<FunctionProtoType>(); 4840 if (!Proto || !(Proto->isVariadic() && Args.size() >= Def->param_size())) 4841 Diag(RParenLoc, diag::warn_call_wrong_number_of_arguments) 4842 << (Args.size() > Def->param_size()) << FDecl << Fn->getSourceRange(); 4843 } 4844 4845 // If the function we're calling isn't a function prototype, but we have 4846 // a function prototype from a prior declaratiom, use that prototype. 4847 if (!FDecl->hasPrototype()) 4848 Proto = FDecl->getType()->getAs<FunctionProtoType>(); 4849 } 4850 4851 // Promote the arguments (C99 6.5.2.2p6). 4852 for (unsigned i = 0, e = Args.size(); i != e; i++) { 4853 Expr *Arg = Args[i]; 4854 4855 if (Proto && i < Proto->getNumParams()) { 4856 InitializedEntity Entity = InitializedEntity::InitializeParameter( 4857 Context, Proto->getParamType(i), Proto->isParamConsumed(i)); 4858 ExprResult ArgE = 4859 PerformCopyInitialization(Entity, SourceLocation(), Arg); 4860 if (ArgE.isInvalid()) 4861 return true; 4862 4863 Arg = ArgE.getAs<Expr>(); 4864 4865 } else { 4866 ExprResult ArgE = DefaultArgumentPromotion(Arg); 4867 4868 if (ArgE.isInvalid()) 4869 return true; 4870 4871 Arg = ArgE.getAs<Expr>(); 4872 } 4873 4874 if (RequireCompleteType(Arg->getLocStart(), 4875 Arg->getType(), 4876 diag::err_call_incomplete_argument, Arg)) 4877 return ExprError(); 4878 4879 TheCall->setArg(i, Arg); 4880 } 4881 } 4882 4883 if (CXXMethodDecl *Method = dyn_cast_or_null<CXXMethodDecl>(FDecl)) 4884 if (!Method->isStatic()) 4885 return ExprError(Diag(LParenLoc, diag::err_member_call_without_object) 4886 << Fn->getSourceRange()); 4887 4888 // Check for sentinels 4889 if (NDecl) 4890 DiagnoseSentinelCalls(NDecl, LParenLoc, Args); 4891 4892 // Do special checking on direct calls to functions. 4893 if (FDecl) { 4894 if (CheckFunctionCall(FDecl, TheCall, Proto)) 4895 return ExprError(); 4896 4897 if (BuiltinID) 4898 return CheckBuiltinFunctionCall(FDecl, BuiltinID, TheCall); 4899 } else if (NDecl) { 4900 if (CheckPointerCall(NDecl, TheCall, Proto)) 4901 return ExprError(); 4902 } else { 4903 if (CheckOtherCall(TheCall, Proto)) 4904 return ExprError(); 4905 } 4906 4907 return MaybeBindToTemporary(TheCall); 4908 } 4909 4910 ExprResult 4911 Sema::ActOnCompoundLiteral(SourceLocation LParenLoc, ParsedType Ty, 4912 SourceLocation RParenLoc, Expr *InitExpr) { 4913 assert(Ty && "ActOnCompoundLiteral(): missing type"); 4914 // FIXME: put back this assert when initializers are worked out. 4915 //assert((InitExpr != 0) && "ActOnCompoundLiteral(): missing expression"); 4916 4917 TypeSourceInfo *TInfo; 4918 QualType literalType = GetTypeFromParser(Ty, &TInfo); 4919 if (!TInfo) 4920 TInfo = Context.getTrivialTypeSourceInfo(literalType); 4921 4922 return BuildCompoundLiteralExpr(LParenLoc, TInfo, RParenLoc, InitExpr); 4923 } 4924 4925 ExprResult 4926 Sema::BuildCompoundLiteralExpr(SourceLocation LParenLoc, TypeSourceInfo *TInfo, 4927 SourceLocation RParenLoc, Expr *LiteralExpr) { 4928 QualType literalType = TInfo->getType(); 4929 4930 if (literalType->isArrayType()) { 4931 if (RequireCompleteType(LParenLoc, Context.getBaseElementType(literalType), 4932 diag::err_illegal_decl_array_incomplete_type, 4933 SourceRange(LParenLoc, 4934 LiteralExpr->getSourceRange().getEnd()))) 4935 return ExprError(); 4936 if (literalType->isVariableArrayType()) 4937 return ExprError(Diag(LParenLoc, diag::err_variable_object_no_init) 4938 << SourceRange(LParenLoc, LiteralExpr->getSourceRange().getEnd())); 4939 } else if (!literalType->isDependentType() && 4940 RequireCompleteType(LParenLoc, literalType, 4941 diag::err_typecheck_decl_incomplete_type, 4942 SourceRange(LParenLoc, LiteralExpr->getSourceRange().getEnd()))) 4943 return ExprError(); 4944 4945 InitializedEntity Entity 4946 = InitializedEntity::InitializeCompoundLiteralInit(TInfo); 4947 InitializationKind Kind 4948 = InitializationKind::CreateCStyleCast(LParenLoc, 4949 SourceRange(LParenLoc, RParenLoc), 4950 /*InitList=*/true); 4951 InitializationSequence InitSeq(*this, Entity, Kind, LiteralExpr); 4952 ExprResult Result = InitSeq.Perform(*this, Entity, Kind, LiteralExpr, 4953 &literalType); 4954 if (Result.isInvalid()) 4955 return ExprError(); 4956 LiteralExpr = Result.get(); 4957 4958 bool isFileScope = getCurFunctionOrMethodDecl() == nullptr; 4959 if (isFileScope && 4960 !LiteralExpr->isTypeDependent() && 4961 !LiteralExpr->isValueDependent() && 4962 !literalType->isDependentType()) { // 6.5.2.5p3 4963 if (CheckForConstantInitializer(LiteralExpr, literalType)) 4964 return ExprError(); 4965 } 4966 4967 // In C, compound literals are l-values for some reason. 4968 ExprValueKind VK = getLangOpts().CPlusPlus ? VK_RValue : VK_LValue; 4969 4970 return MaybeBindToTemporary( 4971 new (Context) CompoundLiteralExpr(LParenLoc, TInfo, literalType, 4972 VK, LiteralExpr, isFileScope)); 4973 } 4974 4975 ExprResult 4976 Sema::ActOnInitList(SourceLocation LBraceLoc, MultiExprArg InitArgList, 4977 SourceLocation RBraceLoc) { 4978 // Immediately handle non-overload placeholders. Overloads can be 4979 // resolved contextually, but everything else here can't. 4980 for (unsigned I = 0, E = InitArgList.size(); I != E; ++I) { 4981 if (InitArgList[I]->getType()->isNonOverloadPlaceholderType()) { 4982 ExprResult result = CheckPlaceholderExpr(InitArgList[I]); 4983 4984 // Ignore failures; dropping the entire initializer list because 4985 // of one failure would be terrible for indexing/etc. 4986 if (result.isInvalid()) continue; 4987 4988 InitArgList[I] = result.get(); 4989 } 4990 } 4991 4992 // Semantic analysis for initializers is done by ActOnDeclarator() and 4993 // CheckInitializer() - it requires knowledge of the object being intialized. 4994 4995 InitListExpr *E = new (Context) InitListExpr(Context, LBraceLoc, InitArgList, 4996 RBraceLoc); 4997 E->setType(Context.VoidTy); // FIXME: just a place holder for now. 4998 return E; 4999 } 5000 5001 /// Do an explicit extend of the given block pointer if we're in ARC. 5002 static void maybeExtendBlockObject(Sema &S, ExprResult &E) { 5003 assert(E.get()->getType()->isBlockPointerType()); 5004 assert(E.get()->isRValue()); 5005 5006 // Only do this in an r-value context. 5007 if (!S.getLangOpts().ObjCAutoRefCount) return; 5008 5009 E = ImplicitCastExpr::Create(S.Context, E.get()->getType(), 5010 CK_ARCExtendBlockObject, E.get(), 5011 /*base path*/ nullptr, VK_RValue); 5012 S.ExprNeedsCleanups = true; 5013 } 5014 5015 /// Prepare a conversion of the given expression to an ObjC object 5016 /// pointer type. 5017 CastKind Sema::PrepareCastToObjCObjectPointer(ExprResult &E) { 5018 QualType type = E.get()->getType(); 5019 if (type->isObjCObjectPointerType()) { 5020 return CK_BitCast; 5021 } else if (type->isBlockPointerType()) { 5022 maybeExtendBlockObject(*this, E); 5023 return CK_BlockPointerToObjCPointerCast; 5024 } else { 5025 assert(type->isPointerType()); 5026 return CK_CPointerToObjCPointerCast; 5027 } 5028 } 5029 5030 /// Prepares for a scalar cast, performing all the necessary stages 5031 /// except the final cast and returning the kind required. 5032 CastKind Sema::PrepareScalarCast(ExprResult &Src, QualType DestTy) { 5033 // Both Src and Dest are scalar types, i.e. arithmetic or pointer. 5034 // Also, callers should have filtered out the invalid cases with 5035 // pointers. Everything else should be possible. 5036 5037 QualType SrcTy = Src.get()->getType(); 5038 if (Context.hasSameUnqualifiedType(SrcTy, DestTy)) 5039 return CK_NoOp; 5040 5041 switch (Type::ScalarTypeKind SrcKind = SrcTy->getScalarTypeKind()) { 5042 case Type::STK_MemberPointer: 5043 llvm_unreachable("member pointer type in C"); 5044 5045 case Type::STK_CPointer: 5046 case Type::STK_BlockPointer: 5047 case Type::STK_ObjCObjectPointer: 5048 switch (DestTy->getScalarTypeKind()) { 5049 case Type::STK_CPointer: { 5050 unsigned SrcAS = SrcTy->getPointeeType().getAddressSpace(); 5051 unsigned DestAS = DestTy->getPointeeType().getAddressSpace(); 5052 if (SrcAS != DestAS) 5053 return CK_AddressSpaceConversion; 5054 return CK_BitCast; 5055 } 5056 case Type::STK_BlockPointer: 5057 return (SrcKind == Type::STK_BlockPointer 5058 ? CK_BitCast : CK_AnyPointerToBlockPointerCast); 5059 case Type::STK_ObjCObjectPointer: 5060 if (SrcKind == Type::STK_ObjCObjectPointer) 5061 return CK_BitCast; 5062 if (SrcKind == Type::STK_CPointer) 5063 return CK_CPointerToObjCPointerCast; 5064 maybeExtendBlockObject(*this, Src); 5065 return CK_BlockPointerToObjCPointerCast; 5066 case Type::STK_Bool: 5067 return CK_PointerToBoolean; 5068 case Type::STK_Integral: 5069 return CK_PointerToIntegral; 5070 case Type::STK_Floating: 5071 case Type::STK_FloatingComplex: 5072 case Type::STK_IntegralComplex: 5073 case Type::STK_MemberPointer: 5074 llvm_unreachable("illegal cast from pointer"); 5075 } 5076 llvm_unreachable("Should have returned before this"); 5077 5078 case Type::STK_Bool: // casting from bool is like casting from an integer 5079 case Type::STK_Integral: 5080 switch (DestTy->getScalarTypeKind()) { 5081 case Type::STK_CPointer: 5082 case Type::STK_ObjCObjectPointer: 5083 case Type::STK_BlockPointer: 5084 if (Src.get()->isNullPointerConstant(Context, 5085 Expr::NPC_ValueDependentIsNull)) 5086 return CK_NullToPointer; 5087 return CK_IntegralToPointer; 5088 case Type::STK_Bool: 5089 return CK_IntegralToBoolean; 5090 case Type::STK_Integral: 5091 return CK_IntegralCast; 5092 case Type::STK_Floating: 5093 return CK_IntegralToFloating; 5094 case Type::STK_IntegralComplex: 5095 Src = ImpCastExprToType(Src.get(), 5096 DestTy->castAs<ComplexType>()->getElementType(), 5097 CK_IntegralCast); 5098 return CK_IntegralRealToComplex; 5099 case Type::STK_FloatingComplex: 5100 Src = ImpCastExprToType(Src.get(), 5101 DestTy->castAs<ComplexType>()->getElementType(), 5102 CK_IntegralToFloating); 5103 return CK_FloatingRealToComplex; 5104 case Type::STK_MemberPointer: 5105 llvm_unreachable("member pointer type in C"); 5106 } 5107 llvm_unreachable("Should have returned before this"); 5108 5109 case Type::STK_Floating: 5110 switch (DestTy->getScalarTypeKind()) { 5111 case Type::STK_Floating: 5112 return CK_FloatingCast; 5113 case Type::STK_Bool: 5114 return CK_FloatingToBoolean; 5115 case Type::STK_Integral: 5116 return CK_FloatingToIntegral; 5117 case Type::STK_FloatingComplex: 5118 Src = ImpCastExprToType(Src.get(), 5119 DestTy->castAs<ComplexType>()->getElementType(), 5120 CK_FloatingCast); 5121 return CK_FloatingRealToComplex; 5122 case Type::STK_IntegralComplex: 5123 Src = ImpCastExprToType(Src.get(), 5124 DestTy->castAs<ComplexType>()->getElementType(), 5125 CK_FloatingToIntegral); 5126 return CK_IntegralRealToComplex; 5127 case Type::STK_CPointer: 5128 case Type::STK_ObjCObjectPointer: 5129 case Type::STK_BlockPointer: 5130 llvm_unreachable("valid float->pointer cast?"); 5131 case Type::STK_MemberPointer: 5132 llvm_unreachable("member pointer type in C"); 5133 } 5134 llvm_unreachable("Should have returned before this"); 5135 5136 case Type::STK_FloatingComplex: 5137 switch (DestTy->getScalarTypeKind()) { 5138 case Type::STK_FloatingComplex: 5139 return CK_FloatingComplexCast; 5140 case Type::STK_IntegralComplex: 5141 return CK_FloatingComplexToIntegralComplex; 5142 case Type::STK_Floating: { 5143 QualType ET = SrcTy->castAs<ComplexType>()->getElementType(); 5144 if (Context.hasSameType(ET, DestTy)) 5145 return CK_FloatingComplexToReal; 5146 Src = ImpCastExprToType(Src.get(), ET, CK_FloatingComplexToReal); 5147 return CK_FloatingCast; 5148 } 5149 case Type::STK_Bool: 5150 return CK_FloatingComplexToBoolean; 5151 case Type::STK_Integral: 5152 Src = ImpCastExprToType(Src.get(), 5153 SrcTy->castAs<ComplexType>()->getElementType(), 5154 CK_FloatingComplexToReal); 5155 return CK_FloatingToIntegral; 5156 case Type::STK_CPointer: 5157 case Type::STK_ObjCObjectPointer: 5158 case Type::STK_BlockPointer: 5159 llvm_unreachable("valid complex float->pointer cast?"); 5160 case Type::STK_MemberPointer: 5161 llvm_unreachable("member pointer type in C"); 5162 } 5163 llvm_unreachable("Should have returned before this"); 5164 5165 case Type::STK_IntegralComplex: 5166 switch (DestTy->getScalarTypeKind()) { 5167 case Type::STK_FloatingComplex: 5168 return CK_IntegralComplexToFloatingComplex; 5169 case Type::STK_IntegralComplex: 5170 return CK_IntegralComplexCast; 5171 case Type::STK_Integral: { 5172 QualType ET = SrcTy->castAs<ComplexType>()->getElementType(); 5173 if (Context.hasSameType(ET, DestTy)) 5174 return CK_IntegralComplexToReal; 5175 Src = ImpCastExprToType(Src.get(), ET, CK_IntegralComplexToReal); 5176 return CK_IntegralCast; 5177 } 5178 case Type::STK_Bool: 5179 return CK_IntegralComplexToBoolean; 5180 case Type::STK_Floating: 5181 Src = ImpCastExprToType(Src.get(), 5182 SrcTy->castAs<ComplexType>()->getElementType(), 5183 CK_IntegralComplexToReal); 5184 return CK_IntegralToFloating; 5185 case Type::STK_CPointer: 5186 case Type::STK_ObjCObjectPointer: 5187 case Type::STK_BlockPointer: 5188 llvm_unreachable("valid complex int->pointer cast?"); 5189 case Type::STK_MemberPointer: 5190 llvm_unreachable("member pointer type in C"); 5191 } 5192 llvm_unreachable("Should have returned before this"); 5193 } 5194 5195 llvm_unreachable("Unhandled scalar cast"); 5196 } 5197 5198 static bool breakDownVectorType(QualType type, uint64_t &len, 5199 QualType &eltType) { 5200 // Vectors are simple. 5201 if (const VectorType *vecType = type->getAs<VectorType>()) { 5202 len = vecType->getNumElements(); 5203 eltType = vecType->getElementType(); 5204 assert(eltType->isScalarType()); 5205 return true; 5206 } 5207 5208 // We allow lax conversion to and from non-vector types, but only if 5209 // they're real types (i.e. non-complex, non-pointer scalar types). 5210 if (!type->isRealType()) return false; 5211 5212 len = 1; 5213 eltType = type; 5214 return true; 5215 } 5216 5217 static bool VectorTypesMatch(Sema &S, QualType srcTy, QualType destTy) { 5218 uint64_t srcLen, destLen; 5219 QualType srcElt, destElt; 5220 if (!breakDownVectorType(srcTy, srcLen, srcElt)) return false; 5221 if (!breakDownVectorType(destTy, destLen, destElt)) return false; 5222 5223 // ASTContext::getTypeSize will return the size rounded up to a 5224 // power of 2, so instead of using that, we need to use the raw 5225 // element size multiplied by the element count. 5226 uint64_t srcEltSize = S.Context.getTypeSize(srcElt); 5227 uint64_t destEltSize = S.Context.getTypeSize(destElt); 5228 5229 return (srcLen * srcEltSize == destLen * destEltSize); 5230 } 5231 5232 /// Is this a legal conversion between two known vector types? 5233 bool Sema::isLaxVectorConversion(QualType srcTy, QualType destTy) { 5234 assert(destTy->isVectorType() || srcTy->isVectorType()); 5235 5236 if (!Context.getLangOpts().LaxVectorConversions) 5237 return false; 5238 return VectorTypesMatch(*this, srcTy, destTy); 5239 } 5240 5241 bool Sema::CheckVectorCast(SourceRange R, QualType VectorTy, QualType Ty, 5242 CastKind &Kind) { 5243 assert(VectorTy->isVectorType() && "Not a vector type!"); 5244 5245 if (Ty->isVectorType() || Ty->isIntegerType()) { 5246 if (!VectorTypesMatch(*this, Ty, VectorTy)) 5247 return Diag(R.getBegin(), 5248 Ty->isVectorType() ? 5249 diag::err_invalid_conversion_between_vectors : 5250 diag::err_invalid_conversion_between_vector_and_integer) 5251 << VectorTy << Ty << R; 5252 } else 5253 return Diag(R.getBegin(), 5254 diag::err_invalid_conversion_between_vector_and_scalar) 5255 << VectorTy << Ty << R; 5256 5257 Kind = CK_BitCast; 5258 return false; 5259 } 5260 5261 ExprResult Sema::CheckExtVectorCast(SourceRange R, QualType DestTy, 5262 Expr *CastExpr, CastKind &Kind) { 5263 assert(DestTy->isExtVectorType() && "Not an extended vector type!"); 5264 5265 QualType SrcTy = CastExpr->getType(); 5266 5267 // If SrcTy is a VectorType, the total size must match to explicitly cast to 5268 // an ExtVectorType. 5269 // In OpenCL, casts between vectors of different types are not allowed. 5270 // (See OpenCL 6.2). 5271 if (SrcTy->isVectorType()) { 5272 if (!VectorTypesMatch(*this, SrcTy, DestTy) 5273 || (getLangOpts().OpenCL && 5274 (DestTy.getCanonicalType() != SrcTy.getCanonicalType()))) { 5275 Diag(R.getBegin(),diag::err_invalid_conversion_between_ext_vectors) 5276 << DestTy << SrcTy << R; 5277 return ExprError(); 5278 } 5279 Kind = CK_BitCast; 5280 return CastExpr; 5281 } 5282 5283 // All non-pointer scalars can be cast to ExtVector type. The appropriate 5284 // conversion will take place first from scalar to elt type, and then 5285 // splat from elt type to vector. 5286 if (SrcTy->isPointerType()) 5287 return Diag(R.getBegin(), 5288 diag::err_invalid_conversion_between_vector_and_scalar) 5289 << DestTy << SrcTy << R; 5290 5291 QualType DestElemTy = DestTy->getAs<ExtVectorType>()->getElementType(); 5292 ExprResult CastExprRes = CastExpr; 5293 CastKind CK = PrepareScalarCast(CastExprRes, DestElemTy); 5294 if (CastExprRes.isInvalid()) 5295 return ExprError(); 5296 CastExpr = ImpCastExprToType(CastExprRes.get(), DestElemTy, CK).get(); 5297 5298 Kind = CK_VectorSplat; 5299 return CastExpr; 5300 } 5301 5302 ExprResult 5303 Sema::ActOnCastExpr(Scope *S, SourceLocation LParenLoc, 5304 Declarator &D, ParsedType &Ty, 5305 SourceLocation RParenLoc, Expr *CastExpr) { 5306 assert(!D.isInvalidType() && (CastExpr != nullptr) && 5307 "ActOnCastExpr(): missing type or expr"); 5308 5309 TypeSourceInfo *castTInfo = GetTypeForDeclaratorCast(D, CastExpr->getType()); 5310 if (D.isInvalidType()) 5311 return ExprError(); 5312 5313 if (getLangOpts().CPlusPlus) { 5314 // Check that there are no default arguments (C++ only). 5315 CheckExtraCXXDefaultArguments(D); 5316 } else { 5317 // Make sure any TypoExprs have been dealt with. 5318 ExprResult Res = CorrectDelayedTyposInExpr(CastExpr); 5319 if (!Res.isUsable()) 5320 return ExprError(); 5321 CastExpr = Res.get(); 5322 } 5323 5324 checkUnusedDeclAttributes(D); 5325 5326 QualType castType = castTInfo->getType(); 5327 Ty = CreateParsedType(castType, castTInfo); 5328 5329 bool isVectorLiteral = false; 5330 5331 // Check for an altivec or OpenCL literal, 5332 // i.e. all the elements are integer constants. 5333 ParenExpr *PE = dyn_cast<ParenExpr>(CastExpr); 5334 ParenListExpr *PLE = dyn_cast<ParenListExpr>(CastExpr); 5335 if ((getLangOpts().AltiVec || getLangOpts().OpenCL) 5336 && castType->isVectorType() && (PE || PLE)) { 5337 if (PLE && PLE->getNumExprs() == 0) { 5338 Diag(PLE->getExprLoc(), diag::err_altivec_empty_initializer); 5339 return ExprError(); 5340 } 5341 if (PE || PLE->getNumExprs() == 1) { 5342 Expr *E = (PE ? PE->getSubExpr() : PLE->getExpr(0)); 5343 if (!E->getType()->isVectorType()) 5344 isVectorLiteral = true; 5345 } 5346 else 5347 isVectorLiteral = true; 5348 } 5349 5350 // If this is a vector initializer, '(' type ')' '(' init, ..., init ')' 5351 // then handle it as such. 5352 if (isVectorLiteral) 5353 return BuildVectorLiteral(LParenLoc, RParenLoc, CastExpr, castTInfo); 5354 5355 // If the Expr being casted is a ParenListExpr, handle it specially. 5356 // This is not an AltiVec-style cast, so turn the ParenListExpr into a 5357 // sequence of BinOp comma operators. 5358 if (isa<ParenListExpr>(CastExpr)) { 5359 ExprResult Result = MaybeConvertParenListExprToParenExpr(S, CastExpr); 5360 if (Result.isInvalid()) return ExprError(); 5361 CastExpr = Result.get(); 5362 } 5363 5364 if (getLangOpts().CPlusPlus && !castType->isVoidType() && 5365 !getSourceManager().isInSystemMacro(LParenLoc)) 5366 Diag(LParenLoc, diag::warn_old_style_cast) << CastExpr->getSourceRange(); 5367 5368 CheckTollFreeBridgeCast(castType, CastExpr); 5369 5370 CheckObjCBridgeRelatedCast(castType, CastExpr); 5371 5372 return BuildCStyleCastExpr(LParenLoc, castTInfo, RParenLoc, CastExpr); 5373 } 5374 5375 ExprResult Sema::BuildVectorLiteral(SourceLocation LParenLoc, 5376 SourceLocation RParenLoc, Expr *E, 5377 TypeSourceInfo *TInfo) { 5378 assert((isa<ParenListExpr>(E) || isa<ParenExpr>(E)) && 5379 "Expected paren or paren list expression"); 5380 5381 Expr **exprs; 5382 unsigned numExprs; 5383 Expr *subExpr; 5384 SourceLocation LiteralLParenLoc, LiteralRParenLoc; 5385 if (ParenListExpr *PE = dyn_cast<ParenListExpr>(E)) { 5386 LiteralLParenLoc = PE->getLParenLoc(); 5387 LiteralRParenLoc = PE->getRParenLoc(); 5388 exprs = PE->getExprs(); 5389 numExprs = PE->getNumExprs(); 5390 } else { // isa<ParenExpr> by assertion at function entrance 5391 LiteralLParenLoc = cast<ParenExpr>(E)->getLParen(); 5392 LiteralRParenLoc = cast<ParenExpr>(E)->getRParen(); 5393 subExpr = cast<ParenExpr>(E)->getSubExpr(); 5394 exprs = &subExpr; 5395 numExprs = 1; 5396 } 5397 5398 QualType Ty = TInfo->getType(); 5399 assert(Ty->isVectorType() && "Expected vector type"); 5400 5401 SmallVector<Expr *, 8> initExprs; 5402 const VectorType *VTy = Ty->getAs<VectorType>(); 5403 unsigned numElems = Ty->getAs<VectorType>()->getNumElements(); 5404 5405 // '(...)' form of vector initialization in AltiVec: the number of 5406 // initializers must be one or must match the size of the vector. 5407 // If a single value is specified in the initializer then it will be 5408 // replicated to all the components of the vector 5409 if (VTy->getVectorKind() == VectorType::AltiVecVector) { 5410 // The number of initializers must be one or must match the size of the 5411 // vector. If a single value is specified in the initializer then it will 5412 // be replicated to all the components of the vector 5413 if (numExprs == 1) { 5414 QualType ElemTy = Ty->getAs<VectorType>()->getElementType(); 5415 ExprResult Literal = DefaultLvalueConversion(exprs[0]); 5416 if (Literal.isInvalid()) 5417 return ExprError(); 5418 Literal = ImpCastExprToType(Literal.get(), ElemTy, 5419 PrepareScalarCast(Literal, ElemTy)); 5420 return BuildCStyleCastExpr(LParenLoc, TInfo, RParenLoc, Literal.get()); 5421 } 5422 else if (numExprs < numElems) { 5423 Diag(E->getExprLoc(), 5424 diag::err_incorrect_number_of_vector_initializers); 5425 return ExprError(); 5426 } 5427 else 5428 initExprs.append(exprs, exprs + numExprs); 5429 } 5430 else { 5431 // For OpenCL, when the number of initializers is a single value, 5432 // it will be replicated to all components of the vector. 5433 if (getLangOpts().OpenCL && 5434 VTy->getVectorKind() == VectorType::GenericVector && 5435 numExprs == 1) { 5436 QualType ElemTy = Ty->getAs<VectorType>()->getElementType(); 5437 ExprResult Literal = DefaultLvalueConversion(exprs[0]); 5438 if (Literal.isInvalid()) 5439 return ExprError(); 5440 Literal = ImpCastExprToType(Literal.get(), ElemTy, 5441 PrepareScalarCast(Literal, ElemTy)); 5442 return BuildCStyleCastExpr(LParenLoc, TInfo, RParenLoc, Literal.get()); 5443 } 5444 5445 initExprs.append(exprs, exprs + numExprs); 5446 } 5447 // FIXME: This means that pretty-printing the final AST will produce curly 5448 // braces instead of the original commas. 5449 InitListExpr *initE = new (Context) InitListExpr(Context, LiteralLParenLoc, 5450 initExprs, LiteralRParenLoc); 5451 initE->setType(Ty); 5452 return BuildCompoundLiteralExpr(LParenLoc, TInfo, RParenLoc, initE); 5453 } 5454 5455 /// This is not an AltiVec-style cast or or C++ direct-initialization, so turn 5456 /// the ParenListExpr into a sequence of comma binary operators. 5457 ExprResult 5458 Sema::MaybeConvertParenListExprToParenExpr(Scope *S, Expr *OrigExpr) { 5459 ParenListExpr *E = dyn_cast<ParenListExpr>(OrigExpr); 5460 if (!E) 5461 return OrigExpr; 5462 5463 ExprResult Result(E->getExpr(0)); 5464 5465 for (unsigned i = 1, e = E->getNumExprs(); i != e && !Result.isInvalid(); ++i) 5466 Result = ActOnBinOp(S, E->getExprLoc(), tok::comma, Result.get(), 5467 E->getExpr(i)); 5468 5469 if (Result.isInvalid()) return ExprError(); 5470 5471 return ActOnParenExpr(E->getLParenLoc(), E->getRParenLoc(), Result.get()); 5472 } 5473 5474 ExprResult Sema::ActOnParenListExpr(SourceLocation L, 5475 SourceLocation R, 5476 MultiExprArg Val) { 5477 Expr *expr = new (Context) ParenListExpr(Context, L, Val, R); 5478 return expr; 5479 } 5480 5481 /// \brief Emit a specialized diagnostic when one expression is a null pointer 5482 /// constant and the other is not a pointer. Returns true if a diagnostic is 5483 /// emitted. 5484 bool Sema::DiagnoseConditionalForNull(Expr *LHSExpr, Expr *RHSExpr, 5485 SourceLocation QuestionLoc) { 5486 Expr *NullExpr = LHSExpr; 5487 Expr *NonPointerExpr = RHSExpr; 5488 Expr::NullPointerConstantKind NullKind = 5489 NullExpr->isNullPointerConstant(Context, 5490 Expr::NPC_ValueDependentIsNotNull); 5491 5492 if (NullKind == Expr::NPCK_NotNull) { 5493 NullExpr = RHSExpr; 5494 NonPointerExpr = LHSExpr; 5495 NullKind = 5496 NullExpr->isNullPointerConstant(Context, 5497 Expr::NPC_ValueDependentIsNotNull); 5498 } 5499 5500 if (NullKind == Expr::NPCK_NotNull) 5501 return false; 5502 5503 if (NullKind == Expr::NPCK_ZeroExpression) 5504 return false; 5505 5506 if (NullKind == Expr::NPCK_ZeroLiteral) { 5507 // In this case, check to make sure that we got here from a "NULL" 5508 // string in the source code. 5509 NullExpr = NullExpr->IgnoreParenImpCasts(); 5510 SourceLocation loc = NullExpr->getExprLoc(); 5511 if (!findMacroSpelling(loc, "NULL")) 5512 return false; 5513 } 5514 5515 int DiagType = (NullKind == Expr::NPCK_CXX11_nullptr); 5516 Diag(QuestionLoc, diag::err_typecheck_cond_incompatible_operands_null) 5517 << NonPointerExpr->getType() << DiagType 5518 << NonPointerExpr->getSourceRange(); 5519 return true; 5520 } 5521 5522 /// \brief Return false if the condition expression is valid, true otherwise. 5523 static bool checkCondition(Sema &S, Expr *Cond) { 5524 QualType CondTy = Cond->getType(); 5525 5526 // C99 6.5.15p2 5527 if (CondTy->isScalarType()) return false; 5528 5529 // OpenCL v1.1 s6.3.i says the condition is allowed to be a vector or scalar. 5530 if (S.getLangOpts().OpenCL && CondTy->isVectorType()) 5531 return false; 5532 5533 // Emit the proper error message. 5534 S.Diag(Cond->getLocStart(), S.getLangOpts().OpenCL ? 5535 diag::err_typecheck_cond_expect_scalar : 5536 diag::err_typecheck_cond_expect_scalar_or_vector) 5537 << CondTy; 5538 return true; 5539 } 5540 5541 /// \brief Return false if the two expressions can be converted to a vector, 5542 /// true otherwise 5543 static bool checkConditionalConvertScalarsToVectors(Sema &S, ExprResult &LHS, 5544 ExprResult &RHS, 5545 QualType CondTy) { 5546 // Both operands should be of scalar type. 5547 if (!LHS.get()->getType()->isScalarType()) { 5548 S.Diag(LHS.get()->getLocStart(), diag::err_typecheck_cond_expect_scalar) 5549 << CondTy; 5550 return true; 5551 } 5552 if (!RHS.get()->getType()->isScalarType()) { 5553 S.Diag(RHS.get()->getLocStart(), diag::err_typecheck_cond_expect_scalar) 5554 << CondTy; 5555 return true; 5556 } 5557 5558 // Implicity convert these scalars to the type of the condition. 5559 LHS = S.ImpCastExprToType(LHS.get(), CondTy, CK_IntegralCast); 5560 RHS = S.ImpCastExprToType(RHS.get(), CondTy, CK_IntegralCast); 5561 return false; 5562 } 5563 5564 /// \brief Handle when one or both operands are void type. 5565 static QualType checkConditionalVoidType(Sema &S, ExprResult &LHS, 5566 ExprResult &RHS) { 5567 Expr *LHSExpr = LHS.get(); 5568 Expr *RHSExpr = RHS.get(); 5569 5570 if (!LHSExpr->getType()->isVoidType()) 5571 S.Diag(RHSExpr->getLocStart(), diag::ext_typecheck_cond_one_void) 5572 << RHSExpr->getSourceRange(); 5573 if (!RHSExpr->getType()->isVoidType()) 5574 S.Diag(LHSExpr->getLocStart(), diag::ext_typecheck_cond_one_void) 5575 << LHSExpr->getSourceRange(); 5576 LHS = S.ImpCastExprToType(LHS.get(), S.Context.VoidTy, CK_ToVoid); 5577 RHS = S.ImpCastExprToType(RHS.get(), S.Context.VoidTy, CK_ToVoid); 5578 return S.Context.VoidTy; 5579 } 5580 5581 /// \brief Return false if the NullExpr can be promoted to PointerTy, 5582 /// true otherwise. 5583 static bool checkConditionalNullPointer(Sema &S, ExprResult &NullExpr, 5584 QualType PointerTy) { 5585 if ((!PointerTy->isAnyPointerType() && !PointerTy->isBlockPointerType()) || 5586 !NullExpr.get()->isNullPointerConstant(S.Context, 5587 Expr::NPC_ValueDependentIsNull)) 5588 return true; 5589 5590 NullExpr = S.ImpCastExprToType(NullExpr.get(), PointerTy, CK_NullToPointer); 5591 return false; 5592 } 5593 5594 /// \brief Checks compatibility between two pointers and return the resulting 5595 /// type. 5596 static QualType checkConditionalPointerCompatibility(Sema &S, ExprResult &LHS, 5597 ExprResult &RHS, 5598 SourceLocation Loc) { 5599 QualType LHSTy = LHS.get()->getType(); 5600 QualType RHSTy = RHS.get()->getType(); 5601 5602 if (S.Context.hasSameType(LHSTy, RHSTy)) { 5603 // Two identical pointers types are always compatible. 5604 return LHSTy; 5605 } 5606 5607 QualType lhptee, rhptee; 5608 5609 // Get the pointee types. 5610 bool IsBlockPointer = false; 5611 if (const BlockPointerType *LHSBTy = LHSTy->getAs<BlockPointerType>()) { 5612 lhptee = LHSBTy->getPointeeType(); 5613 rhptee = RHSTy->castAs<BlockPointerType>()->getPointeeType(); 5614 IsBlockPointer = true; 5615 } else { 5616 lhptee = LHSTy->castAs<PointerType>()->getPointeeType(); 5617 rhptee = RHSTy->castAs<PointerType>()->getPointeeType(); 5618 } 5619 5620 // C99 6.5.15p6: If both operands are pointers to compatible types or to 5621 // differently qualified versions of compatible types, the result type is 5622 // a pointer to an appropriately qualified version of the composite 5623 // type. 5624 5625 // Only CVR-qualifiers exist in the standard, and the differently-qualified 5626 // clause doesn't make sense for our extensions. E.g. address space 2 should 5627 // be incompatible with address space 3: they may live on different devices or 5628 // anything. 5629 Qualifiers lhQual = lhptee.getQualifiers(); 5630 Qualifiers rhQual = rhptee.getQualifiers(); 5631 5632 unsigned MergedCVRQual = lhQual.getCVRQualifiers() | rhQual.getCVRQualifiers(); 5633 lhQual.removeCVRQualifiers(); 5634 rhQual.removeCVRQualifiers(); 5635 5636 lhptee = S.Context.getQualifiedType(lhptee.getUnqualifiedType(), lhQual); 5637 rhptee = S.Context.getQualifiedType(rhptee.getUnqualifiedType(), rhQual); 5638 5639 QualType CompositeTy = S.Context.mergeTypes(lhptee, rhptee); 5640 5641 if (CompositeTy.isNull()) { 5642 S.Diag(Loc, diag::ext_typecheck_cond_incompatible_pointers) 5643 << LHSTy << RHSTy << LHS.get()->getSourceRange() 5644 << RHS.get()->getSourceRange(); 5645 // In this situation, we assume void* type. No especially good 5646 // reason, but this is what gcc does, and we do have to pick 5647 // to get a consistent AST. 5648 QualType incompatTy = S.Context.getPointerType(S.Context.VoidTy); 5649 LHS = S.ImpCastExprToType(LHS.get(), incompatTy, CK_BitCast); 5650 RHS = S.ImpCastExprToType(RHS.get(), incompatTy, CK_BitCast); 5651 return incompatTy; 5652 } 5653 5654 // The pointer types are compatible. 5655 QualType ResultTy = CompositeTy.withCVRQualifiers(MergedCVRQual); 5656 if (IsBlockPointer) 5657 ResultTy = S.Context.getBlockPointerType(ResultTy); 5658 else 5659 ResultTy = S.Context.getPointerType(ResultTy); 5660 5661 LHS = S.ImpCastExprToType(LHS.get(), ResultTy, CK_BitCast); 5662 RHS = S.ImpCastExprToType(RHS.get(), ResultTy, CK_BitCast); 5663 return ResultTy; 5664 } 5665 5666 /// \brief Returns true if QT is quelified-id and implements 'NSObject' and/or 5667 /// 'NSCopying' protocols (and nothing else); or QT is an NSObject and optionally 5668 /// implements 'NSObject' and/or NSCopying' protocols (and nothing else). 5669 static bool isObjCPtrBlockCompatible(Sema &S, ASTContext &C, QualType QT) { 5670 if (QT->isObjCIdType()) 5671 return true; 5672 5673 const ObjCObjectPointerType *OPT = QT->getAs<ObjCObjectPointerType>(); 5674 if (!OPT) 5675 return false; 5676 5677 if (ObjCInterfaceDecl *ID = OPT->getInterfaceDecl()) 5678 if (ID->getIdentifier() != &C.Idents.get("NSObject")) 5679 return false; 5680 5681 ObjCProtocolDecl* PNSCopying = 5682 S.LookupProtocol(&C.Idents.get("NSCopying"), SourceLocation()); 5683 ObjCProtocolDecl* PNSObject = 5684 S.LookupProtocol(&C.Idents.get("NSObject"), SourceLocation()); 5685 5686 for (auto *Proto : OPT->quals()) { 5687 if ((PNSCopying && declaresSameEntity(Proto, PNSCopying)) || 5688 (PNSObject && declaresSameEntity(Proto, PNSObject))) 5689 ; 5690 else 5691 return false; 5692 } 5693 return true; 5694 } 5695 5696 /// \brief Return the resulting type when the operands are both block pointers. 5697 static QualType checkConditionalBlockPointerCompatibility(Sema &S, 5698 ExprResult &LHS, 5699 ExprResult &RHS, 5700 SourceLocation Loc) { 5701 QualType LHSTy = LHS.get()->getType(); 5702 QualType RHSTy = RHS.get()->getType(); 5703 5704 if (!LHSTy->isBlockPointerType() || !RHSTy->isBlockPointerType()) { 5705 if (LHSTy->isVoidPointerType() || RHSTy->isVoidPointerType()) { 5706 QualType destType = S.Context.getPointerType(S.Context.VoidTy); 5707 LHS = S.ImpCastExprToType(LHS.get(), destType, CK_BitCast); 5708 RHS = S.ImpCastExprToType(RHS.get(), destType, CK_BitCast); 5709 return destType; 5710 } 5711 S.Diag(Loc, diag::err_typecheck_cond_incompatible_operands) 5712 << LHSTy << RHSTy << LHS.get()->getSourceRange() 5713 << RHS.get()->getSourceRange(); 5714 return QualType(); 5715 } 5716 5717 // We have 2 block pointer types. 5718 return checkConditionalPointerCompatibility(S, LHS, RHS, Loc); 5719 } 5720 5721 /// \brief Return the resulting type when the operands are both pointers. 5722 static QualType 5723 checkConditionalObjectPointersCompatibility(Sema &S, ExprResult &LHS, 5724 ExprResult &RHS, 5725 SourceLocation Loc) { 5726 // get the pointer types 5727 QualType LHSTy = LHS.get()->getType(); 5728 QualType RHSTy = RHS.get()->getType(); 5729 5730 // get the "pointed to" types 5731 QualType lhptee = LHSTy->getAs<PointerType>()->getPointeeType(); 5732 QualType rhptee = RHSTy->getAs<PointerType>()->getPointeeType(); 5733 5734 // ignore qualifiers on void (C99 6.5.15p3, clause 6) 5735 if (lhptee->isVoidType() && rhptee->isIncompleteOrObjectType()) { 5736 // Figure out necessary qualifiers (C99 6.5.15p6) 5737 QualType destPointee 5738 = S.Context.getQualifiedType(lhptee, rhptee.getQualifiers()); 5739 QualType destType = S.Context.getPointerType(destPointee); 5740 // Add qualifiers if necessary. 5741 LHS = S.ImpCastExprToType(LHS.get(), destType, CK_NoOp); 5742 // Promote to void*. 5743 RHS = S.ImpCastExprToType(RHS.get(), destType, CK_BitCast); 5744 return destType; 5745 } 5746 if (rhptee->isVoidType() && lhptee->isIncompleteOrObjectType()) { 5747 QualType destPointee 5748 = S.Context.getQualifiedType(rhptee, lhptee.getQualifiers()); 5749 QualType destType = S.Context.getPointerType(destPointee); 5750 // Add qualifiers if necessary. 5751 RHS = S.ImpCastExprToType(RHS.get(), destType, CK_NoOp); 5752 // Promote to void*. 5753 LHS = S.ImpCastExprToType(LHS.get(), destType, CK_BitCast); 5754 return destType; 5755 } 5756 5757 return checkConditionalPointerCompatibility(S, LHS, RHS, Loc); 5758 } 5759 5760 /// \brief Return false if the first expression is not an integer and the second 5761 /// expression is not a pointer, true otherwise. 5762 static bool checkPointerIntegerMismatch(Sema &S, ExprResult &Int, 5763 Expr* PointerExpr, SourceLocation Loc, 5764 bool IsIntFirstExpr) { 5765 if (!PointerExpr->getType()->isPointerType() || 5766 !Int.get()->getType()->isIntegerType()) 5767 return false; 5768 5769 Expr *Expr1 = IsIntFirstExpr ? Int.get() : PointerExpr; 5770 Expr *Expr2 = IsIntFirstExpr ? PointerExpr : Int.get(); 5771 5772 S.Diag(Loc, diag::ext_typecheck_cond_pointer_integer_mismatch) 5773 << Expr1->getType() << Expr2->getType() 5774 << Expr1->getSourceRange() << Expr2->getSourceRange(); 5775 Int = S.ImpCastExprToType(Int.get(), PointerExpr->getType(), 5776 CK_IntegralToPointer); 5777 return true; 5778 } 5779 5780 /// Note that LHS is not null here, even if this is the gnu "x ?: y" extension. 5781 /// In that case, LHS = cond. 5782 /// C99 6.5.15 5783 QualType Sema::CheckConditionalOperands(ExprResult &Cond, ExprResult &LHS, 5784 ExprResult &RHS, ExprValueKind &VK, 5785 ExprObjectKind &OK, 5786 SourceLocation QuestionLoc) { 5787 5788 if (!getLangOpts().CPlusPlus) { 5789 // C cannot handle TypoExpr nodes on either side of a binop because it 5790 // doesn't handle dependent types properly, so make sure any TypoExprs have 5791 // been dealt with before checking the operands. 5792 ExprResult CondResult = CorrectDelayedTyposInExpr(Cond); 5793 if (!CondResult.isUsable()) return QualType(); 5794 Cond = CondResult; 5795 } 5796 5797 ExprResult LHSResult = CheckPlaceholderExpr(LHS.get()); 5798 if (!LHSResult.isUsable()) return QualType(); 5799 LHS = LHSResult; 5800 5801 ExprResult RHSResult = CheckPlaceholderExpr(RHS.get()); 5802 if (!RHSResult.isUsable()) return QualType(); 5803 RHS = RHSResult; 5804 5805 // C++ is sufficiently different to merit its own checker. 5806 if (getLangOpts().CPlusPlus) 5807 return CXXCheckConditionalOperands(Cond, LHS, RHS, VK, OK, QuestionLoc); 5808 5809 VK = VK_RValue; 5810 OK = OK_Ordinary; 5811 5812 // First, check the condition. 5813 Cond = UsualUnaryConversions(Cond.get()); 5814 if (Cond.isInvalid()) 5815 return QualType(); 5816 if (checkCondition(*this, Cond.get())) 5817 return QualType(); 5818 5819 // Now check the two expressions. 5820 if (LHS.get()->getType()->isVectorType() || 5821 RHS.get()->getType()->isVectorType()) 5822 return CheckVectorOperands(LHS, RHS, QuestionLoc, /*isCompAssign*/false); 5823 5824 QualType ResTy = UsualArithmeticConversions(LHS, RHS); 5825 if (LHS.isInvalid() || RHS.isInvalid()) 5826 return QualType(); 5827 5828 QualType CondTy = Cond.get()->getType(); 5829 QualType LHSTy = LHS.get()->getType(); 5830 QualType RHSTy = RHS.get()->getType(); 5831 5832 // If the condition is a vector, and both operands are scalar, 5833 // attempt to implicity convert them to the vector type to act like the 5834 // built in select. (OpenCL v1.1 s6.3.i) 5835 if (getLangOpts().OpenCL && CondTy->isVectorType()) 5836 if (checkConditionalConvertScalarsToVectors(*this, LHS, RHS, CondTy)) 5837 return QualType(); 5838 5839 // If both operands have arithmetic type, do the usual arithmetic conversions 5840 // to find a common type: C99 6.5.15p3,5. 5841 if (LHSTy->isArithmeticType() && RHSTy->isArithmeticType()) { 5842 LHS = ImpCastExprToType(LHS.get(), ResTy, PrepareScalarCast(LHS, ResTy)); 5843 RHS = ImpCastExprToType(RHS.get(), ResTy, PrepareScalarCast(RHS, ResTy)); 5844 5845 return ResTy; 5846 } 5847 5848 // If both operands are the same structure or union type, the result is that 5849 // type. 5850 if (const RecordType *LHSRT = LHSTy->getAs<RecordType>()) { // C99 6.5.15p3 5851 if (const RecordType *RHSRT = RHSTy->getAs<RecordType>()) 5852 if (LHSRT->getDecl() == RHSRT->getDecl()) 5853 // "If both the operands have structure or union type, the result has 5854 // that type." This implies that CV qualifiers are dropped. 5855 return LHSTy.getUnqualifiedType(); 5856 // FIXME: Type of conditional expression must be complete in C mode. 5857 } 5858 5859 // C99 6.5.15p5: "If both operands have void type, the result has void type." 5860 // The following || allows only one side to be void (a GCC-ism). 5861 if (LHSTy->isVoidType() || RHSTy->isVoidType()) { 5862 return checkConditionalVoidType(*this, LHS, RHS); 5863 } 5864 5865 // C99 6.5.15p6 - "if one operand is a null pointer constant, the result has 5866 // the type of the other operand." 5867 if (!checkConditionalNullPointer(*this, RHS, LHSTy)) return LHSTy; 5868 if (!checkConditionalNullPointer(*this, LHS, RHSTy)) return RHSTy; 5869 5870 // All objective-c pointer type analysis is done here. 5871 QualType compositeType = FindCompositeObjCPointerType(LHS, RHS, 5872 QuestionLoc); 5873 if (LHS.isInvalid() || RHS.isInvalid()) 5874 return QualType(); 5875 if (!compositeType.isNull()) 5876 return compositeType; 5877 5878 5879 // Handle block pointer types. 5880 if (LHSTy->isBlockPointerType() || RHSTy->isBlockPointerType()) 5881 return checkConditionalBlockPointerCompatibility(*this, LHS, RHS, 5882 QuestionLoc); 5883 5884 // Check constraints for C object pointers types (C99 6.5.15p3,6). 5885 if (LHSTy->isPointerType() && RHSTy->isPointerType()) 5886 return checkConditionalObjectPointersCompatibility(*this, LHS, RHS, 5887 QuestionLoc); 5888 5889 // GCC compatibility: soften pointer/integer mismatch. Note that 5890 // null pointers have been filtered out by this point. 5891 if (checkPointerIntegerMismatch(*this, LHS, RHS.get(), QuestionLoc, 5892 /*isIntFirstExpr=*/true)) 5893 return RHSTy; 5894 if (checkPointerIntegerMismatch(*this, RHS, LHS.get(), QuestionLoc, 5895 /*isIntFirstExpr=*/false)) 5896 return LHSTy; 5897 5898 // Emit a better diagnostic if one of the expressions is a null pointer 5899 // constant and the other is not a pointer type. In this case, the user most 5900 // likely forgot to take the address of the other expression. 5901 if (DiagnoseConditionalForNull(LHS.get(), RHS.get(), QuestionLoc)) 5902 return QualType(); 5903 5904 // Otherwise, the operands are not compatible. 5905 Diag(QuestionLoc, diag::err_typecheck_cond_incompatible_operands) 5906 << LHSTy << RHSTy << LHS.get()->getSourceRange() 5907 << RHS.get()->getSourceRange(); 5908 return QualType(); 5909 } 5910 5911 /// FindCompositeObjCPointerType - Helper method to find composite type of 5912 /// two objective-c pointer types of the two input expressions. 5913 QualType Sema::FindCompositeObjCPointerType(ExprResult &LHS, ExprResult &RHS, 5914 SourceLocation QuestionLoc) { 5915 QualType LHSTy = LHS.get()->getType(); 5916 QualType RHSTy = RHS.get()->getType(); 5917 5918 // Handle things like Class and struct objc_class*. Here we case the result 5919 // to the pseudo-builtin, because that will be implicitly cast back to the 5920 // redefinition type if an attempt is made to access its fields. 5921 if (LHSTy->isObjCClassType() && 5922 (Context.hasSameType(RHSTy, Context.getObjCClassRedefinitionType()))) { 5923 RHS = ImpCastExprToType(RHS.get(), LHSTy, CK_CPointerToObjCPointerCast); 5924 return LHSTy; 5925 } 5926 if (RHSTy->isObjCClassType() && 5927 (Context.hasSameType(LHSTy, Context.getObjCClassRedefinitionType()))) { 5928 LHS = ImpCastExprToType(LHS.get(), RHSTy, CK_CPointerToObjCPointerCast); 5929 return RHSTy; 5930 } 5931 // And the same for struct objc_object* / id 5932 if (LHSTy->isObjCIdType() && 5933 (Context.hasSameType(RHSTy, Context.getObjCIdRedefinitionType()))) { 5934 RHS = ImpCastExprToType(RHS.get(), LHSTy, CK_CPointerToObjCPointerCast); 5935 return LHSTy; 5936 } 5937 if (RHSTy->isObjCIdType() && 5938 (Context.hasSameType(LHSTy, Context.getObjCIdRedefinitionType()))) { 5939 LHS = ImpCastExprToType(LHS.get(), RHSTy, CK_CPointerToObjCPointerCast); 5940 return RHSTy; 5941 } 5942 // And the same for struct objc_selector* / SEL 5943 if (Context.isObjCSelType(LHSTy) && 5944 (Context.hasSameType(RHSTy, Context.getObjCSelRedefinitionType()))) { 5945 RHS = ImpCastExprToType(RHS.get(), LHSTy, CK_BitCast); 5946 return LHSTy; 5947 } 5948 if (Context.isObjCSelType(RHSTy) && 5949 (Context.hasSameType(LHSTy, Context.getObjCSelRedefinitionType()))) { 5950 LHS = ImpCastExprToType(LHS.get(), RHSTy, CK_BitCast); 5951 return RHSTy; 5952 } 5953 // Check constraints for Objective-C object pointers types. 5954 if (LHSTy->isObjCObjectPointerType() && RHSTy->isObjCObjectPointerType()) { 5955 5956 if (Context.getCanonicalType(LHSTy) == Context.getCanonicalType(RHSTy)) { 5957 // Two identical object pointer types are always compatible. 5958 return LHSTy; 5959 } 5960 const ObjCObjectPointerType *LHSOPT = LHSTy->castAs<ObjCObjectPointerType>(); 5961 const ObjCObjectPointerType *RHSOPT = RHSTy->castAs<ObjCObjectPointerType>(); 5962 QualType compositeType = LHSTy; 5963 5964 // If both operands are interfaces and either operand can be 5965 // assigned to the other, use that type as the composite 5966 // type. This allows 5967 // xxx ? (A*) a : (B*) b 5968 // where B is a subclass of A. 5969 // 5970 // Additionally, as for assignment, if either type is 'id' 5971 // allow silent coercion. Finally, if the types are 5972 // incompatible then make sure to use 'id' as the composite 5973 // type so the result is acceptable for sending messages to. 5974 5975 // FIXME: Consider unifying with 'areComparableObjCPointerTypes'. 5976 // It could return the composite type. 5977 if (Context.canAssignObjCInterfaces(LHSOPT, RHSOPT)) { 5978 compositeType = RHSOPT->isObjCBuiltinType() ? RHSTy : LHSTy; 5979 } else if (Context.canAssignObjCInterfaces(RHSOPT, LHSOPT)) { 5980 compositeType = LHSOPT->isObjCBuiltinType() ? LHSTy : RHSTy; 5981 } else if ((LHSTy->isObjCQualifiedIdType() || 5982 RHSTy->isObjCQualifiedIdType()) && 5983 Context.ObjCQualifiedIdTypesAreCompatible(LHSTy, RHSTy, true)) { 5984 // Need to handle "id<xx>" explicitly. 5985 // GCC allows qualified id and any Objective-C type to devolve to 5986 // id. Currently localizing to here until clear this should be 5987 // part of ObjCQualifiedIdTypesAreCompatible. 5988 compositeType = Context.getObjCIdType(); 5989 } else if (LHSTy->isObjCIdType() || RHSTy->isObjCIdType()) { 5990 compositeType = Context.getObjCIdType(); 5991 } else if (!(compositeType = 5992 Context.areCommonBaseCompatible(LHSOPT, RHSOPT)).isNull()) 5993 ; 5994 else { 5995 Diag(QuestionLoc, diag::ext_typecheck_cond_incompatible_operands) 5996 << LHSTy << RHSTy 5997 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 5998 QualType incompatTy = Context.getObjCIdType(); 5999 LHS = ImpCastExprToType(LHS.get(), incompatTy, CK_BitCast); 6000 RHS = ImpCastExprToType(RHS.get(), incompatTy, CK_BitCast); 6001 return incompatTy; 6002 } 6003 // The object pointer types are compatible. 6004 LHS = ImpCastExprToType(LHS.get(), compositeType, CK_BitCast); 6005 RHS = ImpCastExprToType(RHS.get(), compositeType, CK_BitCast); 6006 return compositeType; 6007 } 6008 // Check Objective-C object pointer types and 'void *' 6009 if (LHSTy->isVoidPointerType() && RHSTy->isObjCObjectPointerType()) { 6010 if (getLangOpts().ObjCAutoRefCount) { 6011 // ARC forbids the implicit conversion of object pointers to 'void *', 6012 // so these types are not compatible. 6013 Diag(QuestionLoc, diag::err_cond_voidptr_arc) << LHSTy << RHSTy 6014 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 6015 LHS = RHS = true; 6016 return QualType(); 6017 } 6018 QualType lhptee = LHSTy->getAs<PointerType>()->getPointeeType(); 6019 QualType rhptee = RHSTy->getAs<ObjCObjectPointerType>()->getPointeeType(); 6020 QualType destPointee 6021 = Context.getQualifiedType(lhptee, rhptee.getQualifiers()); 6022 QualType destType = Context.getPointerType(destPointee); 6023 // Add qualifiers if necessary. 6024 LHS = ImpCastExprToType(LHS.get(), destType, CK_NoOp); 6025 // Promote to void*. 6026 RHS = ImpCastExprToType(RHS.get(), destType, CK_BitCast); 6027 return destType; 6028 } 6029 if (LHSTy->isObjCObjectPointerType() && RHSTy->isVoidPointerType()) { 6030 if (getLangOpts().ObjCAutoRefCount) { 6031 // ARC forbids the implicit conversion of object pointers to 'void *', 6032 // so these types are not compatible. 6033 Diag(QuestionLoc, diag::err_cond_voidptr_arc) << LHSTy << RHSTy 6034 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 6035 LHS = RHS = true; 6036 return QualType(); 6037 } 6038 QualType lhptee = LHSTy->getAs<ObjCObjectPointerType>()->getPointeeType(); 6039 QualType rhptee = RHSTy->getAs<PointerType>()->getPointeeType(); 6040 QualType destPointee 6041 = Context.getQualifiedType(rhptee, lhptee.getQualifiers()); 6042 QualType destType = Context.getPointerType(destPointee); 6043 // Add qualifiers if necessary. 6044 RHS = ImpCastExprToType(RHS.get(), destType, CK_NoOp); 6045 // Promote to void*. 6046 LHS = ImpCastExprToType(LHS.get(), destType, CK_BitCast); 6047 return destType; 6048 } 6049 return QualType(); 6050 } 6051 6052 /// SuggestParentheses - Emit a note with a fixit hint that wraps 6053 /// ParenRange in parentheses. 6054 static void SuggestParentheses(Sema &Self, SourceLocation Loc, 6055 const PartialDiagnostic &Note, 6056 SourceRange ParenRange) { 6057 SourceLocation EndLoc = Self.PP.getLocForEndOfToken(ParenRange.getEnd()); 6058 if (ParenRange.getBegin().isFileID() && ParenRange.getEnd().isFileID() && 6059 EndLoc.isValid()) { 6060 Self.Diag(Loc, Note) 6061 << FixItHint::CreateInsertion(ParenRange.getBegin(), "(") 6062 << FixItHint::CreateInsertion(EndLoc, ")"); 6063 } else { 6064 // We can't display the parentheses, so just show the bare note. 6065 Self.Diag(Loc, Note) << ParenRange; 6066 } 6067 } 6068 6069 static bool IsArithmeticOp(BinaryOperatorKind Opc) { 6070 return Opc >= BO_Mul && Opc <= BO_Shr; 6071 } 6072 6073 /// IsArithmeticBinaryExpr - Returns true if E is an arithmetic binary 6074 /// expression, either using a built-in or overloaded operator, 6075 /// and sets *OpCode to the opcode and *RHSExprs to the right-hand side 6076 /// expression. 6077 static bool IsArithmeticBinaryExpr(Expr *E, BinaryOperatorKind *Opcode, 6078 Expr **RHSExprs) { 6079 // Don't strip parenthesis: we should not warn if E is in parenthesis. 6080 E = E->IgnoreImpCasts(); 6081 E = E->IgnoreConversionOperator(); 6082 E = E->IgnoreImpCasts(); 6083 6084 // Built-in binary operator. 6085 if (BinaryOperator *OP = dyn_cast<BinaryOperator>(E)) { 6086 if (IsArithmeticOp(OP->getOpcode())) { 6087 *Opcode = OP->getOpcode(); 6088 *RHSExprs = OP->getRHS(); 6089 return true; 6090 } 6091 } 6092 6093 // Overloaded operator. 6094 if (CXXOperatorCallExpr *Call = dyn_cast<CXXOperatorCallExpr>(E)) { 6095 if (Call->getNumArgs() != 2) 6096 return false; 6097 6098 // Make sure this is really a binary operator that is safe to pass into 6099 // BinaryOperator::getOverloadedOpcode(), e.g. it's not a subscript op. 6100 OverloadedOperatorKind OO = Call->getOperator(); 6101 if (OO < OO_Plus || OO > OO_Arrow || 6102 OO == OO_PlusPlus || OO == OO_MinusMinus) 6103 return false; 6104 6105 BinaryOperatorKind OpKind = BinaryOperator::getOverloadedOpcode(OO); 6106 if (IsArithmeticOp(OpKind)) { 6107 *Opcode = OpKind; 6108 *RHSExprs = Call->getArg(1); 6109 return true; 6110 } 6111 } 6112 6113 return false; 6114 } 6115 6116 static bool IsLogicOp(BinaryOperatorKind Opc) { 6117 return (Opc >= BO_LT && Opc <= BO_NE) || (Opc >= BO_LAnd && Opc <= BO_LOr); 6118 } 6119 6120 /// ExprLooksBoolean - Returns true if E looks boolean, i.e. it has boolean type 6121 /// or is a logical expression such as (x==y) which has int type, but is 6122 /// commonly interpreted as boolean. 6123 static bool ExprLooksBoolean(Expr *E) { 6124 E = E->IgnoreParenImpCasts(); 6125 6126 if (E->getType()->isBooleanType()) 6127 return true; 6128 if (BinaryOperator *OP = dyn_cast<BinaryOperator>(E)) 6129 return IsLogicOp(OP->getOpcode()); 6130 if (UnaryOperator *OP = dyn_cast<UnaryOperator>(E)) 6131 return OP->getOpcode() == UO_LNot; 6132 if (E->getType()->isPointerType()) 6133 return true; 6134 6135 return false; 6136 } 6137 6138 /// DiagnoseConditionalPrecedence - Emit a warning when a conditional operator 6139 /// and binary operator are mixed in a way that suggests the programmer assumed 6140 /// the conditional operator has higher precedence, for example: 6141 /// "int x = a + someBinaryCondition ? 1 : 2". 6142 static void DiagnoseConditionalPrecedence(Sema &Self, 6143 SourceLocation OpLoc, 6144 Expr *Condition, 6145 Expr *LHSExpr, 6146 Expr *RHSExpr) { 6147 BinaryOperatorKind CondOpcode; 6148 Expr *CondRHS; 6149 6150 if (!IsArithmeticBinaryExpr(Condition, &CondOpcode, &CondRHS)) 6151 return; 6152 if (!ExprLooksBoolean(CondRHS)) 6153 return; 6154 6155 // The condition is an arithmetic binary expression, with a right- 6156 // hand side that looks boolean, so warn. 6157 6158 Self.Diag(OpLoc, diag::warn_precedence_conditional) 6159 << Condition->getSourceRange() 6160 << BinaryOperator::getOpcodeStr(CondOpcode); 6161 6162 SuggestParentheses(Self, OpLoc, 6163 Self.PDiag(diag::note_precedence_silence) 6164 << BinaryOperator::getOpcodeStr(CondOpcode), 6165 SourceRange(Condition->getLocStart(), Condition->getLocEnd())); 6166 6167 SuggestParentheses(Self, OpLoc, 6168 Self.PDiag(diag::note_precedence_conditional_first), 6169 SourceRange(CondRHS->getLocStart(), RHSExpr->getLocEnd())); 6170 } 6171 6172 /// ActOnConditionalOp - Parse a ?: operation. Note that 'LHS' may be null 6173 /// in the case of a the GNU conditional expr extension. 6174 ExprResult Sema::ActOnConditionalOp(SourceLocation QuestionLoc, 6175 SourceLocation ColonLoc, 6176 Expr *CondExpr, Expr *LHSExpr, 6177 Expr *RHSExpr) { 6178 // If this is the gnu "x ?: y" extension, analyze the types as though the LHS 6179 // was the condition. 6180 OpaqueValueExpr *opaqueValue = nullptr; 6181 Expr *commonExpr = nullptr; 6182 if (!LHSExpr) { 6183 commonExpr = CondExpr; 6184 // Lower out placeholder types first. This is important so that we don't 6185 // try to capture a placeholder. This happens in few cases in C++; such 6186 // as Objective-C++'s dictionary subscripting syntax. 6187 if (commonExpr->hasPlaceholderType()) { 6188 ExprResult result = CheckPlaceholderExpr(commonExpr); 6189 if (!result.isUsable()) return ExprError(); 6190 commonExpr = result.get(); 6191 } 6192 // We usually want to apply unary conversions *before* saving, except 6193 // in the special case of a C++ l-value conditional. 6194 if (!(getLangOpts().CPlusPlus 6195 && !commonExpr->isTypeDependent() 6196 && commonExpr->getValueKind() == RHSExpr->getValueKind() 6197 && commonExpr->isGLValue() 6198 && commonExpr->isOrdinaryOrBitFieldObject() 6199 && RHSExpr->isOrdinaryOrBitFieldObject() 6200 && Context.hasSameType(commonExpr->getType(), RHSExpr->getType()))) { 6201 ExprResult commonRes = UsualUnaryConversions(commonExpr); 6202 if (commonRes.isInvalid()) 6203 return ExprError(); 6204 commonExpr = commonRes.get(); 6205 } 6206 6207 opaqueValue = new (Context) OpaqueValueExpr(commonExpr->getExprLoc(), 6208 commonExpr->getType(), 6209 commonExpr->getValueKind(), 6210 commonExpr->getObjectKind(), 6211 commonExpr); 6212 LHSExpr = CondExpr = opaqueValue; 6213 } 6214 6215 ExprValueKind VK = VK_RValue; 6216 ExprObjectKind OK = OK_Ordinary; 6217 ExprResult Cond = CondExpr, LHS = LHSExpr, RHS = RHSExpr; 6218 QualType result = CheckConditionalOperands(Cond, LHS, RHS, 6219 VK, OK, QuestionLoc); 6220 if (result.isNull() || Cond.isInvalid() || LHS.isInvalid() || 6221 RHS.isInvalid()) 6222 return ExprError(); 6223 6224 DiagnoseConditionalPrecedence(*this, QuestionLoc, Cond.get(), LHS.get(), 6225 RHS.get()); 6226 6227 if (!commonExpr) 6228 return new (Context) 6229 ConditionalOperator(Cond.get(), QuestionLoc, LHS.get(), ColonLoc, 6230 RHS.get(), result, VK, OK); 6231 6232 return new (Context) BinaryConditionalOperator( 6233 commonExpr, opaqueValue, Cond.get(), LHS.get(), RHS.get(), QuestionLoc, 6234 ColonLoc, result, VK, OK); 6235 } 6236 6237 // checkPointerTypesForAssignment - This is a very tricky routine (despite 6238 // being closely modeled after the C99 spec:-). The odd characteristic of this 6239 // routine is it effectively iqnores the qualifiers on the top level pointee. 6240 // This circumvents the usual type rules specified in 6.2.7p1 & 6.7.5.[1-3]. 6241 // FIXME: add a couple examples in this comment. 6242 static Sema::AssignConvertType 6243 checkPointerTypesForAssignment(Sema &S, QualType LHSType, QualType RHSType) { 6244 assert(LHSType.isCanonical() && "LHS not canonicalized!"); 6245 assert(RHSType.isCanonical() && "RHS not canonicalized!"); 6246 6247 // get the "pointed to" type (ignoring qualifiers at the top level) 6248 const Type *lhptee, *rhptee; 6249 Qualifiers lhq, rhq; 6250 std::tie(lhptee, lhq) = 6251 cast<PointerType>(LHSType)->getPointeeType().split().asPair(); 6252 std::tie(rhptee, rhq) = 6253 cast<PointerType>(RHSType)->getPointeeType().split().asPair(); 6254 6255 Sema::AssignConvertType ConvTy = Sema::Compatible; 6256 6257 // C99 6.5.16.1p1: This following citation is common to constraints 6258 // 3 & 4 (below). ...and the type *pointed to* by the left has all the 6259 // qualifiers of the type *pointed to* by the right; 6260 6261 // As a special case, 'non-__weak A *' -> 'non-__weak const *' is okay. 6262 if (lhq.getObjCLifetime() != rhq.getObjCLifetime() && 6263 lhq.compatiblyIncludesObjCLifetime(rhq)) { 6264 // Ignore lifetime for further calculation. 6265 lhq.removeObjCLifetime(); 6266 rhq.removeObjCLifetime(); 6267 } 6268 6269 if (!lhq.compatiblyIncludes(rhq)) { 6270 // Treat address-space mismatches as fatal. TODO: address subspaces 6271 if (!lhq.isAddressSpaceSupersetOf(rhq)) 6272 ConvTy = Sema::IncompatiblePointerDiscardsQualifiers; 6273 6274 // It's okay to add or remove GC or lifetime qualifiers when converting to 6275 // and from void*. 6276 else if (lhq.withoutObjCGCAttr().withoutObjCLifetime() 6277 .compatiblyIncludes( 6278 rhq.withoutObjCGCAttr().withoutObjCLifetime()) 6279 && (lhptee->isVoidType() || rhptee->isVoidType())) 6280 ; // keep old 6281 6282 // Treat lifetime mismatches as fatal. 6283 else if (lhq.getObjCLifetime() != rhq.getObjCLifetime()) 6284 ConvTy = Sema::IncompatiblePointerDiscardsQualifiers; 6285 6286 // For GCC compatibility, other qualifier mismatches are treated 6287 // as still compatible in C. 6288 else ConvTy = Sema::CompatiblePointerDiscardsQualifiers; 6289 } 6290 6291 // C99 6.5.16.1p1 (constraint 4): If one operand is a pointer to an object or 6292 // incomplete type and the other is a pointer to a qualified or unqualified 6293 // version of void... 6294 if (lhptee->isVoidType()) { 6295 if (rhptee->isIncompleteOrObjectType()) 6296 return ConvTy; 6297 6298 // As an extension, we allow cast to/from void* to function pointer. 6299 assert(rhptee->isFunctionType()); 6300 return Sema::FunctionVoidPointer; 6301 } 6302 6303 if (rhptee->isVoidType()) { 6304 if (lhptee->isIncompleteOrObjectType()) 6305 return ConvTy; 6306 6307 // As an extension, we allow cast to/from void* to function pointer. 6308 assert(lhptee->isFunctionType()); 6309 return Sema::FunctionVoidPointer; 6310 } 6311 6312 // C99 6.5.16.1p1 (constraint 3): both operands are pointers to qualified or 6313 // unqualified versions of compatible types, ... 6314 QualType ltrans = QualType(lhptee, 0), rtrans = QualType(rhptee, 0); 6315 if (!S.Context.typesAreCompatible(ltrans, rtrans)) { 6316 // Check if the pointee types are compatible ignoring the sign. 6317 // We explicitly check for char so that we catch "char" vs 6318 // "unsigned char" on systems where "char" is unsigned. 6319 if (lhptee->isCharType()) 6320 ltrans = S.Context.UnsignedCharTy; 6321 else if (lhptee->hasSignedIntegerRepresentation()) 6322 ltrans = S.Context.getCorrespondingUnsignedType(ltrans); 6323 6324 if (rhptee->isCharType()) 6325 rtrans = S.Context.UnsignedCharTy; 6326 else if (rhptee->hasSignedIntegerRepresentation()) 6327 rtrans = S.Context.getCorrespondingUnsignedType(rtrans); 6328 6329 if (ltrans == rtrans) { 6330 // Types are compatible ignoring the sign. Qualifier incompatibility 6331 // takes priority over sign incompatibility because the sign 6332 // warning can be disabled. 6333 if (ConvTy != Sema::Compatible) 6334 return ConvTy; 6335 6336 return Sema::IncompatiblePointerSign; 6337 } 6338 6339 // If we are a multi-level pointer, it's possible that our issue is simply 6340 // one of qualification - e.g. char ** -> const char ** is not allowed. If 6341 // the eventual target type is the same and the pointers have the same 6342 // level of indirection, this must be the issue. 6343 if (isa<PointerType>(lhptee) && isa<PointerType>(rhptee)) { 6344 do { 6345 lhptee = cast<PointerType>(lhptee)->getPointeeType().getTypePtr(); 6346 rhptee = cast<PointerType>(rhptee)->getPointeeType().getTypePtr(); 6347 } while (isa<PointerType>(lhptee) && isa<PointerType>(rhptee)); 6348 6349 if (lhptee == rhptee) 6350 return Sema::IncompatibleNestedPointerQualifiers; 6351 } 6352 6353 // General pointer incompatibility takes priority over qualifiers. 6354 return Sema::IncompatiblePointer; 6355 } 6356 if (!S.getLangOpts().CPlusPlus && 6357 S.IsNoReturnConversion(ltrans, rtrans, ltrans)) 6358 return Sema::IncompatiblePointer; 6359 return ConvTy; 6360 } 6361 6362 /// checkBlockPointerTypesForAssignment - This routine determines whether two 6363 /// block pointer types are compatible or whether a block and normal pointer 6364 /// are compatible. It is more restrict than comparing two function pointer 6365 // types. 6366 static Sema::AssignConvertType 6367 checkBlockPointerTypesForAssignment(Sema &S, QualType LHSType, 6368 QualType RHSType) { 6369 assert(LHSType.isCanonical() && "LHS not canonicalized!"); 6370 assert(RHSType.isCanonical() && "RHS not canonicalized!"); 6371 6372 QualType lhptee, rhptee; 6373 6374 // get the "pointed to" type (ignoring qualifiers at the top level) 6375 lhptee = cast<BlockPointerType>(LHSType)->getPointeeType(); 6376 rhptee = cast<BlockPointerType>(RHSType)->getPointeeType(); 6377 6378 // In C++, the types have to match exactly. 6379 if (S.getLangOpts().CPlusPlus) 6380 return Sema::IncompatibleBlockPointer; 6381 6382 Sema::AssignConvertType ConvTy = Sema::Compatible; 6383 6384 // For blocks we enforce that qualifiers are identical. 6385 if (lhptee.getLocalQualifiers() != rhptee.getLocalQualifiers()) 6386 ConvTy = Sema::CompatiblePointerDiscardsQualifiers; 6387 6388 if (!S.Context.typesAreBlockPointerCompatible(LHSType, RHSType)) 6389 return Sema::IncompatibleBlockPointer; 6390 6391 return ConvTy; 6392 } 6393 6394 /// checkObjCPointerTypesForAssignment - Compares two objective-c pointer types 6395 /// for assignment compatibility. 6396 static Sema::AssignConvertType 6397 checkObjCPointerTypesForAssignment(Sema &S, QualType LHSType, 6398 QualType RHSType) { 6399 assert(LHSType.isCanonical() && "LHS was not canonicalized!"); 6400 assert(RHSType.isCanonical() && "RHS was not canonicalized!"); 6401 6402 if (LHSType->isObjCBuiltinType()) { 6403 // Class is not compatible with ObjC object pointers. 6404 if (LHSType->isObjCClassType() && !RHSType->isObjCBuiltinType() && 6405 !RHSType->isObjCQualifiedClassType()) 6406 return Sema::IncompatiblePointer; 6407 return Sema::Compatible; 6408 } 6409 if (RHSType->isObjCBuiltinType()) { 6410 if (RHSType->isObjCClassType() && !LHSType->isObjCBuiltinType() && 6411 !LHSType->isObjCQualifiedClassType()) 6412 return Sema::IncompatiblePointer; 6413 return Sema::Compatible; 6414 } 6415 QualType lhptee = LHSType->getAs<ObjCObjectPointerType>()->getPointeeType(); 6416 QualType rhptee = RHSType->getAs<ObjCObjectPointerType>()->getPointeeType(); 6417 6418 if (!lhptee.isAtLeastAsQualifiedAs(rhptee) && 6419 // make an exception for id<P> 6420 !LHSType->isObjCQualifiedIdType()) 6421 return Sema::CompatiblePointerDiscardsQualifiers; 6422 6423 if (S.Context.typesAreCompatible(LHSType, RHSType)) 6424 return Sema::Compatible; 6425 if (LHSType->isObjCQualifiedIdType() || RHSType->isObjCQualifiedIdType()) 6426 return Sema::IncompatibleObjCQualifiedId; 6427 return Sema::IncompatiblePointer; 6428 } 6429 6430 Sema::AssignConvertType 6431 Sema::CheckAssignmentConstraints(SourceLocation Loc, 6432 QualType LHSType, QualType RHSType) { 6433 // Fake up an opaque expression. We don't actually care about what 6434 // cast operations are required, so if CheckAssignmentConstraints 6435 // adds casts to this they'll be wasted, but fortunately that doesn't 6436 // usually happen on valid code. 6437 OpaqueValueExpr RHSExpr(Loc, RHSType, VK_RValue); 6438 ExprResult RHSPtr = &RHSExpr; 6439 CastKind K = CK_Invalid; 6440 6441 return CheckAssignmentConstraints(LHSType, RHSPtr, K); 6442 } 6443 6444 /// CheckAssignmentConstraints (C99 6.5.16) - This routine currently 6445 /// has code to accommodate several GCC extensions when type checking 6446 /// pointers. Here are some objectionable examples that GCC considers warnings: 6447 /// 6448 /// int a, *pint; 6449 /// short *pshort; 6450 /// struct foo *pfoo; 6451 /// 6452 /// pint = pshort; // warning: assignment from incompatible pointer type 6453 /// a = pint; // warning: assignment makes integer from pointer without a cast 6454 /// pint = a; // warning: assignment makes pointer from integer without a cast 6455 /// pint = pfoo; // warning: assignment from incompatible pointer type 6456 /// 6457 /// As a result, the code for dealing with pointers is more complex than the 6458 /// C99 spec dictates. 6459 /// 6460 /// Sets 'Kind' for any result kind except Incompatible. 6461 Sema::AssignConvertType 6462 Sema::CheckAssignmentConstraints(QualType LHSType, ExprResult &RHS, 6463 CastKind &Kind) { 6464 QualType RHSType = RHS.get()->getType(); 6465 QualType OrigLHSType = LHSType; 6466 6467 // Get canonical types. We're not formatting these types, just comparing 6468 // them. 6469 LHSType = Context.getCanonicalType(LHSType).getUnqualifiedType(); 6470 RHSType = Context.getCanonicalType(RHSType).getUnqualifiedType(); 6471 6472 // Common case: no conversion required. 6473 if (LHSType == RHSType) { 6474 Kind = CK_NoOp; 6475 return Compatible; 6476 } 6477 6478 // If we have an atomic type, try a non-atomic assignment, then just add an 6479 // atomic qualification step. 6480 if (const AtomicType *AtomicTy = dyn_cast<AtomicType>(LHSType)) { 6481 Sema::AssignConvertType result = 6482 CheckAssignmentConstraints(AtomicTy->getValueType(), RHS, Kind); 6483 if (result != Compatible) 6484 return result; 6485 if (Kind != CK_NoOp) 6486 RHS = ImpCastExprToType(RHS.get(), AtomicTy->getValueType(), Kind); 6487 Kind = CK_NonAtomicToAtomic; 6488 return Compatible; 6489 } 6490 6491 // If the left-hand side is a reference type, then we are in a 6492 // (rare!) case where we've allowed the use of references in C, 6493 // e.g., as a parameter type in a built-in function. In this case, 6494 // just make sure that the type referenced is compatible with the 6495 // right-hand side type. The caller is responsible for adjusting 6496 // LHSType so that the resulting expression does not have reference 6497 // type. 6498 if (const ReferenceType *LHSTypeRef = LHSType->getAs<ReferenceType>()) { 6499 if (Context.typesAreCompatible(LHSTypeRef->getPointeeType(), RHSType)) { 6500 Kind = CK_LValueBitCast; 6501 return Compatible; 6502 } 6503 return Incompatible; 6504 } 6505 6506 // Allow scalar to ExtVector assignments, and assignments of an ExtVector type 6507 // to the same ExtVector type. 6508 if (LHSType->isExtVectorType()) { 6509 if (RHSType->isExtVectorType()) 6510 return Incompatible; 6511 if (RHSType->isArithmeticType()) { 6512 // CK_VectorSplat does T -> vector T, so first cast to the 6513 // element type. 6514 QualType elType = cast<ExtVectorType>(LHSType)->getElementType(); 6515 if (elType != RHSType) { 6516 Kind = PrepareScalarCast(RHS, elType); 6517 RHS = ImpCastExprToType(RHS.get(), elType, Kind); 6518 } 6519 Kind = CK_VectorSplat; 6520 return Compatible; 6521 } 6522 } 6523 6524 // Conversions to or from vector type. 6525 if (LHSType->isVectorType() || RHSType->isVectorType()) { 6526 if (LHSType->isVectorType() && RHSType->isVectorType()) { 6527 // Allow assignments of an AltiVec vector type to an equivalent GCC 6528 // vector type and vice versa 6529 if (Context.areCompatibleVectorTypes(LHSType, RHSType)) { 6530 Kind = CK_BitCast; 6531 return Compatible; 6532 } 6533 6534 // If we are allowing lax vector conversions, and LHS and RHS are both 6535 // vectors, the total size only needs to be the same. This is a bitcast; 6536 // no bits are changed but the result type is different. 6537 if (isLaxVectorConversion(RHSType, LHSType)) { 6538 Kind = CK_BitCast; 6539 return IncompatibleVectors; 6540 } 6541 } 6542 return Incompatible; 6543 } 6544 6545 // Arithmetic conversions. 6546 if (LHSType->isArithmeticType() && RHSType->isArithmeticType() && 6547 !(getLangOpts().CPlusPlus && LHSType->isEnumeralType())) { 6548 Kind = PrepareScalarCast(RHS, LHSType); 6549 return Compatible; 6550 } 6551 6552 // Conversions to normal pointers. 6553 if (const PointerType *LHSPointer = dyn_cast<PointerType>(LHSType)) { 6554 // U* -> T* 6555 if (isa<PointerType>(RHSType)) { 6556 unsigned AddrSpaceL = LHSPointer->getPointeeType().getAddressSpace(); 6557 unsigned AddrSpaceR = RHSType->getPointeeType().getAddressSpace(); 6558 Kind = AddrSpaceL != AddrSpaceR ? CK_AddressSpaceConversion : CK_BitCast; 6559 return checkPointerTypesForAssignment(*this, LHSType, RHSType); 6560 } 6561 6562 // int -> T* 6563 if (RHSType->isIntegerType()) { 6564 Kind = CK_IntegralToPointer; // FIXME: null? 6565 return IntToPointer; 6566 } 6567 6568 // C pointers are not compatible with ObjC object pointers, 6569 // with two exceptions: 6570 if (isa<ObjCObjectPointerType>(RHSType)) { 6571 // - conversions to void* 6572 if (LHSPointer->getPointeeType()->isVoidType()) { 6573 Kind = CK_BitCast; 6574 return Compatible; 6575 } 6576 6577 // - conversions from 'Class' to the redefinition type 6578 if (RHSType->isObjCClassType() && 6579 Context.hasSameType(LHSType, 6580 Context.getObjCClassRedefinitionType())) { 6581 Kind = CK_BitCast; 6582 return Compatible; 6583 } 6584 6585 Kind = CK_BitCast; 6586 return IncompatiblePointer; 6587 } 6588 6589 // U^ -> void* 6590 if (RHSType->getAs<BlockPointerType>()) { 6591 if (LHSPointer->getPointeeType()->isVoidType()) { 6592 Kind = CK_BitCast; 6593 return Compatible; 6594 } 6595 } 6596 6597 return Incompatible; 6598 } 6599 6600 // Conversions to block pointers. 6601 if (isa<BlockPointerType>(LHSType)) { 6602 // U^ -> T^ 6603 if (RHSType->isBlockPointerType()) { 6604 Kind = CK_BitCast; 6605 return checkBlockPointerTypesForAssignment(*this, LHSType, RHSType); 6606 } 6607 6608 // int or null -> T^ 6609 if (RHSType->isIntegerType()) { 6610 Kind = CK_IntegralToPointer; // FIXME: null 6611 return IntToBlockPointer; 6612 } 6613 6614 // id -> T^ 6615 if (getLangOpts().ObjC1 && RHSType->isObjCIdType()) { 6616 Kind = CK_AnyPointerToBlockPointerCast; 6617 return Compatible; 6618 } 6619 6620 // void* -> T^ 6621 if (const PointerType *RHSPT = RHSType->getAs<PointerType>()) 6622 if (RHSPT->getPointeeType()->isVoidType()) { 6623 Kind = CK_AnyPointerToBlockPointerCast; 6624 return Compatible; 6625 } 6626 6627 return Incompatible; 6628 } 6629 6630 // Conversions to Objective-C pointers. 6631 if (isa<ObjCObjectPointerType>(LHSType)) { 6632 // A* -> B* 6633 if (RHSType->isObjCObjectPointerType()) { 6634 Kind = CK_BitCast; 6635 Sema::AssignConvertType result = 6636 checkObjCPointerTypesForAssignment(*this, LHSType, RHSType); 6637 if (getLangOpts().ObjCAutoRefCount && 6638 result == Compatible && 6639 !CheckObjCARCUnavailableWeakConversion(OrigLHSType, RHSType)) 6640 result = IncompatibleObjCWeakRef; 6641 return result; 6642 } 6643 6644 // int or null -> A* 6645 if (RHSType->isIntegerType()) { 6646 Kind = CK_IntegralToPointer; // FIXME: null 6647 return IntToPointer; 6648 } 6649 6650 // In general, C pointers are not compatible with ObjC object pointers, 6651 // with two exceptions: 6652 if (isa<PointerType>(RHSType)) { 6653 Kind = CK_CPointerToObjCPointerCast; 6654 6655 // - conversions from 'void*' 6656 if (RHSType->isVoidPointerType()) { 6657 return Compatible; 6658 } 6659 6660 // - conversions to 'Class' from its redefinition type 6661 if (LHSType->isObjCClassType() && 6662 Context.hasSameType(RHSType, 6663 Context.getObjCClassRedefinitionType())) { 6664 return Compatible; 6665 } 6666 6667 return IncompatiblePointer; 6668 } 6669 6670 // Only under strict condition T^ is compatible with an Objective-C pointer. 6671 if (RHSType->isBlockPointerType() && 6672 isObjCPtrBlockCompatible(*this, Context, LHSType)) { 6673 maybeExtendBlockObject(*this, RHS); 6674 Kind = CK_BlockPointerToObjCPointerCast; 6675 return Compatible; 6676 } 6677 6678 return Incompatible; 6679 } 6680 6681 // Conversions from pointers that are not covered by the above. 6682 if (isa<PointerType>(RHSType)) { 6683 // T* -> _Bool 6684 if (LHSType == Context.BoolTy) { 6685 Kind = CK_PointerToBoolean; 6686 return Compatible; 6687 } 6688 6689 // T* -> int 6690 if (LHSType->isIntegerType()) { 6691 Kind = CK_PointerToIntegral; 6692 return PointerToInt; 6693 } 6694 6695 return Incompatible; 6696 } 6697 6698 // Conversions from Objective-C pointers that are not covered by the above. 6699 if (isa<ObjCObjectPointerType>(RHSType)) { 6700 // T* -> _Bool 6701 if (LHSType == Context.BoolTy) { 6702 Kind = CK_PointerToBoolean; 6703 return Compatible; 6704 } 6705 6706 // T* -> int 6707 if (LHSType->isIntegerType()) { 6708 Kind = CK_PointerToIntegral; 6709 return PointerToInt; 6710 } 6711 6712 return Incompatible; 6713 } 6714 6715 // struct A -> struct B 6716 if (isa<TagType>(LHSType) && isa<TagType>(RHSType)) { 6717 if (Context.typesAreCompatible(LHSType, RHSType)) { 6718 Kind = CK_NoOp; 6719 return Compatible; 6720 } 6721 } 6722 6723 return Incompatible; 6724 } 6725 6726 /// \brief Constructs a transparent union from an expression that is 6727 /// used to initialize the transparent union. 6728 static void ConstructTransparentUnion(Sema &S, ASTContext &C, 6729 ExprResult &EResult, QualType UnionType, 6730 FieldDecl *Field) { 6731 // Build an initializer list that designates the appropriate member 6732 // of the transparent union. 6733 Expr *E = EResult.get(); 6734 InitListExpr *Initializer = new (C) InitListExpr(C, SourceLocation(), 6735 E, SourceLocation()); 6736 Initializer->setType(UnionType); 6737 Initializer->setInitializedFieldInUnion(Field); 6738 6739 // Build a compound literal constructing a value of the transparent 6740 // union type from this initializer list. 6741 TypeSourceInfo *unionTInfo = C.getTrivialTypeSourceInfo(UnionType); 6742 EResult = new (C) CompoundLiteralExpr(SourceLocation(), unionTInfo, UnionType, 6743 VK_RValue, Initializer, false); 6744 } 6745 6746 Sema::AssignConvertType 6747 Sema::CheckTransparentUnionArgumentConstraints(QualType ArgType, 6748 ExprResult &RHS) { 6749 QualType RHSType = RHS.get()->getType(); 6750 6751 // If the ArgType is a Union type, we want to handle a potential 6752 // transparent_union GCC extension. 6753 const RecordType *UT = ArgType->getAsUnionType(); 6754 if (!UT || !UT->getDecl()->hasAttr<TransparentUnionAttr>()) 6755 return Incompatible; 6756 6757 // The field to initialize within the transparent union. 6758 RecordDecl *UD = UT->getDecl(); 6759 FieldDecl *InitField = nullptr; 6760 // It's compatible if the expression matches any of the fields. 6761 for (auto *it : UD->fields()) { 6762 if (it->getType()->isPointerType()) { 6763 // If the transparent union contains a pointer type, we allow: 6764 // 1) void pointer 6765 // 2) null pointer constant 6766 if (RHSType->isPointerType()) 6767 if (RHSType->castAs<PointerType>()->getPointeeType()->isVoidType()) { 6768 RHS = ImpCastExprToType(RHS.get(), it->getType(), CK_BitCast); 6769 InitField = it; 6770 break; 6771 } 6772 6773 if (RHS.get()->isNullPointerConstant(Context, 6774 Expr::NPC_ValueDependentIsNull)) { 6775 RHS = ImpCastExprToType(RHS.get(), it->getType(), 6776 CK_NullToPointer); 6777 InitField = it; 6778 break; 6779 } 6780 } 6781 6782 CastKind Kind = CK_Invalid; 6783 if (CheckAssignmentConstraints(it->getType(), RHS, Kind) 6784 == Compatible) { 6785 RHS = ImpCastExprToType(RHS.get(), it->getType(), Kind); 6786 InitField = it; 6787 break; 6788 } 6789 } 6790 6791 if (!InitField) 6792 return Incompatible; 6793 6794 ConstructTransparentUnion(*this, Context, RHS, ArgType, InitField); 6795 return Compatible; 6796 } 6797 6798 Sema::AssignConvertType 6799 Sema::CheckSingleAssignmentConstraints(QualType LHSType, ExprResult &RHS, 6800 bool Diagnose, 6801 bool DiagnoseCFAudited) { 6802 if (getLangOpts().CPlusPlus) { 6803 if (!LHSType->isRecordType() && !LHSType->isAtomicType()) { 6804 // C++ 5.17p3: If the left operand is not of class type, the 6805 // expression is implicitly converted (C++ 4) to the 6806 // cv-unqualified type of the left operand. 6807 ExprResult Res; 6808 if (Diagnose) { 6809 Res = PerformImplicitConversion(RHS.get(), LHSType.getUnqualifiedType(), 6810 AA_Assigning); 6811 } else { 6812 ImplicitConversionSequence ICS = 6813 TryImplicitConversion(RHS.get(), LHSType.getUnqualifiedType(), 6814 /*SuppressUserConversions=*/false, 6815 /*AllowExplicit=*/false, 6816 /*InOverloadResolution=*/false, 6817 /*CStyle=*/false, 6818 /*AllowObjCWritebackConversion=*/false); 6819 if (ICS.isFailure()) 6820 return Incompatible; 6821 Res = PerformImplicitConversion(RHS.get(), LHSType.getUnqualifiedType(), 6822 ICS, AA_Assigning); 6823 } 6824 if (Res.isInvalid()) 6825 return Incompatible; 6826 Sema::AssignConvertType result = Compatible; 6827 if (getLangOpts().ObjCAutoRefCount && 6828 !CheckObjCARCUnavailableWeakConversion(LHSType, 6829 RHS.get()->getType())) 6830 result = IncompatibleObjCWeakRef; 6831 RHS = Res; 6832 return result; 6833 } 6834 6835 // FIXME: Currently, we fall through and treat C++ classes like C 6836 // structures. 6837 // FIXME: We also fall through for atomics; not sure what should 6838 // happen there, though. 6839 } 6840 6841 // C99 6.5.16.1p1: the left operand is a pointer and the right is 6842 // a null pointer constant. 6843 if ((LHSType->isPointerType() || LHSType->isObjCObjectPointerType() || 6844 LHSType->isBlockPointerType()) && 6845 RHS.get()->isNullPointerConstant(Context, 6846 Expr::NPC_ValueDependentIsNull)) { 6847 CastKind Kind; 6848 CXXCastPath Path; 6849 CheckPointerConversion(RHS.get(), LHSType, Kind, Path, false); 6850 RHS = ImpCastExprToType(RHS.get(), LHSType, Kind, VK_RValue, &Path); 6851 return Compatible; 6852 } 6853 6854 // This check seems unnatural, however it is necessary to ensure the proper 6855 // conversion of functions/arrays. If the conversion were done for all 6856 // DeclExpr's (created by ActOnIdExpression), it would mess up the unary 6857 // expressions that suppress this implicit conversion (&, sizeof). 6858 // 6859 // Suppress this for references: C++ 8.5.3p5. 6860 if (!LHSType->isReferenceType()) { 6861 RHS = DefaultFunctionArrayLvalueConversion(RHS.get()); 6862 if (RHS.isInvalid()) 6863 return Incompatible; 6864 } 6865 6866 Expr *PRE = RHS.get()->IgnoreParenCasts(); 6867 if (ObjCProtocolExpr *OPE = dyn_cast<ObjCProtocolExpr>(PRE)) { 6868 ObjCProtocolDecl *PDecl = OPE->getProtocol(); 6869 if (PDecl && !PDecl->hasDefinition()) { 6870 Diag(PRE->getExprLoc(), diag::warn_atprotocol_protocol) << PDecl->getName(); 6871 Diag(PDecl->getLocation(), diag::note_entity_declared_at) << PDecl; 6872 } 6873 } 6874 6875 CastKind Kind = CK_Invalid; 6876 Sema::AssignConvertType result = 6877 CheckAssignmentConstraints(LHSType, RHS, Kind); 6878 6879 // C99 6.5.16.1p2: The value of the right operand is converted to the 6880 // type of the assignment expression. 6881 // CheckAssignmentConstraints allows the left-hand side to be a reference, 6882 // so that we can use references in built-in functions even in C. 6883 // The getNonReferenceType() call makes sure that the resulting expression 6884 // does not have reference type. 6885 if (result != Incompatible && RHS.get()->getType() != LHSType) { 6886 QualType Ty = LHSType.getNonLValueExprType(Context); 6887 Expr *E = RHS.get(); 6888 if (getLangOpts().ObjCAutoRefCount) 6889 CheckObjCARCConversion(SourceRange(), Ty, E, CCK_ImplicitConversion, 6890 DiagnoseCFAudited); 6891 if (getLangOpts().ObjC1 && 6892 (CheckObjCBridgeRelatedConversions(E->getLocStart(), 6893 LHSType, E->getType(), E) || 6894 ConversionToObjCStringLiteralCheck(LHSType, E))) { 6895 RHS = E; 6896 return Compatible; 6897 } 6898 6899 RHS = ImpCastExprToType(E, Ty, Kind); 6900 } 6901 return result; 6902 } 6903 6904 QualType Sema::InvalidOperands(SourceLocation Loc, ExprResult &LHS, 6905 ExprResult &RHS) { 6906 Diag(Loc, diag::err_typecheck_invalid_operands) 6907 << LHS.get()->getType() << RHS.get()->getType() 6908 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 6909 return QualType(); 6910 } 6911 6912 /// Try to convert a value of non-vector type to a vector type by converting 6913 /// the type to the element type of the vector and then performing a splat. 6914 /// If the language is OpenCL, we only use conversions that promote scalar 6915 /// rank; for C, Obj-C, and C++ we allow any real scalar conversion except 6916 /// for float->int. 6917 /// 6918 /// \param scalar - if non-null, actually perform the conversions 6919 /// \return true if the operation fails (but without diagnosing the failure) 6920 static bool tryVectorConvertAndSplat(Sema &S, ExprResult *scalar, 6921 QualType scalarTy, 6922 QualType vectorEltTy, 6923 QualType vectorTy) { 6924 // The conversion to apply to the scalar before splatting it, 6925 // if necessary. 6926 CastKind scalarCast = CK_Invalid; 6927 6928 if (vectorEltTy->isIntegralType(S.Context)) { 6929 if (!scalarTy->isIntegralType(S.Context)) 6930 return true; 6931 if (S.getLangOpts().OpenCL && 6932 S.Context.getIntegerTypeOrder(vectorEltTy, scalarTy) < 0) 6933 return true; 6934 scalarCast = CK_IntegralCast; 6935 } else if (vectorEltTy->isRealFloatingType()) { 6936 if (scalarTy->isRealFloatingType()) { 6937 if (S.getLangOpts().OpenCL && 6938 S.Context.getFloatingTypeOrder(vectorEltTy, scalarTy) < 0) 6939 return true; 6940 scalarCast = CK_FloatingCast; 6941 } 6942 else if (scalarTy->isIntegralType(S.Context)) 6943 scalarCast = CK_IntegralToFloating; 6944 else 6945 return true; 6946 } else { 6947 return true; 6948 } 6949 6950 // Adjust scalar if desired. 6951 if (scalar) { 6952 if (scalarCast != CK_Invalid) 6953 *scalar = S.ImpCastExprToType(scalar->get(), vectorEltTy, scalarCast); 6954 *scalar = S.ImpCastExprToType(scalar->get(), vectorTy, CK_VectorSplat); 6955 } 6956 return false; 6957 } 6958 6959 QualType Sema::CheckVectorOperands(ExprResult &LHS, ExprResult &RHS, 6960 SourceLocation Loc, bool IsCompAssign) { 6961 if (!IsCompAssign) { 6962 LHS = DefaultFunctionArrayLvalueConversion(LHS.get()); 6963 if (LHS.isInvalid()) 6964 return QualType(); 6965 } 6966 RHS = DefaultFunctionArrayLvalueConversion(RHS.get()); 6967 if (RHS.isInvalid()) 6968 return QualType(); 6969 6970 // For conversion purposes, we ignore any qualifiers. 6971 // For example, "const float" and "float" are equivalent. 6972 QualType LHSType = LHS.get()->getType().getUnqualifiedType(); 6973 QualType RHSType = RHS.get()->getType().getUnqualifiedType(); 6974 6975 // If the vector types are identical, return. 6976 if (Context.hasSameType(LHSType, RHSType)) 6977 return LHSType; 6978 6979 const VectorType *LHSVecType = LHSType->getAs<VectorType>(); 6980 const VectorType *RHSVecType = RHSType->getAs<VectorType>(); 6981 assert(LHSVecType || RHSVecType); 6982 6983 // If we have compatible AltiVec and GCC vector types, use the AltiVec type. 6984 if (LHSVecType && RHSVecType && 6985 Context.areCompatibleVectorTypes(LHSType, RHSType)) { 6986 if (isa<ExtVectorType>(LHSVecType)) { 6987 RHS = ImpCastExprToType(RHS.get(), LHSType, CK_BitCast); 6988 return LHSType; 6989 } 6990 6991 if (!IsCompAssign) 6992 LHS = ImpCastExprToType(LHS.get(), RHSType, CK_BitCast); 6993 return RHSType; 6994 } 6995 6996 // If there's an ext-vector type and a scalar, try to convert the scalar to 6997 // the vector element type and splat. 6998 if (!RHSVecType && isa<ExtVectorType>(LHSVecType)) { 6999 if (!tryVectorConvertAndSplat(*this, &RHS, RHSType, 7000 LHSVecType->getElementType(), LHSType)) 7001 return LHSType; 7002 } 7003 if (!LHSVecType && isa<ExtVectorType>(RHSVecType)) { 7004 if (!tryVectorConvertAndSplat(*this, (IsCompAssign ? nullptr : &LHS), 7005 LHSType, RHSVecType->getElementType(), 7006 RHSType)) 7007 return RHSType; 7008 } 7009 7010 // If we're allowing lax vector conversions, only the total (data) size 7011 // needs to be the same. 7012 // FIXME: Should we really be allowing this? 7013 // FIXME: We really just pick the LHS type arbitrarily? 7014 if (isLaxVectorConversion(RHSType, LHSType)) { 7015 QualType resultType = LHSType; 7016 RHS = ImpCastExprToType(RHS.get(), resultType, CK_BitCast); 7017 return resultType; 7018 } 7019 7020 // Okay, the expression is invalid. 7021 7022 // If there's a non-vector, non-real operand, diagnose that. 7023 if ((!RHSVecType && !RHSType->isRealType()) || 7024 (!LHSVecType && !LHSType->isRealType())) { 7025 Diag(Loc, diag::err_typecheck_vector_not_convertable_non_scalar) 7026 << LHSType << RHSType 7027 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 7028 return QualType(); 7029 } 7030 7031 // Otherwise, use the generic diagnostic. 7032 Diag(Loc, diag::err_typecheck_vector_not_convertable) 7033 << LHSType << RHSType 7034 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 7035 return QualType(); 7036 } 7037 7038 // checkArithmeticNull - Detect when a NULL constant is used improperly in an 7039 // expression. These are mainly cases where the null pointer is used as an 7040 // integer instead of a pointer. 7041 static void checkArithmeticNull(Sema &S, ExprResult &LHS, ExprResult &RHS, 7042 SourceLocation Loc, bool IsCompare) { 7043 // The canonical way to check for a GNU null is with isNullPointerConstant, 7044 // but we use a bit of a hack here for speed; this is a relatively 7045 // hot path, and isNullPointerConstant is slow. 7046 bool LHSNull = isa<GNUNullExpr>(LHS.get()->IgnoreParenImpCasts()); 7047 bool RHSNull = isa<GNUNullExpr>(RHS.get()->IgnoreParenImpCasts()); 7048 7049 QualType NonNullType = LHSNull ? RHS.get()->getType() : LHS.get()->getType(); 7050 7051 // Avoid analyzing cases where the result will either be invalid (and 7052 // diagnosed as such) or entirely valid and not something to warn about. 7053 if ((!LHSNull && !RHSNull) || NonNullType->isBlockPointerType() || 7054 NonNullType->isMemberPointerType() || NonNullType->isFunctionType()) 7055 return; 7056 7057 // Comparison operations would not make sense with a null pointer no matter 7058 // what the other expression is. 7059 if (!IsCompare) { 7060 S.Diag(Loc, diag::warn_null_in_arithmetic_operation) 7061 << (LHSNull ? LHS.get()->getSourceRange() : SourceRange()) 7062 << (RHSNull ? RHS.get()->getSourceRange() : SourceRange()); 7063 return; 7064 } 7065 7066 // The rest of the operations only make sense with a null pointer 7067 // if the other expression is a pointer. 7068 if (LHSNull == RHSNull || NonNullType->isAnyPointerType() || 7069 NonNullType->canDecayToPointerType()) 7070 return; 7071 7072 S.Diag(Loc, diag::warn_null_in_comparison_operation) 7073 << LHSNull /* LHS is NULL */ << NonNullType 7074 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 7075 } 7076 7077 QualType Sema::CheckMultiplyDivideOperands(ExprResult &LHS, ExprResult &RHS, 7078 SourceLocation Loc, 7079 bool IsCompAssign, bool IsDiv) { 7080 checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false); 7081 7082 if (LHS.get()->getType()->isVectorType() || 7083 RHS.get()->getType()->isVectorType()) 7084 return CheckVectorOperands(LHS, RHS, Loc, IsCompAssign); 7085 7086 QualType compType = UsualArithmeticConversions(LHS, RHS, IsCompAssign); 7087 if (LHS.isInvalid() || RHS.isInvalid()) 7088 return QualType(); 7089 7090 7091 if (compType.isNull() || !compType->isArithmeticType()) 7092 return InvalidOperands(Loc, LHS, RHS); 7093 7094 // Check for division by zero. 7095 llvm::APSInt RHSValue; 7096 if (IsDiv && !RHS.get()->isValueDependent() && 7097 RHS.get()->EvaluateAsInt(RHSValue, Context) && RHSValue == 0) 7098 DiagRuntimeBehavior(Loc, RHS.get(), 7099 PDiag(diag::warn_division_by_zero) 7100 << RHS.get()->getSourceRange()); 7101 7102 return compType; 7103 } 7104 7105 QualType Sema::CheckRemainderOperands( 7106 ExprResult &LHS, ExprResult &RHS, SourceLocation Loc, bool IsCompAssign) { 7107 checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false); 7108 7109 if (LHS.get()->getType()->isVectorType() || 7110 RHS.get()->getType()->isVectorType()) { 7111 if (LHS.get()->getType()->hasIntegerRepresentation() && 7112 RHS.get()->getType()->hasIntegerRepresentation()) 7113 return CheckVectorOperands(LHS, RHS, Loc, IsCompAssign); 7114 return InvalidOperands(Loc, LHS, RHS); 7115 } 7116 7117 QualType compType = UsualArithmeticConversions(LHS, RHS, IsCompAssign); 7118 if (LHS.isInvalid() || RHS.isInvalid()) 7119 return QualType(); 7120 7121 if (compType.isNull() || !compType->isIntegerType()) 7122 return InvalidOperands(Loc, LHS, RHS); 7123 7124 // Check for remainder by zero. 7125 llvm::APSInt RHSValue; 7126 if (!RHS.get()->isValueDependent() && 7127 RHS.get()->EvaluateAsInt(RHSValue, Context) && RHSValue == 0) 7128 DiagRuntimeBehavior(Loc, RHS.get(), 7129 PDiag(diag::warn_remainder_by_zero) 7130 << RHS.get()->getSourceRange()); 7131 7132 return compType; 7133 } 7134 7135 /// \brief Diagnose invalid arithmetic on two void pointers. 7136 static void diagnoseArithmeticOnTwoVoidPointers(Sema &S, SourceLocation Loc, 7137 Expr *LHSExpr, Expr *RHSExpr) { 7138 S.Diag(Loc, S.getLangOpts().CPlusPlus 7139 ? diag::err_typecheck_pointer_arith_void_type 7140 : diag::ext_gnu_void_ptr) 7141 << 1 /* two pointers */ << LHSExpr->getSourceRange() 7142 << RHSExpr->getSourceRange(); 7143 } 7144 7145 /// \brief Diagnose invalid arithmetic on a void pointer. 7146 static void diagnoseArithmeticOnVoidPointer(Sema &S, SourceLocation Loc, 7147 Expr *Pointer) { 7148 S.Diag(Loc, S.getLangOpts().CPlusPlus 7149 ? diag::err_typecheck_pointer_arith_void_type 7150 : diag::ext_gnu_void_ptr) 7151 << 0 /* one pointer */ << Pointer->getSourceRange(); 7152 } 7153 7154 /// \brief Diagnose invalid arithmetic on two function pointers. 7155 static void diagnoseArithmeticOnTwoFunctionPointers(Sema &S, SourceLocation Loc, 7156 Expr *LHS, Expr *RHS) { 7157 assert(LHS->getType()->isAnyPointerType()); 7158 assert(RHS->getType()->isAnyPointerType()); 7159 S.Diag(Loc, S.getLangOpts().CPlusPlus 7160 ? diag::err_typecheck_pointer_arith_function_type 7161 : diag::ext_gnu_ptr_func_arith) 7162 << 1 /* two pointers */ << LHS->getType()->getPointeeType() 7163 // We only show the second type if it differs from the first. 7164 << (unsigned)!S.Context.hasSameUnqualifiedType(LHS->getType(), 7165 RHS->getType()) 7166 << RHS->getType()->getPointeeType() 7167 << LHS->getSourceRange() << RHS->getSourceRange(); 7168 } 7169 7170 /// \brief Diagnose invalid arithmetic on a function pointer. 7171 static void diagnoseArithmeticOnFunctionPointer(Sema &S, SourceLocation Loc, 7172 Expr *Pointer) { 7173 assert(Pointer->getType()->isAnyPointerType()); 7174 S.Diag(Loc, S.getLangOpts().CPlusPlus 7175 ? diag::err_typecheck_pointer_arith_function_type 7176 : diag::ext_gnu_ptr_func_arith) 7177 << 0 /* one pointer */ << Pointer->getType()->getPointeeType() 7178 << 0 /* one pointer, so only one type */ 7179 << Pointer->getSourceRange(); 7180 } 7181 7182 /// \brief Emit error if Operand is incomplete pointer type 7183 /// 7184 /// \returns True if pointer has incomplete type 7185 static bool checkArithmeticIncompletePointerType(Sema &S, SourceLocation Loc, 7186 Expr *Operand) { 7187 assert(Operand->getType()->isAnyPointerType() && 7188 !Operand->getType()->isDependentType()); 7189 QualType PointeeTy = Operand->getType()->getPointeeType(); 7190 return S.RequireCompleteType(Loc, PointeeTy, 7191 diag::err_typecheck_arithmetic_incomplete_type, 7192 PointeeTy, Operand->getSourceRange()); 7193 } 7194 7195 /// \brief Check the validity of an arithmetic pointer operand. 7196 /// 7197 /// If the operand has pointer type, this code will check for pointer types 7198 /// which are invalid in arithmetic operations. These will be diagnosed 7199 /// appropriately, including whether or not the use is supported as an 7200 /// extension. 7201 /// 7202 /// \returns True when the operand is valid to use (even if as an extension). 7203 static bool checkArithmeticOpPointerOperand(Sema &S, SourceLocation Loc, 7204 Expr *Operand) { 7205 if (!Operand->getType()->isAnyPointerType()) return true; 7206 7207 QualType PointeeTy = Operand->getType()->getPointeeType(); 7208 if (PointeeTy->isVoidType()) { 7209 diagnoseArithmeticOnVoidPointer(S, Loc, Operand); 7210 return !S.getLangOpts().CPlusPlus; 7211 } 7212 if (PointeeTy->isFunctionType()) { 7213 diagnoseArithmeticOnFunctionPointer(S, Loc, Operand); 7214 return !S.getLangOpts().CPlusPlus; 7215 } 7216 7217 if (checkArithmeticIncompletePointerType(S, Loc, Operand)) return false; 7218 7219 return true; 7220 } 7221 7222 /// \brief Check the validity of a binary arithmetic operation w.r.t. pointer 7223 /// operands. 7224 /// 7225 /// This routine will diagnose any invalid arithmetic on pointer operands much 7226 /// like \see checkArithmeticOpPointerOperand. However, it has special logic 7227 /// for emitting a single diagnostic even for operations where both LHS and RHS 7228 /// are (potentially problematic) pointers. 7229 /// 7230 /// \returns True when the operand is valid to use (even if as an extension). 7231 static bool checkArithmeticBinOpPointerOperands(Sema &S, SourceLocation Loc, 7232 Expr *LHSExpr, Expr *RHSExpr) { 7233 bool isLHSPointer = LHSExpr->getType()->isAnyPointerType(); 7234 bool isRHSPointer = RHSExpr->getType()->isAnyPointerType(); 7235 if (!isLHSPointer && !isRHSPointer) return true; 7236 7237 QualType LHSPointeeTy, RHSPointeeTy; 7238 if (isLHSPointer) LHSPointeeTy = LHSExpr->getType()->getPointeeType(); 7239 if (isRHSPointer) RHSPointeeTy = RHSExpr->getType()->getPointeeType(); 7240 7241 // if both are pointers check if operation is valid wrt address spaces 7242 if (isLHSPointer && isRHSPointer) { 7243 const PointerType *lhsPtr = LHSExpr->getType()->getAs<PointerType>(); 7244 const PointerType *rhsPtr = RHSExpr->getType()->getAs<PointerType>(); 7245 if (!lhsPtr->isAddressSpaceOverlapping(*rhsPtr)) { 7246 S.Diag(Loc, 7247 diag::err_typecheck_op_on_nonoverlapping_address_space_pointers) 7248 << LHSExpr->getType() << RHSExpr->getType() << 1 /*arithmetic op*/ 7249 << LHSExpr->getSourceRange() << RHSExpr->getSourceRange(); 7250 return false; 7251 } 7252 } 7253 7254 // Check for arithmetic on pointers to incomplete types. 7255 bool isLHSVoidPtr = isLHSPointer && LHSPointeeTy->isVoidType(); 7256 bool isRHSVoidPtr = isRHSPointer && RHSPointeeTy->isVoidType(); 7257 if (isLHSVoidPtr || isRHSVoidPtr) { 7258 if (!isRHSVoidPtr) diagnoseArithmeticOnVoidPointer(S, Loc, LHSExpr); 7259 else if (!isLHSVoidPtr) diagnoseArithmeticOnVoidPointer(S, Loc, RHSExpr); 7260 else diagnoseArithmeticOnTwoVoidPointers(S, Loc, LHSExpr, RHSExpr); 7261 7262 return !S.getLangOpts().CPlusPlus; 7263 } 7264 7265 bool isLHSFuncPtr = isLHSPointer && LHSPointeeTy->isFunctionType(); 7266 bool isRHSFuncPtr = isRHSPointer && RHSPointeeTy->isFunctionType(); 7267 if (isLHSFuncPtr || isRHSFuncPtr) { 7268 if (!isRHSFuncPtr) diagnoseArithmeticOnFunctionPointer(S, Loc, LHSExpr); 7269 else if (!isLHSFuncPtr) diagnoseArithmeticOnFunctionPointer(S, Loc, 7270 RHSExpr); 7271 else diagnoseArithmeticOnTwoFunctionPointers(S, Loc, LHSExpr, RHSExpr); 7272 7273 return !S.getLangOpts().CPlusPlus; 7274 } 7275 7276 if (isLHSPointer && checkArithmeticIncompletePointerType(S, Loc, LHSExpr)) 7277 return false; 7278 if (isRHSPointer && checkArithmeticIncompletePointerType(S, Loc, RHSExpr)) 7279 return false; 7280 7281 return true; 7282 } 7283 7284 /// diagnoseStringPlusInt - Emit a warning when adding an integer to a string 7285 /// literal. 7286 static void diagnoseStringPlusInt(Sema &Self, SourceLocation OpLoc, 7287 Expr *LHSExpr, Expr *RHSExpr) { 7288 StringLiteral* StrExpr = dyn_cast<StringLiteral>(LHSExpr->IgnoreImpCasts()); 7289 Expr* IndexExpr = RHSExpr; 7290 if (!StrExpr) { 7291 StrExpr = dyn_cast<StringLiteral>(RHSExpr->IgnoreImpCasts()); 7292 IndexExpr = LHSExpr; 7293 } 7294 7295 bool IsStringPlusInt = StrExpr && 7296 IndexExpr->getType()->isIntegralOrUnscopedEnumerationType(); 7297 if (!IsStringPlusInt || IndexExpr->isValueDependent()) 7298 return; 7299 7300 llvm::APSInt index; 7301 if (IndexExpr->EvaluateAsInt(index, Self.getASTContext())) { 7302 unsigned StrLenWithNull = StrExpr->getLength() + 1; 7303 if (index.isNonNegative() && 7304 index <= llvm::APSInt(llvm::APInt(index.getBitWidth(), StrLenWithNull), 7305 index.isUnsigned())) 7306 return; 7307 } 7308 7309 SourceRange DiagRange(LHSExpr->getLocStart(), RHSExpr->getLocEnd()); 7310 Self.Diag(OpLoc, diag::warn_string_plus_int) 7311 << DiagRange << IndexExpr->IgnoreImpCasts()->getType(); 7312 7313 // Only print a fixit for "str" + int, not for int + "str". 7314 if (IndexExpr == RHSExpr) { 7315 SourceLocation EndLoc = Self.PP.getLocForEndOfToken(RHSExpr->getLocEnd()); 7316 Self.Diag(OpLoc, diag::note_string_plus_scalar_silence) 7317 << FixItHint::CreateInsertion(LHSExpr->getLocStart(), "&") 7318 << FixItHint::CreateReplacement(SourceRange(OpLoc), "[") 7319 << FixItHint::CreateInsertion(EndLoc, "]"); 7320 } else 7321 Self.Diag(OpLoc, diag::note_string_plus_scalar_silence); 7322 } 7323 7324 /// \brief Emit a warning when adding a char literal to a string. 7325 static void diagnoseStringPlusChar(Sema &Self, SourceLocation OpLoc, 7326 Expr *LHSExpr, Expr *RHSExpr) { 7327 const Expr *StringRefExpr = LHSExpr; 7328 const CharacterLiteral *CharExpr = 7329 dyn_cast<CharacterLiteral>(RHSExpr->IgnoreImpCasts()); 7330 7331 if (!CharExpr) { 7332 CharExpr = dyn_cast<CharacterLiteral>(LHSExpr->IgnoreImpCasts()); 7333 StringRefExpr = RHSExpr; 7334 } 7335 7336 if (!CharExpr || !StringRefExpr) 7337 return; 7338 7339 const QualType StringType = StringRefExpr->getType(); 7340 7341 // Return if not a PointerType. 7342 if (!StringType->isAnyPointerType()) 7343 return; 7344 7345 // Return if not a CharacterType. 7346 if (!StringType->getPointeeType()->isAnyCharacterType()) 7347 return; 7348 7349 ASTContext &Ctx = Self.getASTContext(); 7350 SourceRange DiagRange(LHSExpr->getLocStart(), RHSExpr->getLocEnd()); 7351 7352 const QualType CharType = CharExpr->getType(); 7353 if (!CharType->isAnyCharacterType() && 7354 CharType->isIntegerType() && 7355 llvm::isUIntN(Ctx.getCharWidth(), CharExpr->getValue())) { 7356 Self.Diag(OpLoc, diag::warn_string_plus_char) 7357 << DiagRange << Ctx.CharTy; 7358 } else { 7359 Self.Diag(OpLoc, diag::warn_string_plus_char) 7360 << DiagRange << CharExpr->getType(); 7361 } 7362 7363 // Only print a fixit for str + char, not for char + str. 7364 if (isa<CharacterLiteral>(RHSExpr->IgnoreImpCasts())) { 7365 SourceLocation EndLoc = Self.PP.getLocForEndOfToken(RHSExpr->getLocEnd()); 7366 Self.Diag(OpLoc, diag::note_string_plus_scalar_silence) 7367 << FixItHint::CreateInsertion(LHSExpr->getLocStart(), "&") 7368 << FixItHint::CreateReplacement(SourceRange(OpLoc), "[") 7369 << FixItHint::CreateInsertion(EndLoc, "]"); 7370 } else { 7371 Self.Diag(OpLoc, diag::note_string_plus_scalar_silence); 7372 } 7373 } 7374 7375 /// \brief Emit error when two pointers are incompatible. 7376 static void diagnosePointerIncompatibility(Sema &S, SourceLocation Loc, 7377 Expr *LHSExpr, Expr *RHSExpr) { 7378 assert(LHSExpr->getType()->isAnyPointerType()); 7379 assert(RHSExpr->getType()->isAnyPointerType()); 7380 S.Diag(Loc, diag::err_typecheck_sub_ptr_compatible) 7381 << LHSExpr->getType() << RHSExpr->getType() << LHSExpr->getSourceRange() 7382 << RHSExpr->getSourceRange(); 7383 } 7384 7385 QualType Sema::CheckAdditionOperands( // C99 6.5.6 7386 ExprResult &LHS, ExprResult &RHS, SourceLocation Loc, unsigned Opc, 7387 QualType* CompLHSTy) { 7388 checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false); 7389 7390 if (LHS.get()->getType()->isVectorType() || 7391 RHS.get()->getType()->isVectorType()) { 7392 QualType compType = CheckVectorOperands(LHS, RHS, Loc, CompLHSTy); 7393 if (CompLHSTy) *CompLHSTy = compType; 7394 return compType; 7395 } 7396 7397 QualType compType = UsualArithmeticConversions(LHS, RHS, CompLHSTy); 7398 if (LHS.isInvalid() || RHS.isInvalid()) 7399 return QualType(); 7400 7401 // Diagnose "string literal" '+' int and string '+' "char literal". 7402 if (Opc == BO_Add) { 7403 diagnoseStringPlusInt(*this, Loc, LHS.get(), RHS.get()); 7404 diagnoseStringPlusChar(*this, Loc, LHS.get(), RHS.get()); 7405 } 7406 7407 // handle the common case first (both operands are arithmetic). 7408 if (!compType.isNull() && compType->isArithmeticType()) { 7409 if (CompLHSTy) *CompLHSTy = compType; 7410 return compType; 7411 } 7412 7413 // Type-checking. Ultimately the pointer's going to be in PExp; 7414 // note that we bias towards the LHS being the pointer. 7415 Expr *PExp = LHS.get(), *IExp = RHS.get(); 7416 7417 bool isObjCPointer; 7418 if (PExp->getType()->isPointerType()) { 7419 isObjCPointer = false; 7420 } else if (PExp->getType()->isObjCObjectPointerType()) { 7421 isObjCPointer = true; 7422 } else { 7423 std::swap(PExp, IExp); 7424 if (PExp->getType()->isPointerType()) { 7425 isObjCPointer = false; 7426 } else if (PExp->getType()->isObjCObjectPointerType()) { 7427 isObjCPointer = true; 7428 } else { 7429 return InvalidOperands(Loc, LHS, RHS); 7430 } 7431 } 7432 assert(PExp->getType()->isAnyPointerType()); 7433 7434 if (!IExp->getType()->isIntegerType()) 7435 return InvalidOperands(Loc, LHS, RHS); 7436 7437 if (!checkArithmeticOpPointerOperand(*this, Loc, PExp)) 7438 return QualType(); 7439 7440 if (isObjCPointer && checkArithmeticOnObjCPointer(*this, Loc, PExp)) 7441 return QualType(); 7442 7443 // Check array bounds for pointer arithemtic 7444 CheckArrayAccess(PExp, IExp); 7445 7446 if (CompLHSTy) { 7447 QualType LHSTy = Context.isPromotableBitField(LHS.get()); 7448 if (LHSTy.isNull()) { 7449 LHSTy = LHS.get()->getType(); 7450 if (LHSTy->isPromotableIntegerType()) 7451 LHSTy = Context.getPromotedIntegerType(LHSTy); 7452 } 7453 *CompLHSTy = LHSTy; 7454 } 7455 7456 return PExp->getType(); 7457 } 7458 7459 // C99 6.5.6 7460 QualType Sema::CheckSubtractionOperands(ExprResult &LHS, ExprResult &RHS, 7461 SourceLocation Loc, 7462 QualType* CompLHSTy) { 7463 checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false); 7464 7465 if (LHS.get()->getType()->isVectorType() || 7466 RHS.get()->getType()->isVectorType()) { 7467 QualType compType = CheckVectorOperands(LHS, RHS, Loc, CompLHSTy); 7468 if (CompLHSTy) *CompLHSTy = compType; 7469 return compType; 7470 } 7471 7472 QualType compType = UsualArithmeticConversions(LHS, RHS, CompLHSTy); 7473 if (LHS.isInvalid() || RHS.isInvalid()) 7474 return QualType(); 7475 7476 // Enforce type constraints: C99 6.5.6p3. 7477 7478 // Handle the common case first (both operands are arithmetic). 7479 if (!compType.isNull() && compType->isArithmeticType()) { 7480 if (CompLHSTy) *CompLHSTy = compType; 7481 return compType; 7482 } 7483 7484 // Either ptr - int or ptr - ptr. 7485 if (LHS.get()->getType()->isAnyPointerType()) { 7486 QualType lpointee = LHS.get()->getType()->getPointeeType(); 7487 7488 // Diagnose bad cases where we step over interface counts. 7489 if (LHS.get()->getType()->isObjCObjectPointerType() && 7490 checkArithmeticOnObjCPointer(*this, Loc, LHS.get())) 7491 return QualType(); 7492 7493 // The result type of a pointer-int computation is the pointer type. 7494 if (RHS.get()->getType()->isIntegerType()) { 7495 if (!checkArithmeticOpPointerOperand(*this, Loc, LHS.get())) 7496 return QualType(); 7497 7498 // Check array bounds for pointer arithemtic 7499 CheckArrayAccess(LHS.get(), RHS.get(), /*ArraySubscriptExpr*/nullptr, 7500 /*AllowOnePastEnd*/true, /*IndexNegated*/true); 7501 7502 if (CompLHSTy) *CompLHSTy = LHS.get()->getType(); 7503 return LHS.get()->getType(); 7504 } 7505 7506 // Handle pointer-pointer subtractions. 7507 if (const PointerType *RHSPTy 7508 = RHS.get()->getType()->getAs<PointerType>()) { 7509 QualType rpointee = RHSPTy->getPointeeType(); 7510 7511 if (getLangOpts().CPlusPlus) { 7512 // Pointee types must be the same: C++ [expr.add] 7513 if (!Context.hasSameUnqualifiedType(lpointee, rpointee)) { 7514 diagnosePointerIncompatibility(*this, Loc, LHS.get(), RHS.get()); 7515 } 7516 } else { 7517 // Pointee types must be compatible C99 6.5.6p3 7518 if (!Context.typesAreCompatible( 7519 Context.getCanonicalType(lpointee).getUnqualifiedType(), 7520 Context.getCanonicalType(rpointee).getUnqualifiedType())) { 7521 diagnosePointerIncompatibility(*this, Loc, LHS.get(), RHS.get()); 7522 return QualType(); 7523 } 7524 } 7525 7526 if (!checkArithmeticBinOpPointerOperands(*this, Loc, 7527 LHS.get(), RHS.get())) 7528 return QualType(); 7529 7530 // The pointee type may have zero size. As an extension, a structure or 7531 // union may have zero size or an array may have zero length. In this 7532 // case subtraction does not make sense. 7533 if (!rpointee->isVoidType() && !rpointee->isFunctionType()) { 7534 CharUnits ElementSize = Context.getTypeSizeInChars(rpointee); 7535 if (ElementSize.isZero()) { 7536 Diag(Loc,diag::warn_sub_ptr_zero_size_types) 7537 << rpointee.getUnqualifiedType() 7538 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 7539 } 7540 } 7541 7542 if (CompLHSTy) *CompLHSTy = LHS.get()->getType(); 7543 return Context.getPointerDiffType(); 7544 } 7545 } 7546 7547 return InvalidOperands(Loc, LHS, RHS); 7548 } 7549 7550 static bool isScopedEnumerationType(QualType T) { 7551 if (const EnumType *ET = T->getAs<EnumType>()) 7552 return ET->getDecl()->isScoped(); 7553 return false; 7554 } 7555 7556 static void DiagnoseBadShiftValues(Sema& S, ExprResult &LHS, ExprResult &RHS, 7557 SourceLocation Loc, unsigned Opc, 7558 QualType LHSType) { 7559 // OpenCL 6.3j: shift values are effectively % word size of LHS (more defined), 7560 // so skip remaining warnings as we don't want to modify values within Sema. 7561 if (S.getLangOpts().OpenCL) 7562 return; 7563 7564 llvm::APSInt Right; 7565 // Check right/shifter operand 7566 if (RHS.get()->isValueDependent() || 7567 !RHS.get()->isIntegerConstantExpr(Right, S.Context)) 7568 return; 7569 7570 if (Right.isNegative()) { 7571 S.DiagRuntimeBehavior(Loc, RHS.get(), 7572 S.PDiag(diag::warn_shift_negative) 7573 << RHS.get()->getSourceRange()); 7574 return; 7575 } 7576 llvm::APInt LeftBits(Right.getBitWidth(), 7577 S.Context.getTypeSize(LHS.get()->getType())); 7578 if (Right.uge(LeftBits)) { 7579 S.DiagRuntimeBehavior(Loc, RHS.get(), 7580 S.PDiag(diag::warn_shift_gt_typewidth) 7581 << RHS.get()->getSourceRange()); 7582 return; 7583 } 7584 if (Opc != BO_Shl) 7585 return; 7586 7587 // When left shifting an ICE which is signed, we can check for overflow which 7588 // according to C++ has undefined behavior ([expr.shift] 5.8/2). Unsigned 7589 // integers have defined behavior modulo one more than the maximum value 7590 // representable in the result type, so never warn for those. 7591 llvm::APSInt Left; 7592 if (LHS.get()->isValueDependent() || 7593 !LHS.get()->isIntegerConstantExpr(Left, S.Context) || 7594 LHSType->hasUnsignedIntegerRepresentation()) 7595 return; 7596 llvm::APInt ResultBits = 7597 static_cast<llvm::APInt&>(Right) + Left.getMinSignedBits(); 7598 if (LeftBits.uge(ResultBits)) 7599 return; 7600 llvm::APSInt Result = Left.extend(ResultBits.getLimitedValue()); 7601 Result = Result.shl(Right); 7602 7603 // Print the bit representation of the signed integer as an unsigned 7604 // hexadecimal number. 7605 SmallString<40> HexResult; 7606 Result.toString(HexResult, 16, /*Signed =*/false, /*Literal =*/true); 7607 7608 // If we are only missing a sign bit, this is less likely to result in actual 7609 // bugs -- if the result is cast back to an unsigned type, it will have the 7610 // expected value. Thus we place this behind a different warning that can be 7611 // turned off separately if needed. 7612 if (LeftBits == ResultBits - 1) { 7613 S.Diag(Loc, diag::warn_shift_result_sets_sign_bit) 7614 << HexResult.str() << LHSType 7615 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 7616 return; 7617 } 7618 7619 S.Diag(Loc, diag::warn_shift_result_gt_typewidth) 7620 << HexResult.str() << Result.getMinSignedBits() << LHSType 7621 << Left.getBitWidth() << LHS.get()->getSourceRange() 7622 << RHS.get()->getSourceRange(); 7623 } 7624 7625 // C99 6.5.7 7626 QualType Sema::CheckShiftOperands(ExprResult &LHS, ExprResult &RHS, 7627 SourceLocation Loc, unsigned Opc, 7628 bool IsCompAssign) { 7629 checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false); 7630 7631 // Vector shifts promote their scalar inputs to vector type. 7632 if (LHS.get()->getType()->isVectorType() || 7633 RHS.get()->getType()->isVectorType()) 7634 return CheckVectorOperands(LHS, RHS, Loc, IsCompAssign); 7635 7636 // Shifts don't perform usual arithmetic conversions, they just do integer 7637 // promotions on each operand. C99 6.5.7p3 7638 7639 // For the LHS, do usual unary conversions, but then reset them away 7640 // if this is a compound assignment. 7641 ExprResult OldLHS = LHS; 7642 LHS = UsualUnaryConversions(LHS.get()); 7643 if (LHS.isInvalid()) 7644 return QualType(); 7645 QualType LHSType = LHS.get()->getType(); 7646 if (IsCompAssign) LHS = OldLHS; 7647 7648 // The RHS is simpler. 7649 RHS = UsualUnaryConversions(RHS.get()); 7650 if (RHS.isInvalid()) 7651 return QualType(); 7652 QualType RHSType = RHS.get()->getType(); 7653 7654 // C99 6.5.7p2: Each of the operands shall have integer type. 7655 if (!LHSType->hasIntegerRepresentation() || 7656 !RHSType->hasIntegerRepresentation()) 7657 return InvalidOperands(Loc, LHS, RHS); 7658 7659 // C++0x: Don't allow scoped enums. FIXME: Use something better than 7660 // hasIntegerRepresentation() above instead of this. 7661 if (isScopedEnumerationType(LHSType) || 7662 isScopedEnumerationType(RHSType)) { 7663 return InvalidOperands(Loc, LHS, RHS); 7664 } 7665 // Sanity-check shift operands 7666 DiagnoseBadShiftValues(*this, LHS, RHS, Loc, Opc, LHSType); 7667 7668 // "The type of the result is that of the promoted left operand." 7669 return LHSType; 7670 } 7671 7672 static bool IsWithinTemplateSpecialization(Decl *D) { 7673 if (DeclContext *DC = D->getDeclContext()) { 7674 if (isa<ClassTemplateSpecializationDecl>(DC)) 7675 return true; 7676 if (FunctionDecl *FD = dyn_cast<FunctionDecl>(DC)) 7677 return FD->isFunctionTemplateSpecialization(); 7678 } 7679 return false; 7680 } 7681 7682 /// If two different enums are compared, raise a warning. 7683 static void checkEnumComparison(Sema &S, SourceLocation Loc, Expr *LHS, 7684 Expr *RHS) { 7685 QualType LHSStrippedType = LHS->IgnoreParenImpCasts()->getType(); 7686 QualType RHSStrippedType = RHS->IgnoreParenImpCasts()->getType(); 7687 7688 const EnumType *LHSEnumType = LHSStrippedType->getAs<EnumType>(); 7689 if (!LHSEnumType) 7690 return; 7691 const EnumType *RHSEnumType = RHSStrippedType->getAs<EnumType>(); 7692 if (!RHSEnumType) 7693 return; 7694 7695 // Ignore anonymous enums. 7696 if (!LHSEnumType->getDecl()->getIdentifier()) 7697 return; 7698 if (!RHSEnumType->getDecl()->getIdentifier()) 7699 return; 7700 7701 if (S.Context.hasSameUnqualifiedType(LHSStrippedType, RHSStrippedType)) 7702 return; 7703 7704 S.Diag(Loc, diag::warn_comparison_of_mixed_enum_types) 7705 << LHSStrippedType << RHSStrippedType 7706 << LHS->getSourceRange() << RHS->getSourceRange(); 7707 } 7708 7709 /// \brief Diagnose bad pointer comparisons. 7710 static void diagnoseDistinctPointerComparison(Sema &S, SourceLocation Loc, 7711 ExprResult &LHS, ExprResult &RHS, 7712 bool IsError) { 7713 S.Diag(Loc, IsError ? diag::err_typecheck_comparison_of_distinct_pointers 7714 : diag::ext_typecheck_comparison_of_distinct_pointers) 7715 << LHS.get()->getType() << RHS.get()->getType() 7716 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 7717 } 7718 7719 /// \brief Returns false if the pointers are converted to a composite type, 7720 /// true otherwise. 7721 static bool convertPointersToCompositeType(Sema &S, SourceLocation Loc, 7722 ExprResult &LHS, ExprResult &RHS) { 7723 // C++ [expr.rel]p2: 7724 // [...] Pointer conversions (4.10) and qualification 7725 // conversions (4.4) are performed on pointer operands (or on 7726 // a pointer operand and a null pointer constant) to bring 7727 // them to their composite pointer type. [...] 7728 // 7729 // C++ [expr.eq]p1 uses the same notion for (in)equality 7730 // comparisons of pointers. 7731 7732 // C++ [expr.eq]p2: 7733 // In addition, pointers to members can be compared, or a pointer to 7734 // member and a null pointer constant. Pointer to member conversions 7735 // (4.11) and qualification conversions (4.4) are performed to bring 7736 // them to a common type. If one operand is a null pointer constant, 7737 // the common type is the type of the other operand. Otherwise, the 7738 // common type is a pointer to member type similar (4.4) to the type 7739 // of one of the operands, with a cv-qualification signature (4.4) 7740 // that is the union of the cv-qualification signatures of the operand 7741 // types. 7742 7743 QualType LHSType = LHS.get()->getType(); 7744 QualType RHSType = RHS.get()->getType(); 7745 assert((LHSType->isPointerType() && RHSType->isPointerType()) || 7746 (LHSType->isMemberPointerType() && RHSType->isMemberPointerType())); 7747 7748 bool NonStandardCompositeType = false; 7749 bool *BoolPtr = S.isSFINAEContext() ? nullptr : &NonStandardCompositeType; 7750 QualType T = S.FindCompositePointerType(Loc, LHS, RHS, BoolPtr); 7751 if (T.isNull()) { 7752 diagnoseDistinctPointerComparison(S, Loc, LHS, RHS, /*isError*/true); 7753 return true; 7754 } 7755 7756 if (NonStandardCompositeType) 7757 S.Diag(Loc, diag::ext_typecheck_comparison_of_distinct_pointers_nonstandard) 7758 << LHSType << RHSType << T << LHS.get()->getSourceRange() 7759 << RHS.get()->getSourceRange(); 7760 7761 LHS = S.ImpCastExprToType(LHS.get(), T, CK_BitCast); 7762 RHS = S.ImpCastExprToType(RHS.get(), T, CK_BitCast); 7763 return false; 7764 } 7765 7766 static void diagnoseFunctionPointerToVoidComparison(Sema &S, SourceLocation Loc, 7767 ExprResult &LHS, 7768 ExprResult &RHS, 7769 bool IsError) { 7770 S.Diag(Loc, IsError ? diag::err_typecheck_comparison_of_fptr_to_void 7771 : diag::ext_typecheck_comparison_of_fptr_to_void) 7772 << LHS.get()->getType() << RHS.get()->getType() 7773 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 7774 } 7775 7776 static bool isObjCObjectLiteral(ExprResult &E) { 7777 switch (E.get()->IgnoreParenImpCasts()->getStmtClass()) { 7778 case Stmt::ObjCArrayLiteralClass: 7779 case Stmt::ObjCDictionaryLiteralClass: 7780 case Stmt::ObjCStringLiteralClass: 7781 case Stmt::ObjCBoxedExprClass: 7782 return true; 7783 default: 7784 // Note that ObjCBoolLiteral is NOT an object literal! 7785 return false; 7786 } 7787 } 7788 7789 static bool hasIsEqualMethod(Sema &S, const Expr *LHS, const Expr *RHS) { 7790 const ObjCObjectPointerType *Type = 7791 LHS->getType()->getAs<ObjCObjectPointerType>(); 7792 7793 // If this is not actually an Objective-C object, bail out. 7794 if (!Type) 7795 return false; 7796 7797 // Get the LHS object's interface type. 7798 QualType InterfaceType = Type->getPointeeType(); 7799 if (const ObjCObjectType *iQFaceTy = 7800 InterfaceType->getAsObjCQualifiedInterfaceType()) 7801 InterfaceType = iQFaceTy->getBaseType(); 7802 7803 // If the RHS isn't an Objective-C object, bail out. 7804 if (!RHS->getType()->isObjCObjectPointerType()) 7805 return false; 7806 7807 // Try to find the -isEqual: method. 7808 Selector IsEqualSel = S.NSAPIObj->getIsEqualSelector(); 7809 ObjCMethodDecl *Method = S.LookupMethodInObjectType(IsEqualSel, 7810 InterfaceType, 7811 /*instance=*/true); 7812 if (!Method) { 7813 if (Type->isObjCIdType()) { 7814 // For 'id', just check the global pool. 7815 Method = S.LookupInstanceMethodInGlobalPool(IsEqualSel, SourceRange(), 7816 /*receiverId=*/true, 7817 /*warn=*/false); 7818 } else { 7819 // Check protocols. 7820 Method = S.LookupMethodInQualifiedType(IsEqualSel, Type, 7821 /*instance=*/true); 7822 } 7823 } 7824 7825 if (!Method) 7826 return false; 7827 7828 QualType T = Method->parameters()[0]->getType(); 7829 if (!T->isObjCObjectPointerType()) 7830 return false; 7831 7832 QualType R = Method->getReturnType(); 7833 if (!R->isScalarType()) 7834 return false; 7835 7836 return true; 7837 } 7838 7839 Sema::ObjCLiteralKind Sema::CheckLiteralKind(Expr *FromE) { 7840 FromE = FromE->IgnoreParenImpCasts(); 7841 switch (FromE->getStmtClass()) { 7842 default: 7843 break; 7844 case Stmt::ObjCStringLiteralClass: 7845 // "string literal" 7846 return LK_String; 7847 case Stmt::ObjCArrayLiteralClass: 7848 // "array literal" 7849 return LK_Array; 7850 case Stmt::ObjCDictionaryLiteralClass: 7851 // "dictionary literal" 7852 return LK_Dictionary; 7853 case Stmt::BlockExprClass: 7854 return LK_Block; 7855 case Stmt::ObjCBoxedExprClass: { 7856 Expr *Inner = cast<ObjCBoxedExpr>(FromE)->getSubExpr()->IgnoreParens(); 7857 switch (Inner->getStmtClass()) { 7858 case Stmt::IntegerLiteralClass: 7859 case Stmt::FloatingLiteralClass: 7860 case Stmt::CharacterLiteralClass: 7861 case Stmt::ObjCBoolLiteralExprClass: 7862 case Stmt::CXXBoolLiteralExprClass: 7863 // "numeric literal" 7864 return LK_Numeric; 7865 case Stmt::ImplicitCastExprClass: { 7866 CastKind CK = cast<CastExpr>(Inner)->getCastKind(); 7867 // Boolean literals can be represented by implicit casts. 7868 if (CK == CK_IntegralToBoolean || CK == CK_IntegralCast) 7869 return LK_Numeric; 7870 break; 7871 } 7872 default: 7873 break; 7874 } 7875 return LK_Boxed; 7876 } 7877 } 7878 return LK_None; 7879 } 7880 7881 static void diagnoseObjCLiteralComparison(Sema &S, SourceLocation Loc, 7882 ExprResult &LHS, ExprResult &RHS, 7883 BinaryOperator::Opcode Opc){ 7884 Expr *Literal; 7885 Expr *Other; 7886 if (isObjCObjectLiteral(LHS)) { 7887 Literal = LHS.get(); 7888 Other = RHS.get(); 7889 } else { 7890 Literal = RHS.get(); 7891 Other = LHS.get(); 7892 } 7893 7894 // Don't warn on comparisons against nil. 7895 Other = Other->IgnoreParenCasts(); 7896 if (Other->isNullPointerConstant(S.getASTContext(), 7897 Expr::NPC_ValueDependentIsNotNull)) 7898 return; 7899 7900 // This should be kept in sync with warn_objc_literal_comparison. 7901 // LK_String should always be after the other literals, since it has its own 7902 // warning flag. 7903 Sema::ObjCLiteralKind LiteralKind = S.CheckLiteralKind(Literal); 7904 assert(LiteralKind != Sema::LK_Block); 7905 if (LiteralKind == Sema::LK_None) { 7906 llvm_unreachable("Unknown Objective-C object literal kind"); 7907 } 7908 7909 if (LiteralKind == Sema::LK_String) 7910 S.Diag(Loc, diag::warn_objc_string_literal_comparison) 7911 << Literal->getSourceRange(); 7912 else 7913 S.Diag(Loc, diag::warn_objc_literal_comparison) 7914 << LiteralKind << Literal->getSourceRange(); 7915 7916 if (BinaryOperator::isEqualityOp(Opc) && 7917 hasIsEqualMethod(S, LHS.get(), RHS.get())) { 7918 SourceLocation Start = LHS.get()->getLocStart(); 7919 SourceLocation End = S.PP.getLocForEndOfToken(RHS.get()->getLocEnd()); 7920 CharSourceRange OpRange = 7921 CharSourceRange::getCharRange(Loc, S.PP.getLocForEndOfToken(Loc)); 7922 7923 S.Diag(Loc, diag::note_objc_literal_comparison_isequal) 7924 << FixItHint::CreateInsertion(Start, Opc == BO_EQ ? "[" : "![") 7925 << FixItHint::CreateReplacement(OpRange, " isEqual:") 7926 << FixItHint::CreateInsertion(End, "]"); 7927 } 7928 } 7929 7930 static void diagnoseLogicalNotOnLHSofComparison(Sema &S, ExprResult &LHS, 7931 ExprResult &RHS, 7932 SourceLocation Loc, 7933 unsigned OpaqueOpc) { 7934 // This checking requires bools. 7935 if (!S.getLangOpts().Bool) return; 7936 7937 // Check that left hand side is !something. 7938 UnaryOperator *UO = dyn_cast<UnaryOperator>(LHS.get()->IgnoreImpCasts()); 7939 if (!UO || UO->getOpcode() != UO_LNot) return; 7940 7941 // Only check if the right hand side is non-bool arithmetic type. 7942 if (RHS.get()->getType()->isBooleanType()) return; 7943 7944 // Make sure that the something in !something is not bool. 7945 Expr *SubExpr = UO->getSubExpr()->IgnoreImpCasts(); 7946 if (SubExpr->getType()->isBooleanType()) return; 7947 7948 // Emit warning. 7949 S.Diag(UO->getOperatorLoc(), diag::warn_logical_not_on_lhs_of_comparison) 7950 << Loc; 7951 7952 // First note suggest !(x < y) 7953 SourceLocation FirstOpen = SubExpr->getLocStart(); 7954 SourceLocation FirstClose = RHS.get()->getLocEnd(); 7955 FirstClose = S.getPreprocessor().getLocForEndOfToken(FirstClose); 7956 if (FirstClose.isInvalid()) 7957 FirstOpen = SourceLocation(); 7958 S.Diag(UO->getOperatorLoc(), diag::note_logical_not_fix) 7959 << FixItHint::CreateInsertion(FirstOpen, "(") 7960 << FixItHint::CreateInsertion(FirstClose, ")"); 7961 7962 // Second note suggests (!x) < y 7963 SourceLocation SecondOpen = LHS.get()->getLocStart(); 7964 SourceLocation SecondClose = LHS.get()->getLocEnd(); 7965 SecondClose = S.getPreprocessor().getLocForEndOfToken(SecondClose); 7966 if (SecondClose.isInvalid()) 7967 SecondOpen = SourceLocation(); 7968 S.Diag(UO->getOperatorLoc(), diag::note_logical_not_silence_with_parens) 7969 << FixItHint::CreateInsertion(SecondOpen, "(") 7970 << FixItHint::CreateInsertion(SecondClose, ")"); 7971 } 7972 7973 // Get the decl for a simple expression: a reference to a variable, 7974 // an implicit C++ field reference, or an implicit ObjC ivar reference. 7975 static ValueDecl *getCompareDecl(Expr *E) { 7976 if (DeclRefExpr* DR = dyn_cast<DeclRefExpr>(E)) 7977 return DR->getDecl(); 7978 if (ObjCIvarRefExpr* Ivar = dyn_cast<ObjCIvarRefExpr>(E)) { 7979 if (Ivar->isFreeIvar()) 7980 return Ivar->getDecl(); 7981 } 7982 if (MemberExpr* Mem = dyn_cast<MemberExpr>(E)) { 7983 if (Mem->isImplicitAccess()) 7984 return Mem->getMemberDecl(); 7985 } 7986 return nullptr; 7987 } 7988 7989 // C99 6.5.8, C++ [expr.rel] 7990 QualType Sema::CheckCompareOperands(ExprResult &LHS, ExprResult &RHS, 7991 SourceLocation Loc, unsigned OpaqueOpc, 7992 bool IsRelational) { 7993 checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/true); 7994 7995 BinaryOperatorKind Opc = (BinaryOperatorKind) OpaqueOpc; 7996 7997 // Handle vector comparisons separately. 7998 if (LHS.get()->getType()->isVectorType() || 7999 RHS.get()->getType()->isVectorType()) 8000 return CheckVectorCompareOperands(LHS, RHS, Loc, IsRelational); 8001 8002 QualType LHSType = LHS.get()->getType(); 8003 QualType RHSType = RHS.get()->getType(); 8004 8005 Expr *LHSStripped = LHS.get()->IgnoreParenImpCasts(); 8006 Expr *RHSStripped = RHS.get()->IgnoreParenImpCasts(); 8007 8008 checkEnumComparison(*this, Loc, LHS.get(), RHS.get()); 8009 diagnoseLogicalNotOnLHSofComparison(*this, LHS, RHS, Loc, OpaqueOpc); 8010 8011 if (!LHSType->hasFloatingRepresentation() && 8012 !(LHSType->isBlockPointerType() && IsRelational) && 8013 !LHS.get()->getLocStart().isMacroID() && 8014 !RHS.get()->getLocStart().isMacroID() && 8015 ActiveTemplateInstantiations.empty()) { 8016 // For non-floating point types, check for self-comparisons of the form 8017 // x == x, x != x, x < x, etc. These always evaluate to a constant, and 8018 // often indicate logic errors in the program. 8019 // 8020 // NOTE: Don't warn about comparison expressions resulting from macro 8021 // expansion. Also don't warn about comparisons which are only self 8022 // comparisons within a template specialization. The warnings should catch 8023 // obvious cases in the definition of the template anyways. The idea is to 8024 // warn when the typed comparison operator will always evaluate to the same 8025 // result. 8026 ValueDecl *DL = getCompareDecl(LHSStripped); 8027 ValueDecl *DR = getCompareDecl(RHSStripped); 8028 if (DL && DR && DL == DR && !IsWithinTemplateSpecialization(DL)) { 8029 DiagRuntimeBehavior(Loc, nullptr, PDiag(diag::warn_comparison_always) 8030 << 0 // self- 8031 << (Opc == BO_EQ 8032 || Opc == BO_LE 8033 || Opc == BO_GE)); 8034 } else if (DL && DR && LHSType->isArrayType() && RHSType->isArrayType() && 8035 !DL->getType()->isReferenceType() && 8036 !DR->getType()->isReferenceType()) { 8037 // what is it always going to eval to? 8038 char always_evals_to; 8039 switch(Opc) { 8040 case BO_EQ: // e.g. array1 == array2 8041 always_evals_to = 0; // false 8042 break; 8043 case BO_NE: // e.g. array1 != array2 8044 always_evals_to = 1; // true 8045 break; 8046 default: 8047 // best we can say is 'a constant' 8048 always_evals_to = 2; // e.g. array1 <= array2 8049 break; 8050 } 8051 DiagRuntimeBehavior(Loc, nullptr, PDiag(diag::warn_comparison_always) 8052 << 1 // array 8053 << always_evals_to); 8054 } 8055 8056 if (isa<CastExpr>(LHSStripped)) 8057 LHSStripped = LHSStripped->IgnoreParenCasts(); 8058 if (isa<CastExpr>(RHSStripped)) 8059 RHSStripped = RHSStripped->IgnoreParenCasts(); 8060 8061 // Warn about comparisons against a string constant (unless the other 8062 // operand is null), the user probably wants strcmp. 8063 Expr *literalString = nullptr; 8064 Expr *literalStringStripped = nullptr; 8065 if ((isa<StringLiteral>(LHSStripped) || isa<ObjCEncodeExpr>(LHSStripped)) && 8066 !RHSStripped->isNullPointerConstant(Context, 8067 Expr::NPC_ValueDependentIsNull)) { 8068 literalString = LHS.get(); 8069 literalStringStripped = LHSStripped; 8070 } else if ((isa<StringLiteral>(RHSStripped) || 8071 isa<ObjCEncodeExpr>(RHSStripped)) && 8072 !LHSStripped->isNullPointerConstant(Context, 8073 Expr::NPC_ValueDependentIsNull)) { 8074 literalString = RHS.get(); 8075 literalStringStripped = RHSStripped; 8076 } 8077 8078 if (literalString) { 8079 DiagRuntimeBehavior(Loc, nullptr, 8080 PDiag(diag::warn_stringcompare) 8081 << isa<ObjCEncodeExpr>(literalStringStripped) 8082 << literalString->getSourceRange()); 8083 } 8084 } 8085 8086 // C99 6.5.8p3 / C99 6.5.9p4 8087 UsualArithmeticConversions(LHS, RHS); 8088 if (LHS.isInvalid() || RHS.isInvalid()) 8089 return QualType(); 8090 8091 LHSType = LHS.get()->getType(); 8092 RHSType = RHS.get()->getType(); 8093 8094 // The result of comparisons is 'bool' in C++, 'int' in C. 8095 QualType ResultTy = Context.getLogicalOperationType(); 8096 8097 if (IsRelational) { 8098 if (LHSType->isRealType() && RHSType->isRealType()) 8099 return ResultTy; 8100 } else { 8101 // Check for comparisons of floating point operands using != and ==. 8102 if (LHSType->hasFloatingRepresentation()) 8103 CheckFloatComparison(Loc, LHS.get(), RHS.get()); 8104 8105 if (LHSType->isArithmeticType() && RHSType->isArithmeticType()) 8106 return ResultTy; 8107 } 8108 8109 const Expr::NullPointerConstantKind LHSNullKind = 8110 LHS.get()->isNullPointerConstant(Context, Expr::NPC_ValueDependentIsNull); 8111 const Expr::NullPointerConstantKind RHSNullKind = 8112 RHS.get()->isNullPointerConstant(Context, Expr::NPC_ValueDependentIsNull); 8113 bool LHSIsNull = LHSNullKind != Expr::NPCK_NotNull; 8114 bool RHSIsNull = RHSNullKind != Expr::NPCK_NotNull; 8115 8116 if (!IsRelational && LHSIsNull != RHSIsNull) { 8117 bool IsEquality = Opc == BO_EQ; 8118 if (RHSIsNull) 8119 DiagnoseAlwaysNonNullPointer(LHS.get(), RHSNullKind, IsEquality, 8120 RHS.get()->getSourceRange()); 8121 else 8122 DiagnoseAlwaysNonNullPointer(RHS.get(), LHSNullKind, IsEquality, 8123 LHS.get()->getSourceRange()); 8124 } 8125 8126 // All of the following pointer-related warnings are GCC extensions, except 8127 // when handling null pointer constants. 8128 if (LHSType->isPointerType() && RHSType->isPointerType()) { // C99 6.5.8p2 8129 QualType LCanPointeeTy = 8130 LHSType->castAs<PointerType>()->getPointeeType().getCanonicalType(); 8131 QualType RCanPointeeTy = 8132 RHSType->castAs<PointerType>()->getPointeeType().getCanonicalType(); 8133 8134 if (getLangOpts().CPlusPlus) { 8135 if (LCanPointeeTy == RCanPointeeTy) 8136 return ResultTy; 8137 if (!IsRelational && 8138 (LCanPointeeTy->isVoidType() || RCanPointeeTy->isVoidType())) { 8139 // Valid unless comparison between non-null pointer and function pointer 8140 // This is a gcc extension compatibility comparison. 8141 // In a SFINAE context, we treat this as a hard error to maintain 8142 // conformance with the C++ standard. 8143 if ((LCanPointeeTy->isFunctionType() || RCanPointeeTy->isFunctionType()) 8144 && !LHSIsNull && !RHSIsNull) { 8145 diagnoseFunctionPointerToVoidComparison( 8146 *this, Loc, LHS, RHS, /*isError*/ (bool)isSFINAEContext()); 8147 8148 if (isSFINAEContext()) 8149 return QualType(); 8150 8151 RHS = ImpCastExprToType(RHS.get(), LHSType, CK_BitCast); 8152 return ResultTy; 8153 } 8154 } 8155 8156 if (convertPointersToCompositeType(*this, Loc, LHS, RHS)) 8157 return QualType(); 8158 else 8159 return ResultTy; 8160 } 8161 // C99 6.5.9p2 and C99 6.5.8p2 8162 if (Context.typesAreCompatible(LCanPointeeTy.getUnqualifiedType(), 8163 RCanPointeeTy.getUnqualifiedType())) { 8164 // Valid unless a relational comparison of function pointers 8165 if (IsRelational && LCanPointeeTy->isFunctionType()) { 8166 Diag(Loc, diag::ext_typecheck_ordered_comparison_of_function_pointers) 8167 << LHSType << RHSType << LHS.get()->getSourceRange() 8168 << RHS.get()->getSourceRange(); 8169 } 8170 } else if (!IsRelational && 8171 (LCanPointeeTy->isVoidType() || RCanPointeeTy->isVoidType())) { 8172 // Valid unless comparison between non-null pointer and function pointer 8173 if ((LCanPointeeTy->isFunctionType() || RCanPointeeTy->isFunctionType()) 8174 && !LHSIsNull && !RHSIsNull) 8175 diagnoseFunctionPointerToVoidComparison(*this, Loc, LHS, RHS, 8176 /*isError*/false); 8177 } else { 8178 // Invalid 8179 diagnoseDistinctPointerComparison(*this, Loc, LHS, RHS, /*isError*/false); 8180 } 8181 if (LCanPointeeTy != RCanPointeeTy) { 8182 const PointerType *lhsPtr = LHSType->getAs<PointerType>(); 8183 if (!lhsPtr->isAddressSpaceOverlapping(*RHSType->getAs<PointerType>())) { 8184 Diag(Loc, 8185 diag::err_typecheck_op_on_nonoverlapping_address_space_pointers) 8186 << LHSType << RHSType << 0 /* comparison */ 8187 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 8188 } 8189 unsigned AddrSpaceL = LCanPointeeTy.getAddressSpace(); 8190 unsigned AddrSpaceR = RCanPointeeTy.getAddressSpace(); 8191 CastKind Kind = AddrSpaceL != AddrSpaceR ? CK_AddressSpaceConversion 8192 : CK_BitCast; 8193 if (LHSIsNull && !RHSIsNull) 8194 LHS = ImpCastExprToType(LHS.get(), RHSType, Kind); 8195 else 8196 RHS = ImpCastExprToType(RHS.get(), LHSType, Kind); 8197 } 8198 return ResultTy; 8199 } 8200 8201 if (getLangOpts().CPlusPlus) { 8202 // Comparison of nullptr_t with itself. 8203 if (LHSType->isNullPtrType() && RHSType->isNullPtrType()) 8204 return ResultTy; 8205 8206 // Comparison of pointers with null pointer constants and equality 8207 // comparisons of member pointers to null pointer constants. 8208 if (RHSIsNull && 8209 ((LHSType->isAnyPointerType() || LHSType->isNullPtrType()) || 8210 (!IsRelational && 8211 (LHSType->isMemberPointerType() || LHSType->isBlockPointerType())))) { 8212 RHS = ImpCastExprToType(RHS.get(), LHSType, 8213 LHSType->isMemberPointerType() 8214 ? CK_NullToMemberPointer 8215 : CK_NullToPointer); 8216 return ResultTy; 8217 } 8218 if (LHSIsNull && 8219 ((RHSType->isAnyPointerType() || RHSType->isNullPtrType()) || 8220 (!IsRelational && 8221 (RHSType->isMemberPointerType() || RHSType->isBlockPointerType())))) { 8222 LHS = ImpCastExprToType(LHS.get(), RHSType, 8223 RHSType->isMemberPointerType() 8224 ? CK_NullToMemberPointer 8225 : CK_NullToPointer); 8226 return ResultTy; 8227 } 8228 8229 // Comparison of member pointers. 8230 if (!IsRelational && 8231 LHSType->isMemberPointerType() && RHSType->isMemberPointerType()) { 8232 if (convertPointersToCompositeType(*this, Loc, LHS, RHS)) 8233 return QualType(); 8234 else 8235 return ResultTy; 8236 } 8237 8238 // Handle scoped enumeration types specifically, since they don't promote 8239 // to integers. 8240 if (LHS.get()->getType()->isEnumeralType() && 8241 Context.hasSameUnqualifiedType(LHS.get()->getType(), 8242 RHS.get()->getType())) 8243 return ResultTy; 8244 } 8245 8246 // Handle block pointer types. 8247 if (!IsRelational && LHSType->isBlockPointerType() && 8248 RHSType->isBlockPointerType()) { 8249 QualType lpointee = LHSType->castAs<BlockPointerType>()->getPointeeType(); 8250 QualType rpointee = RHSType->castAs<BlockPointerType>()->getPointeeType(); 8251 8252 if (!LHSIsNull && !RHSIsNull && 8253 !Context.typesAreCompatible(lpointee, rpointee)) { 8254 Diag(Loc, diag::err_typecheck_comparison_of_distinct_blocks) 8255 << LHSType << RHSType << LHS.get()->getSourceRange() 8256 << RHS.get()->getSourceRange(); 8257 } 8258 RHS = ImpCastExprToType(RHS.get(), LHSType, CK_BitCast); 8259 return ResultTy; 8260 } 8261 8262 // Allow block pointers to be compared with null pointer constants. 8263 if (!IsRelational 8264 && ((LHSType->isBlockPointerType() && RHSType->isPointerType()) 8265 || (LHSType->isPointerType() && RHSType->isBlockPointerType()))) { 8266 if (!LHSIsNull && !RHSIsNull) { 8267 if (!((RHSType->isPointerType() && RHSType->castAs<PointerType>() 8268 ->getPointeeType()->isVoidType()) 8269 || (LHSType->isPointerType() && LHSType->castAs<PointerType>() 8270 ->getPointeeType()->isVoidType()))) 8271 Diag(Loc, diag::err_typecheck_comparison_of_distinct_blocks) 8272 << LHSType << RHSType << LHS.get()->getSourceRange() 8273 << RHS.get()->getSourceRange(); 8274 } 8275 if (LHSIsNull && !RHSIsNull) 8276 LHS = ImpCastExprToType(LHS.get(), RHSType, 8277 RHSType->isPointerType() ? CK_BitCast 8278 : CK_AnyPointerToBlockPointerCast); 8279 else 8280 RHS = ImpCastExprToType(RHS.get(), LHSType, 8281 LHSType->isPointerType() ? CK_BitCast 8282 : CK_AnyPointerToBlockPointerCast); 8283 return ResultTy; 8284 } 8285 8286 if (LHSType->isObjCObjectPointerType() || 8287 RHSType->isObjCObjectPointerType()) { 8288 const PointerType *LPT = LHSType->getAs<PointerType>(); 8289 const PointerType *RPT = RHSType->getAs<PointerType>(); 8290 if (LPT || RPT) { 8291 bool LPtrToVoid = LPT ? LPT->getPointeeType()->isVoidType() : false; 8292 bool RPtrToVoid = RPT ? RPT->getPointeeType()->isVoidType() : false; 8293 8294 if (!LPtrToVoid && !RPtrToVoid && 8295 !Context.typesAreCompatible(LHSType, RHSType)) { 8296 diagnoseDistinctPointerComparison(*this, Loc, LHS, RHS, 8297 /*isError*/false); 8298 } 8299 if (LHSIsNull && !RHSIsNull) { 8300 Expr *E = LHS.get(); 8301 if (getLangOpts().ObjCAutoRefCount) 8302 CheckObjCARCConversion(SourceRange(), RHSType, E, CCK_ImplicitConversion); 8303 LHS = ImpCastExprToType(E, RHSType, 8304 RPT ? CK_BitCast :CK_CPointerToObjCPointerCast); 8305 } 8306 else { 8307 Expr *E = RHS.get(); 8308 if (getLangOpts().ObjCAutoRefCount) 8309 CheckObjCARCConversion(SourceRange(), LHSType, E, CCK_ImplicitConversion, false, 8310 Opc); 8311 RHS = ImpCastExprToType(E, LHSType, 8312 LPT ? CK_BitCast :CK_CPointerToObjCPointerCast); 8313 } 8314 return ResultTy; 8315 } 8316 if (LHSType->isObjCObjectPointerType() && 8317 RHSType->isObjCObjectPointerType()) { 8318 if (!Context.areComparableObjCPointerTypes(LHSType, RHSType)) 8319 diagnoseDistinctPointerComparison(*this, Loc, LHS, RHS, 8320 /*isError*/false); 8321 if (isObjCObjectLiteral(LHS) || isObjCObjectLiteral(RHS)) 8322 diagnoseObjCLiteralComparison(*this, Loc, LHS, RHS, Opc); 8323 8324 if (LHSIsNull && !RHSIsNull) 8325 LHS = ImpCastExprToType(LHS.get(), RHSType, CK_BitCast); 8326 else 8327 RHS = ImpCastExprToType(RHS.get(), LHSType, CK_BitCast); 8328 return ResultTy; 8329 } 8330 } 8331 if ((LHSType->isAnyPointerType() && RHSType->isIntegerType()) || 8332 (LHSType->isIntegerType() && RHSType->isAnyPointerType())) { 8333 unsigned DiagID = 0; 8334 bool isError = false; 8335 if (LangOpts.DebuggerSupport) { 8336 // Under a debugger, allow the comparison of pointers to integers, 8337 // since users tend to want to compare addresses. 8338 } else if ((LHSIsNull && LHSType->isIntegerType()) || 8339 (RHSIsNull && RHSType->isIntegerType())) { 8340 if (IsRelational && !getLangOpts().CPlusPlus) 8341 DiagID = diag::ext_typecheck_ordered_comparison_of_pointer_and_zero; 8342 } else if (IsRelational && !getLangOpts().CPlusPlus) 8343 DiagID = diag::ext_typecheck_ordered_comparison_of_pointer_integer; 8344 else if (getLangOpts().CPlusPlus) { 8345 DiagID = diag::err_typecheck_comparison_of_pointer_integer; 8346 isError = true; 8347 } else 8348 DiagID = diag::ext_typecheck_comparison_of_pointer_integer; 8349 8350 if (DiagID) { 8351 Diag(Loc, DiagID) 8352 << LHSType << RHSType << LHS.get()->getSourceRange() 8353 << RHS.get()->getSourceRange(); 8354 if (isError) 8355 return QualType(); 8356 } 8357 8358 if (LHSType->isIntegerType()) 8359 LHS = ImpCastExprToType(LHS.get(), RHSType, 8360 LHSIsNull ? CK_NullToPointer : CK_IntegralToPointer); 8361 else 8362 RHS = ImpCastExprToType(RHS.get(), LHSType, 8363 RHSIsNull ? CK_NullToPointer : CK_IntegralToPointer); 8364 return ResultTy; 8365 } 8366 8367 // Handle block pointers. 8368 if (!IsRelational && RHSIsNull 8369 && LHSType->isBlockPointerType() && RHSType->isIntegerType()) { 8370 RHS = ImpCastExprToType(RHS.get(), LHSType, CK_NullToPointer); 8371 return ResultTy; 8372 } 8373 if (!IsRelational && LHSIsNull 8374 && LHSType->isIntegerType() && RHSType->isBlockPointerType()) { 8375 LHS = ImpCastExprToType(LHS.get(), RHSType, CK_NullToPointer); 8376 return ResultTy; 8377 } 8378 8379 return InvalidOperands(Loc, LHS, RHS); 8380 } 8381 8382 8383 // Return a signed type that is of identical size and number of elements. 8384 // For floating point vectors, return an integer type of identical size 8385 // and number of elements. 8386 QualType Sema::GetSignedVectorType(QualType V) { 8387 const VectorType *VTy = V->getAs<VectorType>(); 8388 unsigned TypeSize = Context.getTypeSize(VTy->getElementType()); 8389 if (TypeSize == Context.getTypeSize(Context.CharTy)) 8390 return Context.getExtVectorType(Context.CharTy, VTy->getNumElements()); 8391 else if (TypeSize == Context.getTypeSize(Context.ShortTy)) 8392 return Context.getExtVectorType(Context.ShortTy, VTy->getNumElements()); 8393 else if (TypeSize == Context.getTypeSize(Context.IntTy)) 8394 return Context.getExtVectorType(Context.IntTy, VTy->getNumElements()); 8395 else if (TypeSize == Context.getTypeSize(Context.LongTy)) 8396 return Context.getExtVectorType(Context.LongTy, VTy->getNumElements()); 8397 assert(TypeSize == Context.getTypeSize(Context.LongLongTy) && 8398 "Unhandled vector element size in vector compare"); 8399 return Context.getExtVectorType(Context.LongLongTy, VTy->getNumElements()); 8400 } 8401 8402 /// CheckVectorCompareOperands - vector comparisons are a clang extension that 8403 /// operates on extended vector types. Instead of producing an IntTy result, 8404 /// like a scalar comparison, a vector comparison produces a vector of integer 8405 /// types. 8406 QualType Sema::CheckVectorCompareOperands(ExprResult &LHS, ExprResult &RHS, 8407 SourceLocation Loc, 8408 bool IsRelational) { 8409 // Check to make sure we're operating on vectors of the same type and width, 8410 // Allowing one side to be a scalar of element type. 8411 QualType vType = CheckVectorOperands(LHS, RHS, Loc, /*isCompAssign*/false); 8412 if (vType.isNull()) 8413 return vType; 8414 8415 QualType LHSType = LHS.get()->getType(); 8416 8417 // If AltiVec, the comparison results in a numeric type, i.e. 8418 // bool for C++, int for C 8419 if (vType->getAs<VectorType>()->getVectorKind() == VectorType::AltiVecVector) 8420 return Context.getLogicalOperationType(); 8421 8422 // For non-floating point types, check for self-comparisons of the form 8423 // x == x, x != x, x < x, etc. These always evaluate to a constant, and 8424 // often indicate logic errors in the program. 8425 if (!LHSType->hasFloatingRepresentation() && 8426 ActiveTemplateInstantiations.empty()) { 8427 if (DeclRefExpr* DRL 8428 = dyn_cast<DeclRefExpr>(LHS.get()->IgnoreParenImpCasts())) 8429 if (DeclRefExpr* DRR 8430 = dyn_cast<DeclRefExpr>(RHS.get()->IgnoreParenImpCasts())) 8431 if (DRL->getDecl() == DRR->getDecl()) 8432 DiagRuntimeBehavior(Loc, nullptr, 8433 PDiag(diag::warn_comparison_always) 8434 << 0 // self- 8435 << 2 // "a constant" 8436 ); 8437 } 8438 8439 // Check for comparisons of floating point operands using != and ==. 8440 if (!IsRelational && LHSType->hasFloatingRepresentation()) { 8441 assert (RHS.get()->getType()->hasFloatingRepresentation()); 8442 CheckFloatComparison(Loc, LHS.get(), RHS.get()); 8443 } 8444 8445 // Return a signed type for the vector. 8446 return GetSignedVectorType(LHSType); 8447 } 8448 8449 QualType Sema::CheckVectorLogicalOperands(ExprResult &LHS, ExprResult &RHS, 8450 SourceLocation Loc) { 8451 // Ensure that either both operands are of the same vector type, or 8452 // one operand is of a vector type and the other is of its element type. 8453 QualType vType = CheckVectorOperands(LHS, RHS, Loc, false); 8454 if (vType.isNull()) 8455 return InvalidOperands(Loc, LHS, RHS); 8456 if (getLangOpts().OpenCL && getLangOpts().OpenCLVersion < 120 && 8457 vType->hasFloatingRepresentation()) 8458 return InvalidOperands(Loc, LHS, RHS); 8459 8460 return GetSignedVectorType(LHS.get()->getType()); 8461 } 8462 8463 inline QualType Sema::CheckBitwiseOperands( 8464 ExprResult &LHS, ExprResult &RHS, SourceLocation Loc, bool IsCompAssign) { 8465 checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false); 8466 8467 if (LHS.get()->getType()->isVectorType() || 8468 RHS.get()->getType()->isVectorType()) { 8469 if (LHS.get()->getType()->hasIntegerRepresentation() && 8470 RHS.get()->getType()->hasIntegerRepresentation()) 8471 return CheckVectorOperands(LHS, RHS, Loc, IsCompAssign); 8472 8473 return InvalidOperands(Loc, LHS, RHS); 8474 } 8475 8476 ExprResult LHSResult = LHS, RHSResult = RHS; 8477 QualType compType = UsualArithmeticConversions(LHSResult, RHSResult, 8478 IsCompAssign); 8479 if (LHSResult.isInvalid() || RHSResult.isInvalid()) 8480 return QualType(); 8481 LHS = LHSResult.get(); 8482 RHS = RHSResult.get(); 8483 8484 if (!compType.isNull() && compType->isIntegralOrUnscopedEnumerationType()) 8485 return compType; 8486 return InvalidOperands(Loc, LHS, RHS); 8487 } 8488 8489 inline QualType Sema::CheckLogicalOperands( // C99 6.5.[13,14] 8490 ExprResult &LHS, ExprResult &RHS, SourceLocation Loc, unsigned Opc) { 8491 8492 // Check vector operands differently. 8493 if (LHS.get()->getType()->isVectorType() || RHS.get()->getType()->isVectorType()) 8494 return CheckVectorLogicalOperands(LHS, RHS, Loc); 8495 8496 // Diagnose cases where the user write a logical and/or but probably meant a 8497 // bitwise one. We do this when the LHS is a non-bool integer and the RHS 8498 // is a constant. 8499 if (LHS.get()->getType()->isIntegerType() && 8500 !LHS.get()->getType()->isBooleanType() && 8501 RHS.get()->getType()->isIntegerType() && !RHS.get()->isValueDependent() && 8502 // Don't warn in macros or template instantiations. 8503 !Loc.isMacroID() && ActiveTemplateInstantiations.empty()) { 8504 // If the RHS can be constant folded, and if it constant folds to something 8505 // that isn't 0 or 1 (which indicate a potential logical operation that 8506 // happened to fold to true/false) then warn. 8507 // Parens on the RHS are ignored. 8508 llvm::APSInt Result; 8509 if (RHS.get()->EvaluateAsInt(Result, Context)) 8510 if ((getLangOpts().Bool && !RHS.get()->getType()->isBooleanType() && 8511 !RHS.get()->getExprLoc().isMacroID()) || 8512 (Result != 0 && Result != 1)) { 8513 Diag(Loc, diag::warn_logical_instead_of_bitwise) 8514 << RHS.get()->getSourceRange() 8515 << (Opc == BO_LAnd ? "&&" : "||"); 8516 // Suggest replacing the logical operator with the bitwise version 8517 Diag(Loc, diag::note_logical_instead_of_bitwise_change_operator) 8518 << (Opc == BO_LAnd ? "&" : "|") 8519 << FixItHint::CreateReplacement(SourceRange( 8520 Loc, Lexer::getLocForEndOfToken(Loc, 0, getSourceManager(), 8521 getLangOpts())), 8522 Opc == BO_LAnd ? "&" : "|"); 8523 if (Opc == BO_LAnd) 8524 // Suggest replacing "Foo() && kNonZero" with "Foo()" 8525 Diag(Loc, diag::note_logical_instead_of_bitwise_remove_constant) 8526 << FixItHint::CreateRemoval( 8527 SourceRange( 8528 Lexer::getLocForEndOfToken(LHS.get()->getLocEnd(), 8529 0, getSourceManager(), 8530 getLangOpts()), 8531 RHS.get()->getLocEnd())); 8532 } 8533 } 8534 8535 if (!Context.getLangOpts().CPlusPlus) { 8536 // OpenCL v1.1 s6.3.g: The logical operators and (&&), or (||) do 8537 // not operate on the built-in scalar and vector float types. 8538 if (Context.getLangOpts().OpenCL && 8539 Context.getLangOpts().OpenCLVersion < 120) { 8540 if (LHS.get()->getType()->isFloatingType() || 8541 RHS.get()->getType()->isFloatingType()) 8542 return InvalidOperands(Loc, LHS, RHS); 8543 } 8544 8545 LHS = UsualUnaryConversions(LHS.get()); 8546 if (LHS.isInvalid()) 8547 return QualType(); 8548 8549 RHS = UsualUnaryConversions(RHS.get()); 8550 if (RHS.isInvalid()) 8551 return QualType(); 8552 8553 if (!LHS.get()->getType()->isScalarType() || 8554 !RHS.get()->getType()->isScalarType()) 8555 return InvalidOperands(Loc, LHS, RHS); 8556 8557 return Context.IntTy; 8558 } 8559 8560 // The following is safe because we only use this method for 8561 // non-overloadable operands. 8562 8563 // C++ [expr.log.and]p1 8564 // C++ [expr.log.or]p1 8565 // The operands are both contextually converted to type bool. 8566 ExprResult LHSRes = PerformContextuallyConvertToBool(LHS.get()); 8567 if (LHSRes.isInvalid()) 8568 return InvalidOperands(Loc, LHS, RHS); 8569 LHS = LHSRes; 8570 8571 ExprResult RHSRes = PerformContextuallyConvertToBool(RHS.get()); 8572 if (RHSRes.isInvalid()) 8573 return InvalidOperands(Loc, LHS, RHS); 8574 RHS = RHSRes; 8575 8576 // C++ [expr.log.and]p2 8577 // C++ [expr.log.or]p2 8578 // The result is a bool. 8579 return Context.BoolTy; 8580 } 8581 8582 static bool IsReadonlyMessage(Expr *E, Sema &S) { 8583 const MemberExpr *ME = dyn_cast<MemberExpr>(E); 8584 if (!ME) return false; 8585 if (!isa<FieldDecl>(ME->getMemberDecl())) return false; 8586 ObjCMessageExpr *Base = 8587 dyn_cast<ObjCMessageExpr>(ME->getBase()->IgnoreParenImpCasts()); 8588 if (!Base) return false; 8589 return Base->getMethodDecl() != nullptr; 8590 } 8591 8592 /// Is the given expression (which must be 'const') a reference to a 8593 /// variable which was originally non-const, but which has become 8594 /// 'const' due to being captured within a block? 8595 enum NonConstCaptureKind { NCCK_None, NCCK_Block, NCCK_Lambda }; 8596 static NonConstCaptureKind isReferenceToNonConstCapture(Sema &S, Expr *E) { 8597 assert(E->isLValue() && E->getType().isConstQualified()); 8598 E = E->IgnoreParens(); 8599 8600 // Must be a reference to a declaration from an enclosing scope. 8601 DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E); 8602 if (!DRE) return NCCK_None; 8603 if (!DRE->refersToEnclosingVariableOrCapture()) return NCCK_None; 8604 8605 // The declaration must be a variable which is not declared 'const'. 8606 VarDecl *var = dyn_cast<VarDecl>(DRE->getDecl()); 8607 if (!var) return NCCK_None; 8608 if (var->getType().isConstQualified()) return NCCK_None; 8609 assert(var->hasLocalStorage() && "capture added 'const' to non-local?"); 8610 8611 // Decide whether the first capture was for a block or a lambda. 8612 DeclContext *DC = S.CurContext, *Prev = nullptr; 8613 while (DC != var->getDeclContext()) { 8614 Prev = DC; 8615 DC = DC->getParent(); 8616 } 8617 // Unless we have an init-capture, we've gone one step too far. 8618 if (!var->isInitCapture()) 8619 DC = Prev; 8620 return (isa<BlockDecl>(DC) ? NCCK_Block : NCCK_Lambda); 8621 } 8622 8623 /// CheckForModifiableLvalue - Verify that E is a modifiable lvalue. If not, 8624 /// emit an error and return true. If so, return false. 8625 static bool CheckForModifiableLvalue(Expr *E, SourceLocation Loc, Sema &S) { 8626 assert(!E->hasPlaceholderType(BuiltinType::PseudoObject)); 8627 SourceLocation OrigLoc = Loc; 8628 Expr::isModifiableLvalueResult IsLV = E->isModifiableLvalue(S.Context, 8629 &Loc); 8630 if (IsLV == Expr::MLV_ClassTemporary && IsReadonlyMessage(E, S)) 8631 IsLV = Expr::MLV_InvalidMessageExpression; 8632 if (IsLV == Expr::MLV_Valid) 8633 return false; 8634 8635 unsigned DiagID = 0; 8636 bool NeedType = false; 8637 switch (IsLV) { // C99 6.5.16p2 8638 case Expr::MLV_ConstQualified: 8639 DiagID = diag::err_typecheck_assign_const; 8640 8641 // Use a specialized diagnostic when we're assigning to an object 8642 // from an enclosing function or block. 8643 if (NonConstCaptureKind NCCK = isReferenceToNonConstCapture(S, E)) { 8644 if (NCCK == NCCK_Block) 8645 DiagID = diag::err_block_decl_ref_not_modifiable_lvalue; 8646 else 8647 DiagID = diag::err_lambda_decl_ref_not_modifiable_lvalue; 8648 break; 8649 } 8650 8651 // In ARC, use some specialized diagnostics for occasions where we 8652 // infer 'const'. These are always pseudo-strong variables. 8653 if (S.getLangOpts().ObjCAutoRefCount) { 8654 DeclRefExpr *declRef = dyn_cast<DeclRefExpr>(E->IgnoreParenCasts()); 8655 if (declRef && isa<VarDecl>(declRef->getDecl())) { 8656 VarDecl *var = cast<VarDecl>(declRef->getDecl()); 8657 8658 // Use the normal diagnostic if it's pseudo-__strong but the 8659 // user actually wrote 'const'. 8660 if (var->isARCPseudoStrong() && 8661 (!var->getTypeSourceInfo() || 8662 !var->getTypeSourceInfo()->getType().isConstQualified())) { 8663 // There are two pseudo-strong cases: 8664 // - self 8665 ObjCMethodDecl *method = S.getCurMethodDecl(); 8666 if (method && var == method->getSelfDecl()) 8667 DiagID = method->isClassMethod() 8668 ? diag::err_typecheck_arc_assign_self_class_method 8669 : diag::err_typecheck_arc_assign_self; 8670 8671 // - fast enumeration variables 8672 else 8673 DiagID = diag::err_typecheck_arr_assign_enumeration; 8674 8675 SourceRange Assign; 8676 if (Loc != OrigLoc) 8677 Assign = SourceRange(OrigLoc, OrigLoc); 8678 S.Diag(Loc, DiagID) << E->getSourceRange() << Assign; 8679 // We need to preserve the AST regardless, so migration tool 8680 // can do its job. 8681 return false; 8682 } 8683 } 8684 } 8685 8686 break; 8687 case Expr::MLV_ArrayType: 8688 case Expr::MLV_ArrayTemporary: 8689 DiagID = diag::err_typecheck_array_not_modifiable_lvalue; 8690 NeedType = true; 8691 break; 8692 case Expr::MLV_NotObjectType: 8693 DiagID = diag::err_typecheck_non_object_not_modifiable_lvalue; 8694 NeedType = true; 8695 break; 8696 case Expr::MLV_LValueCast: 8697 DiagID = diag::err_typecheck_lvalue_casts_not_supported; 8698 break; 8699 case Expr::MLV_Valid: 8700 llvm_unreachable("did not take early return for MLV_Valid"); 8701 case Expr::MLV_InvalidExpression: 8702 case Expr::MLV_MemberFunction: 8703 case Expr::MLV_ClassTemporary: 8704 DiagID = diag::err_typecheck_expression_not_modifiable_lvalue; 8705 break; 8706 case Expr::MLV_IncompleteType: 8707 case Expr::MLV_IncompleteVoidType: 8708 return S.RequireCompleteType(Loc, E->getType(), 8709 diag::err_typecheck_incomplete_type_not_modifiable_lvalue, E); 8710 case Expr::MLV_DuplicateVectorComponents: 8711 DiagID = diag::err_typecheck_duplicate_vector_components_not_mlvalue; 8712 break; 8713 case Expr::MLV_NoSetterProperty: 8714 llvm_unreachable("readonly properties should be processed differently"); 8715 case Expr::MLV_InvalidMessageExpression: 8716 DiagID = diag::error_readonly_message_assignment; 8717 break; 8718 case Expr::MLV_SubObjCPropertySetting: 8719 DiagID = diag::error_no_subobject_property_setting; 8720 break; 8721 } 8722 8723 SourceRange Assign; 8724 if (Loc != OrigLoc) 8725 Assign = SourceRange(OrigLoc, OrigLoc); 8726 if (NeedType) 8727 S.Diag(Loc, DiagID) << E->getType() << E->getSourceRange() << Assign; 8728 else 8729 S.Diag(Loc, DiagID) << E->getSourceRange() << Assign; 8730 return true; 8731 } 8732 8733 static void CheckIdentityFieldAssignment(Expr *LHSExpr, Expr *RHSExpr, 8734 SourceLocation Loc, 8735 Sema &Sema) { 8736 // C / C++ fields 8737 MemberExpr *ML = dyn_cast<MemberExpr>(LHSExpr); 8738 MemberExpr *MR = dyn_cast<MemberExpr>(RHSExpr); 8739 if (ML && MR && ML->getMemberDecl() == MR->getMemberDecl()) { 8740 if (isa<CXXThisExpr>(ML->getBase()) && isa<CXXThisExpr>(MR->getBase())) 8741 Sema.Diag(Loc, diag::warn_identity_field_assign) << 0; 8742 } 8743 8744 // Objective-C instance variables 8745 ObjCIvarRefExpr *OL = dyn_cast<ObjCIvarRefExpr>(LHSExpr); 8746 ObjCIvarRefExpr *OR = dyn_cast<ObjCIvarRefExpr>(RHSExpr); 8747 if (OL && OR && OL->getDecl() == OR->getDecl()) { 8748 DeclRefExpr *RL = dyn_cast<DeclRefExpr>(OL->getBase()->IgnoreImpCasts()); 8749 DeclRefExpr *RR = dyn_cast<DeclRefExpr>(OR->getBase()->IgnoreImpCasts()); 8750 if (RL && RR && RL->getDecl() == RR->getDecl()) 8751 Sema.Diag(Loc, diag::warn_identity_field_assign) << 1; 8752 } 8753 } 8754 8755 // C99 6.5.16.1 8756 QualType Sema::CheckAssignmentOperands(Expr *LHSExpr, ExprResult &RHS, 8757 SourceLocation Loc, 8758 QualType CompoundType) { 8759 assert(!LHSExpr->hasPlaceholderType(BuiltinType::PseudoObject)); 8760 8761 // Verify that LHS is a modifiable lvalue, and emit error if not. 8762 if (CheckForModifiableLvalue(LHSExpr, Loc, *this)) 8763 return QualType(); 8764 8765 QualType LHSType = LHSExpr->getType(); 8766 QualType RHSType = CompoundType.isNull() ? RHS.get()->getType() : 8767 CompoundType; 8768 AssignConvertType ConvTy; 8769 if (CompoundType.isNull()) { 8770 Expr *RHSCheck = RHS.get(); 8771 8772 CheckIdentityFieldAssignment(LHSExpr, RHSCheck, Loc, *this); 8773 8774 QualType LHSTy(LHSType); 8775 ConvTy = CheckSingleAssignmentConstraints(LHSTy, RHS); 8776 if (RHS.isInvalid()) 8777 return QualType(); 8778 // Special case of NSObject attributes on c-style pointer types. 8779 if (ConvTy == IncompatiblePointer && 8780 ((Context.isObjCNSObjectType(LHSType) && 8781 RHSType->isObjCObjectPointerType()) || 8782 (Context.isObjCNSObjectType(RHSType) && 8783 LHSType->isObjCObjectPointerType()))) 8784 ConvTy = Compatible; 8785 8786 if (ConvTy == Compatible && 8787 LHSType->isObjCObjectType()) 8788 Diag(Loc, diag::err_objc_object_assignment) 8789 << LHSType; 8790 8791 // If the RHS is a unary plus or minus, check to see if they = and + are 8792 // right next to each other. If so, the user may have typo'd "x =+ 4" 8793 // instead of "x += 4". 8794 if (ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(RHSCheck)) 8795 RHSCheck = ICE->getSubExpr(); 8796 if (UnaryOperator *UO = dyn_cast<UnaryOperator>(RHSCheck)) { 8797 if ((UO->getOpcode() == UO_Plus || 8798 UO->getOpcode() == UO_Minus) && 8799 Loc.isFileID() && UO->getOperatorLoc().isFileID() && 8800 // Only if the two operators are exactly adjacent. 8801 Loc.getLocWithOffset(1) == UO->getOperatorLoc() && 8802 // And there is a space or other character before the subexpr of the 8803 // unary +/-. We don't want to warn on "x=-1". 8804 Loc.getLocWithOffset(2) != UO->getSubExpr()->getLocStart() && 8805 UO->getSubExpr()->getLocStart().isFileID()) { 8806 Diag(Loc, diag::warn_not_compound_assign) 8807 << (UO->getOpcode() == UO_Plus ? "+" : "-") 8808 << SourceRange(UO->getOperatorLoc(), UO->getOperatorLoc()); 8809 } 8810 } 8811 8812 if (ConvTy == Compatible) { 8813 if (LHSType.getObjCLifetime() == Qualifiers::OCL_Strong) { 8814 // Warn about retain cycles where a block captures the LHS, but 8815 // not if the LHS is a simple variable into which the block is 8816 // being stored...unless that variable can be captured by reference! 8817 const Expr *InnerLHS = LHSExpr->IgnoreParenCasts(); 8818 const DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(InnerLHS); 8819 if (!DRE || DRE->getDecl()->hasAttr<BlocksAttr>()) 8820 checkRetainCycles(LHSExpr, RHS.get()); 8821 8822 // It is safe to assign a weak reference into a strong variable. 8823 // Although this code can still have problems: 8824 // id x = self.weakProp; 8825 // id y = self.weakProp; 8826 // we do not warn to warn spuriously when 'x' and 'y' are on separate 8827 // paths through the function. This should be revisited if 8828 // -Wrepeated-use-of-weak is made flow-sensitive. 8829 if (!Diags.isIgnored(diag::warn_arc_repeated_use_of_weak, 8830 RHS.get()->getLocStart())) 8831 getCurFunction()->markSafeWeakUse(RHS.get()); 8832 8833 } else if (getLangOpts().ObjCAutoRefCount) { 8834 checkUnsafeExprAssigns(Loc, LHSExpr, RHS.get()); 8835 } 8836 } 8837 } else { 8838 // Compound assignment "x += y" 8839 ConvTy = CheckAssignmentConstraints(Loc, LHSType, RHSType); 8840 } 8841 8842 if (DiagnoseAssignmentResult(ConvTy, Loc, LHSType, RHSType, 8843 RHS.get(), AA_Assigning)) 8844 return QualType(); 8845 8846 CheckForNullPointerDereference(*this, LHSExpr); 8847 8848 // C99 6.5.16p3: The type of an assignment expression is the type of the 8849 // left operand unless the left operand has qualified type, in which case 8850 // it is the unqualified version of the type of the left operand. 8851 // C99 6.5.16.1p2: In simple assignment, the value of the right operand 8852 // is converted to the type of the assignment expression (above). 8853 // C++ 5.17p1: the type of the assignment expression is that of its left 8854 // operand. 8855 return (getLangOpts().CPlusPlus 8856 ? LHSType : LHSType.getUnqualifiedType()); 8857 } 8858 8859 // C99 6.5.17 8860 static QualType CheckCommaOperands(Sema &S, ExprResult &LHS, ExprResult &RHS, 8861 SourceLocation Loc) { 8862 LHS = S.CheckPlaceholderExpr(LHS.get()); 8863 RHS = S.CheckPlaceholderExpr(RHS.get()); 8864 if (LHS.isInvalid() || RHS.isInvalid()) 8865 return QualType(); 8866 8867 // C's comma performs lvalue conversion (C99 6.3.2.1) on both its 8868 // operands, but not unary promotions. 8869 // C++'s comma does not do any conversions at all (C++ [expr.comma]p1). 8870 8871 // So we treat the LHS as a ignored value, and in C++ we allow the 8872 // containing site to determine what should be done with the RHS. 8873 LHS = S.IgnoredValueConversions(LHS.get()); 8874 if (LHS.isInvalid()) 8875 return QualType(); 8876 8877 S.DiagnoseUnusedExprResult(LHS.get()); 8878 8879 if (!S.getLangOpts().CPlusPlus) { 8880 RHS = S.DefaultFunctionArrayLvalueConversion(RHS.get()); 8881 if (RHS.isInvalid()) 8882 return QualType(); 8883 if (!RHS.get()->getType()->isVoidType()) 8884 S.RequireCompleteType(Loc, RHS.get()->getType(), 8885 diag::err_incomplete_type); 8886 } 8887 8888 return RHS.get()->getType(); 8889 } 8890 8891 /// CheckIncrementDecrementOperand - unlike most "Check" methods, this routine 8892 /// doesn't need to call UsualUnaryConversions or UsualArithmeticConversions. 8893 static QualType CheckIncrementDecrementOperand(Sema &S, Expr *Op, 8894 ExprValueKind &VK, 8895 ExprObjectKind &OK, 8896 SourceLocation OpLoc, 8897 bool IsInc, bool IsPrefix) { 8898 if (Op->isTypeDependent()) 8899 return S.Context.DependentTy; 8900 8901 QualType ResType = Op->getType(); 8902 // Atomic types can be used for increment / decrement where the non-atomic 8903 // versions can, so ignore the _Atomic() specifier for the purpose of 8904 // checking. 8905 if (const AtomicType *ResAtomicType = ResType->getAs<AtomicType>()) 8906 ResType = ResAtomicType->getValueType(); 8907 8908 assert(!ResType.isNull() && "no type for increment/decrement expression"); 8909 8910 if (S.getLangOpts().CPlusPlus && ResType->isBooleanType()) { 8911 // Decrement of bool is not allowed. 8912 if (!IsInc) { 8913 S.Diag(OpLoc, diag::err_decrement_bool) << Op->getSourceRange(); 8914 return QualType(); 8915 } 8916 // Increment of bool sets it to true, but is deprecated. 8917 S.Diag(OpLoc, diag::warn_increment_bool) << Op->getSourceRange(); 8918 } else if (S.getLangOpts().CPlusPlus && ResType->isEnumeralType()) { 8919 // Error on enum increments and decrements in C++ mode 8920 S.Diag(OpLoc, diag::err_increment_decrement_enum) << IsInc << ResType; 8921 return QualType(); 8922 } else if (ResType->isRealType()) { 8923 // OK! 8924 } else if (ResType->isPointerType()) { 8925 // C99 6.5.2.4p2, 6.5.6p2 8926 if (!checkArithmeticOpPointerOperand(S, OpLoc, Op)) 8927 return QualType(); 8928 } else if (ResType->isObjCObjectPointerType()) { 8929 // On modern runtimes, ObjC pointer arithmetic is forbidden. 8930 // Otherwise, we just need a complete type. 8931 if (checkArithmeticIncompletePointerType(S, OpLoc, Op) || 8932 checkArithmeticOnObjCPointer(S, OpLoc, Op)) 8933 return QualType(); 8934 } else if (ResType->isAnyComplexType()) { 8935 // C99 does not support ++/-- on complex types, we allow as an extension. 8936 S.Diag(OpLoc, diag::ext_integer_increment_complex) 8937 << ResType << Op->getSourceRange(); 8938 } else if (ResType->isPlaceholderType()) { 8939 ExprResult PR = S.CheckPlaceholderExpr(Op); 8940 if (PR.isInvalid()) return QualType(); 8941 return CheckIncrementDecrementOperand(S, PR.get(), VK, OK, OpLoc, 8942 IsInc, IsPrefix); 8943 } else if (S.getLangOpts().AltiVec && ResType->isVectorType()) { 8944 // OK! ( C/C++ Language Extensions for CBEA(Version 2.6) 10.3 ) 8945 } else if(S.getLangOpts().OpenCL && ResType->isVectorType() && 8946 ResType->getAs<VectorType>()->getElementType()->isIntegerType()) { 8947 // OpenCL V1.2 6.3 says dec/inc ops operate on integer vector types. 8948 } else { 8949 S.Diag(OpLoc, diag::err_typecheck_illegal_increment_decrement) 8950 << ResType << int(IsInc) << Op->getSourceRange(); 8951 return QualType(); 8952 } 8953 // At this point, we know we have a real, complex or pointer type. 8954 // Now make sure the operand is a modifiable lvalue. 8955 if (CheckForModifiableLvalue(Op, OpLoc, S)) 8956 return QualType(); 8957 // In C++, a prefix increment is the same type as the operand. Otherwise 8958 // (in C or with postfix), the increment is the unqualified type of the 8959 // operand. 8960 if (IsPrefix && S.getLangOpts().CPlusPlus) { 8961 VK = VK_LValue; 8962 OK = Op->getObjectKind(); 8963 return ResType; 8964 } else { 8965 VK = VK_RValue; 8966 return ResType.getUnqualifiedType(); 8967 } 8968 } 8969 8970 8971 /// getPrimaryDecl - Helper function for CheckAddressOfOperand(). 8972 /// This routine allows us to typecheck complex/recursive expressions 8973 /// where the declaration is needed for type checking. We only need to 8974 /// handle cases when the expression references a function designator 8975 /// or is an lvalue. Here are some examples: 8976 /// - &(x) => x 8977 /// - &*****f => f for f a function designator. 8978 /// - &s.xx => s 8979 /// - &s.zz[1].yy -> s, if zz is an array 8980 /// - *(x + 1) -> x, if x is an array 8981 /// - &"123"[2] -> 0 8982 /// - & __real__ x -> x 8983 static ValueDecl *getPrimaryDecl(Expr *E) { 8984 switch (E->getStmtClass()) { 8985 case Stmt::DeclRefExprClass: 8986 return cast<DeclRefExpr>(E)->getDecl(); 8987 case Stmt::MemberExprClass: 8988 // If this is an arrow operator, the address is an offset from 8989 // the base's value, so the object the base refers to is 8990 // irrelevant. 8991 if (cast<MemberExpr>(E)->isArrow()) 8992 return nullptr; 8993 // Otherwise, the expression refers to a part of the base 8994 return getPrimaryDecl(cast<MemberExpr>(E)->getBase()); 8995 case Stmt::ArraySubscriptExprClass: { 8996 // FIXME: This code shouldn't be necessary! We should catch the implicit 8997 // promotion of register arrays earlier. 8998 Expr* Base = cast<ArraySubscriptExpr>(E)->getBase(); 8999 if (ImplicitCastExpr* ICE = dyn_cast<ImplicitCastExpr>(Base)) { 9000 if (ICE->getSubExpr()->getType()->isArrayType()) 9001 return getPrimaryDecl(ICE->getSubExpr()); 9002 } 9003 return nullptr; 9004 } 9005 case Stmt::UnaryOperatorClass: { 9006 UnaryOperator *UO = cast<UnaryOperator>(E); 9007 9008 switch(UO->getOpcode()) { 9009 case UO_Real: 9010 case UO_Imag: 9011 case UO_Extension: 9012 return getPrimaryDecl(UO->getSubExpr()); 9013 default: 9014 return nullptr; 9015 } 9016 } 9017 case Stmt::ParenExprClass: 9018 return getPrimaryDecl(cast<ParenExpr>(E)->getSubExpr()); 9019 case Stmt::ImplicitCastExprClass: 9020 // If the result of an implicit cast is an l-value, we care about 9021 // the sub-expression; otherwise, the result here doesn't matter. 9022 return getPrimaryDecl(cast<ImplicitCastExpr>(E)->getSubExpr()); 9023 default: 9024 return nullptr; 9025 } 9026 } 9027 9028 namespace { 9029 enum { 9030 AO_Bit_Field = 0, 9031 AO_Vector_Element = 1, 9032 AO_Property_Expansion = 2, 9033 AO_Register_Variable = 3, 9034 AO_No_Error = 4 9035 }; 9036 } 9037 /// \brief Diagnose invalid operand for address of operations. 9038 /// 9039 /// \param Type The type of operand which cannot have its address taken. 9040 static void diagnoseAddressOfInvalidType(Sema &S, SourceLocation Loc, 9041 Expr *E, unsigned Type) { 9042 S.Diag(Loc, diag::err_typecheck_address_of) << Type << E->getSourceRange(); 9043 } 9044 9045 /// CheckAddressOfOperand - The operand of & must be either a function 9046 /// designator or an lvalue designating an object. If it is an lvalue, the 9047 /// object cannot be declared with storage class register or be a bit field. 9048 /// Note: The usual conversions are *not* applied to the operand of the & 9049 /// operator (C99 6.3.2.1p[2-4]), and its result is never an lvalue. 9050 /// In C++, the operand might be an overloaded function name, in which case 9051 /// we allow the '&' but retain the overloaded-function type. 9052 QualType Sema::CheckAddressOfOperand(ExprResult &OrigOp, SourceLocation OpLoc) { 9053 if (const BuiltinType *PTy = OrigOp.get()->getType()->getAsPlaceholderType()){ 9054 if (PTy->getKind() == BuiltinType::Overload) { 9055 Expr *E = OrigOp.get()->IgnoreParens(); 9056 if (!isa<OverloadExpr>(E)) { 9057 assert(cast<UnaryOperator>(E)->getOpcode() == UO_AddrOf); 9058 Diag(OpLoc, diag::err_typecheck_invalid_lvalue_addrof_addrof_function) 9059 << OrigOp.get()->getSourceRange(); 9060 return QualType(); 9061 } 9062 9063 OverloadExpr *Ovl = cast<OverloadExpr>(E); 9064 if (isa<UnresolvedMemberExpr>(Ovl)) 9065 if (!ResolveSingleFunctionTemplateSpecialization(Ovl)) { 9066 Diag(OpLoc, diag::err_invalid_form_pointer_member_function) 9067 << OrigOp.get()->getSourceRange(); 9068 return QualType(); 9069 } 9070 9071 return Context.OverloadTy; 9072 } 9073 9074 if (PTy->getKind() == BuiltinType::UnknownAny) 9075 return Context.UnknownAnyTy; 9076 9077 if (PTy->getKind() == BuiltinType::BoundMember) { 9078 Diag(OpLoc, diag::err_invalid_form_pointer_member_function) 9079 << OrigOp.get()->getSourceRange(); 9080 return QualType(); 9081 } 9082 9083 OrigOp = CheckPlaceholderExpr(OrigOp.get()); 9084 if (OrigOp.isInvalid()) return QualType(); 9085 } 9086 9087 if (OrigOp.get()->isTypeDependent()) 9088 return Context.DependentTy; 9089 9090 assert(!OrigOp.get()->getType()->isPlaceholderType()); 9091 9092 // Make sure to ignore parentheses in subsequent checks 9093 Expr *op = OrigOp.get()->IgnoreParens(); 9094 9095 // OpenCL v1.0 s6.8.a.3: Pointers to functions are not allowed. 9096 if (LangOpts.OpenCL && op->getType()->isFunctionType()) { 9097 Diag(op->getExprLoc(), diag::err_opencl_taking_function_address); 9098 return QualType(); 9099 } 9100 9101 if (getLangOpts().C99) { 9102 // Implement C99-only parts of addressof rules. 9103 if (UnaryOperator* uOp = dyn_cast<UnaryOperator>(op)) { 9104 if (uOp->getOpcode() == UO_Deref) 9105 // Per C99 6.5.3.2, the address of a deref always returns a valid result 9106 // (assuming the deref expression is valid). 9107 return uOp->getSubExpr()->getType(); 9108 } 9109 // Technically, there should be a check for array subscript 9110 // expressions here, but the result of one is always an lvalue anyway. 9111 } 9112 ValueDecl *dcl = getPrimaryDecl(op); 9113 Expr::LValueClassification lval = op->ClassifyLValue(Context); 9114 unsigned AddressOfError = AO_No_Error; 9115 9116 if (lval == Expr::LV_ClassTemporary || lval == Expr::LV_ArrayTemporary) { 9117 bool sfinae = (bool)isSFINAEContext(); 9118 Diag(OpLoc, isSFINAEContext() ? diag::err_typecheck_addrof_temporary 9119 : diag::ext_typecheck_addrof_temporary) 9120 << op->getType() << op->getSourceRange(); 9121 if (sfinae) 9122 return QualType(); 9123 // Materialize the temporary as an lvalue so that we can take its address. 9124 OrigOp = op = new (Context) 9125 MaterializeTemporaryExpr(op->getType(), OrigOp.get(), true); 9126 } else if (isa<ObjCSelectorExpr>(op)) { 9127 return Context.getPointerType(op->getType()); 9128 } else if (lval == Expr::LV_MemberFunction) { 9129 // If it's an instance method, make a member pointer. 9130 // The expression must have exactly the form &A::foo. 9131 9132 // If the underlying expression isn't a decl ref, give up. 9133 if (!isa<DeclRefExpr>(op)) { 9134 Diag(OpLoc, diag::err_invalid_form_pointer_member_function) 9135 << OrigOp.get()->getSourceRange(); 9136 return QualType(); 9137 } 9138 DeclRefExpr *DRE = cast<DeclRefExpr>(op); 9139 CXXMethodDecl *MD = cast<CXXMethodDecl>(DRE->getDecl()); 9140 9141 // The id-expression was parenthesized. 9142 if (OrigOp.get() != DRE) { 9143 Diag(OpLoc, diag::err_parens_pointer_member_function) 9144 << OrigOp.get()->getSourceRange(); 9145 9146 // The method was named without a qualifier. 9147 } else if (!DRE->getQualifier()) { 9148 if (MD->getParent()->getName().empty()) 9149 Diag(OpLoc, diag::err_unqualified_pointer_member_function) 9150 << op->getSourceRange(); 9151 else { 9152 SmallString<32> Str; 9153 StringRef Qual = (MD->getParent()->getName() + "::").toStringRef(Str); 9154 Diag(OpLoc, diag::err_unqualified_pointer_member_function) 9155 << op->getSourceRange() 9156 << FixItHint::CreateInsertion(op->getSourceRange().getBegin(), Qual); 9157 } 9158 } 9159 9160 // Taking the address of a dtor is illegal per C++ [class.dtor]p2. 9161 if (isa<CXXDestructorDecl>(MD)) 9162 Diag(OpLoc, diag::err_typecheck_addrof_dtor) << op->getSourceRange(); 9163 9164 QualType MPTy = Context.getMemberPointerType( 9165 op->getType(), Context.getTypeDeclType(MD->getParent()).getTypePtr()); 9166 if (Context.getTargetInfo().getCXXABI().isMicrosoft()) 9167 RequireCompleteType(OpLoc, MPTy, 0); 9168 return MPTy; 9169 } else if (lval != Expr::LV_Valid && lval != Expr::LV_IncompleteVoidType) { 9170 // C99 6.5.3.2p1 9171 // The operand must be either an l-value or a function designator 9172 if (!op->getType()->isFunctionType()) { 9173 // Use a special diagnostic for loads from property references. 9174 if (isa<PseudoObjectExpr>(op)) { 9175 AddressOfError = AO_Property_Expansion; 9176 } else { 9177 Diag(OpLoc, diag::err_typecheck_invalid_lvalue_addrof) 9178 << op->getType() << op->getSourceRange(); 9179 return QualType(); 9180 } 9181 } 9182 } else if (op->getObjectKind() == OK_BitField) { // C99 6.5.3.2p1 9183 // The operand cannot be a bit-field 9184 AddressOfError = AO_Bit_Field; 9185 } else if (op->getObjectKind() == OK_VectorComponent) { 9186 // The operand cannot be an element of a vector 9187 AddressOfError = AO_Vector_Element; 9188 } else if (dcl) { // C99 6.5.3.2p1 9189 // We have an lvalue with a decl. Make sure the decl is not declared 9190 // with the register storage-class specifier. 9191 if (const VarDecl *vd = dyn_cast<VarDecl>(dcl)) { 9192 // in C++ it is not error to take address of a register 9193 // variable (c++03 7.1.1P3) 9194 if (vd->getStorageClass() == SC_Register && 9195 !getLangOpts().CPlusPlus) { 9196 AddressOfError = AO_Register_Variable; 9197 } 9198 } else if (isa<FunctionTemplateDecl>(dcl)) { 9199 return Context.OverloadTy; 9200 } else if (isa<FieldDecl>(dcl) || isa<IndirectFieldDecl>(dcl)) { 9201 // Okay: we can take the address of a field. 9202 // Could be a pointer to member, though, if there is an explicit 9203 // scope qualifier for the class. 9204 if (isa<DeclRefExpr>(op) && cast<DeclRefExpr>(op)->getQualifier()) { 9205 DeclContext *Ctx = dcl->getDeclContext(); 9206 if (Ctx && Ctx->isRecord()) { 9207 if (dcl->getType()->isReferenceType()) { 9208 Diag(OpLoc, 9209 diag::err_cannot_form_pointer_to_member_of_reference_type) 9210 << dcl->getDeclName() << dcl->getType(); 9211 return QualType(); 9212 } 9213 9214 while (cast<RecordDecl>(Ctx)->isAnonymousStructOrUnion()) 9215 Ctx = Ctx->getParent(); 9216 9217 QualType MPTy = Context.getMemberPointerType( 9218 op->getType(), 9219 Context.getTypeDeclType(cast<RecordDecl>(Ctx)).getTypePtr()); 9220 if (Context.getTargetInfo().getCXXABI().isMicrosoft()) 9221 RequireCompleteType(OpLoc, MPTy, 0); 9222 return MPTy; 9223 } 9224 } 9225 } else if (!isa<FunctionDecl>(dcl) && !isa<NonTypeTemplateParmDecl>(dcl)) 9226 llvm_unreachable("Unknown/unexpected decl type"); 9227 } 9228 9229 if (AddressOfError != AO_No_Error) { 9230 diagnoseAddressOfInvalidType(*this, OpLoc, op, AddressOfError); 9231 return QualType(); 9232 } 9233 9234 if (lval == Expr::LV_IncompleteVoidType) { 9235 // Taking the address of a void variable is technically illegal, but we 9236 // allow it in cases which are otherwise valid. 9237 // Example: "extern void x; void* y = &x;". 9238 Diag(OpLoc, diag::ext_typecheck_addrof_void) << op->getSourceRange(); 9239 } 9240 9241 // If the operand has type "type", the result has type "pointer to type". 9242 if (op->getType()->isObjCObjectType()) 9243 return Context.getObjCObjectPointerType(op->getType()); 9244 return Context.getPointerType(op->getType()); 9245 } 9246 9247 static void RecordModifiableNonNullParam(Sema &S, const Expr *Exp) { 9248 const DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(Exp); 9249 if (!DRE) 9250 return; 9251 const Decl *D = DRE->getDecl(); 9252 if (!D) 9253 return; 9254 const ParmVarDecl *Param = dyn_cast<ParmVarDecl>(D); 9255 if (!Param) 9256 return; 9257 if (const FunctionDecl* FD = dyn_cast<FunctionDecl>(Param->getDeclContext())) 9258 if (!FD->hasAttr<NonNullAttr>() && !Param->hasAttr<NonNullAttr>()) 9259 return; 9260 if (FunctionScopeInfo *FD = S.getCurFunction()) 9261 if (!FD->ModifiedNonNullParams.count(Param)) 9262 FD->ModifiedNonNullParams.insert(Param); 9263 } 9264 9265 /// CheckIndirectionOperand - Type check unary indirection (prefix '*'). 9266 static QualType CheckIndirectionOperand(Sema &S, Expr *Op, ExprValueKind &VK, 9267 SourceLocation OpLoc) { 9268 if (Op->isTypeDependent()) 9269 return S.Context.DependentTy; 9270 9271 ExprResult ConvResult = S.UsualUnaryConversions(Op); 9272 if (ConvResult.isInvalid()) 9273 return QualType(); 9274 Op = ConvResult.get(); 9275 QualType OpTy = Op->getType(); 9276 QualType Result; 9277 9278 if (isa<CXXReinterpretCastExpr>(Op)) { 9279 QualType OpOrigType = Op->IgnoreParenCasts()->getType(); 9280 S.CheckCompatibleReinterpretCast(OpOrigType, OpTy, /*IsDereference*/true, 9281 Op->getSourceRange()); 9282 } 9283 9284 if (const PointerType *PT = OpTy->getAs<PointerType>()) 9285 Result = PT->getPointeeType(); 9286 else if (const ObjCObjectPointerType *OPT = 9287 OpTy->getAs<ObjCObjectPointerType>()) 9288 Result = OPT->getPointeeType(); 9289 else { 9290 ExprResult PR = S.CheckPlaceholderExpr(Op); 9291 if (PR.isInvalid()) return QualType(); 9292 if (PR.get() != Op) 9293 return CheckIndirectionOperand(S, PR.get(), VK, OpLoc); 9294 } 9295 9296 if (Result.isNull()) { 9297 S.Diag(OpLoc, diag::err_typecheck_indirection_requires_pointer) 9298 << OpTy << Op->getSourceRange(); 9299 return QualType(); 9300 } 9301 9302 // Note that per both C89 and C99, indirection is always legal, even if Result 9303 // is an incomplete type or void. It would be possible to warn about 9304 // dereferencing a void pointer, but it's completely well-defined, and such a 9305 // warning is unlikely to catch any mistakes. In C++, indirection is not valid 9306 // for pointers to 'void' but is fine for any other pointer type: 9307 // 9308 // C++ [expr.unary.op]p1: 9309 // [...] the expression to which [the unary * operator] is applied shall 9310 // be a pointer to an object type, or a pointer to a function type 9311 if (S.getLangOpts().CPlusPlus && Result->isVoidType()) 9312 S.Diag(OpLoc, diag::ext_typecheck_indirection_through_void_pointer) 9313 << OpTy << Op->getSourceRange(); 9314 9315 // Dereferences are usually l-values... 9316 VK = VK_LValue; 9317 9318 // ...except that certain expressions are never l-values in C. 9319 if (!S.getLangOpts().CPlusPlus && Result.isCForbiddenLValueType()) 9320 VK = VK_RValue; 9321 9322 return Result; 9323 } 9324 9325 BinaryOperatorKind Sema::ConvertTokenKindToBinaryOpcode(tok::TokenKind Kind) { 9326 BinaryOperatorKind Opc; 9327 switch (Kind) { 9328 default: llvm_unreachable("Unknown binop!"); 9329 case tok::periodstar: Opc = BO_PtrMemD; break; 9330 case tok::arrowstar: Opc = BO_PtrMemI; break; 9331 case tok::star: Opc = BO_Mul; break; 9332 case tok::slash: Opc = BO_Div; break; 9333 case tok::percent: Opc = BO_Rem; break; 9334 case tok::plus: Opc = BO_Add; break; 9335 case tok::minus: Opc = BO_Sub; break; 9336 case tok::lessless: Opc = BO_Shl; break; 9337 case tok::greatergreater: Opc = BO_Shr; break; 9338 case tok::lessequal: Opc = BO_LE; break; 9339 case tok::less: Opc = BO_LT; break; 9340 case tok::greaterequal: Opc = BO_GE; break; 9341 case tok::greater: Opc = BO_GT; break; 9342 case tok::exclaimequal: Opc = BO_NE; break; 9343 case tok::equalequal: Opc = BO_EQ; break; 9344 case tok::amp: Opc = BO_And; break; 9345 case tok::caret: Opc = BO_Xor; break; 9346 case tok::pipe: Opc = BO_Or; break; 9347 case tok::ampamp: Opc = BO_LAnd; break; 9348 case tok::pipepipe: Opc = BO_LOr; break; 9349 case tok::equal: Opc = BO_Assign; break; 9350 case tok::starequal: Opc = BO_MulAssign; break; 9351 case tok::slashequal: Opc = BO_DivAssign; break; 9352 case tok::percentequal: Opc = BO_RemAssign; break; 9353 case tok::plusequal: Opc = BO_AddAssign; break; 9354 case tok::minusequal: Opc = BO_SubAssign; break; 9355 case tok::lesslessequal: Opc = BO_ShlAssign; break; 9356 case tok::greatergreaterequal: Opc = BO_ShrAssign; break; 9357 case tok::ampequal: Opc = BO_AndAssign; break; 9358 case tok::caretequal: Opc = BO_XorAssign; break; 9359 case tok::pipeequal: Opc = BO_OrAssign; break; 9360 case tok::comma: Opc = BO_Comma; break; 9361 } 9362 return Opc; 9363 } 9364 9365 static inline UnaryOperatorKind ConvertTokenKindToUnaryOpcode( 9366 tok::TokenKind Kind) { 9367 UnaryOperatorKind Opc; 9368 switch (Kind) { 9369 default: llvm_unreachable("Unknown unary op!"); 9370 case tok::plusplus: Opc = UO_PreInc; break; 9371 case tok::minusminus: Opc = UO_PreDec; break; 9372 case tok::amp: Opc = UO_AddrOf; break; 9373 case tok::star: Opc = UO_Deref; break; 9374 case tok::plus: Opc = UO_Plus; break; 9375 case tok::minus: Opc = UO_Minus; break; 9376 case tok::tilde: Opc = UO_Not; break; 9377 case tok::exclaim: Opc = UO_LNot; break; 9378 case tok::kw___real: Opc = UO_Real; break; 9379 case tok::kw___imag: Opc = UO_Imag; break; 9380 case tok::kw___extension__: Opc = UO_Extension; break; 9381 } 9382 return Opc; 9383 } 9384 9385 /// DiagnoseSelfAssignment - Emits a warning if a value is assigned to itself. 9386 /// This warning is only emitted for builtin assignment operations. It is also 9387 /// suppressed in the event of macro expansions. 9388 static void DiagnoseSelfAssignment(Sema &S, Expr *LHSExpr, Expr *RHSExpr, 9389 SourceLocation OpLoc) { 9390 if (!S.ActiveTemplateInstantiations.empty()) 9391 return; 9392 if (OpLoc.isInvalid() || OpLoc.isMacroID()) 9393 return; 9394 LHSExpr = LHSExpr->IgnoreParenImpCasts(); 9395 RHSExpr = RHSExpr->IgnoreParenImpCasts(); 9396 const DeclRefExpr *LHSDeclRef = dyn_cast<DeclRefExpr>(LHSExpr); 9397 const DeclRefExpr *RHSDeclRef = dyn_cast<DeclRefExpr>(RHSExpr); 9398 if (!LHSDeclRef || !RHSDeclRef || 9399 LHSDeclRef->getLocation().isMacroID() || 9400 RHSDeclRef->getLocation().isMacroID()) 9401 return; 9402 const ValueDecl *LHSDecl = 9403 cast<ValueDecl>(LHSDeclRef->getDecl()->getCanonicalDecl()); 9404 const ValueDecl *RHSDecl = 9405 cast<ValueDecl>(RHSDeclRef->getDecl()->getCanonicalDecl()); 9406 if (LHSDecl != RHSDecl) 9407 return; 9408 if (LHSDecl->getType().isVolatileQualified()) 9409 return; 9410 if (const ReferenceType *RefTy = LHSDecl->getType()->getAs<ReferenceType>()) 9411 if (RefTy->getPointeeType().isVolatileQualified()) 9412 return; 9413 9414 S.Diag(OpLoc, diag::warn_self_assignment) 9415 << LHSDeclRef->getType() 9416 << LHSExpr->getSourceRange() << RHSExpr->getSourceRange(); 9417 } 9418 9419 /// Check if a bitwise-& is performed on an Objective-C pointer. This 9420 /// is usually indicative of introspection within the Objective-C pointer. 9421 static void checkObjCPointerIntrospection(Sema &S, ExprResult &L, ExprResult &R, 9422 SourceLocation OpLoc) { 9423 if (!S.getLangOpts().ObjC1) 9424 return; 9425 9426 const Expr *ObjCPointerExpr = nullptr, *OtherExpr = nullptr; 9427 const Expr *LHS = L.get(); 9428 const Expr *RHS = R.get(); 9429 9430 if (LHS->IgnoreParenCasts()->getType()->isObjCObjectPointerType()) { 9431 ObjCPointerExpr = LHS; 9432 OtherExpr = RHS; 9433 } 9434 else if (RHS->IgnoreParenCasts()->getType()->isObjCObjectPointerType()) { 9435 ObjCPointerExpr = RHS; 9436 OtherExpr = LHS; 9437 } 9438 9439 // This warning is deliberately made very specific to reduce false 9440 // positives with logic that uses '&' for hashing. This logic mainly 9441 // looks for code trying to introspect into tagged pointers, which 9442 // code should generally never do. 9443 if (ObjCPointerExpr && isa<IntegerLiteral>(OtherExpr->IgnoreParenCasts())) { 9444 unsigned Diag = diag::warn_objc_pointer_masking; 9445 // Determine if we are introspecting the result of performSelectorXXX. 9446 const Expr *Ex = ObjCPointerExpr->IgnoreParenCasts(); 9447 // Special case messages to -performSelector and friends, which 9448 // can return non-pointer values boxed in a pointer value. 9449 // Some clients may wish to silence warnings in this subcase. 9450 if (const ObjCMessageExpr *ME = dyn_cast<ObjCMessageExpr>(Ex)) { 9451 Selector S = ME->getSelector(); 9452 StringRef SelArg0 = S.getNameForSlot(0); 9453 if (SelArg0.startswith("performSelector")) 9454 Diag = diag::warn_objc_pointer_masking_performSelector; 9455 } 9456 9457 S.Diag(OpLoc, Diag) 9458 << ObjCPointerExpr->getSourceRange(); 9459 } 9460 } 9461 9462 /// CreateBuiltinBinOp - Creates a new built-in binary operation with 9463 /// operator @p Opc at location @c TokLoc. This routine only supports 9464 /// built-in operations; ActOnBinOp handles overloaded operators. 9465 ExprResult Sema::CreateBuiltinBinOp(SourceLocation OpLoc, 9466 BinaryOperatorKind Opc, 9467 Expr *LHSExpr, Expr *RHSExpr) { 9468 if (getLangOpts().CPlusPlus11 && isa<InitListExpr>(RHSExpr)) { 9469 // The syntax only allows initializer lists on the RHS of assignment, 9470 // so we don't need to worry about accepting invalid code for 9471 // non-assignment operators. 9472 // C++11 5.17p9: 9473 // The meaning of x = {v} [...] is that of x = T(v) [...]. The meaning 9474 // of x = {} is x = T(). 9475 InitializationKind Kind = 9476 InitializationKind::CreateDirectList(RHSExpr->getLocStart()); 9477 InitializedEntity Entity = 9478 InitializedEntity::InitializeTemporary(LHSExpr->getType()); 9479 InitializationSequence InitSeq(*this, Entity, Kind, RHSExpr); 9480 ExprResult Init = InitSeq.Perform(*this, Entity, Kind, RHSExpr); 9481 if (Init.isInvalid()) 9482 return Init; 9483 RHSExpr = Init.get(); 9484 } 9485 9486 ExprResult LHS = LHSExpr, RHS = RHSExpr; 9487 QualType ResultTy; // Result type of the binary operator. 9488 // The following two variables are used for compound assignment operators 9489 QualType CompLHSTy; // Type of LHS after promotions for computation 9490 QualType CompResultTy; // Type of computation result 9491 ExprValueKind VK = VK_RValue; 9492 ExprObjectKind OK = OK_Ordinary; 9493 9494 if (!getLangOpts().CPlusPlus) { 9495 // C cannot handle TypoExpr nodes on either side of a binop because it 9496 // doesn't handle dependent types properly, so make sure any TypoExprs have 9497 // been dealt with before checking the operands. 9498 LHS = CorrectDelayedTyposInExpr(LHSExpr); 9499 RHS = CorrectDelayedTyposInExpr(RHSExpr); 9500 if (!LHS.isUsable() || !RHS.isUsable()) 9501 return ExprError(); 9502 } 9503 9504 switch (Opc) { 9505 case BO_Assign: 9506 ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, QualType()); 9507 if (getLangOpts().CPlusPlus && 9508 LHS.get()->getObjectKind() != OK_ObjCProperty) { 9509 VK = LHS.get()->getValueKind(); 9510 OK = LHS.get()->getObjectKind(); 9511 } 9512 if (!ResultTy.isNull()) { 9513 DiagnoseSelfAssignment(*this, LHS.get(), RHS.get(), OpLoc); 9514 DiagnoseSelfMove(LHS.get(), RHS.get(), OpLoc); 9515 } 9516 RecordModifiableNonNullParam(*this, LHS.get()); 9517 break; 9518 case BO_PtrMemD: 9519 case BO_PtrMemI: 9520 ResultTy = CheckPointerToMemberOperands(LHS, RHS, VK, OpLoc, 9521 Opc == BO_PtrMemI); 9522 break; 9523 case BO_Mul: 9524 case BO_Div: 9525 ResultTy = CheckMultiplyDivideOperands(LHS, RHS, OpLoc, false, 9526 Opc == BO_Div); 9527 break; 9528 case BO_Rem: 9529 ResultTy = CheckRemainderOperands(LHS, RHS, OpLoc); 9530 break; 9531 case BO_Add: 9532 ResultTy = CheckAdditionOperands(LHS, RHS, OpLoc, Opc); 9533 break; 9534 case BO_Sub: 9535 ResultTy = CheckSubtractionOperands(LHS, RHS, OpLoc); 9536 break; 9537 case BO_Shl: 9538 case BO_Shr: 9539 ResultTy = CheckShiftOperands(LHS, RHS, OpLoc, Opc); 9540 break; 9541 case BO_LE: 9542 case BO_LT: 9543 case BO_GE: 9544 case BO_GT: 9545 ResultTy = CheckCompareOperands(LHS, RHS, OpLoc, Opc, true); 9546 break; 9547 case BO_EQ: 9548 case BO_NE: 9549 ResultTy = CheckCompareOperands(LHS, RHS, OpLoc, Opc, false); 9550 break; 9551 case BO_And: 9552 checkObjCPointerIntrospection(*this, LHS, RHS, OpLoc); 9553 case BO_Xor: 9554 case BO_Or: 9555 ResultTy = CheckBitwiseOperands(LHS, RHS, OpLoc); 9556 break; 9557 case BO_LAnd: 9558 case BO_LOr: 9559 ResultTy = CheckLogicalOperands(LHS, RHS, OpLoc, Opc); 9560 break; 9561 case BO_MulAssign: 9562 case BO_DivAssign: 9563 CompResultTy = CheckMultiplyDivideOperands(LHS, RHS, OpLoc, true, 9564 Opc == BO_DivAssign); 9565 CompLHSTy = CompResultTy; 9566 if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid()) 9567 ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy); 9568 break; 9569 case BO_RemAssign: 9570 CompResultTy = CheckRemainderOperands(LHS, RHS, OpLoc, true); 9571 CompLHSTy = CompResultTy; 9572 if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid()) 9573 ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy); 9574 break; 9575 case BO_AddAssign: 9576 CompResultTy = CheckAdditionOperands(LHS, RHS, OpLoc, Opc, &CompLHSTy); 9577 if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid()) 9578 ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy); 9579 break; 9580 case BO_SubAssign: 9581 CompResultTy = CheckSubtractionOperands(LHS, RHS, OpLoc, &CompLHSTy); 9582 if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid()) 9583 ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy); 9584 break; 9585 case BO_ShlAssign: 9586 case BO_ShrAssign: 9587 CompResultTy = CheckShiftOperands(LHS, RHS, OpLoc, Opc, true); 9588 CompLHSTy = CompResultTy; 9589 if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid()) 9590 ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy); 9591 break; 9592 case BO_AndAssign: 9593 case BO_OrAssign: // fallthrough 9594 DiagnoseSelfAssignment(*this, LHS.get(), RHS.get(), OpLoc); 9595 case BO_XorAssign: 9596 CompResultTy = CheckBitwiseOperands(LHS, RHS, OpLoc, true); 9597 CompLHSTy = CompResultTy; 9598 if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid()) 9599 ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy); 9600 break; 9601 case BO_Comma: 9602 ResultTy = CheckCommaOperands(*this, LHS, RHS, OpLoc); 9603 if (getLangOpts().CPlusPlus && !RHS.isInvalid()) { 9604 VK = RHS.get()->getValueKind(); 9605 OK = RHS.get()->getObjectKind(); 9606 } 9607 break; 9608 } 9609 if (ResultTy.isNull() || LHS.isInvalid() || RHS.isInvalid()) 9610 return ExprError(); 9611 9612 // Check for array bounds violations for both sides of the BinaryOperator 9613 CheckArrayAccess(LHS.get()); 9614 CheckArrayAccess(RHS.get()); 9615 9616 if (const ObjCIsaExpr *OISA = dyn_cast<ObjCIsaExpr>(LHS.get()->IgnoreParenCasts())) { 9617 NamedDecl *ObjectSetClass = LookupSingleName(TUScope, 9618 &Context.Idents.get("object_setClass"), 9619 SourceLocation(), LookupOrdinaryName); 9620 if (ObjectSetClass && isa<ObjCIsaExpr>(LHS.get())) { 9621 SourceLocation RHSLocEnd = PP.getLocForEndOfToken(RHS.get()->getLocEnd()); 9622 Diag(LHS.get()->getExprLoc(), diag::warn_objc_isa_assign) << 9623 FixItHint::CreateInsertion(LHS.get()->getLocStart(), "object_setClass(") << 9624 FixItHint::CreateReplacement(SourceRange(OISA->getOpLoc(), OpLoc), ",") << 9625 FixItHint::CreateInsertion(RHSLocEnd, ")"); 9626 } 9627 else 9628 Diag(LHS.get()->getExprLoc(), diag::warn_objc_isa_assign); 9629 } 9630 else if (const ObjCIvarRefExpr *OIRE = 9631 dyn_cast<ObjCIvarRefExpr>(LHS.get()->IgnoreParenCasts())) 9632 DiagnoseDirectIsaAccess(*this, OIRE, OpLoc, RHS.get()); 9633 9634 if (CompResultTy.isNull()) 9635 return new (Context) BinaryOperator(LHS.get(), RHS.get(), Opc, ResultTy, VK, 9636 OK, OpLoc, FPFeatures.fp_contract); 9637 if (getLangOpts().CPlusPlus && LHS.get()->getObjectKind() != 9638 OK_ObjCProperty) { 9639 VK = VK_LValue; 9640 OK = LHS.get()->getObjectKind(); 9641 } 9642 return new (Context) CompoundAssignOperator( 9643 LHS.get(), RHS.get(), Opc, ResultTy, VK, OK, CompLHSTy, CompResultTy, 9644 OpLoc, FPFeatures.fp_contract); 9645 } 9646 9647 /// DiagnoseBitwisePrecedence - Emit a warning when bitwise and comparison 9648 /// operators are mixed in a way that suggests that the programmer forgot that 9649 /// comparison operators have higher precedence. The most typical example of 9650 /// such code is "flags & 0x0020 != 0", which is equivalent to "flags & 1". 9651 static void DiagnoseBitwisePrecedence(Sema &Self, BinaryOperatorKind Opc, 9652 SourceLocation OpLoc, Expr *LHSExpr, 9653 Expr *RHSExpr) { 9654 BinaryOperator *LHSBO = dyn_cast<BinaryOperator>(LHSExpr); 9655 BinaryOperator *RHSBO = dyn_cast<BinaryOperator>(RHSExpr); 9656 9657 // Check that one of the sides is a comparison operator. 9658 bool isLeftComp = LHSBO && LHSBO->isComparisonOp(); 9659 bool isRightComp = RHSBO && RHSBO->isComparisonOp(); 9660 if (!isLeftComp && !isRightComp) 9661 return; 9662 9663 // Bitwise operations are sometimes used as eager logical ops. 9664 // Don't diagnose this. 9665 bool isLeftBitwise = LHSBO && LHSBO->isBitwiseOp(); 9666 bool isRightBitwise = RHSBO && RHSBO->isBitwiseOp(); 9667 if ((isLeftComp || isLeftBitwise) && (isRightComp || isRightBitwise)) 9668 return; 9669 9670 SourceRange DiagRange = isLeftComp ? SourceRange(LHSExpr->getLocStart(), 9671 OpLoc) 9672 : SourceRange(OpLoc, RHSExpr->getLocEnd()); 9673 StringRef OpStr = isLeftComp ? LHSBO->getOpcodeStr() : RHSBO->getOpcodeStr(); 9674 SourceRange ParensRange = isLeftComp ? 9675 SourceRange(LHSBO->getRHS()->getLocStart(), RHSExpr->getLocEnd()) 9676 : SourceRange(LHSExpr->getLocStart(), RHSBO->getLHS()->getLocEnd()); 9677 9678 Self.Diag(OpLoc, diag::warn_precedence_bitwise_rel) 9679 << DiagRange << BinaryOperator::getOpcodeStr(Opc) << OpStr; 9680 SuggestParentheses(Self, OpLoc, 9681 Self.PDiag(diag::note_precedence_silence) << OpStr, 9682 (isLeftComp ? LHSExpr : RHSExpr)->getSourceRange()); 9683 SuggestParentheses(Self, OpLoc, 9684 Self.PDiag(diag::note_precedence_bitwise_first) 9685 << BinaryOperator::getOpcodeStr(Opc), 9686 ParensRange); 9687 } 9688 9689 /// \brief It accepts a '&' expr that is inside a '|' one. 9690 /// Emit a diagnostic together with a fixit hint that wraps the '&' expression 9691 /// in parentheses. 9692 static void 9693 EmitDiagnosticForBitwiseAndInBitwiseOr(Sema &Self, SourceLocation OpLoc, 9694 BinaryOperator *Bop) { 9695 assert(Bop->getOpcode() == BO_And); 9696 Self.Diag(Bop->getOperatorLoc(), diag::warn_bitwise_and_in_bitwise_or) 9697 << Bop->getSourceRange() << OpLoc; 9698 SuggestParentheses(Self, Bop->getOperatorLoc(), 9699 Self.PDiag(diag::note_precedence_silence) 9700 << Bop->getOpcodeStr(), 9701 Bop->getSourceRange()); 9702 } 9703 9704 /// \brief It accepts a '&&' expr that is inside a '||' one. 9705 /// Emit a diagnostic together with a fixit hint that wraps the '&&' expression 9706 /// in parentheses. 9707 static void 9708 EmitDiagnosticForLogicalAndInLogicalOr(Sema &Self, SourceLocation OpLoc, 9709 BinaryOperator *Bop) { 9710 assert(Bop->getOpcode() == BO_LAnd); 9711 Self.Diag(Bop->getOperatorLoc(), diag::warn_logical_and_in_logical_or) 9712 << Bop->getSourceRange() << OpLoc; 9713 SuggestParentheses(Self, Bop->getOperatorLoc(), 9714 Self.PDiag(diag::note_precedence_silence) 9715 << Bop->getOpcodeStr(), 9716 Bop->getSourceRange()); 9717 } 9718 9719 /// \brief Returns true if the given expression can be evaluated as a constant 9720 /// 'true'. 9721 static bool EvaluatesAsTrue(Sema &S, Expr *E) { 9722 bool Res; 9723 return !E->isValueDependent() && 9724 E->EvaluateAsBooleanCondition(Res, S.getASTContext()) && Res; 9725 } 9726 9727 /// \brief Returns true if the given expression can be evaluated as a constant 9728 /// 'false'. 9729 static bool EvaluatesAsFalse(Sema &S, Expr *E) { 9730 bool Res; 9731 return !E->isValueDependent() && 9732 E->EvaluateAsBooleanCondition(Res, S.getASTContext()) && !Res; 9733 } 9734 9735 /// \brief Look for '&&' in the left hand of a '||' expr. 9736 static void DiagnoseLogicalAndInLogicalOrLHS(Sema &S, SourceLocation OpLoc, 9737 Expr *LHSExpr, Expr *RHSExpr) { 9738 if (BinaryOperator *Bop = dyn_cast<BinaryOperator>(LHSExpr)) { 9739 if (Bop->getOpcode() == BO_LAnd) { 9740 // If it's "a && b || 0" don't warn since the precedence doesn't matter. 9741 if (EvaluatesAsFalse(S, RHSExpr)) 9742 return; 9743 // If it's "1 && a || b" don't warn since the precedence doesn't matter. 9744 if (!EvaluatesAsTrue(S, Bop->getLHS())) 9745 return EmitDiagnosticForLogicalAndInLogicalOr(S, OpLoc, Bop); 9746 } else if (Bop->getOpcode() == BO_LOr) { 9747 if (BinaryOperator *RBop = dyn_cast<BinaryOperator>(Bop->getRHS())) { 9748 // If it's "a || b && 1 || c" we didn't warn earlier for 9749 // "a || b && 1", but warn now. 9750 if (RBop->getOpcode() == BO_LAnd && EvaluatesAsTrue(S, RBop->getRHS())) 9751 return EmitDiagnosticForLogicalAndInLogicalOr(S, OpLoc, RBop); 9752 } 9753 } 9754 } 9755 } 9756 9757 /// \brief Look for '&&' in the right hand of a '||' expr. 9758 static void DiagnoseLogicalAndInLogicalOrRHS(Sema &S, SourceLocation OpLoc, 9759 Expr *LHSExpr, Expr *RHSExpr) { 9760 if (BinaryOperator *Bop = dyn_cast<BinaryOperator>(RHSExpr)) { 9761 if (Bop->getOpcode() == BO_LAnd) { 9762 // If it's "0 || a && b" don't warn since the precedence doesn't matter. 9763 if (EvaluatesAsFalse(S, LHSExpr)) 9764 return; 9765 // If it's "a || b && 1" don't warn since the precedence doesn't matter. 9766 if (!EvaluatesAsTrue(S, Bop->getRHS())) 9767 return EmitDiagnosticForLogicalAndInLogicalOr(S, OpLoc, Bop); 9768 } 9769 } 9770 } 9771 9772 /// \brief Look for '&' in the left or right hand of a '|' expr. 9773 static void DiagnoseBitwiseAndInBitwiseOr(Sema &S, SourceLocation OpLoc, 9774 Expr *OrArg) { 9775 if (BinaryOperator *Bop = dyn_cast<BinaryOperator>(OrArg)) { 9776 if (Bop->getOpcode() == BO_And) 9777 return EmitDiagnosticForBitwiseAndInBitwiseOr(S, OpLoc, Bop); 9778 } 9779 } 9780 9781 static void DiagnoseAdditionInShift(Sema &S, SourceLocation OpLoc, 9782 Expr *SubExpr, StringRef Shift) { 9783 if (BinaryOperator *Bop = dyn_cast<BinaryOperator>(SubExpr)) { 9784 if (Bop->getOpcode() == BO_Add || Bop->getOpcode() == BO_Sub) { 9785 StringRef Op = Bop->getOpcodeStr(); 9786 S.Diag(Bop->getOperatorLoc(), diag::warn_addition_in_bitshift) 9787 << Bop->getSourceRange() << OpLoc << Shift << Op; 9788 SuggestParentheses(S, Bop->getOperatorLoc(), 9789 S.PDiag(diag::note_precedence_silence) << Op, 9790 Bop->getSourceRange()); 9791 } 9792 } 9793 } 9794 9795 static void DiagnoseShiftCompare(Sema &S, SourceLocation OpLoc, 9796 Expr *LHSExpr, Expr *RHSExpr) { 9797 CXXOperatorCallExpr *OCE = dyn_cast<CXXOperatorCallExpr>(LHSExpr); 9798 if (!OCE) 9799 return; 9800 9801 FunctionDecl *FD = OCE->getDirectCallee(); 9802 if (!FD || !FD->isOverloadedOperator()) 9803 return; 9804 9805 OverloadedOperatorKind Kind = FD->getOverloadedOperator(); 9806 if (Kind != OO_LessLess && Kind != OO_GreaterGreater) 9807 return; 9808 9809 S.Diag(OpLoc, diag::warn_overloaded_shift_in_comparison) 9810 << LHSExpr->getSourceRange() << RHSExpr->getSourceRange() 9811 << (Kind == OO_LessLess); 9812 SuggestParentheses(S, OCE->getOperatorLoc(), 9813 S.PDiag(diag::note_precedence_silence) 9814 << (Kind == OO_LessLess ? "<<" : ">>"), 9815 OCE->getSourceRange()); 9816 SuggestParentheses(S, OpLoc, 9817 S.PDiag(diag::note_evaluate_comparison_first), 9818 SourceRange(OCE->getArg(1)->getLocStart(), 9819 RHSExpr->getLocEnd())); 9820 } 9821 9822 /// DiagnoseBinOpPrecedence - Emit warnings for expressions with tricky 9823 /// precedence. 9824 static void DiagnoseBinOpPrecedence(Sema &Self, BinaryOperatorKind Opc, 9825 SourceLocation OpLoc, Expr *LHSExpr, 9826 Expr *RHSExpr){ 9827 // Diagnose "arg1 'bitwise' arg2 'eq' arg3". 9828 if (BinaryOperator::isBitwiseOp(Opc)) 9829 DiagnoseBitwisePrecedence(Self, Opc, OpLoc, LHSExpr, RHSExpr); 9830 9831 // Diagnose "arg1 & arg2 | arg3" 9832 if (Opc == BO_Or && !OpLoc.isMacroID()/* Don't warn in macros. */) { 9833 DiagnoseBitwiseAndInBitwiseOr(Self, OpLoc, LHSExpr); 9834 DiagnoseBitwiseAndInBitwiseOr(Self, OpLoc, RHSExpr); 9835 } 9836 9837 // Warn about arg1 || arg2 && arg3, as GCC 4.3+ does. 9838 // We don't warn for 'assert(a || b && "bad")' since this is safe. 9839 if (Opc == BO_LOr && !OpLoc.isMacroID()/* Don't warn in macros. */) { 9840 DiagnoseLogicalAndInLogicalOrLHS(Self, OpLoc, LHSExpr, RHSExpr); 9841 DiagnoseLogicalAndInLogicalOrRHS(Self, OpLoc, LHSExpr, RHSExpr); 9842 } 9843 9844 if ((Opc == BO_Shl && LHSExpr->getType()->isIntegralType(Self.getASTContext())) 9845 || Opc == BO_Shr) { 9846 StringRef Shift = BinaryOperator::getOpcodeStr(Opc); 9847 DiagnoseAdditionInShift(Self, OpLoc, LHSExpr, Shift); 9848 DiagnoseAdditionInShift(Self, OpLoc, RHSExpr, Shift); 9849 } 9850 9851 // Warn on overloaded shift operators and comparisons, such as: 9852 // cout << 5 == 4; 9853 if (BinaryOperator::isComparisonOp(Opc)) 9854 DiagnoseShiftCompare(Self, OpLoc, LHSExpr, RHSExpr); 9855 } 9856 9857 // Binary Operators. 'Tok' is the token for the operator. 9858 ExprResult Sema::ActOnBinOp(Scope *S, SourceLocation TokLoc, 9859 tok::TokenKind Kind, 9860 Expr *LHSExpr, Expr *RHSExpr) { 9861 BinaryOperatorKind Opc = ConvertTokenKindToBinaryOpcode(Kind); 9862 assert(LHSExpr && "ActOnBinOp(): missing left expression"); 9863 assert(RHSExpr && "ActOnBinOp(): missing right expression"); 9864 9865 // Emit warnings for tricky precedence issues, e.g. "bitfield & 0x4 == 0" 9866 DiagnoseBinOpPrecedence(*this, Opc, TokLoc, LHSExpr, RHSExpr); 9867 9868 return BuildBinOp(S, TokLoc, Opc, LHSExpr, RHSExpr); 9869 } 9870 9871 /// Build an overloaded binary operator expression in the given scope. 9872 static ExprResult BuildOverloadedBinOp(Sema &S, Scope *Sc, SourceLocation OpLoc, 9873 BinaryOperatorKind Opc, 9874 Expr *LHS, Expr *RHS) { 9875 // Find all of the overloaded operators visible from this 9876 // point. We perform both an operator-name lookup from the local 9877 // scope and an argument-dependent lookup based on the types of 9878 // the arguments. 9879 UnresolvedSet<16> Functions; 9880 OverloadedOperatorKind OverOp 9881 = BinaryOperator::getOverloadedOperator(Opc); 9882 if (Sc && OverOp != OO_None && OverOp != OO_Equal) 9883 S.LookupOverloadedOperatorName(OverOp, Sc, LHS->getType(), 9884 RHS->getType(), Functions); 9885 9886 // Build the (potentially-overloaded, potentially-dependent) 9887 // binary operation. 9888 return S.CreateOverloadedBinOp(OpLoc, Opc, Functions, LHS, RHS); 9889 } 9890 9891 ExprResult Sema::BuildBinOp(Scope *S, SourceLocation OpLoc, 9892 BinaryOperatorKind Opc, 9893 Expr *LHSExpr, Expr *RHSExpr) { 9894 // We want to end up calling one of checkPseudoObjectAssignment 9895 // (if the LHS is a pseudo-object), BuildOverloadedBinOp (if 9896 // both expressions are overloadable or either is type-dependent), 9897 // or CreateBuiltinBinOp (in any other case). We also want to get 9898 // any placeholder types out of the way. 9899 9900 // Handle pseudo-objects in the LHS. 9901 if (const BuiltinType *pty = LHSExpr->getType()->getAsPlaceholderType()) { 9902 // Assignments with a pseudo-object l-value need special analysis. 9903 if (pty->getKind() == BuiltinType::PseudoObject && 9904 BinaryOperator::isAssignmentOp(Opc)) 9905 return checkPseudoObjectAssignment(S, OpLoc, Opc, LHSExpr, RHSExpr); 9906 9907 // Don't resolve overloads if the other type is overloadable. 9908 if (pty->getKind() == BuiltinType::Overload) { 9909 // We can't actually test that if we still have a placeholder, 9910 // though. Fortunately, none of the exceptions we see in that 9911 // code below are valid when the LHS is an overload set. Note 9912 // that an overload set can be dependently-typed, but it never 9913 // instantiates to having an overloadable type. 9914 ExprResult resolvedRHS = CheckPlaceholderExpr(RHSExpr); 9915 if (resolvedRHS.isInvalid()) return ExprError(); 9916 RHSExpr = resolvedRHS.get(); 9917 9918 if (RHSExpr->isTypeDependent() || 9919 RHSExpr->getType()->isOverloadableType()) 9920 return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr); 9921 } 9922 9923 ExprResult LHS = CheckPlaceholderExpr(LHSExpr); 9924 if (LHS.isInvalid()) return ExprError(); 9925 LHSExpr = LHS.get(); 9926 } 9927 9928 // Handle pseudo-objects in the RHS. 9929 if (const BuiltinType *pty = RHSExpr->getType()->getAsPlaceholderType()) { 9930 // An overload in the RHS can potentially be resolved by the type 9931 // being assigned to. 9932 if (Opc == BO_Assign && pty->getKind() == BuiltinType::Overload) { 9933 if (LHSExpr->isTypeDependent() || RHSExpr->isTypeDependent()) 9934 return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr); 9935 9936 if (LHSExpr->getType()->isOverloadableType()) 9937 return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr); 9938 9939 return CreateBuiltinBinOp(OpLoc, Opc, LHSExpr, RHSExpr); 9940 } 9941 9942 // Don't resolve overloads if the other type is overloadable. 9943 if (pty->getKind() == BuiltinType::Overload && 9944 LHSExpr->getType()->isOverloadableType()) 9945 return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr); 9946 9947 ExprResult resolvedRHS = CheckPlaceholderExpr(RHSExpr); 9948 if (!resolvedRHS.isUsable()) return ExprError(); 9949 RHSExpr = resolvedRHS.get(); 9950 } 9951 9952 if (getLangOpts().CPlusPlus) { 9953 // If either expression is type-dependent, always build an 9954 // overloaded op. 9955 if (LHSExpr->isTypeDependent() || RHSExpr->isTypeDependent()) 9956 return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr); 9957 9958 // Otherwise, build an overloaded op if either expression has an 9959 // overloadable type. 9960 if (LHSExpr->getType()->isOverloadableType() || 9961 RHSExpr->getType()->isOverloadableType()) 9962 return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr); 9963 } 9964 9965 // Build a built-in binary operation. 9966 return CreateBuiltinBinOp(OpLoc, Opc, LHSExpr, RHSExpr); 9967 } 9968 9969 ExprResult Sema::CreateBuiltinUnaryOp(SourceLocation OpLoc, 9970 UnaryOperatorKind Opc, 9971 Expr *InputExpr) { 9972 ExprResult Input = InputExpr; 9973 ExprValueKind VK = VK_RValue; 9974 ExprObjectKind OK = OK_Ordinary; 9975 QualType resultType; 9976 switch (Opc) { 9977 case UO_PreInc: 9978 case UO_PreDec: 9979 case UO_PostInc: 9980 case UO_PostDec: 9981 resultType = CheckIncrementDecrementOperand(*this, Input.get(), VK, OK, 9982 OpLoc, 9983 Opc == UO_PreInc || 9984 Opc == UO_PostInc, 9985 Opc == UO_PreInc || 9986 Opc == UO_PreDec); 9987 break; 9988 case UO_AddrOf: 9989 resultType = CheckAddressOfOperand(Input, OpLoc); 9990 RecordModifiableNonNullParam(*this, InputExpr); 9991 break; 9992 case UO_Deref: { 9993 Input = DefaultFunctionArrayLvalueConversion(Input.get()); 9994 if (Input.isInvalid()) return ExprError(); 9995 resultType = CheckIndirectionOperand(*this, Input.get(), VK, OpLoc); 9996 break; 9997 } 9998 case UO_Plus: 9999 case UO_Minus: 10000 Input = UsualUnaryConversions(Input.get()); 10001 if (Input.isInvalid()) return ExprError(); 10002 resultType = Input.get()->getType(); 10003 if (resultType->isDependentType()) 10004 break; 10005 if (resultType->isArithmeticType() || // C99 6.5.3.3p1 10006 resultType->isVectorType()) 10007 break; 10008 else if (getLangOpts().CPlusPlus && // C++ [expr.unary.op]p6 10009 Opc == UO_Plus && 10010 resultType->isPointerType()) 10011 break; 10012 10013 return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr) 10014 << resultType << Input.get()->getSourceRange()); 10015 10016 case UO_Not: // bitwise complement 10017 Input = UsualUnaryConversions(Input.get()); 10018 if (Input.isInvalid()) 10019 return ExprError(); 10020 resultType = Input.get()->getType(); 10021 if (resultType->isDependentType()) 10022 break; 10023 // C99 6.5.3.3p1. We allow complex int and float as a GCC extension. 10024 if (resultType->isComplexType() || resultType->isComplexIntegerType()) 10025 // C99 does not support '~' for complex conjugation. 10026 Diag(OpLoc, diag::ext_integer_complement_complex) 10027 << resultType << Input.get()->getSourceRange(); 10028 else if (resultType->hasIntegerRepresentation()) 10029 break; 10030 else if (resultType->isExtVectorType()) { 10031 if (Context.getLangOpts().OpenCL) { 10032 // OpenCL v1.1 s6.3.f: The bitwise operator not (~) does not operate 10033 // on vector float types. 10034 QualType T = resultType->getAs<ExtVectorType>()->getElementType(); 10035 if (!T->isIntegerType()) 10036 return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr) 10037 << resultType << Input.get()->getSourceRange()); 10038 } 10039 break; 10040 } else { 10041 return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr) 10042 << resultType << Input.get()->getSourceRange()); 10043 } 10044 break; 10045 10046 case UO_LNot: // logical negation 10047 // Unlike +/-/~, integer promotions aren't done here (C99 6.5.3.3p5). 10048 Input = DefaultFunctionArrayLvalueConversion(Input.get()); 10049 if (Input.isInvalid()) return ExprError(); 10050 resultType = Input.get()->getType(); 10051 10052 // Though we still have to promote half FP to float... 10053 if (resultType->isHalfType() && !Context.getLangOpts().NativeHalfType) { 10054 Input = ImpCastExprToType(Input.get(), Context.FloatTy, CK_FloatingCast).get(); 10055 resultType = Context.FloatTy; 10056 } 10057 10058 if (resultType->isDependentType()) 10059 break; 10060 if (resultType->isScalarType() && !isScopedEnumerationType(resultType)) { 10061 // C99 6.5.3.3p1: ok, fallthrough; 10062 if (Context.getLangOpts().CPlusPlus) { 10063 // C++03 [expr.unary.op]p8, C++0x [expr.unary.op]p9: 10064 // operand contextually converted to bool. 10065 Input = ImpCastExprToType(Input.get(), Context.BoolTy, 10066 ScalarTypeToBooleanCastKind(resultType)); 10067 } else if (Context.getLangOpts().OpenCL && 10068 Context.getLangOpts().OpenCLVersion < 120) { 10069 // OpenCL v1.1 6.3.h: The logical operator not (!) does not 10070 // operate on scalar float types. 10071 if (!resultType->isIntegerType()) 10072 return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr) 10073 << resultType << Input.get()->getSourceRange()); 10074 } 10075 } else if (resultType->isExtVectorType()) { 10076 if (Context.getLangOpts().OpenCL && 10077 Context.getLangOpts().OpenCLVersion < 120) { 10078 // OpenCL v1.1 6.3.h: The logical operator not (!) does not 10079 // operate on vector float types. 10080 QualType T = resultType->getAs<ExtVectorType>()->getElementType(); 10081 if (!T->isIntegerType()) 10082 return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr) 10083 << resultType << Input.get()->getSourceRange()); 10084 } 10085 // Vector logical not returns the signed variant of the operand type. 10086 resultType = GetSignedVectorType(resultType); 10087 break; 10088 } else { 10089 return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr) 10090 << resultType << Input.get()->getSourceRange()); 10091 } 10092 10093 // LNot always has type int. C99 6.5.3.3p5. 10094 // In C++, it's bool. C++ 5.3.1p8 10095 resultType = Context.getLogicalOperationType(); 10096 break; 10097 case UO_Real: 10098 case UO_Imag: 10099 resultType = CheckRealImagOperand(*this, Input, OpLoc, Opc == UO_Real); 10100 // _Real maps ordinary l-values into ordinary l-values. _Imag maps ordinary 10101 // complex l-values to ordinary l-values and all other values to r-values. 10102 if (Input.isInvalid()) return ExprError(); 10103 if (Opc == UO_Real || Input.get()->getType()->isAnyComplexType()) { 10104 if (Input.get()->getValueKind() != VK_RValue && 10105 Input.get()->getObjectKind() == OK_Ordinary) 10106 VK = Input.get()->getValueKind(); 10107 } else if (!getLangOpts().CPlusPlus) { 10108 // In C, a volatile scalar is read by __imag. In C++, it is not. 10109 Input = DefaultLvalueConversion(Input.get()); 10110 } 10111 break; 10112 case UO_Extension: 10113 resultType = Input.get()->getType(); 10114 VK = Input.get()->getValueKind(); 10115 OK = Input.get()->getObjectKind(); 10116 break; 10117 } 10118 if (resultType.isNull() || Input.isInvalid()) 10119 return ExprError(); 10120 10121 // Check for array bounds violations in the operand of the UnaryOperator, 10122 // except for the '*' and '&' operators that have to be handled specially 10123 // by CheckArrayAccess (as there are special cases like &array[arraysize] 10124 // that are explicitly defined as valid by the standard). 10125 if (Opc != UO_AddrOf && Opc != UO_Deref) 10126 CheckArrayAccess(Input.get()); 10127 10128 return new (Context) 10129 UnaryOperator(Input.get(), Opc, resultType, VK, OK, OpLoc); 10130 } 10131 10132 /// \brief Determine whether the given expression is a qualified member 10133 /// access expression, of a form that could be turned into a pointer to member 10134 /// with the address-of operator. 10135 static bool isQualifiedMemberAccess(Expr *E) { 10136 if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E)) { 10137 if (!DRE->getQualifier()) 10138 return false; 10139 10140 ValueDecl *VD = DRE->getDecl(); 10141 if (!VD->isCXXClassMember()) 10142 return false; 10143 10144 if (isa<FieldDecl>(VD) || isa<IndirectFieldDecl>(VD)) 10145 return true; 10146 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(VD)) 10147 return Method->isInstance(); 10148 10149 return false; 10150 } 10151 10152 if (UnresolvedLookupExpr *ULE = dyn_cast<UnresolvedLookupExpr>(E)) { 10153 if (!ULE->getQualifier()) 10154 return false; 10155 10156 for (UnresolvedLookupExpr::decls_iterator D = ULE->decls_begin(), 10157 DEnd = ULE->decls_end(); 10158 D != DEnd; ++D) { 10159 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(*D)) { 10160 if (Method->isInstance()) 10161 return true; 10162 } else { 10163 // Overload set does not contain methods. 10164 break; 10165 } 10166 } 10167 10168 return false; 10169 } 10170 10171 return false; 10172 } 10173 10174 ExprResult Sema::BuildUnaryOp(Scope *S, SourceLocation OpLoc, 10175 UnaryOperatorKind Opc, Expr *Input) { 10176 // First things first: handle placeholders so that the 10177 // overloaded-operator check considers the right type. 10178 if (const BuiltinType *pty = Input->getType()->getAsPlaceholderType()) { 10179 // Increment and decrement of pseudo-object references. 10180 if (pty->getKind() == BuiltinType::PseudoObject && 10181 UnaryOperator::isIncrementDecrementOp(Opc)) 10182 return checkPseudoObjectIncDec(S, OpLoc, Opc, Input); 10183 10184 // extension is always a builtin operator. 10185 if (Opc == UO_Extension) 10186 return CreateBuiltinUnaryOp(OpLoc, Opc, Input); 10187 10188 // & gets special logic for several kinds of placeholder. 10189 // The builtin code knows what to do. 10190 if (Opc == UO_AddrOf && 10191 (pty->getKind() == BuiltinType::Overload || 10192 pty->getKind() == BuiltinType::UnknownAny || 10193 pty->getKind() == BuiltinType::BoundMember)) 10194 return CreateBuiltinUnaryOp(OpLoc, Opc, Input); 10195 10196 // Anything else needs to be handled now. 10197 ExprResult Result = CheckPlaceholderExpr(Input); 10198 if (Result.isInvalid()) return ExprError(); 10199 Input = Result.get(); 10200 } 10201 10202 if (getLangOpts().CPlusPlus && Input->getType()->isOverloadableType() && 10203 UnaryOperator::getOverloadedOperator(Opc) != OO_None && 10204 !(Opc == UO_AddrOf && isQualifiedMemberAccess(Input))) { 10205 // Find all of the overloaded operators visible from this 10206 // point. We perform both an operator-name lookup from the local 10207 // scope and an argument-dependent lookup based on the types of 10208 // the arguments. 10209 UnresolvedSet<16> Functions; 10210 OverloadedOperatorKind OverOp = UnaryOperator::getOverloadedOperator(Opc); 10211 if (S && OverOp != OO_None) 10212 LookupOverloadedOperatorName(OverOp, S, Input->getType(), QualType(), 10213 Functions); 10214 10215 return CreateOverloadedUnaryOp(OpLoc, Opc, Functions, Input); 10216 } 10217 10218 return CreateBuiltinUnaryOp(OpLoc, Opc, Input); 10219 } 10220 10221 // Unary Operators. 'Tok' is the token for the operator. 10222 ExprResult Sema::ActOnUnaryOp(Scope *S, SourceLocation OpLoc, 10223 tok::TokenKind Op, Expr *Input) { 10224 return BuildUnaryOp(S, OpLoc, ConvertTokenKindToUnaryOpcode(Op), Input); 10225 } 10226 10227 /// ActOnAddrLabel - Parse the GNU address of label extension: "&&foo". 10228 ExprResult Sema::ActOnAddrLabel(SourceLocation OpLoc, SourceLocation LabLoc, 10229 LabelDecl *TheDecl) { 10230 TheDecl->markUsed(Context); 10231 // Create the AST node. The address of a label always has type 'void*'. 10232 return new (Context) AddrLabelExpr(OpLoc, LabLoc, TheDecl, 10233 Context.getPointerType(Context.VoidTy)); 10234 } 10235 10236 /// Given the last statement in a statement-expression, check whether 10237 /// the result is a producing expression (like a call to an 10238 /// ns_returns_retained function) and, if so, rebuild it to hoist the 10239 /// release out of the full-expression. Otherwise, return null. 10240 /// Cannot fail. 10241 static Expr *maybeRebuildARCConsumingStmt(Stmt *Statement) { 10242 // Should always be wrapped with one of these. 10243 ExprWithCleanups *cleanups = dyn_cast<ExprWithCleanups>(Statement); 10244 if (!cleanups) return nullptr; 10245 10246 ImplicitCastExpr *cast = dyn_cast<ImplicitCastExpr>(cleanups->getSubExpr()); 10247 if (!cast || cast->getCastKind() != CK_ARCConsumeObject) 10248 return nullptr; 10249 10250 // Splice out the cast. This shouldn't modify any interesting 10251 // features of the statement. 10252 Expr *producer = cast->getSubExpr(); 10253 assert(producer->getType() == cast->getType()); 10254 assert(producer->getValueKind() == cast->getValueKind()); 10255 cleanups->setSubExpr(producer); 10256 return cleanups; 10257 } 10258 10259 void Sema::ActOnStartStmtExpr() { 10260 PushExpressionEvaluationContext(ExprEvalContexts.back().Context); 10261 } 10262 10263 void Sema::ActOnStmtExprError() { 10264 // Note that function is also called by TreeTransform when leaving a 10265 // StmtExpr scope without rebuilding anything. 10266 10267 DiscardCleanupsInEvaluationContext(); 10268 PopExpressionEvaluationContext(); 10269 } 10270 10271 ExprResult 10272 Sema::ActOnStmtExpr(SourceLocation LPLoc, Stmt *SubStmt, 10273 SourceLocation RPLoc) { // "({..})" 10274 assert(SubStmt && isa<CompoundStmt>(SubStmt) && "Invalid action invocation!"); 10275 CompoundStmt *Compound = cast<CompoundStmt>(SubStmt); 10276 10277 if (hasAnyUnrecoverableErrorsInThisFunction()) 10278 DiscardCleanupsInEvaluationContext(); 10279 assert(!ExprNeedsCleanups && "cleanups within StmtExpr not correctly bound!"); 10280 PopExpressionEvaluationContext(); 10281 10282 // FIXME: there are a variety of strange constraints to enforce here, for 10283 // example, it is not possible to goto into a stmt expression apparently. 10284 // More semantic analysis is needed. 10285 10286 // If there are sub-stmts in the compound stmt, take the type of the last one 10287 // as the type of the stmtexpr. 10288 QualType Ty = Context.VoidTy; 10289 bool StmtExprMayBindToTemp = false; 10290 if (!Compound->body_empty()) { 10291 Stmt *LastStmt = Compound->body_back(); 10292 LabelStmt *LastLabelStmt = nullptr; 10293 // If LastStmt is a label, skip down through into the body. 10294 while (LabelStmt *Label = dyn_cast<LabelStmt>(LastStmt)) { 10295 LastLabelStmt = Label; 10296 LastStmt = Label->getSubStmt(); 10297 } 10298 10299 if (Expr *LastE = dyn_cast<Expr>(LastStmt)) { 10300 // Do function/array conversion on the last expression, but not 10301 // lvalue-to-rvalue. However, initialize an unqualified type. 10302 ExprResult LastExpr = DefaultFunctionArrayConversion(LastE); 10303 if (LastExpr.isInvalid()) 10304 return ExprError(); 10305 Ty = LastExpr.get()->getType().getUnqualifiedType(); 10306 10307 if (!Ty->isDependentType() && !LastExpr.get()->isTypeDependent()) { 10308 // In ARC, if the final expression ends in a consume, splice 10309 // the consume out and bind it later. In the alternate case 10310 // (when dealing with a retainable type), the result 10311 // initialization will create a produce. In both cases the 10312 // result will be +1, and we'll need to balance that out with 10313 // a bind. 10314 if (Expr *rebuiltLastStmt 10315 = maybeRebuildARCConsumingStmt(LastExpr.get())) { 10316 LastExpr = rebuiltLastStmt; 10317 } else { 10318 LastExpr = PerformCopyInitialization( 10319 InitializedEntity::InitializeResult(LPLoc, 10320 Ty, 10321 false), 10322 SourceLocation(), 10323 LastExpr); 10324 } 10325 10326 if (LastExpr.isInvalid()) 10327 return ExprError(); 10328 if (LastExpr.get() != nullptr) { 10329 if (!LastLabelStmt) 10330 Compound->setLastStmt(LastExpr.get()); 10331 else 10332 LastLabelStmt->setSubStmt(LastExpr.get()); 10333 StmtExprMayBindToTemp = true; 10334 } 10335 } 10336 } 10337 } 10338 10339 // FIXME: Check that expression type is complete/non-abstract; statement 10340 // expressions are not lvalues. 10341 Expr *ResStmtExpr = new (Context) StmtExpr(Compound, Ty, LPLoc, RPLoc); 10342 if (StmtExprMayBindToTemp) 10343 return MaybeBindToTemporary(ResStmtExpr); 10344 return ResStmtExpr; 10345 } 10346 10347 ExprResult Sema::BuildBuiltinOffsetOf(SourceLocation BuiltinLoc, 10348 TypeSourceInfo *TInfo, 10349 OffsetOfComponent *CompPtr, 10350 unsigned NumComponents, 10351 SourceLocation RParenLoc) { 10352 QualType ArgTy = TInfo->getType(); 10353 bool Dependent = ArgTy->isDependentType(); 10354 SourceRange TypeRange = TInfo->getTypeLoc().getLocalSourceRange(); 10355 10356 // We must have at least one component that refers to the type, and the first 10357 // one is known to be a field designator. Verify that the ArgTy represents 10358 // a struct/union/class. 10359 if (!Dependent && !ArgTy->isRecordType()) 10360 return ExprError(Diag(BuiltinLoc, diag::err_offsetof_record_type) 10361 << ArgTy << TypeRange); 10362 10363 // Type must be complete per C99 7.17p3 because a declaring a variable 10364 // with an incomplete type would be ill-formed. 10365 if (!Dependent 10366 && RequireCompleteType(BuiltinLoc, ArgTy, 10367 diag::err_offsetof_incomplete_type, TypeRange)) 10368 return ExprError(); 10369 10370 // offsetof with non-identifier designators (e.g. "offsetof(x, a.b[c])") are a 10371 // GCC extension, diagnose them. 10372 // FIXME: This diagnostic isn't actually visible because the location is in 10373 // a system header! 10374 if (NumComponents != 1) 10375 Diag(BuiltinLoc, diag::ext_offsetof_extended_field_designator) 10376 << SourceRange(CompPtr[1].LocStart, CompPtr[NumComponents-1].LocEnd); 10377 10378 bool DidWarnAboutNonPOD = false; 10379 QualType CurrentType = ArgTy; 10380 typedef OffsetOfExpr::OffsetOfNode OffsetOfNode; 10381 SmallVector<OffsetOfNode, 4> Comps; 10382 SmallVector<Expr*, 4> Exprs; 10383 for (unsigned i = 0; i != NumComponents; ++i) { 10384 const OffsetOfComponent &OC = CompPtr[i]; 10385 if (OC.isBrackets) { 10386 // Offset of an array sub-field. TODO: Should we allow vector elements? 10387 if (!CurrentType->isDependentType()) { 10388 const ArrayType *AT = Context.getAsArrayType(CurrentType); 10389 if(!AT) 10390 return ExprError(Diag(OC.LocEnd, diag::err_offsetof_array_type) 10391 << CurrentType); 10392 CurrentType = AT->getElementType(); 10393 } else 10394 CurrentType = Context.DependentTy; 10395 10396 ExprResult IdxRval = DefaultLvalueConversion(static_cast<Expr*>(OC.U.E)); 10397 if (IdxRval.isInvalid()) 10398 return ExprError(); 10399 Expr *Idx = IdxRval.get(); 10400 10401 // The expression must be an integral expression. 10402 // FIXME: An integral constant expression? 10403 if (!Idx->isTypeDependent() && !Idx->isValueDependent() && 10404 !Idx->getType()->isIntegerType()) 10405 return ExprError(Diag(Idx->getLocStart(), 10406 diag::err_typecheck_subscript_not_integer) 10407 << Idx->getSourceRange()); 10408 10409 // Record this array index. 10410 Comps.push_back(OffsetOfNode(OC.LocStart, Exprs.size(), OC.LocEnd)); 10411 Exprs.push_back(Idx); 10412 continue; 10413 } 10414 10415 // Offset of a field. 10416 if (CurrentType->isDependentType()) { 10417 // We have the offset of a field, but we can't look into the dependent 10418 // type. Just record the identifier of the field. 10419 Comps.push_back(OffsetOfNode(OC.LocStart, OC.U.IdentInfo, OC.LocEnd)); 10420 CurrentType = Context.DependentTy; 10421 continue; 10422 } 10423 10424 // We need to have a complete type to look into. 10425 if (RequireCompleteType(OC.LocStart, CurrentType, 10426 diag::err_offsetof_incomplete_type)) 10427 return ExprError(); 10428 10429 // Look for the designated field. 10430 const RecordType *RC = CurrentType->getAs<RecordType>(); 10431 if (!RC) 10432 return ExprError(Diag(OC.LocEnd, diag::err_offsetof_record_type) 10433 << CurrentType); 10434 RecordDecl *RD = RC->getDecl(); 10435 10436 // C++ [lib.support.types]p5: 10437 // The macro offsetof accepts a restricted set of type arguments in this 10438 // International Standard. type shall be a POD structure or a POD union 10439 // (clause 9). 10440 // C++11 [support.types]p4: 10441 // If type is not a standard-layout class (Clause 9), the results are 10442 // undefined. 10443 if (CXXRecordDecl *CRD = dyn_cast<CXXRecordDecl>(RD)) { 10444 bool IsSafe = LangOpts.CPlusPlus11? CRD->isStandardLayout() : CRD->isPOD(); 10445 unsigned DiagID = 10446 LangOpts.CPlusPlus11? diag::ext_offsetof_non_standardlayout_type 10447 : diag::ext_offsetof_non_pod_type; 10448 10449 if (!IsSafe && !DidWarnAboutNonPOD && 10450 DiagRuntimeBehavior(BuiltinLoc, nullptr, 10451 PDiag(DiagID) 10452 << SourceRange(CompPtr[0].LocStart, OC.LocEnd) 10453 << CurrentType)) 10454 DidWarnAboutNonPOD = true; 10455 } 10456 10457 // Look for the field. 10458 LookupResult R(*this, OC.U.IdentInfo, OC.LocStart, LookupMemberName); 10459 LookupQualifiedName(R, RD); 10460 FieldDecl *MemberDecl = R.getAsSingle<FieldDecl>(); 10461 IndirectFieldDecl *IndirectMemberDecl = nullptr; 10462 if (!MemberDecl) { 10463 if ((IndirectMemberDecl = R.getAsSingle<IndirectFieldDecl>())) 10464 MemberDecl = IndirectMemberDecl->getAnonField(); 10465 } 10466 10467 if (!MemberDecl) 10468 return ExprError(Diag(BuiltinLoc, diag::err_no_member) 10469 << OC.U.IdentInfo << RD << SourceRange(OC.LocStart, 10470 OC.LocEnd)); 10471 10472 // C99 7.17p3: 10473 // (If the specified member is a bit-field, the behavior is undefined.) 10474 // 10475 // We diagnose this as an error. 10476 if (MemberDecl->isBitField()) { 10477 Diag(OC.LocEnd, diag::err_offsetof_bitfield) 10478 << MemberDecl->getDeclName() 10479 << SourceRange(BuiltinLoc, RParenLoc); 10480 Diag(MemberDecl->getLocation(), diag::note_bitfield_decl); 10481 return ExprError(); 10482 } 10483 10484 RecordDecl *Parent = MemberDecl->getParent(); 10485 if (IndirectMemberDecl) 10486 Parent = cast<RecordDecl>(IndirectMemberDecl->getDeclContext()); 10487 10488 // If the member was found in a base class, introduce OffsetOfNodes for 10489 // the base class indirections. 10490 CXXBasePaths Paths; 10491 if (IsDerivedFrom(CurrentType, Context.getTypeDeclType(Parent), Paths)) { 10492 if (Paths.getDetectedVirtual()) { 10493 Diag(OC.LocEnd, diag::err_offsetof_field_of_virtual_base) 10494 << MemberDecl->getDeclName() 10495 << SourceRange(BuiltinLoc, RParenLoc); 10496 return ExprError(); 10497 } 10498 10499 CXXBasePath &Path = Paths.front(); 10500 for (CXXBasePath::iterator B = Path.begin(), BEnd = Path.end(); 10501 B != BEnd; ++B) 10502 Comps.push_back(OffsetOfNode(B->Base)); 10503 } 10504 10505 if (IndirectMemberDecl) { 10506 for (auto *FI : IndirectMemberDecl->chain()) { 10507 assert(isa<FieldDecl>(FI)); 10508 Comps.push_back(OffsetOfNode(OC.LocStart, 10509 cast<FieldDecl>(FI), OC.LocEnd)); 10510 } 10511 } else 10512 Comps.push_back(OffsetOfNode(OC.LocStart, MemberDecl, OC.LocEnd)); 10513 10514 CurrentType = MemberDecl->getType().getNonReferenceType(); 10515 } 10516 10517 return OffsetOfExpr::Create(Context, Context.getSizeType(), BuiltinLoc, TInfo, 10518 Comps, Exprs, RParenLoc); 10519 } 10520 10521 ExprResult Sema::ActOnBuiltinOffsetOf(Scope *S, 10522 SourceLocation BuiltinLoc, 10523 SourceLocation TypeLoc, 10524 ParsedType ParsedArgTy, 10525 OffsetOfComponent *CompPtr, 10526 unsigned NumComponents, 10527 SourceLocation RParenLoc) { 10528 10529 TypeSourceInfo *ArgTInfo; 10530 QualType ArgTy = GetTypeFromParser(ParsedArgTy, &ArgTInfo); 10531 if (ArgTy.isNull()) 10532 return ExprError(); 10533 10534 if (!ArgTInfo) 10535 ArgTInfo = Context.getTrivialTypeSourceInfo(ArgTy, TypeLoc); 10536 10537 return BuildBuiltinOffsetOf(BuiltinLoc, ArgTInfo, CompPtr, NumComponents, 10538 RParenLoc); 10539 } 10540 10541 10542 ExprResult Sema::ActOnChooseExpr(SourceLocation BuiltinLoc, 10543 Expr *CondExpr, 10544 Expr *LHSExpr, Expr *RHSExpr, 10545 SourceLocation RPLoc) { 10546 assert((CondExpr && LHSExpr && RHSExpr) && "Missing type argument(s)"); 10547 10548 ExprValueKind VK = VK_RValue; 10549 ExprObjectKind OK = OK_Ordinary; 10550 QualType resType; 10551 bool ValueDependent = false; 10552 bool CondIsTrue = false; 10553 if (CondExpr->isTypeDependent() || CondExpr->isValueDependent()) { 10554 resType = Context.DependentTy; 10555 ValueDependent = true; 10556 } else { 10557 // The conditional expression is required to be a constant expression. 10558 llvm::APSInt condEval(32); 10559 ExprResult CondICE 10560 = VerifyIntegerConstantExpression(CondExpr, &condEval, 10561 diag::err_typecheck_choose_expr_requires_constant, false); 10562 if (CondICE.isInvalid()) 10563 return ExprError(); 10564 CondExpr = CondICE.get(); 10565 CondIsTrue = condEval.getZExtValue(); 10566 10567 // If the condition is > zero, then the AST type is the same as the LSHExpr. 10568 Expr *ActiveExpr = CondIsTrue ? LHSExpr : RHSExpr; 10569 10570 resType = ActiveExpr->getType(); 10571 ValueDependent = ActiveExpr->isValueDependent(); 10572 VK = ActiveExpr->getValueKind(); 10573 OK = ActiveExpr->getObjectKind(); 10574 } 10575 10576 return new (Context) 10577 ChooseExpr(BuiltinLoc, CondExpr, LHSExpr, RHSExpr, resType, VK, OK, RPLoc, 10578 CondIsTrue, resType->isDependentType(), ValueDependent); 10579 } 10580 10581 //===----------------------------------------------------------------------===// 10582 // Clang Extensions. 10583 //===----------------------------------------------------------------------===// 10584 10585 /// ActOnBlockStart - This callback is invoked when a block literal is started. 10586 void Sema::ActOnBlockStart(SourceLocation CaretLoc, Scope *CurScope) { 10587 BlockDecl *Block = BlockDecl::Create(Context, CurContext, CaretLoc); 10588 10589 if (LangOpts.CPlusPlus) { 10590 Decl *ManglingContextDecl; 10591 if (MangleNumberingContext *MCtx = 10592 getCurrentMangleNumberContext(Block->getDeclContext(), 10593 ManglingContextDecl)) { 10594 unsigned ManglingNumber = MCtx->getManglingNumber(Block); 10595 Block->setBlockMangling(ManglingNumber, ManglingContextDecl); 10596 } 10597 } 10598 10599 PushBlockScope(CurScope, Block); 10600 CurContext->addDecl(Block); 10601 if (CurScope) 10602 PushDeclContext(CurScope, Block); 10603 else 10604 CurContext = Block; 10605 10606 getCurBlock()->HasImplicitReturnType = true; 10607 10608 // Enter a new evaluation context to insulate the block from any 10609 // cleanups from the enclosing full-expression. 10610 PushExpressionEvaluationContext(PotentiallyEvaluated); 10611 } 10612 10613 void Sema::ActOnBlockArguments(SourceLocation CaretLoc, Declarator &ParamInfo, 10614 Scope *CurScope) { 10615 assert(ParamInfo.getIdentifier() == nullptr && 10616 "block-id should have no identifier!"); 10617 assert(ParamInfo.getContext() == Declarator::BlockLiteralContext); 10618 BlockScopeInfo *CurBlock = getCurBlock(); 10619 10620 TypeSourceInfo *Sig = GetTypeForDeclarator(ParamInfo, CurScope); 10621 QualType T = Sig->getType(); 10622 10623 // FIXME: We should allow unexpanded parameter packs here, but that would, 10624 // in turn, make the block expression contain unexpanded parameter packs. 10625 if (DiagnoseUnexpandedParameterPack(CaretLoc, Sig, UPPC_Block)) { 10626 // Drop the parameters. 10627 FunctionProtoType::ExtProtoInfo EPI; 10628 EPI.HasTrailingReturn = false; 10629 EPI.TypeQuals |= DeclSpec::TQ_const; 10630 T = Context.getFunctionType(Context.DependentTy, None, EPI); 10631 Sig = Context.getTrivialTypeSourceInfo(T); 10632 } 10633 10634 // GetTypeForDeclarator always produces a function type for a block 10635 // literal signature. Furthermore, it is always a FunctionProtoType 10636 // unless the function was written with a typedef. 10637 assert(T->isFunctionType() && 10638 "GetTypeForDeclarator made a non-function block signature"); 10639 10640 // Look for an explicit signature in that function type. 10641 FunctionProtoTypeLoc ExplicitSignature; 10642 10643 TypeLoc tmp = Sig->getTypeLoc().IgnoreParens(); 10644 if ((ExplicitSignature = tmp.getAs<FunctionProtoTypeLoc>())) { 10645 10646 // Check whether that explicit signature was synthesized by 10647 // GetTypeForDeclarator. If so, don't save that as part of the 10648 // written signature. 10649 if (ExplicitSignature.getLocalRangeBegin() == 10650 ExplicitSignature.getLocalRangeEnd()) { 10651 // This would be much cheaper if we stored TypeLocs instead of 10652 // TypeSourceInfos. 10653 TypeLoc Result = ExplicitSignature.getReturnLoc(); 10654 unsigned Size = Result.getFullDataSize(); 10655 Sig = Context.CreateTypeSourceInfo(Result.getType(), Size); 10656 Sig->getTypeLoc().initializeFullCopy(Result, Size); 10657 10658 ExplicitSignature = FunctionProtoTypeLoc(); 10659 } 10660 } 10661 10662 CurBlock->TheDecl->setSignatureAsWritten(Sig); 10663 CurBlock->FunctionType = T; 10664 10665 const FunctionType *Fn = T->getAs<FunctionType>(); 10666 QualType RetTy = Fn->getReturnType(); 10667 bool isVariadic = 10668 (isa<FunctionProtoType>(Fn) && cast<FunctionProtoType>(Fn)->isVariadic()); 10669 10670 CurBlock->TheDecl->setIsVariadic(isVariadic); 10671 10672 // Context.DependentTy is used as a placeholder for a missing block 10673 // return type. TODO: what should we do with declarators like: 10674 // ^ * { ... } 10675 // If the answer is "apply template argument deduction".... 10676 if (RetTy != Context.DependentTy) { 10677 CurBlock->ReturnType = RetTy; 10678 CurBlock->TheDecl->setBlockMissingReturnType(false); 10679 CurBlock->HasImplicitReturnType = false; 10680 } 10681 10682 // Push block parameters from the declarator if we had them. 10683 SmallVector<ParmVarDecl*, 8> Params; 10684 if (ExplicitSignature) { 10685 for (unsigned I = 0, E = ExplicitSignature.getNumParams(); I != E; ++I) { 10686 ParmVarDecl *Param = ExplicitSignature.getParam(I); 10687 if (Param->getIdentifier() == nullptr && 10688 !Param->isImplicit() && 10689 !Param->isInvalidDecl() && 10690 !getLangOpts().CPlusPlus) 10691 Diag(Param->getLocation(), diag::err_parameter_name_omitted); 10692 Params.push_back(Param); 10693 } 10694 10695 // Fake up parameter variables if we have a typedef, like 10696 // ^ fntype { ... } 10697 } else if (const FunctionProtoType *Fn = T->getAs<FunctionProtoType>()) { 10698 for (const auto &I : Fn->param_types()) { 10699 ParmVarDecl *Param = BuildParmVarDeclForTypedef( 10700 CurBlock->TheDecl, ParamInfo.getLocStart(), I); 10701 Params.push_back(Param); 10702 } 10703 } 10704 10705 // Set the parameters on the block decl. 10706 if (!Params.empty()) { 10707 CurBlock->TheDecl->setParams(Params); 10708 CheckParmsForFunctionDef(CurBlock->TheDecl->param_begin(), 10709 CurBlock->TheDecl->param_end(), 10710 /*CheckParameterNames=*/false); 10711 } 10712 10713 // Finally we can process decl attributes. 10714 ProcessDeclAttributes(CurScope, CurBlock->TheDecl, ParamInfo); 10715 10716 // Put the parameter variables in scope. 10717 for (auto AI : CurBlock->TheDecl->params()) { 10718 AI->setOwningFunction(CurBlock->TheDecl); 10719 10720 // If this has an identifier, add it to the scope stack. 10721 if (AI->getIdentifier()) { 10722 CheckShadow(CurBlock->TheScope, AI); 10723 10724 PushOnScopeChains(AI, CurBlock->TheScope); 10725 } 10726 } 10727 } 10728 10729 /// ActOnBlockError - If there is an error parsing a block, this callback 10730 /// is invoked to pop the information about the block from the action impl. 10731 void Sema::ActOnBlockError(SourceLocation CaretLoc, Scope *CurScope) { 10732 // Leave the expression-evaluation context. 10733 DiscardCleanupsInEvaluationContext(); 10734 PopExpressionEvaluationContext(); 10735 10736 // Pop off CurBlock, handle nested blocks. 10737 PopDeclContext(); 10738 PopFunctionScopeInfo(); 10739 } 10740 10741 /// ActOnBlockStmtExpr - This is called when the body of a block statement 10742 /// literal was successfully completed. ^(int x){...} 10743 ExprResult Sema::ActOnBlockStmtExpr(SourceLocation CaretLoc, 10744 Stmt *Body, Scope *CurScope) { 10745 // If blocks are disabled, emit an error. 10746 if (!LangOpts.Blocks) 10747 Diag(CaretLoc, diag::err_blocks_disable); 10748 10749 // Leave the expression-evaluation context. 10750 if (hasAnyUnrecoverableErrorsInThisFunction()) 10751 DiscardCleanupsInEvaluationContext(); 10752 assert(!ExprNeedsCleanups && "cleanups within block not correctly bound!"); 10753 PopExpressionEvaluationContext(); 10754 10755 BlockScopeInfo *BSI = cast<BlockScopeInfo>(FunctionScopes.back()); 10756 10757 if (BSI->HasImplicitReturnType) 10758 deduceClosureReturnType(*BSI); 10759 10760 PopDeclContext(); 10761 10762 QualType RetTy = Context.VoidTy; 10763 if (!BSI->ReturnType.isNull()) 10764 RetTy = BSI->ReturnType; 10765 10766 bool NoReturn = BSI->TheDecl->hasAttr<NoReturnAttr>(); 10767 QualType BlockTy; 10768 10769 // Set the captured variables on the block. 10770 // FIXME: Share capture structure between BlockDecl and CapturingScopeInfo! 10771 SmallVector<BlockDecl::Capture, 4> Captures; 10772 for (unsigned i = 0, e = BSI->Captures.size(); i != e; i++) { 10773 CapturingScopeInfo::Capture &Cap = BSI->Captures[i]; 10774 if (Cap.isThisCapture()) 10775 continue; 10776 BlockDecl::Capture NewCap(Cap.getVariable(), Cap.isBlockCapture(), 10777 Cap.isNested(), Cap.getInitExpr()); 10778 Captures.push_back(NewCap); 10779 } 10780 BSI->TheDecl->setCaptures(Context, Captures.begin(), Captures.end(), 10781 BSI->CXXThisCaptureIndex != 0); 10782 10783 // If the user wrote a function type in some form, try to use that. 10784 if (!BSI->FunctionType.isNull()) { 10785 const FunctionType *FTy = BSI->FunctionType->getAs<FunctionType>(); 10786 10787 FunctionType::ExtInfo Ext = FTy->getExtInfo(); 10788 if (NoReturn && !Ext.getNoReturn()) Ext = Ext.withNoReturn(true); 10789 10790 // Turn protoless block types into nullary block types. 10791 if (isa<FunctionNoProtoType>(FTy)) { 10792 FunctionProtoType::ExtProtoInfo EPI; 10793 EPI.ExtInfo = Ext; 10794 BlockTy = Context.getFunctionType(RetTy, None, EPI); 10795 10796 // Otherwise, if we don't need to change anything about the function type, 10797 // preserve its sugar structure. 10798 } else if (FTy->getReturnType() == RetTy && 10799 (!NoReturn || FTy->getNoReturnAttr())) { 10800 BlockTy = BSI->FunctionType; 10801 10802 // Otherwise, make the minimal modifications to the function type. 10803 } else { 10804 const FunctionProtoType *FPT = cast<FunctionProtoType>(FTy); 10805 FunctionProtoType::ExtProtoInfo EPI = FPT->getExtProtoInfo(); 10806 EPI.TypeQuals = 0; // FIXME: silently? 10807 EPI.ExtInfo = Ext; 10808 BlockTy = Context.getFunctionType(RetTy, FPT->getParamTypes(), EPI); 10809 } 10810 10811 // If we don't have a function type, just build one from nothing. 10812 } else { 10813 FunctionProtoType::ExtProtoInfo EPI; 10814 EPI.ExtInfo = FunctionType::ExtInfo().withNoReturn(NoReturn); 10815 BlockTy = Context.getFunctionType(RetTy, None, EPI); 10816 } 10817 10818 DiagnoseUnusedParameters(BSI->TheDecl->param_begin(), 10819 BSI->TheDecl->param_end()); 10820 BlockTy = Context.getBlockPointerType(BlockTy); 10821 10822 // If needed, diagnose invalid gotos and switches in the block. 10823 if (getCurFunction()->NeedsScopeChecking() && 10824 !PP.isCodeCompletionEnabled()) 10825 DiagnoseInvalidJumps(cast<CompoundStmt>(Body)); 10826 10827 BSI->TheDecl->setBody(cast<CompoundStmt>(Body)); 10828 10829 // Try to apply the named return value optimization. We have to check again 10830 // if we can do this, though, because blocks keep return statements around 10831 // to deduce an implicit return type. 10832 if (getLangOpts().CPlusPlus && RetTy->isRecordType() && 10833 !BSI->TheDecl->isDependentContext()) 10834 computeNRVO(Body, BSI); 10835 10836 BlockExpr *Result = new (Context) BlockExpr(BSI->TheDecl, BlockTy); 10837 AnalysisBasedWarnings::Policy WP = AnalysisWarnings.getDefaultPolicy(); 10838 PopFunctionScopeInfo(&WP, Result->getBlockDecl(), Result); 10839 10840 // If the block isn't obviously global, i.e. it captures anything at 10841 // all, then we need to do a few things in the surrounding context: 10842 if (Result->getBlockDecl()->hasCaptures()) { 10843 // First, this expression has a new cleanup object. 10844 ExprCleanupObjects.push_back(Result->getBlockDecl()); 10845 ExprNeedsCleanups = true; 10846 10847 // It also gets a branch-protected scope if any of the captured 10848 // variables needs destruction. 10849 for (const auto &CI : Result->getBlockDecl()->captures()) { 10850 const VarDecl *var = CI.getVariable(); 10851 if (var->getType().isDestructedType() != QualType::DK_none) { 10852 getCurFunction()->setHasBranchProtectedScope(); 10853 break; 10854 } 10855 } 10856 } 10857 10858 return Result; 10859 } 10860 10861 ExprResult Sema::ActOnVAArg(SourceLocation BuiltinLoc, 10862 Expr *E, ParsedType Ty, 10863 SourceLocation RPLoc) { 10864 TypeSourceInfo *TInfo; 10865 GetTypeFromParser(Ty, &TInfo); 10866 return BuildVAArgExpr(BuiltinLoc, E, TInfo, RPLoc); 10867 } 10868 10869 ExprResult Sema::BuildVAArgExpr(SourceLocation BuiltinLoc, 10870 Expr *E, TypeSourceInfo *TInfo, 10871 SourceLocation RPLoc) { 10872 Expr *OrigExpr = E; 10873 10874 // Get the va_list type 10875 QualType VaListType = Context.getBuiltinVaListType(); 10876 if (VaListType->isArrayType()) { 10877 // Deal with implicit array decay; for example, on x86-64, 10878 // va_list is an array, but it's supposed to decay to 10879 // a pointer for va_arg. 10880 VaListType = Context.getArrayDecayedType(VaListType); 10881 // Make sure the input expression also decays appropriately. 10882 ExprResult Result = UsualUnaryConversions(E); 10883 if (Result.isInvalid()) 10884 return ExprError(); 10885 E = Result.get(); 10886 } else if (VaListType->isRecordType() && getLangOpts().CPlusPlus) { 10887 // If va_list is a record type and we are compiling in C++ mode, 10888 // check the argument using reference binding. 10889 InitializedEntity Entity 10890 = InitializedEntity::InitializeParameter(Context, 10891 Context.getLValueReferenceType(VaListType), false); 10892 ExprResult Init = PerformCopyInitialization(Entity, SourceLocation(), E); 10893 if (Init.isInvalid()) 10894 return ExprError(); 10895 E = Init.getAs<Expr>(); 10896 } else { 10897 // Otherwise, the va_list argument must be an l-value because 10898 // it is modified by va_arg. 10899 if (!E->isTypeDependent() && 10900 CheckForModifiableLvalue(E, BuiltinLoc, *this)) 10901 return ExprError(); 10902 } 10903 10904 if (!E->isTypeDependent() && 10905 !Context.hasSameType(VaListType, E->getType())) { 10906 return ExprError(Diag(E->getLocStart(), 10907 diag::err_first_argument_to_va_arg_not_of_type_va_list) 10908 << OrigExpr->getType() << E->getSourceRange()); 10909 } 10910 10911 if (!TInfo->getType()->isDependentType()) { 10912 if (RequireCompleteType(TInfo->getTypeLoc().getBeginLoc(), TInfo->getType(), 10913 diag::err_second_parameter_to_va_arg_incomplete, 10914 TInfo->getTypeLoc())) 10915 return ExprError(); 10916 10917 if (RequireNonAbstractType(TInfo->getTypeLoc().getBeginLoc(), 10918 TInfo->getType(), 10919 diag::err_second_parameter_to_va_arg_abstract, 10920 TInfo->getTypeLoc())) 10921 return ExprError(); 10922 10923 if (!TInfo->getType().isPODType(Context)) { 10924 Diag(TInfo->getTypeLoc().getBeginLoc(), 10925 TInfo->getType()->isObjCLifetimeType() 10926 ? diag::warn_second_parameter_to_va_arg_ownership_qualified 10927 : diag::warn_second_parameter_to_va_arg_not_pod) 10928 << TInfo->getType() 10929 << TInfo->getTypeLoc().getSourceRange(); 10930 } 10931 10932 // Check for va_arg where arguments of the given type will be promoted 10933 // (i.e. this va_arg is guaranteed to have undefined behavior). 10934 QualType PromoteType; 10935 if (TInfo->getType()->isPromotableIntegerType()) { 10936 PromoteType = Context.getPromotedIntegerType(TInfo->getType()); 10937 if (Context.typesAreCompatible(PromoteType, TInfo->getType())) 10938 PromoteType = QualType(); 10939 } 10940 if (TInfo->getType()->isSpecificBuiltinType(BuiltinType::Float)) 10941 PromoteType = Context.DoubleTy; 10942 if (!PromoteType.isNull()) 10943 DiagRuntimeBehavior(TInfo->getTypeLoc().getBeginLoc(), E, 10944 PDiag(diag::warn_second_parameter_to_va_arg_never_compatible) 10945 << TInfo->getType() 10946 << PromoteType 10947 << TInfo->getTypeLoc().getSourceRange()); 10948 } 10949 10950 QualType T = TInfo->getType().getNonLValueExprType(Context); 10951 return new (Context) VAArgExpr(BuiltinLoc, E, TInfo, RPLoc, T); 10952 } 10953 10954 ExprResult Sema::ActOnGNUNullExpr(SourceLocation TokenLoc) { 10955 // The type of __null will be int or long, depending on the size of 10956 // pointers on the target. 10957 QualType Ty; 10958 unsigned pw = Context.getTargetInfo().getPointerWidth(0); 10959 if (pw == Context.getTargetInfo().getIntWidth()) 10960 Ty = Context.IntTy; 10961 else if (pw == Context.getTargetInfo().getLongWidth()) 10962 Ty = Context.LongTy; 10963 else if (pw == Context.getTargetInfo().getLongLongWidth()) 10964 Ty = Context.LongLongTy; 10965 else { 10966 llvm_unreachable("I don't know size of pointer!"); 10967 } 10968 10969 return new (Context) GNUNullExpr(Ty, TokenLoc); 10970 } 10971 10972 bool 10973 Sema::ConversionToObjCStringLiteralCheck(QualType DstType, Expr *&Exp) { 10974 if (!getLangOpts().ObjC1) 10975 return false; 10976 10977 const ObjCObjectPointerType *PT = DstType->getAs<ObjCObjectPointerType>(); 10978 if (!PT) 10979 return false; 10980 10981 if (!PT->isObjCIdType()) { 10982 // Check if the destination is the 'NSString' interface. 10983 const ObjCInterfaceDecl *ID = PT->getInterfaceDecl(); 10984 if (!ID || !ID->getIdentifier()->isStr("NSString")) 10985 return false; 10986 } 10987 10988 // Ignore any parens, implicit casts (should only be 10989 // array-to-pointer decays), and not-so-opaque values. The last is 10990 // important for making this trigger for property assignments. 10991 Expr *SrcExpr = Exp->IgnoreParenImpCasts(); 10992 if (OpaqueValueExpr *OV = dyn_cast<OpaqueValueExpr>(SrcExpr)) 10993 if (OV->getSourceExpr()) 10994 SrcExpr = OV->getSourceExpr()->IgnoreParenImpCasts(); 10995 10996 StringLiteral *SL = dyn_cast<StringLiteral>(SrcExpr); 10997 if (!SL || !SL->isAscii()) 10998 return false; 10999 Diag(SL->getLocStart(), diag::err_missing_atsign_prefix) 11000 << FixItHint::CreateInsertion(SL->getLocStart(), "@"); 11001 Exp = BuildObjCStringLiteral(SL->getLocStart(), SL).get(); 11002 return true; 11003 } 11004 11005 bool Sema::DiagnoseAssignmentResult(AssignConvertType ConvTy, 11006 SourceLocation Loc, 11007 QualType DstType, QualType SrcType, 11008 Expr *SrcExpr, AssignmentAction Action, 11009 bool *Complained) { 11010 if (Complained) 11011 *Complained = false; 11012 11013 // Decode the result (notice that AST's are still created for extensions). 11014 bool CheckInferredResultType = false; 11015 bool isInvalid = false; 11016 unsigned DiagKind = 0; 11017 FixItHint Hint; 11018 ConversionFixItGenerator ConvHints; 11019 bool MayHaveConvFixit = false; 11020 bool MayHaveFunctionDiff = false; 11021 const ObjCInterfaceDecl *IFace = nullptr; 11022 const ObjCProtocolDecl *PDecl = nullptr; 11023 11024 switch (ConvTy) { 11025 case Compatible: 11026 DiagnoseAssignmentEnum(DstType, SrcType, SrcExpr); 11027 return false; 11028 11029 case PointerToInt: 11030 DiagKind = diag::ext_typecheck_convert_pointer_int; 11031 ConvHints.tryToFixConversion(SrcExpr, SrcType, DstType, *this); 11032 MayHaveConvFixit = true; 11033 break; 11034 case IntToPointer: 11035 DiagKind = diag::ext_typecheck_convert_int_pointer; 11036 ConvHints.tryToFixConversion(SrcExpr, SrcType, DstType, *this); 11037 MayHaveConvFixit = true; 11038 break; 11039 case IncompatiblePointer: 11040 DiagKind = 11041 (Action == AA_Passing_CFAudited ? 11042 diag::err_arc_typecheck_convert_incompatible_pointer : 11043 diag::ext_typecheck_convert_incompatible_pointer); 11044 CheckInferredResultType = DstType->isObjCObjectPointerType() && 11045 SrcType->isObjCObjectPointerType(); 11046 if (Hint.isNull() && !CheckInferredResultType) { 11047 ConvHints.tryToFixConversion(SrcExpr, SrcType, DstType, *this); 11048 } 11049 else if (CheckInferredResultType) { 11050 SrcType = SrcType.getUnqualifiedType(); 11051 DstType = DstType.getUnqualifiedType(); 11052 } 11053 MayHaveConvFixit = true; 11054 break; 11055 case IncompatiblePointerSign: 11056 DiagKind = diag::ext_typecheck_convert_incompatible_pointer_sign; 11057 break; 11058 case FunctionVoidPointer: 11059 DiagKind = diag::ext_typecheck_convert_pointer_void_func; 11060 break; 11061 case IncompatiblePointerDiscardsQualifiers: { 11062 // Perform array-to-pointer decay if necessary. 11063 if (SrcType->isArrayType()) SrcType = Context.getArrayDecayedType(SrcType); 11064 11065 Qualifiers lhq = SrcType->getPointeeType().getQualifiers(); 11066 Qualifiers rhq = DstType->getPointeeType().getQualifiers(); 11067 if (lhq.getAddressSpace() != rhq.getAddressSpace()) { 11068 DiagKind = diag::err_typecheck_incompatible_address_space; 11069 break; 11070 11071 11072 } else if (lhq.getObjCLifetime() != rhq.getObjCLifetime()) { 11073 DiagKind = diag::err_typecheck_incompatible_ownership; 11074 break; 11075 } 11076 11077 llvm_unreachable("unknown error case for discarding qualifiers!"); 11078 // fallthrough 11079 } 11080 case CompatiblePointerDiscardsQualifiers: 11081 // If the qualifiers lost were because we were applying the 11082 // (deprecated) C++ conversion from a string literal to a char* 11083 // (or wchar_t*), then there was no error (C++ 4.2p2). FIXME: 11084 // Ideally, this check would be performed in 11085 // checkPointerTypesForAssignment. However, that would require a 11086 // bit of refactoring (so that the second argument is an 11087 // expression, rather than a type), which should be done as part 11088 // of a larger effort to fix checkPointerTypesForAssignment for 11089 // C++ semantics. 11090 if (getLangOpts().CPlusPlus && 11091 IsStringLiteralToNonConstPointerConversion(SrcExpr, DstType)) 11092 return false; 11093 DiagKind = diag::ext_typecheck_convert_discards_qualifiers; 11094 break; 11095 case IncompatibleNestedPointerQualifiers: 11096 DiagKind = diag::ext_nested_pointer_qualifier_mismatch; 11097 break; 11098 case IntToBlockPointer: 11099 DiagKind = diag::err_int_to_block_pointer; 11100 break; 11101 case IncompatibleBlockPointer: 11102 DiagKind = diag::err_typecheck_convert_incompatible_block_pointer; 11103 break; 11104 case IncompatibleObjCQualifiedId: { 11105 if (SrcType->isObjCQualifiedIdType()) { 11106 const ObjCObjectPointerType *srcOPT = 11107 SrcType->getAs<ObjCObjectPointerType>(); 11108 for (auto *srcProto : srcOPT->quals()) { 11109 PDecl = srcProto; 11110 break; 11111 } 11112 if (const ObjCInterfaceType *IFaceT = 11113 DstType->getAs<ObjCObjectPointerType>()->getInterfaceType()) 11114 IFace = IFaceT->getDecl(); 11115 } 11116 else if (DstType->isObjCQualifiedIdType()) { 11117 const ObjCObjectPointerType *dstOPT = 11118 DstType->getAs<ObjCObjectPointerType>(); 11119 for (auto *dstProto : dstOPT->quals()) { 11120 PDecl = dstProto; 11121 break; 11122 } 11123 if (const ObjCInterfaceType *IFaceT = 11124 SrcType->getAs<ObjCObjectPointerType>()->getInterfaceType()) 11125 IFace = IFaceT->getDecl(); 11126 } 11127 DiagKind = diag::warn_incompatible_qualified_id; 11128 break; 11129 } 11130 case IncompatibleVectors: 11131 DiagKind = diag::warn_incompatible_vectors; 11132 break; 11133 case IncompatibleObjCWeakRef: 11134 DiagKind = diag::err_arc_weak_unavailable_assign; 11135 break; 11136 case Incompatible: 11137 DiagKind = diag::err_typecheck_convert_incompatible; 11138 ConvHints.tryToFixConversion(SrcExpr, SrcType, DstType, *this); 11139 MayHaveConvFixit = true; 11140 isInvalid = true; 11141 MayHaveFunctionDiff = true; 11142 break; 11143 } 11144 11145 QualType FirstType, SecondType; 11146 switch (Action) { 11147 case AA_Assigning: 11148 case AA_Initializing: 11149 // The destination type comes first. 11150 FirstType = DstType; 11151 SecondType = SrcType; 11152 break; 11153 11154 case AA_Returning: 11155 case AA_Passing: 11156 case AA_Passing_CFAudited: 11157 case AA_Converting: 11158 case AA_Sending: 11159 case AA_Casting: 11160 // The source type comes first. 11161 FirstType = SrcType; 11162 SecondType = DstType; 11163 break; 11164 } 11165 11166 PartialDiagnostic FDiag = PDiag(DiagKind); 11167 if (Action == AA_Passing_CFAudited) 11168 FDiag << FirstType << SecondType << AA_Passing << SrcExpr->getSourceRange(); 11169 else 11170 FDiag << FirstType << SecondType << Action << SrcExpr->getSourceRange(); 11171 11172 // If we can fix the conversion, suggest the FixIts. 11173 assert(ConvHints.isNull() || Hint.isNull()); 11174 if (!ConvHints.isNull()) { 11175 for (std::vector<FixItHint>::iterator HI = ConvHints.Hints.begin(), 11176 HE = ConvHints.Hints.end(); HI != HE; ++HI) 11177 FDiag << *HI; 11178 } else { 11179 FDiag << Hint; 11180 } 11181 if (MayHaveConvFixit) { FDiag << (unsigned) (ConvHints.Kind); } 11182 11183 if (MayHaveFunctionDiff) 11184 HandleFunctionTypeMismatch(FDiag, SecondType, FirstType); 11185 11186 Diag(Loc, FDiag); 11187 if (DiagKind == diag::warn_incompatible_qualified_id && 11188 PDecl && IFace && !IFace->hasDefinition()) 11189 Diag(IFace->getLocation(), diag::not_incomplete_class_and_qualified_id) 11190 << IFace->getName() << PDecl->getName(); 11191 11192 if (SecondType == Context.OverloadTy) 11193 NoteAllOverloadCandidates(OverloadExpr::find(SrcExpr).Expression, 11194 FirstType); 11195 11196 if (CheckInferredResultType) 11197 EmitRelatedResultTypeNote(SrcExpr); 11198 11199 if (Action == AA_Returning && ConvTy == IncompatiblePointer) 11200 EmitRelatedResultTypeNoteForReturn(DstType); 11201 11202 if (Complained) 11203 *Complained = true; 11204 return isInvalid; 11205 } 11206 11207 ExprResult Sema::VerifyIntegerConstantExpression(Expr *E, 11208 llvm::APSInt *Result) { 11209 class SimpleICEDiagnoser : public VerifyICEDiagnoser { 11210 public: 11211 void diagnoseNotICE(Sema &S, SourceLocation Loc, SourceRange SR) override { 11212 S.Diag(Loc, diag::err_expr_not_ice) << S.LangOpts.CPlusPlus << SR; 11213 } 11214 } Diagnoser; 11215 11216 return VerifyIntegerConstantExpression(E, Result, Diagnoser); 11217 } 11218 11219 ExprResult Sema::VerifyIntegerConstantExpression(Expr *E, 11220 llvm::APSInt *Result, 11221 unsigned DiagID, 11222 bool AllowFold) { 11223 class IDDiagnoser : public VerifyICEDiagnoser { 11224 unsigned DiagID; 11225 11226 public: 11227 IDDiagnoser(unsigned DiagID) 11228 : VerifyICEDiagnoser(DiagID == 0), DiagID(DiagID) { } 11229 11230 void diagnoseNotICE(Sema &S, SourceLocation Loc, SourceRange SR) override { 11231 S.Diag(Loc, DiagID) << SR; 11232 } 11233 } Diagnoser(DiagID); 11234 11235 return VerifyIntegerConstantExpression(E, Result, Diagnoser, AllowFold); 11236 } 11237 11238 void Sema::VerifyICEDiagnoser::diagnoseFold(Sema &S, SourceLocation Loc, 11239 SourceRange SR) { 11240 S.Diag(Loc, diag::ext_expr_not_ice) << SR << S.LangOpts.CPlusPlus; 11241 } 11242 11243 ExprResult 11244 Sema::VerifyIntegerConstantExpression(Expr *E, llvm::APSInt *Result, 11245 VerifyICEDiagnoser &Diagnoser, 11246 bool AllowFold) { 11247 SourceLocation DiagLoc = E->getLocStart(); 11248 11249 if (getLangOpts().CPlusPlus11) { 11250 // C++11 [expr.const]p5: 11251 // If an expression of literal class type is used in a context where an 11252 // integral constant expression is required, then that class type shall 11253 // have a single non-explicit conversion function to an integral or 11254 // unscoped enumeration type 11255 ExprResult Converted; 11256 class CXX11ConvertDiagnoser : public ICEConvertDiagnoser { 11257 public: 11258 CXX11ConvertDiagnoser(bool Silent) 11259 : ICEConvertDiagnoser(/*AllowScopedEnumerations*/false, 11260 Silent, true) {} 11261 11262 SemaDiagnosticBuilder diagnoseNotInt(Sema &S, SourceLocation Loc, 11263 QualType T) override { 11264 return S.Diag(Loc, diag::err_ice_not_integral) << T; 11265 } 11266 11267 SemaDiagnosticBuilder diagnoseIncomplete( 11268 Sema &S, SourceLocation Loc, QualType T) override { 11269 return S.Diag(Loc, diag::err_ice_incomplete_type) << T; 11270 } 11271 11272 SemaDiagnosticBuilder diagnoseExplicitConv( 11273 Sema &S, SourceLocation Loc, QualType T, QualType ConvTy) override { 11274 return S.Diag(Loc, diag::err_ice_explicit_conversion) << T << ConvTy; 11275 } 11276 11277 SemaDiagnosticBuilder noteExplicitConv( 11278 Sema &S, CXXConversionDecl *Conv, QualType ConvTy) override { 11279 return S.Diag(Conv->getLocation(), diag::note_ice_conversion_here) 11280 << ConvTy->isEnumeralType() << ConvTy; 11281 } 11282 11283 SemaDiagnosticBuilder diagnoseAmbiguous( 11284 Sema &S, SourceLocation Loc, QualType T) override { 11285 return S.Diag(Loc, diag::err_ice_ambiguous_conversion) << T; 11286 } 11287 11288 SemaDiagnosticBuilder noteAmbiguous( 11289 Sema &S, CXXConversionDecl *Conv, QualType ConvTy) override { 11290 return S.Diag(Conv->getLocation(), diag::note_ice_conversion_here) 11291 << ConvTy->isEnumeralType() << ConvTy; 11292 } 11293 11294 SemaDiagnosticBuilder diagnoseConversion( 11295 Sema &S, SourceLocation Loc, QualType T, QualType ConvTy) override { 11296 llvm_unreachable("conversion functions are permitted"); 11297 } 11298 } ConvertDiagnoser(Diagnoser.Suppress); 11299 11300 Converted = PerformContextualImplicitConversion(DiagLoc, E, 11301 ConvertDiagnoser); 11302 if (Converted.isInvalid()) 11303 return Converted; 11304 E = Converted.get(); 11305 if (!E->getType()->isIntegralOrUnscopedEnumerationType()) 11306 return ExprError(); 11307 } else if (!E->getType()->isIntegralOrUnscopedEnumerationType()) { 11308 // An ICE must be of integral or unscoped enumeration type. 11309 if (!Diagnoser.Suppress) 11310 Diagnoser.diagnoseNotICE(*this, DiagLoc, E->getSourceRange()); 11311 return ExprError(); 11312 } 11313 11314 // Circumvent ICE checking in C++11 to avoid evaluating the expression twice 11315 // in the non-ICE case. 11316 if (!getLangOpts().CPlusPlus11 && E->isIntegerConstantExpr(Context)) { 11317 if (Result) 11318 *Result = E->EvaluateKnownConstInt(Context); 11319 return E; 11320 } 11321 11322 Expr::EvalResult EvalResult; 11323 SmallVector<PartialDiagnosticAt, 8> Notes; 11324 EvalResult.Diag = &Notes; 11325 11326 // Try to evaluate the expression, and produce diagnostics explaining why it's 11327 // not a constant expression as a side-effect. 11328 bool Folded = E->EvaluateAsRValue(EvalResult, Context) && 11329 EvalResult.Val.isInt() && !EvalResult.HasSideEffects; 11330 11331 // In C++11, we can rely on diagnostics being produced for any expression 11332 // which is not a constant expression. If no diagnostics were produced, then 11333 // this is a constant expression. 11334 if (Folded && getLangOpts().CPlusPlus11 && Notes.empty()) { 11335 if (Result) 11336 *Result = EvalResult.Val.getInt(); 11337 return E; 11338 } 11339 11340 // If our only note is the usual "invalid subexpression" note, just point 11341 // the caret at its location rather than producing an essentially 11342 // redundant note. 11343 if (Notes.size() == 1 && Notes[0].second.getDiagID() == 11344 diag::note_invalid_subexpr_in_const_expr) { 11345 DiagLoc = Notes[0].first; 11346 Notes.clear(); 11347 } 11348 11349 if (!Folded || !AllowFold) { 11350 if (!Diagnoser.Suppress) { 11351 Diagnoser.diagnoseNotICE(*this, DiagLoc, E->getSourceRange()); 11352 for (unsigned I = 0, N = Notes.size(); I != N; ++I) 11353 Diag(Notes[I].first, Notes[I].second); 11354 } 11355 11356 return ExprError(); 11357 } 11358 11359 Diagnoser.diagnoseFold(*this, DiagLoc, E->getSourceRange()); 11360 for (unsigned I = 0, N = Notes.size(); I != N; ++I) 11361 Diag(Notes[I].first, Notes[I].second); 11362 11363 if (Result) 11364 *Result = EvalResult.Val.getInt(); 11365 return E; 11366 } 11367 11368 namespace { 11369 // Handle the case where we conclude a expression which we speculatively 11370 // considered to be unevaluated is actually evaluated. 11371 class TransformToPE : public TreeTransform<TransformToPE> { 11372 typedef TreeTransform<TransformToPE> BaseTransform; 11373 11374 public: 11375 TransformToPE(Sema &SemaRef) : BaseTransform(SemaRef) { } 11376 11377 // Make sure we redo semantic analysis 11378 bool AlwaysRebuild() { return true; } 11379 11380 // Make sure we handle LabelStmts correctly. 11381 // FIXME: This does the right thing, but maybe we need a more general 11382 // fix to TreeTransform? 11383 StmtResult TransformLabelStmt(LabelStmt *S) { 11384 S->getDecl()->setStmt(nullptr); 11385 return BaseTransform::TransformLabelStmt(S); 11386 } 11387 11388 // We need to special-case DeclRefExprs referring to FieldDecls which 11389 // are not part of a member pointer formation; normal TreeTransforming 11390 // doesn't catch this case because of the way we represent them in the AST. 11391 // FIXME: This is a bit ugly; is it really the best way to handle this 11392 // case? 11393 // 11394 // Error on DeclRefExprs referring to FieldDecls. 11395 ExprResult TransformDeclRefExpr(DeclRefExpr *E) { 11396 if (isa<FieldDecl>(E->getDecl()) && 11397 !SemaRef.isUnevaluatedContext()) 11398 return SemaRef.Diag(E->getLocation(), 11399 diag::err_invalid_non_static_member_use) 11400 << E->getDecl() << E->getSourceRange(); 11401 11402 return BaseTransform::TransformDeclRefExpr(E); 11403 } 11404 11405 // Exception: filter out member pointer formation 11406 ExprResult TransformUnaryOperator(UnaryOperator *E) { 11407 if (E->getOpcode() == UO_AddrOf && E->getType()->isMemberPointerType()) 11408 return E; 11409 11410 return BaseTransform::TransformUnaryOperator(E); 11411 } 11412 11413 ExprResult TransformLambdaExpr(LambdaExpr *E) { 11414 // Lambdas never need to be transformed. 11415 return E; 11416 } 11417 }; 11418 } 11419 11420 ExprResult Sema::TransformToPotentiallyEvaluated(Expr *E) { 11421 assert(isUnevaluatedContext() && 11422 "Should only transform unevaluated expressions"); 11423 ExprEvalContexts.back().Context = 11424 ExprEvalContexts[ExprEvalContexts.size()-2].Context; 11425 if (isUnevaluatedContext()) 11426 return E; 11427 return TransformToPE(*this).TransformExpr(E); 11428 } 11429 11430 void 11431 Sema::PushExpressionEvaluationContext(ExpressionEvaluationContext NewContext, 11432 Decl *LambdaContextDecl, 11433 bool IsDecltype) { 11434 ExprEvalContexts.push_back( 11435 ExpressionEvaluationContextRecord(NewContext, 11436 ExprCleanupObjects.size(), 11437 ExprNeedsCleanups, 11438 LambdaContextDecl, 11439 IsDecltype)); 11440 ExprNeedsCleanups = false; 11441 if (!MaybeODRUseExprs.empty()) 11442 std::swap(MaybeODRUseExprs, ExprEvalContexts.back().SavedMaybeODRUseExprs); 11443 } 11444 11445 void 11446 Sema::PushExpressionEvaluationContext(ExpressionEvaluationContext NewContext, 11447 ReuseLambdaContextDecl_t, 11448 bool IsDecltype) { 11449 Decl *ClosureContextDecl = ExprEvalContexts.back().ManglingContextDecl; 11450 PushExpressionEvaluationContext(NewContext, ClosureContextDecl, IsDecltype); 11451 } 11452 11453 void Sema::PopExpressionEvaluationContext() { 11454 ExpressionEvaluationContextRecord& Rec = ExprEvalContexts.back(); 11455 unsigned NumTypos = Rec.NumTypos; 11456 11457 if (!Rec.Lambdas.empty()) { 11458 if (Rec.isUnevaluated() || Rec.Context == ConstantEvaluated) { 11459 unsigned D; 11460 if (Rec.isUnevaluated()) { 11461 // C++11 [expr.prim.lambda]p2: 11462 // A lambda-expression shall not appear in an unevaluated operand 11463 // (Clause 5). 11464 D = diag::err_lambda_unevaluated_operand; 11465 } else { 11466 // C++1y [expr.const]p2: 11467 // A conditional-expression e is a core constant expression unless the 11468 // evaluation of e, following the rules of the abstract machine, would 11469 // evaluate [...] a lambda-expression. 11470 D = diag::err_lambda_in_constant_expression; 11471 } 11472 for (const auto *L : Rec.Lambdas) 11473 Diag(L->getLocStart(), D); 11474 } else { 11475 // Mark the capture expressions odr-used. This was deferred 11476 // during lambda expression creation. 11477 for (auto *Lambda : Rec.Lambdas) { 11478 for (auto *C : Lambda->capture_inits()) 11479 MarkDeclarationsReferencedInExpr(C); 11480 } 11481 } 11482 } 11483 11484 // When are coming out of an unevaluated context, clear out any 11485 // temporaries that we may have created as part of the evaluation of 11486 // the expression in that context: they aren't relevant because they 11487 // will never be constructed. 11488 if (Rec.isUnevaluated() || Rec.Context == ConstantEvaluated) { 11489 ExprCleanupObjects.erase(ExprCleanupObjects.begin() + Rec.NumCleanupObjects, 11490 ExprCleanupObjects.end()); 11491 ExprNeedsCleanups = Rec.ParentNeedsCleanups; 11492 CleanupVarDeclMarking(); 11493 std::swap(MaybeODRUseExprs, Rec.SavedMaybeODRUseExprs); 11494 // Otherwise, merge the contexts together. 11495 } else { 11496 ExprNeedsCleanups |= Rec.ParentNeedsCleanups; 11497 MaybeODRUseExprs.insert(Rec.SavedMaybeODRUseExprs.begin(), 11498 Rec.SavedMaybeODRUseExprs.end()); 11499 } 11500 11501 // Pop the current expression evaluation context off the stack. 11502 ExprEvalContexts.pop_back(); 11503 11504 if (!ExprEvalContexts.empty()) 11505 ExprEvalContexts.back().NumTypos += NumTypos; 11506 else 11507 assert(NumTypos == 0 && "There are outstanding typos after popping the " 11508 "last ExpressionEvaluationContextRecord"); 11509 } 11510 11511 void Sema::DiscardCleanupsInEvaluationContext() { 11512 ExprCleanupObjects.erase( 11513 ExprCleanupObjects.begin() + ExprEvalContexts.back().NumCleanupObjects, 11514 ExprCleanupObjects.end()); 11515 ExprNeedsCleanups = false; 11516 MaybeODRUseExprs.clear(); 11517 } 11518 11519 ExprResult Sema::HandleExprEvaluationContextForTypeof(Expr *E) { 11520 if (!E->getType()->isVariablyModifiedType()) 11521 return E; 11522 return TransformToPotentiallyEvaluated(E); 11523 } 11524 11525 static bool IsPotentiallyEvaluatedContext(Sema &SemaRef) { 11526 // Do not mark anything as "used" within a dependent context; wait for 11527 // an instantiation. 11528 if (SemaRef.CurContext->isDependentContext()) 11529 return false; 11530 11531 switch (SemaRef.ExprEvalContexts.back().Context) { 11532 case Sema::Unevaluated: 11533 case Sema::UnevaluatedAbstract: 11534 // We are in an expression that is not potentially evaluated; do nothing. 11535 // (Depending on how you read the standard, we actually do need to do 11536 // something here for null pointer constants, but the standard's 11537 // definition of a null pointer constant is completely crazy.) 11538 return false; 11539 11540 case Sema::ConstantEvaluated: 11541 case Sema::PotentiallyEvaluated: 11542 // We are in a potentially evaluated expression (or a constant-expression 11543 // in C++03); we need to do implicit template instantiation, implicitly 11544 // define class members, and mark most declarations as used. 11545 return true; 11546 11547 case Sema::PotentiallyEvaluatedIfUsed: 11548 // Referenced declarations will only be used if the construct in the 11549 // containing expression is used. 11550 return false; 11551 } 11552 llvm_unreachable("Invalid context"); 11553 } 11554 11555 /// \brief Mark a function referenced, and check whether it is odr-used 11556 /// (C++ [basic.def.odr]p2, C99 6.9p3) 11557 void Sema::MarkFunctionReferenced(SourceLocation Loc, FunctionDecl *Func, 11558 bool OdrUse) { 11559 assert(Func && "No function?"); 11560 11561 Func->setReferenced(); 11562 11563 // C++11 [basic.def.odr]p3: 11564 // A function whose name appears as a potentially-evaluated expression is 11565 // odr-used if it is the unique lookup result or the selected member of a 11566 // set of overloaded functions [...]. 11567 // 11568 // We (incorrectly) mark overload resolution as an unevaluated context, so we 11569 // can just check that here. Skip the rest of this function if we've already 11570 // marked the function as used. 11571 if (Func->isUsed(false) || !IsPotentiallyEvaluatedContext(*this)) { 11572 // C++11 [temp.inst]p3: 11573 // Unless a function template specialization has been explicitly 11574 // instantiated or explicitly specialized, the function template 11575 // specialization is implicitly instantiated when the specialization is 11576 // referenced in a context that requires a function definition to exist. 11577 // 11578 // We consider constexpr function templates to be referenced in a context 11579 // that requires a definition to exist whenever they are referenced. 11580 // 11581 // FIXME: This instantiates constexpr functions too frequently. If this is 11582 // really an unevaluated context (and we're not just in the definition of a 11583 // function template or overload resolution or other cases which we 11584 // incorrectly consider to be unevaluated contexts), and we're not in a 11585 // subexpression which we actually need to evaluate (for instance, a 11586 // template argument, array bound or an expression in a braced-init-list), 11587 // we are not permitted to instantiate this constexpr function definition. 11588 // 11589 // FIXME: This also implicitly defines special members too frequently. They 11590 // are only supposed to be implicitly defined if they are odr-used, but they 11591 // are not odr-used from constant expressions in unevaluated contexts. 11592 // However, they cannot be referenced if they are deleted, and they are 11593 // deleted whenever the implicit definition of the special member would 11594 // fail. 11595 if (!Func->isConstexpr() || Func->getBody()) 11596 return; 11597 CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(Func); 11598 if (!Func->isImplicitlyInstantiable() && (!MD || MD->isUserProvided())) 11599 return; 11600 } 11601 11602 // Note that this declaration has been used. 11603 if (CXXConstructorDecl *Constructor = dyn_cast<CXXConstructorDecl>(Func)) { 11604 Constructor = cast<CXXConstructorDecl>(Constructor->getFirstDecl()); 11605 if (Constructor->isDefaulted() && !Constructor->isDeleted()) { 11606 if (Constructor->isDefaultConstructor()) { 11607 if (Constructor->isTrivial() && !Constructor->hasAttr<DLLExportAttr>()) 11608 return; 11609 DefineImplicitDefaultConstructor(Loc, Constructor); 11610 } else if (Constructor->isCopyConstructor()) { 11611 DefineImplicitCopyConstructor(Loc, Constructor); 11612 } else if (Constructor->isMoveConstructor()) { 11613 DefineImplicitMoveConstructor(Loc, Constructor); 11614 } 11615 } else if (Constructor->getInheritedConstructor()) { 11616 DefineInheritingConstructor(Loc, Constructor); 11617 } 11618 } else if (CXXDestructorDecl *Destructor = 11619 dyn_cast<CXXDestructorDecl>(Func)) { 11620 Destructor = cast<CXXDestructorDecl>(Destructor->getFirstDecl()); 11621 if (Destructor->isDefaulted() && !Destructor->isDeleted()) 11622 DefineImplicitDestructor(Loc, Destructor); 11623 if (Destructor->isVirtual()) 11624 MarkVTableUsed(Loc, Destructor->getParent()); 11625 } else if (CXXMethodDecl *MethodDecl = dyn_cast<CXXMethodDecl>(Func)) { 11626 if (MethodDecl->isOverloadedOperator() && 11627 MethodDecl->getOverloadedOperator() == OO_Equal) { 11628 MethodDecl = cast<CXXMethodDecl>(MethodDecl->getFirstDecl()); 11629 if (MethodDecl->isDefaulted() && !MethodDecl->isDeleted()) { 11630 if (MethodDecl->isCopyAssignmentOperator()) 11631 DefineImplicitCopyAssignment(Loc, MethodDecl); 11632 else 11633 DefineImplicitMoveAssignment(Loc, MethodDecl); 11634 } 11635 } else if (isa<CXXConversionDecl>(MethodDecl) && 11636 MethodDecl->getParent()->isLambda()) { 11637 CXXConversionDecl *Conversion = 11638 cast<CXXConversionDecl>(MethodDecl->getFirstDecl()); 11639 if (Conversion->isLambdaToBlockPointerConversion()) 11640 DefineImplicitLambdaToBlockPointerConversion(Loc, Conversion); 11641 else 11642 DefineImplicitLambdaToFunctionPointerConversion(Loc, Conversion); 11643 } else if (MethodDecl->isVirtual()) 11644 MarkVTableUsed(Loc, MethodDecl->getParent()); 11645 } 11646 11647 // Recursive functions should be marked when used from another function. 11648 // FIXME: Is this really right? 11649 if (CurContext == Func) return; 11650 11651 // Resolve the exception specification for any function which is 11652 // used: CodeGen will need it. 11653 const FunctionProtoType *FPT = Func->getType()->getAs<FunctionProtoType>(); 11654 if (FPT && isUnresolvedExceptionSpec(FPT->getExceptionSpecType())) 11655 ResolveExceptionSpec(Loc, FPT); 11656 11657 if (!OdrUse) return; 11658 11659 // Implicit instantiation of function templates and member functions of 11660 // class templates. 11661 if (Func->isImplicitlyInstantiable()) { 11662 bool AlreadyInstantiated = false; 11663 SourceLocation PointOfInstantiation = Loc; 11664 if (FunctionTemplateSpecializationInfo *SpecInfo 11665 = Func->getTemplateSpecializationInfo()) { 11666 if (SpecInfo->getPointOfInstantiation().isInvalid()) 11667 SpecInfo->setPointOfInstantiation(Loc); 11668 else if (SpecInfo->getTemplateSpecializationKind() 11669 == TSK_ImplicitInstantiation) { 11670 AlreadyInstantiated = true; 11671 PointOfInstantiation = SpecInfo->getPointOfInstantiation(); 11672 } 11673 } else if (MemberSpecializationInfo *MSInfo 11674 = Func->getMemberSpecializationInfo()) { 11675 if (MSInfo->getPointOfInstantiation().isInvalid()) 11676 MSInfo->setPointOfInstantiation(Loc); 11677 else if (MSInfo->getTemplateSpecializationKind() 11678 == TSK_ImplicitInstantiation) { 11679 AlreadyInstantiated = true; 11680 PointOfInstantiation = MSInfo->getPointOfInstantiation(); 11681 } 11682 } 11683 11684 if (!AlreadyInstantiated || Func->isConstexpr()) { 11685 if (isa<CXXRecordDecl>(Func->getDeclContext()) && 11686 cast<CXXRecordDecl>(Func->getDeclContext())->isLocalClass() && 11687 ActiveTemplateInstantiations.size()) 11688 PendingLocalImplicitInstantiations.push_back( 11689 std::make_pair(Func, PointOfInstantiation)); 11690 else if (Func->isConstexpr()) 11691 // Do not defer instantiations of constexpr functions, to avoid the 11692 // expression evaluator needing to call back into Sema if it sees a 11693 // call to such a function. 11694 InstantiateFunctionDefinition(PointOfInstantiation, Func); 11695 else { 11696 PendingInstantiations.push_back(std::make_pair(Func, 11697 PointOfInstantiation)); 11698 // Notify the consumer that a function was implicitly instantiated. 11699 Consumer.HandleCXXImplicitFunctionInstantiation(Func); 11700 } 11701 } 11702 } else { 11703 // Walk redefinitions, as some of them may be instantiable. 11704 for (auto i : Func->redecls()) { 11705 if (!i->isUsed(false) && i->isImplicitlyInstantiable()) 11706 MarkFunctionReferenced(Loc, i); 11707 } 11708 } 11709 11710 // Keep track of used but undefined functions. 11711 if (!Func->isDefined()) { 11712 if (mightHaveNonExternalLinkage(Func)) 11713 UndefinedButUsed.insert(std::make_pair(Func->getCanonicalDecl(), Loc)); 11714 else if (Func->getMostRecentDecl()->isInlined() && 11715 (LangOpts.CPlusPlus || !LangOpts.GNUInline) && 11716 !Func->getMostRecentDecl()->hasAttr<GNUInlineAttr>()) 11717 UndefinedButUsed.insert(std::make_pair(Func->getCanonicalDecl(), Loc)); 11718 } 11719 11720 // Normally the most current decl is marked used while processing the use and 11721 // any subsequent decls are marked used by decl merging. This fails with 11722 // template instantiation since marking can happen at the end of the file 11723 // and, because of the two phase lookup, this function is called with at 11724 // decl in the middle of a decl chain. We loop to maintain the invariant 11725 // that once a decl is used, all decls after it are also used. 11726 for (FunctionDecl *F = Func->getMostRecentDecl();; F = F->getPreviousDecl()) { 11727 F->markUsed(Context); 11728 if (F == Func) 11729 break; 11730 } 11731 } 11732 11733 static void 11734 diagnoseUncapturableValueReference(Sema &S, SourceLocation loc, 11735 VarDecl *var, DeclContext *DC) { 11736 DeclContext *VarDC = var->getDeclContext(); 11737 11738 // If the parameter still belongs to the translation unit, then 11739 // we're actually just using one parameter in the declaration of 11740 // the next. 11741 if (isa<ParmVarDecl>(var) && 11742 isa<TranslationUnitDecl>(VarDC)) 11743 return; 11744 11745 // For C code, don't diagnose about capture if we're not actually in code 11746 // right now; it's impossible to write a non-constant expression outside of 11747 // function context, so we'll get other (more useful) diagnostics later. 11748 // 11749 // For C++, things get a bit more nasty... it would be nice to suppress this 11750 // diagnostic for certain cases like using a local variable in an array bound 11751 // for a member of a local class, but the correct predicate is not obvious. 11752 if (!S.getLangOpts().CPlusPlus && !S.CurContext->isFunctionOrMethod()) 11753 return; 11754 11755 if (isa<CXXMethodDecl>(VarDC) && 11756 cast<CXXRecordDecl>(VarDC->getParent())->isLambda()) { 11757 S.Diag(loc, diag::err_reference_to_local_var_in_enclosing_lambda) 11758 << var->getIdentifier(); 11759 } else if (FunctionDecl *fn = dyn_cast<FunctionDecl>(VarDC)) { 11760 S.Diag(loc, diag::err_reference_to_local_var_in_enclosing_function) 11761 << var->getIdentifier() << fn->getDeclName(); 11762 } else if (isa<BlockDecl>(VarDC)) { 11763 S.Diag(loc, diag::err_reference_to_local_var_in_enclosing_block) 11764 << var->getIdentifier(); 11765 } else { 11766 // FIXME: Is there any other context where a local variable can be 11767 // declared? 11768 S.Diag(loc, diag::err_reference_to_local_var_in_enclosing_context) 11769 << var->getIdentifier(); 11770 } 11771 11772 S.Diag(var->getLocation(), diag::note_entity_declared_at) 11773 << var->getIdentifier(); 11774 11775 // FIXME: Add additional diagnostic info about class etc. which prevents 11776 // capture. 11777 } 11778 11779 11780 static bool isVariableAlreadyCapturedInScopeInfo(CapturingScopeInfo *CSI, VarDecl *Var, 11781 bool &SubCapturesAreNested, 11782 QualType &CaptureType, 11783 QualType &DeclRefType) { 11784 // Check whether we've already captured it. 11785 if (CSI->CaptureMap.count(Var)) { 11786 // If we found a capture, any subcaptures are nested. 11787 SubCapturesAreNested = true; 11788 11789 // Retrieve the capture type for this variable. 11790 CaptureType = CSI->getCapture(Var).getCaptureType(); 11791 11792 // Compute the type of an expression that refers to this variable. 11793 DeclRefType = CaptureType.getNonReferenceType(); 11794 11795 const CapturingScopeInfo::Capture &Cap = CSI->getCapture(Var); 11796 if (Cap.isCopyCapture() && 11797 !(isa<LambdaScopeInfo>(CSI) && cast<LambdaScopeInfo>(CSI)->Mutable)) 11798 DeclRefType.addConst(); 11799 return true; 11800 } 11801 return false; 11802 } 11803 11804 // Only block literals, captured statements, and lambda expressions can 11805 // capture; other scopes don't work. 11806 static DeclContext *getParentOfCapturingContextOrNull(DeclContext *DC, VarDecl *Var, 11807 SourceLocation Loc, 11808 const bool Diagnose, Sema &S) { 11809 if (isa<BlockDecl>(DC) || isa<CapturedDecl>(DC) || isLambdaCallOperator(DC)) 11810 return getLambdaAwareParentOfDeclContext(DC); 11811 else if (Var->hasLocalStorage()) { 11812 if (Diagnose) 11813 diagnoseUncapturableValueReference(S, Loc, Var, DC); 11814 } 11815 return nullptr; 11816 } 11817 11818 // Certain capturing entities (lambdas, blocks etc.) are not allowed to capture 11819 // certain types of variables (unnamed, variably modified types etc.) 11820 // so check for eligibility. 11821 static bool isVariableCapturable(CapturingScopeInfo *CSI, VarDecl *Var, 11822 SourceLocation Loc, 11823 const bool Diagnose, Sema &S) { 11824 11825 bool IsBlock = isa<BlockScopeInfo>(CSI); 11826 bool IsLambda = isa<LambdaScopeInfo>(CSI); 11827 11828 // Lambdas are not allowed to capture unnamed variables 11829 // (e.g. anonymous unions). 11830 // FIXME: The C++11 rule don't actually state this explicitly, but I'm 11831 // assuming that's the intent. 11832 if (IsLambda && !Var->getDeclName()) { 11833 if (Diagnose) { 11834 S.Diag(Loc, diag::err_lambda_capture_anonymous_var); 11835 S.Diag(Var->getLocation(), diag::note_declared_at); 11836 } 11837 return false; 11838 } 11839 11840 // Prohibit variably-modified types in blocks; they're difficult to deal with. 11841 if (Var->getType()->isVariablyModifiedType() && IsBlock) { 11842 if (Diagnose) { 11843 S.Diag(Loc, diag::err_ref_vm_type); 11844 S.Diag(Var->getLocation(), diag::note_previous_decl) 11845 << Var->getDeclName(); 11846 } 11847 return false; 11848 } 11849 // Prohibit structs with flexible array members too. 11850 // We cannot capture what is in the tail end of the struct. 11851 if (const RecordType *VTTy = Var->getType()->getAs<RecordType>()) { 11852 if (VTTy->getDecl()->hasFlexibleArrayMember()) { 11853 if (Diagnose) { 11854 if (IsBlock) 11855 S.Diag(Loc, diag::err_ref_flexarray_type); 11856 else 11857 S.Diag(Loc, diag::err_lambda_capture_flexarray_type) 11858 << Var->getDeclName(); 11859 S.Diag(Var->getLocation(), diag::note_previous_decl) 11860 << Var->getDeclName(); 11861 } 11862 return false; 11863 } 11864 } 11865 const bool HasBlocksAttr = Var->hasAttr<BlocksAttr>(); 11866 // Lambdas and captured statements are not allowed to capture __block 11867 // variables; they don't support the expected semantics. 11868 if (HasBlocksAttr && (IsLambda || isa<CapturedRegionScopeInfo>(CSI))) { 11869 if (Diagnose) { 11870 S.Diag(Loc, diag::err_capture_block_variable) 11871 << Var->getDeclName() << !IsLambda; 11872 S.Diag(Var->getLocation(), diag::note_previous_decl) 11873 << Var->getDeclName(); 11874 } 11875 return false; 11876 } 11877 11878 return true; 11879 } 11880 11881 // Returns true if the capture by block was successful. 11882 static bool captureInBlock(BlockScopeInfo *BSI, VarDecl *Var, 11883 SourceLocation Loc, 11884 const bool BuildAndDiagnose, 11885 QualType &CaptureType, 11886 QualType &DeclRefType, 11887 const bool Nested, 11888 Sema &S) { 11889 Expr *CopyExpr = nullptr; 11890 bool ByRef = false; 11891 11892 // Blocks are not allowed to capture arrays. 11893 if (CaptureType->isArrayType()) { 11894 if (BuildAndDiagnose) { 11895 S.Diag(Loc, diag::err_ref_array_type); 11896 S.Diag(Var->getLocation(), diag::note_previous_decl) 11897 << Var->getDeclName(); 11898 } 11899 return false; 11900 } 11901 11902 // Forbid the block-capture of autoreleasing variables. 11903 if (CaptureType.getObjCLifetime() == Qualifiers::OCL_Autoreleasing) { 11904 if (BuildAndDiagnose) { 11905 S.Diag(Loc, diag::err_arc_autoreleasing_capture) 11906 << /*block*/ 0; 11907 S.Diag(Var->getLocation(), diag::note_previous_decl) 11908 << Var->getDeclName(); 11909 } 11910 return false; 11911 } 11912 const bool HasBlocksAttr = Var->hasAttr<BlocksAttr>(); 11913 if (HasBlocksAttr || CaptureType->isReferenceType()) { 11914 // Block capture by reference does not change the capture or 11915 // declaration reference types. 11916 ByRef = true; 11917 } else { 11918 // Block capture by copy introduces 'const'. 11919 CaptureType = CaptureType.getNonReferenceType().withConst(); 11920 DeclRefType = CaptureType; 11921 11922 if (S.getLangOpts().CPlusPlus && BuildAndDiagnose) { 11923 if (const RecordType *Record = DeclRefType->getAs<RecordType>()) { 11924 // The capture logic needs the destructor, so make sure we mark it. 11925 // Usually this is unnecessary because most local variables have 11926 // their destructors marked at declaration time, but parameters are 11927 // an exception because it's technically only the call site that 11928 // actually requires the destructor. 11929 if (isa<ParmVarDecl>(Var)) 11930 S.FinalizeVarWithDestructor(Var, Record); 11931 11932 // Enter a new evaluation context to insulate the copy 11933 // full-expression. 11934 EnterExpressionEvaluationContext scope(S, S.PotentiallyEvaluated); 11935 11936 // According to the blocks spec, the capture of a variable from 11937 // the stack requires a const copy constructor. This is not true 11938 // of the copy/move done to move a __block variable to the heap. 11939 Expr *DeclRef = new (S.Context) DeclRefExpr(Var, Nested, 11940 DeclRefType.withConst(), 11941 VK_LValue, Loc); 11942 11943 ExprResult Result 11944 = S.PerformCopyInitialization( 11945 InitializedEntity::InitializeBlock(Var->getLocation(), 11946 CaptureType, false), 11947 Loc, DeclRef); 11948 11949 // Build a full-expression copy expression if initialization 11950 // succeeded and used a non-trivial constructor. Recover from 11951 // errors by pretending that the copy isn't necessary. 11952 if (!Result.isInvalid() && 11953 !cast<CXXConstructExpr>(Result.get())->getConstructor() 11954 ->isTrivial()) { 11955 Result = S.MaybeCreateExprWithCleanups(Result); 11956 CopyExpr = Result.get(); 11957 } 11958 } 11959 } 11960 } 11961 11962 // Actually capture the variable. 11963 if (BuildAndDiagnose) 11964 BSI->addCapture(Var, HasBlocksAttr, ByRef, Nested, Loc, 11965 SourceLocation(), CaptureType, CopyExpr); 11966 11967 return true; 11968 11969 } 11970 11971 11972 /// \brief Capture the given variable in the captured region. 11973 static bool captureInCapturedRegion(CapturedRegionScopeInfo *RSI, 11974 VarDecl *Var, 11975 SourceLocation Loc, 11976 const bool BuildAndDiagnose, 11977 QualType &CaptureType, 11978 QualType &DeclRefType, 11979 const bool RefersToCapturedVariable, 11980 Sema &S) { 11981 11982 // By default, capture variables by reference. 11983 bool ByRef = true; 11984 // Using an LValue reference type is consistent with Lambdas (see below). 11985 CaptureType = S.Context.getLValueReferenceType(DeclRefType); 11986 Expr *CopyExpr = nullptr; 11987 if (BuildAndDiagnose) { 11988 // The current implementation assumes that all variables are captured 11989 // by references. Since there is no capture by copy, no expression 11990 // evaluation will be needed. 11991 RecordDecl *RD = RSI->TheRecordDecl; 11992 11993 FieldDecl *Field 11994 = FieldDecl::Create(S.Context, RD, Loc, Loc, nullptr, CaptureType, 11995 S.Context.getTrivialTypeSourceInfo(CaptureType, Loc), 11996 nullptr, false, ICIS_NoInit); 11997 Field->setImplicit(true); 11998 Field->setAccess(AS_private); 11999 RD->addDecl(Field); 12000 12001 CopyExpr = new (S.Context) DeclRefExpr(Var, RefersToCapturedVariable, 12002 DeclRefType, VK_LValue, Loc); 12003 Var->setReferenced(true); 12004 Var->markUsed(S.Context); 12005 } 12006 12007 // Actually capture the variable. 12008 if (BuildAndDiagnose) 12009 RSI->addCapture(Var, /*isBlock*/false, ByRef, RefersToCapturedVariable, Loc, 12010 SourceLocation(), CaptureType, CopyExpr); 12011 12012 12013 return true; 12014 } 12015 12016 /// \brief Create a field within the lambda class for the variable 12017 /// being captured. Handle Array captures. 12018 static ExprResult addAsFieldToClosureType(Sema &S, 12019 LambdaScopeInfo *LSI, 12020 VarDecl *Var, QualType FieldType, 12021 QualType DeclRefType, 12022 SourceLocation Loc, 12023 bool RefersToCapturedVariable) { 12024 CXXRecordDecl *Lambda = LSI->Lambda; 12025 12026 // Build the non-static data member. 12027 FieldDecl *Field 12028 = FieldDecl::Create(S.Context, Lambda, Loc, Loc, nullptr, FieldType, 12029 S.Context.getTrivialTypeSourceInfo(FieldType, Loc), 12030 nullptr, false, ICIS_NoInit); 12031 Field->setImplicit(true); 12032 Field->setAccess(AS_private); 12033 Lambda->addDecl(Field); 12034 12035 // C++11 [expr.prim.lambda]p21: 12036 // When the lambda-expression is evaluated, the entities that 12037 // are captured by copy are used to direct-initialize each 12038 // corresponding non-static data member of the resulting closure 12039 // object. (For array members, the array elements are 12040 // direct-initialized in increasing subscript order.) These 12041 // initializations are performed in the (unspecified) order in 12042 // which the non-static data members are declared. 12043 12044 // Introduce a new evaluation context for the initialization, so 12045 // that temporaries introduced as part of the capture are retained 12046 // to be re-"exported" from the lambda expression itself. 12047 EnterExpressionEvaluationContext scope(S, Sema::PotentiallyEvaluated); 12048 12049 // C++ [expr.prim.labda]p12: 12050 // An entity captured by a lambda-expression is odr-used (3.2) in 12051 // the scope containing the lambda-expression. 12052 Expr *Ref = new (S.Context) DeclRefExpr(Var, RefersToCapturedVariable, 12053 DeclRefType, VK_LValue, Loc); 12054 Var->setReferenced(true); 12055 Var->markUsed(S.Context); 12056 12057 // When the field has array type, create index variables for each 12058 // dimension of the array. We use these index variables to subscript 12059 // the source array, and other clients (e.g., CodeGen) will perform 12060 // the necessary iteration with these index variables. 12061 SmallVector<VarDecl *, 4> IndexVariables; 12062 QualType BaseType = FieldType; 12063 QualType SizeType = S.Context.getSizeType(); 12064 LSI->ArrayIndexStarts.push_back(LSI->ArrayIndexVars.size()); 12065 while (const ConstantArrayType *Array 12066 = S.Context.getAsConstantArrayType(BaseType)) { 12067 // Create the iteration variable for this array index. 12068 IdentifierInfo *IterationVarName = nullptr; 12069 { 12070 SmallString<8> Str; 12071 llvm::raw_svector_ostream OS(Str); 12072 OS << "__i" << IndexVariables.size(); 12073 IterationVarName = &S.Context.Idents.get(OS.str()); 12074 } 12075 VarDecl *IterationVar 12076 = VarDecl::Create(S.Context, S.CurContext, Loc, Loc, 12077 IterationVarName, SizeType, 12078 S.Context.getTrivialTypeSourceInfo(SizeType, Loc), 12079 SC_None); 12080 IndexVariables.push_back(IterationVar); 12081 LSI->ArrayIndexVars.push_back(IterationVar); 12082 12083 // Create a reference to the iteration variable. 12084 ExprResult IterationVarRef 12085 = S.BuildDeclRefExpr(IterationVar, SizeType, VK_LValue, Loc); 12086 assert(!IterationVarRef.isInvalid() && 12087 "Reference to invented variable cannot fail!"); 12088 IterationVarRef = S.DefaultLvalueConversion(IterationVarRef.get()); 12089 assert(!IterationVarRef.isInvalid() && 12090 "Conversion of invented variable cannot fail!"); 12091 12092 // Subscript the array with this iteration variable. 12093 ExprResult Subscript = S.CreateBuiltinArraySubscriptExpr( 12094 Ref, Loc, IterationVarRef.get(), Loc); 12095 if (Subscript.isInvalid()) { 12096 S.CleanupVarDeclMarking(); 12097 S.DiscardCleanupsInEvaluationContext(); 12098 return ExprError(); 12099 } 12100 12101 Ref = Subscript.get(); 12102 BaseType = Array->getElementType(); 12103 } 12104 12105 // Construct the entity that we will be initializing. For an array, this 12106 // will be first element in the array, which may require several levels 12107 // of array-subscript entities. 12108 SmallVector<InitializedEntity, 4> Entities; 12109 Entities.reserve(1 + IndexVariables.size()); 12110 Entities.push_back( 12111 InitializedEntity::InitializeLambdaCapture(Var->getIdentifier(), 12112 Field->getType(), Loc)); 12113 for (unsigned I = 0, N = IndexVariables.size(); I != N; ++I) 12114 Entities.push_back(InitializedEntity::InitializeElement(S.Context, 12115 0, 12116 Entities.back())); 12117 12118 InitializationKind InitKind 12119 = InitializationKind::CreateDirect(Loc, Loc, Loc); 12120 InitializationSequence Init(S, Entities.back(), InitKind, Ref); 12121 ExprResult Result(true); 12122 if (!Init.Diagnose(S, Entities.back(), InitKind, Ref)) 12123 Result = Init.Perform(S, Entities.back(), InitKind, Ref); 12124 12125 // If this initialization requires any cleanups (e.g., due to a 12126 // default argument to a copy constructor), note that for the 12127 // lambda. 12128 if (S.ExprNeedsCleanups) 12129 LSI->ExprNeedsCleanups = true; 12130 12131 // Exit the expression evaluation context used for the capture. 12132 S.CleanupVarDeclMarking(); 12133 S.DiscardCleanupsInEvaluationContext(); 12134 return Result; 12135 } 12136 12137 12138 12139 /// \brief Capture the given variable in the lambda. 12140 static bool captureInLambda(LambdaScopeInfo *LSI, 12141 VarDecl *Var, 12142 SourceLocation Loc, 12143 const bool BuildAndDiagnose, 12144 QualType &CaptureType, 12145 QualType &DeclRefType, 12146 const bool RefersToCapturedVariable, 12147 const Sema::TryCaptureKind Kind, 12148 SourceLocation EllipsisLoc, 12149 const bool IsTopScope, 12150 Sema &S) { 12151 12152 // Determine whether we are capturing by reference or by value. 12153 bool ByRef = false; 12154 if (IsTopScope && Kind != Sema::TryCapture_Implicit) { 12155 ByRef = (Kind == Sema::TryCapture_ExplicitByRef); 12156 } else { 12157 ByRef = (LSI->ImpCaptureStyle == LambdaScopeInfo::ImpCap_LambdaByref); 12158 } 12159 12160 // Compute the type of the field that will capture this variable. 12161 if (ByRef) { 12162 // C++11 [expr.prim.lambda]p15: 12163 // An entity is captured by reference if it is implicitly or 12164 // explicitly captured but not captured by copy. It is 12165 // unspecified whether additional unnamed non-static data 12166 // members are declared in the closure type for entities 12167 // captured by reference. 12168 // 12169 // FIXME: It is not clear whether we want to build an lvalue reference 12170 // to the DeclRefType or to CaptureType.getNonReferenceType(). GCC appears 12171 // to do the former, while EDG does the latter. Core issue 1249 will 12172 // clarify, but for now we follow GCC because it's a more permissive and 12173 // easily defensible position. 12174 CaptureType = S.Context.getLValueReferenceType(DeclRefType); 12175 } else { 12176 // C++11 [expr.prim.lambda]p14: 12177 // For each entity captured by copy, an unnamed non-static 12178 // data member is declared in the closure type. The 12179 // declaration order of these members is unspecified. The type 12180 // of such a data member is the type of the corresponding 12181 // captured entity if the entity is not a reference to an 12182 // object, or the referenced type otherwise. [Note: If the 12183 // captured entity is a reference to a function, the 12184 // corresponding data member is also a reference to a 12185 // function. - end note ] 12186 if (const ReferenceType *RefType = CaptureType->getAs<ReferenceType>()){ 12187 if (!RefType->getPointeeType()->isFunctionType()) 12188 CaptureType = RefType->getPointeeType(); 12189 } 12190 12191 // Forbid the lambda copy-capture of autoreleasing variables. 12192 if (CaptureType.getObjCLifetime() == Qualifiers::OCL_Autoreleasing) { 12193 if (BuildAndDiagnose) { 12194 S.Diag(Loc, diag::err_arc_autoreleasing_capture) << /*lambda*/ 1; 12195 S.Diag(Var->getLocation(), diag::note_previous_decl) 12196 << Var->getDeclName(); 12197 } 12198 return false; 12199 } 12200 12201 // Make sure that by-copy captures are of a complete and non-abstract type. 12202 if (BuildAndDiagnose) { 12203 if (!CaptureType->isDependentType() && 12204 S.RequireCompleteType(Loc, CaptureType, 12205 diag::err_capture_of_incomplete_type, 12206 Var->getDeclName())) 12207 return false; 12208 12209 if (S.RequireNonAbstractType(Loc, CaptureType, 12210 diag::err_capture_of_abstract_type)) 12211 return false; 12212 } 12213 } 12214 12215 // Capture this variable in the lambda. 12216 Expr *CopyExpr = nullptr; 12217 if (BuildAndDiagnose) { 12218 ExprResult Result = addAsFieldToClosureType(S, LSI, Var, 12219 CaptureType, DeclRefType, Loc, 12220 RefersToCapturedVariable); 12221 if (!Result.isInvalid()) 12222 CopyExpr = Result.get(); 12223 } 12224 12225 // Compute the type of a reference to this captured variable. 12226 if (ByRef) 12227 DeclRefType = CaptureType.getNonReferenceType(); 12228 else { 12229 // C++ [expr.prim.lambda]p5: 12230 // The closure type for a lambda-expression has a public inline 12231 // function call operator [...]. This function call operator is 12232 // declared const (9.3.1) if and only if the lambda-expression’s 12233 // parameter-declaration-clause is not followed by mutable. 12234 DeclRefType = CaptureType.getNonReferenceType(); 12235 if (!LSI->Mutable && !CaptureType->isReferenceType()) 12236 DeclRefType.addConst(); 12237 } 12238 12239 // Add the capture. 12240 if (BuildAndDiagnose) 12241 LSI->addCapture(Var, /*IsBlock=*/false, ByRef, RefersToCapturedVariable, 12242 Loc, EllipsisLoc, CaptureType, CopyExpr); 12243 12244 return true; 12245 } 12246 12247 bool Sema::tryCaptureVariable(VarDecl *Var, SourceLocation ExprLoc, 12248 TryCaptureKind Kind, SourceLocation EllipsisLoc, 12249 bool BuildAndDiagnose, 12250 QualType &CaptureType, 12251 QualType &DeclRefType, 12252 const unsigned *const FunctionScopeIndexToStopAt) { 12253 bool Nested = Var->isInitCapture(); 12254 12255 DeclContext *DC = CurContext; 12256 const unsigned MaxFunctionScopesIndex = FunctionScopeIndexToStopAt 12257 ? *FunctionScopeIndexToStopAt : FunctionScopes.size() - 1; 12258 // We need to sync up the Declaration Context with the 12259 // FunctionScopeIndexToStopAt 12260 if (FunctionScopeIndexToStopAt) { 12261 unsigned FSIndex = FunctionScopes.size() - 1; 12262 while (FSIndex != MaxFunctionScopesIndex) { 12263 DC = getLambdaAwareParentOfDeclContext(DC); 12264 --FSIndex; 12265 } 12266 } 12267 12268 12269 // If the variable is declared in the current context (and is not an 12270 // init-capture), there is no need to capture it. 12271 if (!Nested && Var->getDeclContext() == DC) return true; 12272 12273 // Capture global variables if it is required to use private copy of this 12274 // variable. 12275 bool IsGlobal = !Var->hasLocalStorage(); 12276 if (IsGlobal && !(LangOpts.OpenMP && IsOpenMPCapturedVar(Var))) 12277 return true; 12278 12279 // Walk up the stack to determine whether we can capture the variable, 12280 // performing the "simple" checks that don't depend on type. We stop when 12281 // we've either hit the declared scope of the variable or find an existing 12282 // capture of that variable. We start from the innermost capturing-entity 12283 // (the DC) and ensure that all intervening capturing-entities 12284 // (blocks/lambdas etc.) between the innermost capturer and the variable`s 12285 // declcontext can either capture the variable or have already captured 12286 // the variable. 12287 CaptureType = Var->getType(); 12288 DeclRefType = CaptureType.getNonReferenceType(); 12289 bool Explicit = (Kind != TryCapture_Implicit); 12290 unsigned FunctionScopesIndex = MaxFunctionScopesIndex; 12291 do { 12292 // Only block literals, captured statements, and lambda expressions can 12293 // capture; other scopes don't work. 12294 DeclContext *ParentDC = getParentOfCapturingContextOrNull(DC, Var, 12295 ExprLoc, 12296 BuildAndDiagnose, 12297 *this); 12298 // We need to check for the parent *first* because, if we *have* 12299 // private-captured a global variable, we need to recursively capture it in 12300 // intermediate blocks, lambdas, etc. 12301 if (!ParentDC) { 12302 if (IsGlobal) { 12303 FunctionScopesIndex = MaxFunctionScopesIndex - 1; 12304 break; 12305 } 12306 return true; 12307 } 12308 12309 FunctionScopeInfo *FSI = FunctionScopes[FunctionScopesIndex]; 12310 CapturingScopeInfo *CSI = cast<CapturingScopeInfo>(FSI); 12311 12312 12313 // Check whether we've already captured it. 12314 if (isVariableAlreadyCapturedInScopeInfo(CSI, Var, Nested, CaptureType, 12315 DeclRefType)) 12316 break; 12317 // If we are instantiating a generic lambda call operator body, 12318 // we do not want to capture new variables. What was captured 12319 // during either a lambdas transformation or initial parsing 12320 // should be used. 12321 if (isGenericLambdaCallOperatorSpecialization(DC)) { 12322 if (BuildAndDiagnose) { 12323 LambdaScopeInfo *LSI = cast<LambdaScopeInfo>(CSI); 12324 if (LSI->ImpCaptureStyle == CapturingScopeInfo::ImpCap_None) { 12325 Diag(ExprLoc, diag::err_lambda_impcap) << Var->getDeclName(); 12326 Diag(Var->getLocation(), diag::note_previous_decl) 12327 << Var->getDeclName(); 12328 Diag(LSI->Lambda->getLocStart(), diag::note_lambda_decl); 12329 } else 12330 diagnoseUncapturableValueReference(*this, ExprLoc, Var, DC); 12331 } 12332 return true; 12333 } 12334 // Certain capturing entities (lambdas, blocks etc.) are not allowed to capture 12335 // certain types of variables (unnamed, variably modified types etc.) 12336 // so check for eligibility. 12337 if (!isVariableCapturable(CSI, Var, ExprLoc, BuildAndDiagnose, *this)) 12338 return true; 12339 12340 // Try to capture variable-length arrays types. 12341 if (Var->getType()->isVariablyModifiedType()) { 12342 // We're going to walk down into the type and look for VLA 12343 // expressions. 12344 QualType QTy = Var->getType(); 12345 if (ParmVarDecl *PVD = dyn_cast_or_null<ParmVarDecl>(Var)) 12346 QTy = PVD->getOriginalType(); 12347 do { 12348 const Type *Ty = QTy.getTypePtr(); 12349 switch (Ty->getTypeClass()) { 12350 #define TYPE(Class, Base) 12351 #define ABSTRACT_TYPE(Class, Base) 12352 #define NON_CANONICAL_TYPE(Class, Base) 12353 #define DEPENDENT_TYPE(Class, Base) case Type::Class: 12354 #define NON_CANONICAL_UNLESS_DEPENDENT_TYPE(Class, Base) 12355 #include "clang/AST/TypeNodes.def" 12356 QTy = QualType(); 12357 break; 12358 // These types are never variably-modified. 12359 case Type::Builtin: 12360 case Type::Complex: 12361 case Type::Vector: 12362 case Type::ExtVector: 12363 case Type::Record: 12364 case Type::Enum: 12365 case Type::Elaborated: 12366 case Type::TemplateSpecialization: 12367 case Type::ObjCObject: 12368 case Type::ObjCInterface: 12369 case Type::ObjCObjectPointer: 12370 llvm_unreachable("type class is never variably-modified!"); 12371 case Type::Adjusted: 12372 QTy = cast<AdjustedType>(Ty)->getOriginalType(); 12373 break; 12374 case Type::Decayed: 12375 QTy = cast<DecayedType>(Ty)->getPointeeType(); 12376 break; 12377 case Type::Pointer: 12378 QTy = cast<PointerType>(Ty)->getPointeeType(); 12379 break; 12380 case Type::BlockPointer: 12381 QTy = cast<BlockPointerType>(Ty)->getPointeeType(); 12382 break; 12383 case Type::LValueReference: 12384 case Type::RValueReference: 12385 QTy = cast<ReferenceType>(Ty)->getPointeeType(); 12386 break; 12387 case Type::MemberPointer: 12388 QTy = cast<MemberPointerType>(Ty)->getPointeeType(); 12389 break; 12390 case Type::ConstantArray: 12391 case Type::IncompleteArray: 12392 // Losing element qualification here is fine. 12393 QTy = cast<ArrayType>(Ty)->getElementType(); 12394 break; 12395 case Type::VariableArray: { 12396 // Losing element qualification here is fine. 12397 const VariableArrayType *VAT = cast<VariableArrayType>(Ty); 12398 12399 // Unknown size indication requires no size computation. 12400 // Otherwise, evaluate and record it. 12401 if (auto Size = VAT->getSizeExpr()) { 12402 if (!CSI->isVLATypeCaptured(VAT)) { 12403 RecordDecl *CapRecord = nullptr; 12404 if (auto LSI = dyn_cast<LambdaScopeInfo>(CSI)) { 12405 CapRecord = LSI->Lambda; 12406 } else if (auto CRSI = dyn_cast<CapturedRegionScopeInfo>(CSI)) { 12407 CapRecord = CRSI->TheRecordDecl; 12408 } 12409 if (CapRecord) { 12410 auto ExprLoc = Size->getExprLoc(); 12411 auto SizeType = Context.getSizeType(); 12412 // Build the non-static data member. 12413 auto Field = FieldDecl::Create( 12414 Context, CapRecord, ExprLoc, ExprLoc, 12415 /*Id*/ nullptr, SizeType, /*TInfo*/ nullptr, 12416 /*BW*/ nullptr, /*Mutable*/ false, 12417 /*InitStyle*/ ICIS_NoInit); 12418 Field->setImplicit(true); 12419 Field->setAccess(AS_private); 12420 Field->setCapturedVLAType(VAT); 12421 CapRecord->addDecl(Field); 12422 12423 CSI->addVLATypeCapture(ExprLoc, SizeType); 12424 } 12425 } 12426 } 12427 QTy = VAT->getElementType(); 12428 break; 12429 } 12430 case Type::FunctionProto: 12431 case Type::FunctionNoProto: 12432 QTy = cast<FunctionType>(Ty)->getReturnType(); 12433 break; 12434 case Type::Paren: 12435 case Type::TypeOf: 12436 case Type::UnaryTransform: 12437 case Type::Attributed: 12438 case Type::SubstTemplateTypeParm: 12439 case Type::PackExpansion: 12440 // Keep walking after single level desugaring. 12441 QTy = QTy.getSingleStepDesugaredType(getASTContext()); 12442 break; 12443 case Type::Typedef: 12444 QTy = cast<TypedefType>(Ty)->desugar(); 12445 break; 12446 case Type::Decltype: 12447 QTy = cast<DecltypeType>(Ty)->desugar(); 12448 break; 12449 case Type::Auto: 12450 QTy = cast<AutoType>(Ty)->getDeducedType(); 12451 break; 12452 case Type::TypeOfExpr: 12453 QTy = cast<TypeOfExprType>(Ty)->getUnderlyingExpr()->getType(); 12454 break; 12455 case Type::Atomic: 12456 QTy = cast<AtomicType>(Ty)->getValueType(); 12457 break; 12458 } 12459 } while (!QTy.isNull() && QTy->isVariablyModifiedType()); 12460 } 12461 12462 if (CSI->ImpCaptureStyle == CapturingScopeInfo::ImpCap_None && !Explicit) { 12463 // No capture-default, and this is not an explicit capture 12464 // so cannot capture this variable. 12465 if (BuildAndDiagnose) { 12466 Diag(ExprLoc, diag::err_lambda_impcap) << Var->getDeclName(); 12467 Diag(Var->getLocation(), diag::note_previous_decl) 12468 << Var->getDeclName(); 12469 Diag(cast<LambdaScopeInfo>(CSI)->Lambda->getLocStart(), 12470 diag::note_lambda_decl); 12471 // FIXME: If we error out because an outer lambda can not implicitly 12472 // capture a variable that an inner lambda explicitly captures, we 12473 // should have the inner lambda do the explicit capture - because 12474 // it makes for cleaner diagnostics later. This would purely be done 12475 // so that the diagnostic does not misleadingly claim that a variable 12476 // can not be captured by a lambda implicitly even though it is captured 12477 // explicitly. Suggestion: 12478 // - create const bool VariableCaptureWasInitiallyExplicit = Explicit 12479 // at the function head 12480 // - cache the StartingDeclContext - this must be a lambda 12481 // - captureInLambda in the innermost lambda the variable. 12482 } 12483 return true; 12484 } 12485 12486 FunctionScopesIndex--; 12487 DC = ParentDC; 12488 Explicit = false; 12489 } while (!Var->getDeclContext()->Equals(DC)); 12490 12491 // Walk back down the scope stack, (e.g. from outer lambda to inner lambda) 12492 // computing the type of the capture at each step, checking type-specific 12493 // requirements, and adding captures if requested. 12494 // If the variable had already been captured previously, we start capturing 12495 // at the lambda nested within that one. 12496 for (unsigned I = ++FunctionScopesIndex, N = MaxFunctionScopesIndex + 1; I != N; 12497 ++I) { 12498 CapturingScopeInfo *CSI = cast<CapturingScopeInfo>(FunctionScopes[I]); 12499 12500 if (BlockScopeInfo *BSI = dyn_cast<BlockScopeInfo>(CSI)) { 12501 if (!captureInBlock(BSI, Var, ExprLoc, 12502 BuildAndDiagnose, CaptureType, 12503 DeclRefType, Nested, *this)) 12504 return true; 12505 Nested = true; 12506 } else if (CapturedRegionScopeInfo *RSI = dyn_cast<CapturedRegionScopeInfo>(CSI)) { 12507 if (!captureInCapturedRegion(RSI, Var, ExprLoc, 12508 BuildAndDiagnose, CaptureType, 12509 DeclRefType, Nested, *this)) 12510 return true; 12511 Nested = true; 12512 } else { 12513 LambdaScopeInfo *LSI = cast<LambdaScopeInfo>(CSI); 12514 if (!captureInLambda(LSI, Var, ExprLoc, 12515 BuildAndDiagnose, CaptureType, 12516 DeclRefType, Nested, Kind, EllipsisLoc, 12517 /*IsTopScope*/I == N - 1, *this)) 12518 return true; 12519 Nested = true; 12520 } 12521 } 12522 return false; 12523 } 12524 12525 bool Sema::tryCaptureVariable(VarDecl *Var, SourceLocation Loc, 12526 TryCaptureKind Kind, SourceLocation EllipsisLoc) { 12527 QualType CaptureType; 12528 QualType DeclRefType; 12529 return tryCaptureVariable(Var, Loc, Kind, EllipsisLoc, 12530 /*BuildAndDiagnose=*/true, CaptureType, 12531 DeclRefType, nullptr); 12532 } 12533 12534 bool Sema::NeedToCaptureVariable(VarDecl *Var, SourceLocation Loc) { 12535 QualType CaptureType; 12536 QualType DeclRefType; 12537 return !tryCaptureVariable(Var, Loc, TryCapture_Implicit, SourceLocation(), 12538 /*BuildAndDiagnose=*/false, CaptureType, 12539 DeclRefType, nullptr); 12540 } 12541 12542 QualType Sema::getCapturedDeclRefType(VarDecl *Var, SourceLocation Loc) { 12543 QualType CaptureType; 12544 QualType DeclRefType; 12545 12546 // Determine whether we can capture this variable. 12547 if (tryCaptureVariable(Var, Loc, TryCapture_Implicit, SourceLocation(), 12548 /*BuildAndDiagnose=*/false, CaptureType, 12549 DeclRefType, nullptr)) 12550 return QualType(); 12551 12552 return DeclRefType; 12553 } 12554 12555 12556 12557 // If either the type of the variable or the initializer is dependent, 12558 // return false. Otherwise, determine whether the variable is a constant 12559 // expression. Use this if you need to know if a variable that might or 12560 // might not be dependent is truly a constant expression. 12561 static inline bool IsVariableNonDependentAndAConstantExpression(VarDecl *Var, 12562 ASTContext &Context) { 12563 12564 if (Var->getType()->isDependentType()) 12565 return false; 12566 const VarDecl *DefVD = nullptr; 12567 Var->getAnyInitializer(DefVD); 12568 if (!DefVD) 12569 return false; 12570 EvaluatedStmt *Eval = DefVD->ensureEvaluatedStmt(); 12571 Expr *Init = cast<Expr>(Eval->Value); 12572 if (Init->isValueDependent()) 12573 return false; 12574 return IsVariableAConstantExpression(Var, Context); 12575 } 12576 12577 12578 void Sema::UpdateMarkingForLValueToRValue(Expr *E) { 12579 // Per C++11 [basic.def.odr], a variable is odr-used "unless it is 12580 // an object that satisfies the requirements for appearing in a 12581 // constant expression (5.19) and the lvalue-to-rvalue conversion (4.1) 12582 // is immediately applied." This function handles the lvalue-to-rvalue 12583 // conversion part. 12584 MaybeODRUseExprs.erase(E->IgnoreParens()); 12585 12586 // If we are in a lambda, check if this DeclRefExpr or MemberExpr refers 12587 // to a variable that is a constant expression, and if so, identify it as 12588 // a reference to a variable that does not involve an odr-use of that 12589 // variable. 12590 if (LambdaScopeInfo *LSI = getCurLambda()) { 12591 Expr *SansParensExpr = E->IgnoreParens(); 12592 VarDecl *Var = nullptr; 12593 if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(SansParensExpr)) 12594 Var = dyn_cast<VarDecl>(DRE->getFoundDecl()); 12595 else if (MemberExpr *ME = dyn_cast<MemberExpr>(SansParensExpr)) 12596 Var = dyn_cast<VarDecl>(ME->getMemberDecl()); 12597 12598 if (Var && IsVariableNonDependentAndAConstantExpression(Var, Context)) 12599 LSI->markVariableExprAsNonODRUsed(SansParensExpr); 12600 } 12601 } 12602 12603 ExprResult Sema::ActOnConstantExpression(ExprResult Res) { 12604 Res = CorrectDelayedTyposInExpr(Res); 12605 12606 if (!Res.isUsable()) 12607 return Res; 12608 12609 // If a constant-expression is a reference to a variable where we delay 12610 // deciding whether it is an odr-use, just assume we will apply the 12611 // lvalue-to-rvalue conversion. In the one case where this doesn't happen 12612 // (a non-type template argument), we have special handling anyway. 12613 UpdateMarkingForLValueToRValue(Res.get()); 12614 return Res; 12615 } 12616 12617 void Sema::CleanupVarDeclMarking() { 12618 for (llvm::SmallPtrSetIterator<Expr*> i = MaybeODRUseExprs.begin(), 12619 e = MaybeODRUseExprs.end(); 12620 i != e; ++i) { 12621 VarDecl *Var; 12622 SourceLocation Loc; 12623 if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(*i)) { 12624 Var = cast<VarDecl>(DRE->getDecl()); 12625 Loc = DRE->getLocation(); 12626 } else if (MemberExpr *ME = dyn_cast<MemberExpr>(*i)) { 12627 Var = cast<VarDecl>(ME->getMemberDecl()); 12628 Loc = ME->getMemberLoc(); 12629 } else { 12630 llvm_unreachable("Unexpected expression"); 12631 } 12632 12633 MarkVarDeclODRUsed(Var, Loc, *this, 12634 /*MaxFunctionScopeIndex Pointer*/ nullptr); 12635 } 12636 12637 MaybeODRUseExprs.clear(); 12638 } 12639 12640 12641 static void DoMarkVarDeclReferenced(Sema &SemaRef, SourceLocation Loc, 12642 VarDecl *Var, Expr *E) { 12643 assert((!E || isa<DeclRefExpr>(E) || isa<MemberExpr>(E)) && 12644 "Invalid Expr argument to DoMarkVarDeclReferenced"); 12645 Var->setReferenced(); 12646 12647 TemplateSpecializationKind TSK = Var->getTemplateSpecializationKind(); 12648 bool MarkODRUsed = true; 12649 12650 // If the context is not potentially evaluated, this is not an odr-use and 12651 // does not trigger instantiation. 12652 if (!IsPotentiallyEvaluatedContext(SemaRef)) { 12653 if (SemaRef.isUnevaluatedContext()) 12654 return; 12655 12656 // If we don't yet know whether this context is going to end up being an 12657 // evaluated context, and we're referencing a variable from an enclosing 12658 // scope, add a potential capture. 12659 // 12660 // FIXME: Is this necessary? These contexts are only used for default 12661 // arguments, where local variables can't be used. 12662 const bool RefersToEnclosingScope = 12663 (SemaRef.CurContext != Var->getDeclContext() && 12664 Var->getDeclContext()->isFunctionOrMethod() && Var->hasLocalStorage()); 12665 if (RefersToEnclosingScope) { 12666 if (LambdaScopeInfo *const LSI = SemaRef.getCurLambda()) { 12667 // If a variable could potentially be odr-used, defer marking it so 12668 // until we finish analyzing the full expression for any 12669 // lvalue-to-rvalue 12670 // or discarded value conversions that would obviate odr-use. 12671 // Add it to the list of potential captures that will be analyzed 12672 // later (ActOnFinishFullExpr) for eventual capture and odr-use marking 12673 // unless the variable is a reference that was initialized by a constant 12674 // expression (this will never need to be captured or odr-used). 12675 assert(E && "Capture variable should be used in an expression."); 12676 if (!Var->getType()->isReferenceType() || 12677 !IsVariableNonDependentAndAConstantExpression(Var, SemaRef.Context)) 12678 LSI->addPotentialCapture(E->IgnoreParens()); 12679 } 12680 } 12681 12682 if (!isTemplateInstantiation(TSK)) 12683 return; 12684 12685 // Instantiate, but do not mark as odr-used, variable templates. 12686 MarkODRUsed = false; 12687 } 12688 12689 VarTemplateSpecializationDecl *VarSpec = 12690 dyn_cast<VarTemplateSpecializationDecl>(Var); 12691 assert(!isa<VarTemplatePartialSpecializationDecl>(Var) && 12692 "Can't instantiate a partial template specialization."); 12693 12694 // Perform implicit instantiation of static data members, static data member 12695 // templates of class templates, and variable template specializations. Delay 12696 // instantiations of variable templates, except for those that could be used 12697 // in a constant expression. 12698 if (isTemplateInstantiation(TSK)) { 12699 bool TryInstantiating = TSK == TSK_ImplicitInstantiation; 12700 12701 if (TryInstantiating && !isa<VarTemplateSpecializationDecl>(Var)) { 12702 if (Var->getPointOfInstantiation().isInvalid()) { 12703 // This is a modification of an existing AST node. Notify listeners. 12704 if (ASTMutationListener *L = SemaRef.getASTMutationListener()) 12705 L->StaticDataMemberInstantiated(Var); 12706 } else if (!Var->isUsableInConstantExpressions(SemaRef.Context)) 12707 // Don't bother trying to instantiate it again, unless we might need 12708 // its initializer before we get to the end of the TU. 12709 TryInstantiating = false; 12710 } 12711 12712 if (Var->getPointOfInstantiation().isInvalid()) 12713 Var->setTemplateSpecializationKind(TSK, Loc); 12714 12715 if (TryInstantiating) { 12716 SourceLocation PointOfInstantiation = Var->getPointOfInstantiation(); 12717 bool InstantiationDependent = false; 12718 bool IsNonDependent = 12719 VarSpec ? !TemplateSpecializationType::anyDependentTemplateArguments( 12720 VarSpec->getTemplateArgsInfo(), InstantiationDependent) 12721 : true; 12722 12723 // Do not instantiate specializations that are still type-dependent. 12724 if (IsNonDependent) { 12725 if (Var->isUsableInConstantExpressions(SemaRef.Context)) { 12726 // Do not defer instantiations of variables which could be used in a 12727 // constant expression. 12728 SemaRef.InstantiateVariableDefinition(PointOfInstantiation, Var); 12729 } else { 12730 SemaRef.PendingInstantiations 12731 .push_back(std::make_pair(Var, PointOfInstantiation)); 12732 } 12733 } 12734 } 12735 } 12736 12737 if(!MarkODRUsed) return; 12738 12739 // Per C++11 [basic.def.odr], a variable is odr-used "unless it satisfies 12740 // the requirements for appearing in a constant expression (5.19) and, if 12741 // it is an object, the lvalue-to-rvalue conversion (4.1) 12742 // is immediately applied." We check the first part here, and 12743 // Sema::UpdateMarkingForLValueToRValue deals with the second part. 12744 // Note that we use the C++11 definition everywhere because nothing in 12745 // C++03 depends on whether we get the C++03 version correct. The second 12746 // part does not apply to references, since they are not objects. 12747 if (E && IsVariableAConstantExpression(Var, SemaRef.Context)) { 12748 // A reference initialized by a constant expression can never be 12749 // odr-used, so simply ignore it. 12750 if (!Var->getType()->isReferenceType()) 12751 SemaRef.MaybeODRUseExprs.insert(E); 12752 } else 12753 MarkVarDeclODRUsed(Var, Loc, SemaRef, 12754 /*MaxFunctionScopeIndex ptr*/ nullptr); 12755 } 12756 12757 /// \brief Mark a variable referenced, and check whether it is odr-used 12758 /// (C++ [basic.def.odr]p2, C99 6.9p3). Note that this should not be 12759 /// used directly for normal expressions referring to VarDecl. 12760 void Sema::MarkVariableReferenced(SourceLocation Loc, VarDecl *Var) { 12761 DoMarkVarDeclReferenced(*this, Loc, Var, nullptr); 12762 } 12763 12764 static void MarkExprReferenced(Sema &SemaRef, SourceLocation Loc, 12765 Decl *D, Expr *E, bool OdrUse) { 12766 if (VarDecl *Var = dyn_cast<VarDecl>(D)) { 12767 DoMarkVarDeclReferenced(SemaRef, Loc, Var, E); 12768 return; 12769 } 12770 12771 SemaRef.MarkAnyDeclReferenced(Loc, D, OdrUse); 12772 12773 // If this is a call to a method via a cast, also mark the method in the 12774 // derived class used in case codegen can devirtualize the call. 12775 const MemberExpr *ME = dyn_cast<MemberExpr>(E); 12776 if (!ME) 12777 return; 12778 CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(ME->getMemberDecl()); 12779 if (!MD) 12780 return; 12781 // Only attempt to devirtualize if this is truly a virtual call. 12782 bool IsVirtualCall = MD->isVirtual() && !ME->hasQualifier(); 12783 if (!IsVirtualCall) 12784 return; 12785 const Expr *Base = ME->getBase(); 12786 const CXXRecordDecl *MostDerivedClassDecl = Base->getBestDynamicClassType(); 12787 if (!MostDerivedClassDecl) 12788 return; 12789 CXXMethodDecl *DM = MD->getCorrespondingMethodInClass(MostDerivedClassDecl); 12790 if (!DM || DM->isPure()) 12791 return; 12792 SemaRef.MarkAnyDeclReferenced(Loc, DM, OdrUse); 12793 } 12794 12795 /// \brief Perform reference-marking and odr-use handling for a DeclRefExpr. 12796 void Sema::MarkDeclRefReferenced(DeclRefExpr *E) { 12797 // TODO: update this with DR# once a defect report is filed. 12798 // C++11 defect. The address of a pure member should not be an ODR use, even 12799 // if it's a qualified reference. 12800 bool OdrUse = true; 12801 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(E->getDecl())) 12802 if (Method->isVirtual()) 12803 OdrUse = false; 12804 MarkExprReferenced(*this, E->getLocation(), E->getDecl(), E, OdrUse); 12805 } 12806 12807 /// \brief Perform reference-marking and odr-use handling for a MemberExpr. 12808 void Sema::MarkMemberReferenced(MemberExpr *E) { 12809 // C++11 [basic.def.odr]p2: 12810 // A non-overloaded function whose name appears as a potentially-evaluated 12811 // expression or a member of a set of candidate functions, if selected by 12812 // overload resolution when referred to from a potentially-evaluated 12813 // expression, is odr-used, unless it is a pure virtual function and its 12814 // name is not explicitly qualified. 12815 bool OdrUse = true; 12816 if (!E->hasQualifier()) { 12817 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(E->getMemberDecl())) 12818 if (Method->isPure()) 12819 OdrUse = false; 12820 } 12821 SourceLocation Loc = E->getMemberLoc().isValid() ? 12822 E->getMemberLoc() : E->getLocStart(); 12823 MarkExprReferenced(*this, Loc, E->getMemberDecl(), E, OdrUse); 12824 } 12825 12826 /// \brief Perform marking for a reference to an arbitrary declaration. It 12827 /// marks the declaration referenced, and performs odr-use checking for 12828 /// functions and variables. This method should not be used when building a 12829 /// normal expression which refers to a variable. 12830 void Sema::MarkAnyDeclReferenced(SourceLocation Loc, Decl *D, bool OdrUse) { 12831 if (OdrUse) { 12832 if (auto *VD = dyn_cast<VarDecl>(D)) { 12833 MarkVariableReferenced(Loc, VD); 12834 return; 12835 } 12836 } 12837 if (auto *FD = dyn_cast<FunctionDecl>(D)) { 12838 MarkFunctionReferenced(Loc, FD, OdrUse); 12839 return; 12840 } 12841 D->setReferenced(); 12842 } 12843 12844 namespace { 12845 // Mark all of the declarations referenced 12846 // FIXME: Not fully implemented yet! We need to have a better understanding 12847 // of when we're entering 12848 class MarkReferencedDecls : public RecursiveASTVisitor<MarkReferencedDecls> { 12849 Sema &S; 12850 SourceLocation Loc; 12851 12852 public: 12853 typedef RecursiveASTVisitor<MarkReferencedDecls> Inherited; 12854 12855 MarkReferencedDecls(Sema &S, SourceLocation Loc) : S(S), Loc(Loc) { } 12856 12857 bool TraverseTemplateArgument(const TemplateArgument &Arg); 12858 bool TraverseRecordType(RecordType *T); 12859 }; 12860 } 12861 12862 bool MarkReferencedDecls::TraverseTemplateArgument( 12863 const TemplateArgument &Arg) { 12864 if (Arg.getKind() == TemplateArgument::Declaration) { 12865 if (Decl *D = Arg.getAsDecl()) 12866 S.MarkAnyDeclReferenced(Loc, D, true); 12867 } 12868 12869 return Inherited::TraverseTemplateArgument(Arg); 12870 } 12871 12872 bool MarkReferencedDecls::TraverseRecordType(RecordType *T) { 12873 if (ClassTemplateSpecializationDecl *Spec 12874 = dyn_cast<ClassTemplateSpecializationDecl>(T->getDecl())) { 12875 const TemplateArgumentList &Args = Spec->getTemplateArgs(); 12876 return TraverseTemplateArguments(Args.data(), Args.size()); 12877 } 12878 12879 return true; 12880 } 12881 12882 void Sema::MarkDeclarationsReferencedInType(SourceLocation Loc, QualType T) { 12883 MarkReferencedDecls Marker(*this, Loc); 12884 Marker.TraverseType(Context.getCanonicalType(T)); 12885 } 12886 12887 namespace { 12888 /// \brief Helper class that marks all of the declarations referenced by 12889 /// potentially-evaluated subexpressions as "referenced". 12890 class EvaluatedExprMarker : public EvaluatedExprVisitor<EvaluatedExprMarker> { 12891 Sema &S; 12892 bool SkipLocalVariables; 12893 12894 public: 12895 typedef EvaluatedExprVisitor<EvaluatedExprMarker> Inherited; 12896 12897 EvaluatedExprMarker(Sema &S, bool SkipLocalVariables) 12898 : Inherited(S.Context), S(S), SkipLocalVariables(SkipLocalVariables) { } 12899 12900 void VisitDeclRefExpr(DeclRefExpr *E) { 12901 // If we were asked not to visit local variables, don't. 12902 if (SkipLocalVariables) { 12903 if (VarDecl *VD = dyn_cast<VarDecl>(E->getDecl())) 12904 if (VD->hasLocalStorage()) 12905 return; 12906 } 12907 12908 S.MarkDeclRefReferenced(E); 12909 } 12910 12911 void VisitMemberExpr(MemberExpr *E) { 12912 S.MarkMemberReferenced(E); 12913 Inherited::VisitMemberExpr(E); 12914 } 12915 12916 void VisitCXXBindTemporaryExpr(CXXBindTemporaryExpr *E) { 12917 S.MarkFunctionReferenced(E->getLocStart(), 12918 const_cast<CXXDestructorDecl*>(E->getTemporary()->getDestructor())); 12919 Visit(E->getSubExpr()); 12920 } 12921 12922 void VisitCXXNewExpr(CXXNewExpr *E) { 12923 if (E->getOperatorNew()) 12924 S.MarkFunctionReferenced(E->getLocStart(), E->getOperatorNew()); 12925 if (E->getOperatorDelete()) 12926 S.MarkFunctionReferenced(E->getLocStart(), E->getOperatorDelete()); 12927 Inherited::VisitCXXNewExpr(E); 12928 } 12929 12930 void VisitCXXDeleteExpr(CXXDeleteExpr *E) { 12931 if (E->getOperatorDelete()) 12932 S.MarkFunctionReferenced(E->getLocStart(), E->getOperatorDelete()); 12933 QualType Destroyed = S.Context.getBaseElementType(E->getDestroyedType()); 12934 if (const RecordType *DestroyedRec = Destroyed->getAs<RecordType>()) { 12935 CXXRecordDecl *Record = cast<CXXRecordDecl>(DestroyedRec->getDecl()); 12936 S.MarkFunctionReferenced(E->getLocStart(), 12937 S.LookupDestructor(Record)); 12938 } 12939 12940 Inherited::VisitCXXDeleteExpr(E); 12941 } 12942 12943 void VisitCXXConstructExpr(CXXConstructExpr *E) { 12944 S.MarkFunctionReferenced(E->getLocStart(), E->getConstructor()); 12945 Inherited::VisitCXXConstructExpr(E); 12946 } 12947 12948 void VisitCXXDefaultArgExpr(CXXDefaultArgExpr *E) { 12949 Visit(E->getExpr()); 12950 } 12951 12952 void VisitImplicitCastExpr(ImplicitCastExpr *E) { 12953 Inherited::VisitImplicitCastExpr(E); 12954 12955 if (E->getCastKind() == CK_LValueToRValue) 12956 S.UpdateMarkingForLValueToRValue(E->getSubExpr()); 12957 } 12958 }; 12959 } 12960 12961 /// \brief Mark any declarations that appear within this expression or any 12962 /// potentially-evaluated subexpressions as "referenced". 12963 /// 12964 /// \param SkipLocalVariables If true, don't mark local variables as 12965 /// 'referenced'. 12966 void Sema::MarkDeclarationsReferencedInExpr(Expr *E, 12967 bool SkipLocalVariables) { 12968 EvaluatedExprMarker(*this, SkipLocalVariables).Visit(E); 12969 } 12970 12971 /// \brief Emit a diagnostic that describes an effect on the run-time behavior 12972 /// of the program being compiled. 12973 /// 12974 /// This routine emits the given diagnostic when the code currently being 12975 /// type-checked is "potentially evaluated", meaning that there is a 12976 /// possibility that the code will actually be executable. Code in sizeof() 12977 /// expressions, code used only during overload resolution, etc., are not 12978 /// potentially evaluated. This routine will suppress such diagnostics or, 12979 /// in the absolutely nutty case of potentially potentially evaluated 12980 /// expressions (C++ typeid), queue the diagnostic to potentially emit it 12981 /// later. 12982 /// 12983 /// This routine should be used for all diagnostics that describe the run-time 12984 /// behavior of a program, such as passing a non-POD value through an ellipsis. 12985 /// Failure to do so will likely result in spurious diagnostics or failures 12986 /// during overload resolution or within sizeof/alignof/typeof/typeid. 12987 bool Sema::DiagRuntimeBehavior(SourceLocation Loc, const Stmt *Statement, 12988 const PartialDiagnostic &PD) { 12989 switch (ExprEvalContexts.back().Context) { 12990 case Unevaluated: 12991 case UnevaluatedAbstract: 12992 // The argument will never be evaluated, so don't complain. 12993 break; 12994 12995 case ConstantEvaluated: 12996 // Relevant diagnostics should be produced by constant evaluation. 12997 break; 12998 12999 case PotentiallyEvaluated: 13000 case PotentiallyEvaluatedIfUsed: 13001 if (Statement && getCurFunctionOrMethodDecl()) { 13002 FunctionScopes.back()->PossiblyUnreachableDiags. 13003 push_back(sema::PossiblyUnreachableDiag(PD, Loc, Statement)); 13004 } 13005 else 13006 Diag(Loc, PD); 13007 13008 return true; 13009 } 13010 13011 return false; 13012 } 13013 13014 bool Sema::CheckCallReturnType(QualType ReturnType, SourceLocation Loc, 13015 CallExpr *CE, FunctionDecl *FD) { 13016 if (ReturnType->isVoidType() || !ReturnType->isIncompleteType()) 13017 return false; 13018 13019 // If we're inside a decltype's expression, don't check for a valid return 13020 // type or construct temporaries until we know whether this is the last call. 13021 if (ExprEvalContexts.back().IsDecltype) { 13022 ExprEvalContexts.back().DelayedDecltypeCalls.push_back(CE); 13023 return false; 13024 } 13025 13026 class CallReturnIncompleteDiagnoser : public TypeDiagnoser { 13027 FunctionDecl *FD; 13028 CallExpr *CE; 13029 13030 public: 13031 CallReturnIncompleteDiagnoser(FunctionDecl *FD, CallExpr *CE) 13032 : FD(FD), CE(CE) { } 13033 13034 void diagnose(Sema &S, SourceLocation Loc, QualType T) override { 13035 if (!FD) { 13036 S.Diag(Loc, diag::err_call_incomplete_return) 13037 << T << CE->getSourceRange(); 13038 return; 13039 } 13040 13041 S.Diag(Loc, diag::err_call_function_incomplete_return) 13042 << CE->getSourceRange() << FD->getDeclName() << T; 13043 S.Diag(FD->getLocation(), diag::note_entity_declared_at) 13044 << FD->getDeclName(); 13045 } 13046 } Diagnoser(FD, CE); 13047 13048 if (RequireCompleteType(Loc, ReturnType, Diagnoser)) 13049 return true; 13050 13051 return false; 13052 } 13053 13054 // Diagnose the s/=/==/ and s/\|=/!=/ typos. Note that adding parentheses 13055 // will prevent this condition from triggering, which is what we want. 13056 void Sema::DiagnoseAssignmentAsCondition(Expr *E) { 13057 SourceLocation Loc; 13058 13059 unsigned diagnostic = diag::warn_condition_is_assignment; 13060 bool IsOrAssign = false; 13061 13062 if (BinaryOperator *Op = dyn_cast<BinaryOperator>(E)) { 13063 if (Op->getOpcode() != BO_Assign && Op->getOpcode() != BO_OrAssign) 13064 return; 13065 13066 IsOrAssign = Op->getOpcode() == BO_OrAssign; 13067 13068 // Greylist some idioms by putting them into a warning subcategory. 13069 if (ObjCMessageExpr *ME 13070 = dyn_cast<ObjCMessageExpr>(Op->getRHS()->IgnoreParenCasts())) { 13071 Selector Sel = ME->getSelector(); 13072 13073 // self = [<foo> init...] 13074 if (isSelfExpr(Op->getLHS()) && ME->getMethodFamily() == OMF_init) 13075 diagnostic = diag::warn_condition_is_idiomatic_assignment; 13076 13077 // <foo> = [<bar> nextObject] 13078 else if (Sel.isUnarySelector() && Sel.getNameForSlot(0) == "nextObject") 13079 diagnostic = diag::warn_condition_is_idiomatic_assignment; 13080 } 13081 13082 Loc = Op->getOperatorLoc(); 13083 } else if (CXXOperatorCallExpr *Op = dyn_cast<CXXOperatorCallExpr>(E)) { 13084 if (Op->getOperator() != OO_Equal && Op->getOperator() != OO_PipeEqual) 13085 return; 13086 13087 IsOrAssign = Op->getOperator() == OO_PipeEqual; 13088 Loc = Op->getOperatorLoc(); 13089 } else if (PseudoObjectExpr *POE = dyn_cast<PseudoObjectExpr>(E)) 13090 return DiagnoseAssignmentAsCondition(POE->getSyntacticForm()); 13091 else { 13092 // Not an assignment. 13093 return; 13094 } 13095 13096 Diag(Loc, diagnostic) << E->getSourceRange(); 13097 13098 SourceLocation Open = E->getLocStart(); 13099 SourceLocation Close = PP.getLocForEndOfToken(E->getSourceRange().getEnd()); 13100 Diag(Loc, diag::note_condition_assign_silence) 13101 << FixItHint::CreateInsertion(Open, "(") 13102 << FixItHint::CreateInsertion(Close, ")"); 13103 13104 if (IsOrAssign) 13105 Diag(Loc, diag::note_condition_or_assign_to_comparison) 13106 << FixItHint::CreateReplacement(Loc, "!="); 13107 else 13108 Diag(Loc, diag::note_condition_assign_to_comparison) 13109 << FixItHint::CreateReplacement(Loc, "=="); 13110 } 13111 13112 /// \brief Redundant parentheses over an equality comparison can indicate 13113 /// that the user intended an assignment used as condition. 13114 void Sema::DiagnoseEqualityWithExtraParens(ParenExpr *ParenE) { 13115 // Don't warn if the parens came from a macro. 13116 SourceLocation parenLoc = ParenE->getLocStart(); 13117 if (parenLoc.isInvalid() || parenLoc.isMacroID()) 13118 return; 13119 // Don't warn for dependent expressions. 13120 if (ParenE->isTypeDependent()) 13121 return; 13122 13123 Expr *E = ParenE->IgnoreParens(); 13124 13125 if (BinaryOperator *opE = dyn_cast<BinaryOperator>(E)) 13126 if (opE->getOpcode() == BO_EQ && 13127 opE->getLHS()->IgnoreParenImpCasts()->isModifiableLvalue(Context) 13128 == Expr::MLV_Valid) { 13129 SourceLocation Loc = opE->getOperatorLoc(); 13130 13131 Diag(Loc, diag::warn_equality_with_extra_parens) << E->getSourceRange(); 13132 SourceRange ParenERange = ParenE->getSourceRange(); 13133 Diag(Loc, diag::note_equality_comparison_silence) 13134 << FixItHint::CreateRemoval(ParenERange.getBegin()) 13135 << FixItHint::CreateRemoval(ParenERange.getEnd()); 13136 Diag(Loc, diag::note_equality_comparison_to_assign) 13137 << FixItHint::CreateReplacement(Loc, "="); 13138 } 13139 } 13140 13141 ExprResult Sema::CheckBooleanCondition(Expr *E, SourceLocation Loc) { 13142 DiagnoseAssignmentAsCondition(E); 13143 if (ParenExpr *parenE = dyn_cast<ParenExpr>(E)) 13144 DiagnoseEqualityWithExtraParens(parenE); 13145 13146 ExprResult result = CheckPlaceholderExpr(E); 13147 if (result.isInvalid()) return ExprError(); 13148 E = result.get(); 13149 13150 if (!E->isTypeDependent()) { 13151 if (getLangOpts().CPlusPlus) 13152 return CheckCXXBooleanCondition(E); // C++ 6.4p4 13153 13154 ExprResult ERes = DefaultFunctionArrayLvalueConversion(E); 13155 if (ERes.isInvalid()) 13156 return ExprError(); 13157 E = ERes.get(); 13158 13159 QualType T = E->getType(); 13160 if (!T->isScalarType()) { // C99 6.8.4.1p1 13161 Diag(Loc, diag::err_typecheck_statement_requires_scalar) 13162 << T << E->getSourceRange(); 13163 return ExprError(); 13164 } 13165 CheckBoolLikeConversion(E, Loc); 13166 } 13167 13168 return E; 13169 } 13170 13171 ExprResult Sema::ActOnBooleanCondition(Scope *S, SourceLocation Loc, 13172 Expr *SubExpr) { 13173 if (!SubExpr) 13174 return ExprError(); 13175 13176 return CheckBooleanCondition(SubExpr, Loc); 13177 } 13178 13179 namespace { 13180 /// A visitor for rebuilding a call to an __unknown_any expression 13181 /// to have an appropriate type. 13182 struct RebuildUnknownAnyFunction 13183 : StmtVisitor<RebuildUnknownAnyFunction, ExprResult> { 13184 13185 Sema &S; 13186 13187 RebuildUnknownAnyFunction(Sema &S) : S(S) {} 13188 13189 ExprResult VisitStmt(Stmt *S) { 13190 llvm_unreachable("unexpected statement!"); 13191 } 13192 13193 ExprResult VisitExpr(Expr *E) { 13194 S.Diag(E->getExprLoc(), diag::err_unsupported_unknown_any_call) 13195 << E->getSourceRange(); 13196 return ExprError(); 13197 } 13198 13199 /// Rebuild an expression which simply semantically wraps another 13200 /// expression which it shares the type and value kind of. 13201 template <class T> ExprResult rebuildSugarExpr(T *E) { 13202 ExprResult SubResult = Visit(E->getSubExpr()); 13203 if (SubResult.isInvalid()) return ExprError(); 13204 13205 Expr *SubExpr = SubResult.get(); 13206 E->setSubExpr(SubExpr); 13207 E->setType(SubExpr->getType()); 13208 E->setValueKind(SubExpr->getValueKind()); 13209 assert(E->getObjectKind() == OK_Ordinary); 13210 return E; 13211 } 13212 13213 ExprResult VisitParenExpr(ParenExpr *E) { 13214 return rebuildSugarExpr(E); 13215 } 13216 13217 ExprResult VisitUnaryExtension(UnaryOperator *E) { 13218 return rebuildSugarExpr(E); 13219 } 13220 13221 ExprResult VisitUnaryAddrOf(UnaryOperator *E) { 13222 ExprResult SubResult = Visit(E->getSubExpr()); 13223 if (SubResult.isInvalid()) return ExprError(); 13224 13225 Expr *SubExpr = SubResult.get(); 13226 E->setSubExpr(SubExpr); 13227 E->setType(S.Context.getPointerType(SubExpr->getType())); 13228 assert(E->getValueKind() == VK_RValue); 13229 assert(E->getObjectKind() == OK_Ordinary); 13230 return E; 13231 } 13232 13233 ExprResult resolveDecl(Expr *E, ValueDecl *VD) { 13234 if (!isa<FunctionDecl>(VD)) return VisitExpr(E); 13235 13236 E->setType(VD->getType()); 13237 13238 assert(E->getValueKind() == VK_RValue); 13239 if (S.getLangOpts().CPlusPlus && 13240 !(isa<CXXMethodDecl>(VD) && 13241 cast<CXXMethodDecl>(VD)->isInstance())) 13242 E->setValueKind(VK_LValue); 13243 13244 return E; 13245 } 13246 13247 ExprResult VisitMemberExpr(MemberExpr *E) { 13248 return resolveDecl(E, E->getMemberDecl()); 13249 } 13250 13251 ExprResult VisitDeclRefExpr(DeclRefExpr *E) { 13252 return resolveDecl(E, E->getDecl()); 13253 } 13254 }; 13255 } 13256 13257 /// Given a function expression of unknown-any type, try to rebuild it 13258 /// to have a function type. 13259 static ExprResult rebuildUnknownAnyFunction(Sema &S, Expr *FunctionExpr) { 13260 ExprResult Result = RebuildUnknownAnyFunction(S).Visit(FunctionExpr); 13261 if (Result.isInvalid()) return ExprError(); 13262 return S.DefaultFunctionArrayConversion(Result.get()); 13263 } 13264 13265 namespace { 13266 /// A visitor for rebuilding an expression of type __unknown_anytype 13267 /// into one which resolves the type directly on the referring 13268 /// expression. Strict preservation of the original source 13269 /// structure is not a goal. 13270 struct RebuildUnknownAnyExpr 13271 : StmtVisitor<RebuildUnknownAnyExpr, ExprResult> { 13272 13273 Sema &S; 13274 13275 /// The current destination type. 13276 QualType DestType; 13277 13278 RebuildUnknownAnyExpr(Sema &S, QualType CastType) 13279 : S(S), DestType(CastType) {} 13280 13281 ExprResult VisitStmt(Stmt *S) { 13282 llvm_unreachable("unexpected statement!"); 13283 } 13284 13285 ExprResult VisitExpr(Expr *E) { 13286 S.Diag(E->getExprLoc(), diag::err_unsupported_unknown_any_expr) 13287 << E->getSourceRange(); 13288 return ExprError(); 13289 } 13290 13291 ExprResult VisitCallExpr(CallExpr *E); 13292 ExprResult VisitObjCMessageExpr(ObjCMessageExpr *E); 13293 13294 /// Rebuild an expression which simply semantically wraps another 13295 /// expression which it shares the type and value kind of. 13296 template <class T> ExprResult rebuildSugarExpr(T *E) { 13297 ExprResult SubResult = Visit(E->getSubExpr()); 13298 if (SubResult.isInvalid()) return ExprError(); 13299 Expr *SubExpr = SubResult.get(); 13300 E->setSubExpr(SubExpr); 13301 E->setType(SubExpr->getType()); 13302 E->setValueKind(SubExpr->getValueKind()); 13303 assert(E->getObjectKind() == OK_Ordinary); 13304 return E; 13305 } 13306 13307 ExprResult VisitParenExpr(ParenExpr *E) { 13308 return rebuildSugarExpr(E); 13309 } 13310 13311 ExprResult VisitUnaryExtension(UnaryOperator *E) { 13312 return rebuildSugarExpr(E); 13313 } 13314 13315 ExprResult VisitUnaryAddrOf(UnaryOperator *E) { 13316 const PointerType *Ptr = DestType->getAs<PointerType>(); 13317 if (!Ptr) { 13318 S.Diag(E->getOperatorLoc(), diag::err_unknown_any_addrof) 13319 << E->getSourceRange(); 13320 return ExprError(); 13321 } 13322 assert(E->getValueKind() == VK_RValue); 13323 assert(E->getObjectKind() == OK_Ordinary); 13324 E->setType(DestType); 13325 13326 // Build the sub-expression as if it were an object of the pointee type. 13327 DestType = Ptr->getPointeeType(); 13328 ExprResult SubResult = Visit(E->getSubExpr()); 13329 if (SubResult.isInvalid()) return ExprError(); 13330 E->setSubExpr(SubResult.get()); 13331 return E; 13332 } 13333 13334 ExprResult VisitImplicitCastExpr(ImplicitCastExpr *E); 13335 13336 ExprResult resolveDecl(Expr *E, ValueDecl *VD); 13337 13338 ExprResult VisitMemberExpr(MemberExpr *E) { 13339 return resolveDecl(E, E->getMemberDecl()); 13340 } 13341 13342 ExprResult VisitDeclRefExpr(DeclRefExpr *E) { 13343 return resolveDecl(E, E->getDecl()); 13344 } 13345 }; 13346 } 13347 13348 /// Rebuilds a call expression which yielded __unknown_anytype. 13349 ExprResult RebuildUnknownAnyExpr::VisitCallExpr(CallExpr *E) { 13350 Expr *CalleeExpr = E->getCallee(); 13351 13352 enum FnKind { 13353 FK_MemberFunction, 13354 FK_FunctionPointer, 13355 FK_BlockPointer 13356 }; 13357 13358 FnKind Kind; 13359 QualType CalleeType = CalleeExpr->getType(); 13360 if (CalleeType == S.Context.BoundMemberTy) { 13361 assert(isa<CXXMemberCallExpr>(E) || isa<CXXOperatorCallExpr>(E)); 13362 Kind = FK_MemberFunction; 13363 CalleeType = Expr::findBoundMemberType(CalleeExpr); 13364 } else if (const PointerType *Ptr = CalleeType->getAs<PointerType>()) { 13365 CalleeType = Ptr->getPointeeType(); 13366 Kind = FK_FunctionPointer; 13367 } else { 13368 CalleeType = CalleeType->castAs<BlockPointerType>()->getPointeeType(); 13369 Kind = FK_BlockPointer; 13370 } 13371 const FunctionType *FnType = CalleeType->castAs<FunctionType>(); 13372 13373 // Verify that this is a legal result type of a function. 13374 if (DestType->isArrayType() || DestType->isFunctionType()) { 13375 unsigned diagID = diag::err_func_returning_array_function; 13376 if (Kind == FK_BlockPointer) 13377 diagID = diag::err_block_returning_array_function; 13378 13379 S.Diag(E->getExprLoc(), diagID) 13380 << DestType->isFunctionType() << DestType; 13381 return ExprError(); 13382 } 13383 13384 // Otherwise, go ahead and set DestType as the call's result. 13385 E->setType(DestType.getNonLValueExprType(S.Context)); 13386 E->setValueKind(Expr::getValueKindForType(DestType)); 13387 assert(E->getObjectKind() == OK_Ordinary); 13388 13389 // Rebuild the function type, replacing the result type with DestType. 13390 const FunctionProtoType *Proto = dyn_cast<FunctionProtoType>(FnType); 13391 if (Proto) { 13392 // __unknown_anytype(...) is a special case used by the debugger when 13393 // it has no idea what a function's signature is. 13394 // 13395 // We want to build this call essentially under the K&R 13396 // unprototyped rules, but making a FunctionNoProtoType in C++ 13397 // would foul up all sorts of assumptions. However, we cannot 13398 // simply pass all arguments as variadic arguments, nor can we 13399 // portably just call the function under a non-variadic type; see 13400 // the comment on IR-gen's TargetInfo::isNoProtoCallVariadic. 13401 // However, it turns out that in practice it is generally safe to 13402 // call a function declared as "A foo(B,C,D);" under the prototype 13403 // "A foo(B,C,D,...);". The only known exception is with the 13404 // Windows ABI, where any variadic function is implicitly cdecl 13405 // regardless of its normal CC. Therefore we change the parameter 13406 // types to match the types of the arguments. 13407 // 13408 // This is a hack, but it is far superior to moving the 13409 // corresponding target-specific code from IR-gen to Sema/AST. 13410 13411 ArrayRef<QualType> ParamTypes = Proto->getParamTypes(); 13412 SmallVector<QualType, 8> ArgTypes; 13413 if (ParamTypes.empty() && Proto->isVariadic()) { // the special case 13414 ArgTypes.reserve(E->getNumArgs()); 13415 for (unsigned i = 0, e = E->getNumArgs(); i != e; ++i) { 13416 Expr *Arg = E->getArg(i); 13417 QualType ArgType = Arg->getType(); 13418 if (E->isLValue()) { 13419 ArgType = S.Context.getLValueReferenceType(ArgType); 13420 } else if (E->isXValue()) { 13421 ArgType = S.Context.getRValueReferenceType(ArgType); 13422 } 13423 ArgTypes.push_back(ArgType); 13424 } 13425 ParamTypes = ArgTypes; 13426 } 13427 DestType = S.Context.getFunctionType(DestType, ParamTypes, 13428 Proto->getExtProtoInfo()); 13429 } else { 13430 DestType = S.Context.getFunctionNoProtoType(DestType, 13431 FnType->getExtInfo()); 13432 } 13433 13434 // Rebuild the appropriate pointer-to-function type. 13435 switch (Kind) { 13436 case FK_MemberFunction: 13437 // Nothing to do. 13438 break; 13439 13440 case FK_FunctionPointer: 13441 DestType = S.Context.getPointerType(DestType); 13442 break; 13443 13444 case FK_BlockPointer: 13445 DestType = S.Context.getBlockPointerType(DestType); 13446 break; 13447 } 13448 13449 // Finally, we can recurse. 13450 ExprResult CalleeResult = Visit(CalleeExpr); 13451 if (!CalleeResult.isUsable()) return ExprError(); 13452 E->setCallee(CalleeResult.get()); 13453 13454 // Bind a temporary if necessary. 13455 return S.MaybeBindToTemporary(E); 13456 } 13457 13458 ExprResult RebuildUnknownAnyExpr::VisitObjCMessageExpr(ObjCMessageExpr *E) { 13459 // Verify that this is a legal result type of a call. 13460 if (DestType->isArrayType() || DestType->isFunctionType()) { 13461 S.Diag(E->getExprLoc(), diag::err_func_returning_array_function) 13462 << DestType->isFunctionType() << DestType; 13463 return ExprError(); 13464 } 13465 13466 // Rewrite the method result type if available. 13467 if (ObjCMethodDecl *Method = E->getMethodDecl()) { 13468 assert(Method->getReturnType() == S.Context.UnknownAnyTy); 13469 Method->setReturnType(DestType); 13470 } 13471 13472 // Change the type of the message. 13473 E->setType(DestType.getNonReferenceType()); 13474 E->setValueKind(Expr::getValueKindForType(DestType)); 13475 13476 return S.MaybeBindToTemporary(E); 13477 } 13478 13479 ExprResult RebuildUnknownAnyExpr::VisitImplicitCastExpr(ImplicitCastExpr *E) { 13480 // The only case we should ever see here is a function-to-pointer decay. 13481 if (E->getCastKind() == CK_FunctionToPointerDecay) { 13482 assert(E->getValueKind() == VK_RValue); 13483 assert(E->getObjectKind() == OK_Ordinary); 13484 13485 E->setType(DestType); 13486 13487 // Rebuild the sub-expression as the pointee (function) type. 13488 DestType = DestType->castAs<PointerType>()->getPointeeType(); 13489 13490 ExprResult Result = Visit(E->getSubExpr()); 13491 if (!Result.isUsable()) return ExprError(); 13492 13493 E->setSubExpr(Result.get()); 13494 return E; 13495 } else if (E->getCastKind() == CK_LValueToRValue) { 13496 assert(E->getValueKind() == VK_RValue); 13497 assert(E->getObjectKind() == OK_Ordinary); 13498 13499 assert(isa<BlockPointerType>(E->getType())); 13500 13501 E->setType(DestType); 13502 13503 // The sub-expression has to be a lvalue reference, so rebuild it as such. 13504 DestType = S.Context.getLValueReferenceType(DestType); 13505 13506 ExprResult Result = Visit(E->getSubExpr()); 13507 if (!Result.isUsable()) return ExprError(); 13508 13509 E->setSubExpr(Result.get()); 13510 return E; 13511 } else { 13512 llvm_unreachable("Unhandled cast type!"); 13513 } 13514 } 13515 13516 ExprResult RebuildUnknownAnyExpr::resolveDecl(Expr *E, ValueDecl *VD) { 13517 ExprValueKind ValueKind = VK_LValue; 13518 QualType Type = DestType; 13519 13520 // We know how to make this work for certain kinds of decls: 13521 13522 // - functions 13523 if (FunctionDecl *FD = dyn_cast<FunctionDecl>(VD)) { 13524 if (const PointerType *Ptr = Type->getAs<PointerType>()) { 13525 DestType = Ptr->getPointeeType(); 13526 ExprResult Result = resolveDecl(E, VD); 13527 if (Result.isInvalid()) return ExprError(); 13528 return S.ImpCastExprToType(Result.get(), Type, 13529 CK_FunctionToPointerDecay, VK_RValue); 13530 } 13531 13532 if (!Type->isFunctionType()) { 13533 S.Diag(E->getExprLoc(), diag::err_unknown_any_function) 13534 << VD << E->getSourceRange(); 13535 return ExprError(); 13536 } 13537 if (const FunctionProtoType *FT = Type->getAs<FunctionProtoType>()) { 13538 // We must match the FunctionDecl's type to the hack introduced in 13539 // RebuildUnknownAnyExpr::VisitCallExpr to vararg functions of unknown 13540 // type. See the lengthy commentary in that routine. 13541 QualType FDT = FD->getType(); 13542 const FunctionType *FnType = FDT->castAs<FunctionType>(); 13543 const FunctionProtoType *Proto = dyn_cast_or_null<FunctionProtoType>(FnType); 13544 DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E); 13545 if (DRE && Proto && Proto->getParamTypes().empty() && Proto->isVariadic()) { 13546 SourceLocation Loc = FD->getLocation(); 13547 FunctionDecl *NewFD = FunctionDecl::Create(FD->getASTContext(), 13548 FD->getDeclContext(), 13549 Loc, Loc, FD->getNameInfo().getName(), 13550 DestType, FD->getTypeSourceInfo(), 13551 SC_None, false/*isInlineSpecified*/, 13552 FD->hasPrototype(), 13553 false/*isConstexprSpecified*/); 13554 13555 if (FD->getQualifier()) 13556 NewFD->setQualifierInfo(FD->getQualifierLoc()); 13557 13558 SmallVector<ParmVarDecl*, 16> Params; 13559 for (const auto &AI : FT->param_types()) { 13560 ParmVarDecl *Param = 13561 S.BuildParmVarDeclForTypedef(FD, Loc, AI); 13562 Param->setScopeInfo(0, Params.size()); 13563 Params.push_back(Param); 13564 } 13565 NewFD->setParams(Params); 13566 DRE->setDecl(NewFD); 13567 VD = DRE->getDecl(); 13568 } 13569 } 13570 13571 if (CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(FD)) 13572 if (MD->isInstance()) { 13573 ValueKind = VK_RValue; 13574 Type = S.Context.BoundMemberTy; 13575 } 13576 13577 // Function references aren't l-values in C. 13578 if (!S.getLangOpts().CPlusPlus) 13579 ValueKind = VK_RValue; 13580 13581 // - variables 13582 } else if (isa<VarDecl>(VD)) { 13583 if (const ReferenceType *RefTy = Type->getAs<ReferenceType>()) { 13584 Type = RefTy->getPointeeType(); 13585 } else if (Type->isFunctionType()) { 13586 S.Diag(E->getExprLoc(), diag::err_unknown_any_var_function_type) 13587 << VD << E->getSourceRange(); 13588 return ExprError(); 13589 } 13590 13591 // - nothing else 13592 } else { 13593 S.Diag(E->getExprLoc(), diag::err_unsupported_unknown_any_decl) 13594 << VD << E->getSourceRange(); 13595 return ExprError(); 13596 } 13597 13598 // Modifying the declaration like this is friendly to IR-gen but 13599 // also really dangerous. 13600 VD->setType(DestType); 13601 E->setType(Type); 13602 E->setValueKind(ValueKind); 13603 return E; 13604 } 13605 13606 /// Check a cast of an unknown-any type. We intentionally only 13607 /// trigger this for C-style casts. 13608 ExprResult Sema::checkUnknownAnyCast(SourceRange TypeRange, QualType CastType, 13609 Expr *CastExpr, CastKind &CastKind, 13610 ExprValueKind &VK, CXXCastPath &Path) { 13611 // Rewrite the casted expression from scratch. 13612 ExprResult result = RebuildUnknownAnyExpr(*this, CastType).Visit(CastExpr); 13613 if (!result.isUsable()) return ExprError(); 13614 13615 CastExpr = result.get(); 13616 VK = CastExpr->getValueKind(); 13617 CastKind = CK_NoOp; 13618 13619 return CastExpr; 13620 } 13621 13622 ExprResult Sema::forceUnknownAnyToType(Expr *E, QualType ToType) { 13623 return RebuildUnknownAnyExpr(*this, ToType).Visit(E); 13624 } 13625 13626 ExprResult Sema::checkUnknownAnyArg(SourceLocation callLoc, 13627 Expr *arg, QualType ¶mType) { 13628 // If the syntactic form of the argument is not an explicit cast of 13629 // any sort, just do default argument promotion. 13630 ExplicitCastExpr *castArg = dyn_cast<ExplicitCastExpr>(arg->IgnoreParens()); 13631 if (!castArg) { 13632 ExprResult result = DefaultArgumentPromotion(arg); 13633 if (result.isInvalid()) return ExprError(); 13634 paramType = result.get()->getType(); 13635 return result; 13636 } 13637 13638 // Otherwise, use the type that was written in the explicit cast. 13639 assert(!arg->hasPlaceholderType()); 13640 paramType = castArg->getTypeAsWritten(); 13641 13642 // Copy-initialize a parameter of that type. 13643 InitializedEntity entity = 13644 InitializedEntity::InitializeParameter(Context, paramType, 13645 /*consumed*/ false); 13646 return PerformCopyInitialization(entity, callLoc, arg); 13647 } 13648 13649 static ExprResult diagnoseUnknownAnyExpr(Sema &S, Expr *E) { 13650 Expr *orig = E; 13651 unsigned diagID = diag::err_uncasted_use_of_unknown_any; 13652 while (true) { 13653 E = E->IgnoreParenImpCasts(); 13654 if (CallExpr *call = dyn_cast<CallExpr>(E)) { 13655 E = call->getCallee(); 13656 diagID = diag::err_uncasted_call_of_unknown_any; 13657 } else { 13658 break; 13659 } 13660 } 13661 13662 SourceLocation loc; 13663 NamedDecl *d; 13664 if (DeclRefExpr *ref = dyn_cast<DeclRefExpr>(E)) { 13665 loc = ref->getLocation(); 13666 d = ref->getDecl(); 13667 } else if (MemberExpr *mem = dyn_cast<MemberExpr>(E)) { 13668 loc = mem->getMemberLoc(); 13669 d = mem->getMemberDecl(); 13670 } else if (ObjCMessageExpr *msg = dyn_cast<ObjCMessageExpr>(E)) { 13671 diagID = diag::err_uncasted_call_of_unknown_any; 13672 loc = msg->getSelectorStartLoc(); 13673 d = msg->getMethodDecl(); 13674 if (!d) { 13675 S.Diag(loc, diag::err_uncasted_send_to_unknown_any_method) 13676 << static_cast<unsigned>(msg->isClassMessage()) << msg->getSelector() 13677 << orig->getSourceRange(); 13678 return ExprError(); 13679 } 13680 } else { 13681 S.Diag(E->getExprLoc(), diag::err_unsupported_unknown_any_expr) 13682 << E->getSourceRange(); 13683 return ExprError(); 13684 } 13685 13686 S.Diag(loc, diagID) << d << orig->getSourceRange(); 13687 13688 // Never recoverable. 13689 return ExprError(); 13690 } 13691 13692 /// Check for operands with placeholder types and complain if found. 13693 /// Returns true if there was an error and no recovery was possible. 13694 ExprResult Sema::CheckPlaceholderExpr(Expr *E) { 13695 if (!getLangOpts().CPlusPlus) { 13696 // C cannot handle TypoExpr nodes on either side of a binop because it 13697 // doesn't handle dependent types properly, so make sure any TypoExprs have 13698 // been dealt with before checking the operands. 13699 ExprResult Result = CorrectDelayedTyposInExpr(E); 13700 if (!Result.isUsable()) return ExprError(); 13701 E = Result.get(); 13702 } 13703 13704 const BuiltinType *placeholderType = E->getType()->getAsPlaceholderType(); 13705 if (!placeholderType) return E; 13706 13707 switch (placeholderType->getKind()) { 13708 13709 // Overloaded expressions. 13710 case BuiltinType::Overload: { 13711 // Try to resolve a single function template specialization. 13712 // This is obligatory. 13713 ExprResult result = E; 13714 if (ResolveAndFixSingleFunctionTemplateSpecialization(result, false)) { 13715 return result; 13716 13717 // If that failed, try to recover with a call. 13718 } else { 13719 tryToRecoverWithCall(result, PDiag(diag::err_ovl_unresolvable), 13720 /*complain*/ true); 13721 return result; 13722 } 13723 } 13724 13725 // Bound member functions. 13726 case BuiltinType::BoundMember: { 13727 ExprResult result = E; 13728 tryToRecoverWithCall(result, PDiag(diag::err_bound_member_function), 13729 /*complain*/ true); 13730 return result; 13731 } 13732 13733 // ARC unbridged casts. 13734 case BuiltinType::ARCUnbridgedCast: { 13735 Expr *realCast = stripARCUnbridgedCast(E); 13736 diagnoseARCUnbridgedCast(realCast); 13737 return realCast; 13738 } 13739 13740 // Expressions of unknown type. 13741 case BuiltinType::UnknownAny: 13742 return diagnoseUnknownAnyExpr(*this, E); 13743 13744 // Pseudo-objects. 13745 case BuiltinType::PseudoObject: 13746 return checkPseudoObjectRValue(E); 13747 13748 case BuiltinType::BuiltinFn: { 13749 // Accept __noop without parens by implicitly converting it to a call expr. 13750 auto *DRE = dyn_cast<DeclRefExpr>(E->IgnoreParenImpCasts()); 13751 if (DRE) { 13752 auto *FD = cast<FunctionDecl>(DRE->getDecl()); 13753 if (FD->getBuiltinID() == Builtin::BI__noop) { 13754 E = ImpCastExprToType(E, Context.getPointerType(FD->getType()), 13755 CK_BuiltinFnToFnPtr).get(); 13756 return new (Context) CallExpr(Context, E, None, Context.IntTy, 13757 VK_RValue, SourceLocation()); 13758 } 13759 } 13760 13761 Diag(E->getLocStart(), diag::err_builtin_fn_use); 13762 return ExprError(); 13763 } 13764 13765 // Everything else should be impossible. 13766 #define BUILTIN_TYPE(Id, SingletonId) \ 13767 case BuiltinType::Id: 13768 #define PLACEHOLDER_TYPE(Id, SingletonId) 13769 #include "clang/AST/BuiltinTypes.def" 13770 break; 13771 } 13772 13773 llvm_unreachable("invalid placeholder type!"); 13774 } 13775 13776 bool Sema::CheckCaseExpression(Expr *E) { 13777 if (E->isTypeDependent()) 13778 return true; 13779 if (E->isValueDependent() || E->isIntegerConstantExpr(Context)) 13780 return E->getType()->isIntegralOrEnumerationType(); 13781 return false; 13782 } 13783 13784 /// ActOnObjCBoolLiteral - Parse {__objc_yes,__objc_no} literals. 13785 ExprResult 13786 Sema::ActOnObjCBoolLiteral(SourceLocation OpLoc, tok::TokenKind Kind) { 13787 assert((Kind == tok::kw___objc_yes || Kind == tok::kw___objc_no) && 13788 "Unknown Objective-C Boolean value!"); 13789 QualType BoolT = Context.ObjCBuiltinBoolTy; 13790 if (!Context.getBOOLDecl()) { 13791 LookupResult Result(*this, &Context.Idents.get("BOOL"), OpLoc, 13792 Sema::LookupOrdinaryName); 13793 if (LookupName(Result, getCurScope()) && Result.isSingleResult()) { 13794 NamedDecl *ND = Result.getFoundDecl(); 13795 if (TypedefDecl *TD = dyn_cast<TypedefDecl>(ND)) 13796 Context.setBOOLDecl(TD); 13797 } 13798 } 13799 if (Context.getBOOLDecl()) 13800 BoolT = Context.getBOOLType(); 13801 return new (Context) 13802 ObjCBoolLiteralExpr(Kind == tok::kw___objc_yes, BoolT, OpLoc); 13803 } 13804