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 using namespace clang; 46 using namespace sema; 47 48 /// \brief Determine whether the use of this declaration is valid, without 49 /// emitting diagnostics. 50 bool Sema::CanUseDecl(NamedDecl *D) { 51 // See if this is an auto-typed variable whose initializer we are parsing. 52 if (ParsingInitForAutoVars.count(D)) 53 return false; 54 55 // See if this is a deleted function. 56 if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) { 57 if (FD->isDeleted()) 58 return false; 59 60 // If the function has a deduced return type, and we can't deduce it, 61 // then we can't use it either. 62 if (getLangOpts().CPlusPlus1y && FD->getResultType()->isUndeducedType() && 63 DeduceReturnType(FD, SourceLocation(), /*Diagnose*/false)) 64 return false; 65 } 66 67 // See if this function is unavailable. 68 if (D->getAvailability() == AR_Unavailable && 69 cast<Decl>(CurContext)->getAvailability() != AR_Unavailable) 70 return false; 71 72 return true; 73 } 74 75 static void DiagnoseUnusedOfDecl(Sema &S, NamedDecl *D, SourceLocation Loc) { 76 // Warn if this is used but marked unused. 77 if (D->hasAttr<UnusedAttr>()) { 78 const Decl *DC = cast<Decl>(S.getCurObjCLexicalContext()); 79 if (!DC->hasAttr<UnusedAttr>()) 80 S.Diag(Loc, diag::warn_used_but_marked_unused) << D->getDeclName(); 81 } 82 } 83 84 static AvailabilityResult DiagnoseAvailabilityOfDecl(Sema &S, 85 NamedDecl *D, SourceLocation Loc, 86 const ObjCInterfaceDecl *UnknownObjCClass) { 87 // See if this declaration is unavailable or deprecated. 88 std::string Message; 89 AvailabilityResult Result = D->getAvailability(&Message); 90 if (const EnumConstantDecl *ECD = dyn_cast<EnumConstantDecl>(D)) 91 if (Result == AR_Available) { 92 const DeclContext *DC = ECD->getDeclContext(); 93 if (const EnumDecl *TheEnumDecl = dyn_cast<EnumDecl>(DC)) 94 Result = TheEnumDecl->getAvailability(&Message); 95 } 96 97 const ObjCPropertyDecl *ObjCPDecl = 0; 98 if (Result == AR_Deprecated || Result == AR_Unavailable) { 99 if (const ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(D)) { 100 if (const ObjCPropertyDecl *PD = MD->findPropertyDecl()) { 101 AvailabilityResult PDeclResult = PD->getAvailability(0); 102 if (PDeclResult == Result) 103 ObjCPDecl = PD; 104 } 105 } 106 } 107 108 switch (Result) { 109 case AR_Available: 110 case AR_NotYetIntroduced: 111 break; 112 113 case AR_Deprecated: 114 if (S.getCurContextAvailability() != AR_Deprecated) 115 S.EmitAvailabilityWarning(Sema::AD_Deprecation, 116 D, Message, Loc, UnknownObjCClass, ObjCPDecl); 117 break; 118 119 case AR_Unavailable: 120 if (S.getCurContextAvailability() != AR_Unavailable) 121 S.EmitAvailabilityWarning(Sema::AD_Unavailable, 122 D, Message, Loc, UnknownObjCClass, ObjCPDecl); 123 break; 124 125 } 126 return Result; 127 } 128 129 /// \brief Emit a note explaining that this function is deleted. 130 void Sema::NoteDeletedFunction(FunctionDecl *Decl) { 131 assert(Decl->isDeleted()); 132 133 CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(Decl); 134 135 if (Method && Method->isDeleted() && Method->isDefaulted()) { 136 // If the method was explicitly defaulted, point at that declaration. 137 if (!Method->isImplicit()) 138 Diag(Decl->getLocation(), diag::note_implicitly_deleted); 139 140 // Try to diagnose why this special member function was implicitly 141 // deleted. This might fail, if that reason no longer applies. 142 CXXSpecialMember CSM = getSpecialMember(Method); 143 if (CSM != CXXInvalid) 144 ShouldDeleteSpecialMember(Method, CSM, /*Diagnose=*/true); 145 146 return; 147 } 148 149 if (CXXConstructorDecl *CD = dyn_cast<CXXConstructorDecl>(Decl)) { 150 if (CXXConstructorDecl *BaseCD = 151 const_cast<CXXConstructorDecl*>(CD->getInheritedConstructor())) { 152 Diag(Decl->getLocation(), diag::note_inherited_deleted_here); 153 if (BaseCD->isDeleted()) { 154 NoteDeletedFunction(BaseCD); 155 } else { 156 // FIXME: An explanation of why exactly it can't be inherited 157 // would be nice. 158 Diag(BaseCD->getLocation(), diag::note_cannot_inherit); 159 } 160 return; 161 } 162 } 163 164 Diag(Decl->getLocation(), diag::note_availability_specified_here) 165 << Decl << true; 166 } 167 168 /// \brief Determine whether a FunctionDecl was ever declared with an 169 /// explicit storage class. 170 static bool hasAnyExplicitStorageClass(const FunctionDecl *D) { 171 for (FunctionDecl::redecl_iterator I = D->redecls_begin(), 172 E = D->redecls_end(); 173 I != E; ++I) { 174 if (I->getStorageClass() != SC_None) 175 return true; 176 } 177 return false; 178 } 179 180 /// \brief Check whether we're in an extern inline function and referring to a 181 /// variable or function with internal linkage (C11 6.7.4p3). 182 /// 183 /// This is only a warning because we used to silently accept this code, but 184 /// in many cases it will not behave correctly. This is not enabled in C++ mode 185 /// because the restriction language is a bit weaker (C++11 [basic.def.odr]p6) 186 /// and so while there may still be user mistakes, most of the time we can't 187 /// prove that there are errors. 188 static void diagnoseUseOfInternalDeclInInlineFunction(Sema &S, 189 const NamedDecl *D, 190 SourceLocation Loc) { 191 // This is disabled under C++; there are too many ways for this to fire in 192 // contexts where the warning is a false positive, or where it is technically 193 // correct but benign. 194 if (S.getLangOpts().CPlusPlus) 195 return; 196 197 // Check if this is an inlined function or method. 198 FunctionDecl *Current = S.getCurFunctionDecl(); 199 if (!Current) 200 return; 201 if (!Current->isInlined()) 202 return; 203 if (!Current->isExternallyVisible()) 204 return; 205 206 // Check if the decl has internal linkage. 207 if (D->getFormalLinkage() != InternalLinkage) 208 return; 209 210 // Downgrade from ExtWarn to Extension if 211 // (1) the supposedly external inline function is in the main file, 212 // and probably won't be included anywhere else. 213 // (2) the thing we're referencing is a pure function. 214 // (3) the thing we're referencing is another inline function. 215 // This last can give us false negatives, but it's better than warning on 216 // wrappers for simple C library functions. 217 const FunctionDecl *UsedFn = dyn_cast<FunctionDecl>(D); 218 bool DowngradeWarning = S.getSourceManager().isInMainFile(Loc); 219 if (!DowngradeWarning && UsedFn) 220 DowngradeWarning = UsedFn->isInlined() || UsedFn->hasAttr<ConstAttr>(); 221 222 S.Diag(Loc, DowngradeWarning ? diag::ext_internal_in_extern_inline 223 : diag::warn_internal_in_extern_inline) 224 << /*IsVar=*/!UsedFn << D; 225 226 S.MaybeSuggestAddingStaticToDecl(Current); 227 228 S.Diag(D->getCanonicalDecl()->getLocation(), 229 diag::note_internal_decl_declared_here) 230 << D; 231 } 232 233 void Sema::MaybeSuggestAddingStaticToDecl(const FunctionDecl *Cur) { 234 const FunctionDecl *First = Cur->getFirstDecl(); 235 236 // Suggest "static" on the function, if possible. 237 if (!hasAnyExplicitStorageClass(First)) { 238 SourceLocation DeclBegin = First->getSourceRange().getBegin(); 239 Diag(DeclBegin, diag::note_convert_inline_to_static) 240 << Cur << FixItHint::CreateInsertion(DeclBegin, "static "); 241 } 242 } 243 244 /// \brief Determine whether the use of this declaration is valid, and 245 /// emit any corresponding diagnostics. 246 /// 247 /// This routine diagnoses various problems with referencing 248 /// declarations that can occur when using a declaration. For example, 249 /// it might warn if a deprecated or unavailable declaration is being 250 /// used, or produce an error (and return true) if a C++0x deleted 251 /// function is being used. 252 /// 253 /// \returns true if there was an error (this declaration cannot be 254 /// referenced), false otherwise. 255 /// 256 bool Sema::DiagnoseUseOfDecl(NamedDecl *D, SourceLocation Loc, 257 const ObjCInterfaceDecl *UnknownObjCClass) { 258 if (getLangOpts().CPlusPlus && isa<FunctionDecl>(D)) { 259 // If there were any diagnostics suppressed by template argument deduction, 260 // emit them now. 261 SuppressedDiagnosticsMap::iterator 262 Pos = SuppressedDiagnostics.find(D->getCanonicalDecl()); 263 if (Pos != SuppressedDiagnostics.end()) { 264 SmallVectorImpl<PartialDiagnosticAt> &Suppressed = Pos->second; 265 for (unsigned I = 0, N = Suppressed.size(); I != N; ++I) 266 Diag(Suppressed[I].first, Suppressed[I].second); 267 268 // Clear out the list of suppressed diagnostics, so that we don't emit 269 // them again for this specialization. However, we don't obsolete this 270 // entry from the table, because we want to avoid ever emitting these 271 // diagnostics again. 272 Suppressed.clear(); 273 } 274 } 275 276 // See if this is an auto-typed variable whose initializer we are parsing. 277 if (ParsingInitForAutoVars.count(D)) { 278 Diag(Loc, diag::err_auto_variable_cannot_appear_in_own_initializer) 279 << D->getDeclName(); 280 return true; 281 } 282 283 // See if this is a deleted function. 284 if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) { 285 if (FD->isDeleted()) { 286 Diag(Loc, diag::err_deleted_function_use); 287 NoteDeletedFunction(FD); 288 return true; 289 } 290 291 // If the function has a deduced return type, and we can't deduce it, 292 // then we can't use it either. 293 if (getLangOpts().CPlusPlus1y && FD->getResultType()->isUndeducedType() && 294 DeduceReturnType(FD, Loc)) 295 return true; 296 } 297 DiagnoseAvailabilityOfDecl(*this, D, Loc, UnknownObjCClass); 298 299 DiagnoseUnusedOfDecl(*this, D, Loc); 300 301 diagnoseUseOfInternalDeclInInlineFunction(*this, D, Loc); 302 303 return false; 304 } 305 306 /// \brief Retrieve the message suffix that should be added to a 307 /// diagnostic complaining about the given function being deleted or 308 /// unavailable. 309 std::string Sema::getDeletedOrUnavailableSuffix(const FunctionDecl *FD) { 310 std::string Message; 311 if (FD->getAvailability(&Message)) 312 return ": " + Message; 313 314 return std::string(); 315 } 316 317 /// DiagnoseSentinelCalls - This routine checks whether a call or 318 /// message-send is to a declaration with the sentinel attribute, and 319 /// if so, it checks that the requirements of the sentinel are 320 /// satisfied. 321 void Sema::DiagnoseSentinelCalls(NamedDecl *D, SourceLocation Loc, 322 ArrayRef<Expr *> Args) { 323 const SentinelAttr *attr = D->getAttr<SentinelAttr>(); 324 if (!attr) 325 return; 326 327 // The number of formal parameters of the declaration. 328 unsigned numFormalParams; 329 330 // The kind of declaration. This is also an index into a %select in 331 // the diagnostic. 332 enum CalleeType { CT_Function, CT_Method, CT_Block } calleeType; 333 334 if (ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(D)) { 335 numFormalParams = MD->param_size(); 336 calleeType = CT_Method; 337 } else if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) { 338 numFormalParams = FD->param_size(); 339 calleeType = CT_Function; 340 } else if (isa<VarDecl>(D)) { 341 QualType type = cast<ValueDecl>(D)->getType(); 342 const FunctionType *fn = 0; 343 if (const PointerType *ptr = type->getAs<PointerType>()) { 344 fn = ptr->getPointeeType()->getAs<FunctionType>(); 345 if (!fn) return; 346 calleeType = CT_Function; 347 } else if (const BlockPointerType *ptr = type->getAs<BlockPointerType>()) { 348 fn = ptr->getPointeeType()->castAs<FunctionType>(); 349 calleeType = CT_Block; 350 } else { 351 return; 352 } 353 354 if (const FunctionProtoType *proto = dyn_cast<FunctionProtoType>(fn)) { 355 numFormalParams = proto->getNumArgs(); 356 } else { 357 numFormalParams = 0; 358 } 359 } else { 360 return; 361 } 362 363 // "nullPos" is the number of formal parameters at the end which 364 // effectively count as part of the variadic arguments. This is 365 // useful if you would prefer to not have *any* formal parameters, 366 // but the language forces you to have at least one. 367 unsigned nullPos = attr->getNullPos(); 368 assert((nullPos == 0 || nullPos == 1) && "invalid null position on sentinel"); 369 numFormalParams = (nullPos > numFormalParams ? 0 : numFormalParams - nullPos); 370 371 // The number of arguments which should follow the sentinel. 372 unsigned numArgsAfterSentinel = attr->getSentinel(); 373 374 // If there aren't enough arguments for all the formal parameters, 375 // the sentinel, and the args after the sentinel, complain. 376 if (Args.size() < numFormalParams + numArgsAfterSentinel + 1) { 377 Diag(Loc, diag::warn_not_enough_argument) << D->getDeclName(); 378 Diag(D->getLocation(), diag::note_sentinel_here) << int(calleeType); 379 return; 380 } 381 382 // Otherwise, find the sentinel expression. 383 Expr *sentinelExpr = Args[Args.size() - numArgsAfterSentinel - 1]; 384 if (!sentinelExpr) return; 385 if (sentinelExpr->isValueDependent()) return; 386 if (Context.isSentinelNullExpr(sentinelExpr)) return; 387 388 // Pick a reasonable string to insert. Optimistically use 'nil' or 389 // 'NULL' if those are actually defined in the context. Only use 390 // 'nil' for ObjC methods, where it's much more likely that the 391 // variadic arguments form a list of object pointers. 392 SourceLocation MissingNilLoc 393 = PP.getLocForEndOfToken(sentinelExpr->getLocEnd()); 394 std::string NullValue; 395 if (calleeType == CT_Method && 396 PP.getIdentifierInfo("nil")->hasMacroDefinition()) 397 NullValue = "nil"; 398 else if (PP.getIdentifierInfo("NULL")->hasMacroDefinition()) 399 NullValue = "NULL"; 400 else 401 NullValue = "(void*) 0"; 402 403 if (MissingNilLoc.isInvalid()) 404 Diag(Loc, diag::warn_missing_sentinel) << int(calleeType); 405 else 406 Diag(MissingNilLoc, diag::warn_missing_sentinel) 407 << int(calleeType) 408 << FixItHint::CreateInsertion(MissingNilLoc, ", " + NullValue); 409 Diag(D->getLocation(), diag::note_sentinel_here) << int(calleeType); 410 } 411 412 SourceRange Sema::getExprRange(Expr *E) const { 413 return E ? E->getSourceRange() : SourceRange(); 414 } 415 416 //===----------------------------------------------------------------------===// 417 // Standard Promotions and Conversions 418 //===----------------------------------------------------------------------===// 419 420 /// DefaultFunctionArrayConversion (C99 6.3.2.1p3, C99 6.3.2.1p4). 421 ExprResult Sema::DefaultFunctionArrayConversion(Expr *E) { 422 // Handle any placeholder expressions which made it here. 423 if (E->getType()->isPlaceholderType()) { 424 ExprResult result = CheckPlaceholderExpr(E); 425 if (result.isInvalid()) return ExprError(); 426 E = result.take(); 427 } 428 429 QualType Ty = E->getType(); 430 assert(!Ty.isNull() && "DefaultFunctionArrayConversion - missing type"); 431 432 if (Ty->isFunctionType()) 433 E = ImpCastExprToType(E, Context.getPointerType(Ty), 434 CK_FunctionToPointerDecay).take(); 435 else if (Ty->isArrayType()) { 436 // In C90 mode, arrays only promote to pointers if the array expression is 437 // an lvalue. The relevant legalese is C90 6.2.2.1p3: "an lvalue that has 438 // type 'array of type' is converted to an expression that has type 'pointer 439 // to type'...". In C99 this was changed to: C99 6.3.2.1p3: "an expression 440 // that has type 'array of type' ...". The relevant change is "an lvalue" 441 // (C90) to "an expression" (C99). 442 // 443 // C++ 4.2p1: 444 // An lvalue or rvalue of type "array of N T" or "array of unknown bound of 445 // T" can be converted to an rvalue of type "pointer to T". 446 // 447 if (getLangOpts().C99 || getLangOpts().CPlusPlus || E->isLValue()) 448 E = ImpCastExprToType(E, Context.getArrayDecayedType(Ty), 449 CK_ArrayToPointerDecay).take(); 450 } 451 return Owned(E); 452 } 453 454 static void CheckForNullPointerDereference(Sema &S, Expr *E) { 455 // Check to see if we are dereferencing a null pointer. If so, 456 // and if not volatile-qualified, this is undefined behavior that the 457 // optimizer will delete, so warn about it. People sometimes try to use this 458 // to get a deterministic trap and are surprised by clang's behavior. This 459 // only handles the pattern "*null", which is a very syntactic check. 460 if (UnaryOperator *UO = dyn_cast<UnaryOperator>(E->IgnoreParenCasts())) 461 if (UO->getOpcode() == UO_Deref && 462 UO->getSubExpr()->IgnoreParenCasts()-> 463 isNullPointerConstant(S.Context, Expr::NPC_ValueDependentIsNotNull) && 464 !UO->getType().isVolatileQualified()) { 465 S.DiagRuntimeBehavior(UO->getOperatorLoc(), UO, 466 S.PDiag(diag::warn_indirection_through_null) 467 << UO->getSubExpr()->getSourceRange()); 468 S.DiagRuntimeBehavior(UO->getOperatorLoc(), UO, 469 S.PDiag(diag::note_indirection_through_null)); 470 } 471 } 472 473 static void DiagnoseDirectIsaAccess(Sema &S, const ObjCIvarRefExpr *OIRE, 474 SourceLocation AssignLoc, 475 const Expr* RHS) { 476 const ObjCIvarDecl *IV = OIRE->getDecl(); 477 if (!IV) 478 return; 479 480 DeclarationName MemberName = IV->getDeclName(); 481 IdentifierInfo *Member = MemberName.getAsIdentifierInfo(); 482 if (!Member || !Member->isStr("isa")) 483 return; 484 485 const Expr *Base = OIRE->getBase(); 486 QualType BaseType = Base->getType(); 487 if (OIRE->isArrow()) 488 BaseType = BaseType->getPointeeType(); 489 if (const ObjCObjectType *OTy = BaseType->getAs<ObjCObjectType>()) 490 if (ObjCInterfaceDecl *IDecl = OTy->getInterface()) { 491 ObjCInterfaceDecl *ClassDeclared = 0; 492 ObjCIvarDecl *IV = IDecl->lookupInstanceVariable(Member, ClassDeclared); 493 if (!ClassDeclared->getSuperClass() 494 && (*ClassDeclared->ivar_begin()) == IV) { 495 if (RHS) { 496 NamedDecl *ObjectSetClass = 497 S.LookupSingleName(S.TUScope, 498 &S.Context.Idents.get("object_setClass"), 499 SourceLocation(), S.LookupOrdinaryName); 500 if (ObjectSetClass) { 501 SourceLocation RHSLocEnd = S.PP.getLocForEndOfToken(RHS->getLocEnd()); 502 S.Diag(OIRE->getExprLoc(), diag::warn_objc_isa_assign) << 503 FixItHint::CreateInsertion(OIRE->getLocStart(), "object_setClass(") << 504 FixItHint::CreateReplacement(SourceRange(OIRE->getOpLoc(), 505 AssignLoc), ",") << 506 FixItHint::CreateInsertion(RHSLocEnd, ")"); 507 } 508 else 509 S.Diag(OIRE->getLocation(), diag::warn_objc_isa_assign); 510 } else { 511 NamedDecl *ObjectGetClass = 512 S.LookupSingleName(S.TUScope, 513 &S.Context.Idents.get("object_getClass"), 514 SourceLocation(), S.LookupOrdinaryName); 515 if (ObjectGetClass) 516 S.Diag(OIRE->getExprLoc(), diag::warn_objc_isa_use) << 517 FixItHint::CreateInsertion(OIRE->getLocStart(), "object_getClass(") << 518 FixItHint::CreateReplacement( 519 SourceRange(OIRE->getOpLoc(), 520 OIRE->getLocEnd()), ")"); 521 else 522 S.Diag(OIRE->getLocation(), diag::warn_objc_isa_use); 523 } 524 S.Diag(IV->getLocation(), diag::note_ivar_decl); 525 } 526 } 527 } 528 529 ExprResult Sema::DefaultLvalueConversion(Expr *E) { 530 // Handle any placeholder expressions which made it here. 531 if (E->getType()->isPlaceholderType()) { 532 ExprResult result = CheckPlaceholderExpr(E); 533 if (result.isInvalid()) return ExprError(); 534 E = result.take(); 535 } 536 537 // C++ [conv.lval]p1: 538 // A glvalue of a non-function, non-array type T can be 539 // converted to a prvalue. 540 if (!E->isGLValue()) return Owned(E); 541 542 QualType T = E->getType(); 543 assert(!T.isNull() && "r-value conversion on typeless expression?"); 544 545 // We don't want to throw lvalue-to-rvalue casts on top of 546 // expressions of certain types in C++. 547 if (getLangOpts().CPlusPlus && 548 (E->getType() == Context.OverloadTy || 549 T->isDependentType() || 550 T->isRecordType())) 551 return Owned(E); 552 553 // The C standard is actually really unclear on this point, and 554 // DR106 tells us what the result should be but not why. It's 555 // generally best to say that void types just doesn't undergo 556 // lvalue-to-rvalue at all. Note that expressions of unqualified 557 // 'void' type are never l-values, but qualified void can be. 558 if (T->isVoidType()) 559 return Owned(E); 560 561 // OpenCL usually rejects direct accesses to values of 'half' type. 562 if (getLangOpts().OpenCL && !getOpenCLOptions().cl_khr_fp16 && 563 T->isHalfType()) { 564 Diag(E->getExprLoc(), diag::err_opencl_half_load_store) 565 << 0 << T; 566 return ExprError(); 567 } 568 569 CheckForNullPointerDereference(*this, E); 570 if (const ObjCIsaExpr *OISA = dyn_cast<ObjCIsaExpr>(E->IgnoreParenCasts())) { 571 NamedDecl *ObjectGetClass = LookupSingleName(TUScope, 572 &Context.Idents.get("object_getClass"), 573 SourceLocation(), LookupOrdinaryName); 574 if (ObjectGetClass) 575 Diag(E->getExprLoc(), diag::warn_objc_isa_use) << 576 FixItHint::CreateInsertion(OISA->getLocStart(), "object_getClass(") << 577 FixItHint::CreateReplacement( 578 SourceRange(OISA->getOpLoc(), OISA->getIsaMemberLoc()), ")"); 579 else 580 Diag(E->getExprLoc(), diag::warn_objc_isa_use); 581 } 582 else if (const ObjCIvarRefExpr *OIRE = 583 dyn_cast<ObjCIvarRefExpr>(E->IgnoreParenCasts())) 584 DiagnoseDirectIsaAccess(*this, OIRE, SourceLocation(), /* Expr*/0); 585 586 // C++ [conv.lval]p1: 587 // [...] If T is a non-class type, the type of the prvalue is the 588 // cv-unqualified version of T. Otherwise, the type of the 589 // rvalue is T. 590 // 591 // C99 6.3.2.1p2: 592 // If the lvalue has qualified type, the value has the unqualified 593 // version of the type of the lvalue; otherwise, the value has the 594 // type of the lvalue. 595 if (T.hasQualifiers()) 596 T = T.getUnqualifiedType(); 597 598 UpdateMarkingForLValueToRValue(E); 599 600 // Loading a __weak object implicitly retains the value, so we need a cleanup to 601 // balance that. 602 if (getLangOpts().ObjCAutoRefCount && 603 E->getType().getObjCLifetime() == Qualifiers::OCL_Weak) 604 ExprNeedsCleanups = true; 605 606 ExprResult Res = Owned(ImplicitCastExpr::Create(Context, T, CK_LValueToRValue, 607 E, 0, VK_RValue)); 608 609 // C11 6.3.2.1p2: 610 // ... if the lvalue has atomic type, the value has the non-atomic version 611 // of the type of the lvalue ... 612 if (const AtomicType *Atomic = T->getAs<AtomicType>()) { 613 T = Atomic->getValueType().getUnqualifiedType(); 614 Res = Owned(ImplicitCastExpr::Create(Context, T, CK_AtomicToNonAtomic, 615 Res.get(), 0, VK_RValue)); 616 } 617 618 return Res; 619 } 620 621 ExprResult Sema::DefaultFunctionArrayLvalueConversion(Expr *E) { 622 ExprResult Res = DefaultFunctionArrayConversion(E); 623 if (Res.isInvalid()) 624 return ExprError(); 625 Res = DefaultLvalueConversion(Res.take()); 626 if (Res.isInvalid()) 627 return ExprError(); 628 return Res; 629 } 630 631 632 /// UsualUnaryConversions - Performs various conversions that are common to most 633 /// operators (C99 6.3). The conversions of array and function types are 634 /// sometimes suppressed. For example, the array->pointer conversion doesn't 635 /// apply if the array is an argument to the sizeof or address (&) operators. 636 /// In these instances, this routine should *not* be called. 637 ExprResult Sema::UsualUnaryConversions(Expr *E) { 638 // First, convert to an r-value. 639 ExprResult Res = DefaultFunctionArrayLvalueConversion(E); 640 if (Res.isInvalid()) 641 return ExprError(); 642 E = Res.take(); 643 644 QualType Ty = E->getType(); 645 assert(!Ty.isNull() && "UsualUnaryConversions - missing type"); 646 647 // Half FP have to be promoted to float unless it is natively supported 648 if (Ty->isHalfType() && !getLangOpts().NativeHalfType) 649 return ImpCastExprToType(Res.take(), Context.FloatTy, CK_FloatingCast); 650 651 // Try to perform integral promotions if the object has a theoretically 652 // promotable type. 653 if (Ty->isIntegralOrUnscopedEnumerationType()) { 654 // C99 6.3.1.1p2: 655 // 656 // The following may be used in an expression wherever an int or 657 // unsigned int may be used: 658 // - an object or expression with an integer type whose integer 659 // conversion rank is less than or equal to the rank of int 660 // and unsigned int. 661 // - A bit-field of type _Bool, int, signed int, or unsigned int. 662 // 663 // If an int can represent all values of the original type, the 664 // value is converted to an int; otherwise, it is converted to an 665 // unsigned int. These are called the integer promotions. All 666 // other types are unchanged by the integer promotions. 667 668 QualType PTy = Context.isPromotableBitField(E); 669 if (!PTy.isNull()) { 670 E = ImpCastExprToType(E, PTy, CK_IntegralCast).take(); 671 return Owned(E); 672 } 673 if (Ty->isPromotableIntegerType()) { 674 QualType PT = Context.getPromotedIntegerType(Ty); 675 E = ImpCastExprToType(E, PT, CK_IntegralCast).take(); 676 return Owned(E); 677 } 678 } 679 return Owned(E); 680 } 681 682 /// DefaultArgumentPromotion (C99 6.5.2.2p6). Used for function calls that 683 /// do not have a prototype. Arguments that have type float or __fp16 684 /// are promoted to double. All other argument types are converted by 685 /// UsualUnaryConversions(). 686 ExprResult Sema::DefaultArgumentPromotion(Expr *E) { 687 QualType Ty = E->getType(); 688 assert(!Ty.isNull() && "DefaultArgumentPromotion - missing type"); 689 690 ExprResult Res = UsualUnaryConversions(E); 691 if (Res.isInvalid()) 692 return ExprError(); 693 E = Res.take(); 694 695 // If this is a 'float' or '__fp16' (CVR qualified or typedef) promote to 696 // double. 697 const BuiltinType *BTy = Ty->getAs<BuiltinType>(); 698 if (BTy && (BTy->getKind() == BuiltinType::Half || 699 BTy->getKind() == BuiltinType::Float)) 700 E = ImpCastExprToType(E, Context.DoubleTy, CK_FloatingCast).take(); 701 702 // C++ performs lvalue-to-rvalue conversion as a default argument 703 // promotion, even on class types, but note: 704 // C++11 [conv.lval]p2: 705 // When an lvalue-to-rvalue conversion occurs in an unevaluated 706 // operand or a subexpression thereof the value contained in the 707 // referenced object is not accessed. Otherwise, if the glvalue 708 // has a class type, the conversion copy-initializes a temporary 709 // of type T from the glvalue and the result of the conversion 710 // is a prvalue for the temporary. 711 // FIXME: add some way to gate this entire thing for correctness in 712 // potentially potentially evaluated contexts. 713 if (getLangOpts().CPlusPlus && E->isGLValue() && !isUnevaluatedContext()) { 714 ExprResult Temp = PerformCopyInitialization( 715 InitializedEntity::InitializeTemporary(E->getType()), 716 E->getExprLoc(), 717 Owned(E)); 718 if (Temp.isInvalid()) 719 return ExprError(); 720 E = Temp.get(); 721 } 722 723 return Owned(E); 724 } 725 726 /// Determine the degree of POD-ness for an expression. 727 /// Incomplete types are considered POD, since this check can be performed 728 /// when we're in an unevaluated context. 729 Sema::VarArgKind Sema::isValidVarArgType(const QualType &Ty) { 730 if (Ty->isIncompleteType()) { 731 // C++11 [expr.call]p7: 732 // After these conversions, if the argument does not have arithmetic, 733 // enumeration, pointer, pointer to member, or class type, the program 734 // is ill-formed. 735 // 736 // Since we've already performed array-to-pointer and function-to-pointer 737 // decay, the only such type in C++ is cv void. This also handles 738 // initializer lists as variadic arguments. 739 if (Ty->isVoidType()) 740 return VAK_Invalid; 741 742 if (Ty->isObjCObjectType()) 743 return VAK_Invalid; 744 return VAK_Valid; 745 } 746 747 if (Ty.isCXX98PODType(Context)) 748 return VAK_Valid; 749 750 // C++11 [expr.call]p7: 751 // Passing a potentially-evaluated argument of class type (Clause 9) 752 // having a non-trivial copy constructor, a non-trivial move constructor, 753 // or a non-trivial destructor, with no corresponding parameter, 754 // is conditionally-supported with implementation-defined semantics. 755 if (getLangOpts().CPlusPlus11 && !Ty->isDependentType()) 756 if (CXXRecordDecl *Record = Ty->getAsCXXRecordDecl()) 757 if (!Record->hasNonTrivialCopyConstructor() && 758 !Record->hasNonTrivialMoveConstructor() && 759 !Record->hasNonTrivialDestructor()) 760 return VAK_ValidInCXX11; 761 762 if (getLangOpts().ObjCAutoRefCount && Ty->isObjCLifetimeType()) 763 return VAK_Valid; 764 765 if (Ty->isObjCObjectType()) 766 return VAK_Invalid; 767 768 // FIXME: In C++11, these cases are conditionally-supported, meaning we're 769 // permitted to reject them. We should consider doing so. 770 return VAK_Undefined; 771 } 772 773 void Sema::checkVariadicArgument(const Expr *E, VariadicCallType CT) { 774 // Don't allow one to pass an Objective-C interface to a vararg. 775 const QualType &Ty = E->getType(); 776 VarArgKind VAK = isValidVarArgType(Ty); 777 778 // Complain about passing non-POD types through varargs. 779 switch (VAK) { 780 case VAK_Valid: 781 break; 782 783 case VAK_ValidInCXX11: 784 DiagRuntimeBehavior( 785 E->getLocStart(), 0, 786 PDiag(diag::warn_cxx98_compat_pass_non_pod_arg_to_vararg) 787 << E->getType() << CT); 788 break; 789 790 case VAK_Undefined: 791 DiagRuntimeBehavior( 792 E->getLocStart(), 0, 793 PDiag(diag::warn_cannot_pass_non_pod_arg_to_vararg) 794 << getLangOpts().CPlusPlus11 << Ty << CT); 795 break; 796 797 case VAK_Invalid: 798 if (Ty->isObjCObjectType()) 799 DiagRuntimeBehavior( 800 E->getLocStart(), 0, 801 PDiag(diag::err_cannot_pass_objc_interface_to_vararg) 802 << Ty << CT); 803 else 804 Diag(E->getLocStart(), diag::err_cannot_pass_to_vararg) 805 << isa<InitListExpr>(E) << Ty << CT; 806 break; 807 } 808 } 809 810 /// DefaultVariadicArgumentPromotion - Like DefaultArgumentPromotion, but 811 /// will create a trap if the resulting type is not a POD type. 812 ExprResult Sema::DefaultVariadicArgumentPromotion(Expr *E, VariadicCallType CT, 813 FunctionDecl *FDecl) { 814 if (const BuiltinType *PlaceholderTy = E->getType()->getAsPlaceholderType()) { 815 // Strip the unbridged-cast placeholder expression off, if applicable. 816 if (PlaceholderTy->getKind() == BuiltinType::ARCUnbridgedCast && 817 (CT == VariadicMethod || 818 (FDecl && FDecl->hasAttr<CFAuditedTransferAttr>()))) { 819 E = stripARCUnbridgedCast(E); 820 821 // Otherwise, do normal placeholder checking. 822 } else { 823 ExprResult ExprRes = CheckPlaceholderExpr(E); 824 if (ExprRes.isInvalid()) 825 return ExprError(); 826 E = ExprRes.take(); 827 } 828 } 829 830 ExprResult ExprRes = DefaultArgumentPromotion(E); 831 if (ExprRes.isInvalid()) 832 return ExprError(); 833 E = ExprRes.take(); 834 835 // Diagnostics regarding non-POD argument types are 836 // emitted along with format string checking in Sema::CheckFunctionCall(). 837 if (isValidVarArgType(E->getType()) == VAK_Undefined) { 838 // Turn this into a trap. 839 CXXScopeSpec SS; 840 SourceLocation TemplateKWLoc; 841 UnqualifiedId Name; 842 Name.setIdentifier(PP.getIdentifierInfo("__builtin_trap"), 843 E->getLocStart()); 844 ExprResult TrapFn = ActOnIdExpression(TUScope, SS, TemplateKWLoc, 845 Name, true, false); 846 if (TrapFn.isInvalid()) 847 return ExprError(); 848 849 ExprResult Call = ActOnCallExpr(TUScope, TrapFn.get(), 850 E->getLocStart(), None, 851 E->getLocEnd()); 852 if (Call.isInvalid()) 853 return ExprError(); 854 855 ExprResult Comma = ActOnBinOp(TUScope, E->getLocStart(), tok::comma, 856 Call.get(), E); 857 if (Comma.isInvalid()) 858 return ExprError(); 859 return Comma.get(); 860 } 861 862 if (!getLangOpts().CPlusPlus && 863 RequireCompleteType(E->getExprLoc(), E->getType(), 864 diag::err_call_incomplete_argument)) 865 return ExprError(); 866 867 return Owned(E); 868 } 869 870 /// \brief Converts an integer to complex float type. Helper function of 871 /// UsualArithmeticConversions() 872 /// 873 /// \return false if the integer expression is an integer type and is 874 /// successfully converted to the complex type. 875 static bool handleIntegerToComplexFloatConversion(Sema &S, ExprResult &IntExpr, 876 ExprResult &ComplexExpr, 877 QualType IntTy, 878 QualType ComplexTy, 879 bool SkipCast) { 880 if (IntTy->isComplexType() || IntTy->isRealFloatingType()) return true; 881 if (SkipCast) return false; 882 if (IntTy->isIntegerType()) { 883 QualType fpTy = cast<ComplexType>(ComplexTy)->getElementType(); 884 IntExpr = S.ImpCastExprToType(IntExpr.take(), fpTy, CK_IntegralToFloating); 885 IntExpr = S.ImpCastExprToType(IntExpr.take(), ComplexTy, 886 CK_FloatingRealToComplex); 887 } else { 888 assert(IntTy->isComplexIntegerType()); 889 IntExpr = S.ImpCastExprToType(IntExpr.take(), ComplexTy, 890 CK_IntegralComplexToFloatingComplex); 891 } 892 return false; 893 } 894 895 /// \brief Takes two complex float types and converts them to the same type. 896 /// Helper function of UsualArithmeticConversions() 897 static QualType 898 handleComplexFloatToComplexFloatConverstion(Sema &S, ExprResult &LHS, 899 ExprResult &RHS, QualType LHSType, 900 QualType RHSType, 901 bool IsCompAssign) { 902 int order = S.Context.getFloatingTypeOrder(LHSType, RHSType); 903 904 if (order < 0) { 905 // _Complex float -> _Complex double 906 if (!IsCompAssign) 907 LHS = S.ImpCastExprToType(LHS.take(), RHSType, CK_FloatingComplexCast); 908 return RHSType; 909 } 910 if (order > 0) 911 // _Complex float -> _Complex double 912 RHS = S.ImpCastExprToType(RHS.take(), LHSType, CK_FloatingComplexCast); 913 return LHSType; 914 } 915 916 /// \brief Converts otherExpr to complex float and promotes complexExpr if 917 /// necessary. Helper function of UsualArithmeticConversions() 918 static QualType handleOtherComplexFloatConversion(Sema &S, 919 ExprResult &ComplexExpr, 920 ExprResult &OtherExpr, 921 QualType ComplexTy, 922 QualType OtherTy, 923 bool ConvertComplexExpr, 924 bool ConvertOtherExpr) { 925 int order = S.Context.getFloatingTypeOrder(ComplexTy, OtherTy); 926 927 // If just the complexExpr is complex, the otherExpr needs to be converted, 928 // and the complexExpr might need to be promoted. 929 if (order > 0) { // complexExpr is wider 930 // float -> _Complex double 931 if (ConvertOtherExpr) { 932 QualType fp = cast<ComplexType>(ComplexTy)->getElementType(); 933 OtherExpr = S.ImpCastExprToType(OtherExpr.take(), fp, CK_FloatingCast); 934 OtherExpr = S.ImpCastExprToType(OtherExpr.take(), ComplexTy, 935 CK_FloatingRealToComplex); 936 } 937 return ComplexTy; 938 } 939 940 // otherTy is at least as wide. Find its corresponding complex type. 941 QualType result = (order == 0 ? ComplexTy : 942 S.Context.getComplexType(OtherTy)); 943 944 // double -> _Complex double 945 if (ConvertOtherExpr) 946 OtherExpr = S.ImpCastExprToType(OtherExpr.take(), result, 947 CK_FloatingRealToComplex); 948 949 // _Complex float -> _Complex double 950 if (ConvertComplexExpr && order < 0) 951 ComplexExpr = S.ImpCastExprToType(ComplexExpr.take(), result, 952 CK_FloatingComplexCast); 953 954 return result; 955 } 956 957 /// \brief Handle arithmetic conversion with complex types. Helper function of 958 /// UsualArithmeticConversions() 959 static QualType handleComplexFloatConversion(Sema &S, ExprResult &LHS, 960 ExprResult &RHS, QualType LHSType, 961 QualType RHSType, 962 bool IsCompAssign) { 963 // if we have an integer operand, the result is the complex type. 964 if (!handleIntegerToComplexFloatConversion(S, RHS, LHS, RHSType, LHSType, 965 /*skipCast*/false)) 966 return LHSType; 967 if (!handleIntegerToComplexFloatConversion(S, LHS, RHS, LHSType, RHSType, 968 /*skipCast*/IsCompAssign)) 969 return RHSType; 970 971 // This handles complex/complex, complex/float, or float/complex. 972 // When both operands are complex, the shorter operand is converted to the 973 // type of the longer, and that is the type of the result. This corresponds 974 // to what is done when combining two real floating-point operands. 975 // The fun begins when size promotion occur across type domains. 976 // From H&S 6.3.4: When one operand is complex and the other is a real 977 // floating-point type, the less precise type is converted, within it's 978 // real or complex domain, to the precision of the other type. For example, 979 // when combining a "long double" with a "double _Complex", the 980 // "double _Complex" is promoted to "long double _Complex". 981 982 bool LHSComplexFloat = LHSType->isComplexType(); 983 bool RHSComplexFloat = RHSType->isComplexType(); 984 985 // If both are complex, just cast to the more precise type. 986 if (LHSComplexFloat && RHSComplexFloat) 987 return handleComplexFloatToComplexFloatConverstion(S, LHS, RHS, 988 LHSType, RHSType, 989 IsCompAssign); 990 991 // If only one operand is complex, promote it if necessary and convert the 992 // other operand to complex. 993 if (LHSComplexFloat) 994 return handleOtherComplexFloatConversion( 995 S, LHS, RHS, LHSType, RHSType, /*convertComplexExpr*/!IsCompAssign, 996 /*convertOtherExpr*/ true); 997 998 assert(RHSComplexFloat); 999 return handleOtherComplexFloatConversion( 1000 S, RHS, LHS, RHSType, LHSType, /*convertComplexExpr*/true, 1001 /*convertOtherExpr*/ !IsCompAssign); 1002 } 1003 1004 /// \brief Hande arithmetic conversion from integer to float. Helper function 1005 /// of UsualArithmeticConversions() 1006 static QualType handleIntToFloatConversion(Sema &S, ExprResult &FloatExpr, 1007 ExprResult &IntExpr, 1008 QualType FloatTy, QualType IntTy, 1009 bool ConvertFloat, bool ConvertInt) { 1010 if (IntTy->isIntegerType()) { 1011 if (ConvertInt) 1012 // Convert intExpr to the lhs floating point type. 1013 IntExpr = S.ImpCastExprToType(IntExpr.take(), FloatTy, 1014 CK_IntegralToFloating); 1015 return FloatTy; 1016 } 1017 1018 // Convert both sides to the appropriate complex float. 1019 assert(IntTy->isComplexIntegerType()); 1020 QualType result = S.Context.getComplexType(FloatTy); 1021 1022 // _Complex int -> _Complex float 1023 if (ConvertInt) 1024 IntExpr = S.ImpCastExprToType(IntExpr.take(), result, 1025 CK_IntegralComplexToFloatingComplex); 1026 1027 // float -> _Complex float 1028 if (ConvertFloat) 1029 FloatExpr = S.ImpCastExprToType(FloatExpr.take(), result, 1030 CK_FloatingRealToComplex); 1031 1032 return result; 1033 } 1034 1035 /// \brief Handle arithmethic conversion with floating point types. Helper 1036 /// function of UsualArithmeticConversions() 1037 static QualType handleFloatConversion(Sema &S, ExprResult &LHS, 1038 ExprResult &RHS, QualType LHSType, 1039 QualType RHSType, bool IsCompAssign) { 1040 bool LHSFloat = LHSType->isRealFloatingType(); 1041 bool RHSFloat = RHSType->isRealFloatingType(); 1042 1043 // If we have two real floating types, convert the smaller operand 1044 // to the bigger result. 1045 if (LHSFloat && RHSFloat) { 1046 int order = S.Context.getFloatingTypeOrder(LHSType, RHSType); 1047 if (order > 0) { 1048 RHS = S.ImpCastExprToType(RHS.take(), LHSType, CK_FloatingCast); 1049 return LHSType; 1050 } 1051 1052 assert(order < 0 && "illegal float comparison"); 1053 if (!IsCompAssign) 1054 LHS = S.ImpCastExprToType(LHS.take(), RHSType, CK_FloatingCast); 1055 return RHSType; 1056 } 1057 1058 if (LHSFloat) 1059 return handleIntToFloatConversion(S, LHS, RHS, LHSType, RHSType, 1060 /*convertFloat=*/!IsCompAssign, 1061 /*convertInt=*/ true); 1062 assert(RHSFloat); 1063 return handleIntToFloatConversion(S, RHS, LHS, RHSType, LHSType, 1064 /*convertInt=*/ true, 1065 /*convertFloat=*/!IsCompAssign); 1066 } 1067 1068 typedef ExprResult PerformCastFn(Sema &S, Expr *operand, QualType toType); 1069 1070 namespace { 1071 /// These helper callbacks are placed in an anonymous namespace to 1072 /// permit their use as function template parameters. 1073 ExprResult doIntegralCast(Sema &S, Expr *op, QualType toType) { 1074 return S.ImpCastExprToType(op, toType, CK_IntegralCast); 1075 } 1076 1077 ExprResult doComplexIntegralCast(Sema &S, Expr *op, QualType toType) { 1078 return S.ImpCastExprToType(op, S.Context.getComplexType(toType), 1079 CK_IntegralComplexCast); 1080 } 1081 } 1082 1083 /// \brief Handle integer arithmetic conversions. Helper function of 1084 /// UsualArithmeticConversions() 1085 template <PerformCastFn doLHSCast, PerformCastFn doRHSCast> 1086 static QualType handleIntegerConversion(Sema &S, ExprResult &LHS, 1087 ExprResult &RHS, QualType LHSType, 1088 QualType RHSType, bool IsCompAssign) { 1089 // The rules for this case are in C99 6.3.1.8 1090 int order = S.Context.getIntegerTypeOrder(LHSType, RHSType); 1091 bool LHSSigned = LHSType->hasSignedIntegerRepresentation(); 1092 bool RHSSigned = RHSType->hasSignedIntegerRepresentation(); 1093 if (LHSSigned == RHSSigned) { 1094 // Same signedness; use the higher-ranked type 1095 if (order >= 0) { 1096 RHS = (*doRHSCast)(S, RHS.take(), LHSType); 1097 return LHSType; 1098 } else if (!IsCompAssign) 1099 LHS = (*doLHSCast)(S, LHS.take(), RHSType); 1100 return RHSType; 1101 } else if (order != (LHSSigned ? 1 : -1)) { 1102 // The unsigned type has greater than or equal rank to the 1103 // signed type, so use the unsigned type 1104 if (RHSSigned) { 1105 RHS = (*doRHSCast)(S, RHS.take(), LHSType); 1106 return LHSType; 1107 } else if (!IsCompAssign) 1108 LHS = (*doLHSCast)(S, LHS.take(), RHSType); 1109 return RHSType; 1110 } else if (S.Context.getIntWidth(LHSType) != S.Context.getIntWidth(RHSType)) { 1111 // The two types are different widths; if we are here, that 1112 // means the signed type is larger than the unsigned type, so 1113 // use the signed type. 1114 if (LHSSigned) { 1115 RHS = (*doRHSCast)(S, RHS.take(), LHSType); 1116 return LHSType; 1117 } else if (!IsCompAssign) 1118 LHS = (*doLHSCast)(S, LHS.take(), RHSType); 1119 return RHSType; 1120 } else { 1121 // The signed type is higher-ranked than the unsigned type, 1122 // but isn't actually any bigger (like unsigned int and long 1123 // on most 32-bit systems). Use the unsigned type corresponding 1124 // to the signed type. 1125 QualType result = 1126 S.Context.getCorrespondingUnsignedType(LHSSigned ? LHSType : RHSType); 1127 RHS = (*doRHSCast)(S, RHS.take(), result); 1128 if (!IsCompAssign) 1129 LHS = (*doLHSCast)(S, LHS.take(), result); 1130 return result; 1131 } 1132 } 1133 1134 /// \brief Handle conversions with GCC complex int extension. Helper function 1135 /// of UsualArithmeticConversions() 1136 static QualType handleComplexIntConversion(Sema &S, ExprResult &LHS, 1137 ExprResult &RHS, QualType LHSType, 1138 QualType RHSType, 1139 bool IsCompAssign) { 1140 const ComplexType *LHSComplexInt = LHSType->getAsComplexIntegerType(); 1141 const ComplexType *RHSComplexInt = RHSType->getAsComplexIntegerType(); 1142 1143 if (LHSComplexInt && RHSComplexInt) { 1144 QualType LHSEltType = LHSComplexInt->getElementType(); 1145 QualType RHSEltType = RHSComplexInt->getElementType(); 1146 QualType ScalarType = 1147 handleIntegerConversion<doComplexIntegralCast, doComplexIntegralCast> 1148 (S, LHS, RHS, LHSEltType, RHSEltType, IsCompAssign); 1149 1150 return S.Context.getComplexType(ScalarType); 1151 } 1152 1153 if (LHSComplexInt) { 1154 QualType LHSEltType = LHSComplexInt->getElementType(); 1155 QualType ScalarType = 1156 handleIntegerConversion<doComplexIntegralCast, doIntegralCast> 1157 (S, LHS, RHS, LHSEltType, RHSType, IsCompAssign); 1158 QualType ComplexType = S.Context.getComplexType(ScalarType); 1159 RHS = S.ImpCastExprToType(RHS.take(), ComplexType, 1160 CK_IntegralRealToComplex); 1161 1162 return ComplexType; 1163 } 1164 1165 assert(RHSComplexInt); 1166 1167 QualType RHSEltType = RHSComplexInt->getElementType(); 1168 QualType ScalarType = 1169 handleIntegerConversion<doIntegralCast, doComplexIntegralCast> 1170 (S, LHS, RHS, LHSType, RHSEltType, IsCompAssign); 1171 QualType ComplexType = S.Context.getComplexType(ScalarType); 1172 1173 if (!IsCompAssign) 1174 LHS = S.ImpCastExprToType(LHS.take(), ComplexType, 1175 CK_IntegralRealToComplex); 1176 return ComplexType; 1177 } 1178 1179 /// UsualArithmeticConversions - Performs various conversions that are common to 1180 /// binary operators (C99 6.3.1.8). If both operands aren't arithmetic, this 1181 /// routine returns the first non-arithmetic type found. The client is 1182 /// responsible for emitting appropriate error diagnostics. 1183 QualType Sema::UsualArithmeticConversions(ExprResult &LHS, ExprResult &RHS, 1184 bool IsCompAssign) { 1185 if (!IsCompAssign) { 1186 LHS = UsualUnaryConversions(LHS.take()); 1187 if (LHS.isInvalid()) 1188 return QualType(); 1189 } 1190 1191 RHS = UsualUnaryConversions(RHS.take()); 1192 if (RHS.isInvalid()) 1193 return QualType(); 1194 1195 // For conversion purposes, we ignore any qualifiers. 1196 // For example, "const float" and "float" are equivalent. 1197 QualType LHSType = 1198 Context.getCanonicalType(LHS.get()->getType()).getUnqualifiedType(); 1199 QualType RHSType = 1200 Context.getCanonicalType(RHS.get()->getType()).getUnqualifiedType(); 1201 1202 // For conversion purposes, we ignore any atomic qualifier on the LHS. 1203 if (const AtomicType *AtomicLHS = LHSType->getAs<AtomicType>()) 1204 LHSType = AtomicLHS->getValueType(); 1205 1206 // If both types are identical, no conversion is needed. 1207 if (LHSType == RHSType) 1208 return LHSType; 1209 1210 // If either side is a non-arithmetic type (e.g. a pointer), we are done. 1211 // The caller can deal with this (e.g. pointer + int). 1212 if (!LHSType->isArithmeticType() || !RHSType->isArithmeticType()) 1213 return QualType(); 1214 1215 // Apply unary and bitfield promotions to the LHS's type. 1216 QualType LHSUnpromotedType = LHSType; 1217 if (LHSType->isPromotableIntegerType()) 1218 LHSType = Context.getPromotedIntegerType(LHSType); 1219 QualType LHSBitfieldPromoteTy = Context.isPromotableBitField(LHS.get()); 1220 if (!LHSBitfieldPromoteTy.isNull()) 1221 LHSType = LHSBitfieldPromoteTy; 1222 if (LHSType != LHSUnpromotedType && !IsCompAssign) 1223 LHS = ImpCastExprToType(LHS.take(), LHSType, CK_IntegralCast); 1224 1225 // If both types are identical, no conversion is needed. 1226 if (LHSType == RHSType) 1227 return LHSType; 1228 1229 // At this point, we have two different arithmetic types. 1230 1231 // Handle complex types first (C99 6.3.1.8p1). 1232 if (LHSType->isComplexType() || RHSType->isComplexType()) 1233 return handleComplexFloatConversion(*this, LHS, RHS, LHSType, RHSType, 1234 IsCompAssign); 1235 1236 // Now handle "real" floating types (i.e. float, double, long double). 1237 if (LHSType->isRealFloatingType() || RHSType->isRealFloatingType()) 1238 return handleFloatConversion(*this, LHS, RHS, LHSType, RHSType, 1239 IsCompAssign); 1240 1241 // Handle GCC complex int extension. 1242 if (LHSType->isComplexIntegerType() || RHSType->isComplexIntegerType()) 1243 return handleComplexIntConversion(*this, LHS, RHS, LHSType, RHSType, 1244 IsCompAssign); 1245 1246 // Finally, we have two differing integer types. 1247 return handleIntegerConversion<doIntegralCast, doIntegralCast> 1248 (*this, LHS, RHS, LHSType, RHSType, IsCompAssign); 1249 } 1250 1251 1252 //===----------------------------------------------------------------------===// 1253 // Semantic Analysis for various Expression Types 1254 //===----------------------------------------------------------------------===// 1255 1256 1257 ExprResult 1258 Sema::ActOnGenericSelectionExpr(SourceLocation KeyLoc, 1259 SourceLocation DefaultLoc, 1260 SourceLocation RParenLoc, 1261 Expr *ControllingExpr, 1262 ArrayRef<ParsedType> ArgTypes, 1263 ArrayRef<Expr *> ArgExprs) { 1264 unsigned NumAssocs = ArgTypes.size(); 1265 assert(NumAssocs == ArgExprs.size()); 1266 1267 TypeSourceInfo **Types = new TypeSourceInfo*[NumAssocs]; 1268 for (unsigned i = 0; i < NumAssocs; ++i) { 1269 if (ArgTypes[i]) 1270 (void) GetTypeFromParser(ArgTypes[i], &Types[i]); 1271 else 1272 Types[i] = 0; 1273 } 1274 1275 ExprResult ER = CreateGenericSelectionExpr(KeyLoc, DefaultLoc, RParenLoc, 1276 ControllingExpr, 1277 llvm::makeArrayRef(Types, NumAssocs), 1278 ArgExprs); 1279 delete [] Types; 1280 return ER; 1281 } 1282 1283 ExprResult 1284 Sema::CreateGenericSelectionExpr(SourceLocation KeyLoc, 1285 SourceLocation DefaultLoc, 1286 SourceLocation RParenLoc, 1287 Expr *ControllingExpr, 1288 ArrayRef<TypeSourceInfo *> Types, 1289 ArrayRef<Expr *> Exprs) { 1290 unsigned NumAssocs = Types.size(); 1291 assert(NumAssocs == Exprs.size()); 1292 if (ControllingExpr->getType()->isPlaceholderType()) { 1293 ExprResult result = CheckPlaceholderExpr(ControllingExpr); 1294 if (result.isInvalid()) return ExprError(); 1295 ControllingExpr = result.take(); 1296 } 1297 1298 bool TypeErrorFound = false, 1299 IsResultDependent = ControllingExpr->isTypeDependent(), 1300 ContainsUnexpandedParameterPack 1301 = ControllingExpr->containsUnexpandedParameterPack(); 1302 1303 for (unsigned i = 0; i < NumAssocs; ++i) { 1304 if (Exprs[i]->containsUnexpandedParameterPack()) 1305 ContainsUnexpandedParameterPack = true; 1306 1307 if (Types[i]) { 1308 if (Types[i]->getType()->containsUnexpandedParameterPack()) 1309 ContainsUnexpandedParameterPack = true; 1310 1311 if (Types[i]->getType()->isDependentType()) { 1312 IsResultDependent = true; 1313 } else { 1314 // C11 6.5.1.1p2 "The type name in a generic association shall specify a 1315 // complete object type other than a variably modified type." 1316 unsigned D = 0; 1317 if (Types[i]->getType()->isIncompleteType()) 1318 D = diag::err_assoc_type_incomplete; 1319 else if (!Types[i]->getType()->isObjectType()) 1320 D = diag::err_assoc_type_nonobject; 1321 else if (Types[i]->getType()->isVariablyModifiedType()) 1322 D = diag::err_assoc_type_variably_modified; 1323 1324 if (D != 0) { 1325 Diag(Types[i]->getTypeLoc().getBeginLoc(), D) 1326 << Types[i]->getTypeLoc().getSourceRange() 1327 << Types[i]->getType(); 1328 TypeErrorFound = true; 1329 } 1330 1331 // C11 6.5.1.1p2 "No two generic associations in the same generic 1332 // selection shall specify compatible types." 1333 for (unsigned j = i+1; j < NumAssocs; ++j) 1334 if (Types[j] && !Types[j]->getType()->isDependentType() && 1335 Context.typesAreCompatible(Types[i]->getType(), 1336 Types[j]->getType())) { 1337 Diag(Types[j]->getTypeLoc().getBeginLoc(), 1338 diag::err_assoc_compatible_types) 1339 << Types[j]->getTypeLoc().getSourceRange() 1340 << Types[j]->getType() 1341 << Types[i]->getType(); 1342 Diag(Types[i]->getTypeLoc().getBeginLoc(), 1343 diag::note_compat_assoc) 1344 << Types[i]->getTypeLoc().getSourceRange() 1345 << Types[i]->getType(); 1346 TypeErrorFound = true; 1347 } 1348 } 1349 } 1350 } 1351 if (TypeErrorFound) 1352 return ExprError(); 1353 1354 // If we determined that the generic selection is result-dependent, don't 1355 // try to compute the result expression. 1356 if (IsResultDependent) 1357 return Owned(new (Context) GenericSelectionExpr( 1358 Context, KeyLoc, ControllingExpr, 1359 Types, Exprs, 1360 DefaultLoc, RParenLoc, ContainsUnexpandedParameterPack)); 1361 1362 SmallVector<unsigned, 1> CompatIndices; 1363 unsigned DefaultIndex = -1U; 1364 for (unsigned i = 0; i < NumAssocs; ++i) { 1365 if (!Types[i]) 1366 DefaultIndex = i; 1367 else if (Context.typesAreCompatible(ControllingExpr->getType(), 1368 Types[i]->getType())) 1369 CompatIndices.push_back(i); 1370 } 1371 1372 // C11 6.5.1.1p2 "The controlling expression of a generic selection shall have 1373 // type compatible with at most one of the types named in its generic 1374 // association list." 1375 if (CompatIndices.size() > 1) { 1376 // We strip parens here because the controlling expression is typically 1377 // parenthesized in macro definitions. 1378 ControllingExpr = ControllingExpr->IgnoreParens(); 1379 Diag(ControllingExpr->getLocStart(), diag::err_generic_sel_multi_match) 1380 << ControllingExpr->getSourceRange() << ControllingExpr->getType() 1381 << (unsigned) CompatIndices.size(); 1382 for (SmallVectorImpl<unsigned>::iterator I = CompatIndices.begin(), 1383 E = CompatIndices.end(); I != E; ++I) { 1384 Diag(Types[*I]->getTypeLoc().getBeginLoc(), 1385 diag::note_compat_assoc) 1386 << Types[*I]->getTypeLoc().getSourceRange() 1387 << Types[*I]->getType(); 1388 } 1389 return ExprError(); 1390 } 1391 1392 // C11 6.5.1.1p2 "If a generic selection has no default generic association, 1393 // its controlling expression shall have type compatible with exactly one of 1394 // the types named in its generic association list." 1395 if (DefaultIndex == -1U && CompatIndices.size() == 0) { 1396 // We strip parens here because the controlling expression is typically 1397 // parenthesized in macro definitions. 1398 ControllingExpr = ControllingExpr->IgnoreParens(); 1399 Diag(ControllingExpr->getLocStart(), diag::err_generic_sel_no_match) 1400 << ControllingExpr->getSourceRange() << ControllingExpr->getType(); 1401 return ExprError(); 1402 } 1403 1404 // C11 6.5.1.1p3 "If a generic selection has a generic association with a 1405 // type name that is compatible with the type of the controlling expression, 1406 // then the result expression of the generic selection is the expression 1407 // in that generic association. Otherwise, the result expression of the 1408 // generic selection is the expression in the default generic association." 1409 unsigned ResultIndex = 1410 CompatIndices.size() ? CompatIndices[0] : DefaultIndex; 1411 1412 return Owned(new (Context) GenericSelectionExpr( 1413 Context, KeyLoc, ControllingExpr, 1414 Types, Exprs, 1415 DefaultLoc, RParenLoc, ContainsUnexpandedParameterPack, 1416 ResultIndex)); 1417 } 1418 1419 /// getUDSuffixLoc - Create a SourceLocation for a ud-suffix, given the 1420 /// location of the token and the offset of the ud-suffix within it. 1421 static SourceLocation getUDSuffixLoc(Sema &S, SourceLocation TokLoc, 1422 unsigned Offset) { 1423 return Lexer::AdvanceToTokenCharacter(TokLoc, Offset, S.getSourceManager(), 1424 S.getLangOpts()); 1425 } 1426 1427 /// BuildCookedLiteralOperatorCall - A user-defined literal was found. Look up 1428 /// the corresponding cooked (non-raw) literal operator, and build a call to it. 1429 static ExprResult BuildCookedLiteralOperatorCall(Sema &S, Scope *Scope, 1430 IdentifierInfo *UDSuffix, 1431 SourceLocation UDSuffixLoc, 1432 ArrayRef<Expr*> Args, 1433 SourceLocation LitEndLoc) { 1434 assert(Args.size() <= 2 && "too many arguments for literal operator"); 1435 1436 QualType ArgTy[2]; 1437 for (unsigned ArgIdx = 0; ArgIdx != Args.size(); ++ArgIdx) { 1438 ArgTy[ArgIdx] = Args[ArgIdx]->getType(); 1439 if (ArgTy[ArgIdx]->isArrayType()) 1440 ArgTy[ArgIdx] = S.Context.getArrayDecayedType(ArgTy[ArgIdx]); 1441 } 1442 1443 DeclarationName OpName = 1444 S.Context.DeclarationNames.getCXXLiteralOperatorName(UDSuffix); 1445 DeclarationNameInfo OpNameInfo(OpName, UDSuffixLoc); 1446 OpNameInfo.setCXXLiteralOperatorNameLoc(UDSuffixLoc); 1447 1448 LookupResult R(S, OpName, UDSuffixLoc, Sema::LookupOrdinaryName); 1449 if (S.LookupLiteralOperator(Scope, R, llvm::makeArrayRef(ArgTy, Args.size()), 1450 /*AllowRaw*/false, /*AllowTemplate*/false, 1451 /*AllowStringTemplate*/false) == Sema::LOLR_Error) 1452 return ExprError(); 1453 1454 return S.BuildLiteralOperatorCall(R, OpNameInfo, Args, LitEndLoc); 1455 } 1456 1457 /// ActOnStringLiteral - The specified tokens were lexed as pasted string 1458 /// fragments (e.g. "foo" "bar" L"baz"). The result string has to handle string 1459 /// concatenation ([C99 5.1.1.2, translation phase #6]), so it may come from 1460 /// multiple tokens. However, the common case is that StringToks points to one 1461 /// string. 1462 /// 1463 ExprResult 1464 Sema::ActOnStringLiteral(const Token *StringToks, unsigned NumStringToks, 1465 Scope *UDLScope) { 1466 assert(NumStringToks && "Must have at least one string!"); 1467 1468 StringLiteralParser Literal(StringToks, NumStringToks, PP); 1469 if (Literal.hadError) 1470 return ExprError(); 1471 1472 SmallVector<SourceLocation, 4> StringTokLocs; 1473 for (unsigned i = 0; i != NumStringToks; ++i) 1474 StringTokLocs.push_back(StringToks[i].getLocation()); 1475 1476 QualType CharTy = Context.CharTy; 1477 StringLiteral::StringKind Kind = StringLiteral::Ascii; 1478 if (Literal.isWide()) { 1479 CharTy = Context.getWideCharType(); 1480 Kind = StringLiteral::Wide; 1481 } else if (Literal.isUTF8()) { 1482 Kind = StringLiteral::UTF8; 1483 } else if (Literal.isUTF16()) { 1484 CharTy = Context.Char16Ty; 1485 Kind = StringLiteral::UTF16; 1486 } else if (Literal.isUTF32()) { 1487 CharTy = Context.Char32Ty; 1488 Kind = StringLiteral::UTF32; 1489 } else if (Literal.isPascal()) { 1490 CharTy = Context.UnsignedCharTy; 1491 } 1492 1493 QualType CharTyConst = CharTy; 1494 // A C++ string literal has a const-qualified element type (C++ 2.13.4p1). 1495 if (getLangOpts().CPlusPlus || getLangOpts().ConstStrings) 1496 CharTyConst.addConst(); 1497 1498 // Get an array type for the string, according to C99 6.4.5. This includes 1499 // the nul terminator character as well as the string length for pascal 1500 // strings. 1501 QualType StrTy = Context.getConstantArrayType(CharTyConst, 1502 llvm::APInt(32, Literal.GetNumStringChars()+1), 1503 ArrayType::Normal, 0); 1504 1505 // OpenCL v1.1 s6.5.3: a string literal is in the constant address space. 1506 if (getLangOpts().OpenCL) { 1507 StrTy = Context.getAddrSpaceQualType(StrTy, LangAS::opencl_constant); 1508 } 1509 1510 // Pass &StringTokLocs[0], StringTokLocs.size() to factory! 1511 StringLiteral *Lit = StringLiteral::Create(Context, Literal.GetString(), 1512 Kind, Literal.Pascal, StrTy, 1513 &StringTokLocs[0], 1514 StringTokLocs.size()); 1515 if (Literal.getUDSuffix().empty()) 1516 return Owned(Lit); 1517 1518 // We're building a user-defined literal. 1519 IdentifierInfo *UDSuffix = &Context.Idents.get(Literal.getUDSuffix()); 1520 SourceLocation UDSuffixLoc = 1521 getUDSuffixLoc(*this, StringTokLocs[Literal.getUDSuffixToken()], 1522 Literal.getUDSuffixOffset()); 1523 1524 // Make sure we're allowed user-defined literals here. 1525 if (!UDLScope) 1526 return ExprError(Diag(UDSuffixLoc, diag::err_invalid_string_udl)); 1527 1528 // C++11 [lex.ext]p5: The literal L is treated as a call of the form 1529 // operator "" X (str, len) 1530 QualType SizeType = Context.getSizeType(); 1531 1532 DeclarationName OpName = 1533 Context.DeclarationNames.getCXXLiteralOperatorName(UDSuffix); 1534 DeclarationNameInfo OpNameInfo(OpName, UDSuffixLoc); 1535 OpNameInfo.setCXXLiteralOperatorNameLoc(UDSuffixLoc); 1536 1537 QualType ArgTy[] = { 1538 Context.getArrayDecayedType(StrTy), SizeType 1539 }; 1540 1541 LookupResult R(*this, OpName, UDSuffixLoc, LookupOrdinaryName); 1542 switch (LookupLiteralOperator(UDLScope, R, ArgTy, 1543 /*AllowRaw*/false, /*AllowTemplate*/false, 1544 /*AllowStringTemplate*/true)) { 1545 1546 case LOLR_Cooked: { 1547 llvm::APInt Len(Context.getIntWidth(SizeType), Literal.GetNumStringChars()); 1548 IntegerLiteral *LenArg = IntegerLiteral::Create(Context, Len, SizeType, 1549 StringTokLocs[0]); 1550 Expr *Args[] = { Lit, LenArg }; 1551 1552 return BuildLiteralOperatorCall(R, OpNameInfo, Args, StringTokLocs.back()); 1553 } 1554 1555 case LOLR_StringTemplate: { 1556 TemplateArgumentListInfo ExplicitArgs; 1557 1558 unsigned CharBits = Context.getIntWidth(CharTy); 1559 bool CharIsUnsigned = CharTy->isUnsignedIntegerType(); 1560 llvm::APSInt Value(CharBits, CharIsUnsigned); 1561 1562 TemplateArgument TypeArg(CharTy); 1563 TemplateArgumentLocInfo TypeArgInfo(Context.getTrivialTypeSourceInfo(CharTy)); 1564 ExplicitArgs.addArgument(TemplateArgumentLoc(TypeArg, TypeArgInfo)); 1565 1566 for (unsigned I = 0, N = Lit->getLength(); I != N; ++I) { 1567 Value = Lit->getCodeUnit(I); 1568 TemplateArgument Arg(Context, Value, CharTy); 1569 TemplateArgumentLocInfo ArgInfo; 1570 ExplicitArgs.addArgument(TemplateArgumentLoc(Arg, ArgInfo)); 1571 } 1572 return BuildLiteralOperatorCall(R, OpNameInfo, None, StringTokLocs.back(), 1573 &ExplicitArgs); 1574 } 1575 case LOLR_Raw: 1576 case LOLR_Template: 1577 llvm_unreachable("unexpected literal operator lookup result"); 1578 case LOLR_Error: 1579 return ExprError(); 1580 } 1581 llvm_unreachable("unexpected literal operator lookup result"); 1582 } 1583 1584 ExprResult 1585 Sema::BuildDeclRefExpr(ValueDecl *D, QualType Ty, ExprValueKind VK, 1586 SourceLocation Loc, 1587 const CXXScopeSpec *SS) { 1588 DeclarationNameInfo NameInfo(D->getDeclName(), Loc); 1589 return BuildDeclRefExpr(D, Ty, VK, NameInfo, SS); 1590 } 1591 1592 /// BuildDeclRefExpr - Build an expression that references a 1593 /// declaration that does not require a closure capture. 1594 ExprResult 1595 Sema::BuildDeclRefExpr(ValueDecl *D, QualType Ty, ExprValueKind VK, 1596 const DeclarationNameInfo &NameInfo, 1597 const CXXScopeSpec *SS, NamedDecl *FoundD, 1598 const TemplateArgumentListInfo *TemplateArgs) { 1599 if (getLangOpts().CUDA) 1600 if (const FunctionDecl *Caller = dyn_cast<FunctionDecl>(CurContext)) 1601 if (const FunctionDecl *Callee = dyn_cast<FunctionDecl>(D)) { 1602 CUDAFunctionTarget CallerTarget = IdentifyCUDATarget(Caller), 1603 CalleeTarget = IdentifyCUDATarget(Callee); 1604 if (CheckCUDATarget(CallerTarget, CalleeTarget)) { 1605 Diag(NameInfo.getLoc(), diag::err_ref_bad_target) 1606 << CalleeTarget << D->getIdentifier() << CallerTarget; 1607 Diag(D->getLocation(), diag::note_previous_decl) 1608 << D->getIdentifier(); 1609 return ExprError(); 1610 } 1611 } 1612 1613 bool refersToEnclosingScope = 1614 (CurContext != D->getDeclContext() && 1615 D->getDeclContext()->isFunctionOrMethod()) || 1616 (isa<VarDecl>(D) && 1617 cast<VarDecl>(D)->isInitCapture()); 1618 1619 DeclRefExpr *E; 1620 if (isa<VarTemplateSpecializationDecl>(D)) { 1621 VarTemplateSpecializationDecl *VarSpec = 1622 cast<VarTemplateSpecializationDecl>(D); 1623 1624 E = DeclRefExpr::Create( 1625 Context, 1626 SS ? SS->getWithLocInContext(Context) : NestedNameSpecifierLoc(), 1627 VarSpec->getTemplateKeywordLoc(), D, refersToEnclosingScope, 1628 NameInfo.getLoc(), Ty, VK, FoundD, TemplateArgs); 1629 } else { 1630 assert(!TemplateArgs && "No template arguments for non-variable" 1631 " template specialization references"); 1632 E = DeclRefExpr::Create( 1633 Context, 1634 SS ? SS->getWithLocInContext(Context) : NestedNameSpecifierLoc(), 1635 SourceLocation(), D, refersToEnclosingScope, NameInfo, Ty, VK, FoundD); 1636 } 1637 1638 MarkDeclRefReferenced(E); 1639 1640 if (getLangOpts().ObjCARCWeak && isa<VarDecl>(D) && 1641 Ty.getObjCLifetime() == Qualifiers::OCL_Weak) { 1642 DiagnosticsEngine::Level Level = 1643 Diags.getDiagnosticLevel(diag::warn_arc_repeated_use_of_weak, 1644 E->getLocStart()); 1645 if (Level != DiagnosticsEngine::Ignored) 1646 recordUseOfEvaluatedWeak(E); 1647 } 1648 1649 // Just in case we're building an illegal pointer-to-member. 1650 FieldDecl *FD = dyn_cast<FieldDecl>(D); 1651 if (FD && FD->isBitField()) 1652 E->setObjectKind(OK_BitField); 1653 1654 return Owned(E); 1655 } 1656 1657 /// Decomposes the given name into a DeclarationNameInfo, its location, and 1658 /// possibly a list of template arguments. 1659 /// 1660 /// If this produces template arguments, it is permitted to call 1661 /// DecomposeTemplateName. 1662 /// 1663 /// This actually loses a lot of source location information for 1664 /// non-standard name kinds; we should consider preserving that in 1665 /// some way. 1666 void 1667 Sema::DecomposeUnqualifiedId(const UnqualifiedId &Id, 1668 TemplateArgumentListInfo &Buffer, 1669 DeclarationNameInfo &NameInfo, 1670 const TemplateArgumentListInfo *&TemplateArgs) { 1671 if (Id.getKind() == UnqualifiedId::IK_TemplateId) { 1672 Buffer.setLAngleLoc(Id.TemplateId->LAngleLoc); 1673 Buffer.setRAngleLoc(Id.TemplateId->RAngleLoc); 1674 1675 ASTTemplateArgsPtr TemplateArgsPtr(Id.TemplateId->getTemplateArgs(), 1676 Id.TemplateId->NumArgs); 1677 translateTemplateArguments(TemplateArgsPtr, Buffer); 1678 1679 TemplateName TName = Id.TemplateId->Template.get(); 1680 SourceLocation TNameLoc = Id.TemplateId->TemplateNameLoc; 1681 NameInfo = Context.getNameForTemplate(TName, TNameLoc); 1682 TemplateArgs = &Buffer; 1683 } else { 1684 NameInfo = GetNameFromUnqualifiedId(Id); 1685 TemplateArgs = 0; 1686 } 1687 } 1688 1689 /// Diagnose an empty lookup. 1690 /// 1691 /// \return false if new lookup candidates were found 1692 bool Sema::DiagnoseEmptyLookup(Scope *S, CXXScopeSpec &SS, LookupResult &R, 1693 CorrectionCandidateCallback &CCC, 1694 TemplateArgumentListInfo *ExplicitTemplateArgs, 1695 ArrayRef<Expr *> Args) { 1696 DeclarationName Name = R.getLookupName(); 1697 1698 unsigned diagnostic = diag::err_undeclared_var_use; 1699 unsigned diagnostic_suggest = diag::err_undeclared_var_use_suggest; 1700 if (Name.getNameKind() == DeclarationName::CXXOperatorName || 1701 Name.getNameKind() == DeclarationName::CXXLiteralOperatorName || 1702 Name.getNameKind() == DeclarationName::CXXConversionFunctionName) { 1703 diagnostic = diag::err_undeclared_use; 1704 diagnostic_suggest = diag::err_undeclared_use_suggest; 1705 } 1706 1707 // If the original lookup was an unqualified lookup, fake an 1708 // unqualified lookup. This is useful when (for example) the 1709 // original lookup would not have found something because it was a 1710 // dependent name. 1711 DeclContext *DC = (SS.isEmpty() && !CallsUndergoingInstantiation.empty()) 1712 ? CurContext : 0; 1713 while (DC) { 1714 if (isa<CXXRecordDecl>(DC)) { 1715 LookupQualifiedName(R, DC); 1716 1717 if (!R.empty()) { 1718 // Don't give errors about ambiguities in this lookup. 1719 R.suppressDiagnostics(); 1720 1721 // During a default argument instantiation the CurContext points 1722 // to a CXXMethodDecl; but we can't apply a this-> fixit inside a 1723 // function parameter list, hence add an explicit check. 1724 bool isDefaultArgument = !ActiveTemplateInstantiations.empty() && 1725 ActiveTemplateInstantiations.back().Kind == 1726 ActiveTemplateInstantiation::DefaultFunctionArgumentInstantiation; 1727 CXXMethodDecl *CurMethod = dyn_cast<CXXMethodDecl>(CurContext); 1728 bool isInstance = CurMethod && 1729 CurMethod->isInstance() && 1730 DC == CurMethod->getParent() && !isDefaultArgument; 1731 1732 1733 // Give a code modification hint to insert 'this->'. 1734 // TODO: fixit for inserting 'Base<T>::' in the other cases. 1735 // Actually quite difficult! 1736 if (getLangOpts().MSVCCompat) 1737 diagnostic = diag::warn_found_via_dependent_bases_lookup; 1738 if (isInstance) { 1739 Diag(R.getNameLoc(), diagnostic) << Name 1740 << FixItHint::CreateInsertion(R.getNameLoc(), "this->"); 1741 UnresolvedLookupExpr *ULE = cast<UnresolvedLookupExpr>( 1742 CallsUndergoingInstantiation.back()->getCallee()); 1743 1744 CXXMethodDecl *DepMethod; 1745 if (CurMethod->isDependentContext()) 1746 DepMethod = CurMethod; 1747 else if (CurMethod->getTemplatedKind() == 1748 FunctionDecl::TK_FunctionTemplateSpecialization) 1749 DepMethod = cast<CXXMethodDecl>(CurMethod->getPrimaryTemplate()-> 1750 getInstantiatedFromMemberTemplate()->getTemplatedDecl()); 1751 else 1752 DepMethod = cast<CXXMethodDecl>( 1753 CurMethod->getInstantiatedFromMemberFunction()); 1754 assert(DepMethod && "No template pattern found"); 1755 1756 QualType DepThisType = DepMethod->getThisType(Context); 1757 CheckCXXThisCapture(R.getNameLoc()); 1758 CXXThisExpr *DepThis = new (Context) CXXThisExpr( 1759 R.getNameLoc(), DepThisType, false); 1760 TemplateArgumentListInfo TList; 1761 if (ULE->hasExplicitTemplateArgs()) 1762 ULE->copyTemplateArgumentsInto(TList); 1763 1764 CXXScopeSpec SS; 1765 SS.Adopt(ULE->getQualifierLoc()); 1766 CXXDependentScopeMemberExpr *DepExpr = 1767 CXXDependentScopeMemberExpr::Create( 1768 Context, DepThis, DepThisType, true, SourceLocation(), 1769 SS.getWithLocInContext(Context), 1770 ULE->getTemplateKeywordLoc(), 0, 1771 R.getLookupNameInfo(), 1772 ULE->hasExplicitTemplateArgs() ? &TList : 0); 1773 CallsUndergoingInstantiation.back()->setCallee(DepExpr); 1774 } else { 1775 Diag(R.getNameLoc(), diagnostic) << Name; 1776 } 1777 1778 // Do we really want to note all of these? 1779 for (LookupResult::iterator I = R.begin(), E = R.end(); I != E; ++I) 1780 Diag((*I)->getLocation(), diag::note_dependent_var_use); 1781 1782 // Return true if we are inside a default argument instantiation 1783 // and the found name refers to an instance member function, otherwise 1784 // the function calling DiagnoseEmptyLookup will try to create an 1785 // implicit member call and this is wrong for default argument. 1786 if (isDefaultArgument && ((*R.begin())->isCXXInstanceMember())) { 1787 Diag(R.getNameLoc(), diag::err_member_call_without_object); 1788 return true; 1789 } 1790 1791 // Tell the callee to try to recover. 1792 return false; 1793 } 1794 1795 R.clear(); 1796 } 1797 1798 // In Microsoft mode, if we are performing lookup from within a friend 1799 // function definition declared at class scope then we must set 1800 // DC to the lexical parent to be able to search into the parent 1801 // class. 1802 if (getLangOpts().MSVCCompat && isa<FunctionDecl>(DC) && 1803 cast<FunctionDecl>(DC)->getFriendObjectKind() && 1804 DC->getLexicalParent()->isRecord()) 1805 DC = DC->getLexicalParent(); 1806 else 1807 DC = DC->getParent(); 1808 } 1809 1810 // We didn't find anything, so try to correct for a typo. 1811 TypoCorrection Corrected; 1812 if (S && (Corrected = CorrectTypo(R.getLookupNameInfo(), R.getLookupKind(), 1813 S, &SS, CCC))) { 1814 std::string CorrectedStr(Corrected.getAsString(getLangOpts())); 1815 bool DroppedSpecifier = 1816 Corrected.WillReplaceSpecifier() && Name.getAsString() == CorrectedStr; 1817 R.setLookupName(Corrected.getCorrection()); 1818 1819 bool AcceptableWithRecovery = false; 1820 bool AcceptableWithoutRecovery = false; 1821 NamedDecl *ND = Corrected.getCorrectionDecl(); 1822 if (ND) { 1823 if (Corrected.isOverloaded()) { 1824 OverloadCandidateSet OCS(R.getNameLoc()); 1825 OverloadCandidateSet::iterator Best; 1826 for (TypoCorrection::decl_iterator CD = Corrected.begin(), 1827 CDEnd = Corrected.end(); 1828 CD != CDEnd; ++CD) { 1829 if (FunctionTemplateDecl *FTD = 1830 dyn_cast<FunctionTemplateDecl>(*CD)) 1831 AddTemplateOverloadCandidate( 1832 FTD, DeclAccessPair::make(FTD, AS_none), ExplicitTemplateArgs, 1833 Args, OCS); 1834 else if (FunctionDecl *FD = dyn_cast<FunctionDecl>(*CD)) 1835 if (!ExplicitTemplateArgs || ExplicitTemplateArgs->size() == 0) 1836 AddOverloadCandidate(FD, DeclAccessPair::make(FD, AS_none), 1837 Args, OCS); 1838 } 1839 switch (OCS.BestViableFunction(*this, R.getNameLoc(), Best)) { 1840 case OR_Success: 1841 ND = Best->Function; 1842 Corrected.setCorrectionDecl(ND); 1843 break; 1844 default: 1845 // FIXME: Arbitrarily pick the first declaration for the note. 1846 Corrected.setCorrectionDecl(ND); 1847 break; 1848 } 1849 } 1850 R.addDecl(ND); 1851 1852 AcceptableWithRecovery = 1853 isa<ValueDecl>(ND) || isa<FunctionTemplateDecl>(ND); 1854 // FIXME: If we ended up with a typo for a type name or 1855 // Objective-C class name, we're in trouble because the parser 1856 // is in the wrong place to recover. Suggest the typo 1857 // correction, but don't make it a fix-it since we're not going 1858 // to recover well anyway. 1859 AcceptableWithoutRecovery = 1860 isa<TypeDecl>(ND) || isa<ObjCInterfaceDecl>(ND); 1861 } else { 1862 // FIXME: We found a keyword. Suggest it, but don't provide a fix-it 1863 // because we aren't able to recover. 1864 AcceptableWithoutRecovery = true; 1865 } 1866 1867 if (AcceptableWithRecovery || AcceptableWithoutRecovery) { 1868 unsigned NoteID = (Corrected.getCorrectionDecl() && 1869 isa<ImplicitParamDecl>(Corrected.getCorrectionDecl())) 1870 ? diag::note_implicit_param_decl 1871 : diag::note_previous_decl; 1872 if (SS.isEmpty()) 1873 diagnoseTypo(Corrected, PDiag(diagnostic_suggest) << Name, 1874 PDiag(NoteID), AcceptableWithRecovery); 1875 else 1876 diagnoseTypo(Corrected, PDiag(diag::err_no_member_suggest) 1877 << Name << computeDeclContext(SS, false) 1878 << DroppedSpecifier << SS.getRange(), 1879 PDiag(NoteID), AcceptableWithRecovery); 1880 1881 // Tell the callee whether to try to recover. 1882 return !AcceptableWithRecovery; 1883 } 1884 } 1885 R.clear(); 1886 1887 // Emit a special diagnostic for failed member lookups. 1888 // FIXME: computing the declaration context might fail here (?) 1889 if (!SS.isEmpty()) { 1890 Diag(R.getNameLoc(), diag::err_no_member) 1891 << Name << computeDeclContext(SS, false) 1892 << SS.getRange(); 1893 return true; 1894 } 1895 1896 // Give up, we can't recover. 1897 Diag(R.getNameLoc(), diagnostic) << Name; 1898 return true; 1899 } 1900 1901 ExprResult Sema::ActOnIdExpression(Scope *S, 1902 CXXScopeSpec &SS, 1903 SourceLocation TemplateKWLoc, 1904 UnqualifiedId &Id, 1905 bool HasTrailingLParen, 1906 bool IsAddressOfOperand, 1907 CorrectionCandidateCallback *CCC, 1908 bool IsInlineAsmIdentifier) { 1909 assert(!(IsAddressOfOperand && HasTrailingLParen) && 1910 "cannot be direct & operand and have a trailing lparen"); 1911 if (SS.isInvalid()) 1912 return ExprError(); 1913 1914 TemplateArgumentListInfo TemplateArgsBuffer; 1915 1916 // Decompose the UnqualifiedId into the following data. 1917 DeclarationNameInfo NameInfo; 1918 const TemplateArgumentListInfo *TemplateArgs; 1919 DecomposeUnqualifiedId(Id, TemplateArgsBuffer, NameInfo, TemplateArgs); 1920 1921 DeclarationName Name = NameInfo.getName(); 1922 IdentifierInfo *II = Name.getAsIdentifierInfo(); 1923 SourceLocation NameLoc = NameInfo.getLoc(); 1924 1925 // C++ [temp.dep.expr]p3: 1926 // An id-expression is type-dependent if it contains: 1927 // -- an identifier that was declared with a dependent type, 1928 // (note: handled after lookup) 1929 // -- a template-id that is dependent, 1930 // (note: handled in BuildTemplateIdExpr) 1931 // -- a conversion-function-id that specifies a dependent type, 1932 // -- a nested-name-specifier that contains a class-name that 1933 // names a dependent type. 1934 // Determine whether this is a member of an unknown specialization; 1935 // we need to handle these differently. 1936 bool DependentID = false; 1937 if (Name.getNameKind() == DeclarationName::CXXConversionFunctionName && 1938 Name.getCXXNameType()->isDependentType()) { 1939 DependentID = true; 1940 } else if (SS.isSet()) { 1941 if (DeclContext *DC = computeDeclContext(SS, false)) { 1942 if (RequireCompleteDeclContext(SS, DC)) 1943 return ExprError(); 1944 } else { 1945 DependentID = true; 1946 } 1947 } 1948 1949 if (DependentID) 1950 return ActOnDependentIdExpression(SS, TemplateKWLoc, NameInfo, 1951 IsAddressOfOperand, TemplateArgs); 1952 1953 // Perform the required lookup. 1954 LookupResult R(*this, NameInfo, 1955 (Id.getKind() == UnqualifiedId::IK_ImplicitSelfParam) 1956 ? LookupObjCImplicitSelfParam : LookupOrdinaryName); 1957 if (TemplateArgs) { 1958 // Lookup the template name again to correctly establish the context in 1959 // which it was found. This is really unfortunate as we already did the 1960 // lookup to determine that it was a template name in the first place. If 1961 // this becomes a performance hit, we can work harder to preserve those 1962 // results until we get here but it's likely not worth it. 1963 bool MemberOfUnknownSpecialization; 1964 LookupTemplateName(R, S, SS, QualType(), /*EnteringContext=*/false, 1965 MemberOfUnknownSpecialization); 1966 1967 if (MemberOfUnknownSpecialization || 1968 (R.getResultKind() == LookupResult::NotFoundInCurrentInstantiation)) 1969 return ActOnDependentIdExpression(SS, TemplateKWLoc, NameInfo, 1970 IsAddressOfOperand, TemplateArgs); 1971 } else { 1972 bool IvarLookupFollowUp = II && !SS.isSet() && getCurMethodDecl(); 1973 LookupParsedName(R, S, &SS, !IvarLookupFollowUp); 1974 1975 // If the result might be in a dependent base class, this is a dependent 1976 // id-expression. 1977 if (R.getResultKind() == LookupResult::NotFoundInCurrentInstantiation) 1978 return ActOnDependentIdExpression(SS, TemplateKWLoc, NameInfo, 1979 IsAddressOfOperand, TemplateArgs); 1980 1981 // If this reference is in an Objective-C method, then we need to do 1982 // some special Objective-C lookup, too. 1983 if (IvarLookupFollowUp) { 1984 ExprResult E(LookupInObjCMethod(R, S, II, true)); 1985 if (E.isInvalid()) 1986 return ExprError(); 1987 1988 if (Expr *Ex = E.takeAs<Expr>()) 1989 return Owned(Ex); 1990 } 1991 } 1992 1993 if (R.isAmbiguous()) 1994 return ExprError(); 1995 1996 // Determine whether this name might be a candidate for 1997 // argument-dependent lookup. 1998 bool ADL = UseArgumentDependentLookup(SS, R, HasTrailingLParen); 1999 2000 if (R.empty() && !ADL) { 2001 2002 // Otherwise, this could be an implicitly declared function reference (legal 2003 // in C90, extension in C99, forbidden in C++). 2004 if (HasTrailingLParen && II && !getLangOpts().CPlusPlus) { 2005 NamedDecl *D = ImplicitlyDefineFunction(NameLoc, *II, S); 2006 if (D) R.addDecl(D); 2007 } 2008 2009 // If this name wasn't predeclared and if this is not a function 2010 // call, diagnose the problem. 2011 if (R.empty()) { 2012 // In Microsoft mode, if we are inside a template class member function 2013 // whose parent class has dependent base classes, and we can't resolve 2014 // an identifier, then assume the identifier is a member of a dependent 2015 // base class. The goal is to postpone name lookup to instantiation time 2016 // to be able to search into the type dependent base classes. 2017 // FIXME: If we want 100% compatibility with MSVC, we will have delay all 2018 // unqualified name lookup. Any name lookup during template parsing means 2019 // clang might find something that MSVC doesn't. For now, we only handle 2020 // the common case of members of a dependent base class. 2021 if (getLangOpts().MSVCCompat) { 2022 CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(CurContext); 2023 if (MD && MD->isInstance() && MD->getParent()->hasAnyDependentBases()) { 2024 assert(SS.isEmpty() && "qualifiers should be already handled"); 2025 QualType ThisType = MD->getThisType(Context); 2026 // Since the 'this' expression is synthesized, we don't need to 2027 // perform the double-lookup check. 2028 NamedDecl *FirstQualifierInScope = 0; 2029 return Owned(CXXDependentScopeMemberExpr::Create( 2030 Context, /*This=*/0, ThisType, /*IsArrow=*/true, 2031 /*Op=*/SourceLocation(), SS.getWithLocInContext(Context), 2032 TemplateKWLoc, FirstQualifierInScope, NameInfo, TemplateArgs)); 2033 } 2034 } 2035 2036 // Don't diagnose an empty lookup for inline assmebly. 2037 if (IsInlineAsmIdentifier) 2038 return ExprError(); 2039 2040 CorrectionCandidateCallback DefaultValidator; 2041 if (DiagnoseEmptyLookup(S, SS, R, CCC ? *CCC : DefaultValidator)) 2042 return ExprError(); 2043 2044 assert(!R.empty() && 2045 "DiagnoseEmptyLookup returned false but added no results"); 2046 2047 // If we found an Objective-C instance variable, let 2048 // LookupInObjCMethod build the appropriate expression to 2049 // reference the ivar. 2050 if (ObjCIvarDecl *Ivar = R.getAsSingle<ObjCIvarDecl>()) { 2051 R.clear(); 2052 ExprResult E(LookupInObjCMethod(R, S, Ivar->getIdentifier())); 2053 // In a hopelessly buggy code, Objective-C instance variable 2054 // lookup fails and no expression will be built to reference it. 2055 if (!E.isInvalid() && !E.get()) 2056 return ExprError(); 2057 return E; 2058 } 2059 } 2060 } 2061 2062 // This is guaranteed from this point on. 2063 assert(!R.empty() || ADL); 2064 2065 // Check whether this might be a C++ implicit instance member access. 2066 // C++ [class.mfct.non-static]p3: 2067 // When an id-expression that is not part of a class member access 2068 // syntax and not used to form a pointer to member is used in the 2069 // body of a non-static member function of class X, if name lookup 2070 // resolves the name in the id-expression to a non-static non-type 2071 // member of some class C, the id-expression is transformed into a 2072 // class member access expression using (*this) as the 2073 // postfix-expression to the left of the . operator. 2074 // 2075 // But we don't actually need to do this for '&' operands if R 2076 // resolved to a function or overloaded function set, because the 2077 // expression is ill-formed if it actually works out to be a 2078 // non-static member function: 2079 // 2080 // C++ [expr.ref]p4: 2081 // Otherwise, if E1.E2 refers to a non-static member function. . . 2082 // [t]he expression can be used only as the left-hand operand of a 2083 // member function call. 2084 // 2085 // There are other safeguards against such uses, but it's important 2086 // to get this right here so that we don't end up making a 2087 // spuriously dependent expression if we're inside a dependent 2088 // instance method. 2089 if (!R.empty() && (*R.begin())->isCXXClassMember()) { 2090 bool MightBeImplicitMember; 2091 if (!IsAddressOfOperand) 2092 MightBeImplicitMember = true; 2093 else if (!SS.isEmpty()) 2094 MightBeImplicitMember = false; 2095 else if (R.isOverloadedResult()) 2096 MightBeImplicitMember = false; 2097 else if (R.isUnresolvableResult()) 2098 MightBeImplicitMember = true; 2099 else 2100 MightBeImplicitMember = isa<FieldDecl>(R.getFoundDecl()) || 2101 isa<IndirectFieldDecl>(R.getFoundDecl()) || 2102 isa<MSPropertyDecl>(R.getFoundDecl()); 2103 2104 if (MightBeImplicitMember) 2105 return BuildPossibleImplicitMemberExpr(SS, TemplateKWLoc, 2106 R, TemplateArgs); 2107 } 2108 2109 if (TemplateArgs || TemplateKWLoc.isValid()) { 2110 2111 // In C++1y, if this is a variable template id, then check it 2112 // in BuildTemplateIdExpr(). 2113 // The single lookup result must be a variable template declaration. 2114 if (Id.getKind() == UnqualifiedId::IK_TemplateId && Id.TemplateId && 2115 Id.TemplateId->Kind == TNK_Var_template) { 2116 assert(R.getAsSingle<VarTemplateDecl>() && 2117 "There should only be one declaration found."); 2118 } 2119 2120 return BuildTemplateIdExpr(SS, TemplateKWLoc, R, ADL, TemplateArgs); 2121 } 2122 2123 return BuildDeclarationNameExpr(SS, R, ADL); 2124 } 2125 2126 /// BuildQualifiedDeclarationNameExpr - Build a C++ qualified 2127 /// declaration name, generally during template instantiation. 2128 /// There's a large number of things which don't need to be done along 2129 /// this path. 2130 ExprResult 2131 Sema::BuildQualifiedDeclarationNameExpr(CXXScopeSpec &SS, 2132 const DeclarationNameInfo &NameInfo, 2133 bool IsAddressOfOperand) { 2134 DeclContext *DC = computeDeclContext(SS, false); 2135 if (!DC) 2136 return BuildDependentDeclRefExpr(SS, /*TemplateKWLoc=*/SourceLocation(), 2137 NameInfo, /*TemplateArgs=*/0); 2138 2139 if (RequireCompleteDeclContext(SS, DC)) 2140 return ExprError(); 2141 2142 LookupResult R(*this, NameInfo, LookupOrdinaryName); 2143 LookupQualifiedName(R, DC); 2144 2145 if (R.isAmbiguous()) 2146 return ExprError(); 2147 2148 if (R.getResultKind() == LookupResult::NotFoundInCurrentInstantiation) 2149 return BuildDependentDeclRefExpr(SS, /*TemplateKWLoc=*/SourceLocation(), 2150 NameInfo, /*TemplateArgs=*/0); 2151 2152 if (R.empty()) { 2153 Diag(NameInfo.getLoc(), diag::err_no_member) 2154 << NameInfo.getName() << DC << SS.getRange(); 2155 return ExprError(); 2156 } 2157 2158 // Defend against this resolving to an implicit member access. We usually 2159 // won't get here if this might be a legitimate a class member (we end up in 2160 // BuildMemberReferenceExpr instead), but this can be valid if we're forming 2161 // a pointer-to-member or in an unevaluated context in C++11. 2162 if (!R.empty() && (*R.begin())->isCXXClassMember() && !IsAddressOfOperand) 2163 return BuildPossibleImplicitMemberExpr(SS, 2164 /*TemplateKWLoc=*/SourceLocation(), 2165 R, /*TemplateArgs=*/0); 2166 2167 return BuildDeclarationNameExpr(SS, R, /* ADL */ false); 2168 } 2169 2170 /// LookupInObjCMethod - The parser has read a name in, and Sema has 2171 /// detected that we're currently inside an ObjC method. Perform some 2172 /// additional lookup. 2173 /// 2174 /// Ideally, most of this would be done by lookup, but there's 2175 /// actually quite a lot of extra work involved. 2176 /// 2177 /// Returns a null sentinel to indicate trivial success. 2178 ExprResult 2179 Sema::LookupInObjCMethod(LookupResult &Lookup, Scope *S, 2180 IdentifierInfo *II, bool AllowBuiltinCreation) { 2181 SourceLocation Loc = Lookup.getNameLoc(); 2182 ObjCMethodDecl *CurMethod = getCurMethodDecl(); 2183 2184 // Check for error condition which is already reported. 2185 if (!CurMethod) 2186 return ExprError(); 2187 2188 // There are two cases to handle here. 1) scoped lookup could have failed, 2189 // in which case we should look for an ivar. 2) scoped lookup could have 2190 // found a decl, but that decl is outside the current instance method (i.e. 2191 // a global variable). In these two cases, we do a lookup for an ivar with 2192 // this name, if the lookup sucedes, we replace it our current decl. 2193 2194 // If we're in a class method, we don't normally want to look for 2195 // ivars. But if we don't find anything else, and there's an 2196 // ivar, that's an error. 2197 bool IsClassMethod = CurMethod->isClassMethod(); 2198 2199 bool LookForIvars; 2200 if (Lookup.empty()) 2201 LookForIvars = true; 2202 else if (IsClassMethod) 2203 LookForIvars = false; 2204 else 2205 LookForIvars = (Lookup.isSingleResult() && 2206 Lookup.getFoundDecl()->isDefinedOutsideFunctionOrMethod()); 2207 ObjCInterfaceDecl *IFace = 0; 2208 if (LookForIvars) { 2209 IFace = CurMethod->getClassInterface(); 2210 ObjCInterfaceDecl *ClassDeclared; 2211 ObjCIvarDecl *IV = 0; 2212 if (IFace && (IV = IFace->lookupInstanceVariable(II, ClassDeclared))) { 2213 // Diagnose using an ivar in a class method. 2214 if (IsClassMethod) 2215 return ExprError(Diag(Loc, diag::error_ivar_use_in_class_method) 2216 << IV->getDeclName()); 2217 2218 // If we're referencing an invalid decl, just return this as a silent 2219 // error node. The error diagnostic was already emitted on the decl. 2220 if (IV->isInvalidDecl()) 2221 return ExprError(); 2222 2223 // Check if referencing a field with __attribute__((deprecated)). 2224 if (DiagnoseUseOfDecl(IV, Loc)) 2225 return ExprError(); 2226 2227 // Diagnose the use of an ivar outside of the declaring class. 2228 if (IV->getAccessControl() == ObjCIvarDecl::Private && 2229 !declaresSameEntity(ClassDeclared, IFace) && 2230 !getLangOpts().DebuggerSupport) 2231 Diag(Loc, diag::error_private_ivar_access) << IV->getDeclName(); 2232 2233 // FIXME: This should use a new expr for a direct reference, don't 2234 // turn this into Self->ivar, just return a BareIVarExpr or something. 2235 IdentifierInfo &II = Context.Idents.get("self"); 2236 UnqualifiedId SelfName; 2237 SelfName.setIdentifier(&II, SourceLocation()); 2238 SelfName.setKind(UnqualifiedId::IK_ImplicitSelfParam); 2239 CXXScopeSpec SelfScopeSpec; 2240 SourceLocation TemplateKWLoc; 2241 ExprResult SelfExpr = ActOnIdExpression(S, SelfScopeSpec, TemplateKWLoc, 2242 SelfName, false, false); 2243 if (SelfExpr.isInvalid()) 2244 return ExprError(); 2245 2246 SelfExpr = DefaultLvalueConversion(SelfExpr.take()); 2247 if (SelfExpr.isInvalid()) 2248 return ExprError(); 2249 2250 MarkAnyDeclReferenced(Loc, IV, true); 2251 2252 ObjCMethodFamily MF = CurMethod->getMethodFamily(); 2253 if (MF != OMF_init && MF != OMF_dealloc && MF != OMF_finalize && 2254 !IvarBacksCurrentMethodAccessor(IFace, CurMethod, IV)) 2255 Diag(Loc, diag::warn_direct_ivar_access) << IV->getDeclName(); 2256 2257 ObjCIvarRefExpr *Result = new (Context) ObjCIvarRefExpr(IV, IV->getType(), 2258 Loc, IV->getLocation(), 2259 SelfExpr.take(), 2260 true, true); 2261 2262 if (getLangOpts().ObjCAutoRefCount) { 2263 if (IV->getType().getObjCLifetime() == Qualifiers::OCL_Weak) { 2264 DiagnosticsEngine::Level Level = 2265 Diags.getDiagnosticLevel(diag::warn_arc_repeated_use_of_weak, Loc); 2266 if (Level != DiagnosticsEngine::Ignored) 2267 recordUseOfEvaluatedWeak(Result); 2268 } 2269 if (CurContext->isClosure()) 2270 Diag(Loc, diag::warn_implicitly_retains_self) 2271 << FixItHint::CreateInsertion(Loc, "self->"); 2272 } 2273 2274 return Owned(Result); 2275 } 2276 } else if (CurMethod->isInstanceMethod()) { 2277 // We should warn if a local variable hides an ivar. 2278 if (ObjCInterfaceDecl *IFace = CurMethod->getClassInterface()) { 2279 ObjCInterfaceDecl *ClassDeclared; 2280 if (ObjCIvarDecl *IV = IFace->lookupInstanceVariable(II, ClassDeclared)) { 2281 if (IV->getAccessControl() != ObjCIvarDecl::Private || 2282 declaresSameEntity(IFace, ClassDeclared)) 2283 Diag(Loc, diag::warn_ivar_use_hidden) << IV->getDeclName(); 2284 } 2285 } 2286 } else if (Lookup.isSingleResult() && 2287 Lookup.getFoundDecl()->isDefinedOutsideFunctionOrMethod()) { 2288 // If accessing a stand-alone ivar in a class method, this is an error. 2289 if (const ObjCIvarDecl *IV = dyn_cast<ObjCIvarDecl>(Lookup.getFoundDecl())) 2290 return ExprError(Diag(Loc, diag::error_ivar_use_in_class_method) 2291 << IV->getDeclName()); 2292 } 2293 2294 if (Lookup.empty() && II && AllowBuiltinCreation) { 2295 // FIXME. Consolidate this with similar code in LookupName. 2296 if (unsigned BuiltinID = II->getBuiltinID()) { 2297 if (!(getLangOpts().CPlusPlus && 2298 Context.BuiltinInfo.isPredefinedLibFunction(BuiltinID))) { 2299 NamedDecl *D = LazilyCreateBuiltin((IdentifierInfo *)II, BuiltinID, 2300 S, Lookup.isForRedeclaration(), 2301 Lookup.getNameLoc()); 2302 if (D) Lookup.addDecl(D); 2303 } 2304 } 2305 } 2306 // Sentinel value saying that we didn't do anything special. 2307 return Owned((Expr*) 0); 2308 } 2309 2310 /// \brief Cast a base object to a member's actual type. 2311 /// 2312 /// Logically this happens in three phases: 2313 /// 2314 /// * First we cast from the base type to the naming class. 2315 /// The naming class is the class into which we were looking 2316 /// when we found the member; it's the qualifier type if a 2317 /// qualifier was provided, and otherwise it's the base type. 2318 /// 2319 /// * Next we cast from the naming class to the declaring class. 2320 /// If the member we found was brought into a class's scope by 2321 /// a using declaration, this is that class; otherwise it's 2322 /// the class declaring the member. 2323 /// 2324 /// * Finally we cast from the declaring class to the "true" 2325 /// declaring class of the member. This conversion does not 2326 /// obey access control. 2327 ExprResult 2328 Sema::PerformObjectMemberConversion(Expr *From, 2329 NestedNameSpecifier *Qualifier, 2330 NamedDecl *FoundDecl, 2331 NamedDecl *Member) { 2332 CXXRecordDecl *RD = dyn_cast<CXXRecordDecl>(Member->getDeclContext()); 2333 if (!RD) 2334 return Owned(From); 2335 2336 QualType DestRecordType; 2337 QualType DestType; 2338 QualType FromRecordType; 2339 QualType FromType = From->getType(); 2340 bool PointerConversions = false; 2341 if (isa<FieldDecl>(Member)) { 2342 DestRecordType = Context.getCanonicalType(Context.getTypeDeclType(RD)); 2343 2344 if (FromType->getAs<PointerType>()) { 2345 DestType = Context.getPointerType(DestRecordType); 2346 FromRecordType = FromType->getPointeeType(); 2347 PointerConversions = true; 2348 } else { 2349 DestType = DestRecordType; 2350 FromRecordType = FromType; 2351 } 2352 } else if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(Member)) { 2353 if (Method->isStatic()) 2354 return Owned(From); 2355 2356 DestType = Method->getThisType(Context); 2357 DestRecordType = DestType->getPointeeType(); 2358 2359 if (FromType->getAs<PointerType>()) { 2360 FromRecordType = FromType->getPointeeType(); 2361 PointerConversions = true; 2362 } else { 2363 FromRecordType = FromType; 2364 DestType = DestRecordType; 2365 } 2366 } else { 2367 // No conversion necessary. 2368 return Owned(From); 2369 } 2370 2371 if (DestType->isDependentType() || FromType->isDependentType()) 2372 return Owned(From); 2373 2374 // If the unqualified types are the same, no conversion is necessary. 2375 if (Context.hasSameUnqualifiedType(FromRecordType, DestRecordType)) 2376 return Owned(From); 2377 2378 SourceRange FromRange = From->getSourceRange(); 2379 SourceLocation FromLoc = FromRange.getBegin(); 2380 2381 ExprValueKind VK = From->getValueKind(); 2382 2383 // C++ [class.member.lookup]p8: 2384 // [...] Ambiguities can often be resolved by qualifying a name with its 2385 // class name. 2386 // 2387 // If the member was a qualified name and the qualified referred to a 2388 // specific base subobject type, we'll cast to that intermediate type 2389 // first and then to the object in which the member is declared. That allows 2390 // one to resolve ambiguities in, e.g., a diamond-shaped hierarchy such as: 2391 // 2392 // class Base { public: int x; }; 2393 // class Derived1 : public Base { }; 2394 // class Derived2 : public Base { }; 2395 // class VeryDerived : public Derived1, public Derived2 { void f(); }; 2396 // 2397 // void VeryDerived::f() { 2398 // x = 17; // error: ambiguous base subobjects 2399 // Derived1::x = 17; // okay, pick the Base subobject of Derived1 2400 // } 2401 if (Qualifier && Qualifier->getAsType()) { 2402 QualType QType = QualType(Qualifier->getAsType(), 0); 2403 assert(QType->isRecordType() && "lookup done with non-record type"); 2404 2405 QualType QRecordType = QualType(QType->getAs<RecordType>(), 0); 2406 2407 // In C++98, the qualifier type doesn't actually have to be a base 2408 // type of the object type, in which case we just ignore it. 2409 // Otherwise build the appropriate casts. 2410 if (IsDerivedFrom(FromRecordType, QRecordType)) { 2411 CXXCastPath BasePath; 2412 if (CheckDerivedToBaseConversion(FromRecordType, QRecordType, 2413 FromLoc, FromRange, &BasePath)) 2414 return ExprError(); 2415 2416 if (PointerConversions) 2417 QType = Context.getPointerType(QType); 2418 From = ImpCastExprToType(From, QType, CK_UncheckedDerivedToBase, 2419 VK, &BasePath).take(); 2420 2421 FromType = QType; 2422 FromRecordType = QRecordType; 2423 2424 // If the qualifier type was the same as the destination type, 2425 // we're done. 2426 if (Context.hasSameUnqualifiedType(FromRecordType, DestRecordType)) 2427 return Owned(From); 2428 } 2429 } 2430 2431 bool IgnoreAccess = false; 2432 2433 // If we actually found the member through a using declaration, cast 2434 // down to the using declaration's type. 2435 // 2436 // Pointer equality is fine here because only one declaration of a 2437 // class ever has member declarations. 2438 if (FoundDecl->getDeclContext() != Member->getDeclContext()) { 2439 assert(isa<UsingShadowDecl>(FoundDecl)); 2440 QualType URecordType = Context.getTypeDeclType( 2441 cast<CXXRecordDecl>(FoundDecl->getDeclContext())); 2442 2443 // We only need to do this if the naming-class to declaring-class 2444 // conversion is non-trivial. 2445 if (!Context.hasSameUnqualifiedType(FromRecordType, URecordType)) { 2446 assert(IsDerivedFrom(FromRecordType, URecordType)); 2447 CXXCastPath BasePath; 2448 if (CheckDerivedToBaseConversion(FromRecordType, URecordType, 2449 FromLoc, FromRange, &BasePath)) 2450 return ExprError(); 2451 2452 QualType UType = URecordType; 2453 if (PointerConversions) 2454 UType = Context.getPointerType(UType); 2455 From = ImpCastExprToType(From, UType, CK_UncheckedDerivedToBase, 2456 VK, &BasePath).take(); 2457 FromType = UType; 2458 FromRecordType = URecordType; 2459 } 2460 2461 // We don't do access control for the conversion from the 2462 // declaring class to the true declaring class. 2463 IgnoreAccess = true; 2464 } 2465 2466 CXXCastPath BasePath; 2467 if (CheckDerivedToBaseConversion(FromRecordType, DestRecordType, 2468 FromLoc, FromRange, &BasePath, 2469 IgnoreAccess)) 2470 return ExprError(); 2471 2472 return ImpCastExprToType(From, DestType, CK_UncheckedDerivedToBase, 2473 VK, &BasePath); 2474 } 2475 2476 bool Sema::UseArgumentDependentLookup(const CXXScopeSpec &SS, 2477 const LookupResult &R, 2478 bool HasTrailingLParen) { 2479 // Only when used directly as the postfix-expression of a call. 2480 if (!HasTrailingLParen) 2481 return false; 2482 2483 // Never if a scope specifier was provided. 2484 if (SS.isSet()) 2485 return false; 2486 2487 // Only in C++ or ObjC++. 2488 if (!getLangOpts().CPlusPlus) 2489 return false; 2490 2491 // Turn off ADL when we find certain kinds of declarations during 2492 // normal lookup: 2493 for (LookupResult::iterator I = R.begin(), E = R.end(); I != E; ++I) { 2494 NamedDecl *D = *I; 2495 2496 // C++0x [basic.lookup.argdep]p3: 2497 // -- a declaration of a class member 2498 // Since using decls preserve this property, we check this on the 2499 // original decl. 2500 if (D->isCXXClassMember()) 2501 return false; 2502 2503 // C++0x [basic.lookup.argdep]p3: 2504 // -- a block-scope function declaration that is not a 2505 // using-declaration 2506 // NOTE: we also trigger this for function templates (in fact, we 2507 // don't check the decl type at all, since all other decl types 2508 // turn off ADL anyway). 2509 if (isa<UsingShadowDecl>(D)) 2510 D = cast<UsingShadowDecl>(D)->getTargetDecl(); 2511 else if (D->getLexicalDeclContext()->isFunctionOrMethod()) 2512 return false; 2513 2514 // C++0x [basic.lookup.argdep]p3: 2515 // -- a declaration that is neither a function or a function 2516 // template 2517 // And also for builtin functions. 2518 if (isa<FunctionDecl>(D)) { 2519 FunctionDecl *FDecl = cast<FunctionDecl>(D); 2520 2521 // But also builtin functions. 2522 if (FDecl->getBuiltinID() && FDecl->isImplicit()) 2523 return false; 2524 } else if (!isa<FunctionTemplateDecl>(D)) 2525 return false; 2526 } 2527 2528 return true; 2529 } 2530 2531 2532 /// Diagnoses obvious problems with the use of the given declaration 2533 /// as an expression. This is only actually called for lookups that 2534 /// were not overloaded, and it doesn't promise that the declaration 2535 /// will in fact be used. 2536 static bool CheckDeclInExpr(Sema &S, SourceLocation Loc, NamedDecl *D) { 2537 if (isa<TypedefNameDecl>(D)) { 2538 S.Diag(Loc, diag::err_unexpected_typedef) << D->getDeclName(); 2539 return true; 2540 } 2541 2542 if (isa<ObjCInterfaceDecl>(D)) { 2543 S.Diag(Loc, diag::err_unexpected_interface) << D->getDeclName(); 2544 return true; 2545 } 2546 2547 if (isa<NamespaceDecl>(D)) { 2548 S.Diag(Loc, diag::err_unexpected_namespace) << D->getDeclName(); 2549 return true; 2550 } 2551 2552 return false; 2553 } 2554 2555 ExprResult 2556 Sema::BuildDeclarationNameExpr(const CXXScopeSpec &SS, 2557 LookupResult &R, 2558 bool NeedsADL) { 2559 // If this is a single, fully-resolved result and we don't need ADL, 2560 // just build an ordinary singleton decl ref. 2561 if (!NeedsADL && R.isSingleResult() && !R.getAsSingle<FunctionTemplateDecl>()) 2562 return BuildDeclarationNameExpr(SS, R.getLookupNameInfo(), R.getFoundDecl(), 2563 R.getRepresentativeDecl()); 2564 2565 // We only need to check the declaration if there's exactly one 2566 // result, because in the overloaded case the results can only be 2567 // functions and function templates. 2568 if (R.isSingleResult() && 2569 CheckDeclInExpr(*this, R.getNameLoc(), R.getFoundDecl())) 2570 return ExprError(); 2571 2572 // Otherwise, just build an unresolved lookup expression. Suppress 2573 // any lookup-related diagnostics; we'll hash these out later, when 2574 // we've picked a target. 2575 R.suppressDiagnostics(); 2576 2577 UnresolvedLookupExpr *ULE 2578 = UnresolvedLookupExpr::Create(Context, R.getNamingClass(), 2579 SS.getWithLocInContext(Context), 2580 R.getLookupNameInfo(), 2581 NeedsADL, R.isOverloadedResult(), 2582 R.begin(), R.end()); 2583 2584 return Owned(ULE); 2585 } 2586 2587 /// \brief Complete semantic analysis for a reference to the given declaration. 2588 ExprResult Sema::BuildDeclarationNameExpr( 2589 const CXXScopeSpec &SS, const DeclarationNameInfo &NameInfo, NamedDecl *D, 2590 NamedDecl *FoundD, const TemplateArgumentListInfo *TemplateArgs) { 2591 assert(D && "Cannot refer to a NULL declaration"); 2592 assert(!isa<FunctionTemplateDecl>(D) && 2593 "Cannot refer unambiguously to a function template"); 2594 2595 SourceLocation Loc = NameInfo.getLoc(); 2596 if (CheckDeclInExpr(*this, Loc, D)) 2597 return ExprError(); 2598 2599 if (TemplateDecl *Template = dyn_cast<TemplateDecl>(D)) { 2600 // Specifically diagnose references to class templates that are missing 2601 // a template argument list. 2602 Diag(Loc, diag::err_template_decl_ref) << (isa<VarTemplateDecl>(D) ? 1 : 0) 2603 << Template << SS.getRange(); 2604 Diag(Template->getLocation(), diag::note_template_decl_here); 2605 return ExprError(); 2606 } 2607 2608 // Make sure that we're referring to a value. 2609 ValueDecl *VD = dyn_cast<ValueDecl>(D); 2610 if (!VD) { 2611 Diag(Loc, diag::err_ref_non_value) 2612 << D << SS.getRange(); 2613 Diag(D->getLocation(), diag::note_declared_at); 2614 return ExprError(); 2615 } 2616 2617 // Check whether this declaration can be used. Note that we suppress 2618 // this check when we're going to perform argument-dependent lookup 2619 // on this function name, because this might not be the function 2620 // that overload resolution actually selects. 2621 if (DiagnoseUseOfDecl(VD, Loc)) 2622 return ExprError(); 2623 2624 // Only create DeclRefExpr's for valid Decl's. 2625 if (VD->isInvalidDecl()) 2626 return ExprError(); 2627 2628 // Handle members of anonymous structs and unions. If we got here, 2629 // and the reference is to a class member indirect field, then this 2630 // must be the subject of a pointer-to-member expression. 2631 if (IndirectFieldDecl *indirectField = dyn_cast<IndirectFieldDecl>(VD)) 2632 if (!indirectField->isCXXClassMember()) 2633 return BuildAnonymousStructUnionMemberReference(SS, NameInfo.getLoc(), 2634 indirectField); 2635 2636 { 2637 QualType type = VD->getType(); 2638 ExprValueKind valueKind = VK_RValue; 2639 2640 switch (D->getKind()) { 2641 // Ignore all the non-ValueDecl kinds. 2642 #define ABSTRACT_DECL(kind) 2643 #define VALUE(type, base) 2644 #define DECL(type, base) \ 2645 case Decl::type: 2646 #include "clang/AST/DeclNodes.inc" 2647 llvm_unreachable("invalid value decl kind"); 2648 2649 // These shouldn't make it here. 2650 case Decl::ObjCAtDefsField: 2651 case Decl::ObjCIvar: 2652 llvm_unreachable("forming non-member reference to ivar?"); 2653 2654 // Enum constants are always r-values and never references. 2655 // Unresolved using declarations are dependent. 2656 case Decl::EnumConstant: 2657 case Decl::UnresolvedUsingValue: 2658 valueKind = VK_RValue; 2659 break; 2660 2661 // Fields and indirect fields that got here must be for 2662 // pointer-to-member expressions; we just call them l-values for 2663 // internal consistency, because this subexpression doesn't really 2664 // exist in the high-level semantics. 2665 case Decl::Field: 2666 case Decl::IndirectField: 2667 assert(getLangOpts().CPlusPlus && 2668 "building reference to field in C?"); 2669 2670 // These can't have reference type in well-formed programs, but 2671 // for internal consistency we do this anyway. 2672 type = type.getNonReferenceType(); 2673 valueKind = VK_LValue; 2674 break; 2675 2676 // Non-type template parameters are either l-values or r-values 2677 // depending on the type. 2678 case Decl::NonTypeTemplateParm: { 2679 if (const ReferenceType *reftype = type->getAs<ReferenceType>()) { 2680 type = reftype->getPointeeType(); 2681 valueKind = VK_LValue; // even if the parameter is an r-value reference 2682 break; 2683 } 2684 2685 // For non-references, we need to strip qualifiers just in case 2686 // the template parameter was declared as 'const int' or whatever. 2687 valueKind = VK_RValue; 2688 type = type.getUnqualifiedType(); 2689 break; 2690 } 2691 2692 case Decl::Var: 2693 case Decl::VarTemplateSpecialization: 2694 case Decl::VarTemplatePartialSpecialization: 2695 // In C, "extern void blah;" is valid and is an r-value. 2696 if (!getLangOpts().CPlusPlus && 2697 !type.hasQualifiers() && 2698 type->isVoidType()) { 2699 valueKind = VK_RValue; 2700 break; 2701 } 2702 // fallthrough 2703 2704 case Decl::ImplicitParam: 2705 case Decl::ParmVar: { 2706 // These are always l-values. 2707 valueKind = VK_LValue; 2708 type = type.getNonReferenceType(); 2709 2710 // FIXME: Does the addition of const really only apply in 2711 // potentially-evaluated contexts? Since the variable isn't actually 2712 // captured in an unevaluated context, it seems that the answer is no. 2713 if (!isUnevaluatedContext()) { 2714 QualType CapturedType = getCapturedDeclRefType(cast<VarDecl>(VD), Loc); 2715 if (!CapturedType.isNull()) 2716 type = CapturedType; 2717 } 2718 2719 break; 2720 } 2721 2722 case Decl::Function: { 2723 if (unsigned BID = cast<FunctionDecl>(VD)->getBuiltinID()) { 2724 if (!Context.BuiltinInfo.isPredefinedLibFunction(BID)) { 2725 type = Context.BuiltinFnTy; 2726 valueKind = VK_RValue; 2727 break; 2728 } 2729 } 2730 2731 const FunctionType *fty = type->castAs<FunctionType>(); 2732 2733 // If we're referring to a function with an __unknown_anytype 2734 // result type, make the entire expression __unknown_anytype. 2735 if (fty->getResultType() == Context.UnknownAnyTy) { 2736 type = Context.UnknownAnyTy; 2737 valueKind = VK_RValue; 2738 break; 2739 } 2740 2741 // Functions are l-values in C++. 2742 if (getLangOpts().CPlusPlus) { 2743 valueKind = VK_LValue; 2744 break; 2745 } 2746 2747 // C99 DR 316 says that, if a function type comes from a 2748 // function definition (without a prototype), that type is only 2749 // used for checking compatibility. Therefore, when referencing 2750 // the function, we pretend that we don't have the full function 2751 // type. 2752 if (!cast<FunctionDecl>(VD)->hasPrototype() && 2753 isa<FunctionProtoType>(fty)) 2754 type = Context.getFunctionNoProtoType(fty->getResultType(), 2755 fty->getExtInfo()); 2756 2757 // Functions are r-values in C. 2758 valueKind = VK_RValue; 2759 break; 2760 } 2761 2762 case Decl::MSProperty: 2763 valueKind = VK_LValue; 2764 break; 2765 2766 case Decl::CXXMethod: 2767 // If we're referring to a method with an __unknown_anytype 2768 // result type, make the entire expression __unknown_anytype. 2769 // This should only be possible with a type written directly. 2770 if (const FunctionProtoType *proto 2771 = dyn_cast<FunctionProtoType>(VD->getType())) 2772 if (proto->getResultType() == Context.UnknownAnyTy) { 2773 type = Context.UnknownAnyTy; 2774 valueKind = VK_RValue; 2775 break; 2776 } 2777 2778 // C++ methods are l-values if static, r-values if non-static. 2779 if (cast<CXXMethodDecl>(VD)->isStatic()) { 2780 valueKind = VK_LValue; 2781 break; 2782 } 2783 // fallthrough 2784 2785 case Decl::CXXConversion: 2786 case Decl::CXXDestructor: 2787 case Decl::CXXConstructor: 2788 valueKind = VK_RValue; 2789 break; 2790 } 2791 2792 return BuildDeclRefExpr(VD, type, valueKind, NameInfo, &SS, FoundD, 2793 TemplateArgs); 2794 } 2795 } 2796 2797 ExprResult Sema::BuildPredefinedExpr(SourceLocation Loc, 2798 PredefinedExpr::IdentType IT) { 2799 // Pick the current block, lambda, captured statement or function. 2800 Decl *currentDecl = 0; 2801 if (const BlockScopeInfo *BSI = getCurBlock()) 2802 currentDecl = BSI->TheDecl; 2803 else if (const LambdaScopeInfo *LSI = getCurLambda()) 2804 currentDecl = LSI->CallOperator; 2805 else if (const CapturedRegionScopeInfo *CSI = getCurCapturedRegion()) 2806 currentDecl = CSI->TheCapturedDecl; 2807 else 2808 currentDecl = getCurFunctionOrMethodDecl(); 2809 2810 if (!currentDecl) { 2811 Diag(Loc, diag::ext_predef_outside_function); 2812 currentDecl = Context.getTranslationUnitDecl(); 2813 } 2814 2815 QualType ResTy; 2816 if (cast<DeclContext>(currentDecl)->isDependentContext()) 2817 ResTy = Context.DependentTy; 2818 else { 2819 // Pre-defined identifiers are of type char[x], where x is the length of 2820 // the string. 2821 unsigned Length = PredefinedExpr::ComputeName(IT, currentDecl).length(); 2822 2823 llvm::APInt LengthI(32, Length + 1); 2824 if (IT == PredefinedExpr::LFunction) 2825 ResTy = Context.WideCharTy.withConst(); 2826 else 2827 ResTy = Context.CharTy.withConst(); 2828 ResTy = Context.getConstantArrayType(ResTy, LengthI, ArrayType::Normal, 0); 2829 } 2830 2831 return Owned(new (Context) PredefinedExpr(Loc, ResTy, IT)); 2832 } 2833 2834 ExprResult Sema::ActOnPredefinedExpr(SourceLocation Loc, tok::TokenKind Kind) { 2835 PredefinedExpr::IdentType IT; 2836 2837 switch (Kind) { 2838 default: llvm_unreachable("Unknown simple primary expr!"); 2839 case tok::kw___func__: IT = PredefinedExpr::Func; break; // [C99 6.4.2.2] 2840 case tok::kw___FUNCTION__: IT = PredefinedExpr::Function; break; 2841 case tok::kw___FUNCDNAME__: IT = PredefinedExpr::FuncDName; break; // [MS] 2842 case tok::kw_L__FUNCTION__: IT = PredefinedExpr::LFunction; break; 2843 case tok::kw___PRETTY_FUNCTION__: IT = PredefinedExpr::PrettyFunction; break; 2844 } 2845 2846 return BuildPredefinedExpr(Loc, IT); 2847 } 2848 2849 ExprResult Sema::ActOnCharacterConstant(const Token &Tok, Scope *UDLScope) { 2850 SmallString<16> CharBuffer; 2851 bool Invalid = false; 2852 StringRef ThisTok = PP.getSpelling(Tok, CharBuffer, &Invalid); 2853 if (Invalid) 2854 return ExprError(); 2855 2856 CharLiteralParser Literal(ThisTok.begin(), ThisTok.end(), Tok.getLocation(), 2857 PP, Tok.getKind()); 2858 if (Literal.hadError()) 2859 return ExprError(); 2860 2861 QualType Ty; 2862 if (Literal.isWide()) 2863 Ty = Context.WideCharTy; // L'x' -> wchar_t in C and C++. 2864 else if (Literal.isUTF16()) 2865 Ty = Context.Char16Ty; // u'x' -> char16_t in C11 and C++11. 2866 else if (Literal.isUTF32()) 2867 Ty = Context.Char32Ty; // U'x' -> char32_t in C11 and C++11. 2868 else if (!getLangOpts().CPlusPlus || Literal.isMultiChar()) 2869 Ty = Context.IntTy; // 'x' -> int in C, 'wxyz' -> int in C++. 2870 else 2871 Ty = Context.CharTy; // 'x' -> char in C++ 2872 2873 CharacterLiteral::CharacterKind Kind = CharacterLiteral::Ascii; 2874 if (Literal.isWide()) 2875 Kind = CharacterLiteral::Wide; 2876 else if (Literal.isUTF16()) 2877 Kind = CharacterLiteral::UTF16; 2878 else if (Literal.isUTF32()) 2879 Kind = CharacterLiteral::UTF32; 2880 2881 Expr *Lit = new (Context) CharacterLiteral(Literal.getValue(), Kind, Ty, 2882 Tok.getLocation()); 2883 2884 if (Literal.getUDSuffix().empty()) 2885 return Owned(Lit); 2886 2887 // We're building a user-defined literal. 2888 IdentifierInfo *UDSuffix = &Context.Idents.get(Literal.getUDSuffix()); 2889 SourceLocation UDSuffixLoc = 2890 getUDSuffixLoc(*this, Tok.getLocation(), Literal.getUDSuffixOffset()); 2891 2892 // Make sure we're allowed user-defined literals here. 2893 if (!UDLScope) 2894 return ExprError(Diag(UDSuffixLoc, diag::err_invalid_character_udl)); 2895 2896 // C++11 [lex.ext]p6: The literal L is treated as a call of the form 2897 // operator "" X (ch) 2898 return BuildCookedLiteralOperatorCall(*this, UDLScope, UDSuffix, UDSuffixLoc, 2899 Lit, Tok.getLocation()); 2900 } 2901 2902 ExprResult Sema::ActOnIntegerConstant(SourceLocation Loc, uint64_t Val) { 2903 unsigned IntSize = Context.getTargetInfo().getIntWidth(); 2904 return Owned(IntegerLiteral::Create(Context, llvm::APInt(IntSize, Val), 2905 Context.IntTy, Loc)); 2906 } 2907 2908 static Expr *BuildFloatingLiteral(Sema &S, NumericLiteralParser &Literal, 2909 QualType Ty, SourceLocation Loc) { 2910 const llvm::fltSemantics &Format = S.Context.getFloatTypeSemantics(Ty); 2911 2912 using llvm::APFloat; 2913 APFloat Val(Format); 2914 2915 APFloat::opStatus result = Literal.GetFloatValue(Val); 2916 2917 // Overflow is always an error, but underflow is only an error if 2918 // we underflowed to zero (APFloat reports denormals as underflow). 2919 if ((result & APFloat::opOverflow) || 2920 ((result & APFloat::opUnderflow) && Val.isZero())) { 2921 unsigned diagnostic; 2922 SmallString<20> buffer; 2923 if (result & APFloat::opOverflow) { 2924 diagnostic = diag::warn_float_overflow; 2925 APFloat::getLargest(Format).toString(buffer); 2926 } else { 2927 diagnostic = diag::warn_float_underflow; 2928 APFloat::getSmallest(Format).toString(buffer); 2929 } 2930 2931 S.Diag(Loc, diagnostic) 2932 << Ty 2933 << StringRef(buffer.data(), buffer.size()); 2934 } 2935 2936 bool isExact = (result == APFloat::opOK); 2937 return FloatingLiteral::Create(S.Context, Val, isExact, Ty, Loc); 2938 } 2939 2940 ExprResult Sema::ActOnNumericConstant(const Token &Tok, Scope *UDLScope) { 2941 // Fast path for a single digit (which is quite common). A single digit 2942 // cannot have a trigraph, escaped newline, radix prefix, or suffix. 2943 if (Tok.getLength() == 1) { 2944 const char Val = PP.getSpellingOfSingleCharacterNumericConstant(Tok); 2945 return ActOnIntegerConstant(Tok.getLocation(), Val-'0'); 2946 } 2947 2948 SmallString<128> SpellingBuffer; 2949 // NumericLiteralParser wants to overread by one character. Add padding to 2950 // the buffer in case the token is copied to the buffer. If getSpelling() 2951 // returns a StringRef to the memory buffer, it should have a null char at 2952 // the EOF, so it is also safe. 2953 SpellingBuffer.resize(Tok.getLength() + 1); 2954 2955 // Get the spelling of the token, which eliminates trigraphs, etc. 2956 bool Invalid = false; 2957 StringRef TokSpelling = PP.getSpelling(Tok, SpellingBuffer, &Invalid); 2958 if (Invalid) 2959 return ExprError(); 2960 2961 NumericLiteralParser Literal(TokSpelling, Tok.getLocation(), PP); 2962 if (Literal.hadError) 2963 return ExprError(); 2964 2965 if (Literal.hasUDSuffix()) { 2966 // We're building a user-defined literal. 2967 IdentifierInfo *UDSuffix = &Context.Idents.get(Literal.getUDSuffix()); 2968 SourceLocation UDSuffixLoc = 2969 getUDSuffixLoc(*this, Tok.getLocation(), Literal.getUDSuffixOffset()); 2970 2971 // Make sure we're allowed user-defined literals here. 2972 if (!UDLScope) 2973 return ExprError(Diag(UDSuffixLoc, diag::err_invalid_numeric_udl)); 2974 2975 QualType CookedTy; 2976 if (Literal.isFloatingLiteral()) { 2977 // C++11 [lex.ext]p4: If S contains a literal operator with parameter type 2978 // long double, the literal is treated as a call of the form 2979 // operator "" X (f L) 2980 CookedTy = Context.LongDoubleTy; 2981 } else { 2982 // C++11 [lex.ext]p3: If S contains a literal operator with parameter type 2983 // unsigned long long, the literal is treated as a call of the form 2984 // operator "" X (n ULL) 2985 CookedTy = Context.UnsignedLongLongTy; 2986 } 2987 2988 DeclarationName OpName = 2989 Context.DeclarationNames.getCXXLiteralOperatorName(UDSuffix); 2990 DeclarationNameInfo OpNameInfo(OpName, UDSuffixLoc); 2991 OpNameInfo.setCXXLiteralOperatorNameLoc(UDSuffixLoc); 2992 2993 SourceLocation TokLoc = Tok.getLocation(); 2994 2995 // Perform literal operator lookup to determine if we're building a raw 2996 // literal or a cooked one. 2997 LookupResult R(*this, OpName, UDSuffixLoc, LookupOrdinaryName); 2998 switch (LookupLiteralOperator(UDLScope, R, CookedTy, 2999 /*AllowRaw*/true, /*AllowTemplate*/true, 3000 /*AllowStringTemplate*/false)) { 3001 case LOLR_Error: 3002 return ExprError(); 3003 3004 case LOLR_Cooked: { 3005 Expr *Lit; 3006 if (Literal.isFloatingLiteral()) { 3007 Lit = BuildFloatingLiteral(*this, Literal, CookedTy, Tok.getLocation()); 3008 } else { 3009 llvm::APInt ResultVal(Context.getTargetInfo().getLongLongWidth(), 0); 3010 if (Literal.GetIntegerValue(ResultVal)) 3011 Diag(Tok.getLocation(), diag::err_integer_too_large); 3012 Lit = IntegerLiteral::Create(Context, ResultVal, CookedTy, 3013 Tok.getLocation()); 3014 } 3015 return BuildLiteralOperatorCall(R, OpNameInfo, Lit, TokLoc); 3016 } 3017 3018 case LOLR_Raw: { 3019 // C++11 [lit.ext]p3, p4: If S contains a raw literal operator, the 3020 // literal is treated as a call of the form 3021 // operator "" X ("n") 3022 unsigned Length = Literal.getUDSuffixOffset(); 3023 QualType StrTy = Context.getConstantArrayType( 3024 Context.CharTy.withConst(), llvm::APInt(32, Length + 1), 3025 ArrayType::Normal, 0); 3026 Expr *Lit = StringLiteral::Create( 3027 Context, StringRef(TokSpelling.data(), Length), StringLiteral::Ascii, 3028 /*Pascal*/false, StrTy, &TokLoc, 1); 3029 return BuildLiteralOperatorCall(R, OpNameInfo, Lit, TokLoc); 3030 } 3031 3032 case LOLR_Template: { 3033 // C++11 [lit.ext]p3, p4: Otherwise (S contains a literal operator 3034 // template), L is treated as a call fo the form 3035 // operator "" X <'c1', 'c2', ... 'ck'>() 3036 // where n is the source character sequence c1 c2 ... ck. 3037 TemplateArgumentListInfo ExplicitArgs; 3038 unsigned CharBits = Context.getIntWidth(Context.CharTy); 3039 bool CharIsUnsigned = Context.CharTy->isUnsignedIntegerType(); 3040 llvm::APSInt Value(CharBits, CharIsUnsigned); 3041 for (unsigned I = 0, N = Literal.getUDSuffixOffset(); I != N; ++I) { 3042 Value = TokSpelling[I]; 3043 TemplateArgument Arg(Context, Value, Context.CharTy); 3044 TemplateArgumentLocInfo ArgInfo; 3045 ExplicitArgs.addArgument(TemplateArgumentLoc(Arg, ArgInfo)); 3046 } 3047 return BuildLiteralOperatorCall(R, OpNameInfo, None, TokLoc, 3048 &ExplicitArgs); 3049 } 3050 case LOLR_StringTemplate: 3051 llvm_unreachable("unexpected literal operator lookup result"); 3052 } 3053 } 3054 3055 Expr *Res; 3056 3057 if (Literal.isFloatingLiteral()) { 3058 QualType Ty; 3059 if (Literal.isFloat) 3060 Ty = Context.FloatTy; 3061 else if (!Literal.isLong) 3062 Ty = Context.DoubleTy; 3063 else 3064 Ty = Context.LongDoubleTy; 3065 3066 Res = BuildFloatingLiteral(*this, Literal, Ty, Tok.getLocation()); 3067 3068 if (Ty == Context.DoubleTy) { 3069 if (getLangOpts().SinglePrecisionConstants) { 3070 Res = ImpCastExprToType(Res, Context.FloatTy, CK_FloatingCast).take(); 3071 } else if (getLangOpts().OpenCL && !getOpenCLOptions().cl_khr_fp64) { 3072 Diag(Tok.getLocation(), diag::warn_double_const_requires_fp64); 3073 Res = ImpCastExprToType(Res, Context.FloatTy, CK_FloatingCast).take(); 3074 } 3075 } 3076 } else if (!Literal.isIntegerLiteral()) { 3077 return ExprError(); 3078 } else { 3079 QualType Ty; 3080 3081 // 'long long' is a C99 or C++11 feature. 3082 if (!getLangOpts().C99 && Literal.isLongLong) { 3083 if (getLangOpts().CPlusPlus) 3084 Diag(Tok.getLocation(), 3085 getLangOpts().CPlusPlus11 ? 3086 diag::warn_cxx98_compat_longlong : diag::ext_cxx11_longlong); 3087 else 3088 Diag(Tok.getLocation(), diag::ext_c99_longlong); 3089 } 3090 3091 // Get the value in the widest-possible width. 3092 unsigned MaxWidth = Context.getTargetInfo().getIntMaxTWidth(); 3093 // The microsoft literal suffix extensions support 128-bit literals, which 3094 // may be wider than [u]intmax_t. 3095 // FIXME: Actually, they don't. We seem to have accidentally invented the 3096 // i128 suffix. 3097 if (Literal.isMicrosoftInteger && MaxWidth < 128 && 3098 PP.getTargetInfo().hasInt128Type()) 3099 MaxWidth = 128; 3100 llvm::APInt ResultVal(MaxWidth, 0); 3101 3102 if (Literal.GetIntegerValue(ResultVal)) { 3103 // If this value didn't fit into uintmax_t, error and force to ull. 3104 Diag(Tok.getLocation(), diag::err_integer_too_large); 3105 Ty = Context.UnsignedLongLongTy; 3106 assert(Context.getTypeSize(Ty) == ResultVal.getBitWidth() && 3107 "long long is not intmax_t?"); 3108 } else { 3109 // If this value fits into a ULL, try to figure out what else it fits into 3110 // according to the rules of C99 6.4.4.1p5. 3111 3112 // Octal, Hexadecimal, and integers with a U suffix are allowed to 3113 // be an unsigned int. 3114 bool AllowUnsigned = Literal.isUnsigned || Literal.getRadix() != 10; 3115 3116 // Check from smallest to largest, picking the smallest type we can. 3117 unsigned Width = 0; 3118 if (!Literal.isLong && !Literal.isLongLong) { 3119 // Are int/unsigned possibilities? 3120 unsigned IntSize = Context.getTargetInfo().getIntWidth(); 3121 3122 // Does it fit in a unsigned int? 3123 if (ResultVal.isIntN(IntSize)) { 3124 // Does it fit in a signed int? 3125 if (!Literal.isUnsigned && ResultVal[IntSize-1] == 0) 3126 Ty = Context.IntTy; 3127 else if (AllowUnsigned) 3128 Ty = Context.UnsignedIntTy; 3129 Width = IntSize; 3130 } 3131 } 3132 3133 // Are long/unsigned long possibilities? 3134 if (Ty.isNull() && !Literal.isLongLong) { 3135 unsigned LongSize = Context.getTargetInfo().getLongWidth(); 3136 3137 // Does it fit in a unsigned long? 3138 if (ResultVal.isIntN(LongSize)) { 3139 // Does it fit in a signed long? 3140 if (!Literal.isUnsigned && ResultVal[LongSize-1] == 0) 3141 Ty = Context.LongTy; 3142 else if (AllowUnsigned) 3143 Ty = Context.UnsignedLongTy; 3144 Width = LongSize; 3145 } 3146 } 3147 3148 // Check long long if needed. 3149 if (Ty.isNull()) { 3150 unsigned LongLongSize = Context.getTargetInfo().getLongLongWidth(); 3151 3152 // Does it fit in a unsigned long long? 3153 if (ResultVal.isIntN(LongLongSize)) { 3154 // Does it fit in a signed long long? 3155 // To be compatible with MSVC, hex integer literals ending with the 3156 // LL or i64 suffix are always signed in Microsoft mode. 3157 if (!Literal.isUnsigned && (ResultVal[LongLongSize-1] == 0 || 3158 (getLangOpts().MicrosoftExt && Literal.isLongLong))) 3159 Ty = Context.LongLongTy; 3160 else if (AllowUnsigned) 3161 Ty = Context.UnsignedLongLongTy; 3162 Width = LongLongSize; 3163 } 3164 } 3165 3166 // If it doesn't fit in unsigned long long, and we're using Microsoft 3167 // extensions, then its a 128-bit integer literal. 3168 if (Ty.isNull() && Literal.isMicrosoftInteger && 3169 PP.getTargetInfo().hasInt128Type()) { 3170 if (Literal.isUnsigned) 3171 Ty = Context.UnsignedInt128Ty; 3172 else 3173 Ty = Context.Int128Ty; 3174 Width = 128; 3175 } 3176 3177 // If we still couldn't decide a type, we probably have something that 3178 // does not fit in a signed long long, but has no U suffix. 3179 if (Ty.isNull()) { 3180 Diag(Tok.getLocation(), diag::warn_integer_too_large_for_signed); 3181 Ty = Context.UnsignedLongLongTy; 3182 Width = Context.getTargetInfo().getLongLongWidth(); 3183 } 3184 3185 if (ResultVal.getBitWidth() != Width) 3186 ResultVal = ResultVal.trunc(Width); 3187 } 3188 Res = IntegerLiteral::Create(Context, ResultVal, Ty, Tok.getLocation()); 3189 } 3190 3191 // If this is an imaginary literal, create the ImaginaryLiteral wrapper. 3192 if (Literal.isImaginary) 3193 Res = new (Context) ImaginaryLiteral(Res, 3194 Context.getComplexType(Res->getType())); 3195 3196 return Owned(Res); 3197 } 3198 3199 ExprResult Sema::ActOnParenExpr(SourceLocation L, SourceLocation R, Expr *E) { 3200 assert((E != 0) && "ActOnParenExpr() missing expr"); 3201 return Owned(new (Context) ParenExpr(L, R, E)); 3202 } 3203 3204 static bool CheckVecStepTraitOperandType(Sema &S, QualType T, 3205 SourceLocation Loc, 3206 SourceRange ArgRange) { 3207 // [OpenCL 1.1 6.11.12] "The vec_step built-in function takes a built-in 3208 // scalar or vector data type argument..." 3209 // Every built-in scalar type (OpenCL 1.1 6.1.1) is either an arithmetic 3210 // type (C99 6.2.5p18) or void. 3211 if (!(T->isArithmeticType() || T->isVoidType() || T->isVectorType())) { 3212 S.Diag(Loc, diag::err_vecstep_non_scalar_vector_type) 3213 << T << ArgRange; 3214 return true; 3215 } 3216 3217 assert((T->isVoidType() || !T->isIncompleteType()) && 3218 "Scalar types should always be complete"); 3219 return false; 3220 } 3221 3222 static bool CheckExtensionTraitOperandType(Sema &S, QualType T, 3223 SourceLocation Loc, 3224 SourceRange ArgRange, 3225 UnaryExprOrTypeTrait TraitKind) { 3226 // Invalid types must be hard errors for SFINAE in C++. 3227 if (S.LangOpts.CPlusPlus) 3228 return true; 3229 3230 // C99 6.5.3.4p1: 3231 if (T->isFunctionType() && 3232 (TraitKind == UETT_SizeOf || TraitKind == UETT_AlignOf)) { 3233 // sizeof(function)/alignof(function) is allowed as an extension. 3234 S.Diag(Loc, diag::ext_sizeof_alignof_function_type) 3235 << TraitKind << ArgRange; 3236 return false; 3237 } 3238 3239 // Allow sizeof(void)/alignof(void) as an extension, unless in OpenCL where 3240 // this is an error (OpenCL v1.1 s6.3.k) 3241 if (T->isVoidType()) { 3242 unsigned DiagID = S.LangOpts.OpenCL ? diag::err_opencl_sizeof_alignof_type 3243 : diag::ext_sizeof_alignof_void_type; 3244 S.Diag(Loc, DiagID) << TraitKind << ArgRange; 3245 return false; 3246 } 3247 3248 return true; 3249 } 3250 3251 static bool CheckObjCTraitOperandConstraints(Sema &S, QualType T, 3252 SourceLocation Loc, 3253 SourceRange ArgRange, 3254 UnaryExprOrTypeTrait TraitKind) { 3255 // Reject sizeof(interface) and sizeof(interface<proto>) if the 3256 // runtime doesn't allow it. 3257 if (!S.LangOpts.ObjCRuntime.allowsSizeofAlignof() && T->isObjCObjectType()) { 3258 S.Diag(Loc, diag::err_sizeof_nonfragile_interface) 3259 << T << (TraitKind == UETT_SizeOf) 3260 << ArgRange; 3261 return true; 3262 } 3263 3264 return false; 3265 } 3266 3267 /// \brief Check whether E is a pointer from a decayed array type (the decayed 3268 /// pointer type is equal to T) and emit a warning if it is. 3269 static void warnOnSizeofOnArrayDecay(Sema &S, SourceLocation Loc, QualType T, 3270 Expr *E) { 3271 // Don't warn if the operation changed the type. 3272 if (T != E->getType()) 3273 return; 3274 3275 // Now look for array decays. 3276 ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(E); 3277 if (!ICE || ICE->getCastKind() != CK_ArrayToPointerDecay) 3278 return; 3279 3280 S.Diag(Loc, diag::warn_sizeof_array_decay) << ICE->getSourceRange() 3281 << ICE->getType() 3282 << ICE->getSubExpr()->getType(); 3283 } 3284 3285 /// \brief Check the constraints on expression operands to unary type expression 3286 /// and type traits. 3287 /// 3288 /// Completes any types necessary and validates the constraints on the operand 3289 /// expression. The logic mostly mirrors the type-based overload, but may modify 3290 /// the expression as it completes the type for that expression through template 3291 /// instantiation, etc. 3292 bool Sema::CheckUnaryExprOrTypeTraitOperand(Expr *E, 3293 UnaryExprOrTypeTrait ExprKind) { 3294 QualType ExprTy = E->getType(); 3295 assert(!ExprTy->isReferenceType()); 3296 3297 if (ExprKind == UETT_VecStep) 3298 return CheckVecStepTraitOperandType(*this, ExprTy, E->getExprLoc(), 3299 E->getSourceRange()); 3300 3301 // Whitelist some types as extensions 3302 if (!CheckExtensionTraitOperandType(*this, ExprTy, E->getExprLoc(), 3303 E->getSourceRange(), ExprKind)) 3304 return false; 3305 3306 if (RequireCompleteExprType(E, 3307 diag::err_sizeof_alignof_incomplete_type, 3308 ExprKind, E->getSourceRange())) 3309 return true; 3310 3311 // Completing the expression's type may have changed it. 3312 ExprTy = E->getType(); 3313 assert(!ExprTy->isReferenceType()); 3314 3315 if (ExprTy->isFunctionType()) { 3316 Diag(E->getExprLoc(), diag::err_sizeof_alignof_function_type) 3317 << ExprKind << E->getSourceRange(); 3318 return true; 3319 } 3320 3321 if (CheckObjCTraitOperandConstraints(*this, ExprTy, E->getExprLoc(), 3322 E->getSourceRange(), ExprKind)) 3323 return true; 3324 3325 if (ExprKind == UETT_SizeOf) { 3326 if (DeclRefExpr *DeclRef = dyn_cast<DeclRefExpr>(E->IgnoreParens())) { 3327 if (ParmVarDecl *PVD = dyn_cast<ParmVarDecl>(DeclRef->getFoundDecl())) { 3328 QualType OType = PVD->getOriginalType(); 3329 QualType Type = PVD->getType(); 3330 if (Type->isPointerType() && OType->isArrayType()) { 3331 Diag(E->getExprLoc(), diag::warn_sizeof_array_param) 3332 << Type << OType; 3333 Diag(PVD->getLocation(), diag::note_declared_at); 3334 } 3335 } 3336 } 3337 3338 // Warn on "sizeof(array op x)" and "sizeof(x op array)", where the array 3339 // decays into a pointer and returns an unintended result. This is most 3340 // likely a typo for "sizeof(array) op x". 3341 if (BinaryOperator *BO = dyn_cast<BinaryOperator>(E->IgnoreParens())) { 3342 warnOnSizeofOnArrayDecay(*this, BO->getOperatorLoc(), BO->getType(), 3343 BO->getLHS()); 3344 warnOnSizeofOnArrayDecay(*this, BO->getOperatorLoc(), BO->getType(), 3345 BO->getRHS()); 3346 } 3347 } 3348 3349 return false; 3350 } 3351 3352 /// \brief Check the constraints on operands to unary expression and type 3353 /// traits. 3354 /// 3355 /// This will complete any types necessary, and validate the various constraints 3356 /// on those operands. 3357 /// 3358 /// The UsualUnaryConversions() function is *not* called by this routine. 3359 /// C99 6.3.2.1p[2-4] all state: 3360 /// Except when it is the operand of the sizeof operator ... 3361 /// 3362 /// C++ [expr.sizeof]p4 3363 /// The lvalue-to-rvalue, array-to-pointer, and function-to-pointer 3364 /// standard conversions are not applied to the operand of sizeof. 3365 /// 3366 /// This policy is followed for all of the unary trait expressions. 3367 bool Sema::CheckUnaryExprOrTypeTraitOperand(QualType ExprType, 3368 SourceLocation OpLoc, 3369 SourceRange ExprRange, 3370 UnaryExprOrTypeTrait ExprKind) { 3371 if (ExprType->isDependentType()) 3372 return false; 3373 3374 // C++ [expr.sizeof]p2: "When applied to a reference or a reference type, 3375 // the result is the size of the referenced type." 3376 // C++ [expr.alignof]p3: "When alignof is applied to a reference type, the 3377 // result shall be the alignment of the referenced type." 3378 if (const ReferenceType *Ref = ExprType->getAs<ReferenceType>()) 3379 ExprType = Ref->getPointeeType(); 3380 3381 if (ExprKind == UETT_VecStep) 3382 return CheckVecStepTraitOperandType(*this, ExprType, OpLoc, ExprRange); 3383 3384 // Whitelist some types as extensions 3385 if (!CheckExtensionTraitOperandType(*this, ExprType, OpLoc, ExprRange, 3386 ExprKind)) 3387 return false; 3388 3389 if (RequireCompleteType(OpLoc, ExprType, 3390 diag::err_sizeof_alignof_incomplete_type, 3391 ExprKind, ExprRange)) 3392 return true; 3393 3394 if (ExprType->isFunctionType()) { 3395 Diag(OpLoc, diag::err_sizeof_alignof_function_type) 3396 << ExprKind << ExprRange; 3397 return true; 3398 } 3399 3400 if (CheckObjCTraitOperandConstraints(*this, ExprType, OpLoc, ExprRange, 3401 ExprKind)) 3402 return true; 3403 3404 return false; 3405 } 3406 3407 static bool CheckAlignOfExpr(Sema &S, Expr *E) { 3408 E = E->IgnoreParens(); 3409 3410 // Cannot know anything else if the expression is dependent. 3411 if (E->isTypeDependent()) 3412 return false; 3413 3414 if (E->getObjectKind() == OK_BitField) { 3415 S.Diag(E->getExprLoc(), diag::err_sizeof_alignof_bitfield) 3416 << 1 << E->getSourceRange(); 3417 return true; 3418 } 3419 3420 ValueDecl *D = 0; 3421 if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E)) { 3422 D = DRE->getDecl(); 3423 } else if (MemberExpr *ME = dyn_cast<MemberExpr>(E)) { 3424 D = ME->getMemberDecl(); 3425 } 3426 3427 // If it's a field, require the containing struct to have a 3428 // complete definition so that we can compute the layout. 3429 // 3430 // This requires a very particular set of circumstances. For a 3431 // field to be contained within an incomplete type, we must in the 3432 // process of parsing that type. To have an expression refer to a 3433 // field, it must be an id-expression or a member-expression, but 3434 // the latter are always ill-formed when the base type is 3435 // incomplete, including only being partially complete. An 3436 // id-expression can never refer to a field in C because fields 3437 // are not in the ordinary namespace. In C++, an id-expression 3438 // can implicitly be a member access, but only if there's an 3439 // implicit 'this' value, and all such contexts are subject to 3440 // delayed parsing --- except for trailing return types in C++11. 3441 // And if an id-expression referring to a field occurs in a 3442 // context that lacks a 'this' value, it's ill-formed --- except, 3443 // again, in C++11, where such references are allowed in an 3444 // unevaluated context. So C++11 introduces some new complexity. 3445 // 3446 // For the record, since __alignof__ on expressions is a GCC 3447 // extension, GCC seems to permit this but always gives the 3448 // nonsensical answer 0. 3449 // 3450 // We don't really need the layout here --- we could instead just 3451 // directly check for all the appropriate alignment-lowing 3452 // attributes --- but that would require duplicating a lot of 3453 // logic that just isn't worth duplicating for such a marginal 3454 // use-case. 3455 if (FieldDecl *FD = dyn_cast_or_null<FieldDecl>(D)) { 3456 // Fast path this check, since we at least know the record has a 3457 // definition if we can find a member of it. 3458 if (!FD->getParent()->isCompleteDefinition()) { 3459 S.Diag(E->getExprLoc(), diag::err_alignof_member_of_incomplete_type) 3460 << E->getSourceRange(); 3461 return true; 3462 } 3463 3464 // Otherwise, if it's a field, and the field doesn't have 3465 // reference type, then it must have a complete type (or be a 3466 // flexible array member, which we explicitly want to 3467 // white-list anyway), which makes the following checks trivial. 3468 if (!FD->getType()->isReferenceType()) 3469 return false; 3470 } 3471 3472 return S.CheckUnaryExprOrTypeTraitOperand(E, UETT_AlignOf); 3473 } 3474 3475 bool Sema::CheckVecStepExpr(Expr *E) { 3476 E = E->IgnoreParens(); 3477 3478 // Cannot know anything else if the expression is dependent. 3479 if (E->isTypeDependent()) 3480 return false; 3481 3482 return CheckUnaryExprOrTypeTraitOperand(E, UETT_VecStep); 3483 } 3484 3485 /// \brief Build a sizeof or alignof expression given a type operand. 3486 ExprResult 3487 Sema::CreateUnaryExprOrTypeTraitExpr(TypeSourceInfo *TInfo, 3488 SourceLocation OpLoc, 3489 UnaryExprOrTypeTrait ExprKind, 3490 SourceRange R) { 3491 if (!TInfo) 3492 return ExprError(); 3493 3494 QualType T = TInfo->getType(); 3495 3496 if (!T->isDependentType() && 3497 CheckUnaryExprOrTypeTraitOperand(T, OpLoc, R, ExprKind)) 3498 return ExprError(); 3499 3500 // C99 6.5.3.4p4: the type (an unsigned integer type) is size_t. 3501 return Owned(new (Context) UnaryExprOrTypeTraitExpr(ExprKind, TInfo, 3502 Context.getSizeType(), 3503 OpLoc, R.getEnd())); 3504 } 3505 3506 /// \brief Build a sizeof or alignof expression given an expression 3507 /// operand. 3508 ExprResult 3509 Sema::CreateUnaryExprOrTypeTraitExpr(Expr *E, SourceLocation OpLoc, 3510 UnaryExprOrTypeTrait ExprKind) { 3511 ExprResult PE = CheckPlaceholderExpr(E); 3512 if (PE.isInvalid()) 3513 return ExprError(); 3514 3515 E = PE.get(); 3516 3517 // Verify that the operand is valid. 3518 bool isInvalid = false; 3519 if (E->isTypeDependent()) { 3520 // Delay type-checking for type-dependent expressions. 3521 } else if (ExprKind == UETT_AlignOf) { 3522 isInvalid = CheckAlignOfExpr(*this, E); 3523 } else if (ExprKind == UETT_VecStep) { 3524 isInvalid = CheckVecStepExpr(E); 3525 } else if (E->refersToBitField()) { // C99 6.5.3.4p1. 3526 Diag(E->getExprLoc(), diag::err_sizeof_alignof_bitfield) << 0; 3527 isInvalid = true; 3528 } else { 3529 isInvalid = CheckUnaryExprOrTypeTraitOperand(E, UETT_SizeOf); 3530 } 3531 3532 if (isInvalid) 3533 return ExprError(); 3534 3535 if (ExprKind == UETT_SizeOf && E->getType()->isVariableArrayType()) { 3536 PE = TransformToPotentiallyEvaluated(E); 3537 if (PE.isInvalid()) return ExprError(); 3538 E = PE.take(); 3539 } 3540 3541 // C99 6.5.3.4p4: the type (an unsigned integer type) is size_t. 3542 return Owned(new (Context) UnaryExprOrTypeTraitExpr( 3543 ExprKind, E, Context.getSizeType(), OpLoc, 3544 E->getSourceRange().getEnd())); 3545 } 3546 3547 /// ActOnUnaryExprOrTypeTraitExpr - Handle @c sizeof(type) and @c sizeof @c 3548 /// expr and the same for @c alignof and @c __alignof 3549 /// Note that the ArgRange is invalid if isType is false. 3550 ExprResult 3551 Sema::ActOnUnaryExprOrTypeTraitExpr(SourceLocation OpLoc, 3552 UnaryExprOrTypeTrait ExprKind, bool IsType, 3553 void *TyOrEx, const SourceRange &ArgRange) { 3554 // If error parsing type, ignore. 3555 if (TyOrEx == 0) return ExprError(); 3556 3557 if (IsType) { 3558 TypeSourceInfo *TInfo; 3559 (void) GetTypeFromParser(ParsedType::getFromOpaquePtr(TyOrEx), &TInfo); 3560 return CreateUnaryExprOrTypeTraitExpr(TInfo, OpLoc, ExprKind, ArgRange); 3561 } 3562 3563 Expr *ArgEx = (Expr *)TyOrEx; 3564 ExprResult Result = CreateUnaryExprOrTypeTraitExpr(ArgEx, OpLoc, ExprKind); 3565 return Result; 3566 } 3567 3568 static QualType CheckRealImagOperand(Sema &S, ExprResult &V, SourceLocation Loc, 3569 bool IsReal) { 3570 if (V.get()->isTypeDependent()) 3571 return S.Context.DependentTy; 3572 3573 // _Real and _Imag are only l-values for normal l-values. 3574 if (V.get()->getObjectKind() != OK_Ordinary) { 3575 V = S.DefaultLvalueConversion(V.take()); 3576 if (V.isInvalid()) 3577 return QualType(); 3578 } 3579 3580 // These operators return the element type of a complex type. 3581 if (const ComplexType *CT = V.get()->getType()->getAs<ComplexType>()) 3582 return CT->getElementType(); 3583 3584 // Otherwise they pass through real integer and floating point types here. 3585 if (V.get()->getType()->isArithmeticType()) 3586 return V.get()->getType(); 3587 3588 // Test for placeholders. 3589 ExprResult PR = S.CheckPlaceholderExpr(V.get()); 3590 if (PR.isInvalid()) return QualType(); 3591 if (PR.get() != V.get()) { 3592 V = PR; 3593 return CheckRealImagOperand(S, V, Loc, IsReal); 3594 } 3595 3596 // Reject anything else. 3597 S.Diag(Loc, diag::err_realimag_invalid_type) << V.get()->getType() 3598 << (IsReal ? "__real" : "__imag"); 3599 return QualType(); 3600 } 3601 3602 3603 3604 ExprResult 3605 Sema::ActOnPostfixUnaryOp(Scope *S, SourceLocation OpLoc, 3606 tok::TokenKind Kind, Expr *Input) { 3607 UnaryOperatorKind Opc; 3608 switch (Kind) { 3609 default: llvm_unreachable("Unknown unary op!"); 3610 case tok::plusplus: Opc = UO_PostInc; break; 3611 case tok::minusminus: Opc = UO_PostDec; break; 3612 } 3613 3614 // Since this might is a postfix expression, get rid of ParenListExprs. 3615 ExprResult Result = MaybeConvertParenListExprToParenExpr(S, Input); 3616 if (Result.isInvalid()) return ExprError(); 3617 Input = Result.take(); 3618 3619 return BuildUnaryOp(S, OpLoc, Opc, Input); 3620 } 3621 3622 /// \brief Diagnose if arithmetic on the given ObjC pointer is illegal. 3623 /// 3624 /// \return true on error 3625 static bool checkArithmeticOnObjCPointer(Sema &S, 3626 SourceLocation opLoc, 3627 Expr *op) { 3628 assert(op->getType()->isObjCObjectPointerType()); 3629 if (S.LangOpts.ObjCRuntime.allowsPointerArithmetic() && 3630 !S.LangOpts.ObjCSubscriptingLegacyRuntime) 3631 return false; 3632 3633 S.Diag(opLoc, diag::err_arithmetic_nonfragile_interface) 3634 << op->getType()->castAs<ObjCObjectPointerType>()->getPointeeType() 3635 << op->getSourceRange(); 3636 return true; 3637 } 3638 3639 ExprResult 3640 Sema::ActOnArraySubscriptExpr(Scope *S, Expr *base, SourceLocation lbLoc, 3641 Expr *idx, SourceLocation rbLoc) { 3642 // Since this might be a postfix expression, get rid of ParenListExprs. 3643 if (isa<ParenListExpr>(base)) { 3644 ExprResult result = MaybeConvertParenListExprToParenExpr(S, base); 3645 if (result.isInvalid()) return ExprError(); 3646 base = result.take(); 3647 } 3648 3649 // Handle any non-overload placeholder types in the base and index 3650 // expressions. We can't handle overloads here because the other 3651 // operand might be an overloadable type, in which case the overload 3652 // resolution for the operator overload should get the first crack 3653 // at the overload. 3654 if (base->getType()->isNonOverloadPlaceholderType()) { 3655 ExprResult result = CheckPlaceholderExpr(base); 3656 if (result.isInvalid()) return ExprError(); 3657 base = result.take(); 3658 } 3659 if (idx->getType()->isNonOverloadPlaceholderType()) { 3660 ExprResult result = CheckPlaceholderExpr(idx); 3661 if (result.isInvalid()) return ExprError(); 3662 idx = result.take(); 3663 } 3664 3665 // Build an unanalyzed expression if either operand is type-dependent. 3666 if (getLangOpts().CPlusPlus && 3667 (base->isTypeDependent() || idx->isTypeDependent())) { 3668 return Owned(new (Context) ArraySubscriptExpr(base, idx, 3669 Context.DependentTy, 3670 VK_LValue, OK_Ordinary, 3671 rbLoc)); 3672 } 3673 3674 // Use C++ overloaded-operator rules if either operand has record 3675 // type. The spec says to do this if either type is *overloadable*, 3676 // but enum types can't declare subscript operators or conversion 3677 // operators, so there's nothing interesting for overload resolution 3678 // to do if there aren't any record types involved. 3679 // 3680 // ObjC pointers have their own subscripting logic that is not tied 3681 // to overload resolution and so should not take this path. 3682 if (getLangOpts().CPlusPlus && 3683 (base->getType()->isRecordType() || 3684 (!base->getType()->isObjCObjectPointerType() && 3685 idx->getType()->isRecordType()))) { 3686 return CreateOverloadedArraySubscriptExpr(lbLoc, rbLoc, base, idx); 3687 } 3688 3689 return CreateBuiltinArraySubscriptExpr(base, lbLoc, idx, rbLoc); 3690 } 3691 3692 ExprResult 3693 Sema::CreateBuiltinArraySubscriptExpr(Expr *Base, SourceLocation LLoc, 3694 Expr *Idx, SourceLocation RLoc) { 3695 Expr *LHSExp = Base; 3696 Expr *RHSExp = Idx; 3697 3698 // Perform default conversions. 3699 if (!LHSExp->getType()->getAs<VectorType>()) { 3700 ExprResult Result = DefaultFunctionArrayLvalueConversion(LHSExp); 3701 if (Result.isInvalid()) 3702 return ExprError(); 3703 LHSExp = Result.take(); 3704 } 3705 ExprResult Result = DefaultFunctionArrayLvalueConversion(RHSExp); 3706 if (Result.isInvalid()) 3707 return ExprError(); 3708 RHSExp = Result.take(); 3709 3710 QualType LHSTy = LHSExp->getType(), RHSTy = RHSExp->getType(); 3711 ExprValueKind VK = VK_LValue; 3712 ExprObjectKind OK = OK_Ordinary; 3713 3714 // C99 6.5.2.1p2: the expression e1[e2] is by definition precisely equivalent 3715 // to the expression *((e1)+(e2)). This means the array "Base" may actually be 3716 // in the subscript position. As a result, we need to derive the array base 3717 // and index from the expression types. 3718 Expr *BaseExpr, *IndexExpr; 3719 QualType ResultType; 3720 if (LHSTy->isDependentType() || RHSTy->isDependentType()) { 3721 BaseExpr = LHSExp; 3722 IndexExpr = RHSExp; 3723 ResultType = Context.DependentTy; 3724 } else if (const PointerType *PTy = LHSTy->getAs<PointerType>()) { 3725 BaseExpr = LHSExp; 3726 IndexExpr = RHSExp; 3727 ResultType = PTy->getPointeeType(); 3728 } else if (const ObjCObjectPointerType *PTy = 3729 LHSTy->getAs<ObjCObjectPointerType>()) { 3730 BaseExpr = LHSExp; 3731 IndexExpr = RHSExp; 3732 3733 // Use custom logic if this should be the pseudo-object subscript 3734 // expression. 3735 if (!LangOpts.isSubscriptPointerArithmetic()) 3736 return BuildObjCSubscriptExpression(RLoc, BaseExpr, IndexExpr, 0, 0); 3737 3738 ResultType = PTy->getPointeeType(); 3739 } else if (const PointerType *PTy = RHSTy->getAs<PointerType>()) { 3740 // Handle the uncommon case of "123[Ptr]". 3741 BaseExpr = RHSExp; 3742 IndexExpr = LHSExp; 3743 ResultType = PTy->getPointeeType(); 3744 } else if (const ObjCObjectPointerType *PTy = 3745 RHSTy->getAs<ObjCObjectPointerType>()) { 3746 // Handle the uncommon case of "123[Ptr]". 3747 BaseExpr = RHSExp; 3748 IndexExpr = LHSExp; 3749 ResultType = PTy->getPointeeType(); 3750 if (!LangOpts.isSubscriptPointerArithmetic()) { 3751 Diag(LLoc, diag::err_subscript_nonfragile_interface) 3752 << ResultType << BaseExpr->getSourceRange(); 3753 return ExprError(); 3754 } 3755 } else if (const VectorType *VTy = LHSTy->getAs<VectorType>()) { 3756 BaseExpr = LHSExp; // vectors: V[123] 3757 IndexExpr = RHSExp; 3758 VK = LHSExp->getValueKind(); 3759 if (VK != VK_RValue) 3760 OK = OK_VectorComponent; 3761 3762 // FIXME: need to deal with const... 3763 ResultType = VTy->getElementType(); 3764 } else if (LHSTy->isArrayType()) { 3765 // If we see an array that wasn't promoted by 3766 // DefaultFunctionArrayLvalueConversion, it must be an array that 3767 // wasn't promoted because of the C90 rule that doesn't 3768 // allow promoting non-lvalue arrays. Warn, then 3769 // force the promotion here. 3770 Diag(LHSExp->getLocStart(), diag::ext_subscript_non_lvalue) << 3771 LHSExp->getSourceRange(); 3772 LHSExp = ImpCastExprToType(LHSExp, Context.getArrayDecayedType(LHSTy), 3773 CK_ArrayToPointerDecay).take(); 3774 LHSTy = LHSExp->getType(); 3775 3776 BaseExpr = LHSExp; 3777 IndexExpr = RHSExp; 3778 ResultType = LHSTy->getAs<PointerType>()->getPointeeType(); 3779 } else if (RHSTy->isArrayType()) { 3780 // Same as previous, except for 123[f().a] case 3781 Diag(RHSExp->getLocStart(), diag::ext_subscript_non_lvalue) << 3782 RHSExp->getSourceRange(); 3783 RHSExp = ImpCastExprToType(RHSExp, Context.getArrayDecayedType(RHSTy), 3784 CK_ArrayToPointerDecay).take(); 3785 RHSTy = RHSExp->getType(); 3786 3787 BaseExpr = RHSExp; 3788 IndexExpr = LHSExp; 3789 ResultType = RHSTy->getAs<PointerType>()->getPointeeType(); 3790 } else { 3791 return ExprError(Diag(LLoc, diag::err_typecheck_subscript_value) 3792 << LHSExp->getSourceRange() << RHSExp->getSourceRange()); 3793 } 3794 // C99 6.5.2.1p1 3795 if (!IndexExpr->getType()->isIntegerType() && !IndexExpr->isTypeDependent()) 3796 return ExprError(Diag(LLoc, diag::err_typecheck_subscript_not_integer) 3797 << IndexExpr->getSourceRange()); 3798 3799 if ((IndexExpr->getType()->isSpecificBuiltinType(BuiltinType::Char_S) || 3800 IndexExpr->getType()->isSpecificBuiltinType(BuiltinType::Char_U)) 3801 && !IndexExpr->isTypeDependent()) 3802 Diag(LLoc, diag::warn_subscript_is_char) << IndexExpr->getSourceRange(); 3803 3804 // C99 6.5.2.1p1: "shall have type "pointer to *object* type". Similarly, 3805 // C++ [expr.sub]p1: The type "T" shall be a completely-defined object 3806 // type. Note that Functions are not objects, and that (in C99 parlance) 3807 // incomplete types are not object types. 3808 if (ResultType->isFunctionType()) { 3809 Diag(BaseExpr->getLocStart(), diag::err_subscript_function_type) 3810 << ResultType << BaseExpr->getSourceRange(); 3811 return ExprError(); 3812 } 3813 3814 if (ResultType->isVoidType() && !getLangOpts().CPlusPlus) { 3815 // GNU extension: subscripting on pointer to void 3816 Diag(LLoc, diag::ext_gnu_subscript_void_type) 3817 << BaseExpr->getSourceRange(); 3818 3819 // C forbids expressions of unqualified void type from being l-values. 3820 // See IsCForbiddenLValueType. 3821 if (!ResultType.hasQualifiers()) VK = VK_RValue; 3822 } else if (!ResultType->isDependentType() && 3823 RequireCompleteType(LLoc, ResultType, 3824 diag::err_subscript_incomplete_type, BaseExpr)) 3825 return ExprError(); 3826 3827 assert(VK == VK_RValue || LangOpts.CPlusPlus || 3828 !ResultType.isCForbiddenLValueType()); 3829 3830 return Owned(new (Context) ArraySubscriptExpr(LHSExp, RHSExp, 3831 ResultType, VK, OK, RLoc)); 3832 } 3833 3834 ExprResult Sema::BuildCXXDefaultArgExpr(SourceLocation CallLoc, 3835 FunctionDecl *FD, 3836 ParmVarDecl *Param) { 3837 if (Param->hasUnparsedDefaultArg()) { 3838 Diag(CallLoc, 3839 diag::err_use_of_default_argument_to_function_declared_later) << 3840 FD << cast<CXXRecordDecl>(FD->getDeclContext())->getDeclName(); 3841 Diag(UnparsedDefaultArgLocs[Param], 3842 diag::note_default_argument_declared_here); 3843 return ExprError(); 3844 } 3845 3846 if (Param->hasUninstantiatedDefaultArg()) { 3847 Expr *UninstExpr = Param->getUninstantiatedDefaultArg(); 3848 3849 EnterExpressionEvaluationContext EvalContext(*this, PotentiallyEvaluated, 3850 Param); 3851 3852 // Instantiate the expression. 3853 MultiLevelTemplateArgumentList MutiLevelArgList 3854 = getTemplateInstantiationArgs(FD, 0, /*RelativeToPrimary=*/true); 3855 3856 InstantiatingTemplate Inst(*this, CallLoc, Param, 3857 MutiLevelArgList.getInnermost()); 3858 if (Inst.isInvalid()) 3859 return ExprError(); 3860 3861 ExprResult Result; 3862 { 3863 // C++ [dcl.fct.default]p5: 3864 // The names in the [default argument] expression are bound, and 3865 // the semantic constraints are checked, at the point where the 3866 // default argument expression appears. 3867 ContextRAII SavedContext(*this, FD); 3868 LocalInstantiationScope Local(*this); 3869 Result = SubstExpr(UninstExpr, MutiLevelArgList); 3870 } 3871 if (Result.isInvalid()) 3872 return ExprError(); 3873 3874 // Check the expression as an initializer for the parameter. 3875 InitializedEntity Entity 3876 = InitializedEntity::InitializeParameter(Context, Param); 3877 InitializationKind Kind 3878 = InitializationKind::CreateCopy(Param->getLocation(), 3879 /*FIXME:EqualLoc*/UninstExpr->getLocStart()); 3880 Expr *ResultE = Result.takeAs<Expr>(); 3881 3882 InitializationSequence InitSeq(*this, Entity, Kind, ResultE); 3883 Result = InitSeq.Perform(*this, Entity, Kind, ResultE); 3884 if (Result.isInvalid()) 3885 return ExprError(); 3886 3887 Expr *Arg = Result.takeAs<Expr>(); 3888 CheckCompletedExpr(Arg, Param->getOuterLocStart()); 3889 // Build the default argument expression. 3890 return Owned(CXXDefaultArgExpr::Create(Context, CallLoc, Param, Arg)); 3891 } 3892 3893 // If the default expression creates temporaries, we need to 3894 // push them to the current stack of expression temporaries so they'll 3895 // be properly destroyed. 3896 // FIXME: We should really be rebuilding the default argument with new 3897 // bound temporaries; see the comment in PR5810. 3898 // We don't need to do that with block decls, though, because 3899 // blocks in default argument expression can never capture anything. 3900 if (isa<ExprWithCleanups>(Param->getInit())) { 3901 // Set the "needs cleanups" bit regardless of whether there are 3902 // any explicit objects. 3903 ExprNeedsCleanups = true; 3904 3905 // Append all the objects to the cleanup list. Right now, this 3906 // should always be a no-op, because blocks in default argument 3907 // expressions should never be able to capture anything. 3908 assert(!cast<ExprWithCleanups>(Param->getInit())->getNumObjects() && 3909 "default argument expression has capturing blocks?"); 3910 } 3911 3912 // We already type-checked the argument, so we know it works. 3913 // Just mark all of the declarations in this potentially-evaluated expression 3914 // as being "referenced". 3915 MarkDeclarationsReferencedInExpr(Param->getDefaultArg(), 3916 /*SkipLocalVariables=*/true); 3917 return Owned(CXXDefaultArgExpr::Create(Context, CallLoc, Param)); 3918 } 3919 3920 3921 Sema::VariadicCallType 3922 Sema::getVariadicCallType(FunctionDecl *FDecl, const FunctionProtoType *Proto, 3923 Expr *Fn) { 3924 if (Proto && Proto->isVariadic()) { 3925 if (dyn_cast_or_null<CXXConstructorDecl>(FDecl)) 3926 return VariadicConstructor; 3927 else if (Fn && Fn->getType()->isBlockPointerType()) 3928 return VariadicBlock; 3929 else if (FDecl) { 3930 if (CXXMethodDecl *Method = dyn_cast_or_null<CXXMethodDecl>(FDecl)) 3931 if (Method->isInstance()) 3932 return VariadicMethod; 3933 } else if (Fn && Fn->getType() == Context.BoundMemberTy) 3934 return VariadicMethod; 3935 return VariadicFunction; 3936 } 3937 return VariadicDoesNotApply; 3938 } 3939 3940 namespace { 3941 class FunctionCallCCC : public FunctionCallFilterCCC { 3942 public: 3943 FunctionCallCCC(Sema &SemaRef, const IdentifierInfo *FuncName, 3944 unsigned NumArgs, bool HasExplicitTemplateArgs) 3945 : FunctionCallFilterCCC(SemaRef, NumArgs, HasExplicitTemplateArgs), 3946 FunctionName(FuncName) {} 3947 3948 virtual bool ValidateCandidate(const TypoCorrection &candidate) { 3949 if (!candidate.getCorrectionSpecifier() || 3950 candidate.getCorrectionAsIdentifierInfo() != FunctionName) { 3951 return false; 3952 } 3953 3954 return FunctionCallFilterCCC::ValidateCandidate(candidate); 3955 } 3956 3957 private: 3958 const IdentifierInfo *const FunctionName; 3959 }; 3960 } 3961 3962 static TypoCorrection TryTypoCorrectionForCall(Sema &S, 3963 DeclarationNameInfo FuncName, 3964 ArrayRef<Expr *> Args) { 3965 FunctionCallCCC CCC(S, FuncName.getName().getAsIdentifierInfo(), 3966 Args.size(), false); 3967 if (TypoCorrection Corrected = 3968 S.CorrectTypo(FuncName, Sema::LookupOrdinaryName, 3969 S.getScopeForContext(S.CurContext), NULL, CCC)) { 3970 if (NamedDecl *ND = Corrected.getCorrectionDecl()) { 3971 if (Corrected.isOverloaded()) { 3972 OverloadCandidateSet OCS(FuncName.getLoc()); 3973 OverloadCandidateSet::iterator Best; 3974 for (TypoCorrection::decl_iterator CD = Corrected.begin(), 3975 CDEnd = Corrected.end(); 3976 CD != CDEnd; ++CD) { 3977 if (FunctionDecl *FD = dyn_cast<FunctionDecl>(*CD)) 3978 S.AddOverloadCandidate(FD, DeclAccessPair::make(FD, AS_none), Args, 3979 OCS); 3980 } 3981 switch (OCS.BestViableFunction(S, FuncName.getLoc(), Best)) { 3982 case OR_Success: 3983 ND = Best->Function; 3984 Corrected.setCorrectionDecl(ND); 3985 break; 3986 default: 3987 break; 3988 } 3989 } 3990 if (isa<ValueDecl>(ND) || isa<FunctionTemplateDecl>(ND)) { 3991 return Corrected; 3992 } 3993 } 3994 } 3995 return TypoCorrection(); 3996 } 3997 3998 /// ConvertArgumentsForCall - Converts the arguments specified in 3999 /// Args/NumArgs to the parameter types of the function FDecl with 4000 /// function prototype Proto. Call is the call expression itself, and 4001 /// Fn is the function expression. For a C++ member function, this 4002 /// routine does not attempt to convert the object argument. Returns 4003 /// true if the call is ill-formed. 4004 bool 4005 Sema::ConvertArgumentsForCall(CallExpr *Call, Expr *Fn, 4006 FunctionDecl *FDecl, 4007 const FunctionProtoType *Proto, 4008 ArrayRef<Expr *> Args, 4009 SourceLocation RParenLoc, 4010 bool IsExecConfig) { 4011 // Bail out early if calling a builtin with custom typechecking. 4012 // We don't need to do this in the 4013 if (FDecl) 4014 if (unsigned ID = FDecl->getBuiltinID()) 4015 if (Context.BuiltinInfo.hasCustomTypechecking(ID)) 4016 return false; 4017 4018 // C99 6.5.2.2p7 - the arguments are implicitly converted, as if by 4019 // assignment, to the types of the corresponding parameter, ... 4020 unsigned NumArgsInProto = Proto->getNumArgs(); 4021 bool Invalid = false; 4022 unsigned MinArgs = FDecl ? FDecl->getMinRequiredArguments() : NumArgsInProto; 4023 unsigned FnKind = Fn->getType()->isBlockPointerType() 4024 ? 1 /* block */ 4025 : (IsExecConfig ? 3 /* kernel function (exec config) */ 4026 : 0 /* function */); 4027 4028 // If too few arguments are available (and we don't have default 4029 // arguments for the remaining parameters), don't make the call. 4030 if (Args.size() < NumArgsInProto) { 4031 if (Args.size() < MinArgs) { 4032 MemberExpr *ME = dyn_cast<MemberExpr>(Fn); 4033 TypoCorrection TC; 4034 if (FDecl && (TC = TryTypoCorrectionForCall( 4035 *this, DeclarationNameInfo(FDecl->getDeclName(), 4036 (ME ? ME->getMemberLoc() 4037 : Fn->getLocStart())), 4038 Args))) { 4039 unsigned diag_id = 4040 MinArgs == NumArgsInProto && !Proto->isVariadic() 4041 ? diag::err_typecheck_call_too_few_args_suggest 4042 : diag::err_typecheck_call_too_few_args_at_least_suggest; 4043 diagnoseTypo(TC, PDiag(diag_id) << FnKind << MinArgs 4044 << static_cast<unsigned>(Args.size()) 4045 << Fn->getSourceRange()); 4046 } else if (MinArgs == 1 && FDecl && FDecl->getParamDecl(0)->getDeclName()) 4047 Diag(RParenLoc, MinArgs == NumArgsInProto && !Proto->isVariadic() 4048 ? diag::err_typecheck_call_too_few_args_one 4049 : diag::err_typecheck_call_too_few_args_at_least_one) 4050 << FnKind 4051 << FDecl->getParamDecl(0) << Fn->getSourceRange(); 4052 else 4053 Diag(RParenLoc, MinArgs == NumArgsInProto && !Proto->isVariadic() 4054 ? diag::err_typecheck_call_too_few_args 4055 : diag::err_typecheck_call_too_few_args_at_least) 4056 << FnKind 4057 << MinArgs << static_cast<unsigned>(Args.size()) 4058 << Fn->getSourceRange(); 4059 4060 // Emit the location of the prototype. 4061 if (!TC && FDecl && !FDecl->getBuiltinID() && !IsExecConfig) 4062 Diag(FDecl->getLocStart(), diag::note_callee_decl) 4063 << FDecl; 4064 4065 return true; 4066 } 4067 Call->setNumArgs(Context, NumArgsInProto); 4068 } 4069 4070 // If too many are passed and not variadic, error on the extras and drop 4071 // them. 4072 if (Args.size() > NumArgsInProto) { 4073 if (!Proto->isVariadic()) { 4074 TypoCorrection TC; 4075 if (FDecl && (TC = TryTypoCorrectionForCall( 4076 *this, DeclarationNameInfo(FDecl->getDeclName(), 4077 Fn->getLocStart()), 4078 Args))) { 4079 unsigned diag_id = 4080 MinArgs == NumArgsInProto && !Proto->isVariadic() 4081 ? diag::err_typecheck_call_too_many_args_suggest 4082 : diag::err_typecheck_call_too_many_args_at_most_suggest; 4083 diagnoseTypo(TC, PDiag(diag_id) << FnKind << NumArgsInProto 4084 << static_cast<unsigned>(Args.size()) 4085 << Fn->getSourceRange()); 4086 } else if (NumArgsInProto == 1 && FDecl && 4087 FDecl->getParamDecl(0)->getDeclName()) 4088 Diag(Args[NumArgsInProto]->getLocStart(), 4089 MinArgs == NumArgsInProto 4090 ? diag::err_typecheck_call_too_many_args_one 4091 : diag::err_typecheck_call_too_many_args_at_most_one) 4092 << FnKind 4093 << FDecl->getParamDecl(0) << static_cast<unsigned>(Args.size()) 4094 << Fn->getSourceRange() 4095 << SourceRange(Args[NumArgsInProto]->getLocStart(), 4096 Args.back()->getLocEnd()); 4097 else 4098 Diag(Args[NumArgsInProto]->getLocStart(), 4099 MinArgs == NumArgsInProto 4100 ? diag::err_typecheck_call_too_many_args 4101 : diag::err_typecheck_call_too_many_args_at_most) 4102 << FnKind 4103 << NumArgsInProto << static_cast<unsigned>(Args.size()) 4104 << Fn->getSourceRange() 4105 << SourceRange(Args[NumArgsInProto]->getLocStart(), 4106 Args.back()->getLocEnd()); 4107 4108 // Emit the location of the prototype. 4109 if (!TC && FDecl && !FDecl->getBuiltinID() && !IsExecConfig) 4110 Diag(FDecl->getLocStart(), diag::note_callee_decl) 4111 << FDecl; 4112 4113 // This deletes the extra arguments. 4114 Call->setNumArgs(Context, NumArgsInProto); 4115 return true; 4116 } 4117 } 4118 SmallVector<Expr *, 8> AllArgs; 4119 VariadicCallType CallType = getVariadicCallType(FDecl, Proto, Fn); 4120 4121 Invalid = GatherArgumentsForCall(Call->getLocStart(), FDecl, 4122 Proto, 0, Args, AllArgs, CallType); 4123 if (Invalid) 4124 return true; 4125 unsigned TotalNumArgs = AllArgs.size(); 4126 for (unsigned i = 0; i < TotalNumArgs; ++i) 4127 Call->setArg(i, AllArgs[i]); 4128 4129 return false; 4130 } 4131 4132 bool Sema::GatherArgumentsForCall(SourceLocation CallLoc, 4133 FunctionDecl *FDecl, 4134 const FunctionProtoType *Proto, 4135 unsigned FirstProtoArg, 4136 ArrayRef<Expr *> Args, 4137 SmallVectorImpl<Expr *> &AllArgs, 4138 VariadicCallType CallType, 4139 bool AllowExplicit, 4140 bool IsListInitialization) { 4141 unsigned NumArgsInProto = Proto->getNumArgs(); 4142 unsigned NumArgsToCheck = Args.size(); 4143 bool Invalid = false; 4144 if (Args.size() != NumArgsInProto) 4145 // Use default arguments for missing arguments 4146 NumArgsToCheck = NumArgsInProto; 4147 unsigned ArgIx = 0; 4148 // Continue to check argument types (even if we have too few/many args). 4149 for (unsigned i = FirstProtoArg; i != NumArgsToCheck; i++) { 4150 QualType ProtoArgType = Proto->getArgType(i); 4151 4152 Expr *Arg; 4153 ParmVarDecl *Param; 4154 if (ArgIx < Args.size()) { 4155 Arg = Args[ArgIx++]; 4156 4157 if (RequireCompleteType(Arg->getLocStart(), 4158 ProtoArgType, 4159 diag::err_call_incomplete_argument, Arg)) 4160 return true; 4161 4162 // Pass the argument 4163 Param = 0; 4164 if (FDecl && i < FDecl->getNumParams()) 4165 Param = FDecl->getParamDecl(i); 4166 4167 // Strip the unbridged-cast placeholder expression off, if applicable. 4168 bool CFAudited = false; 4169 if (Arg->getType() == Context.ARCUnbridgedCastTy && 4170 FDecl && FDecl->hasAttr<CFAuditedTransferAttr>() && 4171 (!Param || !Param->hasAttr<CFConsumedAttr>())) 4172 Arg = stripARCUnbridgedCast(Arg); 4173 else if (getLangOpts().ObjCAutoRefCount && 4174 FDecl && FDecl->hasAttr<CFAuditedTransferAttr>() && 4175 (!Param || !Param->hasAttr<CFConsumedAttr>())) 4176 CFAudited = true; 4177 4178 InitializedEntity Entity = Param ? 4179 InitializedEntity::InitializeParameter(Context, Param, ProtoArgType) 4180 : InitializedEntity::InitializeParameter(Context, ProtoArgType, 4181 Proto->isArgConsumed(i)); 4182 4183 // Remember that parameter belongs to a CF audited API. 4184 if (CFAudited) 4185 Entity.setParameterCFAudited(); 4186 4187 ExprResult ArgE = PerformCopyInitialization(Entity, 4188 SourceLocation(), 4189 Owned(Arg), 4190 IsListInitialization, 4191 AllowExplicit); 4192 if (ArgE.isInvalid()) 4193 return true; 4194 4195 Arg = ArgE.takeAs<Expr>(); 4196 } else { 4197 assert(FDecl && "can't use default arguments without a known callee"); 4198 Param = FDecl->getParamDecl(i); 4199 4200 ExprResult ArgExpr = 4201 BuildCXXDefaultArgExpr(CallLoc, FDecl, Param); 4202 if (ArgExpr.isInvalid()) 4203 return true; 4204 4205 Arg = ArgExpr.takeAs<Expr>(); 4206 } 4207 4208 // Check for array bounds violations for each argument to the call. This 4209 // check only triggers warnings when the argument isn't a more complex Expr 4210 // with its own checking, such as a BinaryOperator. 4211 CheckArrayAccess(Arg); 4212 4213 // Check for violations of C99 static array rules (C99 6.7.5.3p7). 4214 CheckStaticArrayArgument(CallLoc, Param, Arg); 4215 4216 AllArgs.push_back(Arg); 4217 } 4218 4219 // If this is a variadic call, handle args passed through "...". 4220 if (CallType != VariadicDoesNotApply) { 4221 // Assume that extern "C" functions with variadic arguments that 4222 // return __unknown_anytype aren't *really* variadic. 4223 if (Proto->getResultType() == Context.UnknownAnyTy && 4224 FDecl && FDecl->isExternC()) { 4225 for (unsigned i = ArgIx, e = Args.size(); i != e; ++i) { 4226 QualType paramType; // ignored 4227 ExprResult arg = checkUnknownAnyArg(CallLoc, Args[i], paramType); 4228 Invalid |= arg.isInvalid(); 4229 AllArgs.push_back(arg.take()); 4230 } 4231 4232 // Otherwise do argument promotion, (C99 6.5.2.2p7). 4233 } else { 4234 for (unsigned i = ArgIx, e = Args.size(); i != e; ++i) { 4235 ExprResult Arg = DefaultVariadicArgumentPromotion(Args[i], CallType, 4236 FDecl); 4237 Invalid |= Arg.isInvalid(); 4238 AllArgs.push_back(Arg.take()); 4239 } 4240 } 4241 4242 // Check for array bounds violations. 4243 for (unsigned i = ArgIx, e = Args.size(); i != e; ++i) 4244 CheckArrayAccess(Args[i]); 4245 } 4246 return Invalid; 4247 } 4248 4249 static void DiagnoseCalleeStaticArrayParam(Sema &S, ParmVarDecl *PVD) { 4250 TypeLoc TL = PVD->getTypeSourceInfo()->getTypeLoc(); 4251 if (DecayedTypeLoc DTL = TL.getAs<DecayedTypeLoc>()) 4252 TL = DTL.getOriginalLoc(); 4253 if (ArrayTypeLoc ATL = TL.getAs<ArrayTypeLoc>()) 4254 S.Diag(PVD->getLocation(), diag::note_callee_static_array) 4255 << ATL.getLocalSourceRange(); 4256 } 4257 4258 /// CheckStaticArrayArgument - If the given argument corresponds to a static 4259 /// array parameter, check that it is non-null, and that if it is formed by 4260 /// array-to-pointer decay, the underlying array is sufficiently large. 4261 /// 4262 /// C99 6.7.5.3p7: If the keyword static also appears within the [ and ] of the 4263 /// array type derivation, then for each call to the function, the value of the 4264 /// corresponding actual argument shall provide access to the first element of 4265 /// an array with at least as many elements as specified by the size expression. 4266 void 4267 Sema::CheckStaticArrayArgument(SourceLocation CallLoc, 4268 ParmVarDecl *Param, 4269 const Expr *ArgExpr) { 4270 // Static array parameters are not supported in C++. 4271 if (!Param || getLangOpts().CPlusPlus) 4272 return; 4273 4274 QualType OrigTy = Param->getOriginalType(); 4275 4276 const ArrayType *AT = Context.getAsArrayType(OrigTy); 4277 if (!AT || AT->getSizeModifier() != ArrayType::Static) 4278 return; 4279 4280 if (ArgExpr->isNullPointerConstant(Context, 4281 Expr::NPC_NeverValueDependent)) { 4282 Diag(CallLoc, diag::warn_null_arg) << ArgExpr->getSourceRange(); 4283 DiagnoseCalleeStaticArrayParam(*this, Param); 4284 return; 4285 } 4286 4287 const ConstantArrayType *CAT = dyn_cast<ConstantArrayType>(AT); 4288 if (!CAT) 4289 return; 4290 4291 const ConstantArrayType *ArgCAT = 4292 Context.getAsConstantArrayType(ArgExpr->IgnoreParenImpCasts()->getType()); 4293 if (!ArgCAT) 4294 return; 4295 4296 if (ArgCAT->getSize().ult(CAT->getSize())) { 4297 Diag(CallLoc, diag::warn_static_array_too_small) 4298 << ArgExpr->getSourceRange() 4299 << (unsigned) ArgCAT->getSize().getZExtValue() 4300 << (unsigned) CAT->getSize().getZExtValue(); 4301 DiagnoseCalleeStaticArrayParam(*this, Param); 4302 } 4303 } 4304 4305 /// Given a function expression of unknown-any type, try to rebuild it 4306 /// to have a function type. 4307 static ExprResult rebuildUnknownAnyFunction(Sema &S, Expr *fn); 4308 4309 /// Is the given type a placeholder that we need to lower out 4310 /// immediately during argument processing? 4311 static bool isPlaceholderToRemoveAsArg(QualType type) { 4312 // Placeholders are never sugared. 4313 const BuiltinType *placeholder = dyn_cast<BuiltinType>(type); 4314 if (!placeholder) return false; 4315 4316 switch (placeholder->getKind()) { 4317 // Ignore all the non-placeholder types. 4318 #define PLACEHOLDER_TYPE(ID, SINGLETON_ID) 4319 #define BUILTIN_TYPE(ID, SINGLETON_ID) case BuiltinType::ID: 4320 #include "clang/AST/BuiltinTypes.def" 4321 return false; 4322 4323 // We cannot lower out overload sets; they might validly be resolved 4324 // by the call machinery. 4325 case BuiltinType::Overload: 4326 return false; 4327 4328 // Unbridged casts in ARC can be handled in some call positions and 4329 // should be left in place. 4330 case BuiltinType::ARCUnbridgedCast: 4331 return false; 4332 4333 // Pseudo-objects should be converted as soon as possible. 4334 case BuiltinType::PseudoObject: 4335 return true; 4336 4337 // The debugger mode could theoretically but currently does not try 4338 // to resolve unknown-typed arguments based on known parameter types. 4339 case BuiltinType::UnknownAny: 4340 return true; 4341 4342 // These are always invalid as call arguments and should be reported. 4343 case BuiltinType::BoundMember: 4344 case BuiltinType::BuiltinFn: 4345 return true; 4346 } 4347 llvm_unreachable("bad builtin type kind"); 4348 } 4349 4350 /// Check an argument list for placeholders that we won't try to 4351 /// handle later. 4352 static bool checkArgsForPlaceholders(Sema &S, MultiExprArg args) { 4353 // Apply this processing to all the arguments at once instead of 4354 // dying at the first failure. 4355 bool hasInvalid = false; 4356 for (size_t i = 0, e = args.size(); i != e; i++) { 4357 if (isPlaceholderToRemoveAsArg(args[i]->getType())) { 4358 ExprResult result = S.CheckPlaceholderExpr(args[i]); 4359 if (result.isInvalid()) hasInvalid = true; 4360 else args[i] = result.take(); 4361 } 4362 } 4363 return hasInvalid; 4364 } 4365 4366 /// ActOnCallExpr - Handle a call to Fn with the specified array of arguments. 4367 /// This provides the location of the left/right parens and a list of comma 4368 /// locations. 4369 ExprResult 4370 Sema::ActOnCallExpr(Scope *S, Expr *Fn, SourceLocation LParenLoc, 4371 MultiExprArg ArgExprs, SourceLocation RParenLoc, 4372 Expr *ExecConfig, bool IsExecConfig) { 4373 // Since this might be a postfix expression, get rid of ParenListExprs. 4374 ExprResult Result = MaybeConvertParenListExprToParenExpr(S, Fn); 4375 if (Result.isInvalid()) return ExprError(); 4376 Fn = Result.take(); 4377 4378 if (checkArgsForPlaceholders(*this, ArgExprs)) 4379 return ExprError(); 4380 4381 if (getLangOpts().CPlusPlus) { 4382 // If this is a pseudo-destructor expression, build the call immediately. 4383 if (isa<CXXPseudoDestructorExpr>(Fn)) { 4384 if (!ArgExprs.empty()) { 4385 // Pseudo-destructor calls should not have any arguments. 4386 Diag(Fn->getLocStart(), diag::err_pseudo_dtor_call_with_args) 4387 << FixItHint::CreateRemoval( 4388 SourceRange(ArgExprs[0]->getLocStart(), 4389 ArgExprs.back()->getLocEnd())); 4390 } 4391 4392 return Owned(new (Context) CallExpr(Context, Fn, None, 4393 Context.VoidTy, VK_RValue, 4394 RParenLoc)); 4395 } 4396 if (Fn->getType() == Context.PseudoObjectTy) { 4397 ExprResult result = CheckPlaceholderExpr(Fn); 4398 if (result.isInvalid()) return ExprError(); 4399 Fn = result.take(); 4400 } 4401 4402 // Determine whether this is a dependent call inside a C++ template, 4403 // in which case we won't do any semantic analysis now. 4404 // FIXME: Will need to cache the results of name lookup (including ADL) in 4405 // Fn. 4406 bool Dependent = false; 4407 if (Fn->isTypeDependent()) 4408 Dependent = true; 4409 else if (Expr::hasAnyTypeDependentArguments(ArgExprs)) 4410 Dependent = true; 4411 4412 if (Dependent) { 4413 if (ExecConfig) { 4414 return Owned(new (Context) CUDAKernelCallExpr( 4415 Context, Fn, cast<CallExpr>(ExecConfig), ArgExprs, 4416 Context.DependentTy, VK_RValue, RParenLoc)); 4417 } else { 4418 return Owned(new (Context) CallExpr(Context, Fn, ArgExprs, 4419 Context.DependentTy, VK_RValue, 4420 RParenLoc)); 4421 } 4422 } 4423 4424 // Determine whether this is a call to an object (C++ [over.call.object]). 4425 if (Fn->getType()->isRecordType()) 4426 return Owned(BuildCallToObjectOfClassType(S, Fn, LParenLoc, 4427 ArgExprs, RParenLoc)); 4428 4429 if (Fn->getType() == Context.UnknownAnyTy) { 4430 ExprResult result = rebuildUnknownAnyFunction(*this, Fn); 4431 if (result.isInvalid()) return ExprError(); 4432 Fn = result.take(); 4433 } 4434 4435 if (Fn->getType() == Context.BoundMemberTy) { 4436 return BuildCallToMemberFunction(S, Fn, LParenLoc, ArgExprs, RParenLoc); 4437 } 4438 } 4439 4440 // Check for overloaded calls. This can happen even in C due to extensions. 4441 if (Fn->getType() == Context.OverloadTy) { 4442 OverloadExpr::FindResult find = OverloadExpr::find(Fn); 4443 4444 // We aren't supposed to apply this logic for if there's an '&' involved. 4445 if (!find.HasFormOfMemberPointer) { 4446 OverloadExpr *ovl = find.Expression; 4447 if (isa<UnresolvedLookupExpr>(ovl)) { 4448 UnresolvedLookupExpr *ULE = cast<UnresolvedLookupExpr>(ovl); 4449 return BuildOverloadedCallExpr(S, Fn, ULE, LParenLoc, ArgExprs, 4450 RParenLoc, ExecConfig); 4451 } else { 4452 return BuildCallToMemberFunction(S, Fn, LParenLoc, ArgExprs, 4453 RParenLoc); 4454 } 4455 } 4456 } 4457 4458 // If we're directly calling a function, get the appropriate declaration. 4459 if (Fn->getType() == Context.UnknownAnyTy) { 4460 ExprResult result = rebuildUnknownAnyFunction(*this, Fn); 4461 if (result.isInvalid()) return ExprError(); 4462 Fn = result.take(); 4463 } 4464 4465 Expr *NakedFn = Fn->IgnoreParens(); 4466 4467 NamedDecl *NDecl = 0; 4468 if (UnaryOperator *UnOp = dyn_cast<UnaryOperator>(NakedFn)) 4469 if (UnOp->getOpcode() == UO_AddrOf) 4470 NakedFn = UnOp->getSubExpr()->IgnoreParens(); 4471 4472 if (isa<DeclRefExpr>(NakedFn)) 4473 NDecl = cast<DeclRefExpr>(NakedFn)->getDecl(); 4474 else if (isa<MemberExpr>(NakedFn)) 4475 NDecl = cast<MemberExpr>(NakedFn)->getMemberDecl(); 4476 4477 if (FunctionDecl *FD = dyn_cast_or_null<FunctionDecl>(NDecl)) { 4478 if (FD->hasAttr<EnableIfAttr>()) { 4479 if (const EnableIfAttr *Attr = CheckEnableIf(FD, ArgExprs, true)) { 4480 Diag(Fn->getLocStart(), 4481 isa<CXXMethodDecl>(FD) ? 4482 diag::err_ovl_no_viable_member_function_in_call : 4483 diag::err_ovl_no_viable_function_in_call) 4484 << FD << FD->getSourceRange(); 4485 Diag(FD->getLocation(), 4486 diag::note_ovl_candidate_disabled_by_enable_if_attr) 4487 << Attr->getCond()->getSourceRange() << Attr->getMessage(); 4488 } 4489 } 4490 } 4491 4492 return BuildResolvedCallExpr(Fn, NDecl, LParenLoc, ArgExprs, RParenLoc, 4493 ExecConfig, IsExecConfig); 4494 } 4495 4496 ExprResult 4497 Sema::ActOnCUDAExecConfigExpr(Scope *S, SourceLocation LLLLoc, 4498 MultiExprArg ExecConfig, SourceLocation GGGLoc) { 4499 FunctionDecl *ConfigDecl = Context.getcudaConfigureCallDecl(); 4500 if (!ConfigDecl) 4501 return ExprError(Diag(LLLLoc, diag::err_undeclared_var_use) 4502 << "cudaConfigureCall"); 4503 QualType ConfigQTy = ConfigDecl->getType(); 4504 4505 DeclRefExpr *ConfigDR = new (Context) DeclRefExpr( 4506 ConfigDecl, false, ConfigQTy, VK_LValue, LLLLoc); 4507 MarkFunctionReferenced(LLLLoc, ConfigDecl); 4508 4509 return ActOnCallExpr(S, ConfigDR, LLLLoc, ExecConfig, GGGLoc, 0, 4510 /*IsExecConfig=*/true); 4511 } 4512 4513 /// ActOnAsTypeExpr - create a new asType (bitcast) from the arguments. 4514 /// 4515 /// __builtin_astype( value, dst type ) 4516 /// 4517 ExprResult Sema::ActOnAsTypeExpr(Expr *E, ParsedType ParsedDestTy, 4518 SourceLocation BuiltinLoc, 4519 SourceLocation RParenLoc) { 4520 ExprValueKind VK = VK_RValue; 4521 ExprObjectKind OK = OK_Ordinary; 4522 QualType DstTy = GetTypeFromParser(ParsedDestTy); 4523 QualType SrcTy = E->getType(); 4524 if (Context.getTypeSize(DstTy) != Context.getTypeSize(SrcTy)) 4525 return ExprError(Diag(BuiltinLoc, 4526 diag::err_invalid_astype_of_different_size) 4527 << DstTy 4528 << SrcTy 4529 << E->getSourceRange()); 4530 return Owned(new (Context) AsTypeExpr(E, DstTy, VK, OK, BuiltinLoc, 4531 RParenLoc)); 4532 } 4533 4534 /// ActOnConvertVectorExpr - create a new convert-vector expression from the 4535 /// provided arguments. 4536 /// 4537 /// __builtin_convertvector( value, dst type ) 4538 /// 4539 ExprResult Sema::ActOnConvertVectorExpr(Expr *E, ParsedType ParsedDestTy, 4540 SourceLocation BuiltinLoc, 4541 SourceLocation RParenLoc) { 4542 TypeSourceInfo *TInfo; 4543 GetTypeFromParser(ParsedDestTy, &TInfo); 4544 return SemaConvertVectorExpr(E, TInfo, BuiltinLoc, RParenLoc); 4545 } 4546 4547 /// BuildResolvedCallExpr - Build a call to a resolved expression, 4548 /// i.e. an expression not of \p OverloadTy. The expression should 4549 /// unary-convert to an expression of function-pointer or 4550 /// block-pointer type. 4551 /// 4552 /// \param NDecl the declaration being called, if available 4553 ExprResult 4554 Sema::BuildResolvedCallExpr(Expr *Fn, NamedDecl *NDecl, 4555 SourceLocation LParenLoc, 4556 ArrayRef<Expr *> Args, 4557 SourceLocation RParenLoc, 4558 Expr *Config, bool IsExecConfig) { 4559 FunctionDecl *FDecl = dyn_cast_or_null<FunctionDecl>(NDecl); 4560 unsigned BuiltinID = (FDecl ? FDecl->getBuiltinID() : 0); 4561 4562 // Promote the function operand. 4563 // We special-case function promotion here because we only allow promoting 4564 // builtin functions to function pointers in the callee of a call. 4565 ExprResult Result; 4566 if (BuiltinID && 4567 Fn->getType()->isSpecificBuiltinType(BuiltinType::BuiltinFn)) { 4568 Result = ImpCastExprToType(Fn, Context.getPointerType(FDecl->getType()), 4569 CK_BuiltinFnToFnPtr).take(); 4570 } else { 4571 Result = UsualUnaryConversions(Fn); 4572 } 4573 if (Result.isInvalid()) 4574 return ExprError(); 4575 Fn = Result.take(); 4576 4577 // Make the call expr early, before semantic checks. This guarantees cleanup 4578 // of arguments and function on error. 4579 CallExpr *TheCall; 4580 if (Config) 4581 TheCall = new (Context) CUDAKernelCallExpr(Context, Fn, 4582 cast<CallExpr>(Config), Args, 4583 Context.BoolTy, VK_RValue, 4584 RParenLoc); 4585 else 4586 TheCall = new (Context) CallExpr(Context, Fn, Args, Context.BoolTy, 4587 VK_RValue, RParenLoc); 4588 4589 // Bail out early if calling a builtin with custom typechecking. 4590 if (BuiltinID && Context.BuiltinInfo.hasCustomTypechecking(BuiltinID)) 4591 return CheckBuiltinFunctionCall(BuiltinID, TheCall); 4592 4593 retry: 4594 const FunctionType *FuncT; 4595 if (const PointerType *PT = Fn->getType()->getAs<PointerType>()) { 4596 // C99 6.5.2.2p1 - "The expression that denotes the called function shall 4597 // have type pointer to function". 4598 FuncT = PT->getPointeeType()->getAs<FunctionType>(); 4599 if (FuncT == 0) 4600 return ExprError(Diag(LParenLoc, diag::err_typecheck_call_not_function) 4601 << Fn->getType() << Fn->getSourceRange()); 4602 } else if (const BlockPointerType *BPT = 4603 Fn->getType()->getAs<BlockPointerType>()) { 4604 FuncT = BPT->getPointeeType()->castAs<FunctionType>(); 4605 } else { 4606 // Handle calls to expressions of unknown-any type. 4607 if (Fn->getType() == Context.UnknownAnyTy) { 4608 ExprResult rewrite = rebuildUnknownAnyFunction(*this, Fn); 4609 if (rewrite.isInvalid()) return ExprError(); 4610 Fn = rewrite.take(); 4611 TheCall->setCallee(Fn); 4612 goto retry; 4613 } 4614 4615 return ExprError(Diag(LParenLoc, diag::err_typecheck_call_not_function) 4616 << Fn->getType() << Fn->getSourceRange()); 4617 } 4618 4619 if (getLangOpts().CUDA) { 4620 if (Config) { 4621 // CUDA: Kernel calls must be to global functions 4622 if (FDecl && !FDecl->hasAttr<CUDAGlobalAttr>()) 4623 return ExprError(Diag(LParenLoc,diag::err_kern_call_not_global_function) 4624 << FDecl->getName() << Fn->getSourceRange()); 4625 4626 // CUDA: Kernel function must have 'void' return type 4627 if (!FuncT->getResultType()->isVoidType()) 4628 return ExprError(Diag(LParenLoc, diag::err_kern_type_not_void_return) 4629 << Fn->getType() << Fn->getSourceRange()); 4630 } else { 4631 // CUDA: Calls to global functions must be configured 4632 if (FDecl && FDecl->hasAttr<CUDAGlobalAttr>()) 4633 return ExprError(Diag(LParenLoc, diag::err_global_call_not_config) 4634 << FDecl->getName() << Fn->getSourceRange()); 4635 } 4636 } 4637 4638 // Check for a valid return type 4639 if (CheckCallReturnType(FuncT->getResultType(), 4640 Fn->getLocStart(), TheCall, 4641 FDecl)) 4642 return ExprError(); 4643 4644 // We know the result type of the call, set it. 4645 TheCall->setType(FuncT->getCallResultType(Context)); 4646 TheCall->setValueKind(Expr::getValueKindForType(FuncT->getResultType())); 4647 4648 const FunctionProtoType *Proto = dyn_cast<FunctionProtoType>(FuncT); 4649 if (Proto) { 4650 if (ConvertArgumentsForCall(TheCall, Fn, FDecl, Proto, Args, RParenLoc, 4651 IsExecConfig)) 4652 return ExprError(); 4653 } else { 4654 assert(isa<FunctionNoProtoType>(FuncT) && "Unknown FunctionType!"); 4655 4656 if (FDecl) { 4657 // Check if we have too few/too many template arguments, based 4658 // on our knowledge of the function definition. 4659 const FunctionDecl *Def = 0; 4660 if (FDecl->hasBody(Def) && Args.size() != Def->param_size()) { 4661 Proto = Def->getType()->getAs<FunctionProtoType>(); 4662 if (!Proto || !(Proto->isVariadic() && Args.size() >= Def->param_size())) 4663 Diag(RParenLoc, diag::warn_call_wrong_number_of_arguments) 4664 << (Args.size() > Def->param_size()) << FDecl << Fn->getSourceRange(); 4665 } 4666 4667 // If the function we're calling isn't a function prototype, but we have 4668 // a function prototype from a prior declaratiom, use that prototype. 4669 if (!FDecl->hasPrototype()) 4670 Proto = FDecl->getType()->getAs<FunctionProtoType>(); 4671 } 4672 4673 // Promote the arguments (C99 6.5.2.2p6). 4674 for (unsigned i = 0, e = Args.size(); i != e; i++) { 4675 Expr *Arg = Args[i]; 4676 4677 if (Proto && i < Proto->getNumArgs()) { 4678 InitializedEntity Entity 4679 = InitializedEntity::InitializeParameter(Context, 4680 Proto->getArgType(i), 4681 Proto->isArgConsumed(i)); 4682 ExprResult ArgE = PerformCopyInitialization(Entity, 4683 SourceLocation(), 4684 Owned(Arg)); 4685 if (ArgE.isInvalid()) 4686 return true; 4687 4688 Arg = ArgE.takeAs<Expr>(); 4689 4690 } else { 4691 ExprResult ArgE = DefaultArgumentPromotion(Arg); 4692 4693 if (ArgE.isInvalid()) 4694 return true; 4695 4696 Arg = ArgE.takeAs<Expr>(); 4697 } 4698 4699 if (RequireCompleteType(Arg->getLocStart(), 4700 Arg->getType(), 4701 diag::err_call_incomplete_argument, Arg)) 4702 return ExprError(); 4703 4704 TheCall->setArg(i, Arg); 4705 } 4706 } 4707 4708 if (CXXMethodDecl *Method = dyn_cast_or_null<CXXMethodDecl>(FDecl)) 4709 if (!Method->isStatic()) 4710 return ExprError(Diag(LParenLoc, diag::err_member_call_without_object) 4711 << Fn->getSourceRange()); 4712 4713 // Check for sentinels 4714 if (NDecl) 4715 DiagnoseSentinelCalls(NDecl, LParenLoc, Args); 4716 4717 // Do special checking on direct calls to functions. 4718 if (FDecl) { 4719 if (CheckFunctionCall(FDecl, TheCall, Proto)) 4720 return ExprError(); 4721 4722 if (BuiltinID) 4723 return CheckBuiltinFunctionCall(BuiltinID, TheCall); 4724 } else if (NDecl) { 4725 if (CheckPointerCall(NDecl, TheCall, Proto)) 4726 return ExprError(); 4727 } else { 4728 if (CheckOtherCall(TheCall, Proto)) 4729 return ExprError(); 4730 } 4731 4732 return MaybeBindToTemporary(TheCall); 4733 } 4734 4735 ExprResult 4736 Sema::ActOnCompoundLiteral(SourceLocation LParenLoc, ParsedType Ty, 4737 SourceLocation RParenLoc, Expr *InitExpr) { 4738 assert(Ty && "ActOnCompoundLiteral(): missing type"); 4739 // FIXME: put back this assert when initializers are worked out. 4740 //assert((InitExpr != 0) && "ActOnCompoundLiteral(): missing expression"); 4741 4742 TypeSourceInfo *TInfo; 4743 QualType literalType = GetTypeFromParser(Ty, &TInfo); 4744 if (!TInfo) 4745 TInfo = Context.getTrivialTypeSourceInfo(literalType); 4746 4747 return BuildCompoundLiteralExpr(LParenLoc, TInfo, RParenLoc, InitExpr); 4748 } 4749 4750 ExprResult 4751 Sema::BuildCompoundLiteralExpr(SourceLocation LParenLoc, TypeSourceInfo *TInfo, 4752 SourceLocation RParenLoc, Expr *LiteralExpr) { 4753 QualType literalType = TInfo->getType(); 4754 4755 if (literalType->isArrayType()) { 4756 if (RequireCompleteType(LParenLoc, Context.getBaseElementType(literalType), 4757 diag::err_illegal_decl_array_incomplete_type, 4758 SourceRange(LParenLoc, 4759 LiteralExpr->getSourceRange().getEnd()))) 4760 return ExprError(); 4761 if (literalType->isVariableArrayType()) 4762 return ExprError(Diag(LParenLoc, diag::err_variable_object_no_init) 4763 << SourceRange(LParenLoc, LiteralExpr->getSourceRange().getEnd())); 4764 } else if (!literalType->isDependentType() && 4765 RequireCompleteType(LParenLoc, literalType, 4766 diag::err_typecheck_decl_incomplete_type, 4767 SourceRange(LParenLoc, LiteralExpr->getSourceRange().getEnd()))) 4768 return ExprError(); 4769 4770 InitializedEntity Entity 4771 = InitializedEntity::InitializeCompoundLiteralInit(TInfo); 4772 InitializationKind Kind 4773 = InitializationKind::CreateCStyleCast(LParenLoc, 4774 SourceRange(LParenLoc, RParenLoc), 4775 /*InitList=*/true); 4776 InitializationSequence InitSeq(*this, Entity, Kind, LiteralExpr); 4777 ExprResult Result = InitSeq.Perform(*this, Entity, Kind, LiteralExpr, 4778 &literalType); 4779 if (Result.isInvalid()) 4780 return ExprError(); 4781 LiteralExpr = Result.get(); 4782 4783 bool isFileScope = getCurFunctionOrMethodDecl() == 0; 4784 if (isFileScope && 4785 !LiteralExpr->isTypeDependent() && 4786 !LiteralExpr->isValueDependent() && 4787 !literalType->isDependentType()) { // 6.5.2.5p3 4788 if (CheckForConstantInitializer(LiteralExpr, literalType)) 4789 return ExprError(); 4790 } 4791 4792 // In C, compound literals are l-values for some reason. 4793 ExprValueKind VK = getLangOpts().CPlusPlus ? VK_RValue : VK_LValue; 4794 4795 return MaybeBindToTemporary( 4796 new (Context) CompoundLiteralExpr(LParenLoc, TInfo, literalType, 4797 VK, LiteralExpr, isFileScope)); 4798 } 4799 4800 ExprResult 4801 Sema::ActOnInitList(SourceLocation LBraceLoc, MultiExprArg InitArgList, 4802 SourceLocation RBraceLoc) { 4803 // Immediately handle non-overload placeholders. Overloads can be 4804 // resolved contextually, but everything else here can't. 4805 for (unsigned I = 0, E = InitArgList.size(); I != E; ++I) { 4806 if (InitArgList[I]->getType()->isNonOverloadPlaceholderType()) { 4807 ExprResult result = CheckPlaceholderExpr(InitArgList[I]); 4808 4809 // Ignore failures; dropping the entire initializer list because 4810 // of one failure would be terrible for indexing/etc. 4811 if (result.isInvalid()) continue; 4812 4813 InitArgList[I] = result.take(); 4814 } 4815 } 4816 4817 // Semantic analysis for initializers is done by ActOnDeclarator() and 4818 // CheckInitializer() - it requires knowledge of the object being intialized. 4819 4820 InitListExpr *E = new (Context) InitListExpr(Context, LBraceLoc, InitArgList, 4821 RBraceLoc); 4822 E->setType(Context.VoidTy); // FIXME: just a place holder for now. 4823 return Owned(E); 4824 } 4825 4826 /// Do an explicit extend of the given block pointer if we're in ARC. 4827 static void maybeExtendBlockObject(Sema &S, ExprResult &E) { 4828 assert(E.get()->getType()->isBlockPointerType()); 4829 assert(E.get()->isRValue()); 4830 4831 // Only do this in an r-value context. 4832 if (!S.getLangOpts().ObjCAutoRefCount) return; 4833 4834 E = ImplicitCastExpr::Create(S.Context, E.get()->getType(), 4835 CK_ARCExtendBlockObject, E.get(), 4836 /*base path*/ 0, VK_RValue); 4837 S.ExprNeedsCleanups = true; 4838 } 4839 4840 /// Prepare a conversion of the given expression to an ObjC object 4841 /// pointer type. 4842 CastKind Sema::PrepareCastToObjCObjectPointer(ExprResult &E) { 4843 QualType type = E.get()->getType(); 4844 if (type->isObjCObjectPointerType()) { 4845 return CK_BitCast; 4846 } else if (type->isBlockPointerType()) { 4847 maybeExtendBlockObject(*this, E); 4848 return CK_BlockPointerToObjCPointerCast; 4849 } else { 4850 assert(type->isPointerType()); 4851 return CK_CPointerToObjCPointerCast; 4852 } 4853 } 4854 4855 /// Prepares for a scalar cast, performing all the necessary stages 4856 /// except the final cast and returning the kind required. 4857 CastKind Sema::PrepareScalarCast(ExprResult &Src, QualType DestTy) { 4858 // Both Src and Dest are scalar types, i.e. arithmetic or pointer. 4859 // Also, callers should have filtered out the invalid cases with 4860 // pointers. Everything else should be possible. 4861 4862 QualType SrcTy = Src.get()->getType(); 4863 if (Context.hasSameUnqualifiedType(SrcTy, DestTy)) 4864 return CK_NoOp; 4865 4866 switch (Type::ScalarTypeKind SrcKind = SrcTy->getScalarTypeKind()) { 4867 case Type::STK_MemberPointer: 4868 llvm_unreachable("member pointer type in C"); 4869 4870 case Type::STK_CPointer: 4871 case Type::STK_BlockPointer: 4872 case Type::STK_ObjCObjectPointer: 4873 switch (DestTy->getScalarTypeKind()) { 4874 case Type::STK_CPointer: { 4875 unsigned SrcAS = SrcTy->getPointeeType().getAddressSpace(); 4876 unsigned DestAS = DestTy->getPointeeType().getAddressSpace(); 4877 if (SrcAS != DestAS) 4878 return CK_AddressSpaceConversion; 4879 return CK_BitCast; 4880 } 4881 case Type::STK_BlockPointer: 4882 return (SrcKind == Type::STK_BlockPointer 4883 ? CK_BitCast : CK_AnyPointerToBlockPointerCast); 4884 case Type::STK_ObjCObjectPointer: 4885 if (SrcKind == Type::STK_ObjCObjectPointer) 4886 return CK_BitCast; 4887 if (SrcKind == Type::STK_CPointer) 4888 return CK_CPointerToObjCPointerCast; 4889 maybeExtendBlockObject(*this, Src); 4890 return CK_BlockPointerToObjCPointerCast; 4891 case Type::STK_Bool: 4892 return CK_PointerToBoolean; 4893 case Type::STK_Integral: 4894 return CK_PointerToIntegral; 4895 case Type::STK_Floating: 4896 case Type::STK_FloatingComplex: 4897 case Type::STK_IntegralComplex: 4898 case Type::STK_MemberPointer: 4899 llvm_unreachable("illegal cast from pointer"); 4900 } 4901 llvm_unreachable("Should have returned before this"); 4902 4903 case Type::STK_Bool: // casting from bool is like casting from an integer 4904 case Type::STK_Integral: 4905 switch (DestTy->getScalarTypeKind()) { 4906 case Type::STK_CPointer: 4907 case Type::STK_ObjCObjectPointer: 4908 case Type::STK_BlockPointer: 4909 if (Src.get()->isNullPointerConstant(Context, 4910 Expr::NPC_ValueDependentIsNull)) 4911 return CK_NullToPointer; 4912 return CK_IntegralToPointer; 4913 case Type::STK_Bool: 4914 return CK_IntegralToBoolean; 4915 case Type::STK_Integral: 4916 return CK_IntegralCast; 4917 case Type::STK_Floating: 4918 return CK_IntegralToFloating; 4919 case Type::STK_IntegralComplex: 4920 Src = ImpCastExprToType(Src.take(), 4921 DestTy->castAs<ComplexType>()->getElementType(), 4922 CK_IntegralCast); 4923 return CK_IntegralRealToComplex; 4924 case Type::STK_FloatingComplex: 4925 Src = ImpCastExprToType(Src.take(), 4926 DestTy->castAs<ComplexType>()->getElementType(), 4927 CK_IntegralToFloating); 4928 return CK_FloatingRealToComplex; 4929 case Type::STK_MemberPointer: 4930 llvm_unreachable("member pointer type in C"); 4931 } 4932 llvm_unreachable("Should have returned before this"); 4933 4934 case Type::STK_Floating: 4935 switch (DestTy->getScalarTypeKind()) { 4936 case Type::STK_Floating: 4937 return CK_FloatingCast; 4938 case Type::STK_Bool: 4939 return CK_FloatingToBoolean; 4940 case Type::STK_Integral: 4941 return CK_FloatingToIntegral; 4942 case Type::STK_FloatingComplex: 4943 Src = ImpCastExprToType(Src.take(), 4944 DestTy->castAs<ComplexType>()->getElementType(), 4945 CK_FloatingCast); 4946 return CK_FloatingRealToComplex; 4947 case Type::STK_IntegralComplex: 4948 Src = ImpCastExprToType(Src.take(), 4949 DestTy->castAs<ComplexType>()->getElementType(), 4950 CK_FloatingToIntegral); 4951 return CK_IntegralRealToComplex; 4952 case Type::STK_CPointer: 4953 case Type::STK_ObjCObjectPointer: 4954 case Type::STK_BlockPointer: 4955 llvm_unreachable("valid float->pointer cast?"); 4956 case Type::STK_MemberPointer: 4957 llvm_unreachable("member pointer type in C"); 4958 } 4959 llvm_unreachable("Should have returned before this"); 4960 4961 case Type::STK_FloatingComplex: 4962 switch (DestTy->getScalarTypeKind()) { 4963 case Type::STK_FloatingComplex: 4964 return CK_FloatingComplexCast; 4965 case Type::STK_IntegralComplex: 4966 return CK_FloatingComplexToIntegralComplex; 4967 case Type::STK_Floating: { 4968 QualType ET = SrcTy->castAs<ComplexType>()->getElementType(); 4969 if (Context.hasSameType(ET, DestTy)) 4970 return CK_FloatingComplexToReal; 4971 Src = ImpCastExprToType(Src.take(), ET, CK_FloatingComplexToReal); 4972 return CK_FloatingCast; 4973 } 4974 case Type::STK_Bool: 4975 return CK_FloatingComplexToBoolean; 4976 case Type::STK_Integral: 4977 Src = ImpCastExprToType(Src.take(), 4978 SrcTy->castAs<ComplexType>()->getElementType(), 4979 CK_FloatingComplexToReal); 4980 return CK_FloatingToIntegral; 4981 case Type::STK_CPointer: 4982 case Type::STK_ObjCObjectPointer: 4983 case Type::STK_BlockPointer: 4984 llvm_unreachable("valid complex float->pointer cast?"); 4985 case Type::STK_MemberPointer: 4986 llvm_unreachable("member pointer type in C"); 4987 } 4988 llvm_unreachable("Should have returned before this"); 4989 4990 case Type::STK_IntegralComplex: 4991 switch (DestTy->getScalarTypeKind()) { 4992 case Type::STK_FloatingComplex: 4993 return CK_IntegralComplexToFloatingComplex; 4994 case Type::STK_IntegralComplex: 4995 return CK_IntegralComplexCast; 4996 case Type::STK_Integral: { 4997 QualType ET = SrcTy->castAs<ComplexType>()->getElementType(); 4998 if (Context.hasSameType(ET, DestTy)) 4999 return CK_IntegralComplexToReal; 5000 Src = ImpCastExprToType(Src.take(), ET, CK_IntegralComplexToReal); 5001 return CK_IntegralCast; 5002 } 5003 case Type::STK_Bool: 5004 return CK_IntegralComplexToBoolean; 5005 case Type::STK_Floating: 5006 Src = ImpCastExprToType(Src.take(), 5007 SrcTy->castAs<ComplexType>()->getElementType(), 5008 CK_IntegralComplexToReal); 5009 return CK_IntegralToFloating; 5010 case Type::STK_CPointer: 5011 case Type::STK_ObjCObjectPointer: 5012 case Type::STK_BlockPointer: 5013 llvm_unreachable("valid complex int->pointer cast?"); 5014 case Type::STK_MemberPointer: 5015 llvm_unreachable("member pointer type in C"); 5016 } 5017 llvm_unreachable("Should have returned before this"); 5018 } 5019 5020 llvm_unreachable("Unhandled scalar cast"); 5021 } 5022 5023 bool Sema::CheckVectorCast(SourceRange R, QualType VectorTy, QualType Ty, 5024 CastKind &Kind) { 5025 assert(VectorTy->isVectorType() && "Not a vector type!"); 5026 5027 if (Ty->isVectorType() || Ty->isIntegerType()) { 5028 if (Context.getTypeSize(VectorTy) != Context.getTypeSize(Ty)) 5029 return Diag(R.getBegin(), 5030 Ty->isVectorType() ? 5031 diag::err_invalid_conversion_between_vectors : 5032 diag::err_invalid_conversion_between_vector_and_integer) 5033 << VectorTy << Ty << R; 5034 } else 5035 return Diag(R.getBegin(), 5036 diag::err_invalid_conversion_between_vector_and_scalar) 5037 << VectorTy << Ty << R; 5038 5039 Kind = CK_BitCast; 5040 return false; 5041 } 5042 5043 ExprResult Sema::CheckExtVectorCast(SourceRange R, QualType DestTy, 5044 Expr *CastExpr, CastKind &Kind) { 5045 assert(DestTy->isExtVectorType() && "Not an extended vector type!"); 5046 5047 QualType SrcTy = CastExpr->getType(); 5048 5049 // If SrcTy is a VectorType, the total size must match to explicitly cast to 5050 // an ExtVectorType. 5051 // In OpenCL, casts between vectors of different types are not allowed. 5052 // (See OpenCL 6.2). 5053 if (SrcTy->isVectorType()) { 5054 if (Context.getTypeSize(DestTy) != Context.getTypeSize(SrcTy) 5055 || (getLangOpts().OpenCL && 5056 (DestTy.getCanonicalType() != SrcTy.getCanonicalType()))) { 5057 Diag(R.getBegin(),diag::err_invalid_conversion_between_ext_vectors) 5058 << DestTy << SrcTy << R; 5059 return ExprError(); 5060 } 5061 Kind = CK_BitCast; 5062 return Owned(CastExpr); 5063 } 5064 5065 // All non-pointer scalars can be cast to ExtVector type. The appropriate 5066 // conversion will take place first from scalar to elt type, and then 5067 // splat from elt type to vector. 5068 if (SrcTy->isPointerType()) 5069 return Diag(R.getBegin(), 5070 diag::err_invalid_conversion_between_vector_and_scalar) 5071 << DestTy << SrcTy << R; 5072 5073 QualType DestElemTy = DestTy->getAs<ExtVectorType>()->getElementType(); 5074 ExprResult CastExprRes = Owned(CastExpr); 5075 CastKind CK = PrepareScalarCast(CastExprRes, DestElemTy); 5076 if (CastExprRes.isInvalid()) 5077 return ExprError(); 5078 CastExpr = ImpCastExprToType(CastExprRes.take(), DestElemTy, CK).take(); 5079 5080 Kind = CK_VectorSplat; 5081 return Owned(CastExpr); 5082 } 5083 5084 ExprResult 5085 Sema::ActOnCastExpr(Scope *S, SourceLocation LParenLoc, 5086 Declarator &D, ParsedType &Ty, 5087 SourceLocation RParenLoc, Expr *CastExpr) { 5088 assert(!D.isInvalidType() && (CastExpr != 0) && 5089 "ActOnCastExpr(): missing type or expr"); 5090 5091 TypeSourceInfo *castTInfo = GetTypeForDeclaratorCast(D, CastExpr->getType()); 5092 if (D.isInvalidType()) 5093 return ExprError(); 5094 5095 if (getLangOpts().CPlusPlus) { 5096 // Check that there are no default arguments (C++ only). 5097 CheckExtraCXXDefaultArguments(D); 5098 } 5099 5100 checkUnusedDeclAttributes(D); 5101 5102 QualType castType = castTInfo->getType(); 5103 Ty = CreateParsedType(castType, castTInfo); 5104 5105 bool isVectorLiteral = false; 5106 5107 // Check for an altivec or OpenCL literal, 5108 // i.e. all the elements are integer constants. 5109 ParenExpr *PE = dyn_cast<ParenExpr>(CastExpr); 5110 ParenListExpr *PLE = dyn_cast<ParenListExpr>(CastExpr); 5111 if ((getLangOpts().AltiVec || getLangOpts().OpenCL) 5112 && castType->isVectorType() && (PE || PLE)) { 5113 if (PLE && PLE->getNumExprs() == 0) { 5114 Diag(PLE->getExprLoc(), diag::err_altivec_empty_initializer); 5115 return ExprError(); 5116 } 5117 if (PE || PLE->getNumExprs() == 1) { 5118 Expr *E = (PE ? PE->getSubExpr() : PLE->getExpr(0)); 5119 if (!E->getType()->isVectorType()) 5120 isVectorLiteral = true; 5121 } 5122 else 5123 isVectorLiteral = true; 5124 } 5125 5126 // If this is a vector initializer, '(' type ')' '(' init, ..., init ')' 5127 // then handle it as such. 5128 if (isVectorLiteral) 5129 return BuildVectorLiteral(LParenLoc, RParenLoc, CastExpr, castTInfo); 5130 5131 // If the Expr being casted is a ParenListExpr, handle it specially. 5132 // This is not an AltiVec-style cast, so turn the ParenListExpr into a 5133 // sequence of BinOp comma operators. 5134 if (isa<ParenListExpr>(CastExpr)) { 5135 ExprResult Result = MaybeConvertParenListExprToParenExpr(S, CastExpr); 5136 if (Result.isInvalid()) return ExprError(); 5137 CastExpr = Result.take(); 5138 } 5139 5140 if (getLangOpts().CPlusPlus && !castType->isVoidType() && 5141 !getSourceManager().isInSystemMacro(LParenLoc)) 5142 Diag(LParenLoc, diag::warn_old_style_cast) << CastExpr->getSourceRange(); 5143 5144 return BuildCStyleCastExpr(LParenLoc, castTInfo, RParenLoc, CastExpr); 5145 } 5146 5147 ExprResult Sema::BuildVectorLiteral(SourceLocation LParenLoc, 5148 SourceLocation RParenLoc, Expr *E, 5149 TypeSourceInfo *TInfo) { 5150 assert((isa<ParenListExpr>(E) || isa<ParenExpr>(E)) && 5151 "Expected paren or paren list expression"); 5152 5153 Expr **exprs; 5154 unsigned numExprs; 5155 Expr *subExpr; 5156 SourceLocation LiteralLParenLoc, LiteralRParenLoc; 5157 if (ParenListExpr *PE = dyn_cast<ParenListExpr>(E)) { 5158 LiteralLParenLoc = PE->getLParenLoc(); 5159 LiteralRParenLoc = PE->getRParenLoc(); 5160 exprs = PE->getExprs(); 5161 numExprs = PE->getNumExprs(); 5162 } else { // isa<ParenExpr> by assertion at function entrance 5163 LiteralLParenLoc = cast<ParenExpr>(E)->getLParen(); 5164 LiteralRParenLoc = cast<ParenExpr>(E)->getRParen(); 5165 subExpr = cast<ParenExpr>(E)->getSubExpr(); 5166 exprs = &subExpr; 5167 numExprs = 1; 5168 } 5169 5170 QualType Ty = TInfo->getType(); 5171 assert(Ty->isVectorType() && "Expected vector type"); 5172 5173 SmallVector<Expr *, 8> initExprs; 5174 const VectorType *VTy = Ty->getAs<VectorType>(); 5175 unsigned numElems = Ty->getAs<VectorType>()->getNumElements(); 5176 5177 // '(...)' form of vector initialization in AltiVec: the number of 5178 // initializers must be one or must match the size of the vector. 5179 // If a single value is specified in the initializer then it will be 5180 // replicated to all the components of the vector 5181 if (VTy->getVectorKind() == VectorType::AltiVecVector) { 5182 // The number of initializers must be one or must match the size of the 5183 // vector. If a single value is specified in the initializer then it will 5184 // be replicated to all the components of the vector 5185 if (numExprs == 1) { 5186 QualType ElemTy = Ty->getAs<VectorType>()->getElementType(); 5187 ExprResult Literal = DefaultLvalueConversion(exprs[0]); 5188 if (Literal.isInvalid()) 5189 return ExprError(); 5190 Literal = ImpCastExprToType(Literal.take(), ElemTy, 5191 PrepareScalarCast(Literal, ElemTy)); 5192 return BuildCStyleCastExpr(LParenLoc, TInfo, RParenLoc, Literal.take()); 5193 } 5194 else if (numExprs < numElems) { 5195 Diag(E->getExprLoc(), 5196 diag::err_incorrect_number_of_vector_initializers); 5197 return ExprError(); 5198 } 5199 else 5200 initExprs.append(exprs, exprs + numExprs); 5201 } 5202 else { 5203 // For OpenCL, when the number of initializers is a single value, 5204 // it will be replicated to all components of the vector. 5205 if (getLangOpts().OpenCL && 5206 VTy->getVectorKind() == VectorType::GenericVector && 5207 numExprs == 1) { 5208 QualType ElemTy = Ty->getAs<VectorType>()->getElementType(); 5209 ExprResult Literal = DefaultLvalueConversion(exprs[0]); 5210 if (Literal.isInvalid()) 5211 return ExprError(); 5212 Literal = ImpCastExprToType(Literal.take(), ElemTy, 5213 PrepareScalarCast(Literal, ElemTy)); 5214 return BuildCStyleCastExpr(LParenLoc, TInfo, RParenLoc, Literal.take()); 5215 } 5216 5217 initExprs.append(exprs, exprs + numExprs); 5218 } 5219 // FIXME: This means that pretty-printing the final AST will produce curly 5220 // braces instead of the original commas. 5221 InitListExpr *initE = new (Context) InitListExpr(Context, LiteralLParenLoc, 5222 initExprs, LiteralRParenLoc); 5223 initE->setType(Ty); 5224 return BuildCompoundLiteralExpr(LParenLoc, TInfo, RParenLoc, initE); 5225 } 5226 5227 /// This is not an AltiVec-style cast or or C++ direct-initialization, so turn 5228 /// the ParenListExpr into a sequence of comma binary operators. 5229 ExprResult 5230 Sema::MaybeConvertParenListExprToParenExpr(Scope *S, Expr *OrigExpr) { 5231 ParenListExpr *E = dyn_cast<ParenListExpr>(OrigExpr); 5232 if (!E) 5233 return Owned(OrigExpr); 5234 5235 ExprResult Result(E->getExpr(0)); 5236 5237 for (unsigned i = 1, e = E->getNumExprs(); i != e && !Result.isInvalid(); ++i) 5238 Result = ActOnBinOp(S, E->getExprLoc(), tok::comma, Result.get(), 5239 E->getExpr(i)); 5240 5241 if (Result.isInvalid()) return ExprError(); 5242 5243 return ActOnParenExpr(E->getLParenLoc(), E->getRParenLoc(), Result.get()); 5244 } 5245 5246 ExprResult Sema::ActOnParenListExpr(SourceLocation L, 5247 SourceLocation R, 5248 MultiExprArg Val) { 5249 Expr *expr = new (Context) ParenListExpr(Context, L, Val, R); 5250 return Owned(expr); 5251 } 5252 5253 /// \brief Emit a specialized diagnostic when one expression is a null pointer 5254 /// constant and the other is not a pointer. Returns true if a diagnostic is 5255 /// emitted. 5256 bool Sema::DiagnoseConditionalForNull(Expr *LHSExpr, Expr *RHSExpr, 5257 SourceLocation QuestionLoc) { 5258 Expr *NullExpr = LHSExpr; 5259 Expr *NonPointerExpr = RHSExpr; 5260 Expr::NullPointerConstantKind NullKind = 5261 NullExpr->isNullPointerConstant(Context, 5262 Expr::NPC_ValueDependentIsNotNull); 5263 5264 if (NullKind == Expr::NPCK_NotNull) { 5265 NullExpr = RHSExpr; 5266 NonPointerExpr = LHSExpr; 5267 NullKind = 5268 NullExpr->isNullPointerConstant(Context, 5269 Expr::NPC_ValueDependentIsNotNull); 5270 } 5271 5272 if (NullKind == Expr::NPCK_NotNull) 5273 return false; 5274 5275 if (NullKind == Expr::NPCK_ZeroExpression) 5276 return false; 5277 5278 if (NullKind == Expr::NPCK_ZeroLiteral) { 5279 // In this case, check to make sure that we got here from a "NULL" 5280 // string in the source code. 5281 NullExpr = NullExpr->IgnoreParenImpCasts(); 5282 SourceLocation loc = NullExpr->getExprLoc(); 5283 if (!findMacroSpelling(loc, "NULL")) 5284 return false; 5285 } 5286 5287 int DiagType = (NullKind == Expr::NPCK_CXX11_nullptr); 5288 Diag(QuestionLoc, diag::err_typecheck_cond_incompatible_operands_null) 5289 << NonPointerExpr->getType() << DiagType 5290 << NonPointerExpr->getSourceRange(); 5291 return true; 5292 } 5293 5294 /// \brief Return false if the condition expression is valid, true otherwise. 5295 static bool checkCondition(Sema &S, Expr *Cond) { 5296 QualType CondTy = Cond->getType(); 5297 5298 // C99 6.5.15p2 5299 if (CondTy->isScalarType()) return false; 5300 5301 // OpenCL v1.1 s6.3.i says the condition is allowed to be a vector or scalar. 5302 if (S.getLangOpts().OpenCL && CondTy->isVectorType()) 5303 return false; 5304 5305 // Emit the proper error message. 5306 S.Diag(Cond->getLocStart(), S.getLangOpts().OpenCL ? 5307 diag::err_typecheck_cond_expect_scalar : 5308 diag::err_typecheck_cond_expect_scalar_or_vector) 5309 << CondTy; 5310 return true; 5311 } 5312 5313 /// \brief Return false if the two expressions can be converted to a vector, 5314 /// true otherwise 5315 static bool checkConditionalConvertScalarsToVectors(Sema &S, ExprResult &LHS, 5316 ExprResult &RHS, 5317 QualType CondTy) { 5318 // Both operands should be of scalar type. 5319 if (!LHS.get()->getType()->isScalarType()) { 5320 S.Diag(LHS.get()->getLocStart(), diag::err_typecheck_cond_expect_scalar) 5321 << CondTy; 5322 return true; 5323 } 5324 if (!RHS.get()->getType()->isScalarType()) { 5325 S.Diag(RHS.get()->getLocStart(), diag::err_typecheck_cond_expect_scalar) 5326 << CondTy; 5327 return true; 5328 } 5329 5330 // Implicity convert these scalars to the type of the condition. 5331 LHS = S.ImpCastExprToType(LHS.take(), CondTy, CK_IntegralCast); 5332 RHS = S.ImpCastExprToType(RHS.take(), CondTy, CK_IntegralCast); 5333 return false; 5334 } 5335 5336 /// \brief Handle when one or both operands are void type. 5337 static QualType checkConditionalVoidType(Sema &S, ExprResult &LHS, 5338 ExprResult &RHS) { 5339 Expr *LHSExpr = LHS.get(); 5340 Expr *RHSExpr = RHS.get(); 5341 5342 if (!LHSExpr->getType()->isVoidType()) 5343 S.Diag(RHSExpr->getLocStart(), diag::ext_typecheck_cond_one_void) 5344 << RHSExpr->getSourceRange(); 5345 if (!RHSExpr->getType()->isVoidType()) 5346 S.Diag(LHSExpr->getLocStart(), diag::ext_typecheck_cond_one_void) 5347 << LHSExpr->getSourceRange(); 5348 LHS = S.ImpCastExprToType(LHS.take(), S.Context.VoidTy, CK_ToVoid); 5349 RHS = S.ImpCastExprToType(RHS.take(), S.Context.VoidTy, CK_ToVoid); 5350 return S.Context.VoidTy; 5351 } 5352 5353 /// \brief Return false if the NullExpr can be promoted to PointerTy, 5354 /// true otherwise. 5355 static bool checkConditionalNullPointer(Sema &S, ExprResult &NullExpr, 5356 QualType PointerTy) { 5357 if ((!PointerTy->isAnyPointerType() && !PointerTy->isBlockPointerType()) || 5358 !NullExpr.get()->isNullPointerConstant(S.Context, 5359 Expr::NPC_ValueDependentIsNull)) 5360 return true; 5361 5362 NullExpr = S.ImpCastExprToType(NullExpr.take(), PointerTy, CK_NullToPointer); 5363 return false; 5364 } 5365 5366 /// \brief Checks compatibility between two pointers and return the resulting 5367 /// type. 5368 static QualType checkConditionalPointerCompatibility(Sema &S, ExprResult &LHS, 5369 ExprResult &RHS, 5370 SourceLocation Loc) { 5371 QualType LHSTy = LHS.get()->getType(); 5372 QualType RHSTy = RHS.get()->getType(); 5373 5374 if (S.Context.hasSameType(LHSTy, RHSTy)) { 5375 // Two identical pointers types are always compatible. 5376 return LHSTy; 5377 } 5378 5379 QualType lhptee, rhptee; 5380 5381 // Get the pointee types. 5382 bool IsBlockPointer = false; 5383 if (const BlockPointerType *LHSBTy = LHSTy->getAs<BlockPointerType>()) { 5384 lhptee = LHSBTy->getPointeeType(); 5385 rhptee = RHSTy->castAs<BlockPointerType>()->getPointeeType(); 5386 IsBlockPointer = true; 5387 } else { 5388 lhptee = LHSTy->castAs<PointerType>()->getPointeeType(); 5389 rhptee = RHSTy->castAs<PointerType>()->getPointeeType(); 5390 } 5391 5392 // C99 6.5.15p6: If both operands are pointers to compatible types or to 5393 // differently qualified versions of compatible types, the result type is 5394 // a pointer to an appropriately qualified version of the composite 5395 // type. 5396 5397 // Only CVR-qualifiers exist in the standard, and the differently-qualified 5398 // clause doesn't make sense for our extensions. E.g. address space 2 should 5399 // be incompatible with address space 3: they may live on different devices or 5400 // anything. 5401 Qualifiers lhQual = lhptee.getQualifiers(); 5402 Qualifiers rhQual = rhptee.getQualifiers(); 5403 5404 unsigned MergedCVRQual = lhQual.getCVRQualifiers() | rhQual.getCVRQualifiers(); 5405 lhQual.removeCVRQualifiers(); 5406 rhQual.removeCVRQualifiers(); 5407 5408 lhptee = S.Context.getQualifiedType(lhptee.getUnqualifiedType(), lhQual); 5409 rhptee = S.Context.getQualifiedType(rhptee.getUnqualifiedType(), rhQual); 5410 5411 QualType CompositeTy = S.Context.mergeTypes(lhptee, rhptee); 5412 5413 if (CompositeTy.isNull()) { 5414 S.Diag(Loc, diag::warn_typecheck_cond_incompatible_pointers) 5415 << LHSTy << RHSTy << LHS.get()->getSourceRange() 5416 << RHS.get()->getSourceRange(); 5417 // In this situation, we assume void* type. No especially good 5418 // reason, but this is what gcc does, and we do have to pick 5419 // to get a consistent AST. 5420 QualType incompatTy = S.Context.getPointerType(S.Context.VoidTy); 5421 LHS = S.ImpCastExprToType(LHS.take(), incompatTy, CK_BitCast); 5422 RHS = S.ImpCastExprToType(RHS.take(), incompatTy, CK_BitCast); 5423 return incompatTy; 5424 } 5425 5426 // The pointer types are compatible. 5427 QualType ResultTy = CompositeTy.withCVRQualifiers(MergedCVRQual); 5428 if (IsBlockPointer) 5429 ResultTy = S.Context.getBlockPointerType(ResultTy); 5430 else 5431 ResultTy = S.Context.getPointerType(ResultTy); 5432 5433 LHS = S.ImpCastExprToType(LHS.take(), ResultTy, CK_BitCast); 5434 RHS = S.ImpCastExprToType(RHS.take(), ResultTy, CK_BitCast); 5435 return ResultTy; 5436 } 5437 5438 /// \brief Return the resulting type when the operands are both block pointers. 5439 static QualType checkConditionalBlockPointerCompatibility(Sema &S, 5440 ExprResult &LHS, 5441 ExprResult &RHS, 5442 SourceLocation Loc) { 5443 QualType LHSTy = LHS.get()->getType(); 5444 QualType RHSTy = RHS.get()->getType(); 5445 5446 if (!LHSTy->isBlockPointerType() || !RHSTy->isBlockPointerType()) { 5447 if (LHSTy->isVoidPointerType() || RHSTy->isVoidPointerType()) { 5448 QualType destType = S.Context.getPointerType(S.Context.VoidTy); 5449 LHS = S.ImpCastExprToType(LHS.take(), destType, CK_BitCast); 5450 RHS = S.ImpCastExprToType(RHS.take(), destType, CK_BitCast); 5451 return destType; 5452 } 5453 S.Diag(Loc, diag::err_typecheck_cond_incompatible_operands) 5454 << LHSTy << RHSTy << LHS.get()->getSourceRange() 5455 << RHS.get()->getSourceRange(); 5456 return QualType(); 5457 } 5458 5459 // We have 2 block pointer types. 5460 return checkConditionalPointerCompatibility(S, LHS, RHS, Loc); 5461 } 5462 5463 /// \brief Return the resulting type when the operands are both pointers. 5464 static QualType 5465 checkConditionalObjectPointersCompatibility(Sema &S, ExprResult &LHS, 5466 ExprResult &RHS, 5467 SourceLocation Loc) { 5468 // get the pointer types 5469 QualType LHSTy = LHS.get()->getType(); 5470 QualType RHSTy = RHS.get()->getType(); 5471 5472 // get the "pointed to" types 5473 QualType lhptee = LHSTy->getAs<PointerType>()->getPointeeType(); 5474 QualType rhptee = RHSTy->getAs<PointerType>()->getPointeeType(); 5475 5476 // ignore qualifiers on void (C99 6.5.15p3, clause 6) 5477 if (lhptee->isVoidType() && rhptee->isIncompleteOrObjectType()) { 5478 // Figure out necessary qualifiers (C99 6.5.15p6) 5479 QualType destPointee 5480 = S.Context.getQualifiedType(lhptee, rhptee.getQualifiers()); 5481 QualType destType = S.Context.getPointerType(destPointee); 5482 // Add qualifiers if necessary. 5483 LHS = S.ImpCastExprToType(LHS.take(), destType, CK_NoOp); 5484 // Promote to void*. 5485 RHS = S.ImpCastExprToType(RHS.take(), destType, CK_BitCast); 5486 return destType; 5487 } 5488 if (rhptee->isVoidType() && lhptee->isIncompleteOrObjectType()) { 5489 QualType destPointee 5490 = S.Context.getQualifiedType(rhptee, lhptee.getQualifiers()); 5491 QualType destType = S.Context.getPointerType(destPointee); 5492 // Add qualifiers if necessary. 5493 RHS = S.ImpCastExprToType(RHS.take(), destType, CK_NoOp); 5494 // Promote to void*. 5495 LHS = S.ImpCastExprToType(LHS.take(), destType, CK_BitCast); 5496 return destType; 5497 } 5498 5499 return checkConditionalPointerCompatibility(S, LHS, RHS, Loc); 5500 } 5501 5502 /// \brief Return false if the first expression is not an integer and the second 5503 /// expression is not a pointer, true otherwise. 5504 static bool checkPointerIntegerMismatch(Sema &S, ExprResult &Int, 5505 Expr* PointerExpr, SourceLocation Loc, 5506 bool IsIntFirstExpr) { 5507 if (!PointerExpr->getType()->isPointerType() || 5508 !Int.get()->getType()->isIntegerType()) 5509 return false; 5510 5511 Expr *Expr1 = IsIntFirstExpr ? Int.get() : PointerExpr; 5512 Expr *Expr2 = IsIntFirstExpr ? PointerExpr : Int.get(); 5513 5514 S.Diag(Loc, diag::warn_typecheck_cond_pointer_integer_mismatch) 5515 << Expr1->getType() << Expr2->getType() 5516 << Expr1->getSourceRange() << Expr2->getSourceRange(); 5517 Int = S.ImpCastExprToType(Int.take(), PointerExpr->getType(), 5518 CK_IntegralToPointer); 5519 return true; 5520 } 5521 5522 /// Note that LHS is not null here, even if this is the gnu "x ?: y" extension. 5523 /// In that case, LHS = cond. 5524 /// C99 6.5.15 5525 QualType Sema::CheckConditionalOperands(ExprResult &Cond, ExprResult &LHS, 5526 ExprResult &RHS, ExprValueKind &VK, 5527 ExprObjectKind &OK, 5528 SourceLocation QuestionLoc) { 5529 5530 ExprResult LHSResult = CheckPlaceholderExpr(LHS.get()); 5531 if (!LHSResult.isUsable()) return QualType(); 5532 LHS = LHSResult; 5533 5534 ExprResult RHSResult = CheckPlaceholderExpr(RHS.get()); 5535 if (!RHSResult.isUsable()) return QualType(); 5536 RHS = RHSResult; 5537 5538 // C++ is sufficiently different to merit its own checker. 5539 if (getLangOpts().CPlusPlus) 5540 return CXXCheckConditionalOperands(Cond, LHS, RHS, VK, OK, QuestionLoc); 5541 5542 VK = VK_RValue; 5543 OK = OK_Ordinary; 5544 5545 // First, check the condition. 5546 Cond = UsualUnaryConversions(Cond.take()); 5547 if (Cond.isInvalid()) 5548 return QualType(); 5549 if (checkCondition(*this, Cond.get())) 5550 return QualType(); 5551 5552 // Now check the two expressions. 5553 if (LHS.get()->getType()->isVectorType() || 5554 RHS.get()->getType()->isVectorType()) 5555 return CheckVectorOperands(LHS, RHS, QuestionLoc, /*isCompAssign*/false); 5556 5557 UsualArithmeticConversions(LHS, RHS); 5558 if (LHS.isInvalid() || RHS.isInvalid()) 5559 return QualType(); 5560 5561 QualType CondTy = Cond.get()->getType(); 5562 QualType LHSTy = LHS.get()->getType(); 5563 QualType RHSTy = RHS.get()->getType(); 5564 5565 // If the condition is a vector, and both operands are scalar, 5566 // attempt to implicity convert them to the vector type to act like the 5567 // built in select. (OpenCL v1.1 s6.3.i) 5568 if (getLangOpts().OpenCL && CondTy->isVectorType()) 5569 if (checkConditionalConvertScalarsToVectors(*this, LHS, RHS, CondTy)) 5570 return QualType(); 5571 5572 // If both operands have arithmetic type, do the usual arithmetic conversions 5573 // to find a common type: C99 6.5.15p3,5. 5574 if (LHSTy->isArithmeticType() && RHSTy->isArithmeticType()) 5575 return LHS.get()->getType(); 5576 5577 // If both operands are the same structure or union type, the result is that 5578 // type. 5579 if (const RecordType *LHSRT = LHSTy->getAs<RecordType>()) { // C99 6.5.15p3 5580 if (const RecordType *RHSRT = RHSTy->getAs<RecordType>()) 5581 if (LHSRT->getDecl() == RHSRT->getDecl()) 5582 // "If both the operands have structure or union type, the result has 5583 // that type." This implies that CV qualifiers are dropped. 5584 return LHSTy.getUnqualifiedType(); 5585 // FIXME: Type of conditional expression must be complete in C mode. 5586 } 5587 5588 // C99 6.5.15p5: "If both operands have void type, the result has void type." 5589 // The following || allows only one side to be void (a GCC-ism). 5590 if (LHSTy->isVoidType() || RHSTy->isVoidType()) { 5591 return checkConditionalVoidType(*this, LHS, RHS); 5592 } 5593 5594 // C99 6.5.15p6 - "if one operand is a null pointer constant, the result has 5595 // the type of the other operand." 5596 if (!checkConditionalNullPointer(*this, RHS, LHSTy)) return LHSTy; 5597 if (!checkConditionalNullPointer(*this, LHS, RHSTy)) return RHSTy; 5598 5599 // All objective-c pointer type analysis is done here. 5600 QualType compositeType = FindCompositeObjCPointerType(LHS, RHS, 5601 QuestionLoc); 5602 if (LHS.isInvalid() || RHS.isInvalid()) 5603 return QualType(); 5604 if (!compositeType.isNull()) 5605 return compositeType; 5606 5607 5608 // Handle block pointer types. 5609 if (LHSTy->isBlockPointerType() || RHSTy->isBlockPointerType()) 5610 return checkConditionalBlockPointerCompatibility(*this, LHS, RHS, 5611 QuestionLoc); 5612 5613 // Check constraints for C object pointers types (C99 6.5.15p3,6). 5614 if (LHSTy->isPointerType() && RHSTy->isPointerType()) 5615 return checkConditionalObjectPointersCompatibility(*this, LHS, RHS, 5616 QuestionLoc); 5617 5618 // GCC compatibility: soften pointer/integer mismatch. Note that 5619 // null pointers have been filtered out by this point. 5620 if (checkPointerIntegerMismatch(*this, LHS, RHS.get(), QuestionLoc, 5621 /*isIntFirstExpr=*/true)) 5622 return RHSTy; 5623 if (checkPointerIntegerMismatch(*this, RHS, LHS.get(), QuestionLoc, 5624 /*isIntFirstExpr=*/false)) 5625 return LHSTy; 5626 5627 // Emit a better diagnostic if one of the expressions is a null pointer 5628 // constant and the other is not a pointer type. In this case, the user most 5629 // likely forgot to take the address of the other expression. 5630 if (DiagnoseConditionalForNull(LHS.get(), RHS.get(), QuestionLoc)) 5631 return QualType(); 5632 5633 // Otherwise, the operands are not compatible. 5634 Diag(QuestionLoc, diag::err_typecheck_cond_incompatible_operands) 5635 << LHSTy << RHSTy << LHS.get()->getSourceRange() 5636 << RHS.get()->getSourceRange(); 5637 return QualType(); 5638 } 5639 5640 /// FindCompositeObjCPointerType - Helper method to find composite type of 5641 /// two objective-c pointer types of the two input expressions. 5642 QualType Sema::FindCompositeObjCPointerType(ExprResult &LHS, ExprResult &RHS, 5643 SourceLocation QuestionLoc) { 5644 QualType LHSTy = LHS.get()->getType(); 5645 QualType RHSTy = RHS.get()->getType(); 5646 5647 // Handle things like Class and struct objc_class*. Here we case the result 5648 // to the pseudo-builtin, because that will be implicitly cast back to the 5649 // redefinition type if an attempt is made to access its fields. 5650 if (LHSTy->isObjCClassType() && 5651 (Context.hasSameType(RHSTy, Context.getObjCClassRedefinitionType()))) { 5652 RHS = ImpCastExprToType(RHS.take(), LHSTy, CK_CPointerToObjCPointerCast); 5653 return LHSTy; 5654 } 5655 if (RHSTy->isObjCClassType() && 5656 (Context.hasSameType(LHSTy, Context.getObjCClassRedefinitionType()))) { 5657 LHS = ImpCastExprToType(LHS.take(), RHSTy, CK_CPointerToObjCPointerCast); 5658 return RHSTy; 5659 } 5660 // And the same for struct objc_object* / id 5661 if (LHSTy->isObjCIdType() && 5662 (Context.hasSameType(RHSTy, Context.getObjCIdRedefinitionType()))) { 5663 RHS = ImpCastExprToType(RHS.take(), LHSTy, CK_CPointerToObjCPointerCast); 5664 return LHSTy; 5665 } 5666 if (RHSTy->isObjCIdType() && 5667 (Context.hasSameType(LHSTy, Context.getObjCIdRedefinitionType()))) { 5668 LHS = ImpCastExprToType(LHS.take(), RHSTy, CK_CPointerToObjCPointerCast); 5669 return RHSTy; 5670 } 5671 // And the same for struct objc_selector* / SEL 5672 if (Context.isObjCSelType(LHSTy) && 5673 (Context.hasSameType(RHSTy, Context.getObjCSelRedefinitionType()))) { 5674 RHS = ImpCastExprToType(RHS.take(), LHSTy, CK_BitCast); 5675 return LHSTy; 5676 } 5677 if (Context.isObjCSelType(RHSTy) && 5678 (Context.hasSameType(LHSTy, Context.getObjCSelRedefinitionType()))) { 5679 LHS = ImpCastExprToType(LHS.take(), RHSTy, CK_BitCast); 5680 return RHSTy; 5681 } 5682 // Check constraints for Objective-C object pointers types. 5683 if (LHSTy->isObjCObjectPointerType() && RHSTy->isObjCObjectPointerType()) { 5684 5685 if (Context.getCanonicalType(LHSTy) == Context.getCanonicalType(RHSTy)) { 5686 // Two identical object pointer types are always compatible. 5687 return LHSTy; 5688 } 5689 const ObjCObjectPointerType *LHSOPT = LHSTy->castAs<ObjCObjectPointerType>(); 5690 const ObjCObjectPointerType *RHSOPT = RHSTy->castAs<ObjCObjectPointerType>(); 5691 QualType compositeType = LHSTy; 5692 5693 // If both operands are interfaces and either operand can be 5694 // assigned to the other, use that type as the composite 5695 // type. This allows 5696 // xxx ? (A*) a : (B*) b 5697 // where B is a subclass of A. 5698 // 5699 // Additionally, as for assignment, if either type is 'id' 5700 // allow silent coercion. Finally, if the types are 5701 // incompatible then make sure to use 'id' as the composite 5702 // type so the result is acceptable for sending messages to. 5703 5704 // FIXME: Consider unifying with 'areComparableObjCPointerTypes'. 5705 // It could return the composite type. 5706 if (Context.canAssignObjCInterfaces(LHSOPT, RHSOPT)) { 5707 compositeType = RHSOPT->isObjCBuiltinType() ? RHSTy : LHSTy; 5708 } else if (Context.canAssignObjCInterfaces(RHSOPT, LHSOPT)) { 5709 compositeType = LHSOPT->isObjCBuiltinType() ? LHSTy : RHSTy; 5710 } else if ((LHSTy->isObjCQualifiedIdType() || 5711 RHSTy->isObjCQualifiedIdType()) && 5712 Context.ObjCQualifiedIdTypesAreCompatible(LHSTy, RHSTy, true)) { 5713 // Need to handle "id<xx>" explicitly. 5714 // GCC allows qualified id and any Objective-C type to devolve to 5715 // id. Currently localizing to here until clear this should be 5716 // part of ObjCQualifiedIdTypesAreCompatible. 5717 compositeType = Context.getObjCIdType(); 5718 } else if (LHSTy->isObjCIdType() || RHSTy->isObjCIdType()) { 5719 compositeType = Context.getObjCIdType(); 5720 } else if (!(compositeType = 5721 Context.areCommonBaseCompatible(LHSOPT, RHSOPT)).isNull()) 5722 ; 5723 else { 5724 Diag(QuestionLoc, diag::ext_typecheck_cond_incompatible_operands) 5725 << LHSTy << RHSTy 5726 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 5727 QualType incompatTy = Context.getObjCIdType(); 5728 LHS = ImpCastExprToType(LHS.take(), incompatTy, CK_BitCast); 5729 RHS = ImpCastExprToType(RHS.take(), incompatTy, CK_BitCast); 5730 return incompatTy; 5731 } 5732 // The object pointer types are compatible. 5733 LHS = ImpCastExprToType(LHS.take(), compositeType, CK_BitCast); 5734 RHS = ImpCastExprToType(RHS.take(), compositeType, CK_BitCast); 5735 return compositeType; 5736 } 5737 // Check Objective-C object pointer types and 'void *' 5738 if (LHSTy->isVoidPointerType() && RHSTy->isObjCObjectPointerType()) { 5739 if (getLangOpts().ObjCAutoRefCount) { 5740 // ARC forbids the implicit conversion of object pointers to 'void *', 5741 // so these types are not compatible. 5742 Diag(QuestionLoc, diag::err_cond_voidptr_arc) << LHSTy << RHSTy 5743 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 5744 LHS = RHS = true; 5745 return QualType(); 5746 } 5747 QualType lhptee = LHSTy->getAs<PointerType>()->getPointeeType(); 5748 QualType rhptee = RHSTy->getAs<ObjCObjectPointerType>()->getPointeeType(); 5749 QualType destPointee 5750 = Context.getQualifiedType(lhptee, rhptee.getQualifiers()); 5751 QualType destType = Context.getPointerType(destPointee); 5752 // Add qualifiers if necessary. 5753 LHS = ImpCastExprToType(LHS.take(), destType, CK_NoOp); 5754 // Promote to void*. 5755 RHS = ImpCastExprToType(RHS.take(), destType, CK_BitCast); 5756 return destType; 5757 } 5758 if (LHSTy->isObjCObjectPointerType() && RHSTy->isVoidPointerType()) { 5759 if (getLangOpts().ObjCAutoRefCount) { 5760 // ARC forbids the implicit conversion of object pointers to 'void *', 5761 // so these types are not compatible. 5762 Diag(QuestionLoc, diag::err_cond_voidptr_arc) << LHSTy << RHSTy 5763 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 5764 LHS = RHS = true; 5765 return QualType(); 5766 } 5767 QualType lhptee = LHSTy->getAs<ObjCObjectPointerType>()->getPointeeType(); 5768 QualType rhptee = RHSTy->getAs<PointerType>()->getPointeeType(); 5769 QualType destPointee 5770 = Context.getQualifiedType(rhptee, lhptee.getQualifiers()); 5771 QualType destType = Context.getPointerType(destPointee); 5772 // Add qualifiers if necessary. 5773 RHS = ImpCastExprToType(RHS.take(), destType, CK_NoOp); 5774 // Promote to void*. 5775 LHS = ImpCastExprToType(LHS.take(), destType, CK_BitCast); 5776 return destType; 5777 } 5778 return QualType(); 5779 } 5780 5781 /// SuggestParentheses - Emit a note with a fixit hint that wraps 5782 /// ParenRange in parentheses. 5783 static void SuggestParentheses(Sema &Self, SourceLocation Loc, 5784 const PartialDiagnostic &Note, 5785 SourceRange ParenRange) { 5786 SourceLocation EndLoc = Self.PP.getLocForEndOfToken(ParenRange.getEnd()); 5787 if (ParenRange.getBegin().isFileID() && ParenRange.getEnd().isFileID() && 5788 EndLoc.isValid()) { 5789 Self.Diag(Loc, Note) 5790 << FixItHint::CreateInsertion(ParenRange.getBegin(), "(") 5791 << FixItHint::CreateInsertion(EndLoc, ")"); 5792 } else { 5793 // We can't display the parentheses, so just show the bare note. 5794 Self.Diag(Loc, Note) << ParenRange; 5795 } 5796 } 5797 5798 static bool IsArithmeticOp(BinaryOperatorKind Opc) { 5799 return Opc >= BO_Mul && Opc <= BO_Shr; 5800 } 5801 5802 /// IsArithmeticBinaryExpr - Returns true if E is an arithmetic binary 5803 /// expression, either using a built-in or overloaded operator, 5804 /// and sets *OpCode to the opcode and *RHSExprs to the right-hand side 5805 /// expression. 5806 static bool IsArithmeticBinaryExpr(Expr *E, BinaryOperatorKind *Opcode, 5807 Expr **RHSExprs) { 5808 // Don't strip parenthesis: we should not warn if E is in parenthesis. 5809 E = E->IgnoreImpCasts(); 5810 E = E->IgnoreConversionOperator(); 5811 E = E->IgnoreImpCasts(); 5812 5813 // Built-in binary operator. 5814 if (BinaryOperator *OP = dyn_cast<BinaryOperator>(E)) { 5815 if (IsArithmeticOp(OP->getOpcode())) { 5816 *Opcode = OP->getOpcode(); 5817 *RHSExprs = OP->getRHS(); 5818 return true; 5819 } 5820 } 5821 5822 // Overloaded operator. 5823 if (CXXOperatorCallExpr *Call = dyn_cast<CXXOperatorCallExpr>(E)) { 5824 if (Call->getNumArgs() != 2) 5825 return false; 5826 5827 // Make sure this is really a binary operator that is safe to pass into 5828 // BinaryOperator::getOverloadedOpcode(), e.g. it's not a subscript op. 5829 OverloadedOperatorKind OO = Call->getOperator(); 5830 if (OO < OO_Plus || OO > OO_Arrow || 5831 OO == OO_PlusPlus || OO == OO_MinusMinus) 5832 return false; 5833 5834 BinaryOperatorKind OpKind = BinaryOperator::getOverloadedOpcode(OO); 5835 if (IsArithmeticOp(OpKind)) { 5836 *Opcode = OpKind; 5837 *RHSExprs = Call->getArg(1); 5838 return true; 5839 } 5840 } 5841 5842 return false; 5843 } 5844 5845 static bool IsLogicOp(BinaryOperatorKind Opc) { 5846 return (Opc >= BO_LT && Opc <= BO_NE) || (Opc >= BO_LAnd && Opc <= BO_LOr); 5847 } 5848 5849 /// ExprLooksBoolean - Returns true if E looks boolean, i.e. it has boolean type 5850 /// or is a logical expression such as (x==y) which has int type, but is 5851 /// commonly interpreted as boolean. 5852 static bool ExprLooksBoolean(Expr *E) { 5853 E = E->IgnoreParenImpCasts(); 5854 5855 if (E->getType()->isBooleanType()) 5856 return true; 5857 if (BinaryOperator *OP = dyn_cast<BinaryOperator>(E)) 5858 return IsLogicOp(OP->getOpcode()); 5859 if (UnaryOperator *OP = dyn_cast<UnaryOperator>(E)) 5860 return OP->getOpcode() == UO_LNot; 5861 5862 return false; 5863 } 5864 5865 /// DiagnoseConditionalPrecedence - Emit a warning when a conditional operator 5866 /// and binary operator are mixed in a way that suggests the programmer assumed 5867 /// the conditional operator has higher precedence, for example: 5868 /// "int x = a + someBinaryCondition ? 1 : 2". 5869 static void DiagnoseConditionalPrecedence(Sema &Self, 5870 SourceLocation OpLoc, 5871 Expr *Condition, 5872 Expr *LHSExpr, 5873 Expr *RHSExpr) { 5874 BinaryOperatorKind CondOpcode; 5875 Expr *CondRHS; 5876 5877 if (!IsArithmeticBinaryExpr(Condition, &CondOpcode, &CondRHS)) 5878 return; 5879 if (!ExprLooksBoolean(CondRHS)) 5880 return; 5881 5882 // The condition is an arithmetic binary expression, with a right- 5883 // hand side that looks boolean, so warn. 5884 5885 Self.Diag(OpLoc, diag::warn_precedence_conditional) 5886 << Condition->getSourceRange() 5887 << BinaryOperator::getOpcodeStr(CondOpcode); 5888 5889 SuggestParentheses(Self, OpLoc, 5890 Self.PDiag(diag::note_precedence_silence) 5891 << BinaryOperator::getOpcodeStr(CondOpcode), 5892 SourceRange(Condition->getLocStart(), Condition->getLocEnd())); 5893 5894 SuggestParentheses(Self, OpLoc, 5895 Self.PDiag(diag::note_precedence_conditional_first), 5896 SourceRange(CondRHS->getLocStart(), RHSExpr->getLocEnd())); 5897 } 5898 5899 /// ActOnConditionalOp - Parse a ?: operation. Note that 'LHS' may be null 5900 /// in the case of a the GNU conditional expr extension. 5901 ExprResult Sema::ActOnConditionalOp(SourceLocation QuestionLoc, 5902 SourceLocation ColonLoc, 5903 Expr *CondExpr, Expr *LHSExpr, 5904 Expr *RHSExpr) { 5905 // If this is the gnu "x ?: y" extension, analyze the types as though the LHS 5906 // was the condition. 5907 OpaqueValueExpr *opaqueValue = 0; 5908 Expr *commonExpr = 0; 5909 if (LHSExpr == 0) { 5910 commonExpr = CondExpr; 5911 // Lower out placeholder types first. This is important so that we don't 5912 // try to capture a placeholder. This happens in few cases in C++; such 5913 // as Objective-C++'s dictionary subscripting syntax. 5914 if (commonExpr->hasPlaceholderType()) { 5915 ExprResult result = CheckPlaceholderExpr(commonExpr); 5916 if (!result.isUsable()) return ExprError(); 5917 commonExpr = result.take(); 5918 } 5919 // We usually want to apply unary conversions *before* saving, except 5920 // in the special case of a C++ l-value conditional. 5921 if (!(getLangOpts().CPlusPlus 5922 && !commonExpr->isTypeDependent() 5923 && commonExpr->getValueKind() == RHSExpr->getValueKind() 5924 && commonExpr->isGLValue() 5925 && commonExpr->isOrdinaryOrBitFieldObject() 5926 && RHSExpr->isOrdinaryOrBitFieldObject() 5927 && Context.hasSameType(commonExpr->getType(), RHSExpr->getType()))) { 5928 ExprResult commonRes = UsualUnaryConversions(commonExpr); 5929 if (commonRes.isInvalid()) 5930 return ExprError(); 5931 commonExpr = commonRes.take(); 5932 } 5933 5934 opaqueValue = new (Context) OpaqueValueExpr(commonExpr->getExprLoc(), 5935 commonExpr->getType(), 5936 commonExpr->getValueKind(), 5937 commonExpr->getObjectKind(), 5938 commonExpr); 5939 LHSExpr = CondExpr = opaqueValue; 5940 } 5941 5942 ExprValueKind VK = VK_RValue; 5943 ExprObjectKind OK = OK_Ordinary; 5944 ExprResult Cond = Owned(CondExpr), LHS = Owned(LHSExpr), RHS = Owned(RHSExpr); 5945 QualType result = CheckConditionalOperands(Cond, LHS, RHS, 5946 VK, OK, QuestionLoc); 5947 if (result.isNull() || Cond.isInvalid() || LHS.isInvalid() || 5948 RHS.isInvalid()) 5949 return ExprError(); 5950 5951 DiagnoseConditionalPrecedence(*this, QuestionLoc, Cond.get(), LHS.get(), 5952 RHS.get()); 5953 5954 if (!commonExpr) 5955 return Owned(new (Context) ConditionalOperator(Cond.take(), QuestionLoc, 5956 LHS.take(), ColonLoc, 5957 RHS.take(), result, VK, OK)); 5958 5959 return Owned(new (Context) 5960 BinaryConditionalOperator(commonExpr, opaqueValue, Cond.take(), LHS.take(), 5961 RHS.take(), QuestionLoc, ColonLoc, result, VK, 5962 OK)); 5963 } 5964 5965 // checkPointerTypesForAssignment - This is a very tricky routine (despite 5966 // being closely modeled after the C99 spec:-). The odd characteristic of this 5967 // routine is it effectively iqnores the qualifiers on the top level pointee. 5968 // This circumvents the usual type rules specified in 6.2.7p1 & 6.7.5.[1-3]. 5969 // FIXME: add a couple examples in this comment. 5970 static Sema::AssignConvertType 5971 checkPointerTypesForAssignment(Sema &S, QualType LHSType, QualType RHSType) { 5972 assert(LHSType.isCanonical() && "LHS not canonicalized!"); 5973 assert(RHSType.isCanonical() && "RHS not canonicalized!"); 5974 5975 // get the "pointed to" type (ignoring qualifiers at the top level) 5976 const Type *lhptee, *rhptee; 5977 Qualifiers lhq, rhq; 5978 llvm::tie(lhptee, lhq) = cast<PointerType>(LHSType)->getPointeeType().split(); 5979 llvm::tie(rhptee, rhq) = cast<PointerType>(RHSType)->getPointeeType().split(); 5980 5981 Sema::AssignConvertType ConvTy = Sema::Compatible; 5982 5983 // C99 6.5.16.1p1: This following citation is common to constraints 5984 // 3 & 4 (below). ...and the type *pointed to* by the left has all the 5985 // qualifiers of the type *pointed to* by the right; 5986 5987 // As a special case, 'non-__weak A *' -> 'non-__weak const *' is okay. 5988 if (lhq.getObjCLifetime() != rhq.getObjCLifetime() && 5989 lhq.compatiblyIncludesObjCLifetime(rhq)) { 5990 // Ignore lifetime for further calculation. 5991 lhq.removeObjCLifetime(); 5992 rhq.removeObjCLifetime(); 5993 } 5994 5995 if (!lhq.compatiblyIncludes(rhq)) { 5996 // Treat address-space mismatches as fatal. TODO: address subspaces 5997 if (lhq.getAddressSpace() != rhq.getAddressSpace()) 5998 ConvTy = Sema::IncompatiblePointerDiscardsQualifiers; 5999 6000 // It's okay to add or remove GC or lifetime qualifiers when converting to 6001 // and from void*. 6002 else if (lhq.withoutObjCGCAttr().withoutObjCLifetime() 6003 .compatiblyIncludes( 6004 rhq.withoutObjCGCAttr().withoutObjCLifetime()) 6005 && (lhptee->isVoidType() || rhptee->isVoidType())) 6006 ; // keep old 6007 6008 // Treat lifetime mismatches as fatal. 6009 else if (lhq.getObjCLifetime() != rhq.getObjCLifetime()) 6010 ConvTy = Sema::IncompatiblePointerDiscardsQualifiers; 6011 6012 // For GCC compatibility, other qualifier mismatches are treated 6013 // as still compatible in C. 6014 else ConvTy = Sema::CompatiblePointerDiscardsQualifiers; 6015 } 6016 6017 // C99 6.5.16.1p1 (constraint 4): If one operand is a pointer to an object or 6018 // incomplete type and the other is a pointer to a qualified or unqualified 6019 // version of void... 6020 if (lhptee->isVoidType()) { 6021 if (rhptee->isIncompleteOrObjectType()) 6022 return ConvTy; 6023 6024 // As an extension, we allow cast to/from void* to function pointer. 6025 assert(rhptee->isFunctionType()); 6026 return Sema::FunctionVoidPointer; 6027 } 6028 6029 if (rhptee->isVoidType()) { 6030 if (lhptee->isIncompleteOrObjectType()) 6031 return ConvTy; 6032 6033 // As an extension, we allow cast to/from void* to function pointer. 6034 assert(lhptee->isFunctionType()); 6035 return Sema::FunctionVoidPointer; 6036 } 6037 6038 // C99 6.5.16.1p1 (constraint 3): both operands are pointers to qualified or 6039 // unqualified versions of compatible types, ... 6040 QualType ltrans = QualType(lhptee, 0), rtrans = QualType(rhptee, 0); 6041 if (!S.Context.typesAreCompatible(ltrans, rtrans)) { 6042 // Check if the pointee types are compatible ignoring the sign. 6043 // We explicitly check for char so that we catch "char" vs 6044 // "unsigned char" on systems where "char" is unsigned. 6045 if (lhptee->isCharType()) 6046 ltrans = S.Context.UnsignedCharTy; 6047 else if (lhptee->hasSignedIntegerRepresentation()) 6048 ltrans = S.Context.getCorrespondingUnsignedType(ltrans); 6049 6050 if (rhptee->isCharType()) 6051 rtrans = S.Context.UnsignedCharTy; 6052 else if (rhptee->hasSignedIntegerRepresentation()) 6053 rtrans = S.Context.getCorrespondingUnsignedType(rtrans); 6054 6055 if (ltrans == rtrans) { 6056 // Types are compatible ignoring the sign. Qualifier incompatibility 6057 // takes priority over sign incompatibility because the sign 6058 // warning can be disabled. 6059 if (ConvTy != Sema::Compatible) 6060 return ConvTy; 6061 6062 return Sema::IncompatiblePointerSign; 6063 } 6064 6065 // If we are a multi-level pointer, it's possible that our issue is simply 6066 // one of qualification - e.g. char ** -> const char ** is not allowed. If 6067 // the eventual target type is the same and the pointers have the same 6068 // level of indirection, this must be the issue. 6069 if (isa<PointerType>(lhptee) && isa<PointerType>(rhptee)) { 6070 do { 6071 lhptee = cast<PointerType>(lhptee)->getPointeeType().getTypePtr(); 6072 rhptee = cast<PointerType>(rhptee)->getPointeeType().getTypePtr(); 6073 } while (isa<PointerType>(lhptee) && isa<PointerType>(rhptee)); 6074 6075 if (lhptee == rhptee) 6076 return Sema::IncompatibleNestedPointerQualifiers; 6077 } 6078 6079 // General pointer incompatibility takes priority over qualifiers. 6080 return Sema::IncompatiblePointer; 6081 } 6082 if (!S.getLangOpts().CPlusPlus && 6083 S.IsNoReturnConversion(ltrans, rtrans, ltrans)) 6084 return Sema::IncompatiblePointer; 6085 return ConvTy; 6086 } 6087 6088 /// checkBlockPointerTypesForAssignment - This routine determines whether two 6089 /// block pointer types are compatible or whether a block and normal pointer 6090 /// are compatible. It is more restrict than comparing two function pointer 6091 // types. 6092 static Sema::AssignConvertType 6093 checkBlockPointerTypesForAssignment(Sema &S, QualType LHSType, 6094 QualType RHSType) { 6095 assert(LHSType.isCanonical() && "LHS not canonicalized!"); 6096 assert(RHSType.isCanonical() && "RHS not canonicalized!"); 6097 6098 QualType lhptee, rhptee; 6099 6100 // get the "pointed to" type (ignoring qualifiers at the top level) 6101 lhptee = cast<BlockPointerType>(LHSType)->getPointeeType(); 6102 rhptee = cast<BlockPointerType>(RHSType)->getPointeeType(); 6103 6104 // In C++, the types have to match exactly. 6105 if (S.getLangOpts().CPlusPlus) 6106 return Sema::IncompatibleBlockPointer; 6107 6108 Sema::AssignConvertType ConvTy = Sema::Compatible; 6109 6110 // For blocks we enforce that qualifiers are identical. 6111 if (lhptee.getLocalQualifiers() != rhptee.getLocalQualifiers()) 6112 ConvTy = Sema::CompatiblePointerDiscardsQualifiers; 6113 6114 if (!S.Context.typesAreBlockPointerCompatible(LHSType, RHSType)) 6115 return Sema::IncompatibleBlockPointer; 6116 6117 return ConvTy; 6118 } 6119 6120 /// checkObjCPointerTypesForAssignment - Compares two objective-c pointer types 6121 /// for assignment compatibility. 6122 static Sema::AssignConvertType 6123 checkObjCPointerTypesForAssignment(Sema &S, QualType LHSType, 6124 QualType RHSType) { 6125 assert(LHSType.isCanonical() && "LHS was not canonicalized!"); 6126 assert(RHSType.isCanonical() && "RHS was not canonicalized!"); 6127 6128 if (LHSType->isObjCBuiltinType()) { 6129 // Class is not compatible with ObjC object pointers. 6130 if (LHSType->isObjCClassType() && !RHSType->isObjCBuiltinType() && 6131 !RHSType->isObjCQualifiedClassType()) 6132 return Sema::IncompatiblePointer; 6133 return Sema::Compatible; 6134 } 6135 if (RHSType->isObjCBuiltinType()) { 6136 if (RHSType->isObjCClassType() && !LHSType->isObjCBuiltinType() && 6137 !LHSType->isObjCQualifiedClassType()) 6138 return Sema::IncompatiblePointer; 6139 return Sema::Compatible; 6140 } 6141 QualType lhptee = LHSType->getAs<ObjCObjectPointerType>()->getPointeeType(); 6142 QualType rhptee = RHSType->getAs<ObjCObjectPointerType>()->getPointeeType(); 6143 6144 if (!lhptee.isAtLeastAsQualifiedAs(rhptee) && 6145 // make an exception for id<P> 6146 !LHSType->isObjCQualifiedIdType()) 6147 return Sema::CompatiblePointerDiscardsQualifiers; 6148 6149 if (S.Context.typesAreCompatible(LHSType, RHSType)) 6150 return Sema::Compatible; 6151 if (LHSType->isObjCQualifiedIdType() || RHSType->isObjCQualifiedIdType()) 6152 return Sema::IncompatibleObjCQualifiedId; 6153 return Sema::IncompatiblePointer; 6154 } 6155 6156 Sema::AssignConvertType 6157 Sema::CheckAssignmentConstraints(SourceLocation Loc, 6158 QualType LHSType, QualType RHSType) { 6159 // Fake up an opaque expression. We don't actually care about what 6160 // cast operations are required, so if CheckAssignmentConstraints 6161 // adds casts to this they'll be wasted, but fortunately that doesn't 6162 // usually happen on valid code. 6163 OpaqueValueExpr RHSExpr(Loc, RHSType, VK_RValue); 6164 ExprResult RHSPtr = &RHSExpr; 6165 CastKind K = CK_Invalid; 6166 6167 return CheckAssignmentConstraints(LHSType, RHSPtr, K); 6168 } 6169 6170 /// CheckAssignmentConstraints (C99 6.5.16) - This routine currently 6171 /// has code to accommodate several GCC extensions when type checking 6172 /// pointers. Here are some objectionable examples that GCC considers warnings: 6173 /// 6174 /// int a, *pint; 6175 /// short *pshort; 6176 /// struct foo *pfoo; 6177 /// 6178 /// pint = pshort; // warning: assignment from incompatible pointer type 6179 /// a = pint; // warning: assignment makes integer from pointer without a cast 6180 /// pint = a; // warning: assignment makes pointer from integer without a cast 6181 /// pint = pfoo; // warning: assignment from incompatible pointer type 6182 /// 6183 /// As a result, the code for dealing with pointers is more complex than the 6184 /// C99 spec dictates. 6185 /// 6186 /// Sets 'Kind' for any result kind except Incompatible. 6187 Sema::AssignConvertType 6188 Sema::CheckAssignmentConstraints(QualType LHSType, ExprResult &RHS, 6189 CastKind &Kind) { 6190 QualType RHSType = RHS.get()->getType(); 6191 QualType OrigLHSType = LHSType; 6192 6193 // Get canonical types. We're not formatting these types, just comparing 6194 // them. 6195 LHSType = Context.getCanonicalType(LHSType).getUnqualifiedType(); 6196 RHSType = Context.getCanonicalType(RHSType).getUnqualifiedType(); 6197 6198 // Common case: no conversion required. 6199 if (LHSType == RHSType) { 6200 Kind = CK_NoOp; 6201 return Compatible; 6202 } 6203 6204 // If we have an atomic type, try a non-atomic assignment, then just add an 6205 // atomic qualification step. 6206 if (const AtomicType *AtomicTy = dyn_cast<AtomicType>(LHSType)) { 6207 Sema::AssignConvertType result = 6208 CheckAssignmentConstraints(AtomicTy->getValueType(), RHS, Kind); 6209 if (result != Compatible) 6210 return result; 6211 if (Kind != CK_NoOp) 6212 RHS = ImpCastExprToType(RHS.take(), AtomicTy->getValueType(), Kind); 6213 Kind = CK_NonAtomicToAtomic; 6214 return Compatible; 6215 } 6216 6217 // If the left-hand side is a reference type, then we are in a 6218 // (rare!) case where we've allowed the use of references in C, 6219 // e.g., as a parameter type in a built-in function. In this case, 6220 // just make sure that the type referenced is compatible with the 6221 // right-hand side type. The caller is responsible for adjusting 6222 // LHSType so that the resulting expression does not have reference 6223 // type. 6224 if (const ReferenceType *LHSTypeRef = LHSType->getAs<ReferenceType>()) { 6225 if (Context.typesAreCompatible(LHSTypeRef->getPointeeType(), RHSType)) { 6226 Kind = CK_LValueBitCast; 6227 return Compatible; 6228 } 6229 return Incompatible; 6230 } 6231 6232 // Allow scalar to ExtVector assignments, and assignments of an ExtVector type 6233 // to the same ExtVector type. 6234 if (LHSType->isExtVectorType()) { 6235 if (RHSType->isExtVectorType()) 6236 return Incompatible; 6237 if (RHSType->isArithmeticType()) { 6238 // CK_VectorSplat does T -> vector T, so first cast to the 6239 // element type. 6240 QualType elType = cast<ExtVectorType>(LHSType)->getElementType(); 6241 if (elType != RHSType) { 6242 Kind = PrepareScalarCast(RHS, elType); 6243 RHS = ImpCastExprToType(RHS.take(), elType, Kind); 6244 } 6245 Kind = CK_VectorSplat; 6246 return Compatible; 6247 } 6248 } 6249 6250 // Conversions to or from vector type. 6251 if (LHSType->isVectorType() || RHSType->isVectorType()) { 6252 if (LHSType->isVectorType() && RHSType->isVectorType()) { 6253 // Allow assignments of an AltiVec vector type to an equivalent GCC 6254 // vector type and vice versa 6255 if (Context.areCompatibleVectorTypes(LHSType, RHSType)) { 6256 Kind = CK_BitCast; 6257 return Compatible; 6258 } 6259 6260 // If we are allowing lax vector conversions, and LHS and RHS are both 6261 // vectors, the total size only needs to be the same. This is a bitcast; 6262 // no bits are changed but the result type is different. 6263 if (getLangOpts().LaxVectorConversions && 6264 (Context.getTypeSize(LHSType) == Context.getTypeSize(RHSType))) { 6265 Kind = CK_BitCast; 6266 return IncompatibleVectors; 6267 } 6268 } 6269 return Incompatible; 6270 } 6271 6272 // Arithmetic conversions. 6273 if (LHSType->isArithmeticType() && RHSType->isArithmeticType() && 6274 !(getLangOpts().CPlusPlus && LHSType->isEnumeralType())) { 6275 Kind = PrepareScalarCast(RHS, LHSType); 6276 return Compatible; 6277 } 6278 6279 // Conversions to normal pointers. 6280 if (const PointerType *LHSPointer = dyn_cast<PointerType>(LHSType)) { 6281 // U* -> T* 6282 if (isa<PointerType>(RHSType)) { 6283 Kind = CK_BitCast; 6284 return checkPointerTypesForAssignment(*this, LHSType, RHSType); 6285 } 6286 6287 // int -> T* 6288 if (RHSType->isIntegerType()) { 6289 Kind = CK_IntegralToPointer; // FIXME: null? 6290 return IntToPointer; 6291 } 6292 6293 // C pointers are not compatible with ObjC object pointers, 6294 // with two exceptions: 6295 if (isa<ObjCObjectPointerType>(RHSType)) { 6296 // - conversions to void* 6297 if (LHSPointer->getPointeeType()->isVoidType()) { 6298 Kind = CK_BitCast; 6299 return Compatible; 6300 } 6301 6302 // - conversions from 'Class' to the redefinition type 6303 if (RHSType->isObjCClassType() && 6304 Context.hasSameType(LHSType, 6305 Context.getObjCClassRedefinitionType())) { 6306 Kind = CK_BitCast; 6307 return Compatible; 6308 } 6309 6310 Kind = CK_BitCast; 6311 return IncompatiblePointer; 6312 } 6313 6314 // U^ -> void* 6315 if (RHSType->getAs<BlockPointerType>()) { 6316 if (LHSPointer->getPointeeType()->isVoidType()) { 6317 Kind = CK_BitCast; 6318 return Compatible; 6319 } 6320 } 6321 6322 return Incompatible; 6323 } 6324 6325 // Conversions to block pointers. 6326 if (isa<BlockPointerType>(LHSType)) { 6327 // U^ -> T^ 6328 if (RHSType->isBlockPointerType()) { 6329 Kind = CK_BitCast; 6330 return checkBlockPointerTypesForAssignment(*this, LHSType, RHSType); 6331 } 6332 6333 // int or null -> T^ 6334 if (RHSType->isIntegerType()) { 6335 Kind = CK_IntegralToPointer; // FIXME: null 6336 return IntToBlockPointer; 6337 } 6338 6339 // id -> T^ 6340 if (getLangOpts().ObjC1 && RHSType->isObjCIdType()) { 6341 Kind = CK_AnyPointerToBlockPointerCast; 6342 return Compatible; 6343 } 6344 6345 // void* -> T^ 6346 if (const PointerType *RHSPT = RHSType->getAs<PointerType>()) 6347 if (RHSPT->getPointeeType()->isVoidType()) { 6348 Kind = CK_AnyPointerToBlockPointerCast; 6349 return Compatible; 6350 } 6351 6352 return Incompatible; 6353 } 6354 6355 // Conversions to Objective-C pointers. 6356 if (isa<ObjCObjectPointerType>(LHSType)) { 6357 // A* -> B* 6358 if (RHSType->isObjCObjectPointerType()) { 6359 Kind = CK_BitCast; 6360 Sema::AssignConvertType result = 6361 checkObjCPointerTypesForAssignment(*this, LHSType, RHSType); 6362 if (getLangOpts().ObjCAutoRefCount && 6363 result == Compatible && 6364 !CheckObjCARCUnavailableWeakConversion(OrigLHSType, RHSType)) 6365 result = IncompatibleObjCWeakRef; 6366 return result; 6367 } 6368 6369 // int or null -> A* 6370 if (RHSType->isIntegerType()) { 6371 Kind = CK_IntegralToPointer; // FIXME: null 6372 return IntToPointer; 6373 } 6374 6375 // In general, C pointers are not compatible with ObjC object pointers, 6376 // with two exceptions: 6377 if (isa<PointerType>(RHSType)) { 6378 Kind = CK_CPointerToObjCPointerCast; 6379 6380 // - conversions from 'void*' 6381 if (RHSType->isVoidPointerType()) { 6382 return Compatible; 6383 } 6384 6385 // - conversions to 'Class' from its redefinition type 6386 if (LHSType->isObjCClassType() && 6387 Context.hasSameType(RHSType, 6388 Context.getObjCClassRedefinitionType())) { 6389 return Compatible; 6390 } 6391 6392 return IncompatiblePointer; 6393 } 6394 6395 // T^ -> A* 6396 if (RHSType->isBlockPointerType()) { 6397 maybeExtendBlockObject(*this, RHS); 6398 Kind = CK_BlockPointerToObjCPointerCast; 6399 return Compatible; 6400 } 6401 6402 return Incompatible; 6403 } 6404 6405 // Conversions from pointers that are not covered by the above. 6406 if (isa<PointerType>(RHSType)) { 6407 // T* -> _Bool 6408 if (LHSType == Context.BoolTy) { 6409 Kind = CK_PointerToBoolean; 6410 return Compatible; 6411 } 6412 6413 // T* -> int 6414 if (LHSType->isIntegerType()) { 6415 Kind = CK_PointerToIntegral; 6416 return PointerToInt; 6417 } 6418 6419 return Incompatible; 6420 } 6421 6422 // Conversions from Objective-C pointers that are not covered by the above. 6423 if (isa<ObjCObjectPointerType>(RHSType)) { 6424 // T* -> _Bool 6425 if (LHSType == Context.BoolTy) { 6426 Kind = CK_PointerToBoolean; 6427 return Compatible; 6428 } 6429 6430 // T* -> int 6431 if (LHSType->isIntegerType()) { 6432 Kind = CK_PointerToIntegral; 6433 return PointerToInt; 6434 } 6435 6436 return Incompatible; 6437 } 6438 6439 // struct A -> struct B 6440 if (isa<TagType>(LHSType) && isa<TagType>(RHSType)) { 6441 if (Context.typesAreCompatible(LHSType, RHSType)) { 6442 Kind = CK_NoOp; 6443 return Compatible; 6444 } 6445 } 6446 6447 return Incompatible; 6448 } 6449 6450 /// \brief Constructs a transparent union from an expression that is 6451 /// used to initialize the transparent union. 6452 static void ConstructTransparentUnion(Sema &S, ASTContext &C, 6453 ExprResult &EResult, QualType UnionType, 6454 FieldDecl *Field) { 6455 // Build an initializer list that designates the appropriate member 6456 // of the transparent union. 6457 Expr *E = EResult.take(); 6458 InitListExpr *Initializer = new (C) InitListExpr(C, SourceLocation(), 6459 E, SourceLocation()); 6460 Initializer->setType(UnionType); 6461 Initializer->setInitializedFieldInUnion(Field); 6462 6463 // Build a compound literal constructing a value of the transparent 6464 // union type from this initializer list. 6465 TypeSourceInfo *unionTInfo = C.getTrivialTypeSourceInfo(UnionType); 6466 EResult = S.Owned( 6467 new (C) CompoundLiteralExpr(SourceLocation(), unionTInfo, UnionType, 6468 VK_RValue, Initializer, false)); 6469 } 6470 6471 Sema::AssignConvertType 6472 Sema::CheckTransparentUnionArgumentConstraints(QualType ArgType, 6473 ExprResult &RHS) { 6474 QualType RHSType = RHS.get()->getType(); 6475 6476 // If the ArgType is a Union type, we want to handle a potential 6477 // transparent_union GCC extension. 6478 const RecordType *UT = ArgType->getAsUnionType(); 6479 if (!UT || !UT->getDecl()->hasAttr<TransparentUnionAttr>()) 6480 return Incompatible; 6481 6482 // The field to initialize within the transparent union. 6483 RecordDecl *UD = UT->getDecl(); 6484 FieldDecl *InitField = 0; 6485 // It's compatible if the expression matches any of the fields. 6486 for (RecordDecl::field_iterator it = UD->field_begin(), 6487 itend = UD->field_end(); 6488 it != itend; ++it) { 6489 if (it->getType()->isPointerType()) { 6490 // If the transparent union contains a pointer type, we allow: 6491 // 1) void pointer 6492 // 2) null pointer constant 6493 if (RHSType->isPointerType()) 6494 if (RHSType->castAs<PointerType>()->getPointeeType()->isVoidType()) { 6495 RHS = ImpCastExprToType(RHS.take(), it->getType(), CK_BitCast); 6496 InitField = *it; 6497 break; 6498 } 6499 6500 if (RHS.get()->isNullPointerConstant(Context, 6501 Expr::NPC_ValueDependentIsNull)) { 6502 RHS = ImpCastExprToType(RHS.take(), it->getType(), 6503 CK_NullToPointer); 6504 InitField = *it; 6505 break; 6506 } 6507 } 6508 6509 CastKind Kind = CK_Invalid; 6510 if (CheckAssignmentConstraints(it->getType(), RHS, Kind) 6511 == Compatible) { 6512 RHS = ImpCastExprToType(RHS.take(), it->getType(), Kind); 6513 InitField = *it; 6514 break; 6515 } 6516 } 6517 6518 if (!InitField) 6519 return Incompatible; 6520 6521 ConstructTransparentUnion(*this, Context, RHS, ArgType, InitField); 6522 return Compatible; 6523 } 6524 6525 Sema::AssignConvertType 6526 Sema::CheckSingleAssignmentConstraints(QualType LHSType, ExprResult &RHS, 6527 bool Diagnose, 6528 bool DiagnoseCFAudited) { 6529 if (getLangOpts().CPlusPlus) { 6530 if (!LHSType->isRecordType() && !LHSType->isAtomicType()) { 6531 // C++ 5.17p3: If the left operand is not of class type, the 6532 // expression is implicitly converted (C++ 4) to the 6533 // cv-unqualified type of the left operand. 6534 ExprResult Res; 6535 if (Diagnose) { 6536 Res = PerformImplicitConversion(RHS.get(), LHSType.getUnqualifiedType(), 6537 AA_Assigning); 6538 } else { 6539 ImplicitConversionSequence ICS = 6540 TryImplicitConversion(RHS.get(), LHSType.getUnqualifiedType(), 6541 /*SuppressUserConversions=*/false, 6542 /*AllowExplicit=*/false, 6543 /*InOverloadResolution=*/false, 6544 /*CStyle=*/false, 6545 /*AllowObjCWritebackConversion=*/false); 6546 if (ICS.isFailure()) 6547 return Incompatible; 6548 Res = PerformImplicitConversion(RHS.get(), LHSType.getUnqualifiedType(), 6549 ICS, AA_Assigning); 6550 } 6551 if (Res.isInvalid()) 6552 return Incompatible; 6553 Sema::AssignConvertType result = Compatible; 6554 if (getLangOpts().ObjCAutoRefCount && 6555 !CheckObjCARCUnavailableWeakConversion(LHSType, 6556 RHS.get()->getType())) 6557 result = IncompatibleObjCWeakRef; 6558 RHS = Res; 6559 return result; 6560 } 6561 6562 // FIXME: Currently, we fall through and treat C++ classes like C 6563 // structures. 6564 // FIXME: We also fall through for atomics; not sure what should 6565 // happen there, though. 6566 } 6567 6568 // C99 6.5.16.1p1: the left operand is a pointer and the right is 6569 // a null pointer constant. 6570 if ((LHSType->isPointerType() || LHSType->isObjCObjectPointerType() || 6571 LHSType->isBlockPointerType()) && 6572 RHS.get()->isNullPointerConstant(Context, 6573 Expr::NPC_ValueDependentIsNull)) { 6574 CastKind Kind; 6575 CXXCastPath Path; 6576 CheckPointerConversion(RHS.get(), LHSType, Kind, Path, false); 6577 RHS = ImpCastExprToType(RHS.take(), LHSType, Kind, VK_RValue, &Path); 6578 return Compatible; 6579 } 6580 6581 // This check seems unnatural, however it is necessary to ensure the proper 6582 // conversion of functions/arrays. If the conversion were done for all 6583 // DeclExpr's (created by ActOnIdExpression), it would mess up the unary 6584 // expressions that suppress this implicit conversion (&, sizeof). 6585 // 6586 // Suppress this for references: C++ 8.5.3p5. 6587 if (!LHSType->isReferenceType()) { 6588 RHS = DefaultFunctionArrayLvalueConversion(RHS.take()); 6589 if (RHS.isInvalid()) 6590 return Incompatible; 6591 } 6592 6593 CastKind Kind = CK_Invalid; 6594 Sema::AssignConvertType result = 6595 CheckAssignmentConstraints(LHSType, RHS, Kind); 6596 6597 // C99 6.5.16.1p2: The value of the right operand is converted to the 6598 // type of the assignment expression. 6599 // CheckAssignmentConstraints allows the left-hand side to be a reference, 6600 // so that we can use references in built-in functions even in C. 6601 // The getNonReferenceType() call makes sure that the resulting expression 6602 // does not have reference type. 6603 if (result != Incompatible && RHS.get()->getType() != LHSType) { 6604 QualType Ty = LHSType.getNonLValueExprType(Context); 6605 Expr *E = RHS.take(); 6606 if (getLangOpts().ObjCAutoRefCount) 6607 CheckObjCARCConversion(SourceRange(), Ty, E, CCK_ImplicitConversion, 6608 DiagnoseCFAudited); 6609 if (getLangOpts().ObjC1 && 6610 (CheckObjCBridgeRelatedConversions(E->getLocStart(), 6611 LHSType, E->getType(), E) || 6612 ConversionToObjCStringLiteralCheck(LHSType, E))) { 6613 RHS = Owned(E); 6614 return Compatible; 6615 } 6616 6617 RHS = ImpCastExprToType(E, Ty, Kind); 6618 } 6619 return result; 6620 } 6621 6622 QualType Sema::InvalidOperands(SourceLocation Loc, ExprResult &LHS, 6623 ExprResult &RHS) { 6624 Diag(Loc, diag::err_typecheck_invalid_operands) 6625 << LHS.get()->getType() << RHS.get()->getType() 6626 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 6627 return QualType(); 6628 } 6629 6630 static bool areVectorOperandsLaxBitCastable(ASTContext &Ctx, 6631 QualType LHSType, QualType RHSType){ 6632 if (!Ctx.getLangOpts().LaxVectorConversions) 6633 return false; 6634 6635 if (!(LHSType->isVectorType() || LHSType->isScalarType()) || 6636 !(RHSType->isVectorType() || RHSType->isScalarType())) 6637 return false; 6638 6639 unsigned LHSSize = Ctx.getTypeSize(LHSType); 6640 unsigned RHSSize = Ctx.getTypeSize(RHSType); 6641 if (LHSSize != RHSSize) 6642 return false; 6643 6644 // For a non-power-of-2 vector ASTContext::getTypeSize returns the size 6645 // rounded to the next power-of-2, but the LLVM IR type that we create 6646 // is considered to have num-of-elements*width-of-element width. 6647 // Make sure such width is the same between the types, otherwise we may end 6648 // up with an invalid bitcast. 6649 unsigned LHSIRSize, RHSIRSize; 6650 if (LHSType->isVectorType()) { 6651 const VectorType *Vec = LHSType->getAs<VectorType>(); 6652 LHSIRSize = Vec->getNumElements() * 6653 Ctx.getTypeSize(Vec->getElementType()); 6654 } else { 6655 LHSIRSize = LHSSize; 6656 } 6657 if (RHSType->isVectorType()) { 6658 const VectorType *Vec = RHSType->getAs<VectorType>(); 6659 RHSIRSize = Vec->getNumElements() * 6660 Ctx.getTypeSize(Vec->getElementType()); 6661 } else { 6662 RHSIRSize = RHSSize; 6663 } 6664 if (LHSIRSize != RHSIRSize) 6665 return false; 6666 6667 return true; 6668 } 6669 6670 QualType Sema::CheckVectorOperands(ExprResult &LHS, ExprResult &RHS, 6671 SourceLocation Loc, bool IsCompAssign) { 6672 if (!IsCompAssign) { 6673 LHS = DefaultFunctionArrayLvalueConversion(LHS.take()); 6674 if (LHS.isInvalid()) 6675 return QualType(); 6676 } 6677 RHS = DefaultFunctionArrayLvalueConversion(RHS.take()); 6678 if (RHS.isInvalid()) 6679 return QualType(); 6680 6681 // For conversion purposes, we ignore any qualifiers. 6682 // For example, "const float" and "float" are equivalent. 6683 QualType LHSType = 6684 Context.getCanonicalType(LHS.get()->getType()).getUnqualifiedType(); 6685 QualType RHSType = 6686 Context.getCanonicalType(RHS.get()->getType()).getUnqualifiedType(); 6687 6688 // If the vector types are identical, return. 6689 if (LHSType == RHSType) 6690 return LHSType; 6691 6692 // Handle the case of equivalent AltiVec and GCC vector types 6693 if (LHSType->isVectorType() && RHSType->isVectorType() && 6694 Context.areCompatibleVectorTypes(LHSType, RHSType)) { 6695 if (LHSType->isExtVectorType()) { 6696 RHS = ImpCastExprToType(RHS.take(), LHSType, CK_BitCast); 6697 return LHSType; 6698 } 6699 6700 if (!IsCompAssign) 6701 LHS = ImpCastExprToType(LHS.take(), RHSType, CK_BitCast); 6702 return RHSType; 6703 } 6704 6705 if (areVectorOperandsLaxBitCastable(Context, LHSType, RHSType)) { 6706 // If we are allowing lax vector conversions, and LHS and RHS are both 6707 // vectors, the total size only needs to be the same. This is a 6708 // bitcast; no bits are changed but the result type is different. 6709 // FIXME: Should we really be allowing this? 6710 RHS = ImpCastExprToType(RHS.take(), LHSType, CK_BitCast); 6711 return LHSType; 6712 } 6713 6714 if (!(LHSType->isVectorType() || LHSType->isScalarType()) || 6715 !(RHSType->isVectorType() || RHSType->isScalarType())) { 6716 Diag(Loc, diag::err_typecheck_vector_not_convertable_non_scalar) 6717 << LHS.get()->getType() << RHS.get()->getType() 6718 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 6719 return QualType(); 6720 } 6721 6722 // Canonicalize the ExtVector to the LHS, remember if we swapped so we can 6723 // swap back (so that we don't reverse the inputs to a subtract, for instance. 6724 bool swapped = false; 6725 if (RHSType->isExtVectorType() && !IsCompAssign) { 6726 swapped = true; 6727 std::swap(RHS, LHS); 6728 std::swap(RHSType, LHSType); 6729 } 6730 6731 // Handle the case of an ext vector and scalar. 6732 if (const ExtVectorType *LV = LHSType->getAs<ExtVectorType>()) { 6733 QualType EltTy = LV->getElementType(); 6734 if (EltTy->isIntegralType(Context) && RHSType->isIntegralType(Context)) { 6735 int order = Context.getIntegerTypeOrder(EltTy, RHSType); 6736 if (order > 0) 6737 RHS = ImpCastExprToType(RHS.take(), EltTy, CK_IntegralCast); 6738 if (order >= 0) { 6739 RHS = ImpCastExprToType(RHS.take(), LHSType, CK_VectorSplat); 6740 if (swapped) std::swap(RHS, LHS); 6741 return LHSType; 6742 } 6743 } 6744 if (EltTy->isRealFloatingType() && RHSType->isScalarType()) { 6745 if (RHSType->isRealFloatingType()) { 6746 int order = Context.getFloatingTypeOrder(EltTy, RHSType); 6747 if (order > 0) 6748 RHS = ImpCastExprToType(RHS.take(), EltTy, CK_FloatingCast); 6749 if (order >= 0) { 6750 RHS = ImpCastExprToType(RHS.take(), LHSType, CK_VectorSplat); 6751 if (swapped) std::swap(RHS, LHS); 6752 return LHSType; 6753 } 6754 } 6755 if (RHSType->isIntegralType(Context)) { 6756 RHS = ImpCastExprToType(RHS.take(), EltTy, CK_IntegralToFloating); 6757 RHS = ImpCastExprToType(RHS.take(), LHSType, CK_VectorSplat); 6758 if (swapped) std::swap(RHS, LHS); 6759 return LHSType; 6760 } 6761 } 6762 } 6763 6764 // Vectors of different size or scalar and non-ext-vector are errors. 6765 if (swapped) std::swap(RHS, LHS); 6766 Diag(Loc, diag::err_typecheck_vector_not_convertable) 6767 << LHS.get()->getType() << RHS.get()->getType() 6768 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 6769 return QualType(); 6770 } 6771 6772 // checkArithmeticNull - Detect when a NULL constant is used improperly in an 6773 // expression. These are mainly cases where the null pointer is used as an 6774 // integer instead of a pointer. 6775 static void checkArithmeticNull(Sema &S, ExprResult &LHS, ExprResult &RHS, 6776 SourceLocation Loc, bool IsCompare) { 6777 // The canonical way to check for a GNU null is with isNullPointerConstant, 6778 // but we use a bit of a hack here for speed; this is a relatively 6779 // hot path, and isNullPointerConstant is slow. 6780 bool LHSNull = isa<GNUNullExpr>(LHS.get()->IgnoreParenImpCasts()); 6781 bool RHSNull = isa<GNUNullExpr>(RHS.get()->IgnoreParenImpCasts()); 6782 6783 QualType NonNullType = LHSNull ? RHS.get()->getType() : LHS.get()->getType(); 6784 6785 // Avoid analyzing cases where the result will either be invalid (and 6786 // diagnosed as such) or entirely valid and not something to warn about. 6787 if ((!LHSNull && !RHSNull) || NonNullType->isBlockPointerType() || 6788 NonNullType->isMemberPointerType() || NonNullType->isFunctionType()) 6789 return; 6790 6791 // Comparison operations would not make sense with a null pointer no matter 6792 // what the other expression is. 6793 if (!IsCompare) { 6794 S.Diag(Loc, diag::warn_null_in_arithmetic_operation) 6795 << (LHSNull ? LHS.get()->getSourceRange() : SourceRange()) 6796 << (RHSNull ? RHS.get()->getSourceRange() : SourceRange()); 6797 return; 6798 } 6799 6800 // The rest of the operations only make sense with a null pointer 6801 // if the other expression is a pointer. 6802 if (LHSNull == RHSNull || NonNullType->isAnyPointerType() || 6803 NonNullType->canDecayToPointerType()) 6804 return; 6805 6806 S.Diag(Loc, diag::warn_null_in_comparison_operation) 6807 << LHSNull /* LHS is NULL */ << NonNullType 6808 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 6809 } 6810 6811 QualType Sema::CheckMultiplyDivideOperands(ExprResult &LHS, ExprResult &RHS, 6812 SourceLocation Loc, 6813 bool IsCompAssign, bool IsDiv) { 6814 checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false); 6815 6816 if (LHS.get()->getType()->isVectorType() || 6817 RHS.get()->getType()->isVectorType()) 6818 return CheckVectorOperands(LHS, RHS, Loc, IsCompAssign); 6819 6820 QualType compType = UsualArithmeticConversions(LHS, RHS, IsCompAssign); 6821 if (LHS.isInvalid() || RHS.isInvalid()) 6822 return QualType(); 6823 6824 6825 if (compType.isNull() || !compType->isArithmeticType()) 6826 return InvalidOperands(Loc, LHS, RHS); 6827 6828 // Check for division by zero. 6829 llvm::APSInt RHSValue; 6830 if (IsDiv && !RHS.get()->isValueDependent() && 6831 RHS.get()->EvaluateAsInt(RHSValue, Context) && RHSValue == 0) 6832 DiagRuntimeBehavior(Loc, RHS.get(), 6833 PDiag(diag::warn_division_by_zero) 6834 << RHS.get()->getSourceRange()); 6835 6836 return compType; 6837 } 6838 6839 QualType Sema::CheckRemainderOperands( 6840 ExprResult &LHS, ExprResult &RHS, SourceLocation Loc, bool IsCompAssign) { 6841 checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false); 6842 6843 if (LHS.get()->getType()->isVectorType() || 6844 RHS.get()->getType()->isVectorType()) { 6845 if (LHS.get()->getType()->hasIntegerRepresentation() && 6846 RHS.get()->getType()->hasIntegerRepresentation()) 6847 return CheckVectorOperands(LHS, RHS, Loc, IsCompAssign); 6848 return InvalidOperands(Loc, LHS, RHS); 6849 } 6850 6851 QualType compType = UsualArithmeticConversions(LHS, RHS, IsCompAssign); 6852 if (LHS.isInvalid() || RHS.isInvalid()) 6853 return QualType(); 6854 6855 if (compType.isNull() || !compType->isIntegerType()) 6856 return InvalidOperands(Loc, LHS, RHS); 6857 6858 // Check for remainder by zero. 6859 llvm::APSInt RHSValue; 6860 if (!RHS.get()->isValueDependent() && 6861 RHS.get()->EvaluateAsInt(RHSValue, Context) && RHSValue == 0) 6862 DiagRuntimeBehavior(Loc, RHS.get(), 6863 PDiag(diag::warn_remainder_by_zero) 6864 << RHS.get()->getSourceRange()); 6865 6866 return compType; 6867 } 6868 6869 /// \brief Diagnose invalid arithmetic on two void pointers. 6870 static void diagnoseArithmeticOnTwoVoidPointers(Sema &S, SourceLocation Loc, 6871 Expr *LHSExpr, Expr *RHSExpr) { 6872 S.Diag(Loc, S.getLangOpts().CPlusPlus 6873 ? diag::err_typecheck_pointer_arith_void_type 6874 : diag::ext_gnu_void_ptr) 6875 << 1 /* two pointers */ << LHSExpr->getSourceRange() 6876 << RHSExpr->getSourceRange(); 6877 } 6878 6879 /// \brief Diagnose invalid arithmetic on a void pointer. 6880 static void diagnoseArithmeticOnVoidPointer(Sema &S, SourceLocation Loc, 6881 Expr *Pointer) { 6882 S.Diag(Loc, S.getLangOpts().CPlusPlus 6883 ? diag::err_typecheck_pointer_arith_void_type 6884 : diag::ext_gnu_void_ptr) 6885 << 0 /* one pointer */ << Pointer->getSourceRange(); 6886 } 6887 6888 /// \brief Diagnose invalid arithmetic on two function pointers. 6889 static void diagnoseArithmeticOnTwoFunctionPointers(Sema &S, SourceLocation Loc, 6890 Expr *LHS, Expr *RHS) { 6891 assert(LHS->getType()->isAnyPointerType()); 6892 assert(RHS->getType()->isAnyPointerType()); 6893 S.Diag(Loc, S.getLangOpts().CPlusPlus 6894 ? diag::err_typecheck_pointer_arith_function_type 6895 : diag::ext_gnu_ptr_func_arith) 6896 << 1 /* two pointers */ << LHS->getType()->getPointeeType() 6897 // We only show the second type if it differs from the first. 6898 << (unsigned)!S.Context.hasSameUnqualifiedType(LHS->getType(), 6899 RHS->getType()) 6900 << RHS->getType()->getPointeeType() 6901 << LHS->getSourceRange() << RHS->getSourceRange(); 6902 } 6903 6904 /// \brief Diagnose invalid arithmetic on a function pointer. 6905 static void diagnoseArithmeticOnFunctionPointer(Sema &S, SourceLocation Loc, 6906 Expr *Pointer) { 6907 assert(Pointer->getType()->isAnyPointerType()); 6908 S.Diag(Loc, S.getLangOpts().CPlusPlus 6909 ? diag::err_typecheck_pointer_arith_function_type 6910 : diag::ext_gnu_ptr_func_arith) 6911 << 0 /* one pointer */ << Pointer->getType()->getPointeeType() 6912 << 0 /* one pointer, so only one type */ 6913 << Pointer->getSourceRange(); 6914 } 6915 6916 /// \brief Emit error if Operand is incomplete pointer type 6917 /// 6918 /// \returns True if pointer has incomplete type 6919 static bool checkArithmeticIncompletePointerType(Sema &S, SourceLocation Loc, 6920 Expr *Operand) { 6921 assert(Operand->getType()->isAnyPointerType() && 6922 !Operand->getType()->isDependentType()); 6923 QualType PointeeTy = Operand->getType()->getPointeeType(); 6924 return S.RequireCompleteType(Loc, PointeeTy, 6925 diag::err_typecheck_arithmetic_incomplete_type, 6926 PointeeTy, Operand->getSourceRange()); 6927 } 6928 6929 /// \brief Check the validity of an arithmetic pointer operand. 6930 /// 6931 /// If the operand has pointer type, this code will check for pointer types 6932 /// which are invalid in arithmetic operations. These will be diagnosed 6933 /// appropriately, including whether or not the use is supported as an 6934 /// extension. 6935 /// 6936 /// \returns True when the operand is valid to use (even if as an extension). 6937 static bool checkArithmeticOpPointerOperand(Sema &S, SourceLocation Loc, 6938 Expr *Operand) { 6939 if (!Operand->getType()->isAnyPointerType()) return true; 6940 6941 QualType PointeeTy = Operand->getType()->getPointeeType(); 6942 if (PointeeTy->isVoidType()) { 6943 diagnoseArithmeticOnVoidPointer(S, Loc, Operand); 6944 return !S.getLangOpts().CPlusPlus; 6945 } 6946 if (PointeeTy->isFunctionType()) { 6947 diagnoseArithmeticOnFunctionPointer(S, Loc, Operand); 6948 return !S.getLangOpts().CPlusPlus; 6949 } 6950 6951 if (checkArithmeticIncompletePointerType(S, Loc, Operand)) return false; 6952 6953 return true; 6954 } 6955 6956 /// \brief Check the validity of a binary arithmetic operation w.r.t. pointer 6957 /// operands. 6958 /// 6959 /// This routine will diagnose any invalid arithmetic on pointer operands much 6960 /// like \see checkArithmeticOpPointerOperand. However, it has special logic 6961 /// for emitting a single diagnostic even for operations where both LHS and RHS 6962 /// are (potentially problematic) pointers. 6963 /// 6964 /// \returns True when the operand is valid to use (even if as an extension). 6965 static bool checkArithmeticBinOpPointerOperands(Sema &S, SourceLocation Loc, 6966 Expr *LHSExpr, Expr *RHSExpr) { 6967 bool isLHSPointer = LHSExpr->getType()->isAnyPointerType(); 6968 bool isRHSPointer = RHSExpr->getType()->isAnyPointerType(); 6969 if (!isLHSPointer && !isRHSPointer) return true; 6970 6971 QualType LHSPointeeTy, RHSPointeeTy; 6972 if (isLHSPointer) LHSPointeeTy = LHSExpr->getType()->getPointeeType(); 6973 if (isRHSPointer) RHSPointeeTy = RHSExpr->getType()->getPointeeType(); 6974 6975 // Check for arithmetic on pointers to incomplete types. 6976 bool isLHSVoidPtr = isLHSPointer && LHSPointeeTy->isVoidType(); 6977 bool isRHSVoidPtr = isRHSPointer && RHSPointeeTy->isVoidType(); 6978 if (isLHSVoidPtr || isRHSVoidPtr) { 6979 if (!isRHSVoidPtr) diagnoseArithmeticOnVoidPointer(S, Loc, LHSExpr); 6980 else if (!isLHSVoidPtr) diagnoseArithmeticOnVoidPointer(S, Loc, RHSExpr); 6981 else diagnoseArithmeticOnTwoVoidPointers(S, Loc, LHSExpr, RHSExpr); 6982 6983 return !S.getLangOpts().CPlusPlus; 6984 } 6985 6986 bool isLHSFuncPtr = isLHSPointer && LHSPointeeTy->isFunctionType(); 6987 bool isRHSFuncPtr = isRHSPointer && RHSPointeeTy->isFunctionType(); 6988 if (isLHSFuncPtr || isRHSFuncPtr) { 6989 if (!isRHSFuncPtr) diagnoseArithmeticOnFunctionPointer(S, Loc, LHSExpr); 6990 else if (!isLHSFuncPtr) diagnoseArithmeticOnFunctionPointer(S, Loc, 6991 RHSExpr); 6992 else diagnoseArithmeticOnTwoFunctionPointers(S, Loc, LHSExpr, RHSExpr); 6993 6994 return !S.getLangOpts().CPlusPlus; 6995 } 6996 6997 if (isLHSPointer && checkArithmeticIncompletePointerType(S, Loc, LHSExpr)) 6998 return false; 6999 if (isRHSPointer && checkArithmeticIncompletePointerType(S, Loc, RHSExpr)) 7000 return false; 7001 7002 return true; 7003 } 7004 7005 /// diagnoseStringPlusInt - Emit a warning when adding an integer to a string 7006 /// literal. 7007 static void diagnoseStringPlusInt(Sema &Self, SourceLocation OpLoc, 7008 Expr *LHSExpr, Expr *RHSExpr) { 7009 StringLiteral* StrExpr = dyn_cast<StringLiteral>(LHSExpr->IgnoreImpCasts()); 7010 Expr* IndexExpr = RHSExpr; 7011 if (!StrExpr) { 7012 StrExpr = dyn_cast<StringLiteral>(RHSExpr->IgnoreImpCasts()); 7013 IndexExpr = LHSExpr; 7014 } 7015 7016 bool IsStringPlusInt = StrExpr && 7017 IndexExpr->getType()->isIntegralOrUnscopedEnumerationType(); 7018 if (!IsStringPlusInt) 7019 return; 7020 7021 llvm::APSInt index; 7022 if (IndexExpr->EvaluateAsInt(index, Self.getASTContext())) { 7023 unsigned StrLenWithNull = StrExpr->getLength() + 1; 7024 if (index.isNonNegative() && 7025 index <= llvm::APSInt(llvm::APInt(index.getBitWidth(), StrLenWithNull), 7026 index.isUnsigned())) 7027 return; 7028 } 7029 7030 SourceRange DiagRange(LHSExpr->getLocStart(), RHSExpr->getLocEnd()); 7031 Self.Diag(OpLoc, diag::warn_string_plus_int) 7032 << DiagRange << IndexExpr->IgnoreImpCasts()->getType(); 7033 7034 // Only print a fixit for "str" + int, not for int + "str". 7035 if (IndexExpr == RHSExpr) { 7036 SourceLocation EndLoc = Self.PP.getLocForEndOfToken(RHSExpr->getLocEnd()); 7037 Self.Diag(OpLoc, diag::note_string_plus_scalar_silence) 7038 << FixItHint::CreateInsertion(LHSExpr->getLocStart(), "&") 7039 << FixItHint::CreateReplacement(SourceRange(OpLoc), "[") 7040 << FixItHint::CreateInsertion(EndLoc, "]"); 7041 } else 7042 Self.Diag(OpLoc, diag::note_string_plus_scalar_silence); 7043 } 7044 7045 /// \brief Emit a warning when adding a char literal to a string. 7046 static void diagnoseStringPlusChar(Sema &Self, SourceLocation OpLoc, 7047 Expr *LHSExpr, Expr *RHSExpr) { 7048 const DeclRefExpr *StringRefExpr = 7049 dyn_cast<DeclRefExpr>(LHSExpr->IgnoreImpCasts()); 7050 const CharacterLiteral *CharExpr = 7051 dyn_cast<CharacterLiteral>(RHSExpr->IgnoreImpCasts()); 7052 if (!StringRefExpr) { 7053 StringRefExpr = dyn_cast<DeclRefExpr>(RHSExpr->IgnoreImpCasts()); 7054 CharExpr = dyn_cast<CharacterLiteral>(LHSExpr->IgnoreImpCasts()); 7055 } 7056 7057 if (!CharExpr || !StringRefExpr) 7058 return; 7059 7060 const QualType StringType = StringRefExpr->getType(); 7061 7062 // Return if not a PointerType. 7063 if (!StringType->isAnyPointerType()) 7064 return; 7065 7066 // Return if not a CharacterType. 7067 if (!StringType->getPointeeType()->isAnyCharacterType()) 7068 return; 7069 7070 ASTContext &Ctx = Self.getASTContext(); 7071 SourceRange DiagRange(LHSExpr->getLocStart(), RHSExpr->getLocEnd()); 7072 7073 const QualType CharType = CharExpr->getType(); 7074 if (!CharType->isAnyCharacterType() && 7075 CharType->isIntegerType() && 7076 llvm::isUIntN(Ctx.getCharWidth(), CharExpr->getValue())) { 7077 Self.Diag(OpLoc, diag::warn_string_plus_char) 7078 << DiagRange << Ctx.CharTy; 7079 } else { 7080 Self.Diag(OpLoc, diag::warn_string_plus_char) 7081 << DiagRange << CharExpr->getType(); 7082 } 7083 7084 // Only print a fixit for str + char, not for char + str. 7085 if (isa<CharacterLiteral>(RHSExpr->IgnoreImpCasts())) { 7086 SourceLocation EndLoc = Self.PP.getLocForEndOfToken(RHSExpr->getLocEnd()); 7087 Self.Diag(OpLoc, diag::note_string_plus_scalar_silence) 7088 << FixItHint::CreateInsertion(LHSExpr->getLocStart(), "&") 7089 << FixItHint::CreateReplacement(SourceRange(OpLoc), "[") 7090 << FixItHint::CreateInsertion(EndLoc, "]"); 7091 } else { 7092 Self.Diag(OpLoc, diag::note_string_plus_scalar_silence); 7093 } 7094 } 7095 7096 /// \brief Emit error when two pointers are incompatible. 7097 static void diagnosePointerIncompatibility(Sema &S, SourceLocation Loc, 7098 Expr *LHSExpr, Expr *RHSExpr) { 7099 assert(LHSExpr->getType()->isAnyPointerType()); 7100 assert(RHSExpr->getType()->isAnyPointerType()); 7101 S.Diag(Loc, diag::err_typecheck_sub_ptr_compatible) 7102 << LHSExpr->getType() << RHSExpr->getType() << LHSExpr->getSourceRange() 7103 << RHSExpr->getSourceRange(); 7104 } 7105 7106 QualType Sema::CheckAdditionOperands( // C99 6.5.6 7107 ExprResult &LHS, ExprResult &RHS, SourceLocation Loc, unsigned Opc, 7108 QualType* CompLHSTy) { 7109 checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false); 7110 7111 if (LHS.get()->getType()->isVectorType() || 7112 RHS.get()->getType()->isVectorType()) { 7113 QualType compType = CheckVectorOperands(LHS, RHS, Loc, CompLHSTy); 7114 if (CompLHSTy) *CompLHSTy = compType; 7115 return compType; 7116 } 7117 7118 QualType compType = UsualArithmeticConversions(LHS, RHS, CompLHSTy); 7119 if (LHS.isInvalid() || RHS.isInvalid()) 7120 return QualType(); 7121 7122 // Diagnose "string literal" '+' int and string '+' "char literal". 7123 if (Opc == BO_Add) { 7124 diagnoseStringPlusInt(*this, Loc, LHS.get(), RHS.get()); 7125 diagnoseStringPlusChar(*this, Loc, LHS.get(), RHS.get()); 7126 } 7127 7128 // handle the common case first (both operands are arithmetic). 7129 if (!compType.isNull() && compType->isArithmeticType()) { 7130 if (CompLHSTy) *CompLHSTy = compType; 7131 return compType; 7132 } 7133 7134 // Type-checking. Ultimately the pointer's going to be in PExp; 7135 // note that we bias towards the LHS being the pointer. 7136 Expr *PExp = LHS.get(), *IExp = RHS.get(); 7137 7138 bool isObjCPointer; 7139 if (PExp->getType()->isPointerType()) { 7140 isObjCPointer = false; 7141 } else if (PExp->getType()->isObjCObjectPointerType()) { 7142 isObjCPointer = true; 7143 } else { 7144 std::swap(PExp, IExp); 7145 if (PExp->getType()->isPointerType()) { 7146 isObjCPointer = false; 7147 } else if (PExp->getType()->isObjCObjectPointerType()) { 7148 isObjCPointer = true; 7149 } else { 7150 return InvalidOperands(Loc, LHS, RHS); 7151 } 7152 } 7153 assert(PExp->getType()->isAnyPointerType()); 7154 7155 if (!IExp->getType()->isIntegerType()) 7156 return InvalidOperands(Loc, LHS, RHS); 7157 7158 if (!checkArithmeticOpPointerOperand(*this, Loc, PExp)) 7159 return QualType(); 7160 7161 if (isObjCPointer && checkArithmeticOnObjCPointer(*this, Loc, PExp)) 7162 return QualType(); 7163 7164 // Check array bounds for pointer arithemtic 7165 CheckArrayAccess(PExp, IExp); 7166 7167 if (CompLHSTy) { 7168 QualType LHSTy = Context.isPromotableBitField(LHS.get()); 7169 if (LHSTy.isNull()) { 7170 LHSTy = LHS.get()->getType(); 7171 if (LHSTy->isPromotableIntegerType()) 7172 LHSTy = Context.getPromotedIntegerType(LHSTy); 7173 } 7174 *CompLHSTy = LHSTy; 7175 } 7176 7177 return PExp->getType(); 7178 } 7179 7180 // C99 6.5.6 7181 QualType Sema::CheckSubtractionOperands(ExprResult &LHS, ExprResult &RHS, 7182 SourceLocation Loc, 7183 QualType* CompLHSTy) { 7184 checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false); 7185 7186 if (LHS.get()->getType()->isVectorType() || 7187 RHS.get()->getType()->isVectorType()) { 7188 QualType compType = CheckVectorOperands(LHS, RHS, Loc, CompLHSTy); 7189 if (CompLHSTy) *CompLHSTy = compType; 7190 return compType; 7191 } 7192 7193 QualType compType = UsualArithmeticConversions(LHS, RHS, CompLHSTy); 7194 if (LHS.isInvalid() || RHS.isInvalid()) 7195 return QualType(); 7196 7197 // Enforce type constraints: C99 6.5.6p3. 7198 7199 // Handle the common case first (both operands are arithmetic). 7200 if (!compType.isNull() && compType->isArithmeticType()) { 7201 if (CompLHSTy) *CompLHSTy = compType; 7202 return compType; 7203 } 7204 7205 // Either ptr - int or ptr - ptr. 7206 if (LHS.get()->getType()->isAnyPointerType()) { 7207 QualType lpointee = LHS.get()->getType()->getPointeeType(); 7208 7209 // Diagnose bad cases where we step over interface counts. 7210 if (LHS.get()->getType()->isObjCObjectPointerType() && 7211 checkArithmeticOnObjCPointer(*this, Loc, LHS.get())) 7212 return QualType(); 7213 7214 // The result type of a pointer-int computation is the pointer type. 7215 if (RHS.get()->getType()->isIntegerType()) { 7216 if (!checkArithmeticOpPointerOperand(*this, Loc, LHS.get())) 7217 return QualType(); 7218 7219 // Check array bounds for pointer arithemtic 7220 CheckArrayAccess(LHS.get(), RHS.get(), /*ArraySubscriptExpr*/0, 7221 /*AllowOnePastEnd*/true, /*IndexNegated*/true); 7222 7223 if (CompLHSTy) *CompLHSTy = LHS.get()->getType(); 7224 return LHS.get()->getType(); 7225 } 7226 7227 // Handle pointer-pointer subtractions. 7228 if (const PointerType *RHSPTy 7229 = RHS.get()->getType()->getAs<PointerType>()) { 7230 QualType rpointee = RHSPTy->getPointeeType(); 7231 7232 if (getLangOpts().CPlusPlus) { 7233 // Pointee types must be the same: C++ [expr.add] 7234 if (!Context.hasSameUnqualifiedType(lpointee, rpointee)) { 7235 diagnosePointerIncompatibility(*this, Loc, LHS.get(), RHS.get()); 7236 } 7237 } else { 7238 // Pointee types must be compatible C99 6.5.6p3 7239 if (!Context.typesAreCompatible( 7240 Context.getCanonicalType(lpointee).getUnqualifiedType(), 7241 Context.getCanonicalType(rpointee).getUnqualifiedType())) { 7242 diagnosePointerIncompatibility(*this, Loc, LHS.get(), RHS.get()); 7243 return QualType(); 7244 } 7245 } 7246 7247 if (!checkArithmeticBinOpPointerOperands(*this, Loc, 7248 LHS.get(), RHS.get())) 7249 return QualType(); 7250 7251 // The pointee type may have zero size. As an extension, a structure or 7252 // union may have zero size or an array may have zero length. In this 7253 // case subtraction does not make sense. 7254 if (!rpointee->isVoidType() && !rpointee->isFunctionType()) { 7255 CharUnits ElementSize = Context.getTypeSizeInChars(rpointee); 7256 if (ElementSize.isZero()) { 7257 Diag(Loc,diag::warn_sub_ptr_zero_size_types) 7258 << rpointee.getUnqualifiedType() 7259 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 7260 } 7261 } 7262 7263 if (CompLHSTy) *CompLHSTy = LHS.get()->getType(); 7264 return Context.getPointerDiffType(); 7265 } 7266 } 7267 7268 return InvalidOperands(Loc, LHS, RHS); 7269 } 7270 7271 static bool isScopedEnumerationType(QualType T) { 7272 if (const EnumType *ET = dyn_cast<EnumType>(T)) 7273 return ET->getDecl()->isScoped(); 7274 return false; 7275 } 7276 7277 static void DiagnoseBadShiftValues(Sema& S, ExprResult &LHS, ExprResult &RHS, 7278 SourceLocation Loc, unsigned Opc, 7279 QualType LHSType) { 7280 // OpenCL 6.3j: shift values are effectively % word size of LHS (more defined), 7281 // so skip remaining warnings as we don't want to modify values within Sema. 7282 if (S.getLangOpts().OpenCL) 7283 return; 7284 7285 llvm::APSInt Right; 7286 // Check right/shifter operand 7287 if (RHS.get()->isValueDependent() || 7288 !RHS.get()->isIntegerConstantExpr(Right, S.Context)) 7289 return; 7290 7291 if (Right.isNegative()) { 7292 S.DiagRuntimeBehavior(Loc, RHS.get(), 7293 S.PDiag(diag::warn_shift_negative) 7294 << RHS.get()->getSourceRange()); 7295 return; 7296 } 7297 llvm::APInt LeftBits(Right.getBitWidth(), 7298 S.Context.getTypeSize(LHS.get()->getType())); 7299 if (Right.uge(LeftBits)) { 7300 S.DiagRuntimeBehavior(Loc, RHS.get(), 7301 S.PDiag(diag::warn_shift_gt_typewidth) 7302 << RHS.get()->getSourceRange()); 7303 return; 7304 } 7305 if (Opc != BO_Shl) 7306 return; 7307 7308 // When left shifting an ICE which is signed, we can check for overflow which 7309 // according to C++ has undefined behavior ([expr.shift] 5.8/2). Unsigned 7310 // integers have defined behavior modulo one more than the maximum value 7311 // representable in the result type, so never warn for those. 7312 llvm::APSInt Left; 7313 if (LHS.get()->isValueDependent() || 7314 !LHS.get()->isIntegerConstantExpr(Left, S.Context) || 7315 LHSType->hasUnsignedIntegerRepresentation()) 7316 return; 7317 llvm::APInt ResultBits = 7318 static_cast<llvm::APInt&>(Right) + Left.getMinSignedBits(); 7319 if (LeftBits.uge(ResultBits)) 7320 return; 7321 llvm::APSInt Result = Left.extend(ResultBits.getLimitedValue()); 7322 Result = Result.shl(Right); 7323 7324 // Print the bit representation of the signed integer as an unsigned 7325 // hexadecimal number. 7326 SmallString<40> HexResult; 7327 Result.toString(HexResult, 16, /*Signed =*/false, /*Literal =*/true); 7328 7329 // If we are only missing a sign bit, this is less likely to result in actual 7330 // bugs -- if the result is cast back to an unsigned type, it will have the 7331 // expected value. Thus we place this behind a different warning that can be 7332 // turned off separately if needed. 7333 if (LeftBits == ResultBits - 1) { 7334 S.Diag(Loc, diag::warn_shift_result_sets_sign_bit) 7335 << HexResult.str() << LHSType 7336 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 7337 return; 7338 } 7339 7340 S.Diag(Loc, diag::warn_shift_result_gt_typewidth) 7341 << HexResult.str() << Result.getMinSignedBits() << LHSType 7342 << Left.getBitWidth() << LHS.get()->getSourceRange() 7343 << RHS.get()->getSourceRange(); 7344 } 7345 7346 // C99 6.5.7 7347 QualType Sema::CheckShiftOperands(ExprResult &LHS, ExprResult &RHS, 7348 SourceLocation Loc, unsigned Opc, 7349 bool IsCompAssign) { 7350 checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false); 7351 7352 // Vector shifts promote their scalar inputs to vector type. 7353 if (LHS.get()->getType()->isVectorType() || 7354 RHS.get()->getType()->isVectorType()) 7355 return CheckVectorOperands(LHS, RHS, Loc, IsCompAssign); 7356 7357 // Shifts don't perform usual arithmetic conversions, they just do integer 7358 // promotions on each operand. C99 6.5.7p3 7359 7360 // For the LHS, do usual unary conversions, but then reset them away 7361 // if this is a compound assignment. 7362 ExprResult OldLHS = LHS; 7363 LHS = UsualUnaryConversions(LHS.take()); 7364 if (LHS.isInvalid()) 7365 return QualType(); 7366 QualType LHSType = LHS.get()->getType(); 7367 if (IsCompAssign) LHS = OldLHS; 7368 7369 // The RHS is simpler. 7370 RHS = UsualUnaryConversions(RHS.take()); 7371 if (RHS.isInvalid()) 7372 return QualType(); 7373 QualType RHSType = RHS.get()->getType(); 7374 7375 // C99 6.5.7p2: Each of the operands shall have integer type. 7376 if (!LHSType->hasIntegerRepresentation() || 7377 !RHSType->hasIntegerRepresentation()) 7378 return InvalidOperands(Loc, LHS, RHS); 7379 7380 // C++0x: Don't allow scoped enums. FIXME: Use something better than 7381 // hasIntegerRepresentation() above instead of this. 7382 if (isScopedEnumerationType(LHSType) || 7383 isScopedEnumerationType(RHSType)) { 7384 return InvalidOperands(Loc, LHS, RHS); 7385 } 7386 // Sanity-check shift operands 7387 DiagnoseBadShiftValues(*this, LHS, RHS, Loc, Opc, LHSType); 7388 7389 // "The type of the result is that of the promoted left operand." 7390 return LHSType; 7391 } 7392 7393 static bool IsWithinTemplateSpecialization(Decl *D) { 7394 if (DeclContext *DC = D->getDeclContext()) { 7395 if (isa<ClassTemplateSpecializationDecl>(DC)) 7396 return true; 7397 if (FunctionDecl *FD = dyn_cast<FunctionDecl>(DC)) 7398 return FD->isFunctionTemplateSpecialization(); 7399 } 7400 return false; 7401 } 7402 7403 /// If two different enums are compared, raise a warning. 7404 static void checkEnumComparison(Sema &S, SourceLocation Loc, Expr *LHS, 7405 Expr *RHS) { 7406 QualType LHSStrippedType = LHS->IgnoreParenImpCasts()->getType(); 7407 QualType RHSStrippedType = RHS->IgnoreParenImpCasts()->getType(); 7408 7409 const EnumType *LHSEnumType = LHSStrippedType->getAs<EnumType>(); 7410 if (!LHSEnumType) 7411 return; 7412 const EnumType *RHSEnumType = RHSStrippedType->getAs<EnumType>(); 7413 if (!RHSEnumType) 7414 return; 7415 7416 // Ignore anonymous enums. 7417 if (!LHSEnumType->getDecl()->getIdentifier()) 7418 return; 7419 if (!RHSEnumType->getDecl()->getIdentifier()) 7420 return; 7421 7422 if (S.Context.hasSameUnqualifiedType(LHSStrippedType, RHSStrippedType)) 7423 return; 7424 7425 S.Diag(Loc, diag::warn_comparison_of_mixed_enum_types) 7426 << LHSStrippedType << RHSStrippedType 7427 << LHS->getSourceRange() << RHS->getSourceRange(); 7428 } 7429 7430 /// \brief Diagnose bad pointer comparisons. 7431 static void diagnoseDistinctPointerComparison(Sema &S, SourceLocation Loc, 7432 ExprResult &LHS, ExprResult &RHS, 7433 bool IsError) { 7434 S.Diag(Loc, IsError ? diag::err_typecheck_comparison_of_distinct_pointers 7435 : diag::ext_typecheck_comparison_of_distinct_pointers) 7436 << LHS.get()->getType() << RHS.get()->getType() 7437 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 7438 } 7439 7440 /// \brief Returns false if the pointers are converted to a composite type, 7441 /// true otherwise. 7442 static bool convertPointersToCompositeType(Sema &S, SourceLocation Loc, 7443 ExprResult &LHS, ExprResult &RHS) { 7444 // C++ [expr.rel]p2: 7445 // [...] Pointer conversions (4.10) and qualification 7446 // conversions (4.4) are performed on pointer operands (or on 7447 // a pointer operand and a null pointer constant) to bring 7448 // them to their composite pointer type. [...] 7449 // 7450 // C++ [expr.eq]p1 uses the same notion for (in)equality 7451 // comparisons of pointers. 7452 7453 // C++ [expr.eq]p2: 7454 // In addition, pointers to members can be compared, or a pointer to 7455 // member and a null pointer constant. Pointer to member conversions 7456 // (4.11) and qualification conversions (4.4) are performed to bring 7457 // them to a common type. If one operand is a null pointer constant, 7458 // the common type is the type of the other operand. Otherwise, the 7459 // common type is a pointer to member type similar (4.4) to the type 7460 // of one of the operands, with a cv-qualification signature (4.4) 7461 // that is the union of the cv-qualification signatures of the operand 7462 // types. 7463 7464 QualType LHSType = LHS.get()->getType(); 7465 QualType RHSType = RHS.get()->getType(); 7466 assert((LHSType->isPointerType() && RHSType->isPointerType()) || 7467 (LHSType->isMemberPointerType() && RHSType->isMemberPointerType())); 7468 7469 bool NonStandardCompositeType = false; 7470 bool *BoolPtr = S.isSFINAEContext() ? 0 : &NonStandardCompositeType; 7471 QualType T = S.FindCompositePointerType(Loc, LHS, RHS, BoolPtr); 7472 if (T.isNull()) { 7473 diagnoseDistinctPointerComparison(S, Loc, LHS, RHS, /*isError*/true); 7474 return true; 7475 } 7476 7477 if (NonStandardCompositeType) 7478 S.Diag(Loc, diag::ext_typecheck_comparison_of_distinct_pointers_nonstandard) 7479 << LHSType << RHSType << T << LHS.get()->getSourceRange() 7480 << RHS.get()->getSourceRange(); 7481 7482 LHS = S.ImpCastExprToType(LHS.take(), T, CK_BitCast); 7483 RHS = S.ImpCastExprToType(RHS.take(), T, CK_BitCast); 7484 return false; 7485 } 7486 7487 static void diagnoseFunctionPointerToVoidComparison(Sema &S, SourceLocation Loc, 7488 ExprResult &LHS, 7489 ExprResult &RHS, 7490 bool IsError) { 7491 S.Diag(Loc, IsError ? diag::err_typecheck_comparison_of_fptr_to_void 7492 : diag::ext_typecheck_comparison_of_fptr_to_void) 7493 << LHS.get()->getType() << RHS.get()->getType() 7494 << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); 7495 } 7496 7497 static bool isObjCObjectLiteral(ExprResult &E) { 7498 switch (E.get()->IgnoreParenImpCasts()->getStmtClass()) { 7499 case Stmt::ObjCArrayLiteralClass: 7500 case Stmt::ObjCDictionaryLiteralClass: 7501 case Stmt::ObjCStringLiteralClass: 7502 case Stmt::ObjCBoxedExprClass: 7503 return true; 7504 default: 7505 // Note that ObjCBoolLiteral is NOT an object literal! 7506 return false; 7507 } 7508 } 7509 7510 static bool hasIsEqualMethod(Sema &S, const Expr *LHS, const Expr *RHS) { 7511 const ObjCObjectPointerType *Type = 7512 LHS->getType()->getAs<ObjCObjectPointerType>(); 7513 7514 // If this is not actually an Objective-C object, bail out. 7515 if (!Type) 7516 return false; 7517 7518 // Get the LHS object's interface type. 7519 QualType InterfaceType = Type->getPointeeType(); 7520 if (const ObjCObjectType *iQFaceTy = 7521 InterfaceType->getAsObjCQualifiedInterfaceType()) 7522 InterfaceType = iQFaceTy->getBaseType(); 7523 7524 // If the RHS isn't an Objective-C object, bail out. 7525 if (!RHS->getType()->isObjCObjectPointerType()) 7526 return false; 7527 7528 // Try to find the -isEqual: method. 7529 Selector IsEqualSel = S.NSAPIObj->getIsEqualSelector(); 7530 ObjCMethodDecl *Method = S.LookupMethodInObjectType(IsEqualSel, 7531 InterfaceType, 7532 /*instance=*/true); 7533 if (!Method) { 7534 if (Type->isObjCIdType()) { 7535 // For 'id', just check the global pool. 7536 Method = S.LookupInstanceMethodInGlobalPool(IsEqualSel, SourceRange(), 7537 /*receiverId=*/true, 7538 /*warn=*/false); 7539 } else { 7540 // Check protocols. 7541 Method = S.LookupMethodInQualifiedType(IsEqualSel, Type, 7542 /*instance=*/true); 7543 } 7544 } 7545 7546 if (!Method) 7547 return false; 7548 7549 QualType T = Method->param_begin()[0]->getType(); 7550 if (!T->isObjCObjectPointerType()) 7551 return false; 7552 7553 QualType R = Method->getResultType(); 7554 if (!R->isScalarType()) 7555 return false; 7556 7557 return true; 7558 } 7559 7560 Sema::ObjCLiteralKind Sema::CheckLiteralKind(Expr *FromE) { 7561 FromE = FromE->IgnoreParenImpCasts(); 7562 switch (FromE->getStmtClass()) { 7563 default: 7564 break; 7565 case Stmt::ObjCStringLiteralClass: 7566 // "string literal" 7567 return LK_String; 7568 case Stmt::ObjCArrayLiteralClass: 7569 // "array literal" 7570 return LK_Array; 7571 case Stmt::ObjCDictionaryLiteralClass: 7572 // "dictionary literal" 7573 return LK_Dictionary; 7574 case Stmt::BlockExprClass: 7575 return LK_Block; 7576 case Stmt::ObjCBoxedExprClass: { 7577 Expr *Inner = cast<ObjCBoxedExpr>(FromE)->getSubExpr()->IgnoreParens(); 7578 switch (Inner->getStmtClass()) { 7579 case Stmt::IntegerLiteralClass: 7580 case Stmt::FloatingLiteralClass: 7581 case Stmt::CharacterLiteralClass: 7582 case Stmt::ObjCBoolLiteralExprClass: 7583 case Stmt::CXXBoolLiteralExprClass: 7584 // "numeric literal" 7585 return LK_Numeric; 7586 case Stmt::ImplicitCastExprClass: { 7587 CastKind CK = cast<CastExpr>(Inner)->getCastKind(); 7588 // Boolean literals can be represented by implicit casts. 7589 if (CK == CK_IntegralToBoolean || CK == CK_IntegralCast) 7590 return LK_Numeric; 7591 break; 7592 } 7593 default: 7594 break; 7595 } 7596 return LK_Boxed; 7597 } 7598 } 7599 return LK_None; 7600 } 7601 7602 static void diagnoseObjCLiteralComparison(Sema &S, SourceLocation Loc, 7603 ExprResult &LHS, ExprResult &RHS, 7604 BinaryOperator::Opcode Opc){ 7605 Expr *Literal; 7606 Expr *Other; 7607 if (isObjCObjectLiteral(LHS)) { 7608 Literal = LHS.get(); 7609 Other = RHS.get(); 7610 } else { 7611 Literal = RHS.get(); 7612 Other = LHS.get(); 7613 } 7614 7615 // Don't warn on comparisons against nil. 7616 Other = Other->IgnoreParenCasts(); 7617 if (Other->isNullPointerConstant(S.getASTContext(), 7618 Expr::NPC_ValueDependentIsNotNull)) 7619 return; 7620 7621 // This should be kept in sync with warn_objc_literal_comparison. 7622 // LK_String should always be after the other literals, since it has its own 7623 // warning flag. 7624 Sema::ObjCLiteralKind LiteralKind = S.CheckLiteralKind(Literal); 7625 assert(LiteralKind != Sema::LK_Block); 7626 if (LiteralKind == Sema::LK_None) { 7627 llvm_unreachable("Unknown Objective-C object literal kind"); 7628 } 7629 7630 if (LiteralKind == Sema::LK_String) 7631 S.Diag(Loc, diag::warn_objc_string_literal_comparison) 7632 << Literal->getSourceRange(); 7633 else 7634 S.Diag(Loc, diag::warn_objc_literal_comparison) 7635 << LiteralKind << Literal->getSourceRange(); 7636 7637 if (BinaryOperator::isEqualityOp(Opc) && 7638 hasIsEqualMethod(S, LHS.get(), RHS.get())) { 7639 SourceLocation Start = LHS.get()->getLocStart(); 7640 SourceLocation End = S.PP.getLocForEndOfToken(RHS.get()->getLocEnd()); 7641 CharSourceRange OpRange = 7642 CharSourceRange::getCharRange(Loc, S.PP.getLocForEndOfToken(Loc)); 7643 7644 S.Diag(Loc, diag::note_objc_literal_comparison_isequal) 7645 << FixItHint::CreateInsertion(Start, Opc == BO_EQ ? "[" : "![") 7646 << FixItHint::CreateReplacement(OpRange, " isEqual:") 7647 << FixItHint::CreateInsertion(End, "]"); 7648 } 7649 } 7650 7651 static void diagnoseLogicalNotOnLHSofComparison(Sema &S, ExprResult &LHS, 7652 ExprResult &RHS, 7653 SourceLocation Loc, 7654 unsigned OpaqueOpc) { 7655 // This checking requires bools. 7656 if (!S.getLangOpts().Bool) return; 7657 7658 // Check that left hand side is !something. 7659 UnaryOperator *UO = dyn_cast<UnaryOperator>(LHS.get()->IgnoreImpCasts()); 7660 if (!UO || UO->getOpcode() != UO_LNot) return; 7661 7662 // Only check if the right hand side is non-bool arithmetic type. 7663 if (RHS.get()->getType()->isBooleanType()) return; 7664 7665 // Make sure that the something in !something is not bool. 7666 Expr *SubExpr = UO->getSubExpr()->IgnoreImpCasts(); 7667 if (SubExpr->getType()->isBooleanType()) return; 7668 7669 // Emit warning. 7670 S.Diag(UO->getOperatorLoc(), diag::warn_logical_not_on_lhs_of_comparison) 7671 << Loc; 7672 7673 // First note suggest !(x < y) 7674 SourceLocation FirstOpen = SubExpr->getLocStart(); 7675 SourceLocation FirstClose = RHS.get()->getLocEnd(); 7676 FirstClose = S.getPreprocessor().getLocForEndOfToken(FirstClose); 7677 if (FirstClose.isInvalid()) 7678 FirstOpen = SourceLocation(); 7679 S.Diag(UO->getOperatorLoc(), diag::note_logical_not_fix) 7680 << FixItHint::CreateInsertion(FirstOpen, "(") 7681 << FixItHint::CreateInsertion(FirstClose, ")"); 7682 7683 // Second note suggests (!x) < y 7684 SourceLocation SecondOpen = LHS.get()->getLocStart(); 7685 SourceLocation SecondClose = LHS.get()->getLocEnd(); 7686 SecondClose = S.getPreprocessor().getLocForEndOfToken(SecondClose); 7687 if (SecondClose.isInvalid()) 7688 SecondOpen = SourceLocation(); 7689 S.Diag(UO->getOperatorLoc(), diag::note_logical_not_silence_with_parens) 7690 << FixItHint::CreateInsertion(SecondOpen, "(") 7691 << FixItHint::CreateInsertion(SecondClose, ")"); 7692 } 7693 7694 // Get the decl for a simple expression: a reference to a variable, 7695 // an implicit C++ field reference, or an implicit ObjC ivar reference. 7696 static ValueDecl *getCompareDecl(Expr *E) { 7697 if (DeclRefExpr* DR = dyn_cast<DeclRefExpr>(E)) 7698 return DR->getDecl(); 7699 if (ObjCIvarRefExpr* Ivar = dyn_cast<ObjCIvarRefExpr>(E)) { 7700 if (Ivar->isFreeIvar()) 7701 return Ivar->getDecl(); 7702 } 7703 if (MemberExpr* Mem = dyn_cast<MemberExpr>(E)) { 7704 if (Mem->isImplicitAccess()) 7705 return Mem->getMemberDecl(); 7706 } 7707 return 0; 7708 } 7709 7710 // C99 6.5.8, C++ [expr.rel] 7711 QualType Sema::CheckCompareOperands(ExprResult &LHS, ExprResult &RHS, 7712 SourceLocation Loc, unsigned OpaqueOpc, 7713 bool IsRelational) { 7714 checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/true); 7715 7716 BinaryOperatorKind Opc = (BinaryOperatorKind) OpaqueOpc; 7717 7718 // Handle vector comparisons separately. 7719 if (LHS.get()->getType()->isVectorType() || 7720 RHS.get()->getType()->isVectorType()) 7721 return CheckVectorCompareOperands(LHS, RHS, Loc, IsRelational); 7722 7723 QualType LHSType = LHS.get()->getType(); 7724 QualType RHSType = RHS.get()->getType(); 7725 7726 Expr *LHSStripped = LHS.get()->IgnoreParenImpCasts(); 7727 Expr *RHSStripped = RHS.get()->IgnoreParenImpCasts(); 7728 7729 checkEnumComparison(*this, Loc, LHS.get(), RHS.get()); 7730 diagnoseLogicalNotOnLHSofComparison(*this, LHS, RHS, Loc, OpaqueOpc); 7731 7732 if (!LHSType->hasFloatingRepresentation() && 7733 !(LHSType->isBlockPointerType() && IsRelational) && 7734 !LHS.get()->getLocStart().isMacroID() && 7735 !RHS.get()->getLocStart().isMacroID() && 7736 ActiveTemplateInstantiations.empty()) { 7737 // For non-floating point types, check for self-comparisons of the form 7738 // x == x, x != x, x < x, etc. These always evaluate to a constant, and 7739 // often indicate logic errors in the program. 7740 // 7741 // NOTE: Don't warn about comparison expressions resulting from macro 7742 // expansion. Also don't warn about comparisons which are only self 7743 // comparisons within a template specialization. The warnings should catch 7744 // obvious cases in the definition of the template anyways. The idea is to 7745 // warn when the typed comparison operator will always evaluate to the same 7746 // result. 7747 ValueDecl *DL = getCompareDecl(LHSStripped); 7748 ValueDecl *DR = getCompareDecl(RHSStripped); 7749 if (DL && DR && DL == DR && !IsWithinTemplateSpecialization(DL)) { 7750 DiagRuntimeBehavior(Loc, 0, PDiag(diag::warn_comparison_always) 7751 << 0 // self- 7752 << (Opc == BO_EQ 7753 || Opc == BO_LE 7754 || Opc == BO_GE)); 7755 } else if (DL && DR && LHSType->isArrayType() && RHSType->isArrayType() && 7756 !DL->getType()->isReferenceType() && 7757 !DR->getType()->isReferenceType()) { 7758 // what is it always going to eval to? 7759 char always_evals_to; 7760 switch(Opc) { 7761 case BO_EQ: // e.g. array1 == array2 7762 always_evals_to = 0; // false 7763 break; 7764 case BO_NE: // e.g. array1 != array2 7765 always_evals_to = 1; // true 7766 break; 7767 default: 7768 // best we can say is 'a constant' 7769 always_evals_to = 2; // e.g. array1 <= array2 7770 break; 7771 } 7772 DiagRuntimeBehavior(Loc, 0, PDiag(diag::warn_comparison_always) 7773 << 1 // array 7774 << always_evals_to); 7775 } 7776 7777 if (isa<CastExpr>(LHSStripped)) 7778 LHSStripped = LHSStripped->IgnoreParenCasts(); 7779 if (isa<CastExpr>(RHSStripped)) 7780 RHSStripped = RHSStripped->IgnoreParenCasts(); 7781 7782 // Warn about comparisons against a string constant (unless the other 7783 // operand is null), the user probably wants strcmp. 7784 Expr *literalString = 0; 7785 Expr *literalStringStripped = 0; 7786 if ((isa<StringLiteral>(LHSStripped) || isa<ObjCEncodeExpr>(LHSStripped)) && 7787 !RHSStripped->isNullPointerConstant(Context, 7788 Expr::NPC_ValueDependentIsNull)) { 7789 literalString = LHS.get(); 7790 literalStringStripped = LHSStripped; 7791 } else if ((isa<StringLiteral>(RHSStripped) || 7792 isa<ObjCEncodeExpr>(RHSStripped)) && 7793 !LHSStripped->isNullPointerConstant(Context, 7794 Expr::NPC_ValueDependentIsNull)) { 7795 literalString = RHS.get(); 7796 literalStringStripped = RHSStripped; 7797 } 7798 7799 if (literalString) { 7800 DiagRuntimeBehavior(Loc, 0, 7801 PDiag(diag::warn_stringcompare) 7802 << isa<ObjCEncodeExpr>(literalStringStripped) 7803 << literalString->getSourceRange()); 7804 } 7805 } 7806 7807 // C99 6.5.8p3 / C99 6.5.9p4 7808 UsualArithmeticConversions(LHS, RHS); 7809 if (LHS.isInvalid() || RHS.isInvalid()) 7810 return QualType(); 7811 7812 LHSType = LHS.get()->getType(); 7813 RHSType = RHS.get()->getType(); 7814 7815 // The result of comparisons is 'bool' in C++, 'int' in C. 7816 QualType ResultTy = Context.getLogicalOperationType(); 7817 7818 if (IsRelational) { 7819 if (LHSType->isRealType() && RHSType->isRealType()) 7820 return ResultTy; 7821 } else { 7822 // Check for comparisons of floating point operands using != and ==. 7823 if (LHSType->hasFloatingRepresentation()) 7824 CheckFloatComparison(Loc, LHS.get(), RHS.get()); 7825 7826 if (LHSType->isArithmeticType() && RHSType->isArithmeticType()) 7827 return ResultTy; 7828 } 7829 7830 bool LHSIsNull = LHS.get()->isNullPointerConstant(Context, 7831 Expr::NPC_ValueDependentIsNull); 7832 bool RHSIsNull = RHS.get()->isNullPointerConstant(Context, 7833 Expr::NPC_ValueDependentIsNull); 7834 7835 // All of the following pointer-related warnings are GCC extensions, except 7836 // when handling null pointer constants. 7837 if (LHSType->isPointerType() && RHSType->isPointerType()) { // C99 6.5.8p2 7838 QualType LCanPointeeTy = 7839 LHSType->castAs<PointerType>()->getPointeeType().getCanonicalType(); 7840 QualType RCanPointeeTy = 7841 RHSType->castAs<PointerType>()->getPointeeType().getCanonicalType(); 7842 7843 if (getLangOpts().CPlusPlus) { 7844 if (LCanPointeeTy == RCanPointeeTy) 7845 return ResultTy; 7846 if (!IsRelational && 7847 (LCanPointeeTy->isVoidType() || RCanPointeeTy->isVoidType())) { 7848 // Valid unless comparison between non-null pointer and function pointer 7849 // This is a gcc extension compatibility comparison. 7850 // In a SFINAE context, we treat this as a hard error to maintain 7851 // conformance with the C++ standard. 7852 if ((LCanPointeeTy->isFunctionType() || RCanPointeeTy->isFunctionType()) 7853 && !LHSIsNull && !RHSIsNull) { 7854 diagnoseFunctionPointerToVoidComparison( 7855 *this, Loc, LHS, RHS, /*isError*/ (bool)isSFINAEContext()); 7856 7857 if (isSFINAEContext()) 7858 return QualType(); 7859 7860 RHS = ImpCastExprToType(RHS.take(), LHSType, CK_BitCast); 7861 return ResultTy; 7862 } 7863 } 7864 7865 if (convertPointersToCompositeType(*this, Loc, LHS, RHS)) 7866 return QualType(); 7867 else 7868 return ResultTy; 7869 } 7870 // C99 6.5.9p2 and C99 6.5.8p2 7871 if (Context.typesAreCompatible(LCanPointeeTy.getUnqualifiedType(), 7872 RCanPointeeTy.getUnqualifiedType())) { 7873 // Valid unless a relational comparison of function pointers 7874 if (IsRelational && LCanPointeeTy->isFunctionType()) { 7875 Diag(Loc, diag::ext_typecheck_ordered_comparison_of_function_pointers) 7876 << LHSType << RHSType << LHS.get()->getSourceRange() 7877 << RHS.get()->getSourceRange(); 7878 } 7879 } else if (!IsRelational && 7880 (LCanPointeeTy->isVoidType() || RCanPointeeTy->isVoidType())) { 7881 // Valid unless comparison between non-null pointer and function pointer 7882 if ((LCanPointeeTy->isFunctionType() || RCanPointeeTy->isFunctionType()) 7883 && !LHSIsNull && !RHSIsNull) 7884 diagnoseFunctionPointerToVoidComparison(*this, Loc, LHS, RHS, 7885 /*isError*/false); 7886 } else { 7887 // Invalid 7888 diagnoseDistinctPointerComparison(*this, Loc, LHS, RHS, /*isError*/false); 7889 } 7890 if (LCanPointeeTy != RCanPointeeTy) { 7891 unsigned AddrSpaceL = LCanPointeeTy.getAddressSpace(); 7892 unsigned AddrSpaceR = RCanPointeeTy.getAddressSpace(); 7893 CastKind Kind = AddrSpaceL != AddrSpaceR ? CK_AddressSpaceConversion 7894 : CK_BitCast; 7895 if (LHSIsNull && !RHSIsNull) 7896 LHS = ImpCastExprToType(LHS.take(), RHSType, Kind); 7897 else 7898 RHS = ImpCastExprToType(RHS.take(), LHSType, Kind); 7899 } 7900 return ResultTy; 7901 } 7902 7903 if (getLangOpts().CPlusPlus) { 7904 // Comparison of nullptr_t with itself. 7905 if (LHSType->isNullPtrType() && RHSType->isNullPtrType()) 7906 return ResultTy; 7907 7908 // Comparison of pointers with null pointer constants and equality 7909 // comparisons of member pointers to null pointer constants. 7910 if (RHSIsNull && 7911 ((LHSType->isAnyPointerType() || LHSType->isNullPtrType()) || 7912 (!IsRelational && 7913 (LHSType->isMemberPointerType() || LHSType->isBlockPointerType())))) { 7914 RHS = ImpCastExprToType(RHS.take(), LHSType, 7915 LHSType->isMemberPointerType() 7916 ? CK_NullToMemberPointer 7917 : CK_NullToPointer); 7918 return ResultTy; 7919 } 7920 if (LHSIsNull && 7921 ((RHSType->isAnyPointerType() || RHSType->isNullPtrType()) || 7922 (!IsRelational && 7923 (RHSType->isMemberPointerType() || RHSType->isBlockPointerType())))) { 7924 LHS = ImpCastExprToType(LHS.take(), RHSType, 7925 RHSType->isMemberPointerType() 7926 ? CK_NullToMemberPointer 7927 : CK_NullToPointer); 7928 return ResultTy; 7929 } 7930 7931 // Comparison of member pointers. 7932 if (!IsRelational && 7933 LHSType->isMemberPointerType() && RHSType->isMemberPointerType()) { 7934 if (convertPointersToCompositeType(*this, Loc, LHS, RHS)) 7935 return QualType(); 7936 else 7937 return ResultTy; 7938 } 7939 7940 // Handle scoped enumeration types specifically, since they don't promote 7941 // to integers. 7942 if (LHS.get()->getType()->isEnumeralType() && 7943 Context.hasSameUnqualifiedType(LHS.get()->getType(), 7944 RHS.get()->getType())) 7945 return ResultTy; 7946 } 7947 7948 // Handle block pointer types. 7949 if (!IsRelational && LHSType->isBlockPointerType() && 7950 RHSType->isBlockPointerType()) { 7951 QualType lpointee = LHSType->castAs<BlockPointerType>()->getPointeeType(); 7952 QualType rpointee = RHSType->castAs<BlockPointerType>()->getPointeeType(); 7953 7954 if (!LHSIsNull && !RHSIsNull && 7955 !Context.typesAreCompatible(lpointee, rpointee)) { 7956 Diag(Loc, diag::err_typecheck_comparison_of_distinct_blocks) 7957 << LHSType << RHSType << LHS.get()->getSourceRange() 7958 << RHS.get()->getSourceRange(); 7959 } 7960 RHS = ImpCastExprToType(RHS.take(), LHSType, CK_BitCast); 7961 return ResultTy; 7962 } 7963 7964 // Allow block pointers to be compared with null pointer constants. 7965 if (!IsRelational 7966 && ((LHSType->isBlockPointerType() && RHSType->isPointerType()) 7967 || (LHSType->isPointerType() && RHSType->isBlockPointerType()))) { 7968 if (!LHSIsNull && !RHSIsNull) { 7969 if (!((RHSType->isPointerType() && RHSType->castAs<PointerType>() 7970 ->getPointeeType()->isVoidType()) 7971 || (LHSType->isPointerType() && LHSType->castAs<PointerType>() 7972 ->getPointeeType()->isVoidType()))) 7973 Diag(Loc, diag::err_typecheck_comparison_of_distinct_blocks) 7974 << LHSType << RHSType << LHS.get()->getSourceRange() 7975 << RHS.get()->getSourceRange(); 7976 } 7977 if (LHSIsNull && !RHSIsNull) 7978 LHS = ImpCastExprToType(LHS.take(), RHSType, 7979 RHSType->isPointerType() ? CK_BitCast 7980 : CK_AnyPointerToBlockPointerCast); 7981 else 7982 RHS = ImpCastExprToType(RHS.take(), LHSType, 7983 LHSType->isPointerType() ? CK_BitCast 7984 : CK_AnyPointerToBlockPointerCast); 7985 return ResultTy; 7986 } 7987 7988 if (LHSType->isObjCObjectPointerType() || 7989 RHSType->isObjCObjectPointerType()) { 7990 const PointerType *LPT = LHSType->getAs<PointerType>(); 7991 const PointerType *RPT = RHSType->getAs<PointerType>(); 7992 if (LPT || RPT) { 7993 bool LPtrToVoid = LPT ? LPT->getPointeeType()->isVoidType() : false; 7994 bool RPtrToVoid = RPT ? RPT->getPointeeType()->isVoidType() : false; 7995 7996 if (!LPtrToVoid && !RPtrToVoid && 7997 !Context.typesAreCompatible(LHSType, RHSType)) { 7998 diagnoseDistinctPointerComparison(*this, Loc, LHS, RHS, 7999 /*isError*/false); 8000 } 8001 if (LHSIsNull && !RHSIsNull) { 8002 Expr *E = LHS.take(); 8003 if (getLangOpts().ObjCAutoRefCount) 8004 CheckObjCARCConversion(SourceRange(), RHSType, E, CCK_ImplicitConversion); 8005 LHS = ImpCastExprToType(E, RHSType, 8006 RPT ? CK_BitCast :CK_CPointerToObjCPointerCast); 8007 } 8008 else { 8009 Expr *E = RHS.take(); 8010 if (getLangOpts().ObjCAutoRefCount) 8011 CheckObjCARCConversion(SourceRange(), LHSType, E, CCK_ImplicitConversion); 8012 RHS = ImpCastExprToType(E, LHSType, 8013 LPT ? CK_BitCast :CK_CPointerToObjCPointerCast); 8014 } 8015 return ResultTy; 8016 } 8017 if (LHSType->isObjCObjectPointerType() && 8018 RHSType->isObjCObjectPointerType()) { 8019 if (!Context.areComparableObjCPointerTypes(LHSType, RHSType)) 8020 diagnoseDistinctPointerComparison(*this, Loc, LHS, RHS, 8021 /*isError*/false); 8022 if (isObjCObjectLiteral(LHS) || isObjCObjectLiteral(RHS)) 8023 diagnoseObjCLiteralComparison(*this, Loc, LHS, RHS, Opc); 8024 8025 if (LHSIsNull && !RHSIsNull) 8026 LHS = ImpCastExprToType(LHS.take(), RHSType, CK_BitCast); 8027 else 8028 RHS = ImpCastExprToType(RHS.take(), LHSType, CK_BitCast); 8029 return ResultTy; 8030 } 8031 } 8032 if ((LHSType->isAnyPointerType() && RHSType->isIntegerType()) || 8033 (LHSType->isIntegerType() && RHSType->isAnyPointerType())) { 8034 unsigned DiagID = 0; 8035 bool isError = false; 8036 if (LangOpts.DebuggerSupport) { 8037 // Under a debugger, allow the comparison of pointers to integers, 8038 // since users tend to want to compare addresses. 8039 } else if ((LHSIsNull && LHSType->isIntegerType()) || 8040 (RHSIsNull && RHSType->isIntegerType())) { 8041 if (IsRelational && !getLangOpts().CPlusPlus) 8042 DiagID = diag::ext_typecheck_ordered_comparison_of_pointer_and_zero; 8043 } else if (IsRelational && !getLangOpts().CPlusPlus) 8044 DiagID = diag::ext_typecheck_ordered_comparison_of_pointer_integer; 8045 else if (getLangOpts().CPlusPlus) { 8046 DiagID = diag::err_typecheck_comparison_of_pointer_integer; 8047 isError = true; 8048 } else 8049 DiagID = diag::ext_typecheck_comparison_of_pointer_integer; 8050 8051 if (DiagID) { 8052 Diag(Loc, DiagID) 8053 << LHSType << RHSType << LHS.get()->getSourceRange() 8054 << RHS.get()->getSourceRange(); 8055 if (isError) 8056 return QualType(); 8057 } 8058 8059 if (LHSType->isIntegerType()) 8060 LHS = ImpCastExprToType(LHS.take(), RHSType, 8061 LHSIsNull ? CK_NullToPointer : CK_IntegralToPointer); 8062 else 8063 RHS = ImpCastExprToType(RHS.take(), LHSType, 8064 RHSIsNull ? CK_NullToPointer : CK_IntegralToPointer); 8065 return ResultTy; 8066 } 8067 8068 // Handle block pointers. 8069 if (!IsRelational && RHSIsNull 8070 && LHSType->isBlockPointerType() && RHSType->isIntegerType()) { 8071 RHS = ImpCastExprToType(RHS.take(), LHSType, CK_NullToPointer); 8072 return ResultTy; 8073 } 8074 if (!IsRelational && LHSIsNull 8075 && LHSType->isIntegerType() && RHSType->isBlockPointerType()) { 8076 LHS = ImpCastExprToType(LHS.take(), RHSType, CK_NullToPointer); 8077 return ResultTy; 8078 } 8079 8080 return InvalidOperands(Loc, LHS, RHS); 8081 } 8082 8083 8084 // Return a signed type that is of identical size and number of elements. 8085 // For floating point vectors, return an integer type of identical size 8086 // and number of elements. 8087 QualType Sema::GetSignedVectorType(QualType V) { 8088 const VectorType *VTy = V->getAs<VectorType>(); 8089 unsigned TypeSize = Context.getTypeSize(VTy->getElementType()); 8090 if (TypeSize == Context.getTypeSize(Context.CharTy)) 8091 return Context.getExtVectorType(Context.CharTy, VTy->getNumElements()); 8092 else if (TypeSize == Context.getTypeSize(Context.ShortTy)) 8093 return Context.getExtVectorType(Context.ShortTy, VTy->getNumElements()); 8094 else if (TypeSize == Context.getTypeSize(Context.IntTy)) 8095 return Context.getExtVectorType(Context.IntTy, VTy->getNumElements()); 8096 else if (TypeSize == Context.getTypeSize(Context.LongTy)) 8097 return Context.getExtVectorType(Context.LongTy, VTy->getNumElements()); 8098 assert(TypeSize == Context.getTypeSize(Context.LongLongTy) && 8099 "Unhandled vector element size in vector compare"); 8100 return Context.getExtVectorType(Context.LongLongTy, VTy->getNumElements()); 8101 } 8102 8103 /// CheckVectorCompareOperands - vector comparisons are a clang extension that 8104 /// operates on extended vector types. Instead of producing an IntTy result, 8105 /// like a scalar comparison, a vector comparison produces a vector of integer 8106 /// types. 8107 QualType Sema::CheckVectorCompareOperands(ExprResult &LHS, ExprResult &RHS, 8108 SourceLocation Loc, 8109 bool IsRelational) { 8110 // Check to make sure we're operating on vectors of the same type and width, 8111 // Allowing one side to be a scalar of element type. 8112 QualType vType = CheckVectorOperands(LHS, RHS, Loc, /*isCompAssign*/false); 8113 if (vType.isNull()) 8114 return vType; 8115 8116 QualType LHSType = LHS.get()->getType(); 8117 8118 // If AltiVec, the comparison results in a numeric type, i.e. 8119 // bool for C++, int for C 8120 if (vType->getAs<VectorType>()->getVectorKind() == VectorType::AltiVecVector) 8121 return Context.getLogicalOperationType(); 8122 8123 // For non-floating point types, check for self-comparisons of the form 8124 // x == x, x != x, x < x, etc. These always evaluate to a constant, and 8125 // often indicate logic errors in the program. 8126 if (!LHSType->hasFloatingRepresentation() && 8127 ActiveTemplateInstantiations.empty()) { 8128 if (DeclRefExpr* DRL 8129 = dyn_cast<DeclRefExpr>(LHS.get()->IgnoreParenImpCasts())) 8130 if (DeclRefExpr* DRR 8131 = dyn_cast<DeclRefExpr>(RHS.get()->IgnoreParenImpCasts())) 8132 if (DRL->getDecl() == DRR->getDecl()) 8133 DiagRuntimeBehavior(Loc, 0, 8134 PDiag(diag::warn_comparison_always) 8135 << 0 // self- 8136 << 2 // "a constant" 8137 ); 8138 } 8139 8140 // Check for comparisons of floating point operands using != and ==. 8141 if (!IsRelational && LHSType->hasFloatingRepresentation()) { 8142 assert (RHS.get()->getType()->hasFloatingRepresentation()); 8143 CheckFloatComparison(Loc, LHS.get(), RHS.get()); 8144 } 8145 8146 // Return a signed type for the vector. 8147 return GetSignedVectorType(LHSType); 8148 } 8149 8150 QualType Sema::CheckVectorLogicalOperands(ExprResult &LHS, ExprResult &RHS, 8151 SourceLocation Loc) { 8152 // Ensure that either both operands are of the same vector type, or 8153 // one operand is of a vector type and the other is of its element type. 8154 QualType vType = CheckVectorOperands(LHS, RHS, Loc, false); 8155 if (vType.isNull()) 8156 return InvalidOperands(Loc, LHS, RHS); 8157 if (getLangOpts().OpenCL && getLangOpts().OpenCLVersion < 120 && 8158 vType->hasFloatingRepresentation()) 8159 return InvalidOperands(Loc, LHS, RHS); 8160 8161 return GetSignedVectorType(LHS.get()->getType()); 8162 } 8163 8164 inline QualType Sema::CheckBitwiseOperands( 8165 ExprResult &LHS, ExprResult &RHS, SourceLocation Loc, bool IsCompAssign) { 8166 checkArithmeticNull(*this, LHS, RHS, Loc, /*isCompare=*/false); 8167 8168 if (LHS.get()->getType()->isVectorType() || 8169 RHS.get()->getType()->isVectorType()) { 8170 if (LHS.get()->getType()->hasIntegerRepresentation() && 8171 RHS.get()->getType()->hasIntegerRepresentation()) 8172 return CheckVectorOperands(LHS, RHS, Loc, IsCompAssign); 8173 8174 return InvalidOperands(Loc, LHS, RHS); 8175 } 8176 8177 ExprResult LHSResult = Owned(LHS), RHSResult = Owned(RHS); 8178 QualType compType = UsualArithmeticConversions(LHSResult, RHSResult, 8179 IsCompAssign); 8180 if (LHSResult.isInvalid() || RHSResult.isInvalid()) 8181 return QualType(); 8182 LHS = LHSResult.take(); 8183 RHS = RHSResult.take(); 8184 8185 if (!compType.isNull() && compType->isIntegralOrUnscopedEnumerationType()) 8186 return compType; 8187 return InvalidOperands(Loc, LHS, RHS); 8188 } 8189 8190 inline QualType Sema::CheckLogicalOperands( // C99 6.5.[13,14] 8191 ExprResult &LHS, ExprResult &RHS, SourceLocation Loc, unsigned Opc) { 8192 8193 // Check vector operands differently. 8194 if (LHS.get()->getType()->isVectorType() || RHS.get()->getType()->isVectorType()) 8195 return CheckVectorLogicalOperands(LHS, RHS, Loc); 8196 8197 // Diagnose cases where the user write a logical and/or but probably meant a 8198 // bitwise one. We do this when the LHS is a non-bool integer and the RHS 8199 // is a constant. 8200 if (LHS.get()->getType()->isIntegerType() && 8201 !LHS.get()->getType()->isBooleanType() && 8202 RHS.get()->getType()->isIntegerType() && !RHS.get()->isValueDependent() && 8203 // Don't warn in macros or template instantiations. 8204 !Loc.isMacroID() && ActiveTemplateInstantiations.empty()) { 8205 // If the RHS can be constant folded, and if it constant folds to something 8206 // that isn't 0 or 1 (which indicate a potential logical operation that 8207 // happened to fold to true/false) then warn. 8208 // Parens on the RHS are ignored. 8209 llvm::APSInt Result; 8210 if (RHS.get()->EvaluateAsInt(Result, Context)) 8211 if ((getLangOpts().Bool && !RHS.get()->getType()->isBooleanType()) || 8212 (Result != 0 && Result != 1)) { 8213 Diag(Loc, diag::warn_logical_instead_of_bitwise) 8214 << RHS.get()->getSourceRange() 8215 << (Opc == BO_LAnd ? "&&" : "||"); 8216 // Suggest replacing the logical operator with the bitwise version 8217 Diag(Loc, diag::note_logical_instead_of_bitwise_change_operator) 8218 << (Opc == BO_LAnd ? "&" : "|") 8219 << FixItHint::CreateReplacement(SourceRange( 8220 Loc, Lexer::getLocForEndOfToken(Loc, 0, getSourceManager(), 8221 getLangOpts())), 8222 Opc == BO_LAnd ? "&" : "|"); 8223 if (Opc == BO_LAnd) 8224 // Suggest replacing "Foo() && kNonZero" with "Foo()" 8225 Diag(Loc, diag::note_logical_instead_of_bitwise_remove_constant) 8226 << FixItHint::CreateRemoval( 8227 SourceRange( 8228 Lexer::getLocForEndOfToken(LHS.get()->getLocEnd(), 8229 0, getSourceManager(), 8230 getLangOpts()), 8231 RHS.get()->getLocEnd())); 8232 } 8233 } 8234 8235 if (!Context.getLangOpts().CPlusPlus) { 8236 // OpenCL v1.1 s6.3.g: The logical operators and (&&), or (||) do 8237 // not operate on the built-in scalar and vector float types. 8238 if (Context.getLangOpts().OpenCL && 8239 Context.getLangOpts().OpenCLVersion < 120) { 8240 if (LHS.get()->getType()->isFloatingType() || 8241 RHS.get()->getType()->isFloatingType()) 8242 return InvalidOperands(Loc, LHS, RHS); 8243 } 8244 8245 LHS = UsualUnaryConversions(LHS.take()); 8246 if (LHS.isInvalid()) 8247 return QualType(); 8248 8249 RHS = UsualUnaryConversions(RHS.take()); 8250 if (RHS.isInvalid()) 8251 return QualType(); 8252 8253 if (!LHS.get()->getType()->isScalarType() || 8254 !RHS.get()->getType()->isScalarType()) 8255 return InvalidOperands(Loc, LHS, RHS); 8256 8257 return Context.IntTy; 8258 } 8259 8260 // The following is safe because we only use this method for 8261 // non-overloadable operands. 8262 8263 // C++ [expr.log.and]p1 8264 // C++ [expr.log.or]p1 8265 // The operands are both contextually converted to type bool. 8266 ExprResult LHSRes = PerformContextuallyConvertToBool(LHS.get()); 8267 if (LHSRes.isInvalid()) 8268 return InvalidOperands(Loc, LHS, RHS); 8269 LHS = LHSRes; 8270 8271 ExprResult RHSRes = PerformContextuallyConvertToBool(RHS.get()); 8272 if (RHSRes.isInvalid()) 8273 return InvalidOperands(Loc, LHS, RHS); 8274 RHS = RHSRes; 8275 8276 // C++ [expr.log.and]p2 8277 // C++ [expr.log.or]p2 8278 // The result is a bool. 8279 return Context.BoolTy; 8280 } 8281 8282 static bool IsReadonlyMessage(Expr *E, Sema &S) { 8283 const MemberExpr *ME = dyn_cast<MemberExpr>(E); 8284 if (!ME) return false; 8285 if (!isa<FieldDecl>(ME->getMemberDecl())) return false; 8286 ObjCMessageExpr *Base = 8287 dyn_cast<ObjCMessageExpr>(ME->getBase()->IgnoreParenImpCasts()); 8288 if (!Base) return false; 8289 return Base->getMethodDecl() != 0; 8290 } 8291 8292 /// Is the given expression (which must be 'const') a reference to a 8293 /// variable which was originally non-const, but which has become 8294 /// 'const' due to being captured within a block? 8295 enum NonConstCaptureKind { NCCK_None, NCCK_Block, NCCK_Lambda }; 8296 static NonConstCaptureKind isReferenceToNonConstCapture(Sema &S, Expr *E) { 8297 assert(E->isLValue() && E->getType().isConstQualified()); 8298 E = E->IgnoreParens(); 8299 8300 // Must be a reference to a declaration from an enclosing scope. 8301 DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E); 8302 if (!DRE) return NCCK_None; 8303 if (!DRE->refersToEnclosingLocal()) return NCCK_None; 8304 8305 // The declaration must be a variable which is not declared 'const'. 8306 VarDecl *var = dyn_cast<VarDecl>(DRE->getDecl()); 8307 if (!var) return NCCK_None; 8308 if (var->getType().isConstQualified()) return NCCK_None; 8309 assert(var->hasLocalStorage() && "capture added 'const' to non-local?"); 8310 8311 // Decide whether the first capture was for a block or a lambda. 8312 DeclContext *DC = S.CurContext, *Prev = 0; 8313 while (DC != var->getDeclContext()) { 8314 Prev = DC; 8315 DC = DC->getParent(); 8316 } 8317 // Unless we have an init-capture, we've gone one step too far. 8318 if (!var->isInitCapture()) 8319 DC = Prev; 8320 return (isa<BlockDecl>(DC) ? NCCK_Block : NCCK_Lambda); 8321 } 8322 8323 /// CheckForModifiableLvalue - Verify that E is a modifiable lvalue. If not, 8324 /// emit an error and return true. If so, return false. 8325 static bool CheckForModifiableLvalue(Expr *E, SourceLocation Loc, Sema &S) { 8326 assert(!E->hasPlaceholderType(BuiltinType::PseudoObject)); 8327 SourceLocation OrigLoc = Loc; 8328 Expr::isModifiableLvalueResult IsLV = E->isModifiableLvalue(S.Context, 8329 &Loc); 8330 if (IsLV == Expr::MLV_ClassTemporary && IsReadonlyMessage(E, S)) 8331 IsLV = Expr::MLV_InvalidMessageExpression; 8332 if (IsLV == Expr::MLV_Valid) 8333 return false; 8334 8335 unsigned Diag = 0; 8336 bool NeedType = false; 8337 switch (IsLV) { // C99 6.5.16p2 8338 case Expr::MLV_ConstQualified: 8339 Diag = diag::err_typecheck_assign_const; 8340 8341 // Use a specialized diagnostic when we're assigning to an object 8342 // from an enclosing function or block. 8343 if (NonConstCaptureKind NCCK = isReferenceToNonConstCapture(S, E)) { 8344 if (NCCK == NCCK_Block) 8345 Diag = diag::err_block_decl_ref_not_modifiable_lvalue; 8346 else 8347 Diag = diag::err_lambda_decl_ref_not_modifiable_lvalue; 8348 break; 8349 } 8350 8351 // In ARC, use some specialized diagnostics for occasions where we 8352 // infer 'const'. These are always pseudo-strong variables. 8353 if (S.getLangOpts().ObjCAutoRefCount) { 8354 DeclRefExpr *declRef = dyn_cast<DeclRefExpr>(E->IgnoreParenCasts()); 8355 if (declRef && isa<VarDecl>(declRef->getDecl())) { 8356 VarDecl *var = cast<VarDecl>(declRef->getDecl()); 8357 8358 // Use the normal diagnostic if it's pseudo-__strong but the 8359 // user actually wrote 'const'. 8360 if (var->isARCPseudoStrong() && 8361 (!var->getTypeSourceInfo() || 8362 !var->getTypeSourceInfo()->getType().isConstQualified())) { 8363 // There are two pseudo-strong cases: 8364 // - self 8365 ObjCMethodDecl *method = S.getCurMethodDecl(); 8366 if (method && var == method->getSelfDecl()) 8367 Diag = method->isClassMethod() 8368 ? diag::err_typecheck_arc_assign_self_class_method 8369 : diag::err_typecheck_arc_assign_self; 8370 8371 // - fast enumeration variables 8372 else 8373 Diag = diag::err_typecheck_arr_assign_enumeration; 8374 8375 SourceRange Assign; 8376 if (Loc != OrigLoc) 8377 Assign = SourceRange(OrigLoc, OrigLoc); 8378 S.Diag(Loc, Diag) << E->getSourceRange() << Assign; 8379 // We need to preserve the AST regardless, so migration tool 8380 // can do its job. 8381 return false; 8382 } 8383 } 8384 } 8385 8386 break; 8387 case Expr::MLV_ArrayType: 8388 case Expr::MLV_ArrayTemporary: 8389 Diag = diag::err_typecheck_array_not_modifiable_lvalue; 8390 NeedType = true; 8391 break; 8392 case Expr::MLV_NotObjectType: 8393 Diag = diag::err_typecheck_non_object_not_modifiable_lvalue; 8394 NeedType = true; 8395 break; 8396 case Expr::MLV_LValueCast: 8397 Diag = diag::err_typecheck_lvalue_casts_not_supported; 8398 break; 8399 case Expr::MLV_Valid: 8400 llvm_unreachable("did not take early return for MLV_Valid"); 8401 case Expr::MLV_InvalidExpression: 8402 case Expr::MLV_MemberFunction: 8403 case Expr::MLV_ClassTemporary: 8404 Diag = diag::err_typecheck_expression_not_modifiable_lvalue; 8405 break; 8406 case Expr::MLV_IncompleteType: 8407 case Expr::MLV_IncompleteVoidType: 8408 return S.RequireCompleteType(Loc, E->getType(), 8409 diag::err_typecheck_incomplete_type_not_modifiable_lvalue, E); 8410 case Expr::MLV_DuplicateVectorComponents: 8411 Diag = diag::err_typecheck_duplicate_vector_components_not_mlvalue; 8412 break; 8413 case Expr::MLV_NoSetterProperty: 8414 llvm_unreachable("readonly properties should be processed differently"); 8415 case Expr::MLV_InvalidMessageExpression: 8416 Diag = diag::error_readonly_message_assignment; 8417 break; 8418 case Expr::MLV_SubObjCPropertySetting: 8419 Diag = diag::error_no_subobject_property_setting; 8420 break; 8421 } 8422 8423 SourceRange Assign; 8424 if (Loc != OrigLoc) 8425 Assign = SourceRange(OrigLoc, OrigLoc); 8426 if (NeedType) 8427 S.Diag(Loc, Diag) << E->getType() << E->getSourceRange() << Assign; 8428 else 8429 S.Diag(Loc, Diag) << E->getSourceRange() << Assign; 8430 return true; 8431 } 8432 8433 static void CheckIdentityFieldAssignment(Expr *LHSExpr, Expr *RHSExpr, 8434 SourceLocation Loc, 8435 Sema &Sema) { 8436 // C / C++ fields 8437 MemberExpr *ML = dyn_cast<MemberExpr>(LHSExpr); 8438 MemberExpr *MR = dyn_cast<MemberExpr>(RHSExpr); 8439 if (ML && MR && ML->getMemberDecl() == MR->getMemberDecl()) { 8440 if (isa<CXXThisExpr>(ML->getBase()) && isa<CXXThisExpr>(MR->getBase())) 8441 Sema.Diag(Loc, diag::warn_identity_field_assign) << 0; 8442 } 8443 8444 // Objective-C instance variables 8445 ObjCIvarRefExpr *OL = dyn_cast<ObjCIvarRefExpr>(LHSExpr); 8446 ObjCIvarRefExpr *OR = dyn_cast<ObjCIvarRefExpr>(RHSExpr); 8447 if (OL && OR && OL->getDecl() == OR->getDecl()) { 8448 DeclRefExpr *RL = dyn_cast<DeclRefExpr>(OL->getBase()->IgnoreImpCasts()); 8449 DeclRefExpr *RR = dyn_cast<DeclRefExpr>(OR->getBase()->IgnoreImpCasts()); 8450 if (RL && RR && RL->getDecl() == RR->getDecl()) 8451 Sema.Diag(Loc, diag::warn_identity_field_assign) << 1; 8452 } 8453 } 8454 8455 // C99 6.5.16.1 8456 QualType Sema::CheckAssignmentOperands(Expr *LHSExpr, ExprResult &RHS, 8457 SourceLocation Loc, 8458 QualType CompoundType) { 8459 assert(!LHSExpr->hasPlaceholderType(BuiltinType::PseudoObject)); 8460 8461 // Verify that LHS is a modifiable lvalue, and emit error if not. 8462 if (CheckForModifiableLvalue(LHSExpr, Loc, *this)) 8463 return QualType(); 8464 8465 QualType LHSType = LHSExpr->getType(); 8466 QualType RHSType = CompoundType.isNull() ? RHS.get()->getType() : 8467 CompoundType; 8468 AssignConvertType ConvTy; 8469 if (CompoundType.isNull()) { 8470 Expr *RHSCheck = RHS.get(); 8471 8472 CheckIdentityFieldAssignment(LHSExpr, RHSCheck, Loc, *this); 8473 8474 QualType LHSTy(LHSType); 8475 ConvTy = CheckSingleAssignmentConstraints(LHSTy, RHS); 8476 if (RHS.isInvalid()) 8477 return QualType(); 8478 // Special case of NSObject attributes on c-style pointer types. 8479 if (ConvTy == IncompatiblePointer && 8480 ((Context.isObjCNSObjectType(LHSType) && 8481 RHSType->isObjCObjectPointerType()) || 8482 (Context.isObjCNSObjectType(RHSType) && 8483 LHSType->isObjCObjectPointerType()))) 8484 ConvTy = Compatible; 8485 8486 if (ConvTy == Compatible && 8487 LHSType->isObjCObjectType()) 8488 Diag(Loc, diag::err_objc_object_assignment) 8489 << LHSType; 8490 8491 // If the RHS is a unary plus or minus, check to see if they = and + are 8492 // right next to each other. If so, the user may have typo'd "x =+ 4" 8493 // instead of "x += 4". 8494 if (ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(RHSCheck)) 8495 RHSCheck = ICE->getSubExpr(); 8496 if (UnaryOperator *UO = dyn_cast<UnaryOperator>(RHSCheck)) { 8497 if ((UO->getOpcode() == UO_Plus || 8498 UO->getOpcode() == UO_Minus) && 8499 Loc.isFileID() && UO->getOperatorLoc().isFileID() && 8500 // Only if the two operators are exactly adjacent. 8501 Loc.getLocWithOffset(1) == UO->getOperatorLoc() && 8502 // And there is a space or other character before the subexpr of the 8503 // unary +/-. We don't want to warn on "x=-1". 8504 Loc.getLocWithOffset(2) != UO->getSubExpr()->getLocStart() && 8505 UO->getSubExpr()->getLocStart().isFileID()) { 8506 Diag(Loc, diag::warn_not_compound_assign) 8507 << (UO->getOpcode() == UO_Plus ? "+" : "-") 8508 << SourceRange(UO->getOperatorLoc(), UO->getOperatorLoc()); 8509 } 8510 } 8511 8512 if (ConvTy == Compatible) { 8513 if (LHSType.getObjCLifetime() == Qualifiers::OCL_Strong) { 8514 // Warn about retain cycles where a block captures the LHS, but 8515 // not if the LHS is a simple variable into which the block is 8516 // being stored...unless that variable can be captured by reference! 8517 const Expr *InnerLHS = LHSExpr->IgnoreParenCasts(); 8518 const DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(InnerLHS); 8519 if (!DRE || DRE->getDecl()->hasAttr<BlocksAttr>()) 8520 checkRetainCycles(LHSExpr, RHS.get()); 8521 8522 // It is safe to assign a weak reference into a strong variable. 8523 // Although this code can still have problems: 8524 // id x = self.weakProp; 8525 // id y = self.weakProp; 8526 // we do not warn to warn spuriously when 'x' and 'y' are on separate 8527 // paths through the function. This should be revisited if 8528 // -Wrepeated-use-of-weak is made flow-sensitive. 8529 DiagnosticsEngine::Level Level = 8530 Diags.getDiagnosticLevel(diag::warn_arc_repeated_use_of_weak, 8531 RHS.get()->getLocStart()); 8532 if (Level != DiagnosticsEngine::Ignored) 8533 getCurFunction()->markSafeWeakUse(RHS.get()); 8534 8535 } else if (getLangOpts().ObjCAutoRefCount) { 8536 checkUnsafeExprAssigns(Loc, LHSExpr, RHS.get()); 8537 } 8538 } 8539 } else { 8540 // Compound assignment "x += y" 8541 ConvTy = CheckAssignmentConstraints(Loc, LHSType, RHSType); 8542 } 8543 8544 if (DiagnoseAssignmentResult(ConvTy, Loc, LHSType, RHSType, 8545 RHS.get(), AA_Assigning)) 8546 return QualType(); 8547 8548 CheckForNullPointerDereference(*this, LHSExpr); 8549 8550 // C99 6.5.16p3: The type of an assignment expression is the type of the 8551 // left operand unless the left operand has qualified type, in which case 8552 // it is the unqualified version of the type of the left operand. 8553 // C99 6.5.16.1p2: In simple assignment, the value of the right operand 8554 // is converted to the type of the assignment expression (above). 8555 // C++ 5.17p1: the type of the assignment expression is that of its left 8556 // operand. 8557 return (getLangOpts().CPlusPlus 8558 ? LHSType : LHSType.getUnqualifiedType()); 8559 } 8560 8561 // C99 6.5.17 8562 static QualType CheckCommaOperands(Sema &S, ExprResult &LHS, ExprResult &RHS, 8563 SourceLocation Loc) { 8564 LHS = S.CheckPlaceholderExpr(LHS.take()); 8565 RHS = S.CheckPlaceholderExpr(RHS.take()); 8566 if (LHS.isInvalid() || RHS.isInvalid()) 8567 return QualType(); 8568 8569 // C's comma performs lvalue conversion (C99 6.3.2.1) on both its 8570 // operands, but not unary promotions. 8571 // C++'s comma does not do any conversions at all (C++ [expr.comma]p1). 8572 8573 // So we treat the LHS as a ignored value, and in C++ we allow the 8574 // containing site to determine what should be done with the RHS. 8575 LHS = S.IgnoredValueConversions(LHS.take()); 8576 if (LHS.isInvalid()) 8577 return QualType(); 8578 8579 S.DiagnoseUnusedExprResult(LHS.get()); 8580 8581 if (!S.getLangOpts().CPlusPlus) { 8582 RHS = S.DefaultFunctionArrayLvalueConversion(RHS.take()); 8583 if (RHS.isInvalid()) 8584 return QualType(); 8585 if (!RHS.get()->getType()->isVoidType()) 8586 S.RequireCompleteType(Loc, RHS.get()->getType(), 8587 diag::err_incomplete_type); 8588 } 8589 8590 return RHS.get()->getType(); 8591 } 8592 8593 /// CheckIncrementDecrementOperand - unlike most "Check" methods, this routine 8594 /// doesn't need to call UsualUnaryConversions or UsualArithmeticConversions. 8595 static QualType CheckIncrementDecrementOperand(Sema &S, Expr *Op, 8596 ExprValueKind &VK, 8597 SourceLocation OpLoc, 8598 bool IsInc, bool IsPrefix) { 8599 if (Op->isTypeDependent()) 8600 return S.Context.DependentTy; 8601 8602 QualType ResType = Op->getType(); 8603 // Atomic types can be used for increment / decrement where the non-atomic 8604 // versions can, so ignore the _Atomic() specifier for the purpose of 8605 // checking. 8606 if (const AtomicType *ResAtomicType = ResType->getAs<AtomicType>()) 8607 ResType = ResAtomicType->getValueType(); 8608 8609 assert(!ResType.isNull() && "no type for increment/decrement expression"); 8610 8611 if (S.getLangOpts().CPlusPlus && ResType->isBooleanType()) { 8612 // Decrement of bool is not allowed. 8613 if (!IsInc) { 8614 S.Diag(OpLoc, diag::err_decrement_bool) << Op->getSourceRange(); 8615 return QualType(); 8616 } 8617 // Increment of bool sets it to true, but is deprecated. 8618 S.Diag(OpLoc, diag::warn_increment_bool) << Op->getSourceRange(); 8619 } else if (S.getLangOpts().CPlusPlus && ResType->isEnumeralType()) { 8620 // Error on enum increments and decrements in C++ mode 8621 S.Diag(OpLoc, diag::err_increment_decrement_enum) << IsInc << ResType; 8622 return QualType(); 8623 } else if (ResType->isRealType()) { 8624 // OK! 8625 } else if (ResType->isPointerType()) { 8626 // C99 6.5.2.4p2, 6.5.6p2 8627 if (!checkArithmeticOpPointerOperand(S, OpLoc, Op)) 8628 return QualType(); 8629 } else if (ResType->isObjCObjectPointerType()) { 8630 // On modern runtimes, ObjC pointer arithmetic is forbidden. 8631 // Otherwise, we just need a complete type. 8632 if (checkArithmeticIncompletePointerType(S, OpLoc, Op) || 8633 checkArithmeticOnObjCPointer(S, OpLoc, Op)) 8634 return QualType(); 8635 } else if (ResType->isAnyComplexType()) { 8636 // C99 does not support ++/-- on complex types, we allow as an extension. 8637 S.Diag(OpLoc, diag::ext_integer_increment_complex) 8638 << ResType << Op->getSourceRange(); 8639 } else if (ResType->isPlaceholderType()) { 8640 ExprResult PR = S.CheckPlaceholderExpr(Op); 8641 if (PR.isInvalid()) return QualType(); 8642 return CheckIncrementDecrementOperand(S, PR.take(), VK, OpLoc, 8643 IsInc, IsPrefix); 8644 } else if (S.getLangOpts().AltiVec && ResType->isVectorType()) { 8645 // OK! ( C/C++ Language Extensions for CBEA(Version 2.6) 10.3 ) 8646 } else if(S.getLangOpts().OpenCL && ResType->isVectorType() && 8647 ResType->getAs<VectorType>()->getElementType()->isIntegerType()) { 8648 // OpenCL V1.2 6.3 says dec/inc ops operate on integer vector types. 8649 } else { 8650 S.Diag(OpLoc, diag::err_typecheck_illegal_increment_decrement) 8651 << ResType << int(IsInc) << Op->getSourceRange(); 8652 return QualType(); 8653 } 8654 // At this point, we know we have a real, complex or pointer type. 8655 // Now make sure the operand is a modifiable lvalue. 8656 if (CheckForModifiableLvalue(Op, OpLoc, S)) 8657 return QualType(); 8658 // In C++, a prefix increment is the same type as the operand. Otherwise 8659 // (in C or with postfix), the increment is the unqualified type of the 8660 // operand. 8661 if (IsPrefix && S.getLangOpts().CPlusPlus) { 8662 VK = VK_LValue; 8663 return ResType; 8664 } else { 8665 VK = VK_RValue; 8666 return ResType.getUnqualifiedType(); 8667 } 8668 } 8669 8670 8671 /// getPrimaryDecl - Helper function for CheckAddressOfOperand(). 8672 /// This routine allows us to typecheck complex/recursive expressions 8673 /// where the declaration is needed for type checking. We only need to 8674 /// handle cases when the expression references a function designator 8675 /// or is an lvalue. Here are some examples: 8676 /// - &(x) => x 8677 /// - &*****f => f for f a function designator. 8678 /// - &s.xx => s 8679 /// - &s.zz[1].yy -> s, if zz is an array 8680 /// - *(x + 1) -> x, if x is an array 8681 /// - &"123"[2] -> 0 8682 /// - & __real__ x -> x 8683 static ValueDecl *getPrimaryDecl(Expr *E) { 8684 switch (E->getStmtClass()) { 8685 case Stmt::DeclRefExprClass: 8686 return cast<DeclRefExpr>(E)->getDecl(); 8687 case Stmt::MemberExprClass: 8688 // If this is an arrow operator, the address is an offset from 8689 // the base's value, so the object the base refers to is 8690 // irrelevant. 8691 if (cast<MemberExpr>(E)->isArrow()) 8692 return 0; 8693 // Otherwise, the expression refers to a part of the base 8694 return getPrimaryDecl(cast<MemberExpr>(E)->getBase()); 8695 case Stmt::ArraySubscriptExprClass: { 8696 // FIXME: This code shouldn't be necessary! We should catch the implicit 8697 // promotion of register arrays earlier. 8698 Expr* Base = cast<ArraySubscriptExpr>(E)->getBase(); 8699 if (ImplicitCastExpr* ICE = dyn_cast<ImplicitCastExpr>(Base)) { 8700 if (ICE->getSubExpr()->getType()->isArrayType()) 8701 return getPrimaryDecl(ICE->getSubExpr()); 8702 } 8703 return 0; 8704 } 8705 case Stmt::UnaryOperatorClass: { 8706 UnaryOperator *UO = cast<UnaryOperator>(E); 8707 8708 switch(UO->getOpcode()) { 8709 case UO_Real: 8710 case UO_Imag: 8711 case UO_Extension: 8712 return getPrimaryDecl(UO->getSubExpr()); 8713 default: 8714 return 0; 8715 } 8716 } 8717 case Stmt::ParenExprClass: 8718 return getPrimaryDecl(cast<ParenExpr>(E)->getSubExpr()); 8719 case Stmt::ImplicitCastExprClass: 8720 // If the result of an implicit cast is an l-value, we care about 8721 // the sub-expression; otherwise, the result here doesn't matter. 8722 return getPrimaryDecl(cast<ImplicitCastExpr>(E)->getSubExpr()); 8723 default: 8724 return 0; 8725 } 8726 } 8727 8728 namespace { 8729 enum { 8730 AO_Bit_Field = 0, 8731 AO_Vector_Element = 1, 8732 AO_Property_Expansion = 2, 8733 AO_Register_Variable = 3, 8734 AO_No_Error = 4 8735 }; 8736 } 8737 /// \brief Diagnose invalid operand for address of operations. 8738 /// 8739 /// \param Type The type of operand which cannot have its address taken. 8740 static void diagnoseAddressOfInvalidType(Sema &S, SourceLocation Loc, 8741 Expr *E, unsigned Type) { 8742 S.Diag(Loc, diag::err_typecheck_address_of) << Type << E->getSourceRange(); 8743 } 8744 8745 /// CheckAddressOfOperand - The operand of & must be either a function 8746 /// designator or an lvalue designating an object. If it is an lvalue, the 8747 /// object cannot be declared with storage class register or be a bit field. 8748 /// Note: The usual conversions are *not* applied to the operand of the & 8749 /// operator (C99 6.3.2.1p[2-4]), and its result is never an lvalue. 8750 /// In C++, the operand might be an overloaded function name, in which case 8751 /// we allow the '&' but retain the overloaded-function type. 8752 QualType Sema::CheckAddressOfOperand(ExprResult &OrigOp, SourceLocation OpLoc) { 8753 if (const BuiltinType *PTy = OrigOp.get()->getType()->getAsPlaceholderType()){ 8754 if (PTy->getKind() == BuiltinType::Overload) { 8755 Expr *E = OrigOp.get()->IgnoreParens(); 8756 if (!isa<OverloadExpr>(E)) { 8757 assert(cast<UnaryOperator>(E)->getOpcode() == UO_AddrOf); 8758 Diag(OpLoc, diag::err_typecheck_invalid_lvalue_addrof_addrof_function) 8759 << OrigOp.get()->getSourceRange(); 8760 return QualType(); 8761 } 8762 8763 OverloadExpr *Ovl = cast<OverloadExpr>(E); 8764 if (isa<UnresolvedMemberExpr>(Ovl)) 8765 if (!ResolveSingleFunctionTemplateSpecialization(Ovl)) { 8766 Diag(OpLoc, diag::err_invalid_form_pointer_member_function) 8767 << OrigOp.get()->getSourceRange(); 8768 return QualType(); 8769 } 8770 8771 return Context.OverloadTy; 8772 } 8773 8774 if (PTy->getKind() == BuiltinType::UnknownAny) 8775 return Context.UnknownAnyTy; 8776 8777 if (PTy->getKind() == BuiltinType::BoundMember) { 8778 Diag(OpLoc, diag::err_invalid_form_pointer_member_function) 8779 << OrigOp.get()->getSourceRange(); 8780 return QualType(); 8781 } 8782 8783 OrigOp = CheckPlaceholderExpr(OrigOp.take()); 8784 if (OrigOp.isInvalid()) return QualType(); 8785 } 8786 8787 if (OrigOp.get()->isTypeDependent()) 8788 return Context.DependentTy; 8789 8790 assert(!OrigOp.get()->getType()->isPlaceholderType()); 8791 8792 // Make sure to ignore parentheses in subsequent checks 8793 Expr *op = OrigOp.get()->IgnoreParens(); 8794 8795 if (getLangOpts().C99) { 8796 // Implement C99-only parts of addressof rules. 8797 if (UnaryOperator* uOp = dyn_cast<UnaryOperator>(op)) { 8798 if (uOp->getOpcode() == UO_Deref) 8799 // Per C99 6.5.3.2, the address of a deref always returns a valid result 8800 // (assuming the deref expression is valid). 8801 return uOp->getSubExpr()->getType(); 8802 } 8803 // Technically, there should be a check for array subscript 8804 // expressions here, but the result of one is always an lvalue anyway. 8805 } 8806 ValueDecl *dcl = getPrimaryDecl(op); 8807 Expr::LValueClassification lval = op->ClassifyLValue(Context); 8808 unsigned AddressOfError = AO_No_Error; 8809 8810 if (lval == Expr::LV_ClassTemporary || lval == Expr::LV_ArrayTemporary) { 8811 bool sfinae = (bool)isSFINAEContext(); 8812 Diag(OpLoc, isSFINAEContext() ? diag::err_typecheck_addrof_temporary 8813 : diag::ext_typecheck_addrof_temporary) 8814 << op->getType() << op->getSourceRange(); 8815 if (sfinae) 8816 return QualType(); 8817 // Materialize the temporary as an lvalue so that we can take its address. 8818 OrigOp = op = new (Context) 8819 MaterializeTemporaryExpr(op->getType(), OrigOp.take(), true, 0); 8820 } else if (isa<ObjCSelectorExpr>(op)) { 8821 return Context.getPointerType(op->getType()); 8822 } else if (lval == Expr::LV_MemberFunction) { 8823 // If it's an instance method, make a member pointer. 8824 // The expression must have exactly the form &A::foo. 8825 8826 // If the underlying expression isn't a decl ref, give up. 8827 if (!isa<DeclRefExpr>(op)) { 8828 Diag(OpLoc, diag::err_invalid_form_pointer_member_function) 8829 << OrigOp.get()->getSourceRange(); 8830 return QualType(); 8831 } 8832 DeclRefExpr *DRE = cast<DeclRefExpr>(op); 8833 CXXMethodDecl *MD = cast<CXXMethodDecl>(DRE->getDecl()); 8834 8835 // The id-expression was parenthesized. 8836 if (OrigOp.get() != DRE) { 8837 Diag(OpLoc, diag::err_parens_pointer_member_function) 8838 << OrigOp.get()->getSourceRange(); 8839 8840 // The method was named without a qualifier. 8841 } else if (!DRE->getQualifier()) { 8842 if (MD->getParent()->getName().empty()) 8843 Diag(OpLoc, diag::err_unqualified_pointer_member_function) 8844 << op->getSourceRange(); 8845 else { 8846 SmallString<32> Str; 8847 StringRef Qual = (MD->getParent()->getName() + "::").toStringRef(Str); 8848 Diag(OpLoc, diag::err_unqualified_pointer_member_function) 8849 << op->getSourceRange() 8850 << FixItHint::CreateInsertion(op->getSourceRange().getBegin(), Qual); 8851 } 8852 } 8853 8854 // Taking the address of a dtor is illegal per C++ [class.dtor]p2. 8855 if (isa<CXXDestructorDecl>(MD)) 8856 Diag(OpLoc, diag::err_typecheck_addrof_dtor) << op->getSourceRange(); 8857 8858 QualType MPTy = Context.getMemberPointerType( 8859 op->getType(), Context.getTypeDeclType(MD->getParent()).getTypePtr()); 8860 if (Context.getTargetInfo().getCXXABI().isMicrosoft()) 8861 RequireCompleteType(OpLoc, MPTy, 0); 8862 return MPTy; 8863 } else if (lval != Expr::LV_Valid && lval != Expr::LV_IncompleteVoidType) { 8864 // C99 6.5.3.2p1 8865 // The operand must be either an l-value or a function designator 8866 if (!op->getType()->isFunctionType()) { 8867 // Use a special diagnostic for loads from property references. 8868 if (isa<PseudoObjectExpr>(op)) { 8869 AddressOfError = AO_Property_Expansion; 8870 } else { 8871 Diag(OpLoc, diag::err_typecheck_invalid_lvalue_addrof) 8872 << op->getType() << op->getSourceRange(); 8873 return QualType(); 8874 } 8875 } 8876 } else if (op->getObjectKind() == OK_BitField) { // C99 6.5.3.2p1 8877 // The operand cannot be a bit-field 8878 AddressOfError = AO_Bit_Field; 8879 } else if (op->getObjectKind() == OK_VectorComponent) { 8880 // The operand cannot be an element of a vector 8881 AddressOfError = AO_Vector_Element; 8882 } else if (dcl) { // C99 6.5.3.2p1 8883 // We have an lvalue with a decl. Make sure the decl is not declared 8884 // with the register storage-class specifier. 8885 if (const VarDecl *vd = dyn_cast<VarDecl>(dcl)) { 8886 // in C++ it is not error to take address of a register 8887 // variable (c++03 7.1.1P3) 8888 if (vd->getStorageClass() == SC_Register && 8889 !getLangOpts().CPlusPlus) { 8890 AddressOfError = AO_Register_Variable; 8891 } 8892 } else if (isa<FunctionTemplateDecl>(dcl)) { 8893 return Context.OverloadTy; 8894 } else if (isa<FieldDecl>(dcl) || isa<IndirectFieldDecl>(dcl)) { 8895 // Okay: we can take the address of a field. 8896 // Could be a pointer to member, though, if there is an explicit 8897 // scope qualifier for the class. 8898 if (isa<DeclRefExpr>(op) && cast<DeclRefExpr>(op)->getQualifier()) { 8899 DeclContext *Ctx = dcl->getDeclContext(); 8900 if (Ctx && Ctx->isRecord()) { 8901 if (dcl->getType()->isReferenceType()) { 8902 Diag(OpLoc, 8903 diag::err_cannot_form_pointer_to_member_of_reference_type) 8904 << dcl->getDeclName() << dcl->getType(); 8905 return QualType(); 8906 } 8907 8908 while (cast<RecordDecl>(Ctx)->isAnonymousStructOrUnion()) 8909 Ctx = Ctx->getParent(); 8910 8911 QualType MPTy = Context.getMemberPointerType( 8912 op->getType(), 8913 Context.getTypeDeclType(cast<RecordDecl>(Ctx)).getTypePtr()); 8914 if (Context.getTargetInfo().getCXXABI().isMicrosoft()) 8915 RequireCompleteType(OpLoc, MPTy, 0); 8916 return MPTy; 8917 } 8918 } 8919 } else if (!isa<FunctionDecl>(dcl) && !isa<NonTypeTemplateParmDecl>(dcl)) 8920 llvm_unreachable("Unknown/unexpected decl type"); 8921 } 8922 8923 if (AddressOfError != AO_No_Error) { 8924 diagnoseAddressOfInvalidType(*this, OpLoc, op, AddressOfError); 8925 return QualType(); 8926 } 8927 8928 if (lval == Expr::LV_IncompleteVoidType) { 8929 // Taking the address of a void variable is technically illegal, but we 8930 // allow it in cases which are otherwise valid. 8931 // Example: "extern void x; void* y = &x;". 8932 Diag(OpLoc, diag::ext_typecheck_addrof_void) << op->getSourceRange(); 8933 } 8934 8935 // If the operand has type "type", the result has type "pointer to type". 8936 if (op->getType()->isObjCObjectType()) 8937 return Context.getObjCObjectPointerType(op->getType()); 8938 return Context.getPointerType(op->getType()); 8939 } 8940 8941 /// CheckIndirectionOperand - Type check unary indirection (prefix '*'). 8942 static QualType CheckIndirectionOperand(Sema &S, Expr *Op, ExprValueKind &VK, 8943 SourceLocation OpLoc) { 8944 if (Op->isTypeDependent()) 8945 return S.Context.DependentTy; 8946 8947 ExprResult ConvResult = S.UsualUnaryConversions(Op); 8948 if (ConvResult.isInvalid()) 8949 return QualType(); 8950 Op = ConvResult.take(); 8951 QualType OpTy = Op->getType(); 8952 QualType Result; 8953 8954 if (isa<CXXReinterpretCastExpr>(Op)) { 8955 QualType OpOrigType = Op->IgnoreParenCasts()->getType(); 8956 S.CheckCompatibleReinterpretCast(OpOrigType, OpTy, /*IsDereference*/true, 8957 Op->getSourceRange()); 8958 } 8959 8960 // Note that per both C89 and C99, indirection is always legal, even if OpTy 8961 // is an incomplete type or void. It would be possible to warn about 8962 // dereferencing a void pointer, but it's completely well-defined, and such a 8963 // warning is unlikely to catch any mistakes. 8964 if (const PointerType *PT = OpTy->getAs<PointerType>()) 8965 Result = PT->getPointeeType(); 8966 else if (const ObjCObjectPointerType *OPT = 8967 OpTy->getAs<ObjCObjectPointerType>()) 8968 Result = OPT->getPointeeType(); 8969 else { 8970 ExprResult PR = S.CheckPlaceholderExpr(Op); 8971 if (PR.isInvalid()) return QualType(); 8972 if (PR.take() != Op) 8973 return CheckIndirectionOperand(S, PR.take(), VK, OpLoc); 8974 } 8975 8976 if (Result.isNull()) { 8977 S.Diag(OpLoc, diag::err_typecheck_indirection_requires_pointer) 8978 << OpTy << Op->getSourceRange(); 8979 return QualType(); 8980 } 8981 8982 // Dereferences are usually l-values... 8983 VK = VK_LValue; 8984 8985 // ...except that certain expressions are never l-values in C. 8986 if (!S.getLangOpts().CPlusPlus && Result.isCForbiddenLValueType()) 8987 VK = VK_RValue; 8988 8989 return Result; 8990 } 8991 8992 static inline BinaryOperatorKind ConvertTokenKindToBinaryOpcode( 8993 tok::TokenKind Kind) { 8994 BinaryOperatorKind Opc; 8995 switch (Kind) { 8996 default: llvm_unreachable("Unknown binop!"); 8997 case tok::periodstar: Opc = BO_PtrMemD; break; 8998 case tok::arrowstar: Opc = BO_PtrMemI; break; 8999 case tok::star: Opc = BO_Mul; break; 9000 case tok::slash: Opc = BO_Div; break; 9001 case tok::percent: Opc = BO_Rem; break; 9002 case tok::plus: Opc = BO_Add; break; 9003 case tok::minus: Opc = BO_Sub; break; 9004 case tok::lessless: Opc = BO_Shl; break; 9005 case tok::greatergreater: Opc = BO_Shr; break; 9006 case tok::lessequal: Opc = BO_LE; break; 9007 case tok::less: Opc = BO_LT; break; 9008 case tok::greaterequal: Opc = BO_GE; break; 9009 case tok::greater: Opc = BO_GT; break; 9010 case tok::exclaimequal: Opc = BO_NE; break; 9011 case tok::equalequal: Opc = BO_EQ; break; 9012 case tok::amp: Opc = BO_And; break; 9013 case tok::caret: Opc = BO_Xor; break; 9014 case tok::pipe: Opc = BO_Or; break; 9015 case tok::ampamp: Opc = BO_LAnd; break; 9016 case tok::pipepipe: Opc = BO_LOr; break; 9017 case tok::equal: Opc = BO_Assign; break; 9018 case tok::starequal: Opc = BO_MulAssign; break; 9019 case tok::slashequal: Opc = BO_DivAssign; break; 9020 case tok::percentequal: Opc = BO_RemAssign; break; 9021 case tok::plusequal: Opc = BO_AddAssign; break; 9022 case tok::minusequal: Opc = BO_SubAssign; break; 9023 case tok::lesslessequal: Opc = BO_ShlAssign; break; 9024 case tok::greatergreaterequal: Opc = BO_ShrAssign; break; 9025 case tok::ampequal: Opc = BO_AndAssign; break; 9026 case tok::caretequal: Opc = BO_XorAssign; break; 9027 case tok::pipeequal: Opc = BO_OrAssign; break; 9028 case tok::comma: Opc = BO_Comma; break; 9029 } 9030 return Opc; 9031 } 9032 9033 static inline UnaryOperatorKind ConvertTokenKindToUnaryOpcode( 9034 tok::TokenKind Kind) { 9035 UnaryOperatorKind Opc; 9036 switch (Kind) { 9037 default: llvm_unreachable("Unknown unary op!"); 9038 case tok::plusplus: Opc = UO_PreInc; break; 9039 case tok::minusminus: Opc = UO_PreDec; break; 9040 case tok::amp: Opc = UO_AddrOf; break; 9041 case tok::star: Opc = UO_Deref; break; 9042 case tok::plus: Opc = UO_Plus; break; 9043 case tok::minus: Opc = UO_Minus; break; 9044 case tok::tilde: Opc = UO_Not; break; 9045 case tok::exclaim: Opc = UO_LNot; break; 9046 case tok::kw___real: Opc = UO_Real; break; 9047 case tok::kw___imag: Opc = UO_Imag; break; 9048 case tok::kw___extension__: Opc = UO_Extension; break; 9049 } 9050 return Opc; 9051 } 9052 9053 /// DiagnoseSelfAssignment - Emits a warning if a value is assigned to itself. 9054 /// This warning is only emitted for builtin assignment operations. It is also 9055 /// suppressed in the event of macro expansions. 9056 static void DiagnoseSelfAssignment(Sema &S, Expr *LHSExpr, Expr *RHSExpr, 9057 SourceLocation OpLoc) { 9058 if (!S.ActiveTemplateInstantiations.empty()) 9059 return; 9060 if (OpLoc.isInvalid() || OpLoc.isMacroID()) 9061 return; 9062 LHSExpr = LHSExpr->IgnoreParenImpCasts(); 9063 RHSExpr = RHSExpr->IgnoreParenImpCasts(); 9064 const DeclRefExpr *LHSDeclRef = dyn_cast<DeclRefExpr>(LHSExpr); 9065 const DeclRefExpr *RHSDeclRef = dyn_cast<DeclRefExpr>(RHSExpr); 9066 if (!LHSDeclRef || !RHSDeclRef || 9067 LHSDeclRef->getLocation().isMacroID() || 9068 RHSDeclRef->getLocation().isMacroID()) 9069 return; 9070 const ValueDecl *LHSDecl = 9071 cast<ValueDecl>(LHSDeclRef->getDecl()->getCanonicalDecl()); 9072 const ValueDecl *RHSDecl = 9073 cast<ValueDecl>(RHSDeclRef->getDecl()->getCanonicalDecl()); 9074 if (LHSDecl != RHSDecl) 9075 return; 9076 if (LHSDecl->getType().isVolatileQualified()) 9077 return; 9078 if (const ReferenceType *RefTy = LHSDecl->getType()->getAs<ReferenceType>()) 9079 if (RefTy->getPointeeType().isVolatileQualified()) 9080 return; 9081 9082 S.Diag(OpLoc, diag::warn_self_assignment) 9083 << LHSDeclRef->getType() 9084 << LHSExpr->getSourceRange() << RHSExpr->getSourceRange(); 9085 } 9086 9087 /// Check if a bitwise-& is performed on an Objective-C pointer. This 9088 /// is usually indicative of introspection within the Objective-C pointer. 9089 static void checkObjCPointerIntrospection(Sema &S, ExprResult &L, ExprResult &R, 9090 SourceLocation OpLoc) { 9091 if (!S.getLangOpts().ObjC1) 9092 return; 9093 9094 const Expr *ObjCPointerExpr = 0, *OtherExpr = 0; 9095 const Expr *LHS = L.get(); 9096 const Expr *RHS = R.get(); 9097 9098 if (LHS->IgnoreParenCasts()->getType()->isObjCObjectPointerType()) { 9099 ObjCPointerExpr = LHS; 9100 OtherExpr = RHS; 9101 } 9102 else if (RHS->IgnoreParenCasts()->getType()->isObjCObjectPointerType()) { 9103 ObjCPointerExpr = RHS; 9104 OtherExpr = LHS; 9105 } 9106 9107 // This warning is deliberately made very specific to reduce false 9108 // positives with logic that uses '&' for hashing. This logic mainly 9109 // looks for code trying to introspect into tagged pointers, which 9110 // code should generally never do. 9111 if (ObjCPointerExpr && isa<IntegerLiteral>(OtherExpr->IgnoreParenCasts())) { 9112 unsigned Diag = diag::warn_objc_pointer_masking; 9113 // Determine if we are introspecting the result of performSelectorXXX. 9114 const Expr *Ex = ObjCPointerExpr->IgnoreParenCasts(); 9115 // Special case messages to -performSelector and friends, which 9116 // can return non-pointer values boxed in a pointer value. 9117 // Some clients may wish to silence warnings in this subcase. 9118 if (const ObjCMessageExpr *ME = dyn_cast<ObjCMessageExpr>(Ex)) { 9119 Selector S = ME->getSelector(); 9120 StringRef SelArg0 = S.getNameForSlot(0); 9121 if (SelArg0.startswith("performSelector")) 9122 Diag = diag::warn_objc_pointer_masking_performSelector; 9123 } 9124 9125 S.Diag(OpLoc, Diag) 9126 << ObjCPointerExpr->getSourceRange(); 9127 } 9128 } 9129 9130 /// CreateBuiltinBinOp - Creates a new built-in binary operation with 9131 /// operator @p Opc at location @c TokLoc. This routine only supports 9132 /// built-in operations; ActOnBinOp handles overloaded operators. 9133 ExprResult Sema::CreateBuiltinBinOp(SourceLocation OpLoc, 9134 BinaryOperatorKind Opc, 9135 Expr *LHSExpr, Expr *RHSExpr) { 9136 if (getLangOpts().CPlusPlus11 && isa<InitListExpr>(RHSExpr)) { 9137 // The syntax only allows initializer lists on the RHS of assignment, 9138 // so we don't need to worry about accepting invalid code for 9139 // non-assignment operators. 9140 // C++11 5.17p9: 9141 // The meaning of x = {v} [...] is that of x = T(v) [...]. The meaning 9142 // of x = {} is x = T(). 9143 InitializationKind Kind = 9144 InitializationKind::CreateDirectList(RHSExpr->getLocStart()); 9145 InitializedEntity Entity = 9146 InitializedEntity::InitializeTemporary(LHSExpr->getType()); 9147 InitializationSequence InitSeq(*this, Entity, Kind, RHSExpr); 9148 ExprResult Init = InitSeq.Perform(*this, Entity, Kind, RHSExpr); 9149 if (Init.isInvalid()) 9150 return Init; 9151 RHSExpr = Init.take(); 9152 } 9153 9154 ExprResult LHS = Owned(LHSExpr), RHS = Owned(RHSExpr); 9155 QualType ResultTy; // Result type of the binary operator. 9156 // The following two variables are used for compound assignment operators 9157 QualType CompLHSTy; // Type of LHS after promotions for computation 9158 QualType CompResultTy; // Type of computation result 9159 ExprValueKind VK = VK_RValue; 9160 ExprObjectKind OK = OK_Ordinary; 9161 9162 switch (Opc) { 9163 case BO_Assign: 9164 ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, QualType()); 9165 if (getLangOpts().CPlusPlus && 9166 LHS.get()->getObjectKind() != OK_ObjCProperty) { 9167 VK = LHS.get()->getValueKind(); 9168 OK = LHS.get()->getObjectKind(); 9169 } 9170 if (!ResultTy.isNull()) 9171 DiagnoseSelfAssignment(*this, LHS.get(), RHS.get(), OpLoc); 9172 break; 9173 case BO_PtrMemD: 9174 case BO_PtrMemI: 9175 ResultTy = CheckPointerToMemberOperands(LHS, RHS, VK, OpLoc, 9176 Opc == BO_PtrMemI); 9177 break; 9178 case BO_Mul: 9179 case BO_Div: 9180 ResultTy = CheckMultiplyDivideOperands(LHS, RHS, OpLoc, false, 9181 Opc == BO_Div); 9182 break; 9183 case BO_Rem: 9184 ResultTy = CheckRemainderOperands(LHS, RHS, OpLoc); 9185 break; 9186 case BO_Add: 9187 ResultTy = CheckAdditionOperands(LHS, RHS, OpLoc, Opc); 9188 break; 9189 case BO_Sub: 9190 ResultTy = CheckSubtractionOperands(LHS, RHS, OpLoc); 9191 break; 9192 case BO_Shl: 9193 case BO_Shr: 9194 ResultTy = CheckShiftOperands(LHS, RHS, OpLoc, Opc); 9195 break; 9196 case BO_LE: 9197 case BO_LT: 9198 case BO_GE: 9199 case BO_GT: 9200 ResultTy = CheckCompareOperands(LHS, RHS, OpLoc, Opc, true); 9201 break; 9202 case BO_EQ: 9203 case BO_NE: 9204 ResultTy = CheckCompareOperands(LHS, RHS, OpLoc, Opc, false); 9205 break; 9206 case BO_And: 9207 checkObjCPointerIntrospection(*this, LHS, RHS, OpLoc); 9208 case BO_Xor: 9209 case BO_Or: 9210 ResultTy = CheckBitwiseOperands(LHS, RHS, OpLoc); 9211 break; 9212 case BO_LAnd: 9213 case BO_LOr: 9214 ResultTy = CheckLogicalOperands(LHS, RHS, OpLoc, Opc); 9215 break; 9216 case BO_MulAssign: 9217 case BO_DivAssign: 9218 CompResultTy = CheckMultiplyDivideOperands(LHS, RHS, OpLoc, true, 9219 Opc == BO_DivAssign); 9220 CompLHSTy = CompResultTy; 9221 if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid()) 9222 ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy); 9223 break; 9224 case BO_RemAssign: 9225 CompResultTy = CheckRemainderOperands(LHS, RHS, OpLoc, true); 9226 CompLHSTy = CompResultTy; 9227 if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid()) 9228 ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy); 9229 break; 9230 case BO_AddAssign: 9231 CompResultTy = CheckAdditionOperands(LHS, RHS, OpLoc, Opc, &CompLHSTy); 9232 if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid()) 9233 ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy); 9234 break; 9235 case BO_SubAssign: 9236 CompResultTy = CheckSubtractionOperands(LHS, RHS, OpLoc, &CompLHSTy); 9237 if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid()) 9238 ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy); 9239 break; 9240 case BO_ShlAssign: 9241 case BO_ShrAssign: 9242 CompResultTy = CheckShiftOperands(LHS, RHS, OpLoc, Opc, true); 9243 CompLHSTy = CompResultTy; 9244 if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid()) 9245 ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy); 9246 break; 9247 case BO_AndAssign: 9248 case BO_XorAssign: 9249 case BO_OrAssign: 9250 CompResultTy = CheckBitwiseOperands(LHS, RHS, OpLoc, true); 9251 CompLHSTy = CompResultTy; 9252 if (!CompResultTy.isNull() && !LHS.isInvalid() && !RHS.isInvalid()) 9253 ResultTy = CheckAssignmentOperands(LHS.get(), RHS, OpLoc, CompResultTy); 9254 break; 9255 case BO_Comma: 9256 ResultTy = CheckCommaOperands(*this, LHS, RHS, OpLoc); 9257 if (getLangOpts().CPlusPlus && !RHS.isInvalid()) { 9258 VK = RHS.get()->getValueKind(); 9259 OK = RHS.get()->getObjectKind(); 9260 } 9261 break; 9262 } 9263 if (ResultTy.isNull() || LHS.isInvalid() || RHS.isInvalid()) 9264 return ExprError(); 9265 9266 // Check for array bounds violations for both sides of the BinaryOperator 9267 CheckArrayAccess(LHS.get()); 9268 CheckArrayAccess(RHS.get()); 9269 9270 if (const ObjCIsaExpr *OISA = dyn_cast<ObjCIsaExpr>(LHS.get()->IgnoreParenCasts())) { 9271 NamedDecl *ObjectSetClass = LookupSingleName(TUScope, 9272 &Context.Idents.get("object_setClass"), 9273 SourceLocation(), LookupOrdinaryName); 9274 if (ObjectSetClass && isa<ObjCIsaExpr>(LHS.get())) { 9275 SourceLocation RHSLocEnd = PP.getLocForEndOfToken(RHS.get()->getLocEnd()); 9276 Diag(LHS.get()->getExprLoc(), diag::warn_objc_isa_assign) << 9277 FixItHint::CreateInsertion(LHS.get()->getLocStart(), "object_setClass(") << 9278 FixItHint::CreateReplacement(SourceRange(OISA->getOpLoc(), OpLoc), ",") << 9279 FixItHint::CreateInsertion(RHSLocEnd, ")"); 9280 } 9281 else 9282 Diag(LHS.get()->getExprLoc(), diag::warn_objc_isa_assign); 9283 } 9284 else if (const ObjCIvarRefExpr *OIRE = 9285 dyn_cast<ObjCIvarRefExpr>(LHS.get()->IgnoreParenCasts())) 9286 DiagnoseDirectIsaAccess(*this, OIRE, OpLoc, RHS.get()); 9287 9288 if (CompResultTy.isNull()) 9289 return Owned(new (Context) BinaryOperator(LHS.take(), RHS.take(), Opc, 9290 ResultTy, VK, OK, OpLoc, 9291 FPFeatures.fp_contract)); 9292 if (getLangOpts().CPlusPlus && LHS.get()->getObjectKind() != 9293 OK_ObjCProperty) { 9294 VK = VK_LValue; 9295 OK = LHS.get()->getObjectKind(); 9296 } 9297 return Owned(new (Context) CompoundAssignOperator(LHS.take(), RHS.take(), Opc, 9298 ResultTy, VK, OK, CompLHSTy, 9299 CompResultTy, OpLoc, 9300 FPFeatures.fp_contract)); 9301 } 9302 9303 /// DiagnoseBitwisePrecedence - Emit a warning when bitwise and comparison 9304 /// operators are mixed in a way that suggests that the programmer forgot that 9305 /// comparison operators have higher precedence. The most typical example of 9306 /// such code is "flags & 0x0020 != 0", which is equivalent to "flags & 1". 9307 static void DiagnoseBitwisePrecedence(Sema &Self, BinaryOperatorKind Opc, 9308 SourceLocation OpLoc, Expr *LHSExpr, 9309 Expr *RHSExpr) { 9310 BinaryOperator *LHSBO = dyn_cast<BinaryOperator>(LHSExpr); 9311 BinaryOperator *RHSBO = dyn_cast<BinaryOperator>(RHSExpr); 9312 9313 // Check that one of the sides is a comparison operator. 9314 bool isLeftComp = LHSBO && LHSBO->isComparisonOp(); 9315 bool isRightComp = RHSBO && RHSBO->isComparisonOp(); 9316 if (!isLeftComp && !isRightComp) 9317 return; 9318 9319 // Bitwise operations are sometimes used as eager logical ops. 9320 // Don't diagnose this. 9321 bool isLeftBitwise = LHSBO && LHSBO->isBitwiseOp(); 9322 bool isRightBitwise = RHSBO && RHSBO->isBitwiseOp(); 9323 if ((isLeftComp || isLeftBitwise) && (isRightComp || isRightBitwise)) 9324 return; 9325 9326 SourceRange DiagRange = isLeftComp ? SourceRange(LHSExpr->getLocStart(), 9327 OpLoc) 9328 : SourceRange(OpLoc, RHSExpr->getLocEnd()); 9329 StringRef OpStr = isLeftComp ? LHSBO->getOpcodeStr() : RHSBO->getOpcodeStr(); 9330 SourceRange ParensRange = isLeftComp ? 9331 SourceRange(LHSBO->getRHS()->getLocStart(), RHSExpr->getLocEnd()) 9332 : SourceRange(LHSExpr->getLocStart(), RHSBO->getLHS()->getLocStart()); 9333 9334 Self.Diag(OpLoc, diag::warn_precedence_bitwise_rel) 9335 << DiagRange << BinaryOperator::getOpcodeStr(Opc) << OpStr; 9336 SuggestParentheses(Self, OpLoc, 9337 Self.PDiag(diag::note_precedence_silence) << OpStr, 9338 (isLeftComp ? LHSExpr : RHSExpr)->getSourceRange()); 9339 SuggestParentheses(Self, OpLoc, 9340 Self.PDiag(diag::note_precedence_bitwise_first) 9341 << BinaryOperator::getOpcodeStr(Opc), 9342 ParensRange); 9343 } 9344 9345 /// \brief It accepts a '&' expr that is inside a '|' one. 9346 /// Emit a diagnostic together with a fixit hint that wraps the '&' expression 9347 /// in parentheses. 9348 static void 9349 EmitDiagnosticForBitwiseAndInBitwiseOr(Sema &Self, SourceLocation OpLoc, 9350 BinaryOperator *Bop) { 9351 assert(Bop->getOpcode() == BO_And); 9352 Self.Diag(Bop->getOperatorLoc(), diag::warn_bitwise_and_in_bitwise_or) 9353 << Bop->getSourceRange() << OpLoc; 9354 SuggestParentheses(Self, Bop->getOperatorLoc(), 9355 Self.PDiag(diag::note_precedence_silence) 9356 << Bop->getOpcodeStr(), 9357 Bop->getSourceRange()); 9358 } 9359 9360 /// \brief It accepts a '&&' expr that is inside a '||' one. 9361 /// Emit a diagnostic together with a fixit hint that wraps the '&&' expression 9362 /// in parentheses. 9363 static void 9364 EmitDiagnosticForLogicalAndInLogicalOr(Sema &Self, SourceLocation OpLoc, 9365 BinaryOperator *Bop) { 9366 assert(Bop->getOpcode() == BO_LAnd); 9367 Self.Diag(Bop->getOperatorLoc(), diag::warn_logical_and_in_logical_or) 9368 << Bop->getSourceRange() << OpLoc; 9369 SuggestParentheses(Self, Bop->getOperatorLoc(), 9370 Self.PDiag(diag::note_precedence_silence) 9371 << Bop->getOpcodeStr(), 9372 Bop->getSourceRange()); 9373 } 9374 9375 /// \brief Returns true if the given expression can be evaluated as a constant 9376 /// 'true'. 9377 static bool EvaluatesAsTrue(Sema &S, Expr *E) { 9378 bool Res; 9379 return !E->isValueDependent() && 9380 E->EvaluateAsBooleanCondition(Res, S.getASTContext()) && Res; 9381 } 9382 9383 /// \brief Returns true if the given expression can be evaluated as a constant 9384 /// 'false'. 9385 static bool EvaluatesAsFalse(Sema &S, Expr *E) { 9386 bool Res; 9387 return !E->isValueDependent() && 9388 E->EvaluateAsBooleanCondition(Res, S.getASTContext()) && !Res; 9389 } 9390 9391 /// \brief Look for '&&' in the left hand of a '||' expr. 9392 static void DiagnoseLogicalAndInLogicalOrLHS(Sema &S, SourceLocation OpLoc, 9393 Expr *LHSExpr, Expr *RHSExpr) { 9394 if (BinaryOperator *Bop = dyn_cast<BinaryOperator>(LHSExpr)) { 9395 if (Bop->getOpcode() == BO_LAnd) { 9396 // If it's "a && b || 0" don't warn since the precedence doesn't matter. 9397 if (EvaluatesAsFalse(S, RHSExpr)) 9398 return; 9399 // If it's "1 && a || b" don't warn since the precedence doesn't matter. 9400 if (!EvaluatesAsTrue(S, Bop->getLHS())) 9401 return EmitDiagnosticForLogicalAndInLogicalOr(S, OpLoc, Bop); 9402 } else if (Bop->getOpcode() == BO_LOr) { 9403 if (BinaryOperator *RBop = dyn_cast<BinaryOperator>(Bop->getRHS())) { 9404 // If it's "a || b && 1 || c" we didn't warn earlier for 9405 // "a || b && 1", but warn now. 9406 if (RBop->getOpcode() == BO_LAnd && EvaluatesAsTrue(S, RBop->getRHS())) 9407 return EmitDiagnosticForLogicalAndInLogicalOr(S, OpLoc, RBop); 9408 } 9409 } 9410 } 9411 } 9412 9413 /// \brief Look for '&&' in the right hand of a '||' expr. 9414 static void DiagnoseLogicalAndInLogicalOrRHS(Sema &S, SourceLocation OpLoc, 9415 Expr *LHSExpr, Expr *RHSExpr) { 9416 if (BinaryOperator *Bop = dyn_cast<BinaryOperator>(RHSExpr)) { 9417 if (Bop->getOpcode() == BO_LAnd) { 9418 // If it's "0 || a && b" don't warn since the precedence doesn't matter. 9419 if (EvaluatesAsFalse(S, LHSExpr)) 9420 return; 9421 // If it's "a || b && 1" don't warn since the precedence doesn't matter. 9422 if (!EvaluatesAsTrue(S, Bop->getRHS())) 9423 return EmitDiagnosticForLogicalAndInLogicalOr(S, OpLoc, Bop); 9424 } 9425 } 9426 } 9427 9428 /// \brief Look for '&' in the left or right hand of a '|' expr. 9429 static void DiagnoseBitwiseAndInBitwiseOr(Sema &S, SourceLocation OpLoc, 9430 Expr *OrArg) { 9431 if (BinaryOperator *Bop = dyn_cast<BinaryOperator>(OrArg)) { 9432 if (Bop->getOpcode() == BO_And) 9433 return EmitDiagnosticForBitwiseAndInBitwiseOr(S, OpLoc, Bop); 9434 } 9435 } 9436 9437 static void DiagnoseAdditionInShift(Sema &S, SourceLocation OpLoc, 9438 Expr *SubExpr, StringRef Shift) { 9439 if (BinaryOperator *Bop = dyn_cast<BinaryOperator>(SubExpr)) { 9440 if (Bop->getOpcode() == BO_Add || Bop->getOpcode() == BO_Sub) { 9441 StringRef Op = Bop->getOpcodeStr(); 9442 S.Diag(Bop->getOperatorLoc(), diag::warn_addition_in_bitshift) 9443 << Bop->getSourceRange() << OpLoc << Shift << Op; 9444 SuggestParentheses(S, Bop->getOperatorLoc(), 9445 S.PDiag(diag::note_precedence_silence) << Op, 9446 Bop->getSourceRange()); 9447 } 9448 } 9449 } 9450 9451 static void DiagnoseShiftCompare(Sema &S, SourceLocation OpLoc, 9452 Expr *LHSExpr, Expr *RHSExpr) { 9453 CXXOperatorCallExpr *OCE = dyn_cast<CXXOperatorCallExpr>(LHSExpr); 9454 if (!OCE) 9455 return; 9456 9457 FunctionDecl *FD = OCE->getDirectCallee(); 9458 if (!FD || !FD->isOverloadedOperator()) 9459 return; 9460 9461 OverloadedOperatorKind Kind = FD->getOverloadedOperator(); 9462 if (Kind != OO_LessLess && Kind != OO_GreaterGreater) 9463 return; 9464 9465 S.Diag(OpLoc, diag::warn_overloaded_shift_in_comparison) 9466 << LHSExpr->getSourceRange() << RHSExpr->getSourceRange() 9467 << (Kind == OO_LessLess); 9468 SuggestParentheses(S, OCE->getOperatorLoc(), 9469 S.PDiag(diag::note_precedence_silence) 9470 << (Kind == OO_LessLess ? "<<" : ">>"), 9471 OCE->getSourceRange()); 9472 SuggestParentheses(S, OpLoc, 9473 S.PDiag(diag::note_evaluate_comparison_first), 9474 SourceRange(OCE->getArg(1)->getLocStart(), 9475 RHSExpr->getLocEnd())); 9476 } 9477 9478 /// DiagnoseBinOpPrecedence - Emit warnings for expressions with tricky 9479 /// precedence. 9480 static void DiagnoseBinOpPrecedence(Sema &Self, BinaryOperatorKind Opc, 9481 SourceLocation OpLoc, Expr *LHSExpr, 9482 Expr *RHSExpr){ 9483 // Diagnose "arg1 'bitwise' arg2 'eq' arg3". 9484 if (BinaryOperator::isBitwiseOp(Opc)) 9485 DiagnoseBitwisePrecedence(Self, Opc, OpLoc, LHSExpr, RHSExpr); 9486 9487 // Diagnose "arg1 & arg2 | arg3" 9488 if (Opc == BO_Or && !OpLoc.isMacroID()/* Don't warn in macros. */) { 9489 DiagnoseBitwiseAndInBitwiseOr(Self, OpLoc, LHSExpr); 9490 DiagnoseBitwiseAndInBitwiseOr(Self, OpLoc, RHSExpr); 9491 } 9492 9493 // Warn about arg1 || arg2 && arg3, as GCC 4.3+ does. 9494 // We don't warn for 'assert(a || b && "bad")' since this is safe. 9495 if (Opc == BO_LOr && !OpLoc.isMacroID()/* Don't warn in macros. */) { 9496 DiagnoseLogicalAndInLogicalOrLHS(Self, OpLoc, LHSExpr, RHSExpr); 9497 DiagnoseLogicalAndInLogicalOrRHS(Self, OpLoc, LHSExpr, RHSExpr); 9498 } 9499 9500 if ((Opc == BO_Shl && LHSExpr->getType()->isIntegralType(Self.getASTContext())) 9501 || Opc == BO_Shr) { 9502 StringRef Shift = BinaryOperator::getOpcodeStr(Opc); 9503 DiagnoseAdditionInShift(Self, OpLoc, LHSExpr, Shift); 9504 DiagnoseAdditionInShift(Self, OpLoc, RHSExpr, Shift); 9505 } 9506 9507 // Warn on overloaded shift operators and comparisons, such as: 9508 // cout << 5 == 4; 9509 if (BinaryOperator::isComparisonOp(Opc)) 9510 DiagnoseShiftCompare(Self, OpLoc, LHSExpr, RHSExpr); 9511 } 9512 9513 // Binary Operators. 'Tok' is the token for the operator. 9514 ExprResult Sema::ActOnBinOp(Scope *S, SourceLocation TokLoc, 9515 tok::TokenKind Kind, 9516 Expr *LHSExpr, Expr *RHSExpr) { 9517 BinaryOperatorKind Opc = ConvertTokenKindToBinaryOpcode(Kind); 9518 assert((LHSExpr != 0) && "ActOnBinOp(): missing left expression"); 9519 assert((RHSExpr != 0) && "ActOnBinOp(): missing right expression"); 9520 9521 // Emit warnings for tricky precedence issues, e.g. "bitfield & 0x4 == 0" 9522 DiagnoseBinOpPrecedence(*this, Opc, TokLoc, LHSExpr, RHSExpr); 9523 9524 return BuildBinOp(S, TokLoc, Opc, LHSExpr, RHSExpr); 9525 } 9526 9527 /// Build an overloaded binary operator expression in the given scope. 9528 static ExprResult BuildOverloadedBinOp(Sema &S, Scope *Sc, SourceLocation OpLoc, 9529 BinaryOperatorKind Opc, 9530 Expr *LHS, Expr *RHS) { 9531 // Find all of the overloaded operators visible from this 9532 // point. We perform both an operator-name lookup from the local 9533 // scope and an argument-dependent lookup based on the types of 9534 // the arguments. 9535 UnresolvedSet<16> Functions; 9536 OverloadedOperatorKind OverOp 9537 = BinaryOperator::getOverloadedOperator(Opc); 9538 if (Sc && OverOp != OO_None) 9539 S.LookupOverloadedOperatorName(OverOp, Sc, LHS->getType(), 9540 RHS->getType(), Functions); 9541 9542 // Build the (potentially-overloaded, potentially-dependent) 9543 // binary operation. 9544 return S.CreateOverloadedBinOp(OpLoc, Opc, Functions, LHS, RHS); 9545 } 9546 9547 ExprResult Sema::BuildBinOp(Scope *S, SourceLocation OpLoc, 9548 BinaryOperatorKind Opc, 9549 Expr *LHSExpr, Expr *RHSExpr) { 9550 // We want to end up calling one of checkPseudoObjectAssignment 9551 // (if the LHS is a pseudo-object), BuildOverloadedBinOp (if 9552 // both expressions are overloadable or either is type-dependent), 9553 // or CreateBuiltinBinOp (in any other case). We also want to get 9554 // any placeholder types out of the way. 9555 9556 // Handle pseudo-objects in the LHS. 9557 if (const BuiltinType *pty = LHSExpr->getType()->getAsPlaceholderType()) { 9558 // Assignments with a pseudo-object l-value need special analysis. 9559 if (pty->getKind() == BuiltinType::PseudoObject && 9560 BinaryOperator::isAssignmentOp(Opc)) 9561 return checkPseudoObjectAssignment(S, OpLoc, Opc, LHSExpr, RHSExpr); 9562 9563 // Don't resolve overloads if the other type is overloadable. 9564 if (pty->getKind() == BuiltinType::Overload) { 9565 // We can't actually test that if we still have a placeholder, 9566 // though. Fortunately, none of the exceptions we see in that 9567 // code below are valid when the LHS is an overload set. Note 9568 // that an overload set can be dependently-typed, but it never 9569 // instantiates to having an overloadable type. 9570 ExprResult resolvedRHS = CheckPlaceholderExpr(RHSExpr); 9571 if (resolvedRHS.isInvalid()) return ExprError(); 9572 RHSExpr = resolvedRHS.take(); 9573 9574 if (RHSExpr->isTypeDependent() || 9575 RHSExpr->getType()->isOverloadableType()) 9576 return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr); 9577 } 9578 9579 ExprResult LHS = CheckPlaceholderExpr(LHSExpr); 9580 if (LHS.isInvalid()) return ExprError(); 9581 LHSExpr = LHS.take(); 9582 } 9583 9584 // Handle pseudo-objects in the RHS. 9585 if (const BuiltinType *pty = RHSExpr->getType()->getAsPlaceholderType()) { 9586 // An overload in the RHS can potentially be resolved by the type 9587 // being assigned to. 9588 if (Opc == BO_Assign && pty->getKind() == BuiltinType::Overload) { 9589 if (LHSExpr->isTypeDependent() || RHSExpr->isTypeDependent()) 9590 return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr); 9591 9592 if (LHSExpr->getType()->isOverloadableType()) 9593 return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr); 9594 9595 return CreateBuiltinBinOp(OpLoc, Opc, LHSExpr, RHSExpr); 9596 } 9597 9598 // Don't resolve overloads if the other type is overloadable. 9599 if (pty->getKind() == BuiltinType::Overload && 9600 LHSExpr->getType()->isOverloadableType()) 9601 return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr); 9602 9603 ExprResult resolvedRHS = CheckPlaceholderExpr(RHSExpr); 9604 if (!resolvedRHS.isUsable()) return ExprError(); 9605 RHSExpr = resolvedRHS.take(); 9606 } 9607 9608 if (getLangOpts().CPlusPlus) { 9609 // If either expression is type-dependent, always build an 9610 // overloaded op. 9611 if (LHSExpr->isTypeDependent() || RHSExpr->isTypeDependent()) 9612 return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr); 9613 9614 // Otherwise, build an overloaded op if either expression has an 9615 // overloadable type. 9616 if (LHSExpr->getType()->isOverloadableType() || 9617 RHSExpr->getType()->isOverloadableType()) 9618 return BuildOverloadedBinOp(*this, S, OpLoc, Opc, LHSExpr, RHSExpr); 9619 } 9620 9621 // Build a built-in binary operation. 9622 return CreateBuiltinBinOp(OpLoc, Opc, LHSExpr, RHSExpr); 9623 } 9624 9625 ExprResult Sema::CreateBuiltinUnaryOp(SourceLocation OpLoc, 9626 UnaryOperatorKind Opc, 9627 Expr *InputExpr) { 9628 ExprResult Input = Owned(InputExpr); 9629 ExprValueKind VK = VK_RValue; 9630 ExprObjectKind OK = OK_Ordinary; 9631 QualType resultType; 9632 switch (Opc) { 9633 case UO_PreInc: 9634 case UO_PreDec: 9635 case UO_PostInc: 9636 case UO_PostDec: 9637 resultType = CheckIncrementDecrementOperand(*this, Input.get(), VK, OpLoc, 9638 Opc == UO_PreInc || 9639 Opc == UO_PostInc, 9640 Opc == UO_PreInc || 9641 Opc == UO_PreDec); 9642 break; 9643 case UO_AddrOf: 9644 resultType = CheckAddressOfOperand(Input, OpLoc); 9645 break; 9646 case UO_Deref: { 9647 Input = DefaultFunctionArrayLvalueConversion(Input.take()); 9648 if (Input.isInvalid()) return ExprError(); 9649 resultType = CheckIndirectionOperand(*this, Input.get(), VK, OpLoc); 9650 break; 9651 } 9652 case UO_Plus: 9653 case UO_Minus: 9654 Input = UsualUnaryConversions(Input.take()); 9655 if (Input.isInvalid()) return ExprError(); 9656 resultType = Input.get()->getType(); 9657 if (resultType->isDependentType()) 9658 break; 9659 if (resultType->isArithmeticType() || // C99 6.5.3.3p1 9660 resultType->isVectorType()) 9661 break; 9662 else if (getLangOpts().CPlusPlus && // C++ [expr.unary.op]p6 9663 Opc == UO_Plus && 9664 resultType->isPointerType()) 9665 break; 9666 9667 return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr) 9668 << resultType << Input.get()->getSourceRange()); 9669 9670 case UO_Not: // bitwise complement 9671 Input = UsualUnaryConversions(Input.take()); 9672 if (Input.isInvalid()) 9673 return ExprError(); 9674 resultType = Input.get()->getType(); 9675 if (resultType->isDependentType()) 9676 break; 9677 // C99 6.5.3.3p1. We allow complex int and float as a GCC extension. 9678 if (resultType->isComplexType() || resultType->isComplexIntegerType()) 9679 // C99 does not support '~' for complex conjugation. 9680 Diag(OpLoc, diag::ext_integer_complement_complex) 9681 << resultType << Input.get()->getSourceRange(); 9682 else if (resultType->hasIntegerRepresentation()) 9683 break; 9684 else if (resultType->isExtVectorType()) { 9685 if (Context.getLangOpts().OpenCL) { 9686 // OpenCL v1.1 s6.3.f: The bitwise operator not (~) does not operate 9687 // on vector float types. 9688 QualType T = resultType->getAs<ExtVectorType>()->getElementType(); 9689 if (!T->isIntegerType()) 9690 return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr) 9691 << resultType << Input.get()->getSourceRange()); 9692 } 9693 break; 9694 } else { 9695 return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr) 9696 << resultType << Input.get()->getSourceRange()); 9697 } 9698 break; 9699 9700 case UO_LNot: // logical negation 9701 // Unlike +/-/~, integer promotions aren't done here (C99 6.5.3.3p5). 9702 Input = DefaultFunctionArrayLvalueConversion(Input.take()); 9703 if (Input.isInvalid()) return ExprError(); 9704 resultType = Input.get()->getType(); 9705 9706 // Though we still have to promote half FP to float... 9707 if (resultType->isHalfType() && !Context.getLangOpts().NativeHalfType) { 9708 Input = ImpCastExprToType(Input.take(), Context.FloatTy, CK_FloatingCast).take(); 9709 resultType = Context.FloatTy; 9710 } 9711 9712 if (resultType->isDependentType()) 9713 break; 9714 if (resultType->isScalarType() && !isScopedEnumerationType(resultType)) { 9715 // C99 6.5.3.3p1: ok, fallthrough; 9716 if (Context.getLangOpts().CPlusPlus) { 9717 // C++03 [expr.unary.op]p8, C++0x [expr.unary.op]p9: 9718 // operand contextually converted to bool. 9719 Input = ImpCastExprToType(Input.take(), Context.BoolTy, 9720 ScalarTypeToBooleanCastKind(resultType)); 9721 } else if (Context.getLangOpts().OpenCL && 9722 Context.getLangOpts().OpenCLVersion < 120) { 9723 // OpenCL v1.1 6.3.h: The logical operator not (!) does not 9724 // operate on scalar float types. 9725 if (!resultType->isIntegerType()) 9726 return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr) 9727 << resultType << Input.get()->getSourceRange()); 9728 } 9729 } else if (resultType->isExtVectorType()) { 9730 if (Context.getLangOpts().OpenCL && 9731 Context.getLangOpts().OpenCLVersion < 120) { 9732 // OpenCL v1.1 6.3.h: The logical operator not (!) does not 9733 // operate on vector float types. 9734 QualType T = resultType->getAs<ExtVectorType>()->getElementType(); 9735 if (!T->isIntegerType()) 9736 return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr) 9737 << resultType << Input.get()->getSourceRange()); 9738 } 9739 // Vector logical not returns the signed variant of the operand type. 9740 resultType = GetSignedVectorType(resultType); 9741 break; 9742 } else { 9743 return ExprError(Diag(OpLoc, diag::err_typecheck_unary_expr) 9744 << resultType << Input.get()->getSourceRange()); 9745 } 9746 9747 // LNot always has type int. C99 6.5.3.3p5. 9748 // In C++, it's bool. C++ 5.3.1p8 9749 resultType = Context.getLogicalOperationType(); 9750 break; 9751 case UO_Real: 9752 case UO_Imag: 9753 resultType = CheckRealImagOperand(*this, Input, OpLoc, Opc == UO_Real); 9754 // _Real maps ordinary l-values into ordinary l-values. _Imag maps ordinary 9755 // complex l-values to ordinary l-values and all other values to r-values. 9756 if (Input.isInvalid()) return ExprError(); 9757 if (Opc == UO_Real || Input.get()->getType()->isAnyComplexType()) { 9758 if (Input.get()->getValueKind() != VK_RValue && 9759 Input.get()->getObjectKind() == OK_Ordinary) 9760 VK = Input.get()->getValueKind(); 9761 } else if (!getLangOpts().CPlusPlus) { 9762 // In C, a volatile scalar is read by __imag. In C++, it is not. 9763 Input = DefaultLvalueConversion(Input.take()); 9764 } 9765 break; 9766 case UO_Extension: 9767 resultType = Input.get()->getType(); 9768 VK = Input.get()->getValueKind(); 9769 OK = Input.get()->getObjectKind(); 9770 break; 9771 } 9772 if (resultType.isNull() || Input.isInvalid()) 9773 return ExprError(); 9774 9775 // Check for array bounds violations in the operand of the UnaryOperator, 9776 // except for the '*' and '&' operators that have to be handled specially 9777 // by CheckArrayAccess (as there are special cases like &array[arraysize] 9778 // that are explicitly defined as valid by the standard). 9779 if (Opc != UO_AddrOf && Opc != UO_Deref) 9780 CheckArrayAccess(Input.get()); 9781 9782 return Owned(new (Context) UnaryOperator(Input.take(), Opc, resultType, 9783 VK, OK, OpLoc)); 9784 } 9785 9786 /// \brief Determine whether the given expression is a qualified member 9787 /// access expression, of a form that could be turned into a pointer to member 9788 /// with the address-of operator. 9789 static bool isQualifiedMemberAccess(Expr *E) { 9790 if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E)) { 9791 if (!DRE->getQualifier()) 9792 return false; 9793 9794 ValueDecl *VD = DRE->getDecl(); 9795 if (!VD->isCXXClassMember()) 9796 return false; 9797 9798 if (isa<FieldDecl>(VD) || isa<IndirectFieldDecl>(VD)) 9799 return true; 9800 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(VD)) 9801 return Method->isInstance(); 9802 9803 return false; 9804 } 9805 9806 if (UnresolvedLookupExpr *ULE = dyn_cast<UnresolvedLookupExpr>(E)) { 9807 if (!ULE->getQualifier()) 9808 return false; 9809 9810 for (UnresolvedLookupExpr::decls_iterator D = ULE->decls_begin(), 9811 DEnd = ULE->decls_end(); 9812 D != DEnd; ++D) { 9813 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(*D)) { 9814 if (Method->isInstance()) 9815 return true; 9816 } else { 9817 // Overload set does not contain methods. 9818 break; 9819 } 9820 } 9821 9822 return false; 9823 } 9824 9825 return false; 9826 } 9827 9828 ExprResult Sema::BuildUnaryOp(Scope *S, SourceLocation OpLoc, 9829 UnaryOperatorKind Opc, Expr *Input) { 9830 // First things first: handle placeholders so that the 9831 // overloaded-operator check considers the right type. 9832 if (const BuiltinType *pty = Input->getType()->getAsPlaceholderType()) { 9833 // Increment and decrement of pseudo-object references. 9834 if (pty->getKind() == BuiltinType::PseudoObject && 9835 UnaryOperator::isIncrementDecrementOp(Opc)) 9836 return checkPseudoObjectIncDec(S, OpLoc, Opc, Input); 9837 9838 // extension is always a builtin operator. 9839 if (Opc == UO_Extension) 9840 return CreateBuiltinUnaryOp(OpLoc, Opc, Input); 9841 9842 // & gets special logic for several kinds of placeholder. 9843 // The builtin code knows what to do. 9844 if (Opc == UO_AddrOf && 9845 (pty->getKind() == BuiltinType::Overload || 9846 pty->getKind() == BuiltinType::UnknownAny || 9847 pty->getKind() == BuiltinType::BoundMember)) 9848 return CreateBuiltinUnaryOp(OpLoc, Opc, Input); 9849 9850 // Anything else needs to be handled now. 9851 ExprResult Result = CheckPlaceholderExpr(Input); 9852 if (Result.isInvalid()) return ExprError(); 9853 Input = Result.take(); 9854 } 9855 9856 if (getLangOpts().CPlusPlus && Input->getType()->isOverloadableType() && 9857 UnaryOperator::getOverloadedOperator(Opc) != OO_None && 9858 !(Opc == UO_AddrOf && isQualifiedMemberAccess(Input))) { 9859 // Find all of the overloaded operators visible from this 9860 // point. We perform both an operator-name lookup from the local 9861 // scope and an argument-dependent lookup based on the types of 9862 // the arguments. 9863 UnresolvedSet<16> Functions; 9864 OverloadedOperatorKind OverOp = UnaryOperator::getOverloadedOperator(Opc); 9865 if (S && OverOp != OO_None) 9866 LookupOverloadedOperatorName(OverOp, S, Input->getType(), QualType(), 9867 Functions); 9868 9869 return CreateOverloadedUnaryOp(OpLoc, Opc, Functions, Input); 9870 } 9871 9872 return CreateBuiltinUnaryOp(OpLoc, Opc, Input); 9873 } 9874 9875 // Unary Operators. 'Tok' is the token for the operator. 9876 ExprResult Sema::ActOnUnaryOp(Scope *S, SourceLocation OpLoc, 9877 tok::TokenKind Op, Expr *Input) { 9878 return BuildUnaryOp(S, OpLoc, ConvertTokenKindToUnaryOpcode(Op), Input); 9879 } 9880 9881 /// ActOnAddrLabel - Parse the GNU address of label extension: "&&foo". 9882 ExprResult Sema::ActOnAddrLabel(SourceLocation OpLoc, SourceLocation LabLoc, 9883 LabelDecl *TheDecl) { 9884 TheDecl->markUsed(Context); 9885 // Create the AST node. The address of a label always has type 'void*'. 9886 return Owned(new (Context) AddrLabelExpr(OpLoc, LabLoc, TheDecl, 9887 Context.getPointerType(Context.VoidTy))); 9888 } 9889 9890 /// Given the last statement in a statement-expression, check whether 9891 /// the result is a producing expression (like a call to an 9892 /// ns_returns_retained function) and, if so, rebuild it to hoist the 9893 /// release out of the full-expression. Otherwise, return null. 9894 /// Cannot fail. 9895 static Expr *maybeRebuildARCConsumingStmt(Stmt *Statement) { 9896 // Should always be wrapped with one of these. 9897 ExprWithCleanups *cleanups = dyn_cast<ExprWithCleanups>(Statement); 9898 if (!cleanups) return 0; 9899 9900 ImplicitCastExpr *cast = dyn_cast<ImplicitCastExpr>(cleanups->getSubExpr()); 9901 if (!cast || cast->getCastKind() != CK_ARCConsumeObject) 9902 return 0; 9903 9904 // Splice out the cast. This shouldn't modify any interesting 9905 // features of the statement. 9906 Expr *producer = cast->getSubExpr(); 9907 assert(producer->getType() == cast->getType()); 9908 assert(producer->getValueKind() == cast->getValueKind()); 9909 cleanups->setSubExpr(producer); 9910 return cleanups; 9911 } 9912 9913 void Sema::ActOnStartStmtExpr() { 9914 PushExpressionEvaluationContext(ExprEvalContexts.back().Context); 9915 } 9916 9917 void Sema::ActOnStmtExprError() { 9918 // Note that function is also called by TreeTransform when leaving a 9919 // StmtExpr scope without rebuilding anything. 9920 9921 DiscardCleanupsInEvaluationContext(); 9922 PopExpressionEvaluationContext(); 9923 } 9924 9925 ExprResult 9926 Sema::ActOnStmtExpr(SourceLocation LPLoc, Stmt *SubStmt, 9927 SourceLocation RPLoc) { // "({..})" 9928 assert(SubStmt && isa<CompoundStmt>(SubStmt) && "Invalid action invocation!"); 9929 CompoundStmt *Compound = cast<CompoundStmt>(SubStmt); 9930 9931 if (hasAnyUnrecoverableErrorsInThisFunction()) 9932 DiscardCleanupsInEvaluationContext(); 9933 assert(!ExprNeedsCleanups && "cleanups within StmtExpr not correctly bound!"); 9934 PopExpressionEvaluationContext(); 9935 9936 bool isFileScope 9937 = (getCurFunctionOrMethodDecl() == 0) && (getCurBlock() == 0); 9938 if (isFileScope) 9939 return ExprError(Diag(LPLoc, diag::err_stmtexpr_file_scope)); 9940 9941 // FIXME: there are a variety of strange constraints to enforce here, for 9942 // example, it is not possible to goto into a stmt expression apparently. 9943 // More semantic analysis is needed. 9944 9945 // If there are sub-stmts in the compound stmt, take the type of the last one 9946 // as the type of the stmtexpr. 9947 QualType Ty = Context.VoidTy; 9948 bool StmtExprMayBindToTemp = false; 9949 if (!Compound->body_empty()) { 9950 Stmt *LastStmt = Compound->body_back(); 9951 LabelStmt *LastLabelStmt = 0; 9952 // If LastStmt is a label, skip down through into the body. 9953 while (LabelStmt *Label = dyn_cast<LabelStmt>(LastStmt)) { 9954 LastLabelStmt = Label; 9955 LastStmt = Label->getSubStmt(); 9956 } 9957 9958 if (Expr *LastE = dyn_cast<Expr>(LastStmt)) { 9959 // Do function/array conversion on the last expression, but not 9960 // lvalue-to-rvalue. However, initialize an unqualified type. 9961 ExprResult LastExpr = DefaultFunctionArrayConversion(LastE); 9962 if (LastExpr.isInvalid()) 9963 return ExprError(); 9964 Ty = LastExpr.get()->getType().getUnqualifiedType(); 9965 9966 if (!Ty->isDependentType() && !LastExpr.get()->isTypeDependent()) { 9967 // In ARC, if the final expression ends in a consume, splice 9968 // the consume out and bind it later. In the alternate case 9969 // (when dealing with a retainable type), the result 9970 // initialization will create a produce. In both cases the 9971 // result will be +1, and we'll need to balance that out with 9972 // a bind. 9973 if (Expr *rebuiltLastStmt 9974 = maybeRebuildARCConsumingStmt(LastExpr.get())) { 9975 LastExpr = rebuiltLastStmt; 9976 } else { 9977 LastExpr = PerformCopyInitialization( 9978 InitializedEntity::InitializeResult(LPLoc, 9979 Ty, 9980 false), 9981 SourceLocation(), 9982 LastExpr); 9983 } 9984 9985 if (LastExpr.isInvalid()) 9986 return ExprError(); 9987 if (LastExpr.get() != 0) { 9988 if (!LastLabelStmt) 9989 Compound->setLastStmt(LastExpr.take()); 9990 else 9991 LastLabelStmt->setSubStmt(LastExpr.take()); 9992 StmtExprMayBindToTemp = true; 9993 } 9994 } 9995 } 9996 } 9997 9998 // FIXME: Check that expression type is complete/non-abstract; statement 9999 // expressions are not lvalues. 10000 Expr *ResStmtExpr = new (Context) StmtExpr(Compound, Ty, LPLoc, RPLoc); 10001 if (StmtExprMayBindToTemp) 10002 return MaybeBindToTemporary(ResStmtExpr); 10003 return Owned(ResStmtExpr); 10004 } 10005 10006 ExprResult Sema::BuildBuiltinOffsetOf(SourceLocation BuiltinLoc, 10007 TypeSourceInfo *TInfo, 10008 OffsetOfComponent *CompPtr, 10009 unsigned NumComponents, 10010 SourceLocation RParenLoc) { 10011 QualType ArgTy = TInfo->getType(); 10012 bool Dependent = ArgTy->isDependentType(); 10013 SourceRange TypeRange = TInfo->getTypeLoc().getLocalSourceRange(); 10014 10015 // We must have at least one component that refers to the type, and the first 10016 // one is known to be a field designator. Verify that the ArgTy represents 10017 // a struct/union/class. 10018 if (!Dependent && !ArgTy->isRecordType()) 10019 return ExprError(Diag(BuiltinLoc, diag::err_offsetof_record_type) 10020 << ArgTy << TypeRange); 10021 10022 // Type must be complete per C99 7.17p3 because a declaring a variable 10023 // with an incomplete type would be ill-formed. 10024 if (!Dependent 10025 && RequireCompleteType(BuiltinLoc, ArgTy, 10026 diag::err_offsetof_incomplete_type, TypeRange)) 10027 return ExprError(); 10028 10029 // offsetof with non-identifier designators (e.g. "offsetof(x, a.b[c])") are a 10030 // GCC extension, diagnose them. 10031 // FIXME: This diagnostic isn't actually visible because the location is in 10032 // a system header! 10033 if (NumComponents != 1) 10034 Diag(BuiltinLoc, diag::ext_offsetof_extended_field_designator) 10035 << SourceRange(CompPtr[1].LocStart, CompPtr[NumComponents-1].LocEnd); 10036 10037 bool DidWarnAboutNonPOD = false; 10038 QualType CurrentType = ArgTy; 10039 typedef OffsetOfExpr::OffsetOfNode OffsetOfNode; 10040 SmallVector<OffsetOfNode, 4> Comps; 10041 SmallVector<Expr*, 4> Exprs; 10042 for (unsigned i = 0; i != NumComponents; ++i) { 10043 const OffsetOfComponent &OC = CompPtr[i]; 10044 if (OC.isBrackets) { 10045 // Offset of an array sub-field. TODO: Should we allow vector elements? 10046 if (!CurrentType->isDependentType()) { 10047 const ArrayType *AT = Context.getAsArrayType(CurrentType); 10048 if(!AT) 10049 return ExprError(Diag(OC.LocEnd, diag::err_offsetof_array_type) 10050 << CurrentType); 10051 CurrentType = AT->getElementType(); 10052 } else 10053 CurrentType = Context.DependentTy; 10054 10055 ExprResult IdxRval = DefaultLvalueConversion(static_cast<Expr*>(OC.U.E)); 10056 if (IdxRval.isInvalid()) 10057 return ExprError(); 10058 Expr *Idx = IdxRval.take(); 10059 10060 // The expression must be an integral expression. 10061 // FIXME: An integral constant expression? 10062 if (!Idx->isTypeDependent() && !Idx->isValueDependent() && 10063 !Idx->getType()->isIntegerType()) 10064 return ExprError(Diag(Idx->getLocStart(), 10065 diag::err_typecheck_subscript_not_integer) 10066 << Idx->getSourceRange()); 10067 10068 // Record this array index. 10069 Comps.push_back(OffsetOfNode(OC.LocStart, Exprs.size(), OC.LocEnd)); 10070 Exprs.push_back(Idx); 10071 continue; 10072 } 10073 10074 // Offset of a field. 10075 if (CurrentType->isDependentType()) { 10076 // We have the offset of a field, but we can't look into the dependent 10077 // type. Just record the identifier of the field. 10078 Comps.push_back(OffsetOfNode(OC.LocStart, OC.U.IdentInfo, OC.LocEnd)); 10079 CurrentType = Context.DependentTy; 10080 continue; 10081 } 10082 10083 // We need to have a complete type to look into. 10084 if (RequireCompleteType(OC.LocStart, CurrentType, 10085 diag::err_offsetof_incomplete_type)) 10086 return ExprError(); 10087 10088 // Look for the designated field. 10089 const RecordType *RC = CurrentType->getAs<RecordType>(); 10090 if (!RC) 10091 return ExprError(Diag(OC.LocEnd, diag::err_offsetof_record_type) 10092 << CurrentType); 10093 RecordDecl *RD = RC->getDecl(); 10094 10095 // C++ [lib.support.types]p5: 10096 // The macro offsetof accepts a restricted set of type arguments in this 10097 // International Standard. type shall be a POD structure or a POD union 10098 // (clause 9). 10099 // C++11 [support.types]p4: 10100 // If type is not a standard-layout class (Clause 9), the results are 10101 // undefined. 10102 if (CXXRecordDecl *CRD = dyn_cast<CXXRecordDecl>(RD)) { 10103 bool IsSafe = LangOpts.CPlusPlus11? CRD->isStandardLayout() : CRD->isPOD(); 10104 unsigned DiagID = 10105 LangOpts.CPlusPlus11? diag::warn_offsetof_non_standardlayout_type 10106 : diag::warn_offsetof_non_pod_type; 10107 10108 if (!IsSafe && !DidWarnAboutNonPOD && 10109 DiagRuntimeBehavior(BuiltinLoc, 0, 10110 PDiag(DiagID) 10111 << SourceRange(CompPtr[0].LocStart, OC.LocEnd) 10112 << CurrentType)) 10113 DidWarnAboutNonPOD = true; 10114 } 10115 10116 // Look for the field. 10117 LookupResult R(*this, OC.U.IdentInfo, OC.LocStart, LookupMemberName); 10118 LookupQualifiedName(R, RD); 10119 FieldDecl *MemberDecl = R.getAsSingle<FieldDecl>(); 10120 IndirectFieldDecl *IndirectMemberDecl = 0; 10121 if (!MemberDecl) { 10122 if ((IndirectMemberDecl = R.getAsSingle<IndirectFieldDecl>())) 10123 MemberDecl = IndirectMemberDecl->getAnonField(); 10124 } 10125 10126 if (!MemberDecl) 10127 return ExprError(Diag(BuiltinLoc, diag::err_no_member) 10128 << OC.U.IdentInfo << RD << SourceRange(OC.LocStart, 10129 OC.LocEnd)); 10130 10131 // C99 7.17p3: 10132 // (If the specified member is a bit-field, the behavior is undefined.) 10133 // 10134 // We diagnose this as an error. 10135 if (MemberDecl->isBitField()) { 10136 Diag(OC.LocEnd, diag::err_offsetof_bitfield) 10137 << MemberDecl->getDeclName() 10138 << SourceRange(BuiltinLoc, RParenLoc); 10139 Diag(MemberDecl->getLocation(), diag::note_bitfield_decl); 10140 return ExprError(); 10141 } 10142 10143 RecordDecl *Parent = MemberDecl->getParent(); 10144 if (IndirectMemberDecl) 10145 Parent = cast<RecordDecl>(IndirectMemberDecl->getDeclContext()); 10146 10147 // If the member was found in a base class, introduce OffsetOfNodes for 10148 // the base class indirections. 10149 CXXBasePaths Paths; 10150 if (IsDerivedFrom(CurrentType, Context.getTypeDeclType(Parent), Paths)) { 10151 if (Paths.getDetectedVirtual()) { 10152 Diag(OC.LocEnd, diag::err_offsetof_field_of_virtual_base) 10153 << MemberDecl->getDeclName() 10154 << SourceRange(BuiltinLoc, RParenLoc); 10155 return ExprError(); 10156 } 10157 10158 CXXBasePath &Path = Paths.front(); 10159 for (CXXBasePath::iterator B = Path.begin(), BEnd = Path.end(); 10160 B != BEnd; ++B) 10161 Comps.push_back(OffsetOfNode(B->Base)); 10162 } 10163 10164 if (IndirectMemberDecl) { 10165 for (IndirectFieldDecl::chain_iterator FI = 10166 IndirectMemberDecl->chain_begin(), 10167 FEnd = IndirectMemberDecl->chain_end(); FI != FEnd; FI++) { 10168 assert(isa<FieldDecl>(*FI)); 10169 Comps.push_back(OffsetOfNode(OC.LocStart, 10170 cast<FieldDecl>(*FI), OC.LocEnd)); 10171 } 10172 } else 10173 Comps.push_back(OffsetOfNode(OC.LocStart, MemberDecl, OC.LocEnd)); 10174 10175 CurrentType = MemberDecl->getType().getNonReferenceType(); 10176 } 10177 10178 return Owned(OffsetOfExpr::Create(Context, Context.getSizeType(), BuiltinLoc, 10179 TInfo, Comps, Exprs, RParenLoc)); 10180 } 10181 10182 ExprResult Sema::ActOnBuiltinOffsetOf(Scope *S, 10183 SourceLocation BuiltinLoc, 10184 SourceLocation TypeLoc, 10185 ParsedType ParsedArgTy, 10186 OffsetOfComponent *CompPtr, 10187 unsigned NumComponents, 10188 SourceLocation RParenLoc) { 10189 10190 TypeSourceInfo *ArgTInfo; 10191 QualType ArgTy = GetTypeFromParser(ParsedArgTy, &ArgTInfo); 10192 if (ArgTy.isNull()) 10193 return ExprError(); 10194 10195 if (!ArgTInfo) 10196 ArgTInfo = Context.getTrivialTypeSourceInfo(ArgTy, TypeLoc); 10197 10198 return BuildBuiltinOffsetOf(BuiltinLoc, ArgTInfo, CompPtr, NumComponents, 10199 RParenLoc); 10200 } 10201 10202 10203 ExprResult Sema::ActOnChooseExpr(SourceLocation BuiltinLoc, 10204 Expr *CondExpr, 10205 Expr *LHSExpr, Expr *RHSExpr, 10206 SourceLocation RPLoc) { 10207 assert((CondExpr && LHSExpr && RHSExpr) && "Missing type argument(s)"); 10208 10209 ExprValueKind VK = VK_RValue; 10210 ExprObjectKind OK = OK_Ordinary; 10211 QualType resType; 10212 bool ValueDependent = false; 10213 bool CondIsTrue = false; 10214 if (CondExpr->isTypeDependent() || CondExpr->isValueDependent()) { 10215 resType = Context.DependentTy; 10216 ValueDependent = true; 10217 } else { 10218 // The conditional expression is required to be a constant expression. 10219 llvm::APSInt condEval(32); 10220 ExprResult CondICE 10221 = VerifyIntegerConstantExpression(CondExpr, &condEval, 10222 diag::err_typecheck_choose_expr_requires_constant, false); 10223 if (CondICE.isInvalid()) 10224 return ExprError(); 10225 CondExpr = CondICE.take(); 10226 CondIsTrue = condEval.getZExtValue(); 10227 10228 // If the condition is > zero, then the AST type is the same as the LSHExpr. 10229 Expr *ActiveExpr = CondIsTrue ? LHSExpr : RHSExpr; 10230 10231 resType = ActiveExpr->getType(); 10232 ValueDependent = ActiveExpr->isValueDependent(); 10233 VK = ActiveExpr->getValueKind(); 10234 OK = ActiveExpr->getObjectKind(); 10235 } 10236 10237 return Owned(new (Context) ChooseExpr(BuiltinLoc, CondExpr, LHSExpr, RHSExpr, 10238 resType, VK, OK, RPLoc, CondIsTrue, 10239 resType->isDependentType(), 10240 ValueDependent)); 10241 } 10242 10243 //===----------------------------------------------------------------------===// 10244 // Clang Extensions. 10245 //===----------------------------------------------------------------------===// 10246 10247 /// ActOnBlockStart - This callback is invoked when a block literal is started. 10248 void Sema::ActOnBlockStart(SourceLocation CaretLoc, Scope *CurScope) { 10249 BlockDecl *Block = BlockDecl::Create(Context, CurContext, CaretLoc); 10250 10251 if (LangOpts.CPlusPlus) { 10252 Decl *ManglingContextDecl; 10253 if (MangleNumberingContext *MCtx = 10254 getCurrentMangleNumberContext(Block->getDeclContext(), 10255 ManglingContextDecl)) { 10256 unsigned ManglingNumber = MCtx->getManglingNumber(Block); 10257 Block->setBlockMangling(ManglingNumber, ManglingContextDecl); 10258 } 10259 } 10260 10261 PushBlockScope(CurScope, Block); 10262 CurContext->addDecl(Block); 10263 if (CurScope) 10264 PushDeclContext(CurScope, Block); 10265 else 10266 CurContext = Block; 10267 10268 getCurBlock()->HasImplicitReturnType = true; 10269 10270 // Enter a new evaluation context to insulate the block from any 10271 // cleanups from the enclosing full-expression. 10272 PushExpressionEvaluationContext(PotentiallyEvaluated); 10273 } 10274 10275 void Sema::ActOnBlockArguments(SourceLocation CaretLoc, Declarator &ParamInfo, 10276 Scope *CurScope) { 10277 assert(ParamInfo.getIdentifier()==0 && "block-id should have no identifier!"); 10278 assert(ParamInfo.getContext() == Declarator::BlockLiteralContext); 10279 BlockScopeInfo *CurBlock = getCurBlock(); 10280 10281 TypeSourceInfo *Sig = GetTypeForDeclarator(ParamInfo, CurScope); 10282 QualType T = Sig->getType(); 10283 10284 // FIXME: We should allow unexpanded parameter packs here, but that would, 10285 // in turn, make the block expression contain unexpanded parameter packs. 10286 if (DiagnoseUnexpandedParameterPack(CaretLoc, Sig, UPPC_Block)) { 10287 // Drop the parameters. 10288 FunctionProtoType::ExtProtoInfo EPI; 10289 EPI.HasTrailingReturn = false; 10290 EPI.TypeQuals |= DeclSpec::TQ_const; 10291 T = Context.getFunctionType(Context.DependentTy, None, EPI); 10292 Sig = Context.getTrivialTypeSourceInfo(T); 10293 } 10294 10295 // GetTypeForDeclarator always produces a function type for a block 10296 // literal signature. Furthermore, it is always a FunctionProtoType 10297 // unless the function was written with a typedef. 10298 assert(T->isFunctionType() && 10299 "GetTypeForDeclarator made a non-function block signature"); 10300 10301 // Look for an explicit signature in that function type. 10302 FunctionProtoTypeLoc ExplicitSignature; 10303 10304 TypeLoc tmp = Sig->getTypeLoc().IgnoreParens(); 10305 if ((ExplicitSignature = tmp.getAs<FunctionProtoTypeLoc>())) { 10306 10307 // Check whether that explicit signature was synthesized by 10308 // GetTypeForDeclarator. If so, don't save that as part of the 10309 // written signature. 10310 if (ExplicitSignature.getLocalRangeBegin() == 10311 ExplicitSignature.getLocalRangeEnd()) { 10312 // This would be much cheaper if we stored TypeLocs instead of 10313 // TypeSourceInfos. 10314 TypeLoc Result = ExplicitSignature.getResultLoc(); 10315 unsigned Size = Result.getFullDataSize(); 10316 Sig = Context.CreateTypeSourceInfo(Result.getType(), Size); 10317 Sig->getTypeLoc().initializeFullCopy(Result, Size); 10318 10319 ExplicitSignature = FunctionProtoTypeLoc(); 10320 } 10321 } 10322 10323 CurBlock->TheDecl->setSignatureAsWritten(Sig); 10324 CurBlock->FunctionType = T; 10325 10326 const FunctionType *Fn = T->getAs<FunctionType>(); 10327 QualType RetTy = Fn->getResultType(); 10328 bool isVariadic = 10329 (isa<FunctionProtoType>(Fn) && cast<FunctionProtoType>(Fn)->isVariadic()); 10330 10331 CurBlock->TheDecl->setIsVariadic(isVariadic); 10332 10333 // Context.DependentTy is used as a placeholder for a missing block 10334 // return type. TODO: what should we do with declarators like: 10335 // ^ * { ... } 10336 // If the answer is "apply template argument deduction".... 10337 if (RetTy != Context.DependentTy) { 10338 CurBlock->ReturnType = RetTy; 10339 CurBlock->TheDecl->setBlockMissingReturnType(false); 10340 CurBlock->HasImplicitReturnType = false; 10341 } 10342 10343 // Push block parameters from the declarator if we had them. 10344 SmallVector<ParmVarDecl*, 8> Params; 10345 if (ExplicitSignature) { 10346 for (unsigned I = 0, E = ExplicitSignature.getNumArgs(); I != E; ++I) { 10347 ParmVarDecl *Param = ExplicitSignature.getArg(I); 10348 if (Param->getIdentifier() == 0 && 10349 !Param->isImplicit() && 10350 !Param->isInvalidDecl() && 10351 !getLangOpts().CPlusPlus) 10352 Diag(Param->getLocation(), diag::err_parameter_name_omitted); 10353 Params.push_back(Param); 10354 } 10355 10356 // Fake up parameter variables if we have a typedef, like 10357 // ^ fntype { ... } 10358 } else if (const FunctionProtoType *Fn = T->getAs<FunctionProtoType>()) { 10359 for (FunctionProtoType::arg_type_iterator 10360 I = Fn->arg_type_begin(), E = Fn->arg_type_end(); I != E; ++I) { 10361 ParmVarDecl *Param = 10362 BuildParmVarDeclForTypedef(CurBlock->TheDecl, 10363 ParamInfo.getLocStart(), 10364 *I); 10365 Params.push_back(Param); 10366 } 10367 } 10368 10369 // Set the parameters on the block decl. 10370 if (!Params.empty()) { 10371 CurBlock->TheDecl->setParams(Params); 10372 CheckParmsForFunctionDef(CurBlock->TheDecl->param_begin(), 10373 CurBlock->TheDecl->param_end(), 10374 /*CheckParameterNames=*/false); 10375 } 10376 10377 // Finally we can process decl attributes. 10378 ProcessDeclAttributes(CurScope, CurBlock->TheDecl, ParamInfo); 10379 10380 // Put the parameter variables in scope. 10381 for (BlockDecl::param_iterator AI = CurBlock->TheDecl->param_begin(), 10382 E = CurBlock->TheDecl->param_end(); AI != E; ++AI) { 10383 (*AI)->setOwningFunction(CurBlock->TheDecl); 10384 10385 // If this has an identifier, add it to the scope stack. 10386 if ((*AI)->getIdentifier()) { 10387 CheckShadow(CurBlock->TheScope, *AI); 10388 10389 PushOnScopeChains(*AI, CurBlock->TheScope); 10390 } 10391 } 10392 } 10393 10394 /// ActOnBlockError - If there is an error parsing a block, this callback 10395 /// is invoked to pop the information about the block from the action impl. 10396 void Sema::ActOnBlockError(SourceLocation CaretLoc, Scope *CurScope) { 10397 // Leave the expression-evaluation context. 10398 DiscardCleanupsInEvaluationContext(); 10399 PopExpressionEvaluationContext(); 10400 10401 // Pop off CurBlock, handle nested blocks. 10402 PopDeclContext(); 10403 PopFunctionScopeInfo(); 10404 } 10405 10406 /// ActOnBlockStmtExpr - This is called when the body of a block statement 10407 /// literal was successfully completed. ^(int x){...} 10408 ExprResult Sema::ActOnBlockStmtExpr(SourceLocation CaretLoc, 10409 Stmt *Body, Scope *CurScope) { 10410 // If blocks are disabled, emit an error. 10411 if (!LangOpts.Blocks) 10412 Diag(CaretLoc, diag::err_blocks_disable); 10413 10414 // Leave the expression-evaluation context. 10415 if (hasAnyUnrecoverableErrorsInThisFunction()) 10416 DiscardCleanupsInEvaluationContext(); 10417 assert(!ExprNeedsCleanups && "cleanups within block not correctly bound!"); 10418 PopExpressionEvaluationContext(); 10419 10420 BlockScopeInfo *BSI = cast<BlockScopeInfo>(FunctionScopes.back()); 10421 10422 if (BSI->HasImplicitReturnType) 10423 deduceClosureReturnType(*BSI); 10424 10425 PopDeclContext(); 10426 10427 QualType RetTy = Context.VoidTy; 10428 if (!BSI->ReturnType.isNull()) 10429 RetTy = BSI->ReturnType; 10430 10431 bool NoReturn = BSI->TheDecl->hasAttr<NoReturnAttr>(); 10432 QualType BlockTy; 10433 10434 // Set the captured variables on the block. 10435 // FIXME: Share capture structure between BlockDecl and CapturingScopeInfo! 10436 SmallVector<BlockDecl::Capture, 4> Captures; 10437 for (unsigned i = 0, e = BSI->Captures.size(); i != e; i++) { 10438 CapturingScopeInfo::Capture &Cap = BSI->Captures[i]; 10439 if (Cap.isThisCapture()) 10440 continue; 10441 BlockDecl::Capture NewCap(Cap.getVariable(), Cap.isBlockCapture(), 10442 Cap.isNested(), Cap.getInitExpr()); 10443 Captures.push_back(NewCap); 10444 } 10445 BSI->TheDecl->setCaptures(Context, Captures.begin(), Captures.end(), 10446 BSI->CXXThisCaptureIndex != 0); 10447 10448 // If the user wrote a function type in some form, try to use that. 10449 if (!BSI->FunctionType.isNull()) { 10450 const FunctionType *FTy = BSI->FunctionType->getAs<FunctionType>(); 10451 10452 FunctionType::ExtInfo Ext = FTy->getExtInfo(); 10453 if (NoReturn && !Ext.getNoReturn()) Ext = Ext.withNoReturn(true); 10454 10455 // Turn protoless block types into nullary block types. 10456 if (isa<FunctionNoProtoType>(FTy)) { 10457 FunctionProtoType::ExtProtoInfo EPI; 10458 EPI.ExtInfo = Ext; 10459 BlockTy = Context.getFunctionType(RetTy, None, EPI); 10460 10461 // Otherwise, if we don't need to change anything about the function type, 10462 // preserve its sugar structure. 10463 } else if (FTy->getResultType() == RetTy && 10464 (!NoReturn || FTy->getNoReturnAttr())) { 10465 BlockTy = BSI->FunctionType; 10466 10467 // Otherwise, make the minimal modifications to the function type. 10468 } else { 10469 const FunctionProtoType *FPT = cast<FunctionProtoType>(FTy); 10470 FunctionProtoType::ExtProtoInfo EPI = FPT->getExtProtoInfo(); 10471 EPI.TypeQuals = 0; // FIXME: silently? 10472 EPI.ExtInfo = Ext; 10473 BlockTy = Context.getFunctionType(RetTy, FPT->getArgTypes(), EPI); 10474 } 10475 10476 // If we don't have a function type, just build one from nothing. 10477 } else { 10478 FunctionProtoType::ExtProtoInfo EPI; 10479 EPI.ExtInfo = FunctionType::ExtInfo().withNoReturn(NoReturn); 10480 BlockTy = Context.getFunctionType(RetTy, None, EPI); 10481 } 10482 10483 DiagnoseUnusedParameters(BSI->TheDecl->param_begin(), 10484 BSI->TheDecl->param_end()); 10485 BlockTy = Context.getBlockPointerType(BlockTy); 10486 10487 // If needed, diagnose invalid gotos and switches in the block. 10488 if (getCurFunction()->NeedsScopeChecking() && 10489 !hasAnyUnrecoverableErrorsInThisFunction() && 10490 !PP.isCodeCompletionEnabled()) 10491 DiagnoseInvalidJumps(cast<CompoundStmt>(Body)); 10492 10493 BSI->TheDecl->setBody(cast<CompoundStmt>(Body)); 10494 10495 // Try to apply the named return value optimization. We have to check again 10496 // if we can do this, though, because blocks keep return statements around 10497 // to deduce an implicit return type. 10498 if (getLangOpts().CPlusPlus && RetTy->isRecordType() && 10499 !BSI->TheDecl->isDependentContext()) 10500 computeNRVO(Body, getCurBlock()); 10501 10502 BlockExpr *Result = new (Context) BlockExpr(BSI->TheDecl, BlockTy); 10503 AnalysisBasedWarnings::Policy WP = AnalysisWarnings.getDefaultPolicy(); 10504 PopFunctionScopeInfo(&WP, Result->getBlockDecl(), Result); 10505 10506 // If the block isn't obviously global, i.e. it captures anything at 10507 // all, then we need to do a few things in the surrounding context: 10508 if (Result->getBlockDecl()->hasCaptures()) { 10509 // First, this expression has a new cleanup object. 10510 ExprCleanupObjects.push_back(Result->getBlockDecl()); 10511 ExprNeedsCleanups = true; 10512 10513 // It also gets a branch-protected scope if any of the captured 10514 // variables needs destruction. 10515 for (BlockDecl::capture_const_iterator 10516 ci = Result->getBlockDecl()->capture_begin(), 10517 ce = Result->getBlockDecl()->capture_end(); ci != ce; ++ci) { 10518 const VarDecl *var = ci->getVariable(); 10519 if (var->getType().isDestructedType() != QualType::DK_none) { 10520 getCurFunction()->setHasBranchProtectedScope(); 10521 break; 10522 } 10523 } 10524 } 10525 10526 return Owned(Result); 10527 } 10528 10529 ExprResult Sema::ActOnVAArg(SourceLocation BuiltinLoc, 10530 Expr *E, ParsedType Ty, 10531 SourceLocation RPLoc) { 10532 TypeSourceInfo *TInfo; 10533 GetTypeFromParser(Ty, &TInfo); 10534 return BuildVAArgExpr(BuiltinLoc, E, TInfo, RPLoc); 10535 } 10536 10537 ExprResult Sema::BuildVAArgExpr(SourceLocation BuiltinLoc, 10538 Expr *E, TypeSourceInfo *TInfo, 10539 SourceLocation RPLoc) { 10540 Expr *OrigExpr = E; 10541 10542 // Get the va_list type 10543 QualType VaListType = Context.getBuiltinVaListType(); 10544 if (VaListType->isArrayType()) { 10545 // Deal with implicit array decay; for example, on x86-64, 10546 // va_list is an array, but it's supposed to decay to 10547 // a pointer for va_arg. 10548 VaListType = Context.getArrayDecayedType(VaListType); 10549 // Make sure the input expression also decays appropriately. 10550 ExprResult Result = UsualUnaryConversions(E); 10551 if (Result.isInvalid()) 10552 return ExprError(); 10553 E = Result.take(); 10554 } else if (VaListType->isRecordType() && getLangOpts().CPlusPlus) { 10555 // If va_list is a record type and we are compiling in C++ mode, 10556 // check the argument using reference binding. 10557 InitializedEntity Entity 10558 = InitializedEntity::InitializeParameter(Context, 10559 Context.getLValueReferenceType(VaListType), false); 10560 ExprResult Init = PerformCopyInitialization(Entity, SourceLocation(), E); 10561 if (Init.isInvalid()) 10562 return ExprError(); 10563 E = Init.takeAs<Expr>(); 10564 } else { 10565 // Otherwise, the va_list argument must be an l-value because 10566 // it is modified by va_arg. 10567 if (!E->isTypeDependent() && 10568 CheckForModifiableLvalue(E, BuiltinLoc, *this)) 10569 return ExprError(); 10570 } 10571 10572 if (!E->isTypeDependent() && 10573 !Context.hasSameType(VaListType, E->getType())) { 10574 return ExprError(Diag(E->getLocStart(), 10575 diag::err_first_argument_to_va_arg_not_of_type_va_list) 10576 << OrigExpr->getType() << E->getSourceRange()); 10577 } 10578 10579 if (!TInfo->getType()->isDependentType()) { 10580 if (RequireCompleteType(TInfo->getTypeLoc().getBeginLoc(), TInfo->getType(), 10581 diag::err_second_parameter_to_va_arg_incomplete, 10582 TInfo->getTypeLoc())) 10583 return ExprError(); 10584 10585 if (RequireNonAbstractType(TInfo->getTypeLoc().getBeginLoc(), 10586 TInfo->getType(), 10587 diag::err_second_parameter_to_va_arg_abstract, 10588 TInfo->getTypeLoc())) 10589 return ExprError(); 10590 10591 if (!TInfo->getType().isPODType(Context)) { 10592 Diag(TInfo->getTypeLoc().getBeginLoc(), 10593 TInfo->getType()->isObjCLifetimeType() 10594 ? diag::warn_second_parameter_to_va_arg_ownership_qualified 10595 : diag::warn_second_parameter_to_va_arg_not_pod) 10596 << TInfo->getType() 10597 << TInfo->getTypeLoc().getSourceRange(); 10598 } 10599 10600 // Check for va_arg where arguments of the given type will be promoted 10601 // (i.e. this va_arg is guaranteed to have undefined behavior). 10602 QualType PromoteType; 10603 if (TInfo->getType()->isPromotableIntegerType()) { 10604 PromoteType = Context.getPromotedIntegerType(TInfo->getType()); 10605 if (Context.typesAreCompatible(PromoteType, TInfo->getType())) 10606 PromoteType = QualType(); 10607 } 10608 if (TInfo->getType()->isSpecificBuiltinType(BuiltinType::Float)) 10609 PromoteType = Context.DoubleTy; 10610 if (!PromoteType.isNull()) 10611 DiagRuntimeBehavior(TInfo->getTypeLoc().getBeginLoc(), E, 10612 PDiag(diag::warn_second_parameter_to_va_arg_never_compatible) 10613 << TInfo->getType() 10614 << PromoteType 10615 << TInfo->getTypeLoc().getSourceRange()); 10616 } 10617 10618 QualType T = TInfo->getType().getNonLValueExprType(Context); 10619 return Owned(new (Context) VAArgExpr(BuiltinLoc, E, TInfo, RPLoc, T)); 10620 } 10621 10622 ExprResult Sema::ActOnGNUNullExpr(SourceLocation TokenLoc) { 10623 // The type of __null will be int or long, depending on the size of 10624 // pointers on the target. 10625 QualType Ty; 10626 unsigned pw = Context.getTargetInfo().getPointerWidth(0); 10627 if (pw == Context.getTargetInfo().getIntWidth()) 10628 Ty = Context.IntTy; 10629 else if (pw == Context.getTargetInfo().getLongWidth()) 10630 Ty = Context.LongTy; 10631 else if (pw == Context.getTargetInfo().getLongLongWidth()) 10632 Ty = Context.LongLongTy; 10633 else { 10634 llvm_unreachable("I don't know size of pointer!"); 10635 } 10636 10637 return Owned(new (Context) GNUNullExpr(Ty, TokenLoc)); 10638 } 10639 10640 bool 10641 Sema::ConversionToObjCStringLiteralCheck(QualType DstType, Expr *&Exp) { 10642 if (!getLangOpts().ObjC1) 10643 return false; 10644 10645 const ObjCObjectPointerType *PT = DstType->getAs<ObjCObjectPointerType>(); 10646 if (!PT) 10647 return false; 10648 10649 if (!PT->isObjCIdType()) { 10650 // Check if the destination is the 'NSString' interface. 10651 const ObjCInterfaceDecl *ID = PT->getInterfaceDecl(); 10652 if (!ID || !ID->getIdentifier()->isStr("NSString")) 10653 return false; 10654 } 10655 10656 // Ignore any parens, implicit casts (should only be 10657 // array-to-pointer decays), and not-so-opaque values. The last is 10658 // important for making this trigger for property assignments. 10659 Expr *SrcExpr = Exp->IgnoreParenImpCasts(); 10660 if (OpaqueValueExpr *OV = dyn_cast<OpaqueValueExpr>(SrcExpr)) 10661 if (OV->getSourceExpr()) 10662 SrcExpr = OV->getSourceExpr()->IgnoreParenImpCasts(); 10663 10664 StringLiteral *SL = dyn_cast<StringLiteral>(SrcExpr); 10665 if (!SL || !SL->isAscii()) 10666 return false; 10667 Diag(SL->getLocStart(), diag::err_missing_atsign_prefix) 10668 << FixItHint::CreateInsertion(SL->getLocStart(), "@"); 10669 Exp = BuildObjCStringLiteral(SL->getLocStart(), SL).take(); 10670 return true; 10671 } 10672 10673 bool Sema::DiagnoseAssignmentResult(AssignConvertType ConvTy, 10674 SourceLocation Loc, 10675 QualType DstType, QualType SrcType, 10676 Expr *SrcExpr, AssignmentAction Action, 10677 bool *Complained) { 10678 if (Complained) 10679 *Complained = false; 10680 10681 // Decode the result (notice that AST's are still created for extensions). 10682 bool CheckInferredResultType = false; 10683 bool isInvalid = false; 10684 unsigned DiagKind = 0; 10685 FixItHint Hint; 10686 ConversionFixItGenerator ConvHints; 10687 bool MayHaveConvFixit = false; 10688 bool MayHaveFunctionDiff = false; 10689 10690 switch (ConvTy) { 10691 case Compatible: 10692 DiagnoseAssignmentEnum(DstType, SrcType, SrcExpr); 10693 return false; 10694 10695 case PointerToInt: 10696 DiagKind = diag::ext_typecheck_convert_pointer_int; 10697 ConvHints.tryToFixConversion(SrcExpr, SrcType, DstType, *this); 10698 MayHaveConvFixit = true; 10699 break; 10700 case IntToPointer: 10701 DiagKind = diag::ext_typecheck_convert_int_pointer; 10702 ConvHints.tryToFixConversion(SrcExpr, SrcType, DstType, *this); 10703 MayHaveConvFixit = true; 10704 break; 10705 case IncompatiblePointer: 10706 DiagKind = 10707 (Action == AA_Passing_CFAudited ? 10708 diag::err_arc_typecheck_convert_incompatible_pointer : 10709 diag::ext_typecheck_convert_incompatible_pointer); 10710 CheckInferredResultType = DstType->isObjCObjectPointerType() && 10711 SrcType->isObjCObjectPointerType(); 10712 if (Hint.isNull() && !CheckInferredResultType) { 10713 ConvHints.tryToFixConversion(SrcExpr, SrcType, DstType, *this); 10714 } 10715 else if (CheckInferredResultType) { 10716 SrcType = SrcType.getUnqualifiedType(); 10717 DstType = DstType.getUnqualifiedType(); 10718 } 10719 MayHaveConvFixit = true; 10720 break; 10721 case IncompatiblePointerSign: 10722 DiagKind = diag::ext_typecheck_convert_incompatible_pointer_sign; 10723 break; 10724 case FunctionVoidPointer: 10725 DiagKind = diag::ext_typecheck_convert_pointer_void_func; 10726 break; 10727 case IncompatiblePointerDiscardsQualifiers: { 10728 // Perform array-to-pointer decay if necessary. 10729 if (SrcType->isArrayType()) SrcType = Context.getArrayDecayedType(SrcType); 10730 10731 Qualifiers lhq = SrcType->getPointeeType().getQualifiers(); 10732 Qualifiers rhq = DstType->getPointeeType().getQualifiers(); 10733 if (lhq.getAddressSpace() != rhq.getAddressSpace()) { 10734 DiagKind = diag::err_typecheck_incompatible_address_space; 10735 break; 10736 10737 10738 } else if (lhq.getObjCLifetime() != rhq.getObjCLifetime()) { 10739 DiagKind = diag::err_typecheck_incompatible_ownership; 10740 break; 10741 } 10742 10743 llvm_unreachable("unknown error case for discarding qualifiers!"); 10744 // fallthrough 10745 } 10746 case CompatiblePointerDiscardsQualifiers: 10747 // If the qualifiers lost were because we were applying the 10748 // (deprecated) C++ conversion from a string literal to a char* 10749 // (or wchar_t*), then there was no error (C++ 4.2p2). FIXME: 10750 // Ideally, this check would be performed in 10751 // checkPointerTypesForAssignment. However, that would require a 10752 // bit of refactoring (so that the second argument is an 10753 // expression, rather than a type), which should be done as part 10754 // of a larger effort to fix checkPointerTypesForAssignment for 10755 // C++ semantics. 10756 if (getLangOpts().CPlusPlus && 10757 IsStringLiteralToNonConstPointerConversion(SrcExpr, DstType)) 10758 return false; 10759 DiagKind = diag::ext_typecheck_convert_discards_qualifiers; 10760 break; 10761 case IncompatibleNestedPointerQualifiers: 10762 DiagKind = diag::ext_nested_pointer_qualifier_mismatch; 10763 break; 10764 case IntToBlockPointer: 10765 DiagKind = diag::err_int_to_block_pointer; 10766 break; 10767 case IncompatibleBlockPointer: 10768 DiagKind = diag::err_typecheck_convert_incompatible_block_pointer; 10769 break; 10770 case IncompatibleObjCQualifiedId: 10771 // FIXME: Diagnose the problem in ObjCQualifiedIdTypesAreCompatible, since 10772 // it can give a more specific diagnostic. 10773 DiagKind = diag::warn_incompatible_qualified_id; 10774 break; 10775 case IncompatibleVectors: 10776 DiagKind = diag::warn_incompatible_vectors; 10777 break; 10778 case IncompatibleObjCWeakRef: 10779 DiagKind = diag::err_arc_weak_unavailable_assign; 10780 break; 10781 case Incompatible: 10782 DiagKind = diag::err_typecheck_convert_incompatible; 10783 ConvHints.tryToFixConversion(SrcExpr, SrcType, DstType, *this); 10784 MayHaveConvFixit = true; 10785 isInvalid = true; 10786 MayHaveFunctionDiff = true; 10787 break; 10788 } 10789 10790 QualType FirstType, SecondType; 10791 switch (Action) { 10792 case AA_Assigning: 10793 case AA_Initializing: 10794 // The destination type comes first. 10795 FirstType = DstType; 10796 SecondType = SrcType; 10797 break; 10798 10799 case AA_Returning: 10800 case AA_Passing: 10801 case AA_Passing_CFAudited: 10802 case AA_Converting: 10803 case AA_Sending: 10804 case AA_Casting: 10805 // The source type comes first. 10806 FirstType = SrcType; 10807 SecondType = DstType; 10808 break; 10809 } 10810 10811 PartialDiagnostic FDiag = PDiag(DiagKind); 10812 if (Action == AA_Passing_CFAudited) 10813 FDiag << FirstType << SecondType << SrcExpr->getSourceRange(); 10814 else 10815 FDiag << FirstType << SecondType << Action << SrcExpr->getSourceRange(); 10816 10817 // If we can fix the conversion, suggest the FixIts. 10818 assert(ConvHints.isNull() || Hint.isNull()); 10819 if (!ConvHints.isNull()) { 10820 for (std::vector<FixItHint>::iterator HI = ConvHints.Hints.begin(), 10821 HE = ConvHints.Hints.end(); HI != HE; ++HI) 10822 FDiag << *HI; 10823 } else { 10824 FDiag << Hint; 10825 } 10826 if (MayHaveConvFixit) { FDiag << (unsigned) (ConvHints.Kind); } 10827 10828 if (MayHaveFunctionDiff) 10829 HandleFunctionTypeMismatch(FDiag, SecondType, FirstType); 10830 10831 Diag(Loc, FDiag); 10832 10833 if (SecondType == Context.OverloadTy) 10834 NoteAllOverloadCandidates(OverloadExpr::find(SrcExpr).Expression, 10835 FirstType); 10836 10837 if (CheckInferredResultType) 10838 EmitRelatedResultTypeNote(SrcExpr); 10839 10840 if (Action == AA_Returning && ConvTy == IncompatiblePointer) 10841 EmitRelatedResultTypeNoteForReturn(DstType); 10842 10843 if (Complained) 10844 *Complained = true; 10845 return isInvalid; 10846 } 10847 10848 ExprResult Sema::VerifyIntegerConstantExpression(Expr *E, 10849 llvm::APSInt *Result) { 10850 class SimpleICEDiagnoser : public VerifyICEDiagnoser { 10851 public: 10852 virtual void diagnoseNotICE(Sema &S, SourceLocation Loc, SourceRange SR) { 10853 S.Diag(Loc, diag::err_expr_not_ice) << S.LangOpts.CPlusPlus << SR; 10854 } 10855 } Diagnoser; 10856 10857 return VerifyIntegerConstantExpression(E, Result, Diagnoser); 10858 } 10859 10860 ExprResult Sema::VerifyIntegerConstantExpression(Expr *E, 10861 llvm::APSInt *Result, 10862 unsigned DiagID, 10863 bool AllowFold) { 10864 class IDDiagnoser : public VerifyICEDiagnoser { 10865 unsigned DiagID; 10866 10867 public: 10868 IDDiagnoser(unsigned DiagID) 10869 : VerifyICEDiagnoser(DiagID == 0), DiagID(DiagID) { } 10870 10871 virtual void diagnoseNotICE(Sema &S, SourceLocation Loc, SourceRange SR) { 10872 S.Diag(Loc, DiagID) << SR; 10873 } 10874 } Diagnoser(DiagID); 10875 10876 return VerifyIntegerConstantExpression(E, Result, Diagnoser, AllowFold); 10877 } 10878 10879 void Sema::VerifyICEDiagnoser::diagnoseFold(Sema &S, SourceLocation Loc, 10880 SourceRange SR) { 10881 S.Diag(Loc, diag::ext_expr_not_ice) << SR << S.LangOpts.CPlusPlus; 10882 } 10883 10884 ExprResult 10885 Sema::VerifyIntegerConstantExpression(Expr *E, llvm::APSInt *Result, 10886 VerifyICEDiagnoser &Diagnoser, 10887 bool AllowFold) { 10888 SourceLocation DiagLoc = E->getLocStart(); 10889 10890 if (getLangOpts().CPlusPlus11) { 10891 // C++11 [expr.const]p5: 10892 // If an expression of literal class type is used in a context where an 10893 // integral constant expression is required, then that class type shall 10894 // have a single non-explicit conversion function to an integral or 10895 // unscoped enumeration type 10896 ExprResult Converted; 10897 class CXX11ConvertDiagnoser : public ICEConvertDiagnoser { 10898 public: 10899 CXX11ConvertDiagnoser(bool Silent) 10900 : ICEConvertDiagnoser(/*AllowScopedEnumerations*/false, 10901 Silent, true) {} 10902 10903 virtual SemaDiagnosticBuilder diagnoseNotInt(Sema &S, SourceLocation Loc, 10904 QualType T) { 10905 return S.Diag(Loc, diag::err_ice_not_integral) << T; 10906 } 10907 10908 virtual SemaDiagnosticBuilder diagnoseIncomplete( 10909 Sema &S, SourceLocation Loc, QualType T) { 10910 return S.Diag(Loc, diag::err_ice_incomplete_type) << T; 10911 } 10912 10913 virtual SemaDiagnosticBuilder diagnoseExplicitConv( 10914 Sema &S, SourceLocation Loc, QualType T, QualType ConvTy) { 10915 return S.Diag(Loc, diag::err_ice_explicit_conversion) << T << ConvTy; 10916 } 10917 10918 virtual SemaDiagnosticBuilder noteExplicitConv( 10919 Sema &S, CXXConversionDecl *Conv, QualType ConvTy) { 10920 return S.Diag(Conv->getLocation(), diag::note_ice_conversion_here) 10921 << ConvTy->isEnumeralType() << ConvTy; 10922 } 10923 10924 virtual SemaDiagnosticBuilder diagnoseAmbiguous( 10925 Sema &S, SourceLocation Loc, QualType T) { 10926 return S.Diag(Loc, diag::err_ice_ambiguous_conversion) << T; 10927 } 10928 10929 virtual SemaDiagnosticBuilder noteAmbiguous( 10930 Sema &S, CXXConversionDecl *Conv, QualType ConvTy) { 10931 return S.Diag(Conv->getLocation(), diag::note_ice_conversion_here) 10932 << ConvTy->isEnumeralType() << ConvTy; 10933 } 10934 10935 virtual SemaDiagnosticBuilder diagnoseConversion( 10936 Sema &S, SourceLocation Loc, QualType T, QualType ConvTy) { 10937 llvm_unreachable("conversion functions are permitted"); 10938 } 10939 } ConvertDiagnoser(Diagnoser.Suppress); 10940 10941 Converted = PerformContextualImplicitConversion(DiagLoc, E, 10942 ConvertDiagnoser); 10943 if (Converted.isInvalid()) 10944 return Converted; 10945 E = Converted.take(); 10946 if (!E->getType()->isIntegralOrUnscopedEnumerationType()) 10947 return ExprError(); 10948 } else if (!E->getType()->isIntegralOrUnscopedEnumerationType()) { 10949 // An ICE must be of integral or unscoped enumeration type. 10950 if (!Diagnoser.Suppress) 10951 Diagnoser.diagnoseNotICE(*this, DiagLoc, E->getSourceRange()); 10952 return ExprError(); 10953 } 10954 10955 // Circumvent ICE checking in C++11 to avoid evaluating the expression twice 10956 // in the non-ICE case. 10957 if (!getLangOpts().CPlusPlus11 && E->isIntegerConstantExpr(Context)) { 10958 if (Result) 10959 *Result = E->EvaluateKnownConstInt(Context); 10960 return Owned(E); 10961 } 10962 10963 Expr::EvalResult EvalResult; 10964 SmallVector<PartialDiagnosticAt, 8> Notes; 10965 EvalResult.Diag = &Notes; 10966 10967 // Try to evaluate the expression, and produce diagnostics explaining why it's 10968 // not a constant expression as a side-effect. 10969 bool Folded = E->EvaluateAsRValue(EvalResult, Context) && 10970 EvalResult.Val.isInt() && !EvalResult.HasSideEffects; 10971 10972 // In C++11, we can rely on diagnostics being produced for any expression 10973 // which is not a constant expression. If no diagnostics were produced, then 10974 // this is a constant expression. 10975 if (Folded && getLangOpts().CPlusPlus11 && Notes.empty()) { 10976 if (Result) 10977 *Result = EvalResult.Val.getInt(); 10978 return Owned(E); 10979 } 10980 10981 // If our only note is the usual "invalid subexpression" note, just point 10982 // the caret at its location rather than producing an essentially 10983 // redundant note. 10984 if (Notes.size() == 1 && Notes[0].second.getDiagID() == 10985 diag::note_invalid_subexpr_in_const_expr) { 10986 DiagLoc = Notes[0].first; 10987 Notes.clear(); 10988 } 10989 10990 if (!Folded || !AllowFold) { 10991 if (!Diagnoser.Suppress) { 10992 Diagnoser.diagnoseNotICE(*this, DiagLoc, E->getSourceRange()); 10993 for (unsigned I = 0, N = Notes.size(); I != N; ++I) 10994 Diag(Notes[I].first, Notes[I].second); 10995 } 10996 10997 return ExprError(); 10998 } 10999 11000 Diagnoser.diagnoseFold(*this, DiagLoc, E->getSourceRange()); 11001 for (unsigned I = 0, N = Notes.size(); I != N; ++I) 11002 Diag(Notes[I].first, Notes[I].second); 11003 11004 if (Result) 11005 *Result = EvalResult.Val.getInt(); 11006 return Owned(E); 11007 } 11008 11009 namespace { 11010 // Handle the case where we conclude a expression which we speculatively 11011 // considered to be unevaluated is actually evaluated. 11012 class TransformToPE : public TreeTransform<TransformToPE> { 11013 typedef TreeTransform<TransformToPE> BaseTransform; 11014 11015 public: 11016 TransformToPE(Sema &SemaRef) : BaseTransform(SemaRef) { } 11017 11018 // Make sure we redo semantic analysis 11019 bool AlwaysRebuild() { return true; } 11020 11021 // Make sure we handle LabelStmts correctly. 11022 // FIXME: This does the right thing, but maybe we need a more general 11023 // fix to TreeTransform? 11024 StmtResult TransformLabelStmt(LabelStmt *S) { 11025 S->getDecl()->setStmt(0); 11026 return BaseTransform::TransformLabelStmt(S); 11027 } 11028 11029 // We need to special-case DeclRefExprs referring to FieldDecls which 11030 // are not part of a member pointer formation; normal TreeTransforming 11031 // doesn't catch this case because of the way we represent them in the AST. 11032 // FIXME: This is a bit ugly; is it really the best way to handle this 11033 // case? 11034 // 11035 // Error on DeclRefExprs referring to FieldDecls. 11036 ExprResult TransformDeclRefExpr(DeclRefExpr *E) { 11037 if (isa<FieldDecl>(E->getDecl()) && 11038 !SemaRef.isUnevaluatedContext()) 11039 return SemaRef.Diag(E->getLocation(), 11040 diag::err_invalid_non_static_member_use) 11041 << E->getDecl() << E->getSourceRange(); 11042 11043 return BaseTransform::TransformDeclRefExpr(E); 11044 } 11045 11046 // Exception: filter out member pointer formation 11047 ExprResult TransformUnaryOperator(UnaryOperator *E) { 11048 if (E->getOpcode() == UO_AddrOf && E->getType()->isMemberPointerType()) 11049 return E; 11050 11051 return BaseTransform::TransformUnaryOperator(E); 11052 } 11053 11054 ExprResult TransformLambdaExpr(LambdaExpr *E) { 11055 // Lambdas never need to be transformed. 11056 return E; 11057 } 11058 }; 11059 } 11060 11061 ExprResult Sema::TransformToPotentiallyEvaluated(Expr *E) { 11062 assert(isUnevaluatedContext() && 11063 "Should only transform unevaluated expressions"); 11064 ExprEvalContexts.back().Context = 11065 ExprEvalContexts[ExprEvalContexts.size()-2].Context; 11066 if (isUnevaluatedContext()) 11067 return E; 11068 return TransformToPE(*this).TransformExpr(E); 11069 } 11070 11071 void 11072 Sema::PushExpressionEvaluationContext(ExpressionEvaluationContext NewContext, 11073 Decl *LambdaContextDecl, 11074 bool IsDecltype) { 11075 ExprEvalContexts.push_back( 11076 ExpressionEvaluationContextRecord(NewContext, 11077 ExprCleanupObjects.size(), 11078 ExprNeedsCleanups, 11079 LambdaContextDecl, 11080 IsDecltype)); 11081 ExprNeedsCleanups = false; 11082 if (!MaybeODRUseExprs.empty()) 11083 std::swap(MaybeODRUseExprs, ExprEvalContexts.back().SavedMaybeODRUseExprs); 11084 } 11085 11086 void 11087 Sema::PushExpressionEvaluationContext(ExpressionEvaluationContext NewContext, 11088 ReuseLambdaContextDecl_t, 11089 bool IsDecltype) { 11090 Decl *ClosureContextDecl = ExprEvalContexts.back().ManglingContextDecl; 11091 PushExpressionEvaluationContext(NewContext, ClosureContextDecl, IsDecltype); 11092 } 11093 11094 void Sema::PopExpressionEvaluationContext() { 11095 ExpressionEvaluationContextRecord& Rec = ExprEvalContexts.back(); 11096 11097 if (!Rec.Lambdas.empty()) { 11098 if (Rec.isUnevaluated() || Rec.Context == ConstantEvaluated) { 11099 unsigned D; 11100 if (Rec.isUnevaluated()) { 11101 // C++11 [expr.prim.lambda]p2: 11102 // A lambda-expression shall not appear in an unevaluated operand 11103 // (Clause 5). 11104 D = diag::err_lambda_unevaluated_operand; 11105 } else { 11106 // C++1y [expr.const]p2: 11107 // A conditional-expression e is a core constant expression unless the 11108 // evaluation of e, following the rules of the abstract machine, would 11109 // evaluate [...] a lambda-expression. 11110 D = diag::err_lambda_in_constant_expression; 11111 } 11112 for (unsigned I = 0, N = Rec.Lambdas.size(); I != N; ++I) 11113 Diag(Rec.Lambdas[I]->getLocStart(), D); 11114 } else { 11115 // Mark the capture expressions odr-used. This was deferred 11116 // during lambda expression creation. 11117 for (unsigned I = 0, N = Rec.Lambdas.size(); I != N; ++I) { 11118 LambdaExpr *Lambda = Rec.Lambdas[I]; 11119 for (LambdaExpr::capture_init_iterator 11120 C = Lambda->capture_init_begin(), 11121 CEnd = Lambda->capture_init_end(); 11122 C != CEnd; ++C) { 11123 MarkDeclarationsReferencedInExpr(*C); 11124 } 11125 } 11126 } 11127 } 11128 11129 // When are coming out of an unevaluated context, clear out any 11130 // temporaries that we may have created as part of the evaluation of 11131 // the expression in that context: they aren't relevant because they 11132 // will never be constructed. 11133 if (Rec.isUnevaluated() || Rec.Context == ConstantEvaluated) { 11134 ExprCleanupObjects.erase(ExprCleanupObjects.begin() + Rec.NumCleanupObjects, 11135 ExprCleanupObjects.end()); 11136 ExprNeedsCleanups = Rec.ParentNeedsCleanups; 11137 CleanupVarDeclMarking(); 11138 std::swap(MaybeODRUseExprs, Rec.SavedMaybeODRUseExprs); 11139 // Otherwise, merge the contexts together. 11140 } else { 11141 ExprNeedsCleanups |= Rec.ParentNeedsCleanups; 11142 MaybeODRUseExprs.insert(Rec.SavedMaybeODRUseExprs.begin(), 11143 Rec.SavedMaybeODRUseExprs.end()); 11144 } 11145 11146 // Pop the current expression evaluation context off the stack. 11147 ExprEvalContexts.pop_back(); 11148 } 11149 11150 void Sema::DiscardCleanupsInEvaluationContext() { 11151 ExprCleanupObjects.erase( 11152 ExprCleanupObjects.begin() + ExprEvalContexts.back().NumCleanupObjects, 11153 ExprCleanupObjects.end()); 11154 ExprNeedsCleanups = false; 11155 MaybeODRUseExprs.clear(); 11156 } 11157 11158 ExprResult Sema::HandleExprEvaluationContextForTypeof(Expr *E) { 11159 if (!E->getType()->isVariablyModifiedType()) 11160 return E; 11161 return TransformToPotentiallyEvaluated(E); 11162 } 11163 11164 static bool IsPotentiallyEvaluatedContext(Sema &SemaRef) { 11165 // Do not mark anything as "used" within a dependent context; wait for 11166 // an instantiation. 11167 if (SemaRef.CurContext->isDependentContext()) 11168 return false; 11169 11170 switch (SemaRef.ExprEvalContexts.back().Context) { 11171 case Sema::Unevaluated: 11172 case Sema::UnevaluatedAbstract: 11173 // We are in an expression that is not potentially evaluated; do nothing. 11174 // (Depending on how you read the standard, we actually do need to do 11175 // something here for null pointer constants, but the standard's 11176 // definition of a null pointer constant is completely crazy.) 11177 return false; 11178 11179 case Sema::ConstantEvaluated: 11180 case Sema::PotentiallyEvaluated: 11181 // We are in a potentially evaluated expression (or a constant-expression 11182 // in C++03); we need to do implicit template instantiation, implicitly 11183 // define class members, and mark most declarations as used. 11184 return true; 11185 11186 case Sema::PotentiallyEvaluatedIfUsed: 11187 // Referenced declarations will only be used if the construct in the 11188 // containing expression is used. 11189 return false; 11190 } 11191 llvm_unreachable("Invalid context"); 11192 } 11193 11194 /// \brief Mark a function referenced, and check whether it is odr-used 11195 /// (C++ [basic.def.odr]p2, C99 6.9p3) 11196 void Sema::MarkFunctionReferenced(SourceLocation Loc, FunctionDecl *Func) { 11197 assert(Func && "No function?"); 11198 11199 Func->setReferenced(); 11200 11201 // C++11 [basic.def.odr]p3: 11202 // A function whose name appears as a potentially-evaluated expression is 11203 // odr-used if it is the unique lookup result or the selected member of a 11204 // set of overloaded functions [...]. 11205 // 11206 // We (incorrectly) mark overload resolution as an unevaluated context, so we 11207 // can just check that here. Skip the rest of this function if we've already 11208 // marked the function as used. 11209 if (Func->isUsed(false) || !IsPotentiallyEvaluatedContext(*this)) { 11210 // C++11 [temp.inst]p3: 11211 // Unless a function template specialization has been explicitly 11212 // instantiated or explicitly specialized, the function template 11213 // specialization is implicitly instantiated when the specialization is 11214 // referenced in a context that requires a function definition to exist. 11215 // 11216 // We consider constexpr function templates to be referenced in a context 11217 // that requires a definition to exist whenever they are referenced. 11218 // 11219 // FIXME: This instantiates constexpr functions too frequently. If this is 11220 // really an unevaluated context (and we're not just in the definition of a 11221 // function template or overload resolution or other cases which we 11222 // incorrectly consider to be unevaluated contexts), and we're not in a 11223 // subexpression which we actually need to evaluate (for instance, a 11224 // template argument, array bound or an expression in a braced-init-list), 11225 // we are not permitted to instantiate this constexpr function definition. 11226 // 11227 // FIXME: This also implicitly defines special members too frequently. They 11228 // are only supposed to be implicitly defined if they are odr-used, but they 11229 // are not odr-used from constant expressions in unevaluated contexts. 11230 // However, they cannot be referenced if they are deleted, and they are 11231 // deleted whenever the implicit definition of the special member would 11232 // fail. 11233 if (!Func->isConstexpr() || Func->getBody()) 11234 return; 11235 CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(Func); 11236 if (!Func->isImplicitlyInstantiable() && (!MD || MD->isUserProvided())) 11237 return; 11238 } 11239 11240 // Note that this declaration has been used. 11241 if (CXXConstructorDecl *Constructor = dyn_cast<CXXConstructorDecl>(Func)) { 11242 Constructor = cast<CXXConstructorDecl>(Constructor->getFirstDecl()); 11243 if (Constructor->isDefaulted() && !Constructor->isDeleted()) { 11244 if (Constructor->isDefaultConstructor()) { 11245 if (Constructor->isTrivial()) 11246 return; 11247 DefineImplicitDefaultConstructor(Loc, Constructor); 11248 } else if (Constructor->isCopyConstructor()) { 11249 DefineImplicitCopyConstructor(Loc, Constructor); 11250 } else if (Constructor->isMoveConstructor()) { 11251 DefineImplicitMoveConstructor(Loc, Constructor); 11252 } 11253 } else if (Constructor->getInheritedConstructor()) { 11254 DefineInheritingConstructor(Loc, Constructor); 11255 } 11256 11257 MarkVTableUsed(Loc, Constructor->getParent()); 11258 } else if (CXXDestructorDecl *Destructor = 11259 dyn_cast<CXXDestructorDecl>(Func)) { 11260 Destructor = cast<CXXDestructorDecl>(Destructor->getFirstDecl()); 11261 if (Destructor->isDefaulted() && !Destructor->isDeleted()) 11262 DefineImplicitDestructor(Loc, Destructor); 11263 if (Destructor->isVirtual()) 11264 MarkVTableUsed(Loc, Destructor->getParent()); 11265 } else if (CXXMethodDecl *MethodDecl = dyn_cast<CXXMethodDecl>(Func)) { 11266 if (MethodDecl->isOverloadedOperator() && 11267 MethodDecl->getOverloadedOperator() == OO_Equal) { 11268 MethodDecl = cast<CXXMethodDecl>(MethodDecl->getFirstDecl()); 11269 if (MethodDecl->isDefaulted() && !MethodDecl->isDeleted()) { 11270 if (MethodDecl->isCopyAssignmentOperator()) 11271 DefineImplicitCopyAssignment(Loc, MethodDecl); 11272 else 11273 DefineImplicitMoveAssignment(Loc, MethodDecl); 11274 } 11275 } else if (isa<CXXConversionDecl>(MethodDecl) && 11276 MethodDecl->getParent()->isLambda()) { 11277 CXXConversionDecl *Conversion = 11278 cast<CXXConversionDecl>(MethodDecl->getFirstDecl()); 11279 if (Conversion->isLambdaToBlockPointerConversion()) 11280 DefineImplicitLambdaToBlockPointerConversion(Loc, Conversion); 11281 else 11282 DefineImplicitLambdaToFunctionPointerConversion(Loc, Conversion); 11283 } else if (MethodDecl->isVirtual()) 11284 MarkVTableUsed(Loc, MethodDecl->getParent()); 11285 } 11286 11287 // Recursive functions should be marked when used from another function. 11288 // FIXME: Is this really right? 11289 if (CurContext == Func) return; 11290 11291 // Resolve the exception specification for any function which is 11292 // used: CodeGen will need it. 11293 const FunctionProtoType *FPT = Func->getType()->getAs<FunctionProtoType>(); 11294 if (FPT && isUnresolvedExceptionSpec(FPT->getExceptionSpecType())) 11295 ResolveExceptionSpec(Loc, FPT); 11296 11297 // Implicit instantiation of function templates and member functions of 11298 // class templates. 11299 if (Func->isImplicitlyInstantiable()) { 11300 bool AlreadyInstantiated = false; 11301 SourceLocation PointOfInstantiation = Loc; 11302 if (FunctionTemplateSpecializationInfo *SpecInfo 11303 = Func->getTemplateSpecializationInfo()) { 11304 if (SpecInfo->getPointOfInstantiation().isInvalid()) 11305 SpecInfo->setPointOfInstantiation(Loc); 11306 else if (SpecInfo->getTemplateSpecializationKind() 11307 == TSK_ImplicitInstantiation) { 11308 AlreadyInstantiated = true; 11309 PointOfInstantiation = SpecInfo->getPointOfInstantiation(); 11310 } 11311 } else if (MemberSpecializationInfo *MSInfo 11312 = Func->getMemberSpecializationInfo()) { 11313 if (MSInfo->getPointOfInstantiation().isInvalid()) 11314 MSInfo->setPointOfInstantiation(Loc); 11315 else if (MSInfo->getTemplateSpecializationKind() 11316 == TSK_ImplicitInstantiation) { 11317 AlreadyInstantiated = true; 11318 PointOfInstantiation = MSInfo->getPointOfInstantiation(); 11319 } 11320 } 11321 11322 if (!AlreadyInstantiated || Func->isConstexpr()) { 11323 if (isa<CXXRecordDecl>(Func->getDeclContext()) && 11324 cast<CXXRecordDecl>(Func->getDeclContext())->isLocalClass() && 11325 ActiveTemplateInstantiations.size()) 11326 PendingLocalImplicitInstantiations.push_back( 11327 std::make_pair(Func, PointOfInstantiation)); 11328 else if (Func->isConstexpr()) 11329 // Do not defer instantiations of constexpr functions, to avoid the 11330 // expression evaluator needing to call back into Sema if it sees a 11331 // call to such a function. 11332 InstantiateFunctionDefinition(PointOfInstantiation, Func); 11333 else { 11334 PendingInstantiations.push_back(std::make_pair(Func, 11335 PointOfInstantiation)); 11336 // Notify the consumer that a function was implicitly instantiated. 11337 Consumer.HandleCXXImplicitFunctionInstantiation(Func); 11338 } 11339 } 11340 } else { 11341 // Walk redefinitions, as some of them may be instantiable. 11342 for (FunctionDecl::redecl_iterator i(Func->redecls_begin()), 11343 e(Func->redecls_end()); i != e; ++i) { 11344 if (!i->isUsed(false) && i->isImplicitlyInstantiable()) 11345 MarkFunctionReferenced(Loc, *i); 11346 } 11347 } 11348 11349 // Keep track of used but undefined functions. 11350 if (!Func->isDefined()) { 11351 if (mightHaveNonExternalLinkage(Func)) 11352 UndefinedButUsed.insert(std::make_pair(Func->getCanonicalDecl(), Loc)); 11353 else if (Func->getMostRecentDecl()->isInlined() && 11354 (LangOpts.CPlusPlus || !LangOpts.GNUInline) && 11355 !Func->getMostRecentDecl()->hasAttr<GNUInlineAttr>()) 11356 UndefinedButUsed.insert(std::make_pair(Func->getCanonicalDecl(), Loc)); 11357 } 11358 11359 // Normally the most current decl is marked used while processing the use and 11360 // any subsequent decls are marked used by decl merging. This fails with 11361 // template instantiation since marking can happen at the end of the file 11362 // and, because of the two phase lookup, this function is called with at 11363 // decl in the middle of a decl chain. We loop to maintain the invariant 11364 // that once a decl is used, all decls after it are also used. 11365 for (FunctionDecl *F = Func->getMostRecentDecl();; F = F->getPreviousDecl()) { 11366 F->markUsed(Context); 11367 if (F == Func) 11368 break; 11369 } 11370 } 11371 11372 static void 11373 diagnoseUncapturableValueReference(Sema &S, SourceLocation loc, 11374 VarDecl *var, DeclContext *DC) { 11375 DeclContext *VarDC = var->getDeclContext(); 11376 11377 // If the parameter still belongs to the translation unit, then 11378 // we're actually just using one parameter in the declaration of 11379 // the next. 11380 if (isa<ParmVarDecl>(var) && 11381 isa<TranslationUnitDecl>(VarDC)) 11382 return; 11383 11384 // For C code, don't diagnose about capture if we're not actually in code 11385 // right now; it's impossible to write a non-constant expression outside of 11386 // function context, so we'll get other (more useful) diagnostics later. 11387 // 11388 // For C++, things get a bit more nasty... it would be nice to suppress this 11389 // diagnostic for certain cases like using a local variable in an array bound 11390 // for a member of a local class, but the correct predicate is not obvious. 11391 if (!S.getLangOpts().CPlusPlus && !S.CurContext->isFunctionOrMethod()) 11392 return; 11393 11394 if (isa<CXXMethodDecl>(VarDC) && 11395 cast<CXXRecordDecl>(VarDC->getParent())->isLambda()) { 11396 S.Diag(loc, diag::err_reference_to_local_var_in_enclosing_lambda) 11397 << var->getIdentifier(); 11398 } else if (FunctionDecl *fn = dyn_cast<FunctionDecl>(VarDC)) { 11399 S.Diag(loc, diag::err_reference_to_local_var_in_enclosing_function) 11400 << var->getIdentifier() << fn->getDeclName(); 11401 } else if (isa<BlockDecl>(VarDC)) { 11402 S.Diag(loc, diag::err_reference_to_local_var_in_enclosing_block) 11403 << var->getIdentifier(); 11404 } else { 11405 // FIXME: Is there any other context where a local variable can be 11406 // declared? 11407 S.Diag(loc, diag::err_reference_to_local_var_in_enclosing_context) 11408 << var->getIdentifier(); 11409 } 11410 11411 S.Diag(var->getLocation(), diag::note_local_variable_declared_here) 11412 << var->getIdentifier(); 11413 11414 // FIXME: Add additional diagnostic info about class etc. which prevents 11415 // capture. 11416 } 11417 11418 11419 static bool isVariableAlreadyCapturedInScopeInfo(CapturingScopeInfo *CSI, VarDecl *Var, 11420 bool &SubCapturesAreNested, 11421 QualType &CaptureType, 11422 QualType &DeclRefType) { 11423 // Check whether we've already captured it. 11424 if (CSI->CaptureMap.count(Var)) { 11425 // If we found a capture, any subcaptures are nested. 11426 SubCapturesAreNested = true; 11427 11428 // Retrieve the capture type for this variable. 11429 CaptureType = CSI->getCapture(Var).getCaptureType(); 11430 11431 // Compute the type of an expression that refers to this variable. 11432 DeclRefType = CaptureType.getNonReferenceType(); 11433 11434 const CapturingScopeInfo::Capture &Cap = CSI->getCapture(Var); 11435 if (Cap.isCopyCapture() && 11436 !(isa<LambdaScopeInfo>(CSI) && cast<LambdaScopeInfo>(CSI)->Mutable)) 11437 DeclRefType.addConst(); 11438 return true; 11439 } 11440 return false; 11441 } 11442 11443 // Only block literals, captured statements, and lambda expressions can 11444 // capture; other scopes don't work. 11445 static DeclContext *getParentOfCapturingContextOrNull(DeclContext *DC, VarDecl *Var, 11446 SourceLocation Loc, 11447 const bool Diagnose, Sema &S) { 11448 if (isa<BlockDecl>(DC) || isa<CapturedDecl>(DC) || isLambdaCallOperator(DC)) 11449 return getLambdaAwareParentOfDeclContext(DC); 11450 else { 11451 if (Diagnose) 11452 diagnoseUncapturableValueReference(S, Loc, Var, DC); 11453 } 11454 return 0; 11455 } 11456 11457 // Certain capturing entities (lambdas, blocks etc.) are not allowed to capture 11458 // certain types of variables (unnamed, variably modified types etc.) 11459 // so check for eligibility. 11460 static bool isVariableCapturable(CapturingScopeInfo *CSI, VarDecl *Var, 11461 SourceLocation Loc, 11462 const bool Diagnose, Sema &S) { 11463 11464 bool IsBlock = isa<BlockScopeInfo>(CSI); 11465 bool IsLambda = isa<LambdaScopeInfo>(CSI); 11466 11467 // Lambdas are not allowed to capture unnamed variables 11468 // (e.g. anonymous unions). 11469 // FIXME: The C++11 rule don't actually state this explicitly, but I'm 11470 // assuming that's the intent. 11471 if (IsLambda && !Var->getDeclName()) { 11472 if (Diagnose) { 11473 S.Diag(Loc, diag::err_lambda_capture_anonymous_var); 11474 S.Diag(Var->getLocation(), diag::note_declared_at); 11475 } 11476 return false; 11477 } 11478 11479 // Prohibit variably-modified types; they're difficult to deal with. 11480 if (Var->getType()->isVariablyModifiedType()) { 11481 if (Diagnose) { 11482 if (IsBlock) 11483 S.Diag(Loc, diag::err_ref_vm_type); 11484 else 11485 S.Diag(Loc, diag::err_lambda_capture_vm_type) << Var->getDeclName(); 11486 S.Diag(Var->getLocation(), diag::note_previous_decl) 11487 << Var->getDeclName(); 11488 } 11489 return false; 11490 } 11491 // Prohibit structs with flexible array members too. 11492 // We cannot capture what is in the tail end of the struct. 11493 if (const RecordType *VTTy = Var->getType()->getAs<RecordType>()) { 11494 if (VTTy->getDecl()->hasFlexibleArrayMember()) { 11495 if (Diagnose) { 11496 if (IsBlock) 11497 S.Diag(Loc, diag::err_ref_flexarray_type); 11498 else 11499 S.Diag(Loc, diag::err_lambda_capture_flexarray_type) 11500 << Var->getDeclName(); 11501 S.Diag(Var->getLocation(), diag::note_previous_decl) 11502 << Var->getDeclName(); 11503 } 11504 return false; 11505 } 11506 } 11507 const bool HasBlocksAttr = Var->hasAttr<BlocksAttr>(); 11508 // Lambdas and captured statements are not allowed to capture __block 11509 // variables; they don't support the expected semantics. 11510 if (HasBlocksAttr && (IsLambda || isa<CapturedRegionScopeInfo>(CSI))) { 11511 if (Diagnose) { 11512 S.Diag(Loc, diag::err_capture_block_variable) 11513 << Var->getDeclName() << !IsLambda; 11514 S.Diag(Var->getLocation(), diag::note_previous_decl) 11515 << Var->getDeclName(); 11516 } 11517 return false; 11518 } 11519 11520 return true; 11521 } 11522 11523 // Returns true if the capture by block was successful. 11524 static bool captureInBlock(BlockScopeInfo *BSI, VarDecl *Var, 11525 SourceLocation Loc, 11526 const bool BuildAndDiagnose, 11527 QualType &CaptureType, 11528 QualType &DeclRefType, 11529 const bool Nested, 11530 Sema &S) { 11531 Expr *CopyExpr = 0; 11532 bool ByRef = false; 11533 11534 // Blocks are not allowed to capture arrays. 11535 if (CaptureType->isArrayType()) { 11536 if (BuildAndDiagnose) { 11537 S.Diag(Loc, diag::err_ref_array_type); 11538 S.Diag(Var->getLocation(), diag::note_previous_decl) 11539 << Var->getDeclName(); 11540 } 11541 return false; 11542 } 11543 11544 // Forbid the block-capture of autoreleasing variables. 11545 if (CaptureType.getObjCLifetime() == Qualifiers::OCL_Autoreleasing) { 11546 if (BuildAndDiagnose) { 11547 S.Diag(Loc, diag::err_arc_autoreleasing_capture) 11548 << /*block*/ 0; 11549 S.Diag(Var->getLocation(), diag::note_previous_decl) 11550 << Var->getDeclName(); 11551 } 11552 return false; 11553 } 11554 const bool HasBlocksAttr = Var->hasAttr<BlocksAttr>(); 11555 if (HasBlocksAttr || CaptureType->isReferenceType()) { 11556 // Block capture by reference does not change the capture or 11557 // declaration reference types. 11558 ByRef = true; 11559 } else { 11560 // Block capture by copy introduces 'const'. 11561 CaptureType = CaptureType.getNonReferenceType().withConst(); 11562 DeclRefType = CaptureType; 11563 11564 if (S.getLangOpts().CPlusPlus && BuildAndDiagnose) { 11565 if (const RecordType *Record = DeclRefType->getAs<RecordType>()) { 11566 // The capture logic needs the destructor, so make sure we mark it. 11567 // Usually this is unnecessary because most local variables have 11568 // their destructors marked at declaration time, but parameters are 11569 // an exception because it's technically only the call site that 11570 // actually requires the destructor. 11571 if (isa<ParmVarDecl>(Var)) 11572 S.FinalizeVarWithDestructor(Var, Record); 11573 11574 // Enter a new evaluation context to insulate the copy 11575 // full-expression. 11576 EnterExpressionEvaluationContext scope(S, S.PotentiallyEvaluated); 11577 11578 // According to the blocks spec, the capture of a variable from 11579 // the stack requires a const copy constructor. This is not true 11580 // of the copy/move done to move a __block variable to the heap. 11581 Expr *DeclRef = new (S.Context) DeclRefExpr(Var, Nested, 11582 DeclRefType.withConst(), 11583 VK_LValue, Loc); 11584 11585 ExprResult Result 11586 = S.PerformCopyInitialization( 11587 InitializedEntity::InitializeBlock(Var->getLocation(), 11588 CaptureType, false), 11589 Loc, S.Owned(DeclRef)); 11590 11591 // Build a full-expression copy expression if initialization 11592 // succeeded and used a non-trivial constructor. Recover from 11593 // errors by pretending that the copy isn't necessary. 11594 if (!Result.isInvalid() && 11595 !cast<CXXConstructExpr>(Result.get())->getConstructor() 11596 ->isTrivial()) { 11597 Result = S.MaybeCreateExprWithCleanups(Result); 11598 CopyExpr = Result.take(); 11599 } 11600 } 11601 } 11602 } 11603 11604 // Actually capture the variable. 11605 if (BuildAndDiagnose) 11606 BSI->addCapture(Var, HasBlocksAttr, ByRef, Nested, Loc, 11607 SourceLocation(), CaptureType, CopyExpr); 11608 11609 return true; 11610 11611 } 11612 11613 11614 /// \brief Capture the given variable in the captured region. 11615 static bool captureInCapturedRegion(CapturedRegionScopeInfo *RSI, 11616 VarDecl *Var, 11617 SourceLocation Loc, 11618 const bool BuildAndDiagnose, 11619 QualType &CaptureType, 11620 QualType &DeclRefType, 11621 const bool RefersToEnclosingLocal, 11622 Sema &S) { 11623 11624 // By default, capture variables by reference. 11625 bool ByRef = true; 11626 // Using an LValue reference type is consistent with Lambdas (see below). 11627 CaptureType = S.Context.getLValueReferenceType(DeclRefType); 11628 Expr *CopyExpr = 0; 11629 if (BuildAndDiagnose) { 11630 // The current implementation assumes that all variables are captured 11631 // by references. Since there is no capture by copy, no expression evaluation 11632 // will be needed. 11633 // 11634 RecordDecl *RD = RSI->TheRecordDecl; 11635 11636 FieldDecl *Field 11637 = FieldDecl::Create(S.Context, RD, Loc, Loc, 0, CaptureType, 11638 S.Context.getTrivialTypeSourceInfo(CaptureType, Loc), 11639 0, false, ICIS_NoInit); 11640 Field->setImplicit(true); 11641 Field->setAccess(AS_private); 11642 RD->addDecl(Field); 11643 11644 CopyExpr = new (S.Context) DeclRefExpr(Var, RefersToEnclosingLocal, 11645 DeclRefType, VK_LValue, Loc); 11646 Var->setReferenced(true); 11647 Var->markUsed(S.Context); 11648 } 11649 11650 // Actually capture the variable. 11651 if (BuildAndDiagnose) 11652 RSI->addCapture(Var, /*isBlock*/false, ByRef, RefersToEnclosingLocal, Loc, 11653 SourceLocation(), CaptureType, CopyExpr); 11654 11655 11656 return true; 11657 } 11658 11659 /// \brief Create a field within the lambda class for the variable 11660 /// being captured. Handle Array captures. 11661 static ExprResult addAsFieldToClosureType(Sema &S, 11662 LambdaScopeInfo *LSI, 11663 VarDecl *Var, QualType FieldType, 11664 QualType DeclRefType, 11665 SourceLocation Loc, 11666 bool RefersToEnclosingLocal) { 11667 CXXRecordDecl *Lambda = LSI->Lambda; 11668 11669 // Make sure that by-copy captures are of a complete type. 11670 if (!DeclRefType->isDependentType() && 11671 !DeclRefType->isReferenceType() && 11672 S.RequireCompleteType(Loc, DeclRefType, 11673 diag::err_capture_of_incomplete_type, 11674 Var->getDeclName())) { 11675 return ExprError(); 11676 } 11677 11678 // Build the non-static data member. 11679 FieldDecl *Field 11680 = FieldDecl::Create(S.Context, Lambda, Loc, Loc, 0, FieldType, 11681 S.Context.getTrivialTypeSourceInfo(FieldType, Loc), 11682 0, false, ICIS_NoInit); 11683 Field->setImplicit(true); 11684 Field->setAccess(AS_private); 11685 Lambda->addDecl(Field); 11686 11687 // C++11 [expr.prim.lambda]p21: 11688 // When the lambda-expression is evaluated, the entities that 11689 // are captured by copy are used to direct-initialize each 11690 // corresponding non-static data member of the resulting closure 11691 // object. (For array members, the array elements are 11692 // direct-initialized in increasing subscript order.) These 11693 // initializations are performed in the (unspecified) order in 11694 // which the non-static data members are declared. 11695 11696 // Introduce a new evaluation context for the initialization, so 11697 // that temporaries introduced as part of the capture are retained 11698 // to be re-"exported" from the lambda expression itself. 11699 EnterExpressionEvaluationContext scope(S, Sema::PotentiallyEvaluated); 11700 11701 // C++ [expr.prim.labda]p12: 11702 // An entity captured by a lambda-expression is odr-used (3.2) in 11703 // the scope containing the lambda-expression. 11704 Expr *Ref = new (S.Context) DeclRefExpr(Var, RefersToEnclosingLocal, 11705 DeclRefType, VK_LValue, Loc); 11706 Var->setReferenced(true); 11707 Var->markUsed(S.Context); 11708 11709 // When the field has array type, create index variables for each 11710 // dimension of the array. We use these index variables to subscript 11711 // the source array, and other clients (e.g., CodeGen) will perform 11712 // the necessary iteration with these index variables. 11713 SmallVector<VarDecl *, 4> IndexVariables; 11714 QualType BaseType = FieldType; 11715 QualType SizeType = S.Context.getSizeType(); 11716 LSI->ArrayIndexStarts.push_back(LSI->ArrayIndexVars.size()); 11717 while (const ConstantArrayType *Array 11718 = S.Context.getAsConstantArrayType(BaseType)) { 11719 // Create the iteration variable for this array index. 11720 IdentifierInfo *IterationVarName = 0; 11721 { 11722 SmallString<8> Str; 11723 llvm::raw_svector_ostream OS(Str); 11724 OS << "__i" << IndexVariables.size(); 11725 IterationVarName = &S.Context.Idents.get(OS.str()); 11726 } 11727 VarDecl *IterationVar 11728 = VarDecl::Create(S.Context, S.CurContext, Loc, Loc, 11729 IterationVarName, SizeType, 11730 S.Context.getTrivialTypeSourceInfo(SizeType, Loc), 11731 SC_None); 11732 IndexVariables.push_back(IterationVar); 11733 LSI->ArrayIndexVars.push_back(IterationVar); 11734 11735 // Create a reference to the iteration variable. 11736 ExprResult IterationVarRef 11737 = S.BuildDeclRefExpr(IterationVar, SizeType, VK_LValue, Loc); 11738 assert(!IterationVarRef.isInvalid() && 11739 "Reference to invented variable cannot fail!"); 11740 IterationVarRef = S.DefaultLvalueConversion(IterationVarRef.take()); 11741 assert(!IterationVarRef.isInvalid() && 11742 "Conversion of invented variable cannot fail!"); 11743 11744 // Subscript the array with this iteration variable. 11745 ExprResult Subscript = S.CreateBuiltinArraySubscriptExpr( 11746 Ref, Loc, IterationVarRef.take(), Loc); 11747 if (Subscript.isInvalid()) { 11748 S.CleanupVarDeclMarking(); 11749 S.DiscardCleanupsInEvaluationContext(); 11750 return ExprError(); 11751 } 11752 11753 Ref = Subscript.take(); 11754 BaseType = Array->getElementType(); 11755 } 11756 11757 // Construct the entity that we will be initializing. For an array, this 11758 // will be first element in the array, which may require several levels 11759 // of array-subscript entities. 11760 SmallVector<InitializedEntity, 4> Entities; 11761 Entities.reserve(1 + IndexVariables.size()); 11762 Entities.push_back( 11763 InitializedEntity::InitializeLambdaCapture(Var->getIdentifier(), 11764 Field->getType(), Loc)); 11765 for (unsigned I = 0, N = IndexVariables.size(); I != N; ++I) 11766 Entities.push_back(InitializedEntity::InitializeElement(S.Context, 11767 0, 11768 Entities.back())); 11769 11770 InitializationKind InitKind 11771 = InitializationKind::CreateDirect(Loc, Loc, Loc); 11772 InitializationSequence Init(S, Entities.back(), InitKind, Ref); 11773 ExprResult Result(true); 11774 if (!Init.Diagnose(S, Entities.back(), InitKind, Ref)) 11775 Result = Init.Perform(S, Entities.back(), InitKind, Ref); 11776 11777 // If this initialization requires any cleanups (e.g., due to a 11778 // default argument to a copy constructor), note that for the 11779 // lambda. 11780 if (S.ExprNeedsCleanups) 11781 LSI->ExprNeedsCleanups = true; 11782 11783 // Exit the expression evaluation context used for the capture. 11784 S.CleanupVarDeclMarking(); 11785 S.DiscardCleanupsInEvaluationContext(); 11786 return Result; 11787 } 11788 11789 11790 11791 /// \brief Capture the given variable in the lambda. 11792 static bool captureInLambda(LambdaScopeInfo *LSI, 11793 VarDecl *Var, 11794 SourceLocation Loc, 11795 const bool BuildAndDiagnose, 11796 QualType &CaptureType, 11797 QualType &DeclRefType, 11798 const bool RefersToEnclosingLocal, 11799 const Sema::TryCaptureKind Kind, 11800 SourceLocation EllipsisLoc, 11801 const bool IsTopScope, 11802 Sema &S) { 11803 11804 // Determine whether we are capturing by reference or by value. 11805 bool ByRef = false; 11806 if (IsTopScope && Kind != Sema::TryCapture_Implicit) { 11807 ByRef = (Kind == Sema::TryCapture_ExplicitByRef); 11808 } else { 11809 ByRef = (LSI->ImpCaptureStyle == LambdaScopeInfo::ImpCap_LambdaByref); 11810 } 11811 11812 // Compute the type of the field that will capture this variable. 11813 if (ByRef) { 11814 // C++11 [expr.prim.lambda]p15: 11815 // An entity is captured by reference if it is implicitly or 11816 // explicitly captured but not captured by copy. It is 11817 // unspecified whether additional unnamed non-static data 11818 // members are declared in the closure type for entities 11819 // captured by reference. 11820 // 11821 // FIXME: It is not clear whether we want to build an lvalue reference 11822 // to the DeclRefType or to CaptureType.getNonReferenceType(). GCC appears 11823 // to do the former, while EDG does the latter. Core issue 1249 will 11824 // clarify, but for now we follow GCC because it's a more permissive and 11825 // easily defensible position. 11826 CaptureType = S.Context.getLValueReferenceType(DeclRefType); 11827 } else { 11828 // C++11 [expr.prim.lambda]p14: 11829 // For each entity captured by copy, an unnamed non-static 11830 // data member is declared in the closure type. The 11831 // declaration order of these members is unspecified. The type 11832 // of such a data member is the type of the corresponding 11833 // captured entity if the entity is not a reference to an 11834 // object, or the referenced type otherwise. [Note: If the 11835 // captured entity is a reference to a function, the 11836 // corresponding data member is also a reference to a 11837 // function. - end note ] 11838 if (const ReferenceType *RefType = CaptureType->getAs<ReferenceType>()){ 11839 if (!RefType->getPointeeType()->isFunctionType()) 11840 CaptureType = RefType->getPointeeType(); 11841 } 11842 11843 // Forbid the lambda copy-capture of autoreleasing variables. 11844 if (CaptureType.getObjCLifetime() == Qualifiers::OCL_Autoreleasing) { 11845 if (BuildAndDiagnose) { 11846 S.Diag(Loc, diag::err_arc_autoreleasing_capture) << /*lambda*/ 1; 11847 S.Diag(Var->getLocation(), diag::note_previous_decl) 11848 << Var->getDeclName(); 11849 } 11850 return false; 11851 } 11852 11853 if (S.RequireNonAbstractType(Loc, CaptureType, 11854 diag::err_capture_of_abstract_type)) 11855 return false; 11856 } 11857 11858 // Capture this variable in the lambda. 11859 Expr *CopyExpr = 0; 11860 if (BuildAndDiagnose) { 11861 ExprResult Result = addAsFieldToClosureType(S, LSI, Var, 11862 CaptureType, DeclRefType, Loc, 11863 RefersToEnclosingLocal); 11864 if (!Result.isInvalid()) 11865 CopyExpr = Result.take(); 11866 } 11867 11868 // Compute the type of a reference to this captured variable. 11869 if (ByRef) 11870 DeclRefType = CaptureType.getNonReferenceType(); 11871 else { 11872 // C++ [expr.prim.lambda]p5: 11873 // The closure type for a lambda-expression has a public inline 11874 // function call operator [...]. This function call operator is 11875 // declared const (9.3.1) if and only if the lambda-expression’s 11876 // parameter-declaration-clause is not followed by mutable. 11877 DeclRefType = CaptureType.getNonReferenceType(); 11878 if (!LSI->Mutable && !CaptureType->isReferenceType()) 11879 DeclRefType.addConst(); 11880 } 11881 11882 // Add the capture. 11883 if (BuildAndDiagnose) 11884 LSI->addCapture(Var, /*IsBlock=*/false, ByRef, RefersToEnclosingLocal, 11885 Loc, EllipsisLoc, CaptureType, CopyExpr); 11886 11887 return true; 11888 } 11889 11890 11891 bool Sema::tryCaptureVariable(VarDecl *Var, SourceLocation ExprLoc, 11892 TryCaptureKind Kind, SourceLocation EllipsisLoc, 11893 bool BuildAndDiagnose, 11894 QualType &CaptureType, 11895 QualType &DeclRefType, 11896 const unsigned *const FunctionScopeIndexToStopAt) { 11897 bool Nested = false; 11898 11899 DeclContext *DC = CurContext; 11900 const unsigned MaxFunctionScopesIndex = FunctionScopeIndexToStopAt 11901 ? *FunctionScopeIndexToStopAt : FunctionScopes.size() - 1; 11902 // We need to sync up the Declaration Context with the 11903 // FunctionScopeIndexToStopAt 11904 if (FunctionScopeIndexToStopAt) { 11905 unsigned FSIndex = FunctionScopes.size() - 1; 11906 while (FSIndex != MaxFunctionScopesIndex) { 11907 DC = getLambdaAwareParentOfDeclContext(DC); 11908 --FSIndex; 11909 } 11910 } 11911 11912 11913 // If the variable is declared in the current context (and is not an 11914 // init-capture), there is no need to capture it. 11915 if (!Var->isInitCapture() && Var->getDeclContext() == DC) return true; 11916 if (!Var->hasLocalStorage()) return true; 11917 11918 // Walk up the stack to determine whether we can capture the variable, 11919 // performing the "simple" checks that don't depend on type. We stop when 11920 // we've either hit the declared scope of the variable or find an existing 11921 // capture of that variable. We start from the innermost capturing-entity 11922 // (the DC) and ensure that all intervening capturing-entities 11923 // (blocks/lambdas etc.) between the innermost capturer and the variable`s 11924 // declcontext can either capture the variable or have already captured 11925 // the variable. 11926 CaptureType = Var->getType(); 11927 DeclRefType = CaptureType.getNonReferenceType(); 11928 bool Explicit = (Kind != TryCapture_Implicit); 11929 unsigned FunctionScopesIndex = MaxFunctionScopesIndex; 11930 do { 11931 // Only block literals, captured statements, and lambda expressions can 11932 // capture; other scopes don't work. 11933 DeclContext *ParentDC = getParentOfCapturingContextOrNull(DC, Var, 11934 ExprLoc, 11935 BuildAndDiagnose, 11936 *this); 11937 if (!ParentDC) return true; 11938 11939 FunctionScopeInfo *FSI = FunctionScopes[FunctionScopesIndex]; 11940 CapturingScopeInfo *CSI = cast<CapturingScopeInfo>(FSI); 11941 11942 11943 // Check whether we've already captured it. 11944 if (isVariableAlreadyCapturedInScopeInfo(CSI, Var, Nested, CaptureType, 11945 DeclRefType)) 11946 break; 11947 // If we are instantiating a generic lambda call operator body, 11948 // we do not want to capture new variables. What was captured 11949 // during either a lambdas transformation or initial parsing 11950 // should be used. 11951 if (isGenericLambdaCallOperatorSpecialization(DC)) { 11952 if (BuildAndDiagnose) { 11953 LambdaScopeInfo *LSI = cast<LambdaScopeInfo>(CSI); 11954 if (LSI->ImpCaptureStyle == CapturingScopeInfo::ImpCap_None) { 11955 Diag(ExprLoc, diag::err_lambda_impcap) << Var->getDeclName(); 11956 Diag(Var->getLocation(), diag::note_previous_decl) 11957 << Var->getDeclName(); 11958 Diag(LSI->Lambda->getLocStart(), diag::note_lambda_decl); 11959 } else 11960 diagnoseUncapturableValueReference(*this, ExprLoc, Var, DC); 11961 } 11962 return true; 11963 } 11964 // Certain capturing entities (lambdas, blocks etc.) are not allowed to capture 11965 // certain types of variables (unnamed, variably modified types etc.) 11966 // so check for eligibility. 11967 if (!isVariableCapturable(CSI, Var, ExprLoc, BuildAndDiagnose, *this)) 11968 return true; 11969 11970 if (CSI->ImpCaptureStyle == CapturingScopeInfo::ImpCap_None && !Explicit) { 11971 // No capture-default, and this is not an explicit capture 11972 // so cannot capture this variable. 11973 if (BuildAndDiagnose) { 11974 Diag(ExprLoc, diag::err_lambda_impcap) << Var->getDeclName(); 11975 Diag(Var->getLocation(), diag::note_previous_decl) 11976 << Var->getDeclName(); 11977 Diag(cast<LambdaScopeInfo>(CSI)->Lambda->getLocStart(), 11978 diag::note_lambda_decl); 11979 // FIXME: If we error out because an outer lambda can not implicitly 11980 // capture a variable that an inner lambda explicitly captures, we 11981 // should have the inner lambda do the explicit capture - because 11982 // it makes for cleaner diagnostics later. This would purely be done 11983 // so that the diagnostic does not misleadingly claim that a variable 11984 // can not be captured by a lambda implicitly even though it is captured 11985 // explicitly. Suggestion: 11986 // - create const bool VariableCaptureWasInitiallyExplicit = Explicit 11987 // at the function head 11988 // - cache the StartingDeclContext - this must be a lambda 11989 // - captureInLambda in the innermost lambda the variable. 11990 } 11991 return true; 11992 } 11993 11994 FunctionScopesIndex--; 11995 DC = ParentDC; 11996 Explicit = false; 11997 } while (!Var->getDeclContext()->Equals(DC)); 11998 11999 // Walk back down the scope stack, (e.g. from outer lambda to inner lambda) 12000 // computing the type of the capture at each step, checking type-specific 12001 // requirements, and adding captures if requested. 12002 // If the variable had already been captured previously, we start capturing 12003 // at the lambda nested within that one. 12004 for (unsigned I = ++FunctionScopesIndex, N = MaxFunctionScopesIndex + 1; I != N; 12005 ++I) { 12006 CapturingScopeInfo *CSI = cast<CapturingScopeInfo>(FunctionScopes[I]); 12007 12008 if (BlockScopeInfo *BSI = dyn_cast<BlockScopeInfo>(CSI)) { 12009 if (!captureInBlock(BSI, Var, ExprLoc, 12010 BuildAndDiagnose, CaptureType, 12011 DeclRefType, Nested, *this)) 12012 return true; 12013 Nested = true; 12014 } else if (CapturedRegionScopeInfo *RSI = dyn_cast<CapturedRegionScopeInfo>(CSI)) { 12015 if (!captureInCapturedRegion(RSI, Var, ExprLoc, 12016 BuildAndDiagnose, CaptureType, 12017 DeclRefType, Nested, *this)) 12018 return true; 12019 Nested = true; 12020 } else { 12021 LambdaScopeInfo *LSI = cast<LambdaScopeInfo>(CSI); 12022 if (!captureInLambda(LSI, Var, ExprLoc, 12023 BuildAndDiagnose, CaptureType, 12024 DeclRefType, Nested, Kind, EllipsisLoc, 12025 /*IsTopScope*/I == N - 1, *this)) 12026 return true; 12027 Nested = true; 12028 } 12029 } 12030 return false; 12031 } 12032 12033 bool Sema::tryCaptureVariable(VarDecl *Var, SourceLocation Loc, 12034 TryCaptureKind Kind, SourceLocation EllipsisLoc) { 12035 QualType CaptureType; 12036 QualType DeclRefType; 12037 return tryCaptureVariable(Var, Loc, Kind, EllipsisLoc, 12038 /*BuildAndDiagnose=*/true, CaptureType, 12039 DeclRefType, 0); 12040 } 12041 12042 QualType Sema::getCapturedDeclRefType(VarDecl *Var, SourceLocation Loc) { 12043 QualType CaptureType; 12044 QualType DeclRefType; 12045 12046 // Determine whether we can capture this variable. 12047 if (tryCaptureVariable(Var, Loc, TryCapture_Implicit, SourceLocation(), 12048 /*BuildAndDiagnose=*/false, CaptureType, 12049 DeclRefType, 0)) 12050 return QualType(); 12051 12052 return DeclRefType; 12053 } 12054 12055 12056 12057 // If either the type of the variable or the initializer is dependent, 12058 // return false. Otherwise, determine whether the variable is a constant 12059 // expression. Use this if you need to know if a variable that might or 12060 // might not be dependent is truly a constant expression. 12061 static inline bool IsVariableNonDependentAndAConstantExpression(VarDecl *Var, 12062 ASTContext &Context) { 12063 12064 if (Var->getType()->isDependentType()) 12065 return false; 12066 const VarDecl *DefVD = 0; 12067 Var->getAnyInitializer(DefVD); 12068 if (!DefVD) 12069 return false; 12070 EvaluatedStmt *Eval = DefVD->ensureEvaluatedStmt(); 12071 Expr *Init = cast<Expr>(Eval->Value); 12072 if (Init->isValueDependent()) 12073 return false; 12074 return IsVariableAConstantExpression(Var, Context); 12075 } 12076 12077 12078 void Sema::UpdateMarkingForLValueToRValue(Expr *E) { 12079 // Per C++11 [basic.def.odr], a variable is odr-used "unless it is 12080 // an object that satisfies the requirements for appearing in a 12081 // constant expression (5.19) and the lvalue-to-rvalue conversion (4.1) 12082 // is immediately applied." This function handles the lvalue-to-rvalue 12083 // conversion part. 12084 MaybeODRUseExprs.erase(E->IgnoreParens()); 12085 12086 // If we are in a lambda, check if this DeclRefExpr or MemberExpr refers 12087 // to a variable that is a constant expression, and if so, identify it as 12088 // a reference to a variable that does not involve an odr-use of that 12089 // variable. 12090 if (LambdaScopeInfo *LSI = getCurLambda()) { 12091 Expr *SansParensExpr = E->IgnoreParens(); 12092 VarDecl *Var = 0; 12093 if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(SansParensExpr)) 12094 Var = dyn_cast<VarDecl>(DRE->getFoundDecl()); 12095 else if (MemberExpr *ME = dyn_cast<MemberExpr>(SansParensExpr)) 12096 Var = dyn_cast<VarDecl>(ME->getMemberDecl()); 12097 12098 if (Var && IsVariableNonDependentAndAConstantExpression(Var, Context)) 12099 LSI->markVariableExprAsNonODRUsed(SansParensExpr); 12100 } 12101 } 12102 12103 ExprResult Sema::ActOnConstantExpression(ExprResult Res) { 12104 if (!Res.isUsable()) 12105 return Res; 12106 12107 // If a constant-expression is a reference to a variable where we delay 12108 // deciding whether it is an odr-use, just assume we will apply the 12109 // lvalue-to-rvalue conversion. In the one case where this doesn't happen 12110 // (a non-type template argument), we have special handling anyway. 12111 UpdateMarkingForLValueToRValue(Res.get()); 12112 return Res; 12113 } 12114 12115 void Sema::CleanupVarDeclMarking() { 12116 for (llvm::SmallPtrSetIterator<Expr*> i = MaybeODRUseExprs.begin(), 12117 e = MaybeODRUseExprs.end(); 12118 i != e; ++i) { 12119 VarDecl *Var; 12120 SourceLocation Loc; 12121 if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(*i)) { 12122 Var = cast<VarDecl>(DRE->getDecl()); 12123 Loc = DRE->getLocation(); 12124 } else if (MemberExpr *ME = dyn_cast<MemberExpr>(*i)) { 12125 Var = cast<VarDecl>(ME->getMemberDecl()); 12126 Loc = ME->getMemberLoc(); 12127 } else { 12128 llvm_unreachable("Unexpcted expression"); 12129 } 12130 12131 MarkVarDeclODRUsed(Var, Loc, *this, /*MaxFunctionScopeIndex Pointer*/ 0); 12132 } 12133 12134 MaybeODRUseExprs.clear(); 12135 } 12136 12137 12138 static void DoMarkVarDeclReferenced(Sema &SemaRef, SourceLocation Loc, 12139 VarDecl *Var, Expr *E) { 12140 assert((!E || isa<DeclRefExpr>(E) || isa<MemberExpr>(E)) && 12141 "Invalid Expr argument to DoMarkVarDeclReferenced"); 12142 Var->setReferenced(); 12143 12144 // If the context is not PotentiallyEvaluated and not Unevaluated 12145 // (i.e PotentiallyEvaluatedIfUsed) do not bother to consider variables 12146 // in this context for odr-use unless we are within a lambda. 12147 // If we don't know whether the context is potentially evaluated or not 12148 // (for e.g., if we're in a generic lambda), we want to add a potential 12149 // capture and eventually analyze for odr-use. 12150 // We should also be able to analyze certain constructs in a non-generic 12151 // lambda setting for potential odr-use and capture violation: 12152 // template<class T> void foo(T t) { 12153 // auto L = [](int i) { return t; }; 12154 // } 12155 // 12156 if (!IsPotentiallyEvaluatedContext(SemaRef)) { 12157 12158 if (SemaRef.isUnevaluatedContext()) return; 12159 12160 const bool refersToEnclosingScope = 12161 (SemaRef.CurContext != Var->getDeclContext() && 12162 Var->getDeclContext()->isFunctionOrMethod()); 12163 if (!refersToEnclosingScope) return; 12164 12165 if (LambdaScopeInfo *const LSI = SemaRef.getCurLambda()) { 12166 // If a variable could potentially be odr-used, defer marking it so 12167 // until we finish analyzing the full expression for any lvalue-to-rvalue 12168 // or discarded value conversions that would obviate odr-use. 12169 // Add it to the list of potential captures that will be analyzed 12170 // later (ActOnFinishFullExpr) for eventual capture and odr-use marking 12171 // unless the variable is a reference that was initialized by a constant 12172 // expression (this will never need to be captured or odr-used). 12173 const bool IsConstantExpr = IsVariableNonDependentAndAConstantExpression( 12174 Var, SemaRef.Context); 12175 assert(E && "Capture variable should be used in an expression."); 12176 if (!IsConstantExpr || !Var->getType()->isReferenceType()) 12177 LSI->addPotentialCapture(E->IgnoreParens()); 12178 } 12179 return; 12180 } 12181 12182 VarTemplateSpecializationDecl *VarSpec = 12183 dyn_cast<VarTemplateSpecializationDecl>(Var); 12184 assert(!isa<VarTemplatePartialSpecializationDecl>(Var) && 12185 "Can't instantiate a partial template specialization."); 12186 12187 // Implicit instantiation of static data members, static data member 12188 // templates of class templates, and variable template specializations. 12189 // Delay instantiations of variable templates, except for those 12190 // that could be used in a constant expression. 12191 TemplateSpecializationKind TSK = Var->getTemplateSpecializationKind(); 12192 if (isTemplateInstantiation(TSK)) { 12193 bool TryInstantiating = TSK == TSK_ImplicitInstantiation; 12194 12195 if (TryInstantiating && !isa<VarTemplateSpecializationDecl>(Var)) { 12196 if (Var->getPointOfInstantiation().isInvalid()) { 12197 // This is a modification of an existing AST node. Notify listeners. 12198 if (ASTMutationListener *L = SemaRef.getASTMutationListener()) 12199 L->StaticDataMemberInstantiated(Var); 12200 } else if (!Var->isUsableInConstantExpressions(SemaRef.Context)) 12201 // Don't bother trying to instantiate it again, unless we might need 12202 // its initializer before we get to the end of the TU. 12203 TryInstantiating = false; 12204 } 12205 12206 if (Var->getPointOfInstantiation().isInvalid()) 12207 Var->setTemplateSpecializationKind(TSK, Loc); 12208 12209 if (TryInstantiating) { 12210 SourceLocation PointOfInstantiation = Var->getPointOfInstantiation(); 12211 bool InstantiationDependent = false; 12212 bool IsNonDependent = 12213 VarSpec ? !TemplateSpecializationType::anyDependentTemplateArguments( 12214 VarSpec->getTemplateArgsInfo(), InstantiationDependent) 12215 : true; 12216 12217 // Do not instantiate specializations that are still type-dependent. 12218 if (IsNonDependent) { 12219 if (Var->isUsableInConstantExpressions(SemaRef.Context)) { 12220 // Do not defer instantiations of variables which could be used in a 12221 // constant expression. 12222 SemaRef.InstantiateVariableDefinition(PointOfInstantiation, Var); 12223 } else { 12224 SemaRef.PendingInstantiations 12225 .push_back(std::make_pair(Var, PointOfInstantiation)); 12226 } 12227 } 12228 } 12229 } 12230 // Per C++11 [basic.def.odr], a variable is odr-used "unless it satisfies 12231 // the requirements for appearing in a constant expression (5.19) and, if 12232 // it is an object, the lvalue-to-rvalue conversion (4.1) 12233 // is immediately applied." We check the first part here, and 12234 // Sema::UpdateMarkingForLValueToRValue deals with the second part. 12235 // Note that we use the C++11 definition everywhere because nothing in 12236 // C++03 depends on whether we get the C++03 version correct. The second 12237 // part does not apply to references, since they are not objects. 12238 if (E && IsVariableAConstantExpression(Var, SemaRef.Context)) { 12239 // A reference initialized by a constant expression can never be 12240 // odr-used, so simply ignore it. 12241 // But a non-reference might get odr-used if it doesn't undergo 12242 // an lvalue-to-rvalue or is discarded, so track it. 12243 if (!Var->getType()->isReferenceType()) 12244 SemaRef.MaybeODRUseExprs.insert(E); 12245 } 12246 else 12247 MarkVarDeclODRUsed(Var, Loc, SemaRef, /*MaxFunctionScopeIndex ptr*/0); 12248 } 12249 12250 /// \brief Mark a variable referenced, and check whether it is odr-used 12251 /// (C++ [basic.def.odr]p2, C99 6.9p3). Note that this should not be 12252 /// used directly for normal expressions referring to VarDecl. 12253 void Sema::MarkVariableReferenced(SourceLocation Loc, VarDecl *Var) { 12254 DoMarkVarDeclReferenced(*this, Loc, Var, 0); 12255 } 12256 12257 static void MarkExprReferenced(Sema &SemaRef, SourceLocation Loc, 12258 Decl *D, Expr *E, bool OdrUse) { 12259 if (VarDecl *Var = dyn_cast<VarDecl>(D)) { 12260 DoMarkVarDeclReferenced(SemaRef, Loc, Var, E); 12261 return; 12262 } 12263 12264 SemaRef.MarkAnyDeclReferenced(Loc, D, OdrUse); 12265 12266 // If this is a call to a method via a cast, also mark the method in the 12267 // derived class used in case codegen can devirtualize the call. 12268 const MemberExpr *ME = dyn_cast<MemberExpr>(E); 12269 if (!ME) 12270 return; 12271 CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(ME->getMemberDecl()); 12272 if (!MD) 12273 return; 12274 const Expr *Base = ME->getBase(); 12275 const CXXRecordDecl *MostDerivedClassDecl = Base->getBestDynamicClassType(); 12276 if (!MostDerivedClassDecl) 12277 return; 12278 CXXMethodDecl *DM = MD->getCorrespondingMethodInClass(MostDerivedClassDecl); 12279 if (!DM || DM->isPure()) 12280 return; 12281 SemaRef.MarkAnyDeclReferenced(Loc, DM, OdrUse); 12282 } 12283 12284 /// \brief Perform reference-marking and odr-use handling for a DeclRefExpr. 12285 void Sema::MarkDeclRefReferenced(DeclRefExpr *E) { 12286 // TODO: update this with DR# once a defect report is filed. 12287 // C++11 defect. The address of a pure member should not be an ODR use, even 12288 // if it's a qualified reference. 12289 bool OdrUse = true; 12290 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(E->getDecl())) 12291 if (Method->isVirtual()) 12292 OdrUse = false; 12293 MarkExprReferenced(*this, E->getLocation(), E->getDecl(), E, OdrUse); 12294 } 12295 12296 /// \brief Perform reference-marking and odr-use handling for a MemberExpr. 12297 void Sema::MarkMemberReferenced(MemberExpr *E) { 12298 // C++11 [basic.def.odr]p2: 12299 // A non-overloaded function whose name appears as a potentially-evaluated 12300 // expression or a member of a set of candidate functions, if selected by 12301 // overload resolution when referred to from a potentially-evaluated 12302 // expression, is odr-used, unless it is a pure virtual function and its 12303 // name is not explicitly qualified. 12304 bool OdrUse = true; 12305 if (!E->hasQualifier()) { 12306 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(E->getMemberDecl())) 12307 if (Method->isPure()) 12308 OdrUse = false; 12309 } 12310 SourceLocation Loc = E->getMemberLoc().isValid() ? 12311 E->getMemberLoc() : E->getLocStart(); 12312 MarkExprReferenced(*this, Loc, E->getMemberDecl(), E, OdrUse); 12313 } 12314 12315 /// \brief Perform marking for a reference to an arbitrary declaration. It 12316 /// marks the declaration referenced, and performs odr-use checking for functions 12317 /// and variables. This method should not be used when building an normal 12318 /// expression which refers to a variable. 12319 void Sema::MarkAnyDeclReferenced(SourceLocation Loc, Decl *D, bool OdrUse) { 12320 if (OdrUse) { 12321 if (VarDecl *VD = dyn_cast<VarDecl>(D)) { 12322 MarkVariableReferenced(Loc, VD); 12323 return; 12324 } 12325 if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) { 12326 MarkFunctionReferenced(Loc, FD); 12327 return; 12328 } 12329 } 12330 D->setReferenced(); 12331 } 12332 12333 namespace { 12334 // Mark all of the declarations referenced 12335 // FIXME: Not fully implemented yet! We need to have a better understanding 12336 // of when we're entering 12337 class MarkReferencedDecls : public RecursiveASTVisitor<MarkReferencedDecls> { 12338 Sema &S; 12339 SourceLocation Loc; 12340 12341 public: 12342 typedef RecursiveASTVisitor<MarkReferencedDecls> Inherited; 12343 12344 MarkReferencedDecls(Sema &S, SourceLocation Loc) : S(S), Loc(Loc) { } 12345 12346 bool TraverseTemplateArgument(const TemplateArgument &Arg); 12347 bool TraverseRecordType(RecordType *T); 12348 }; 12349 } 12350 12351 bool MarkReferencedDecls::TraverseTemplateArgument( 12352 const TemplateArgument &Arg) { 12353 if (Arg.getKind() == TemplateArgument::Declaration) { 12354 if (Decl *D = Arg.getAsDecl()) 12355 S.MarkAnyDeclReferenced(Loc, D, true); 12356 } 12357 12358 return Inherited::TraverseTemplateArgument(Arg); 12359 } 12360 12361 bool MarkReferencedDecls::TraverseRecordType(RecordType *T) { 12362 if (ClassTemplateSpecializationDecl *Spec 12363 = dyn_cast<ClassTemplateSpecializationDecl>(T->getDecl())) { 12364 const TemplateArgumentList &Args = Spec->getTemplateArgs(); 12365 return TraverseTemplateArguments(Args.data(), Args.size()); 12366 } 12367 12368 return true; 12369 } 12370 12371 void Sema::MarkDeclarationsReferencedInType(SourceLocation Loc, QualType T) { 12372 MarkReferencedDecls Marker(*this, Loc); 12373 Marker.TraverseType(Context.getCanonicalType(T)); 12374 } 12375 12376 namespace { 12377 /// \brief Helper class that marks all of the declarations referenced by 12378 /// potentially-evaluated subexpressions as "referenced". 12379 class EvaluatedExprMarker : public EvaluatedExprVisitor<EvaluatedExprMarker> { 12380 Sema &S; 12381 bool SkipLocalVariables; 12382 12383 public: 12384 typedef EvaluatedExprVisitor<EvaluatedExprMarker> Inherited; 12385 12386 EvaluatedExprMarker(Sema &S, bool SkipLocalVariables) 12387 : Inherited(S.Context), S(S), SkipLocalVariables(SkipLocalVariables) { } 12388 12389 void VisitDeclRefExpr(DeclRefExpr *E) { 12390 // If we were asked not to visit local variables, don't. 12391 if (SkipLocalVariables) { 12392 if (VarDecl *VD = dyn_cast<VarDecl>(E->getDecl())) 12393 if (VD->hasLocalStorage()) 12394 return; 12395 } 12396 12397 S.MarkDeclRefReferenced(E); 12398 } 12399 12400 void VisitMemberExpr(MemberExpr *E) { 12401 S.MarkMemberReferenced(E); 12402 Inherited::VisitMemberExpr(E); 12403 } 12404 12405 void VisitCXXBindTemporaryExpr(CXXBindTemporaryExpr *E) { 12406 S.MarkFunctionReferenced(E->getLocStart(), 12407 const_cast<CXXDestructorDecl*>(E->getTemporary()->getDestructor())); 12408 Visit(E->getSubExpr()); 12409 } 12410 12411 void VisitCXXNewExpr(CXXNewExpr *E) { 12412 if (E->getOperatorNew()) 12413 S.MarkFunctionReferenced(E->getLocStart(), E->getOperatorNew()); 12414 if (E->getOperatorDelete()) 12415 S.MarkFunctionReferenced(E->getLocStart(), E->getOperatorDelete()); 12416 Inherited::VisitCXXNewExpr(E); 12417 } 12418 12419 void VisitCXXDeleteExpr(CXXDeleteExpr *E) { 12420 if (E->getOperatorDelete()) 12421 S.MarkFunctionReferenced(E->getLocStart(), E->getOperatorDelete()); 12422 QualType Destroyed = S.Context.getBaseElementType(E->getDestroyedType()); 12423 if (const RecordType *DestroyedRec = Destroyed->getAs<RecordType>()) { 12424 CXXRecordDecl *Record = cast<CXXRecordDecl>(DestroyedRec->getDecl()); 12425 S.MarkFunctionReferenced(E->getLocStart(), 12426 S.LookupDestructor(Record)); 12427 } 12428 12429 Inherited::VisitCXXDeleteExpr(E); 12430 } 12431 12432 void VisitCXXConstructExpr(CXXConstructExpr *E) { 12433 S.MarkFunctionReferenced(E->getLocStart(), E->getConstructor()); 12434 Inherited::VisitCXXConstructExpr(E); 12435 } 12436 12437 void VisitCXXDefaultArgExpr(CXXDefaultArgExpr *E) { 12438 Visit(E->getExpr()); 12439 } 12440 12441 void VisitImplicitCastExpr(ImplicitCastExpr *E) { 12442 Inherited::VisitImplicitCastExpr(E); 12443 12444 if (E->getCastKind() == CK_LValueToRValue) 12445 S.UpdateMarkingForLValueToRValue(E->getSubExpr()); 12446 } 12447 }; 12448 } 12449 12450 /// \brief Mark any declarations that appear within this expression or any 12451 /// potentially-evaluated subexpressions as "referenced". 12452 /// 12453 /// \param SkipLocalVariables If true, don't mark local variables as 12454 /// 'referenced'. 12455 void Sema::MarkDeclarationsReferencedInExpr(Expr *E, 12456 bool SkipLocalVariables) { 12457 EvaluatedExprMarker(*this, SkipLocalVariables).Visit(E); 12458 } 12459 12460 /// \brief Emit a diagnostic that describes an effect on the run-time behavior 12461 /// of the program being compiled. 12462 /// 12463 /// This routine emits the given diagnostic when the code currently being 12464 /// type-checked is "potentially evaluated", meaning that there is a 12465 /// possibility that the code will actually be executable. Code in sizeof() 12466 /// expressions, code used only during overload resolution, etc., are not 12467 /// potentially evaluated. This routine will suppress such diagnostics or, 12468 /// in the absolutely nutty case of potentially potentially evaluated 12469 /// expressions (C++ typeid), queue the diagnostic to potentially emit it 12470 /// later. 12471 /// 12472 /// This routine should be used for all diagnostics that describe the run-time 12473 /// behavior of a program, such as passing a non-POD value through an ellipsis. 12474 /// Failure to do so will likely result in spurious diagnostics or failures 12475 /// during overload resolution or within sizeof/alignof/typeof/typeid. 12476 bool Sema::DiagRuntimeBehavior(SourceLocation Loc, const Stmt *Statement, 12477 const PartialDiagnostic &PD) { 12478 switch (ExprEvalContexts.back().Context) { 12479 case Unevaluated: 12480 case UnevaluatedAbstract: 12481 // The argument will never be evaluated, so don't complain. 12482 break; 12483 12484 case ConstantEvaluated: 12485 // Relevant diagnostics should be produced by constant evaluation. 12486 break; 12487 12488 case PotentiallyEvaluated: 12489 case PotentiallyEvaluatedIfUsed: 12490 if (Statement && getCurFunctionOrMethodDecl()) { 12491 FunctionScopes.back()->PossiblyUnreachableDiags. 12492 push_back(sema::PossiblyUnreachableDiag(PD, Loc, Statement)); 12493 } 12494 else 12495 Diag(Loc, PD); 12496 12497 return true; 12498 } 12499 12500 return false; 12501 } 12502 12503 bool Sema::CheckCallReturnType(QualType ReturnType, SourceLocation Loc, 12504 CallExpr *CE, FunctionDecl *FD) { 12505 if (ReturnType->isVoidType() || !ReturnType->isIncompleteType()) 12506 return false; 12507 12508 // If we're inside a decltype's expression, don't check for a valid return 12509 // type or construct temporaries until we know whether this is the last call. 12510 if (ExprEvalContexts.back().IsDecltype) { 12511 ExprEvalContexts.back().DelayedDecltypeCalls.push_back(CE); 12512 return false; 12513 } 12514 12515 class CallReturnIncompleteDiagnoser : public TypeDiagnoser { 12516 FunctionDecl *FD; 12517 CallExpr *CE; 12518 12519 public: 12520 CallReturnIncompleteDiagnoser(FunctionDecl *FD, CallExpr *CE) 12521 : FD(FD), CE(CE) { } 12522 12523 virtual void diagnose(Sema &S, SourceLocation Loc, QualType T) { 12524 if (!FD) { 12525 S.Diag(Loc, diag::err_call_incomplete_return) 12526 << T << CE->getSourceRange(); 12527 return; 12528 } 12529 12530 S.Diag(Loc, diag::err_call_function_incomplete_return) 12531 << CE->getSourceRange() << FD->getDeclName() << T; 12532 S.Diag(FD->getLocation(), 12533 diag::note_function_with_incomplete_return_type_declared_here) 12534 << FD->getDeclName(); 12535 } 12536 } Diagnoser(FD, CE); 12537 12538 if (RequireCompleteType(Loc, ReturnType, Diagnoser)) 12539 return true; 12540 12541 return false; 12542 } 12543 12544 // Diagnose the s/=/==/ and s/\|=/!=/ typos. Note that adding parentheses 12545 // will prevent this condition from triggering, which is what we want. 12546 void Sema::DiagnoseAssignmentAsCondition(Expr *E) { 12547 SourceLocation Loc; 12548 12549 unsigned diagnostic = diag::warn_condition_is_assignment; 12550 bool IsOrAssign = false; 12551 12552 if (BinaryOperator *Op = dyn_cast<BinaryOperator>(E)) { 12553 if (Op->getOpcode() != BO_Assign && Op->getOpcode() != BO_OrAssign) 12554 return; 12555 12556 IsOrAssign = Op->getOpcode() == BO_OrAssign; 12557 12558 // Greylist some idioms by putting them into a warning subcategory. 12559 if (ObjCMessageExpr *ME 12560 = dyn_cast<ObjCMessageExpr>(Op->getRHS()->IgnoreParenCasts())) { 12561 Selector Sel = ME->getSelector(); 12562 12563 // self = [<foo> init...] 12564 if (isSelfExpr(Op->getLHS()) && ME->getMethodFamily() == OMF_init) 12565 diagnostic = diag::warn_condition_is_idiomatic_assignment; 12566 12567 // <foo> = [<bar> nextObject] 12568 else if (Sel.isUnarySelector() && Sel.getNameForSlot(0) == "nextObject") 12569 diagnostic = diag::warn_condition_is_idiomatic_assignment; 12570 } 12571 12572 Loc = Op->getOperatorLoc(); 12573 } else if (CXXOperatorCallExpr *Op = dyn_cast<CXXOperatorCallExpr>(E)) { 12574 if (Op->getOperator() != OO_Equal && Op->getOperator() != OO_PipeEqual) 12575 return; 12576 12577 IsOrAssign = Op->getOperator() == OO_PipeEqual; 12578 Loc = Op->getOperatorLoc(); 12579 } else if (PseudoObjectExpr *POE = dyn_cast<PseudoObjectExpr>(E)) 12580 return DiagnoseAssignmentAsCondition(POE->getSyntacticForm()); 12581 else { 12582 // Not an assignment. 12583 return; 12584 } 12585 12586 Diag(Loc, diagnostic) << E->getSourceRange(); 12587 12588 SourceLocation Open = E->getLocStart(); 12589 SourceLocation Close = PP.getLocForEndOfToken(E->getSourceRange().getEnd()); 12590 Diag(Loc, diag::note_condition_assign_silence) 12591 << FixItHint::CreateInsertion(Open, "(") 12592 << FixItHint::CreateInsertion(Close, ")"); 12593 12594 if (IsOrAssign) 12595 Diag(Loc, diag::note_condition_or_assign_to_comparison) 12596 << FixItHint::CreateReplacement(Loc, "!="); 12597 else 12598 Diag(Loc, diag::note_condition_assign_to_comparison) 12599 << FixItHint::CreateReplacement(Loc, "=="); 12600 } 12601 12602 /// \brief Redundant parentheses over an equality comparison can indicate 12603 /// that the user intended an assignment used as condition. 12604 void Sema::DiagnoseEqualityWithExtraParens(ParenExpr *ParenE) { 12605 // Don't warn if the parens came from a macro. 12606 SourceLocation parenLoc = ParenE->getLocStart(); 12607 if (parenLoc.isInvalid() || parenLoc.isMacroID()) 12608 return; 12609 // Don't warn for dependent expressions. 12610 if (ParenE->isTypeDependent()) 12611 return; 12612 12613 Expr *E = ParenE->IgnoreParens(); 12614 12615 if (BinaryOperator *opE = dyn_cast<BinaryOperator>(E)) 12616 if (opE->getOpcode() == BO_EQ && 12617 opE->getLHS()->IgnoreParenImpCasts()->isModifiableLvalue(Context) 12618 == Expr::MLV_Valid) { 12619 SourceLocation Loc = opE->getOperatorLoc(); 12620 12621 Diag(Loc, diag::warn_equality_with_extra_parens) << E->getSourceRange(); 12622 SourceRange ParenERange = ParenE->getSourceRange(); 12623 Diag(Loc, diag::note_equality_comparison_silence) 12624 << FixItHint::CreateRemoval(ParenERange.getBegin()) 12625 << FixItHint::CreateRemoval(ParenERange.getEnd()); 12626 Diag(Loc, diag::note_equality_comparison_to_assign) 12627 << FixItHint::CreateReplacement(Loc, "="); 12628 } 12629 } 12630 12631 ExprResult Sema::CheckBooleanCondition(Expr *E, SourceLocation Loc) { 12632 DiagnoseAssignmentAsCondition(E); 12633 if (ParenExpr *parenE = dyn_cast<ParenExpr>(E)) 12634 DiagnoseEqualityWithExtraParens(parenE); 12635 12636 ExprResult result = CheckPlaceholderExpr(E); 12637 if (result.isInvalid()) return ExprError(); 12638 E = result.take(); 12639 12640 if (!E->isTypeDependent()) { 12641 if (getLangOpts().CPlusPlus) 12642 return CheckCXXBooleanCondition(E); // C++ 6.4p4 12643 12644 ExprResult ERes = DefaultFunctionArrayLvalueConversion(E); 12645 if (ERes.isInvalid()) 12646 return ExprError(); 12647 E = ERes.take(); 12648 12649 QualType T = E->getType(); 12650 if (!T->isScalarType()) { // C99 6.8.4.1p1 12651 Diag(Loc, diag::err_typecheck_statement_requires_scalar) 12652 << T << E->getSourceRange(); 12653 return ExprError(); 12654 } 12655 } 12656 12657 return Owned(E); 12658 } 12659 12660 ExprResult Sema::ActOnBooleanCondition(Scope *S, SourceLocation Loc, 12661 Expr *SubExpr) { 12662 if (!SubExpr) 12663 return ExprError(); 12664 12665 return CheckBooleanCondition(SubExpr, Loc); 12666 } 12667 12668 namespace { 12669 /// A visitor for rebuilding a call to an __unknown_any expression 12670 /// to have an appropriate type. 12671 struct RebuildUnknownAnyFunction 12672 : StmtVisitor<RebuildUnknownAnyFunction, ExprResult> { 12673 12674 Sema &S; 12675 12676 RebuildUnknownAnyFunction(Sema &S) : S(S) {} 12677 12678 ExprResult VisitStmt(Stmt *S) { 12679 llvm_unreachable("unexpected statement!"); 12680 } 12681 12682 ExprResult VisitExpr(Expr *E) { 12683 S.Diag(E->getExprLoc(), diag::err_unsupported_unknown_any_call) 12684 << E->getSourceRange(); 12685 return ExprError(); 12686 } 12687 12688 /// Rebuild an expression which simply semantically wraps another 12689 /// expression which it shares the type and value kind of. 12690 template <class T> ExprResult rebuildSugarExpr(T *E) { 12691 ExprResult SubResult = Visit(E->getSubExpr()); 12692 if (SubResult.isInvalid()) return ExprError(); 12693 12694 Expr *SubExpr = SubResult.take(); 12695 E->setSubExpr(SubExpr); 12696 E->setType(SubExpr->getType()); 12697 E->setValueKind(SubExpr->getValueKind()); 12698 assert(E->getObjectKind() == OK_Ordinary); 12699 return E; 12700 } 12701 12702 ExprResult VisitParenExpr(ParenExpr *E) { 12703 return rebuildSugarExpr(E); 12704 } 12705 12706 ExprResult VisitUnaryExtension(UnaryOperator *E) { 12707 return rebuildSugarExpr(E); 12708 } 12709 12710 ExprResult VisitUnaryAddrOf(UnaryOperator *E) { 12711 ExprResult SubResult = Visit(E->getSubExpr()); 12712 if (SubResult.isInvalid()) return ExprError(); 12713 12714 Expr *SubExpr = SubResult.take(); 12715 E->setSubExpr(SubExpr); 12716 E->setType(S.Context.getPointerType(SubExpr->getType())); 12717 assert(E->getValueKind() == VK_RValue); 12718 assert(E->getObjectKind() == OK_Ordinary); 12719 return E; 12720 } 12721 12722 ExprResult resolveDecl(Expr *E, ValueDecl *VD) { 12723 if (!isa<FunctionDecl>(VD)) return VisitExpr(E); 12724 12725 E->setType(VD->getType()); 12726 12727 assert(E->getValueKind() == VK_RValue); 12728 if (S.getLangOpts().CPlusPlus && 12729 !(isa<CXXMethodDecl>(VD) && 12730 cast<CXXMethodDecl>(VD)->isInstance())) 12731 E->setValueKind(VK_LValue); 12732 12733 return E; 12734 } 12735 12736 ExprResult VisitMemberExpr(MemberExpr *E) { 12737 return resolveDecl(E, E->getMemberDecl()); 12738 } 12739 12740 ExprResult VisitDeclRefExpr(DeclRefExpr *E) { 12741 return resolveDecl(E, E->getDecl()); 12742 } 12743 }; 12744 } 12745 12746 /// Given a function expression of unknown-any type, try to rebuild it 12747 /// to have a function type. 12748 static ExprResult rebuildUnknownAnyFunction(Sema &S, Expr *FunctionExpr) { 12749 ExprResult Result = RebuildUnknownAnyFunction(S).Visit(FunctionExpr); 12750 if (Result.isInvalid()) return ExprError(); 12751 return S.DefaultFunctionArrayConversion(Result.take()); 12752 } 12753 12754 namespace { 12755 /// A visitor for rebuilding an expression of type __unknown_anytype 12756 /// into one which resolves the type directly on the referring 12757 /// expression. Strict preservation of the original source 12758 /// structure is not a goal. 12759 struct RebuildUnknownAnyExpr 12760 : StmtVisitor<RebuildUnknownAnyExpr, ExprResult> { 12761 12762 Sema &S; 12763 12764 /// The current destination type. 12765 QualType DestType; 12766 12767 RebuildUnknownAnyExpr(Sema &S, QualType CastType) 12768 : S(S), DestType(CastType) {} 12769 12770 ExprResult VisitStmt(Stmt *S) { 12771 llvm_unreachable("unexpected statement!"); 12772 } 12773 12774 ExprResult VisitExpr(Expr *E) { 12775 S.Diag(E->getExprLoc(), diag::err_unsupported_unknown_any_expr) 12776 << E->getSourceRange(); 12777 return ExprError(); 12778 } 12779 12780 ExprResult VisitCallExpr(CallExpr *E); 12781 ExprResult VisitObjCMessageExpr(ObjCMessageExpr *E); 12782 12783 /// Rebuild an expression which simply semantically wraps another 12784 /// expression which it shares the type and value kind of. 12785 template <class T> ExprResult rebuildSugarExpr(T *E) { 12786 ExprResult SubResult = Visit(E->getSubExpr()); 12787 if (SubResult.isInvalid()) return ExprError(); 12788 Expr *SubExpr = SubResult.take(); 12789 E->setSubExpr(SubExpr); 12790 E->setType(SubExpr->getType()); 12791 E->setValueKind(SubExpr->getValueKind()); 12792 assert(E->getObjectKind() == OK_Ordinary); 12793 return E; 12794 } 12795 12796 ExprResult VisitParenExpr(ParenExpr *E) { 12797 return rebuildSugarExpr(E); 12798 } 12799 12800 ExprResult VisitUnaryExtension(UnaryOperator *E) { 12801 return rebuildSugarExpr(E); 12802 } 12803 12804 ExprResult VisitUnaryAddrOf(UnaryOperator *E) { 12805 const PointerType *Ptr = DestType->getAs<PointerType>(); 12806 if (!Ptr) { 12807 S.Diag(E->getOperatorLoc(), diag::err_unknown_any_addrof) 12808 << E->getSourceRange(); 12809 return ExprError(); 12810 } 12811 assert(E->getValueKind() == VK_RValue); 12812 assert(E->getObjectKind() == OK_Ordinary); 12813 E->setType(DestType); 12814 12815 // Build the sub-expression as if it were an object of the pointee type. 12816 DestType = Ptr->getPointeeType(); 12817 ExprResult SubResult = Visit(E->getSubExpr()); 12818 if (SubResult.isInvalid()) return ExprError(); 12819 E->setSubExpr(SubResult.take()); 12820 return E; 12821 } 12822 12823 ExprResult VisitImplicitCastExpr(ImplicitCastExpr *E); 12824 12825 ExprResult resolveDecl(Expr *E, ValueDecl *VD); 12826 12827 ExprResult VisitMemberExpr(MemberExpr *E) { 12828 return resolveDecl(E, E->getMemberDecl()); 12829 } 12830 12831 ExprResult VisitDeclRefExpr(DeclRefExpr *E) { 12832 return resolveDecl(E, E->getDecl()); 12833 } 12834 }; 12835 } 12836 12837 /// Rebuilds a call expression which yielded __unknown_anytype. 12838 ExprResult RebuildUnknownAnyExpr::VisitCallExpr(CallExpr *E) { 12839 Expr *CalleeExpr = E->getCallee(); 12840 12841 enum FnKind { 12842 FK_MemberFunction, 12843 FK_FunctionPointer, 12844 FK_BlockPointer 12845 }; 12846 12847 FnKind Kind; 12848 QualType CalleeType = CalleeExpr->getType(); 12849 if (CalleeType == S.Context.BoundMemberTy) { 12850 assert(isa<CXXMemberCallExpr>(E) || isa<CXXOperatorCallExpr>(E)); 12851 Kind = FK_MemberFunction; 12852 CalleeType = Expr::findBoundMemberType(CalleeExpr); 12853 } else if (const PointerType *Ptr = CalleeType->getAs<PointerType>()) { 12854 CalleeType = Ptr->getPointeeType(); 12855 Kind = FK_FunctionPointer; 12856 } else { 12857 CalleeType = CalleeType->castAs<BlockPointerType>()->getPointeeType(); 12858 Kind = FK_BlockPointer; 12859 } 12860 const FunctionType *FnType = CalleeType->castAs<FunctionType>(); 12861 12862 // Verify that this is a legal result type of a function. 12863 if (DestType->isArrayType() || DestType->isFunctionType()) { 12864 unsigned diagID = diag::err_func_returning_array_function; 12865 if (Kind == FK_BlockPointer) 12866 diagID = diag::err_block_returning_array_function; 12867 12868 S.Diag(E->getExprLoc(), diagID) 12869 << DestType->isFunctionType() << DestType; 12870 return ExprError(); 12871 } 12872 12873 // Otherwise, go ahead and set DestType as the call's result. 12874 E->setType(DestType.getNonLValueExprType(S.Context)); 12875 E->setValueKind(Expr::getValueKindForType(DestType)); 12876 assert(E->getObjectKind() == OK_Ordinary); 12877 12878 // Rebuild the function type, replacing the result type with DestType. 12879 const FunctionProtoType *Proto = dyn_cast<FunctionProtoType>(FnType); 12880 if (Proto) { 12881 // __unknown_anytype(...) is a special case used by the debugger when 12882 // it has no idea what a function's signature is. 12883 // 12884 // We want to build this call essentially under the K&R 12885 // unprototyped rules, but making a FunctionNoProtoType in C++ 12886 // would foul up all sorts of assumptions. However, we cannot 12887 // simply pass all arguments as variadic arguments, nor can we 12888 // portably just call the function under a non-variadic type; see 12889 // the comment on IR-gen's TargetInfo::isNoProtoCallVariadic. 12890 // However, it turns out that in practice it is generally safe to 12891 // call a function declared as "A foo(B,C,D);" under the prototype 12892 // "A foo(B,C,D,...);". The only known exception is with the 12893 // Windows ABI, where any variadic function is implicitly cdecl 12894 // regardless of its normal CC. Therefore we change the parameter 12895 // types to match the types of the arguments. 12896 // 12897 // This is a hack, but it is far superior to moving the 12898 // corresponding target-specific code from IR-gen to Sema/AST. 12899 12900 ArrayRef<QualType> ParamTypes = Proto->getArgTypes(); 12901 SmallVector<QualType, 8> ArgTypes; 12902 if (ParamTypes.empty() && Proto->isVariadic()) { // the special case 12903 ArgTypes.reserve(E->getNumArgs()); 12904 for (unsigned i = 0, e = E->getNumArgs(); i != e; ++i) { 12905 Expr *Arg = E->getArg(i); 12906 QualType ArgType = Arg->getType(); 12907 if (E->isLValue()) { 12908 ArgType = S.Context.getLValueReferenceType(ArgType); 12909 } else if (E->isXValue()) { 12910 ArgType = S.Context.getRValueReferenceType(ArgType); 12911 } 12912 ArgTypes.push_back(ArgType); 12913 } 12914 ParamTypes = ArgTypes; 12915 } 12916 DestType = S.Context.getFunctionType(DestType, ParamTypes, 12917 Proto->getExtProtoInfo()); 12918 } else { 12919 DestType = S.Context.getFunctionNoProtoType(DestType, 12920 FnType->getExtInfo()); 12921 } 12922 12923 // Rebuild the appropriate pointer-to-function type. 12924 switch (Kind) { 12925 case FK_MemberFunction: 12926 // Nothing to do. 12927 break; 12928 12929 case FK_FunctionPointer: 12930 DestType = S.Context.getPointerType(DestType); 12931 break; 12932 12933 case FK_BlockPointer: 12934 DestType = S.Context.getBlockPointerType(DestType); 12935 break; 12936 } 12937 12938 // Finally, we can recurse. 12939 ExprResult CalleeResult = Visit(CalleeExpr); 12940 if (!CalleeResult.isUsable()) return ExprError(); 12941 E->setCallee(CalleeResult.take()); 12942 12943 // Bind a temporary if necessary. 12944 return S.MaybeBindToTemporary(E); 12945 } 12946 12947 ExprResult RebuildUnknownAnyExpr::VisitObjCMessageExpr(ObjCMessageExpr *E) { 12948 // Verify that this is a legal result type of a call. 12949 if (DestType->isArrayType() || DestType->isFunctionType()) { 12950 S.Diag(E->getExprLoc(), diag::err_func_returning_array_function) 12951 << DestType->isFunctionType() << DestType; 12952 return ExprError(); 12953 } 12954 12955 // Rewrite the method result type if available. 12956 if (ObjCMethodDecl *Method = E->getMethodDecl()) { 12957 assert(Method->getResultType() == S.Context.UnknownAnyTy); 12958 Method->setResultType(DestType); 12959 } 12960 12961 // Change the type of the message. 12962 E->setType(DestType.getNonReferenceType()); 12963 E->setValueKind(Expr::getValueKindForType(DestType)); 12964 12965 return S.MaybeBindToTemporary(E); 12966 } 12967 12968 ExprResult RebuildUnknownAnyExpr::VisitImplicitCastExpr(ImplicitCastExpr *E) { 12969 // The only case we should ever see here is a function-to-pointer decay. 12970 if (E->getCastKind() == CK_FunctionToPointerDecay) { 12971 assert(E->getValueKind() == VK_RValue); 12972 assert(E->getObjectKind() == OK_Ordinary); 12973 12974 E->setType(DestType); 12975 12976 // Rebuild the sub-expression as the pointee (function) type. 12977 DestType = DestType->castAs<PointerType>()->getPointeeType(); 12978 12979 ExprResult Result = Visit(E->getSubExpr()); 12980 if (!Result.isUsable()) return ExprError(); 12981 12982 E->setSubExpr(Result.take()); 12983 return S.Owned(E); 12984 } else if (E->getCastKind() == CK_LValueToRValue) { 12985 assert(E->getValueKind() == VK_RValue); 12986 assert(E->getObjectKind() == OK_Ordinary); 12987 12988 assert(isa<BlockPointerType>(E->getType())); 12989 12990 E->setType(DestType); 12991 12992 // The sub-expression has to be a lvalue reference, so rebuild it as such. 12993 DestType = S.Context.getLValueReferenceType(DestType); 12994 12995 ExprResult Result = Visit(E->getSubExpr()); 12996 if (!Result.isUsable()) return ExprError(); 12997 12998 E->setSubExpr(Result.take()); 12999 return S.Owned(E); 13000 } else { 13001 llvm_unreachable("Unhandled cast type!"); 13002 } 13003 } 13004 13005 ExprResult RebuildUnknownAnyExpr::resolveDecl(Expr *E, ValueDecl *VD) { 13006 ExprValueKind ValueKind = VK_LValue; 13007 QualType Type = DestType; 13008 13009 // We know how to make this work for certain kinds of decls: 13010 13011 // - functions 13012 if (FunctionDecl *FD = dyn_cast<FunctionDecl>(VD)) { 13013 if (const PointerType *Ptr = Type->getAs<PointerType>()) { 13014 DestType = Ptr->getPointeeType(); 13015 ExprResult Result = resolveDecl(E, VD); 13016 if (Result.isInvalid()) return ExprError(); 13017 return S.ImpCastExprToType(Result.take(), Type, 13018 CK_FunctionToPointerDecay, VK_RValue); 13019 } 13020 13021 if (!Type->isFunctionType()) { 13022 S.Diag(E->getExprLoc(), diag::err_unknown_any_function) 13023 << VD << E->getSourceRange(); 13024 return ExprError(); 13025 } 13026 13027 if (CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(FD)) 13028 if (MD->isInstance()) { 13029 ValueKind = VK_RValue; 13030 Type = S.Context.BoundMemberTy; 13031 } 13032 13033 // Function references aren't l-values in C. 13034 if (!S.getLangOpts().CPlusPlus) 13035 ValueKind = VK_RValue; 13036 13037 // - variables 13038 } else if (isa<VarDecl>(VD)) { 13039 if (const ReferenceType *RefTy = Type->getAs<ReferenceType>()) { 13040 Type = RefTy->getPointeeType(); 13041 } else if (Type->isFunctionType()) { 13042 S.Diag(E->getExprLoc(), diag::err_unknown_any_var_function_type) 13043 << VD << E->getSourceRange(); 13044 return ExprError(); 13045 } 13046 13047 // - nothing else 13048 } else { 13049 S.Diag(E->getExprLoc(), diag::err_unsupported_unknown_any_decl) 13050 << VD << E->getSourceRange(); 13051 return ExprError(); 13052 } 13053 13054 // Modifying the declaration like this is friendly to IR-gen but 13055 // also really dangerous. 13056 VD->setType(DestType); 13057 E->setType(Type); 13058 E->setValueKind(ValueKind); 13059 return S.Owned(E); 13060 } 13061 13062 /// Check a cast of an unknown-any type. We intentionally only 13063 /// trigger this for C-style casts. 13064 ExprResult Sema::checkUnknownAnyCast(SourceRange TypeRange, QualType CastType, 13065 Expr *CastExpr, CastKind &CastKind, 13066 ExprValueKind &VK, CXXCastPath &Path) { 13067 // Rewrite the casted expression from scratch. 13068 ExprResult result = RebuildUnknownAnyExpr(*this, CastType).Visit(CastExpr); 13069 if (!result.isUsable()) return ExprError(); 13070 13071 CastExpr = result.take(); 13072 VK = CastExpr->getValueKind(); 13073 CastKind = CK_NoOp; 13074 13075 return CastExpr; 13076 } 13077 13078 ExprResult Sema::forceUnknownAnyToType(Expr *E, QualType ToType) { 13079 return RebuildUnknownAnyExpr(*this, ToType).Visit(E); 13080 } 13081 13082 ExprResult Sema::checkUnknownAnyArg(SourceLocation callLoc, 13083 Expr *arg, QualType ¶mType) { 13084 // If the syntactic form of the argument is not an explicit cast of 13085 // any sort, just do default argument promotion. 13086 ExplicitCastExpr *castArg = dyn_cast<ExplicitCastExpr>(arg->IgnoreParens()); 13087 if (!castArg) { 13088 ExprResult result = DefaultArgumentPromotion(arg); 13089 if (result.isInvalid()) return ExprError(); 13090 paramType = result.get()->getType(); 13091 return result; 13092 } 13093 13094 // Otherwise, use the type that was written in the explicit cast. 13095 assert(!arg->hasPlaceholderType()); 13096 paramType = castArg->getTypeAsWritten(); 13097 13098 // Copy-initialize a parameter of that type. 13099 InitializedEntity entity = 13100 InitializedEntity::InitializeParameter(Context, paramType, 13101 /*consumed*/ false); 13102 return PerformCopyInitialization(entity, callLoc, Owned(arg)); 13103 } 13104 13105 static ExprResult diagnoseUnknownAnyExpr(Sema &S, Expr *E) { 13106 Expr *orig = E; 13107 unsigned diagID = diag::err_uncasted_use_of_unknown_any; 13108 while (true) { 13109 E = E->IgnoreParenImpCasts(); 13110 if (CallExpr *call = dyn_cast<CallExpr>(E)) { 13111 E = call->getCallee(); 13112 diagID = diag::err_uncasted_call_of_unknown_any; 13113 } else { 13114 break; 13115 } 13116 } 13117 13118 SourceLocation loc; 13119 NamedDecl *d; 13120 if (DeclRefExpr *ref = dyn_cast<DeclRefExpr>(E)) { 13121 loc = ref->getLocation(); 13122 d = ref->getDecl(); 13123 } else if (MemberExpr *mem = dyn_cast<MemberExpr>(E)) { 13124 loc = mem->getMemberLoc(); 13125 d = mem->getMemberDecl(); 13126 } else if (ObjCMessageExpr *msg = dyn_cast<ObjCMessageExpr>(E)) { 13127 diagID = diag::err_uncasted_call_of_unknown_any; 13128 loc = msg->getSelectorStartLoc(); 13129 d = msg->getMethodDecl(); 13130 if (!d) { 13131 S.Diag(loc, diag::err_uncasted_send_to_unknown_any_method) 13132 << static_cast<unsigned>(msg->isClassMessage()) << msg->getSelector() 13133 << orig->getSourceRange(); 13134 return ExprError(); 13135 } 13136 } else { 13137 S.Diag(E->getExprLoc(), diag::err_unsupported_unknown_any_expr) 13138 << E->getSourceRange(); 13139 return ExprError(); 13140 } 13141 13142 S.Diag(loc, diagID) << d << orig->getSourceRange(); 13143 13144 // Never recoverable. 13145 return ExprError(); 13146 } 13147 13148 /// Check for operands with placeholder types and complain if found. 13149 /// Returns true if there was an error and no recovery was possible. 13150 ExprResult Sema::CheckPlaceholderExpr(Expr *E) { 13151 const BuiltinType *placeholderType = E->getType()->getAsPlaceholderType(); 13152 if (!placeholderType) return Owned(E); 13153 13154 switch (placeholderType->getKind()) { 13155 13156 // Overloaded expressions. 13157 case BuiltinType::Overload: { 13158 // Try to resolve a single function template specialization. 13159 // This is obligatory. 13160 ExprResult result = Owned(E); 13161 if (ResolveAndFixSingleFunctionTemplateSpecialization(result, false)) { 13162 return result; 13163 13164 // If that failed, try to recover with a call. 13165 } else { 13166 tryToRecoverWithCall(result, PDiag(diag::err_ovl_unresolvable), 13167 /*complain*/ true); 13168 return result; 13169 } 13170 } 13171 13172 // Bound member functions. 13173 case BuiltinType::BoundMember: { 13174 ExprResult result = Owned(E); 13175 tryToRecoverWithCall(result, PDiag(diag::err_bound_member_function), 13176 /*complain*/ true); 13177 return result; 13178 } 13179 13180 // ARC unbridged casts. 13181 case BuiltinType::ARCUnbridgedCast: { 13182 Expr *realCast = stripARCUnbridgedCast(E); 13183 diagnoseARCUnbridgedCast(realCast); 13184 return Owned(realCast); 13185 } 13186 13187 // Expressions of unknown type. 13188 case BuiltinType::UnknownAny: 13189 return diagnoseUnknownAnyExpr(*this, E); 13190 13191 // Pseudo-objects. 13192 case BuiltinType::PseudoObject: 13193 return checkPseudoObjectRValue(E); 13194 13195 case BuiltinType::BuiltinFn: 13196 Diag(E->getLocStart(), diag::err_builtin_fn_use); 13197 return ExprError(); 13198 13199 // Everything else should be impossible. 13200 #define BUILTIN_TYPE(Id, SingletonId) \ 13201 case BuiltinType::Id: 13202 #define PLACEHOLDER_TYPE(Id, SingletonId) 13203 #include "clang/AST/BuiltinTypes.def" 13204 break; 13205 } 13206 13207 llvm_unreachable("invalid placeholder type!"); 13208 } 13209 13210 bool Sema::CheckCaseExpression(Expr *E) { 13211 if (E->isTypeDependent()) 13212 return true; 13213 if (E->isValueDependent() || E->isIntegerConstantExpr(Context)) 13214 return E->getType()->isIntegralOrEnumerationType(); 13215 return false; 13216 } 13217 13218 /// ActOnObjCBoolLiteral - Parse {__objc_yes,__objc_no} literals. 13219 ExprResult 13220 Sema::ActOnObjCBoolLiteral(SourceLocation OpLoc, tok::TokenKind Kind) { 13221 assert((Kind == tok::kw___objc_yes || Kind == tok::kw___objc_no) && 13222 "Unknown Objective-C Boolean value!"); 13223 QualType BoolT = Context.ObjCBuiltinBoolTy; 13224 if (!Context.getBOOLDecl()) { 13225 LookupResult Result(*this, &Context.Idents.get("BOOL"), OpLoc, 13226 Sema::LookupOrdinaryName); 13227 if (LookupName(Result, getCurScope()) && Result.isSingleResult()) { 13228 NamedDecl *ND = Result.getFoundDecl(); 13229 if (TypedefDecl *TD = dyn_cast<TypedefDecl>(ND)) 13230 Context.setBOOLDecl(TD); 13231 } 13232 } 13233 if (Context.getBOOLDecl()) 13234 BoolT = Context.getBOOLType(); 13235 return Owned(new (Context) ObjCBoolLiteralExpr(Kind == tok::kw___objc_yes, 13236 BoolT, OpLoc)); 13237 } 13238