1 //===--- Type.cpp - Type representation and manipulation ------------------===// 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 type-related functionality. 11 // 12 //===----------------------------------------------------------------------===// 13 14 #include "clang/AST/ASTContext.h" 15 #include "clang/AST/CharUnits.h" 16 #include "clang/AST/Type.h" 17 #include "clang/AST/DeclCXX.h" 18 #include "clang/AST/DeclObjC.h" 19 #include "clang/AST/DeclTemplate.h" 20 #include "clang/AST/Expr.h" 21 #include "clang/AST/PrettyPrinter.h" 22 #include "clang/AST/TypeVisitor.h" 23 #include "clang/Basic/Specifiers.h" 24 #include "llvm/ADT/APSInt.h" 25 #include "llvm/ADT/StringExtras.h" 26 #include "llvm/Support/raw_ostream.h" 27 #include <algorithm> 28 using namespace clang; 29 30 bool Qualifiers::isStrictSupersetOf(Qualifiers Other) const { 31 return (*this != Other) && 32 // CVR qualifiers superset 33 (((Mask & CVRMask) | (Other.Mask & CVRMask)) == (Mask & CVRMask)) && 34 // ObjC GC qualifiers superset 35 ((getObjCGCAttr() == Other.getObjCGCAttr()) || 36 (hasObjCGCAttr() && !Other.hasObjCGCAttr())) && 37 // Address space superset. 38 ((getAddressSpace() == Other.getAddressSpace()) || 39 (hasAddressSpace()&& !Other.hasAddressSpace())) && 40 // Lifetime qualifier superset. 41 ((getObjCLifetime() == Other.getObjCLifetime()) || 42 (hasObjCLifetime() && !Other.hasObjCLifetime())); 43 } 44 45 const IdentifierInfo* QualType::getBaseTypeIdentifier() const { 46 const Type* ty = getTypePtr(); 47 NamedDecl *ND = NULL; 48 if (ty->isPointerType() || ty->isReferenceType()) 49 return ty->getPointeeType().getBaseTypeIdentifier(); 50 else if (ty->isRecordType()) 51 ND = ty->getAs<RecordType>()->getDecl(); 52 else if (ty->isEnumeralType()) 53 ND = ty->getAs<EnumType>()->getDecl(); 54 else if (ty->getTypeClass() == Type::Typedef) 55 ND = ty->getAs<TypedefType>()->getDecl(); 56 else if (ty->isArrayType()) 57 return ty->castAsArrayTypeUnsafe()-> 58 getElementType().getBaseTypeIdentifier(); 59 60 if (ND) 61 return ND->getIdentifier(); 62 return NULL; 63 } 64 65 bool QualType::isConstant(QualType T, ASTContext &Ctx) { 66 if (T.isConstQualified()) 67 return true; 68 69 if (const ArrayType *AT = Ctx.getAsArrayType(T)) 70 return AT->getElementType().isConstant(Ctx); 71 72 return false; 73 } 74 75 unsigned ConstantArrayType::getNumAddressingBits(ASTContext &Context, 76 QualType ElementType, 77 const llvm::APInt &NumElements) { 78 llvm::APSInt SizeExtended(NumElements, true); 79 unsigned SizeTypeBits = Context.getTypeSize(Context.getSizeType()); 80 SizeExtended = SizeExtended.extend(std::max(SizeTypeBits, 81 SizeExtended.getBitWidth()) * 2); 82 83 uint64_t ElementSize 84 = Context.getTypeSizeInChars(ElementType).getQuantity(); 85 llvm::APSInt TotalSize(llvm::APInt(SizeExtended.getBitWidth(), ElementSize)); 86 TotalSize *= SizeExtended; 87 88 return TotalSize.getActiveBits(); 89 } 90 91 unsigned ConstantArrayType::getMaxSizeBits(ASTContext &Context) { 92 unsigned Bits = Context.getTypeSize(Context.getSizeType()); 93 94 // GCC appears to only allow 63 bits worth of address space when compiling 95 // for 64-bit, so we do the same. 96 if (Bits == 64) 97 --Bits; 98 99 return Bits; 100 } 101 102 DependentSizedArrayType::DependentSizedArrayType(const ASTContext &Context, 103 QualType et, QualType can, 104 Expr *e, ArraySizeModifier sm, 105 unsigned tq, 106 SourceRange brackets) 107 : ArrayType(DependentSizedArray, et, can, sm, tq, 108 (et->containsUnexpandedParameterPack() || 109 (e && e->containsUnexpandedParameterPack()))), 110 Context(Context), SizeExpr((Stmt*) e), Brackets(brackets) 111 { 112 } 113 114 void DependentSizedArrayType::Profile(llvm::FoldingSetNodeID &ID, 115 const ASTContext &Context, 116 QualType ET, 117 ArraySizeModifier SizeMod, 118 unsigned TypeQuals, 119 Expr *E) { 120 ID.AddPointer(ET.getAsOpaquePtr()); 121 ID.AddInteger(SizeMod); 122 ID.AddInteger(TypeQuals); 123 E->Profile(ID, Context, true); 124 } 125 126 DependentSizedExtVectorType::DependentSizedExtVectorType(const 127 ASTContext &Context, 128 QualType ElementType, 129 QualType can, 130 Expr *SizeExpr, 131 SourceLocation loc) 132 : Type(DependentSizedExtVector, can, /*Dependent=*/true, 133 /*InstantiationDependent=*/true, 134 ElementType->isVariablyModifiedType(), 135 (ElementType->containsUnexpandedParameterPack() || 136 (SizeExpr && SizeExpr->containsUnexpandedParameterPack()))), 137 Context(Context), SizeExpr(SizeExpr), ElementType(ElementType), 138 loc(loc) 139 { 140 } 141 142 void 143 DependentSizedExtVectorType::Profile(llvm::FoldingSetNodeID &ID, 144 const ASTContext &Context, 145 QualType ElementType, Expr *SizeExpr) { 146 ID.AddPointer(ElementType.getAsOpaquePtr()); 147 SizeExpr->Profile(ID, Context, true); 148 } 149 150 VectorType::VectorType(QualType vecType, unsigned nElements, QualType canonType, 151 VectorKind vecKind) 152 : Type(Vector, canonType, vecType->isDependentType(), 153 vecType->isInstantiationDependentType(), 154 vecType->isVariablyModifiedType(), 155 vecType->containsUnexpandedParameterPack()), 156 ElementType(vecType) 157 { 158 VectorTypeBits.VecKind = vecKind; 159 VectorTypeBits.NumElements = nElements; 160 } 161 162 VectorType::VectorType(TypeClass tc, QualType vecType, unsigned nElements, 163 QualType canonType, VectorKind vecKind) 164 : Type(tc, canonType, vecType->isDependentType(), 165 vecType->isInstantiationDependentType(), 166 vecType->isVariablyModifiedType(), 167 vecType->containsUnexpandedParameterPack()), 168 ElementType(vecType) 169 { 170 VectorTypeBits.VecKind = vecKind; 171 VectorTypeBits.NumElements = nElements; 172 } 173 174 /// getArrayElementTypeNoTypeQual - If this is an array type, return the 175 /// element type of the array, potentially with type qualifiers missing. 176 /// This method should never be used when type qualifiers are meaningful. 177 const Type *Type::getArrayElementTypeNoTypeQual() const { 178 // If this is directly an array type, return it. 179 if (const ArrayType *ATy = dyn_cast<ArrayType>(this)) 180 return ATy->getElementType().getTypePtr(); 181 182 // If the canonical form of this type isn't the right kind, reject it. 183 if (!isa<ArrayType>(CanonicalType)) 184 return 0; 185 186 // If this is a typedef for an array type, strip the typedef off without 187 // losing all typedef information. 188 return cast<ArrayType>(getUnqualifiedDesugaredType()) 189 ->getElementType().getTypePtr(); 190 } 191 192 /// getDesugaredType - Return the specified type with any "sugar" removed from 193 /// the type. This takes off typedefs, typeof's etc. If the outer level of 194 /// the type is already concrete, it returns it unmodified. This is similar 195 /// to getting the canonical type, but it doesn't remove *all* typedefs. For 196 /// example, it returns "T*" as "T*", (not as "int*"), because the pointer is 197 /// concrete. 198 QualType QualType::getDesugaredType(QualType T, const ASTContext &Context) { 199 SplitQualType split = getSplitDesugaredType(T); 200 return Context.getQualifiedType(split.first, split.second); 201 } 202 203 QualType QualType::getSingleStepDesugaredType(const ASTContext &Context) const { 204 QualifierCollector Qs; 205 206 const Type *CurTy = Qs.strip(*this); 207 switch (CurTy->getTypeClass()) { 208 #define ABSTRACT_TYPE(Class, Parent) 209 #define TYPE(Class, Parent) \ 210 case Type::Class: { \ 211 const Class##Type *Ty = cast<Class##Type>(CurTy); \ 212 if (!Ty->isSugared()) \ 213 return *this; \ 214 return Context.getQualifiedType(Ty->desugar(), Qs); \ 215 break; \ 216 } 217 #include "clang/AST/TypeNodes.def" 218 } 219 220 return *this; 221 } 222 223 SplitQualType QualType::getSplitDesugaredType(QualType T) { 224 QualifierCollector Qs; 225 226 QualType Cur = T; 227 while (true) { 228 const Type *CurTy = Qs.strip(Cur); 229 switch (CurTy->getTypeClass()) { 230 #define ABSTRACT_TYPE(Class, Parent) 231 #define TYPE(Class, Parent) \ 232 case Type::Class: { \ 233 const Class##Type *Ty = cast<Class##Type>(CurTy); \ 234 if (!Ty->isSugared()) \ 235 return SplitQualType(Ty, Qs); \ 236 Cur = Ty->desugar(); \ 237 break; \ 238 } 239 #include "clang/AST/TypeNodes.def" 240 } 241 } 242 } 243 244 SplitQualType QualType::getSplitUnqualifiedTypeImpl(QualType type) { 245 SplitQualType split = type.split(); 246 247 // All the qualifiers we've seen so far. 248 Qualifiers quals = split.second; 249 250 // The last type node we saw with any nodes inside it. 251 const Type *lastTypeWithQuals = split.first; 252 253 while (true) { 254 QualType next; 255 256 // Do a single-step desugar, aborting the loop if the type isn't 257 // sugared. 258 switch (split.first->getTypeClass()) { 259 #define ABSTRACT_TYPE(Class, Parent) 260 #define TYPE(Class, Parent) \ 261 case Type::Class: { \ 262 const Class##Type *ty = cast<Class##Type>(split.first); \ 263 if (!ty->isSugared()) goto done; \ 264 next = ty->desugar(); \ 265 break; \ 266 } 267 #include "clang/AST/TypeNodes.def" 268 } 269 270 // Otherwise, split the underlying type. If that yields qualifiers, 271 // update the information. 272 split = next.split(); 273 if (!split.second.empty()) { 274 lastTypeWithQuals = split.first; 275 quals.addConsistentQualifiers(split.second); 276 } 277 } 278 279 done: 280 return SplitQualType(lastTypeWithQuals, quals); 281 } 282 283 QualType QualType::IgnoreParens(QualType T) { 284 // FIXME: this seems inherently un-qualifiers-safe. 285 while (const ParenType *PT = T->getAs<ParenType>()) 286 T = PT->getInnerType(); 287 return T; 288 } 289 290 /// getUnqualifiedDesugaredType - Pull any qualifiers and syntactic 291 /// sugar off the given type. This should produce an object of the 292 /// same dynamic type as the canonical type. 293 const Type *Type::getUnqualifiedDesugaredType() const { 294 const Type *Cur = this; 295 296 while (true) { 297 switch (Cur->getTypeClass()) { 298 #define ABSTRACT_TYPE(Class, Parent) 299 #define TYPE(Class, Parent) \ 300 case Class: { \ 301 const Class##Type *Ty = cast<Class##Type>(Cur); \ 302 if (!Ty->isSugared()) return Cur; \ 303 Cur = Ty->desugar().getTypePtr(); \ 304 break; \ 305 } 306 #include "clang/AST/TypeNodes.def" 307 } 308 } 309 } 310 311 /// isVoidType - Helper method to determine if this is the 'void' type. 312 bool Type::isVoidType() const { 313 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 314 return BT->getKind() == BuiltinType::Void; 315 return false; 316 } 317 318 bool Type::isDerivedType() const { 319 switch (CanonicalType->getTypeClass()) { 320 case Pointer: 321 case VariableArray: 322 case ConstantArray: 323 case IncompleteArray: 324 case FunctionProto: 325 case FunctionNoProto: 326 case LValueReference: 327 case RValueReference: 328 case Record: 329 return true; 330 default: 331 return false; 332 } 333 } 334 bool Type::isClassType() const { 335 if (const RecordType *RT = getAs<RecordType>()) 336 return RT->getDecl()->isClass(); 337 return false; 338 } 339 bool Type::isStructureType() const { 340 if (const RecordType *RT = getAs<RecordType>()) 341 return RT->getDecl()->isStruct(); 342 return false; 343 } 344 bool Type::isStructureOrClassType() const { 345 if (const RecordType *RT = getAs<RecordType>()) 346 return RT->getDecl()->isStruct() || RT->getDecl()->isClass(); 347 return false; 348 } 349 bool Type::isVoidPointerType() const { 350 if (const PointerType *PT = getAs<PointerType>()) 351 return PT->getPointeeType()->isVoidType(); 352 return false; 353 } 354 355 bool Type::isUnionType() const { 356 if (const RecordType *RT = getAs<RecordType>()) 357 return RT->getDecl()->isUnion(); 358 return false; 359 } 360 361 bool Type::isComplexType() const { 362 if (const ComplexType *CT = dyn_cast<ComplexType>(CanonicalType)) 363 return CT->getElementType()->isFloatingType(); 364 return false; 365 } 366 367 bool Type::isComplexIntegerType() const { 368 // Check for GCC complex integer extension. 369 return getAsComplexIntegerType(); 370 } 371 372 const ComplexType *Type::getAsComplexIntegerType() const { 373 if (const ComplexType *Complex = getAs<ComplexType>()) 374 if (Complex->getElementType()->isIntegerType()) 375 return Complex; 376 return 0; 377 } 378 379 QualType Type::getPointeeType() const { 380 if (const PointerType *PT = getAs<PointerType>()) 381 return PT->getPointeeType(); 382 if (const ObjCObjectPointerType *OPT = getAs<ObjCObjectPointerType>()) 383 return OPT->getPointeeType(); 384 if (const BlockPointerType *BPT = getAs<BlockPointerType>()) 385 return BPT->getPointeeType(); 386 if (const ReferenceType *RT = getAs<ReferenceType>()) 387 return RT->getPointeeType(); 388 return QualType(); 389 } 390 391 const RecordType *Type::getAsStructureType() const { 392 // If this is directly a structure type, return it. 393 if (const RecordType *RT = dyn_cast<RecordType>(this)) { 394 if (RT->getDecl()->isStruct()) 395 return RT; 396 } 397 398 // If the canonical form of this type isn't the right kind, reject it. 399 if (const RecordType *RT = dyn_cast<RecordType>(CanonicalType)) { 400 if (!RT->getDecl()->isStruct()) 401 return 0; 402 403 // If this is a typedef for a structure type, strip the typedef off without 404 // losing all typedef information. 405 return cast<RecordType>(getUnqualifiedDesugaredType()); 406 } 407 return 0; 408 } 409 410 const RecordType *Type::getAsUnionType() const { 411 // If this is directly a union type, return it. 412 if (const RecordType *RT = dyn_cast<RecordType>(this)) { 413 if (RT->getDecl()->isUnion()) 414 return RT; 415 } 416 417 // If the canonical form of this type isn't the right kind, reject it. 418 if (const RecordType *RT = dyn_cast<RecordType>(CanonicalType)) { 419 if (!RT->getDecl()->isUnion()) 420 return 0; 421 422 // If this is a typedef for a union type, strip the typedef off without 423 // losing all typedef information. 424 return cast<RecordType>(getUnqualifiedDesugaredType()); 425 } 426 427 return 0; 428 } 429 430 ObjCObjectType::ObjCObjectType(QualType Canonical, QualType Base, 431 ObjCProtocolDecl * const *Protocols, 432 unsigned NumProtocols) 433 : Type(ObjCObject, Canonical, false, false, false, false), 434 BaseType(Base) 435 { 436 ObjCObjectTypeBits.NumProtocols = NumProtocols; 437 assert(getNumProtocols() == NumProtocols && 438 "bitfield overflow in protocol count"); 439 if (NumProtocols) 440 memcpy(getProtocolStorage(), Protocols, 441 NumProtocols * sizeof(ObjCProtocolDecl*)); 442 } 443 444 const ObjCObjectType *Type::getAsObjCQualifiedInterfaceType() const { 445 // There is no sugar for ObjCObjectType's, just return the canonical 446 // type pointer if it is the right class. There is no typedef information to 447 // return and these cannot be Address-space qualified. 448 if (const ObjCObjectType *T = getAs<ObjCObjectType>()) 449 if (T->getNumProtocols() && T->getInterface()) 450 return T; 451 return 0; 452 } 453 454 bool Type::isObjCQualifiedInterfaceType() const { 455 return getAsObjCQualifiedInterfaceType() != 0; 456 } 457 458 const ObjCObjectPointerType *Type::getAsObjCQualifiedIdType() const { 459 // There is no sugar for ObjCQualifiedIdType's, just return the canonical 460 // type pointer if it is the right class. 461 if (const ObjCObjectPointerType *OPT = getAs<ObjCObjectPointerType>()) { 462 if (OPT->isObjCQualifiedIdType()) 463 return OPT; 464 } 465 return 0; 466 } 467 468 const ObjCObjectPointerType *Type::getAsObjCQualifiedClassType() const { 469 // There is no sugar for ObjCQualifiedClassType's, just return the canonical 470 // type pointer if it is the right class. 471 if (const ObjCObjectPointerType *OPT = getAs<ObjCObjectPointerType>()) { 472 if (OPT->isObjCQualifiedClassType()) 473 return OPT; 474 } 475 return 0; 476 } 477 478 const ObjCObjectPointerType *Type::getAsObjCInterfacePointerType() const { 479 if (const ObjCObjectPointerType *OPT = getAs<ObjCObjectPointerType>()) { 480 if (OPT->getInterfaceType()) 481 return OPT; 482 } 483 return 0; 484 } 485 486 const CXXRecordDecl *Type::getCXXRecordDeclForPointerType() const { 487 if (const PointerType *PT = getAs<PointerType>()) 488 if (const RecordType *RT = PT->getPointeeType()->getAs<RecordType>()) 489 return dyn_cast<CXXRecordDecl>(RT->getDecl()); 490 return 0; 491 } 492 493 CXXRecordDecl *Type::getAsCXXRecordDecl() const { 494 if (const RecordType *RT = getAs<RecordType>()) 495 return dyn_cast<CXXRecordDecl>(RT->getDecl()); 496 else if (const InjectedClassNameType *Injected 497 = getAs<InjectedClassNameType>()) 498 return Injected->getDecl(); 499 500 return 0; 501 } 502 503 namespace { 504 class GetContainedAutoVisitor : 505 public TypeVisitor<GetContainedAutoVisitor, AutoType*> { 506 public: 507 using TypeVisitor<GetContainedAutoVisitor, AutoType*>::Visit; 508 AutoType *Visit(QualType T) { 509 if (T.isNull()) 510 return 0; 511 return Visit(T.getTypePtr()); 512 } 513 514 // The 'auto' type itself. 515 AutoType *VisitAutoType(const AutoType *AT) { 516 return const_cast<AutoType*>(AT); 517 } 518 519 // Only these types can contain the desired 'auto' type. 520 AutoType *VisitPointerType(const PointerType *T) { 521 return Visit(T->getPointeeType()); 522 } 523 AutoType *VisitBlockPointerType(const BlockPointerType *T) { 524 return Visit(T->getPointeeType()); 525 } 526 AutoType *VisitReferenceType(const ReferenceType *T) { 527 return Visit(T->getPointeeTypeAsWritten()); 528 } 529 AutoType *VisitMemberPointerType(const MemberPointerType *T) { 530 return Visit(T->getPointeeType()); 531 } 532 AutoType *VisitArrayType(const ArrayType *T) { 533 return Visit(T->getElementType()); 534 } 535 AutoType *VisitDependentSizedExtVectorType( 536 const DependentSizedExtVectorType *T) { 537 return Visit(T->getElementType()); 538 } 539 AutoType *VisitVectorType(const VectorType *T) { 540 return Visit(T->getElementType()); 541 } 542 AutoType *VisitFunctionType(const FunctionType *T) { 543 return Visit(T->getResultType()); 544 } 545 AutoType *VisitParenType(const ParenType *T) { 546 return Visit(T->getInnerType()); 547 } 548 AutoType *VisitAttributedType(const AttributedType *T) { 549 return Visit(T->getModifiedType()); 550 } 551 }; 552 } 553 554 AutoType *Type::getContainedAutoType() const { 555 return GetContainedAutoVisitor().Visit(this); 556 } 557 558 bool Type::isIntegerType() const { 559 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 560 return BT->getKind() >= BuiltinType::Bool && 561 BT->getKind() <= BuiltinType::Int128; 562 if (const EnumType *ET = dyn_cast<EnumType>(CanonicalType)) 563 // Incomplete enum types are not treated as integer types. 564 // FIXME: In C++, enum types are never integer types. 565 return ET->getDecl()->isComplete() && !ET->getDecl()->isScoped(); 566 return false; 567 } 568 569 bool Type::hasIntegerRepresentation() const { 570 if (const VectorType *VT = dyn_cast<VectorType>(CanonicalType)) 571 return VT->getElementType()->isIntegerType(); 572 else 573 return isIntegerType(); 574 } 575 576 /// \brief Determine whether this type is an integral type. 577 /// 578 /// This routine determines whether the given type is an integral type per 579 /// C++ [basic.fundamental]p7. Although the C standard does not define the 580 /// term "integral type", it has a similar term "integer type", and in C++ 581 /// the two terms are equivalent. However, C's "integer type" includes 582 /// enumeration types, while C++'s "integer type" does not. The \c ASTContext 583 /// parameter is used to determine whether we should be following the C or 584 /// C++ rules when determining whether this type is an integral/integer type. 585 /// 586 /// For cases where C permits "an integer type" and C++ permits "an integral 587 /// type", use this routine. 588 /// 589 /// For cases where C permits "an integer type" and C++ permits "an integral 590 /// or enumeration type", use \c isIntegralOrEnumerationType() instead. 591 /// 592 /// \param Ctx The context in which this type occurs. 593 /// 594 /// \returns true if the type is considered an integral type, false otherwise. 595 bool Type::isIntegralType(ASTContext &Ctx) const { 596 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 597 return BT->getKind() >= BuiltinType::Bool && 598 BT->getKind() <= BuiltinType::Int128; 599 600 if (!Ctx.getLangOptions().CPlusPlus) 601 if (const EnumType *ET = dyn_cast<EnumType>(CanonicalType)) 602 return ET->getDecl()->isComplete(); // Complete enum types are integral in C. 603 604 return false; 605 } 606 607 bool Type::isIntegralOrEnumerationType() const { 608 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 609 return BT->getKind() >= BuiltinType::Bool && 610 BT->getKind() <= BuiltinType::Int128; 611 612 // Check for a complete enum type; incomplete enum types are not properly an 613 // enumeration type in the sense required here. 614 if (const EnumType *ET = dyn_cast<EnumType>(CanonicalType)) 615 return ET->getDecl()->isComplete(); 616 617 return false; 618 } 619 620 bool Type::isIntegralOrUnscopedEnumerationType() const { 621 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 622 return BT->getKind() >= BuiltinType::Bool && 623 BT->getKind() <= BuiltinType::Int128; 624 625 // Check for a complete enum type; incomplete enum types are not properly an 626 // enumeration type in the sense required here. 627 // C++0x: However, if the underlying type of the enum is fixed, it is 628 // considered complete. 629 if (const EnumType *ET = dyn_cast<EnumType>(CanonicalType)) 630 return ET->getDecl()->isComplete() && !ET->getDecl()->isScoped(); 631 632 return false; 633 } 634 635 636 bool Type::isBooleanType() const { 637 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 638 return BT->getKind() == BuiltinType::Bool; 639 return false; 640 } 641 642 bool Type::isCharType() const { 643 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 644 return BT->getKind() == BuiltinType::Char_U || 645 BT->getKind() == BuiltinType::UChar || 646 BT->getKind() == BuiltinType::Char_S || 647 BT->getKind() == BuiltinType::SChar; 648 return false; 649 } 650 651 bool Type::isWideCharType() const { 652 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 653 return BT->getKind() == BuiltinType::WChar_S || 654 BT->getKind() == BuiltinType::WChar_U; 655 return false; 656 } 657 658 bool Type::isChar16Type() const { 659 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 660 return BT->getKind() == BuiltinType::Char16; 661 return false; 662 } 663 664 bool Type::isChar32Type() const { 665 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 666 return BT->getKind() == BuiltinType::Char32; 667 return false; 668 } 669 670 /// \brief Determine whether this type is any of the built-in character 671 /// types. 672 bool Type::isAnyCharacterType() const { 673 const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType); 674 if (BT == 0) return false; 675 switch (BT->getKind()) { 676 default: return false; 677 case BuiltinType::Char_U: 678 case BuiltinType::UChar: 679 case BuiltinType::WChar_U: 680 case BuiltinType::Char16: 681 case BuiltinType::Char32: 682 case BuiltinType::Char_S: 683 case BuiltinType::SChar: 684 case BuiltinType::WChar_S: 685 return true; 686 } 687 } 688 689 /// isSignedIntegerType - Return true if this is an integer type that is 690 /// signed, according to C99 6.2.5p4 [char, signed char, short, int, long..], 691 /// an enum decl which has a signed representation 692 bool Type::isSignedIntegerType() const { 693 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) { 694 return BT->getKind() >= BuiltinType::Char_S && 695 BT->getKind() <= BuiltinType::Int128; 696 } 697 698 if (const EnumType *ET = dyn_cast<EnumType>(CanonicalType)) { 699 // Incomplete enum types are not treated as integer types. 700 // FIXME: In C++, enum types are never integer types. 701 if (ET->getDecl()->isComplete() && !ET->getDecl()->isScoped()) 702 return ET->getDecl()->getIntegerType()->isSignedIntegerType(); 703 } 704 705 return false; 706 } 707 708 bool Type::isSignedIntegerOrEnumerationType() const { 709 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) { 710 return BT->getKind() >= BuiltinType::Char_S && 711 BT->getKind() <= BuiltinType::Int128; 712 } 713 714 if (const EnumType *ET = dyn_cast<EnumType>(CanonicalType)) { 715 if (ET->getDecl()->isComplete()) 716 return ET->getDecl()->getIntegerType()->isSignedIntegerType(); 717 } 718 719 return false; 720 } 721 722 bool Type::hasSignedIntegerRepresentation() const { 723 if (const VectorType *VT = dyn_cast<VectorType>(CanonicalType)) 724 return VT->getElementType()->isSignedIntegerType(); 725 else 726 return isSignedIntegerType(); 727 } 728 729 /// isUnsignedIntegerType - Return true if this is an integer type that is 730 /// unsigned, according to C99 6.2.5p6 [which returns true for _Bool], an enum 731 /// decl which has an unsigned representation 732 bool Type::isUnsignedIntegerType() const { 733 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) { 734 return BT->getKind() >= BuiltinType::Bool && 735 BT->getKind() <= BuiltinType::UInt128; 736 } 737 738 if (const EnumType *ET = dyn_cast<EnumType>(CanonicalType)) { 739 // Incomplete enum types are not treated as integer types. 740 // FIXME: In C++, enum types are never integer types. 741 if (ET->getDecl()->isComplete() && !ET->getDecl()->isScoped()) 742 return ET->getDecl()->getIntegerType()->isUnsignedIntegerType(); 743 } 744 745 return false; 746 } 747 748 bool Type::isUnsignedIntegerOrEnumerationType() const { 749 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) { 750 return BT->getKind() >= BuiltinType::Bool && 751 BT->getKind() <= BuiltinType::UInt128; 752 } 753 754 if (const EnumType *ET = dyn_cast<EnumType>(CanonicalType)) { 755 if (ET->getDecl()->isComplete()) 756 return ET->getDecl()->getIntegerType()->isUnsignedIntegerType(); 757 } 758 759 return false; 760 } 761 762 bool Type::hasUnsignedIntegerRepresentation() const { 763 if (const VectorType *VT = dyn_cast<VectorType>(CanonicalType)) 764 return VT->getElementType()->isUnsignedIntegerType(); 765 else 766 return isUnsignedIntegerType(); 767 } 768 769 bool Type::isHalfType() const { 770 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 771 return BT->getKind() == BuiltinType::Half; 772 // FIXME: Should we allow complex __fp16? Probably not. 773 return false; 774 } 775 776 bool Type::isFloatingType() const { 777 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 778 return BT->getKind() >= BuiltinType::Half && 779 BT->getKind() <= BuiltinType::LongDouble; 780 if (const ComplexType *CT = dyn_cast<ComplexType>(CanonicalType)) 781 return CT->getElementType()->isFloatingType(); 782 return false; 783 } 784 785 bool Type::hasFloatingRepresentation() const { 786 if (const VectorType *VT = dyn_cast<VectorType>(CanonicalType)) 787 return VT->getElementType()->isFloatingType(); 788 else 789 return isFloatingType(); 790 } 791 792 bool Type::isRealFloatingType() const { 793 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 794 return BT->isFloatingPoint(); 795 return false; 796 } 797 798 bool Type::isRealType() const { 799 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 800 return BT->getKind() >= BuiltinType::Bool && 801 BT->getKind() <= BuiltinType::LongDouble; 802 if (const EnumType *ET = dyn_cast<EnumType>(CanonicalType)) 803 return ET->getDecl()->isComplete() && !ET->getDecl()->isScoped(); 804 return false; 805 } 806 807 bool Type::isArithmeticType() const { 808 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 809 return BT->getKind() >= BuiltinType::Bool && 810 BT->getKind() <= BuiltinType::LongDouble; 811 if (const EnumType *ET = dyn_cast<EnumType>(CanonicalType)) 812 // GCC allows forward declaration of enum types (forbid by C99 6.7.2.3p2). 813 // If a body isn't seen by the time we get here, return false. 814 // 815 // C++0x: Enumerations are not arithmetic types. For now, just return 816 // false for scoped enumerations since that will disable any 817 // unwanted implicit conversions. 818 return !ET->getDecl()->isScoped() && ET->getDecl()->isComplete(); 819 return isa<ComplexType>(CanonicalType); 820 } 821 822 bool Type::isScalarType() const { 823 if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) 824 return BT->getKind() > BuiltinType::Void && 825 BT->getKind() <= BuiltinType::NullPtr; 826 if (const EnumType *ET = dyn_cast<EnumType>(CanonicalType)) 827 // Enums are scalar types, but only if they are defined. Incomplete enums 828 // are not treated as scalar types. 829 return ET->getDecl()->isComplete(); 830 return isa<PointerType>(CanonicalType) || 831 isa<BlockPointerType>(CanonicalType) || 832 isa<MemberPointerType>(CanonicalType) || 833 isa<ComplexType>(CanonicalType) || 834 isa<ObjCObjectPointerType>(CanonicalType); 835 } 836 837 Type::ScalarTypeKind Type::getScalarTypeKind() const { 838 assert(isScalarType()); 839 840 const Type *T = CanonicalType.getTypePtr(); 841 if (const BuiltinType *BT = dyn_cast<BuiltinType>(T)) { 842 if (BT->getKind() == BuiltinType::Bool) return STK_Bool; 843 if (BT->getKind() == BuiltinType::NullPtr) return STK_CPointer; 844 if (BT->isInteger()) return STK_Integral; 845 if (BT->isFloatingPoint()) return STK_Floating; 846 llvm_unreachable("unknown scalar builtin type"); 847 } else if (isa<PointerType>(T)) { 848 return STK_CPointer; 849 } else if (isa<BlockPointerType>(T)) { 850 return STK_BlockPointer; 851 } else if (isa<ObjCObjectPointerType>(T)) { 852 return STK_ObjCObjectPointer; 853 } else if (isa<MemberPointerType>(T)) { 854 return STK_MemberPointer; 855 } else if (isa<EnumType>(T)) { 856 assert(cast<EnumType>(T)->getDecl()->isComplete()); 857 return STK_Integral; 858 } else if (const ComplexType *CT = dyn_cast<ComplexType>(T)) { 859 if (CT->getElementType()->isRealFloatingType()) 860 return STK_FloatingComplex; 861 return STK_IntegralComplex; 862 } 863 864 llvm_unreachable("unknown scalar type"); 865 } 866 867 /// \brief Determines whether the type is a C++ aggregate type or C 868 /// aggregate or union type. 869 /// 870 /// An aggregate type is an array or a class type (struct, union, or 871 /// class) that has no user-declared constructors, no private or 872 /// protected non-static data members, no base classes, and no virtual 873 /// functions (C++ [dcl.init.aggr]p1). The notion of an aggregate type 874 /// subsumes the notion of C aggregates (C99 6.2.5p21) because it also 875 /// includes union types. 876 bool Type::isAggregateType() const { 877 if (const RecordType *Record = dyn_cast<RecordType>(CanonicalType)) { 878 if (CXXRecordDecl *ClassDecl = dyn_cast<CXXRecordDecl>(Record->getDecl())) 879 return ClassDecl->isAggregate(); 880 881 return true; 882 } 883 884 return isa<ArrayType>(CanonicalType); 885 } 886 887 /// isConstantSizeType - Return true if this is not a variable sized type, 888 /// according to the rules of C99 6.7.5p3. It is not legal to call this on 889 /// incomplete types or dependent types. 890 bool Type::isConstantSizeType() const { 891 assert(!isIncompleteType() && "This doesn't make sense for incomplete types"); 892 assert(!isDependentType() && "This doesn't make sense for dependent types"); 893 // The VAT must have a size, as it is known to be complete. 894 return !isa<VariableArrayType>(CanonicalType); 895 } 896 897 /// isIncompleteType - Return true if this is an incomplete type (C99 6.2.5p1) 898 /// - a type that can describe objects, but which lacks information needed to 899 /// determine its size. 900 bool Type::isIncompleteType(NamedDecl **Def) const { 901 if (Def) 902 *Def = 0; 903 904 switch (CanonicalType->getTypeClass()) { 905 default: return false; 906 case Builtin: 907 // Void is the only incomplete builtin type. Per C99 6.2.5p19, it can never 908 // be completed. 909 return isVoidType(); 910 case Enum: { 911 EnumDecl *EnumD = cast<EnumType>(CanonicalType)->getDecl(); 912 if (Def) 913 *Def = EnumD; 914 915 // An enumeration with fixed underlying type is complete (C++0x 7.2p3). 916 if (EnumD->isFixed()) 917 return false; 918 919 return !EnumD->isCompleteDefinition(); 920 } 921 case Record: { 922 // A tagged type (struct/union/enum/class) is incomplete if the decl is a 923 // forward declaration, but not a full definition (C99 6.2.5p22). 924 RecordDecl *Rec = cast<RecordType>(CanonicalType)->getDecl(); 925 if (Def) 926 *Def = Rec; 927 return !Rec->isCompleteDefinition(); 928 } 929 case ConstantArray: 930 // An array is incomplete if its element type is incomplete 931 // (C++ [dcl.array]p1). 932 // We don't handle variable arrays (they're not allowed in C++) or 933 // dependent-sized arrays (dependent types are never treated as incomplete). 934 return cast<ArrayType>(CanonicalType)->getElementType() 935 ->isIncompleteType(Def); 936 case IncompleteArray: 937 // An array of unknown size is an incomplete type (C99 6.2.5p22). 938 return true; 939 case ObjCObject: 940 return cast<ObjCObjectType>(CanonicalType)->getBaseType() 941 ->isIncompleteType(Def); 942 case ObjCInterface: { 943 // ObjC interfaces are incomplete if they are @class, not @interface. 944 ObjCInterfaceDecl *Interface 945 = cast<ObjCInterfaceType>(CanonicalType)->getDecl(); 946 if (Def) 947 *Def = Interface; 948 return !Interface->hasDefinition(); 949 } 950 } 951 } 952 953 bool QualType::isPODType(ASTContext &Context) const { 954 // The compiler shouldn't query this for incomplete types, but the user might. 955 // We return false for that case. Except for incomplete arrays of PODs, which 956 // are PODs according to the standard. 957 if (isNull()) 958 return 0; 959 960 if ((*this)->isIncompleteArrayType()) 961 return Context.getBaseElementType(*this).isPODType(Context); 962 963 if ((*this)->isIncompleteType()) 964 return false; 965 966 if (Context.getLangOptions().ObjCAutoRefCount) { 967 switch (getObjCLifetime()) { 968 case Qualifiers::OCL_ExplicitNone: 969 return true; 970 971 case Qualifiers::OCL_Strong: 972 case Qualifiers::OCL_Weak: 973 case Qualifiers::OCL_Autoreleasing: 974 return false; 975 976 case Qualifiers::OCL_None: 977 break; 978 } 979 } 980 981 QualType CanonicalType = getTypePtr()->CanonicalType; 982 switch (CanonicalType->getTypeClass()) { 983 // Everything not explicitly mentioned is not POD. 984 default: return false; 985 case Type::VariableArray: 986 case Type::ConstantArray: 987 // IncompleteArray is handled above. 988 return Context.getBaseElementType(*this).isPODType(Context); 989 990 case Type::ObjCObjectPointer: 991 case Type::BlockPointer: 992 case Type::Builtin: 993 case Type::Complex: 994 case Type::Pointer: 995 case Type::MemberPointer: 996 case Type::Vector: 997 case Type::ExtVector: 998 return true; 999 1000 case Type::Enum: 1001 return true; 1002 1003 case Type::Record: 1004 if (CXXRecordDecl *ClassDecl 1005 = dyn_cast<CXXRecordDecl>(cast<RecordType>(CanonicalType)->getDecl())) 1006 return ClassDecl->isPOD(); 1007 1008 // C struct/union is POD. 1009 return true; 1010 } 1011 } 1012 1013 bool QualType::isTrivialType(ASTContext &Context) const { 1014 // The compiler shouldn't query this for incomplete types, but the user might. 1015 // We return false for that case. Except for incomplete arrays of PODs, which 1016 // are PODs according to the standard. 1017 if (isNull()) 1018 return 0; 1019 1020 if ((*this)->isArrayType()) 1021 return Context.getBaseElementType(*this).isTrivialType(Context); 1022 1023 // Return false for incomplete types after skipping any incomplete array 1024 // types which are expressly allowed by the standard and thus our API. 1025 if ((*this)->isIncompleteType()) 1026 return false; 1027 1028 if (Context.getLangOptions().ObjCAutoRefCount) { 1029 switch (getObjCLifetime()) { 1030 case Qualifiers::OCL_ExplicitNone: 1031 return true; 1032 1033 case Qualifiers::OCL_Strong: 1034 case Qualifiers::OCL_Weak: 1035 case Qualifiers::OCL_Autoreleasing: 1036 return false; 1037 1038 case Qualifiers::OCL_None: 1039 if ((*this)->isObjCLifetimeType()) 1040 return false; 1041 break; 1042 } 1043 } 1044 1045 QualType CanonicalType = getTypePtr()->CanonicalType; 1046 if (CanonicalType->isDependentType()) 1047 return false; 1048 1049 // C++0x [basic.types]p9: 1050 // Scalar types, trivial class types, arrays of such types, and 1051 // cv-qualified versions of these types are collectively called trivial 1052 // types. 1053 1054 // As an extension, Clang treats vector types as Scalar types. 1055 if (CanonicalType->isScalarType() || CanonicalType->isVectorType()) 1056 return true; 1057 if (const RecordType *RT = CanonicalType->getAs<RecordType>()) { 1058 if (const CXXRecordDecl *ClassDecl = 1059 dyn_cast<CXXRecordDecl>(RT->getDecl())) { 1060 // C++0x [class]p5: 1061 // A trivial class is a class that has a trivial default constructor 1062 if (!ClassDecl->hasTrivialDefaultConstructor()) return false; 1063 // and is trivially copyable. 1064 if (!ClassDecl->isTriviallyCopyable()) return false; 1065 } 1066 1067 return true; 1068 } 1069 1070 // No other types can match. 1071 return false; 1072 } 1073 1074 bool QualType::isTriviallyCopyableType(ASTContext &Context) const { 1075 if ((*this)->isArrayType()) 1076 return Context.getBaseElementType(*this).isTrivialType(Context); 1077 1078 if (Context.getLangOptions().ObjCAutoRefCount) { 1079 switch (getObjCLifetime()) { 1080 case Qualifiers::OCL_ExplicitNone: 1081 return true; 1082 1083 case Qualifiers::OCL_Strong: 1084 case Qualifiers::OCL_Weak: 1085 case Qualifiers::OCL_Autoreleasing: 1086 return false; 1087 1088 case Qualifiers::OCL_None: 1089 if ((*this)->isObjCLifetimeType()) 1090 return false; 1091 break; 1092 } 1093 } 1094 1095 // C++0x [basic.types]p9 1096 // Scalar types, trivially copyable class types, arrays of such types, and 1097 // cv-qualified versions of these types are collectively called trivial 1098 // types. 1099 1100 QualType CanonicalType = getCanonicalType(); 1101 if (CanonicalType->isDependentType()) 1102 return false; 1103 1104 // Return false for incomplete types after skipping any incomplete array types 1105 // which are expressly allowed by the standard and thus our API. 1106 if (CanonicalType->isIncompleteType()) 1107 return false; 1108 1109 // As an extension, Clang treats vector types as Scalar types. 1110 if (CanonicalType->isScalarType() || CanonicalType->isVectorType()) 1111 return true; 1112 1113 if (const RecordType *RT = CanonicalType->getAs<RecordType>()) { 1114 if (const CXXRecordDecl *ClassDecl = 1115 dyn_cast<CXXRecordDecl>(RT->getDecl())) { 1116 if (!ClassDecl->isTriviallyCopyable()) return false; 1117 } 1118 1119 return true; 1120 } 1121 1122 // No other types can match. 1123 return false; 1124 } 1125 1126 1127 1128 bool Type::isLiteralType() const { 1129 if (isDependentType()) 1130 return false; 1131 1132 // C++0x [basic.types]p10: 1133 // A type is a literal type if it is: 1134 // [...] 1135 // -- an array of literal type. 1136 // Extension: variable arrays cannot be literal types, since they're 1137 // runtime-sized. 1138 if (isVariableArrayType()) 1139 return false; 1140 const Type *BaseTy = getBaseElementTypeUnsafe(); 1141 assert(BaseTy && "NULL element type"); 1142 1143 // Return false for incomplete types after skipping any incomplete array 1144 // types; those are expressly allowed by the standard and thus our API. 1145 if (BaseTy->isIncompleteType()) 1146 return false; 1147 1148 // C++0x [basic.types]p10: 1149 // A type is a literal type if it is: 1150 // -- a scalar type; or 1151 // As an extension, Clang treats vector types and complex types as 1152 // literal types. 1153 if (BaseTy->isScalarType() || BaseTy->isVectorType() || 1154 BaseTy->isAnyComplexType()) 1155 return true; 1156 // -- a reference type; or 1157 if (BaseTy->isReferenceType()) 1158 return true; 1159 // -- a class type that has all of the following properties: 1160 if (const RecordType *RT = BaseTy->getAs<RecordType>()) { 1161 // -- a trivial destructor, 1162 // -- every constructor call and full-expression in the 1163 // brace-or-equal-initializers for non-static data members (if any) 1164 // is a constant expression, 1165 // -- it is an aggregate type or has at least one constexpr 1166 // constructor or constructor template that is not a copy or move 1167 // constructor, and 1168 // -- all non-static data members and base classes of literal types 1169 // 1170 // We resolve DR1361 by ignoring the second bullet. 1171 if (const CXXRecordDecl *ClassDecl = 1172 dyn_cast<CXXRecordDecl>(RT->getDecl())) 1173 return ClassDecl->isLiteral(); 1174 1175 return true; 1176 } 1177 1178 return false; 1179 } 1180 1181 bool Type::isStandardLayoutType() const { 1182 if (isDependentType()) 1183 return false; 1184 1185 // C++0x [basic.types]p9: 1186 // Scalar types, standard-layout class types, arrays of such types, and 1187 // cv-qualified versions of these types are collectively called 1188 // standard-layout types. 1189 const Type *BaseTy = getBaseElementTypeUnsafe(); 1190 assert(BaseTy && "NULL element type"); 1191 1192 // Return false for incomplete types after skipping any incomplete array 1193 // types which are expressly allowed by the standard and thus our API. 1194 if (BaseTy->isIncompleteType()) 1195 return false; 1196 1197 // As an extension, Clang treats vector types as Scalar types. 1198 if (BaseTy->isScalarType() || BaseTy->isVectorType()) return true; 1199 if (const RecordType *RT = BaseTy->getAs<RecordType>()) { 1200 if (const CXXRecordDecl *ClassDecl = 1201 dyn_cast<CXXRecordDecl>(RT->getDecl())) 1202 if (!ClassDecl->isStandardLayout()) 1203 return false; 1204 1205 // Default to 'true' for non-C++ class types. 1206 // FIXME: This is a bit dubious, but plain C structs should trivially meet 1207 // all the requirements of standard layout classes. 1208 return true; 1209 } 1210 1211 // No other types can match. 1212 return false; 1213 } 1214 1215 // This is effectively the intersection of isTrivialType and 1216 // isStandardLayoutType. We implement it directly to avoid redundant 1217 // conversions from a type to a CXXRecordDecl. 1218 bool QualType::isCXX11PODType(ASTContext &Context) const { 1219 const Type *ty = getTypePtr(); 1220 if (ty->isDependentType()) 1221 return false; 1222 1223 if (Context.getLangOptions().ObjCAutoRefCount) { 1224 switch (getObjCLifetime()) { 1225 case Qualifiers::OCL_ExplicitNone: 1226 return true; 1227 1228 case Qualifiers::OCL_Strong: 1229 case Qualifiers::OCL_Weak: 1230 case Qualifiers::OCL_Autoreleasing: 1231 return false; 1232 1233 case Qualifiers::OCL_None: 1234 if (ty->isObjCLifetimeType()) 1235 return false; 1236 break; 1237 } 1238 } 1239 1240 // C++11 [basic.types]p9: 1241 // Scalar types, POD classes, arrays of such types, and cv-qualified 1242 // versions of these types are collectively called trivial types. 1243 const Type *BaseTy = ty->getBaseElementTypeUnsafe(); 1244 assert(BaseTy && "NULL element type"); 1245 1246 // Return false for incomplete types after skipping any incomplete array 1247 // types which are expressly allowed by the standard and thus our API. 1248 if (BaseTy->isIncompleteType()) 1249 return false; 1250 1251 // As an extension, Clang treats vector types as Scalar types. 1252 if (BaseTy->isScalarType() || BaseTy->isVectorType()) return true; 1253 if (const RecordType *RT = BaseTy->getAs<RecordType>()) { 1254 if (const CXXRecordDecl *ClassDecl = 1255 dyn_cast<CXXRecordDecl>(RT->getDecl())) { 1256 // C++11 [class]p10: 1257 // A POD struct is a non-union class that is both a trivial class [...] 1258 if (!ClassDecl->isTrivial()) return false; 1259 1260 // C++11 [class]p10: 1261 // A POD struct is a non-union class that is both a trivial class and 1262 // a standard-layout class [...] 1263 if (!ClassDecl->isStandardLayout()) return false; 1264 1265 // C++11 [class]p10: 1266 // A POD struct is a non-union class that is both a trivial class and 1267 // a standard-layout class, and has no non-static data members of type 1268 // non-POD struct, non-POD union (or array of such types). [...] 1269 // 1270 // We don't directly query the recursive aspect as the requiremets for 1271 // both standard-layout classes and trivial classes apply recursively 1272 // already. 1273 } 1274 1275 return true; 1276 } 1277 1278 // No other types can match. 1279 return false; 1280 } 1281 1282 bool Type::isPromotableIntegerType() const { 1283 if (const BuiltinType *BT = getAs<BuiltinType>()) 1284 switch (BT->getKind()) { 1285 case BuiltinType::Bool: 1286 case BuiltinType::Char_S: 1287 case BuiltinType::Char_U: 1288 case BuiltinType::SChar: 1289 case BuiltinType::UChar: 1290 case BuiltinType::Short: 1291 case BuiltinType::UShort: 1292 case BuiltinType::WChar_S: 1293 case BuiltinType::WChar_U: 1294 case BuiltinType::Char16: 1295 case BuiltinType::Char32: 1296 return true; 1297 default: 1298 return false; 1299 } 1300 1301 // Enumerated types are promotable to their compatible integer types 1302 // (C99 6.3.1.1) a.k.a. its underlying type (C++ [conv.prom]p2). 1303 if (const EnumType *ET = getAs<EnumType>()){ 1304 if (this->isDependentType() || ET->getDecl()->getPromotionType().isNull() 1305 || ET->getDecl()->isScoped()) 1306 return false; 1307 1308 return true; 1309 } 1310 1311 return false; 1312 } 1313 1314 bool Type::isNullPtrType() const { 1315 if (const BuiltinType *BT = getAs<BuiltinType>()) 1316 return BT->getKind() == BuiltinType::NullPtr; 1317 return false; 1318 } 1319 1320 bool Type::isSpecifierType() const { 1321 // Note that this intentionally does not use the canonical type. 1322 switch (getTypeClass()) { 1323 case Builtin: 1324 case Record: 1325 case Enum: 1326 case Typedef: 1327 case Complex: 1328 case TypeOfExpr: 1329 case TypeOf: 1330 case TemplateTypeParm: 1331 case SubstTemplateTypeParm: 1332 case TemplateSpecialization: 1333 case Elaborated: 1334 case DependentName: 1335 case DependentTemplateSpecialization: 1336 case ObjCInterface: 1337 case ObjCObject: 1338 case ObjCObjectPointer: // FIXME: object pointers aren't really specifiers 1339 return true; 1340 default: 1341 return false; 1342 } 1343 } 1344 1345 ElaboratedTypeKeyword 1346 TypeWithKeyword::getKeywordForTypeSpec(unsigned TypeSpec) { 1347 switch (TypeSpec) { 1348 default: return ETK_None; 1349 case TST_typename: return ETK_Typename; 1350 case TST_class: return ETK_Class; 1351 case TST_struct: return ETK_Struct; 1352 case TST_union: return ETK_Union; 1353 case TST_enum: return ETK_Enum; 1354 } 1355 } 1356 1357 TagTypeKind 1358 TypeWithKeyword::getTagTypeKindForTypeSpec(unsigned TypeSpec) { 1359 switch(TypeSpec) { 1360 case TST_class: return TTK_Class; 1361 case TST_struct: return TTK_Struct; 1362 case TST_union: return TTK_Union; 1363 case TST_enum: return TTK_Enum; 1364 } 1365 1366 llvm_unreachable("Type specifier is not a tag type kind."); 1367 } 1368 1369 ElaboratedTypeKeyword 1370 TypeWithKeyword::getKeywordForTagTypeKind(TagTypeKind Kind) { 1371 switch (Kind) { 1372 case TTK_Class: return ETK_Class; 1373 case TTK_Struct: return ETK_Struct; 1374 case TTK_Union: return ETK_Union; 1375 case TTK_Enum: return ETK_Enum; 1376 } 1377 llvm_unreachable("Unknown tag type kind."); 1378 } 1379 1380 TagTypeKind 1381 TypeWithKeyword::getTagTypeKindForKeyword(ElaboratedTypeKeyword Keyword) { 1382 switch (Keyword) { 1383 case ETK_Class: return TTK_Class; 1384 case ETK_Struct: return TTK_Struct; 1385 case ETK_Union: return TTK_Union; 1386 case ETK_Enum: return TTK_Enum; 1387 case ETK_None: // Fall through. 1388 case ETK_Typename: 1389 llvm_unreachable("Elaborated type keyword is not a tag type kind."); 1390 } 1391 llvm_unreachable("Unknown elaborated type keyword."); 1392 } 1393 1394 bool 1395 TypeWithKeyword::KeywordIsTagTypeKind(ElaboratedTypeKeyword Keyword) { 1396 switch (Keyword) { 1397 case ETK_None: 1398 case ETK_Typename: 1399 return false; 1400 case ETK_Class: 1401 case ETK_Struct: 1402 case ETK_Union: 1403 case ETK_Enum: 1404 return true; 1405 } 1406 llvm_unreachable("Unknown elaborated type keyword."); 1407 } 1408 1409 const char* 1410 TypeWithKeyword::getKeywordName(ElaboratedTypeKeyword Keyword) { 1411 switch (Keyword) { 1412 case ETK_None: return ""; 1413 case ETK_Typename: return "typename"; 1414 case ETK_Class: return "class"; 1415 case ETK_Struct: return "struct"; 1416 case ETK_Union: return "union"; 1417 case ETK_Enum: return "enum"; 1418 } 1419 1420 llvm_unreachable("Unknown elaborated type keyword."); 1421 } 1422 1423 DependentTemplateSpecializationType::DependentTemplateSpecializationType( 1424 ElaboratedTypeKeyword Keyword, 1425 NestedNameSpecifier *NNS, const IdentifierInfo *Name, 1426 unsigned NumArgs, const TemplateArgument *Args, 1427 QualType Canon) 1428 : TypeWithKeyword(Keyword, DependentTemplateSpecialization, Canon, true, true, 1429 /*VariablyModified=*/false, 1430 NNS && NNS->containsUnexpandedParameterPack()), 1431 NNS(NNS), Name(Name), NumArgs(NumArgs) { 1432 assert((!NNS || NNS->isDependent()) && 1433 "DependentTemplateSpecializatonType requires dependent qualifier"); 1434 for (unsigned I = 0; I != NumArgs; ++I) { 1435 if (Args[I].containsUnexpandedParameterPack()) 1436 setContainsUnexpandedParameterPack(); 1437 1438 new (&getArgBuffer()[I]) TemplateArgument(Args[I]); 1439 } 1440 } 1441 1442 void 1443 DependentTemplateSpecializationType::Profile(llvm::FoldingSetNodeID &ID, 1444 const ASTContext &Context, 1445 ElaboratedTypeKeyword Keyword, 1446 NestedNameSpecifier *Qualifier, 1447 const IdentifierInfo *Name, 1448 unsigned NumArgs, 1449 const TemplateArgument *Args) { 1450 ID.AddInteger(Keyword); 1451 ID.AddPointer(Qualifier); 1452 ID.AddPointer(Name); 1453 for (unsigned Idx = 0; Idx < NumArgs; ++Idx) 1454 Args[Idx].Profile(ID, Context); 1455 } 1456 1457 bool Type::isElaboratedTypeSpecifier() const { 1458 ElaboratedTypeKeyword Keyword; 1459 if (const ElaboratedType *Elab = dyn_cast<ElaboratedType>(this)) 1460 Keyword = Elab->getKeyword(); 1461 else if (const DependentNameType *DepName = dyn_cast<DependentNameType>(this)) 1462 Keyword = DepName->getKeyword(); 1463 else if (const DependentTemplateSpecializationType *DepTST = 1464 dyn_cast<DependentTemplateSpecializationType>(this)) 1465 Keyword = DepTST->getKeyword(); 1466 else 1467 return false; 1468 1469 return TypeWithKeyword::KeywordIsTagTypeKind(Keyword); 1470 } 1471 1472 const char *Type::getTypeClassName() const { 1473 switch (TypeBits.TC) { 1474 #define ABSTRACT_TYPE(Derived, Base) 1475 #define TYPE(Derived, Base) case Derived: return #Derived; 1476 #include "clang/AST/TypeNodes.def" 1477 } 1478 1479 llvm_unreachable("Invalid type class."); 1480 } 1481 1482 const char *BuiltinType::getName(const PrintingPolicy &Policy) const { 1483 switch (getKind()) { 1484 case Void: return "void"; 1485 case Bool: return Policy.Bool ? "bool" : "_Bool"; 1486 case Char_S: return "char"; 1487 case Char_U: return "char"; 1488 case SChar: return "signed char"; 1489 case Short: return "short"; 1490 case Int: return "int"; 1491 case Long: return "long"; 1492 case LongLong: return "long long"; 1493 case Int128: return "__int128_t"; 1494 case UChar: return "unsigned char"; 1495 case UShort: return "unsigned short"; 1496 case UInt: return "unsigned int"; 1497 case ULong: return "unsigned long"; 1498 case ULongLong: return "unsigned long long"; 1499 case UInt128: return "__uint128_t"; 1500 case Half: return "half"; 1501 case Float: return "float"; 1502 case Double: return "double"; 1503 case LongDouble: return "long double"; 1504 case WChar_S: 1505 case WChar_U: return "wchar_t"; 1506 case Char16: return "char16_t"; 1507 case Char32: return "char32_t"; 1508 case NullPtr: return "nullptr_t"; 1509 case Overload: return "<overloaded function type>"; 1510 case BoundMember: return "<bound member function type>"; 1511 case PseudoObject: return "<pseudo-object type>"; 1512 case Dependent: return "<dependent type>"; 1513 case UnknownAny: return "<unknown type>"; 1514 case ARCUnbridgedCast: return "<ARC unbridged cast type>"; 1515 case ObjCId: return "id"; 1516 case ObjCClass: return "Class"; 1517 case ObjCSel: return "SEL"; 1518 } 1519 1520 llvm_unreachable("Invalid builtin type."); 1521 } 1522 1523 QualType QualType::getNonLValueExprType(ASTContext &Context) const { 1524 if (const ReferenceType *RefType = getTypePtr()->getAs<ReferenceType>()) 1525 return RefType->getPointeeType(); 1526 1527 // C++0x [basic.lval]: 1528 // Class prvalues can have cv-qualified types; non-class prvalues always 1529 // have cv-unqualified types. 1530 // 1531 // See also C99 6.3.2.1p2. 1532 if (!Context.getLangOptions().CPlusPlus || 1533 (!getTypePtr()->isDependentType() && !getTypePtr()->isRecordType())) 1534 return getUnqualifiedType(); 1535 1536 return *this; 1537 } 1538 1539 StringRef FunctionType::getNameForCallConv(CallingConv CC) { 1540 switch (CC) { 1541 case CC_Default: 1542 llvm_unreachable("no name for default cc"); 1543 1544 case CC_C: return "cdecl"; 1545 case CC_X86StdCall: return "stdcall"; 1546 case CC_X86FastCall: return "fastcall"; 1547 case CC_X86ThisCall: return "thiscall"; 1548 case CC_X86Pascal: return "pascal"; 1549 case CC_AAPCS: return "aapcs"; 1550 case CC_AAPCS_VFP: return "aapcs-vfp"; 1551 } 1552 1553 llvm_unreachable("Invalid calling convention."); 1554 } 1555 1556 FunctionProtoType::FunctionProtoType(QualType result, const QualType *args, 1557 unsigned numArgs, QualType canonical, 1558 const ExtProtoInfo &epi) 1559 : FunctionType(FunctionProto, result, epi.Variadic, epi.TypeQuals, 1560 epi.RefQualifier, canonical, 1561 result->isDependentType(), 1562 result->isInstantiationDependentType(), 1563 result->isVariablyModifiedType(), 1564 result->containsUnexpandedParameterPack(), 1565 epi.ExtInfo), 1566 NumArgs(numArgs), NumExceptions(epi.NumExceptions), 1567 ExceptionSpecType(epi.ExceptionSpecType), 1568 HasAnyConsumedArgs(epi.ConsumedArguments != 0) 1569 { 1570 // Fill in the trailing argument array. 1571 QualType *argSlot = reinterpret_cast<QualType*>(this+1); 1572 for (unsigned i = 0; i != numArgs; ++i) { 1573 if (args[i]->isDependentType()) 1574 setDependent(); 1575 else if (args[i]->isInstantiationDependentType()) 1576 setInstantiationDependent(); 1577 1578 if (args[i]->containsUnexpandedParameterPack()) 1579 setContainsUnexpandedParameterPack(); 1580 1581 argSlot[i] = args[i]; 1582 } 1583 1584 if (getExceptionSpecType() == EST_Dynamic) { 1585 // Fill in the exception array. 1586 QualType *exnSlot = argSlot + numArgs; 1587 for (unsigned i = 0, e = epi.NumExceptions; i != e; ++i) { 1588 if (epi.Exceptions[i]->isDependentType()) 1589 setDependent(); 1590 else if (epi.Exceptions[i]->isInstantiationDependentType()) 1591 setInstantiationDependent(); 1592 1593 if (epi.Exceptions[i]->containsUnexpandedParameterPack()) 1594 setContainsUnexpandedParameterPack(); 1595 1596 exnSlot[i] = epi.Exceptions[i]; 1597 } 1598 } else if (getExceptionSpecType() == EST_ComputedNoexcept) { 1599 // Store the noexcept expression and context. 1600 Expr **noexSlot = reinterpret_cast<Expr**>(argSlot + numArgs); 1601 *noexSlot = epi.NoexceptExpr; 1602 1603 if (epi.NoexceptExpr) { 1604 if (epi.NoexceptExpr->isValueDependent() 1605 || epi.NoexceptExpr->isTypeDependent()) 1606 setDependent(); 1607 else if (epi.NoexceptExpr->isInstantiationDependent()) 1608 setInstantiationDependent(); 1609 } 1610 } 1611 1612 if (epi.ConsumedArguments) { 1613 bool *consumedArgs = const_cast<bool*>(getConsumedArgsBuffer()); 1614 for (unsigned i = 0; i != numArgs; ++i) 1615 consumedArgs[i] = epi.ConsumedArguments[i]; 1616 } 1617 } 1618 1619 FunctionProtoType::NoexceptResult 1620 FunctionProtoType::getNoexceptSpec(ASTContext &ctx) const { 1621 ExceptionSpecificationType est = getExceptionSpecType(); 1622 if (est == EST_BasicNoexcept) 1623 return NR_Nothrow; 1624 1625 if (est != EST_ComputedNoexcept) 1626 return NR_NoNoexcept; 1627 1628 Expr *noexceptExpr = getNoexceptExpr(); 1629 if (!noexceptExpr) 1630 return NR_BadNoexcept; 1631 if (noexceptExpr->isValueDependent()) 1632 return NR_Dependent; 1633 1634 llvm::APSInt value; 1635 bool isICE = noexceptExpr->isIntegerConstantExpr(value, ctx, 0, 1636 /*evaluated*/false); 1637 (void)isICE; 1638 assert(isICE && "AST should not contain bad noexcept expressions."); 1639 1640 return value.getBoolValue() ? NR_Nothrow : NR_Throw; 1641 } 1642 1643 bool FunctionProtoType::isTemplateVariadic() const { 1644 for (unsigned ArgIdx = getNumArgs(); ArgIdx; --ArgIdx) 1645 if (isa<PackExpansionType>(getArgType(ArgIdx - 1))) 1646 return true; 1647 1648 return false; 1649 } 1650 1651 void FunctionProtoType::Profile(llvm::FoldingSetNodeID &ID, QualType Result, 1652 const QualType *ArgTys, unsigned NumArgs, 1653 const ExtProtoInfo &epi, 1654 const ASTContext &Context) { 1655 1656 // We have to be careful not to get ambiguous profile encodings. 1657 // Note that valid type pointers are never ambiguous with anything else. 1658 // 1659 // The encoding grammar begins: 1660 // type type* bool int bool 1661 // If that final bool is true, then there is a section for the EH spec: 1662 // bool type* 1663 // This is followed by an optional "consumed argument" section of the 1664 // same length as the first type sequence: 1665 // bool* 1666 // Finally, we have the ext info: 1667 // int 1668 // 1669 // There is no ambiguity between the consumed arguments and an empty EH 1670 // spec because of the leading 'bool' which unambiguously indicates 1671 // whether the following bool is the EH spec or part of the arguments. 1672 1673 ID.AddPointer(Result.getAsOpaquePtr()); 1674 for (unsigned i = 0; i != NumArgs; ++i) 1675 ID.AddPointer(ArgTys[i].getAsOpaquePtr()); 1676 // This method is relatively performance sensitive, so as a performance 1677 // shortcut, use one AddInteger call instead of four for the next four 1678 // fields. 1679 assert(!(unsigned(epi.Variadic) & ~1) && 1680 !(unsigned(epi.TypeQuals) & ~255) && 1681 !(unsigned(epi.RefQualifier) & ~3) && 1682 !(unsigned(epi.ExceptionSpecType) & ~7) && 1683 "Values larger than expected."); 1684 ID.AddInteger(unsigned(epi.Variadic) + 1685 (epi.TypeQuals << 1) + 1686 (epi.RefQualifier << 9) + 1687 (epi.ExceptionSpecType << 11)); 1688 if (epi.ExceptionSpecType == EST_Dynamic) { 1689 for (unsigned i = 0; i != epi.NumExceptions; ++i) 1690 ID.AddPointer(epi.Exceptions[i].getAsOpaquePtr()); 1691 } else if (epi.ExceptionSpecType == EST_ComputedNoexcept && epi.NoexceptExpr){ 1692 epi.NoexceptExpr->Profile(ID, Context, false); 1693 } 1694 if (epi.ConsumedArguments) { 1695 for (unsigned i = 0; i != NumArgs; ++i) 1696 ID.AddBoolean(epi.ConsumedArguments[i]); 1697 } 1698 epi.ExtInfo.Profile(ID); 1699 } 1700 1701 void FunctionProtoType::Profile(llvm::FoldingSetNodeID &ID, 1702 const ASTContext &Ctx) { 1703 Profile(ID, getResultType(), arg_type_begin(), NumArgs, getExtProtoInfo(), 1704 Ctx); 1705 } 1706 1707 QualType TypedefType::desugar() const { 1708 return getDecl()->getUnderlyingType(); 1709 } 1710 1711 TypeOfExprType::TypeOfExprType(Expr *E, QualType can) 1712 : Type(TypeOfExpr, can, E->isTypeDependent(), 1713 E->isInstantiationDependent(), 1714 E->getType()->isVariablyModifiedType(), 1715 E->containsUnexpandedParameterPack()), 1716 TOExpr(E) { 1717 } 1718 1719 bool TypeOfExprType::isSugared() const { 1720 return !TOExpr->isTypeDependent(); 1721 } 1722 1723 QualType TypeOfExprType::desugar() const { 1724 if (isSugared()) 1725 return getUnderlyingExpr()->getType(); 1726 1727 return QualType(this, 0); 1728 } 1729 1730 void DependentTypeOfExprType::Profile(llvm::FoldingSetNodeID &ID, 1731 const ASTContext &Context, Expr *E) { 1732 E->Profile(ID, Context, true); 1733 } 1734 1735 DecltypeType::DecltypeType(Expr *E, QualType underlyingType, QualType can) 1736 // C++11 [temp.type]p2: "If an expression e involves a template parameter, 1737 // decltype(e) denotes a unique dependent type." Hence a decltype type is 1738 // type-dependent even if its expression is only instantiation-dependent. 1739 : Type(Decltype, can, E->isInstantiationDependent(), 1740 E->isInstantiationDependent(), 1741 E->getType()->isVariablyModifiedType(), 1742 E->containsUnexpandedParameterPack()), 1743 E(E), 1744 UnderlyingType(underlyingType) { 1745 } 1746 1747 bool DecltypeType::isSugared() const { return !E->isInstantiationDependent(); } 1748 1749 QualType DecltypeType::desugar() const { 1750 if (isSugared()) 1751 return getUnderlyingType(); 1752 1753 return QualType(this, 0); 1754 } 1755 1756 DependentDecltypeType::DependentDecltypeType(const ASTContext &Context, Expr *E) 1757 : DecltypeType(E, Context.DependentTy), Context(Context) { } 1758 1759 void DependentDecltypeType::Profile(llvm::FoldingSetNodeID &ID, 1760 const ASTContext &Context, Expr *E) { 1761 E->Profile(ID, Context, true); 1762 } 1763 1764 TagType::TagType(TypeClass TC, const TagDecl *D, QualType can) 1765 : Type(TC, can, D->isDependentType(), 1766 /*InstantiationDependent=*/D->isDependentType(), 1767 /*VariablyModified=*/false, 1768 /*ContainsUnexpandedParameterPack=*/false), 1769 decl(const_cast<TagDecl*>(D)) {} 1770 1771 static TagDecl *getInterestingTagDecl(TagDecl *decl) { 1772 for (TagDecl::redecl_iterator I = decl->redecls_begin(), 1773 E = decl->redecls_end(); 1774 I != E; ++I) { 1775 if (I->isCompleteDefinition() || I->isBeingDefined()) 1776 return *I; 1777 } 1778 // If there's no definition (not even in progress), return what we have. 1779 return decl; 1780 } 1781 1782 UnaryTransformType::UnaryTransformType(QualType BaseType, 1783 QualType UnderlyingType, 1784 UTTKind UKind, 1785 QualType CanonicalType) 1786 : Type(UnaryTransform, CanonicalType, UnderlyingType->isDependentType(), 1787 UnderlyingType->isInstantiationDependentType(), 1788 UnderlyingType->isVariablyModifiedType(), 1789 BaseType->containsUnexpandedParameterPack()) 1790 , BaseType(BaseType), UnderlyingType(UnderlyingType), UKind(UKind) 1791 {} 1792 1793 TagDecl *TagType::getDecl() const { 1794 return getInterestingTagDecl(decl); 1795 } 1796 1797 bool TagType::isBeingDefined() const { 1798 return getDecl()->isBeingDefined(); 1799 } 1800 1801 CXXRecordDecl *InjectedClassNameType::getDecl() const { 1802 return cast<CXXRecordDecl>(getInterestingTagDecl(Decl)); 1803 } 1804 1805 bool RecordType::classof(const TagType *TT) { 1806 return isa<RecordDecl>(TT->getDecl()); 1807 } 1808 1809 bool EnumType::classof(const TagType *TT) { 1810 return isa<EnumDecl>(TT->getDecl()); 1811 } 1812 1813 IdentifierInfo *TemplateTypeParmType::getIdentifier() const { 1814 return isCanonicalUnqualified() ? 0 : getDecl()->getIdentifier(); 1815 } 1816 1817 SubstTemplateTypeParmPackType:: 1818 SubstTemplateTypeParmPackType(const TemplateTypeParmType *Param, 1819 QualType Canon, 1820 const TemplateArgument &ArgPack) 1821 : Type(SubstTemplateTypeParmPack, Canon, true, true, false, true), 1822 Replaced(Param), 1823 Arguments(ArgPack.pack_begin()), NumArguments(ArgPack.pack_size()) 1824 { 1825 } 1826 1827 TemplateArgument SubstTemplateTypeParmPackType::getArgumentPack() const { 1828 return TemplateArgument(Arguments, NumArguments); 1829 } 1830 1831 void SubstTemplateTypeParmPackType::Profile(llvm::FoldingSetNodeID &ID) { 1832 Profile(ID, getReplacedParameter(), getArgumentPack()); 1833 } 1834 1835 void SubstTemplateTypeParmPackType::Profile(llvm::FoldingSetNodeID &ID, 1836 const TemplateTypeParmType *Replaced, 1837 const TemplateArgument &ArgPack) { 1838 ID.AddPointer(Replaced); 1839 ID.AddInteger(ArgPack.pack_size()); 1840 for (TemplateArgument::pack_iterator P = ArgPack.pack_begin(), 1841 PEnd = ArgPack.pack_end(); 1842 P != PEnd; ++P) 1843 ID.AddPointer(P->getAsType().getAsOpaquePtr()); 1844 } 1845 1846 bool TemplateSpecializationType:: 1847 anyDependentTemplateArguments(const TemplateArgumentListInfo &Args, 1848 bool &InstantiationDependent) { 1849 return anyDependentTemplateArguments(Args.getArgumentArray(), Args.size(), 1850 InstantiationDependent); 1851 } 1852 1853 bool TemplateSpecializationType:: 1854 anyDependentTemplateArguments(const TemplateArgumentLoc *Args, unsigned N, 1855 bool &InstantiationDependent) { 1856 for (unsigned i = 0; i != N; ++i) { 1857 if (Args[i].getArgument().isDependent()) { 1858 InstantiationDependent = true; 1859 return true; 1860 } 1861 1862 if (Args[i].getArgument().isInstantiationDependent()) 1863 InstantiationDependent = true; 1864 } 1865 return false; 1866 } 1867 1868 bool TemplateSpecializationType:: 1869 anyDependentTemplateArguments(const TemplateArgument *Args, unsigned N, 1870 bool &InstantiationDependent) { 1871 for (unsigned i = 0; i != N; ++i) { 1872 if (Args[i].isDependent()) { 1873 InstantiationDependent = true; 1874 return true; 1875 } 1876 1877 if (Args[i].isInstantiationDependent()) 1878 InstantiationDependent = true; 1879 } 1880 return false; 1881 } 1882 1883 TemplateSpecializationType:: 1884 TemplateSpecializationType(TemplateName T, 1885 const TemplateArgument *Args, unsigned NumArgs, 1886 QualType Canon, QualType AliasedType) 1887 : Type(TemplateSpecialization, 1888 Canon.isNull()? QualType(this, 0) : Canon, 1889 Canon.isNull()? T.isDependent() : Canon->isDependentType(), 1890 Canon.isNull()? T.isDependent() 1891 : Canon->isInstantiationDependentType(), 1892 false, 1893 Canon.isNull()? T.containsUnexpandedParameterPack() 1894 : Canon->containsUnexpandedParameterPack()), 1895 Template(T), NumArgs(NumArgs) { 1896 assert(!T.getAsDependentTemplateName() && 1897 "Use DependentTemplateSpecializationType for dependent template-name"); 1898 assert((T.getKind() == TemplateName::Template || 1899 T.getKind() == TemplateName::SubstTemplateTemplateParm || 1900 T.getKind() == TemplateName::SubstTemplateTemplateParmPack) && 1901 "Unexpected template name for TemplateSpecializationType"); 1902 bool InstantiationDependent; 1903 (void)InstantiationDependent; 1904 assert((!Canon.isNull() || 1905 T.isDependent() || 1906 anyDependentTemplateArguments(Args, NumArgs, 1907 InstantiationDependent)) && 1908 "No canonical type for non-dependent class template specialization"); 1909 1910 TemplateArgument *TemplateArgs 1911 = reinterpret_cast<TemplateArgument *>(this + 1); 1912 for (unsigned Arg = 0; Arg < NumArgs; ++Arg) { 1913 // Update dependent and variably-modified bits. 1914 // If the canonical type exists and is non-dependent, the template 1915 // specialization type can be non-dependent even if one of the type 1916 // arguments is. Given: 1917 // template<typename T> using U = int; 1918 // U<T> is always non-dependent, irrespective of the type T. 1919 if (Canon.isNull() && Args[Arg].isDependent()) 1920 setDependent(); 1921 else if (Args[Arg].isInstantiationDependent()) 1922 setInstantiationDependent(); 1923 1924 if (Args[Arg].getKind() == TemplateArgument::Type && 1925 Args[Arg].getAsType()->isVariablyModifiedType()) 1926 setVariablyModified(); 1927 if (Canon.isNull() && Args[Arg].containsUnexpandedParameterPack()) 1928 setContainsUnexpandedParameterPack(); 1929 1930 new (&TemplateArgs[Arg]) TemplateArgument(Args[Arg]); 1931 } 1932 1933 // Store the aliased type if this is a type alias template specialization. 1934 bool IsTypeAlias = !AliasedType.isNull(); 1935 assert(IsTypeAlias == isTypeAlias() && 1936 "allocated wrong size for type alias"); 1937 if (IsTypeAlias) { 1938 TemplateArgument *Begin = reinterpret_cast<TemplateArgument *>(this + 1); 1939 *reinterpret_cast<QualType*>(Begin + getNumArgs()) = AliasedType; 1940 } 1941 } 1942 1943 void 1944 TemplateSpecializationType::Profile(llvm::FoldingSetNodeID &ID, 1945 TemplateName T, 1946 const TemplateArgument *Args, 1947 unsigned NumArgs, 1948 const ASTContext &Context) { 1949 T.Profile(ID); 1950 for (unsigned Idx = 0; Idx < NumArgs; ++Idx) 1951 Args[Idx].Profile(ID, Context); 1952 } 1953 1954 bool TemplateSpecializationType::isTypeAlias() const { 1955 TemplateDecl *D = Template.getAsTemplateDecl(); 1956 return D && isa<TypeAliasTemplateDecl>(D); 1957 } 1958 1959 QualType 1960 QualifierCollector::apply(const ASTContext &Context, QualType QT) const { 1961 if (!hasNonFastQualifiers()) 1962 return QT.withFastQualifiers(getFastQualifiers()); 1963 1964 return Context.getQualifiedType(QT, *this); 1965 } 1966 1967 QualType 1968 QualifierCollector::apply(const ASTContext &Context, const Type *T) const { 1969 if (!hasNonFastQualifiers()) 1970 return QualType(T, getFastQualifiers()); 1971 1972 return Context.getQualifiedType(T, *this); 1973 } 1974 1975 void ObjCObjectTypeImpl::Profile(llvm::FoldingSetNodeID &ID, 1976 QualType BaseType, 1977 ObjCProtocolDecl * const *Protocols, 1978 unsigned NumProtocols) { 1979 ID.AddPointer(BaseType.getAsOpaquePtr()); 1980 for (unsigned i = 0; i != NumProtocols; i++) 1981 ID.AddPointer(Protocols[i]); 1982 } 1983 1984 void ObjCObjectTypeImpl::Profile(llvm::FoldingSetNodeID &ID) { 1985 Profile(ID, getBaseType(), qual_begin(), getNumProtocols()); 1986 } 1987 1988 namespace { 1989 1990 /// \brief The cached properties of a type. 1991 class CachedProperties { 1992 NamedDecl::LinkageInfo LV; 1993 bool local; 1994 1995 public: 1996 CachedProperties(NamedDecl::LinkageInfo LV, bool local) 1997 : LV(LV), local(local) {} 1998 1999 Linkage getLinkage() const { return LV.linkage(); } 2000 Visibility getVisibility() const { return LV.visibility(); } 2001 bool isVisibilityExplicit() const { return LV.visibilityExplicit(); } 2002 bool hasLocalOrUnnamedType() const { return local; } 2003 2004 friend CachedProperties merge(CachedProperties L, CachedProperties R) { 2005 NamedDecl::LinkageInfo MergedLV = L.LV; 2006 MergedLV.merge(R.LV); 2007 return CachedProperties(MergedLV, 2008 L.hasLocalOrUnnamedType() | R.hasLocalOrUnnamedType()); 2009 } 2010 }; 2011 } 2012 2013 static CachedProperties computeCachedProperties(const Type *T); 2014 2015 namespace clang { 2016 /// The type-property cache. This is templated so as to be 2017 /// instantiated at an internal type to prevent unnecessary symbol 2018 /// leakage. 2019 template <class Private> class TypePropertyCache { 2020 public: 2021 static CachedProperties get(QualType T) { 2022 return get(T.getTypePtr()); 2023 } 2024 2025 static CachedProperties get(const Type *T) { 2026 ensure(T); 2027 NamedDecl::LinkageInfo LV(T->TypeBits.getLinkage(), 2028 T->TypeBits.getVisibility(), 2029 T->TypeBits.isVisibilityExplicit()); 2030 return CachedProperties(LV, T->TypeBits.hasLocalOrUnnamedType()); 2031 } 2032 2033 static void ensure(const Type *T) { 2034 // If the cache is valid, we're okay. 2035 if (T->TypeBits.isCacheValid()) return; 2036 2037 // If this type is non-canonical, ask its canonical type for the 2038 // relevant information. 2039 if (!T->isCanonicalUnqualified()) { 2040 const Type *CT = T->getCanonicalTypeInternal().getTypePtr(); 2041 ensure(CT); 2042 T->TypeBits.CacheValidAndVisibility = 2043 CT->TypeBits.CacheValidAndVisibility; 2044 T->TypeBits.CachedExplicitVisibility = 2045 CT->TypeBits.CachedExplicitVisibility; 2046 T->TypeBits.CachedLinkage = CT->TypeBits.CachedLinkage; 2047 T->TypeBits.CachedLocalOrUnnamed = CT->TypeBits.CachedLocalOrUnnamed; 2048 return; 2049 } 2050 2051 // Compute the cached properties and then set the cache. 2052 CachedProperties Result = computeCachedProperties(T); 2053 T->TypeBits.CacheValidAndVisibility = Result.getVisibility() + 1U; 2054 T->TypeBits.CachedExplicitVisibility = Result.isVisibilityExplicit(); 2055 assert(T->TypeBits.isCacheValid() && 2056 T->TypeBits.getVisibility() == Result.getVisibility()); 2057 T->TypeBits.CachedLinkage = Result.getLinkage(); 2058 T->TypeBits.CachedLocalOrUnnamed = Result.hasLocalOrUnnamedType(); 2059 } 2060 }; 2061 } 2062 2063 // Instantiate the friend template at a private class. In a 2064 // reasonable implementation, these symbols will be internal. 2065 // It is terrible that this is the best way to accomplish this. 2066 namespace { class Private {}; } 2067 typedef TypePropertyCache<Private> Cache; 2068 2069 static CachedProperties computeCachedProperties(const Type *T) { 2070 switch (T->getTypeClass()) { 2071 #define TYPE(Class,Base) 2072 #define NON_CANONICAL_TYPE(Class,Base) case Type::Class: 2073 #include "clang/AST/TypeNodes.def" 2074 llvm_unreachable("didn't expect a non-canonical type here"); 2075 2076 #define TYPE(Class,Base) 2077 #define DEPENDENT_TYPE(Class,Base) case Type::Class: 2078 #define NON_CANONICAL_UNLESS_DEPENDENT_TYPE(Class,Base) case Type::Class: 2079 #include "clang/AST/TypeNodes.def" 2080 // Treat instantiation-dependent types as external. 2081 assert(T->isInstantiationDependentType()); 2082 return CachedProperties(NamedDecl::LinkageInfo(), false); 2083 2084 case Type::Builtin: 2085 // C++ [basic.link]p8: 2086 // A type is said to have linkage if and only if: 2087 // - it is a fundamental type (3.9.1); or 2088 return CachedProperties(NamedDecl::LinkageInfo(), false); 2089 2090 case Type::Record: 2091 case Type::Enum: { 2092 const TagDecl *Tag = cast<TagType>(T)->getDecl(); 2093 2094 // C++ [basic.link]p8: 2095 // - it is a class or enumeration type that is named (or has a name 2096 // for linkage purposes (7.1.3)) and the name has linkage; or 2097 // - it is a specialization of a class template (14); or 2098 NamedDecl::LinkageInfo LV = Tag->getLinkageAndVisibility(); 2099 bool IsLocalOrUnnamed = 2100 Tag->getDeclContext()->isFunctionOrMethod() || 2101 (!Tag->getIdentifier() && !Tag->getTypedefNameForAnonDecl()); 2102 return CachedProperties(LV, IsLocalOrUnnamed); 2103 } 2104 2105 // C++ [basic.link]p8: 2106 // - it is a compound type (3.9.2) other than a class or enumeration, 2107 // compounded exclusively from types that have linkage; or 2108 case Type::Complex: 2109 return Cache::get(cast<ComplexType>(T)->getElementType()); 2110 case Type::Pointer: 2111 return Cache::get(cast<PointerType>(T)->getPointeeType()); 2112 case Type::BlockPointer: 2113 return Cache::get(cast<BlockPointerType>(T)->getPointeeType()); 2114 case Type::LValueReference: 2115 case Type::RValueReference: 2116 return Cache::get(cast<ReferenceType>(T)->getPointeeType()); 2117 case Type::MemberPointer: { 2118 const MemberPointerType *MPT = cast<MemberPointerType>(T); 2119 return merge(Cache::get(MPT->getClass()), 2120 Cache::get(MPT->getPointeeType())); 2121 } 2122 case Type::ConstantArray: 2123 case Type::IncompleteArray: 2124 case Type::VariableArray: 2125 return Cache::get(cast<ArrayType>(T)->getElementType()); 2126 case Type::Vector: 2127 case Type::ExtVector: 2128 return Cache::get(cast<VectorType>(T)->getElementType()); 2129 case Type::FunctionNoProto: 2130 return Cache::get(cast<FunctionType>(T)->getResultType()); 2131 case Type::FunctionProto: { 2132 const FunctionProtoType *FPT = cast<FunctionProtoType>(T); 2133 CachedProperties result = Cache::get(FPT->getResultType()); 2134 for (FunctionProtoType::arg_type_iterator ai = FPT->arg_type_begin(), 2135 ae = FPT->arg_type_end(); ai != ae; ++ai) 2136 result = merge(result, Cache::get(*ai)); 2137 return result; 2138 } 2139 case Type::ObjCInterface: { 2140 NamedDecl::LinkageInfo LV = 2141 cast<ObjCInterfaceType>(T)->getDecl()->getLinkageAndVisibility(); 2142 return CachedProperties(LV, false); 2143 } 2144 case Type::ObjCObject: 2145 return Cache::get(cast<ObjCObjectType>(T)->getBaseType()); 2146 case Type::ObjCObjectPointer: 2147 return Cache::get(cast<ObjCObjectPointerType>(T)->getPointeeType()); 2148 case Type::Atomic: 2149 return Cache::get(cast<AtomicType>(T)->getValueType()); 2150 } 2151 2152 llvm_unreachable("unhandled type class"); 2153 2154 // C++ [basic.link]p8: 2155 // Names not covered by these rules have no linkage. 2156 NamedDecl::LinkageInfo LV(NoLinkage, DefaultVisibility, false); 2157 return CachedProperties(LV, false); 2158 } 2159 2160 /// \brief Determine the linkage of this type. 2161 Linkage Type::getLinkage() const { 2162 Cache::ensure(this); 2163 return TypeBits.getLinkage(); 2164 } 2165 2166 /// \brief Determine the linkage of this type. 2167 Visibility Type::getVisibility() const { 2168 Cache::ensure(this); 2169 return TypeBits.getVisibility(); 2170 } 2171 2172 bool Type::isVisibilityExplicit() const { 2173 Cache::ensure(this); 2174 return TypeBits.isVisibilityExplicit(); 2175 } 2176 2177 bool Type::hasUnnamedOrLocalType() const { 2178 Cache::ensure(this); 2179 return TypeBits.hasLocalOrUnnamedType(); 2180 } 2181 2182 std::pair<Linkage,Visibility> Type::getLinkageAndVisibility() const { 2183 Cache::ensure(this); 2184 return std::make_pair(TypeBits.getLinkage(), TypeBits.getVisibility()); 2185 } 2186 2187 void Type::ClearLinkageCache() { 2188 TypeBits.CacheValidAndVisibility = 0; 2189 if (QualType(this, 0) != CanonicalType) 2190 CanonicalType->TypeBits.CacheValidAndVisibility = 0; 2191 } 2192 2193 Qualifiers::ObjCLifetime Type::getObjCARCImplicitLifetime() const { 2194 if (isObjCARCImplicitlyUnretainedType()) 2195 return Qualifiers::OCL_ExplicitNone; 2196 return Qualifiers::OCL_Strong; 2197 } 2198 2199 bool Type::isObjCARCImplicitlyUnretainedType() const { 2200 assert(isObjCLifetimeType() && 2201 "cannot query implicit lifetime for non-inferrable type"); 2202 2203 const Type *canon = getCanonicalTypeInternal().getTypePtr(); 2204 2205 // Walk down to the base type. We don't care about qualifiers for this. 2206 while (const ArrayType *array = dyn_cast<ArrayType>(canon)) 2207 canon = array->getElementType().getTypePtr(); 2208 2209 if (const ObjCObjectPointerType *opt 2210 = dyn_cast<ObjCObjectPointerType>(canon)) { 2211 // Class and Class<Protocol> don't require retension. 2212 if (opt->getObjectType()->isObjCClass()) 2213 return true; 2214 } 2215 2216 return false; 2217 } 2218 2219 bool Type::isObjCNSObjectType() const { 2220 if (const TypedefType *typedefType = dyn_cast<TypedefType>(this)) 2221 return typedefType->getDecl()->hasAttr<ObjCNSObjectAttr>(); 2222 return false; 2223 } 2224 bool Type::isObjCRetainableType() const { 2225 return isObjCObjectPointerType() || 2226 isBlockPointerType() || 2227 isObjCNSObjectType(); 2228 } 2229 bool Type::isObjCIndirectLifetimeType() const { 2230 if (isObjCLifetimeType()) 2231 return true; 2232 if (const PointerType *OPT = getAs<PointerType>()) 2233 return OPT->getPointeeType()->isObjCIndirectLifetimeType(); 2234 if (const ReferenceType *Ref = getAs<ReferenceType>()) 2235 return Ref->getPointeeType()->isObjCIndirectLifetimeType(); 2236 if (const MemberPointerType *MemPtr = getAs<MemberPointerType>()) 2237 return MemPtr->getPointeeType()->isObjCIndirectLifetimeType(); 2238 return false; 2239 } 2240 2241 /// Returns true if objects of this type have lifetime semantics under 2242 /// ARC. 2243 bool Type::isObjCLifetimeType() const { 2244 const Type *type = this; 2245 while (const ArrayType *array = type->getAsArrayTypeUnsafe()) 2246 type = array->getElementType().getTypePtr(); 2247 return type->isObjCRetainableType(); 2248 } 2249 2250 /// \brief Determine whether the given type T is a "bridgable" Objective-C type, 2251 /// which is either an Objective-C object pointer type or an 2252 bool Type::isObjCARCBridgableType() const { 2253 return isObjCObjectPointerType() || isBlockPointerType(); 2254 } 2255 2256 /// \brief Determine whether the given type T is a "bridgeable" C type. 2257 bool Type::isCARCBridgableType() const { 2258 const PointerType *Pointer = getAs<PointerType>(); 2259 if (!Pointer) 2260 return false; 2261 2262 QualType Pointee = Pointer->getPointeeType(); 2263 return Pointee->isVoidType() || Pointee->isRecordType(); 2264 } 2265 2266 bool Type::hasSizedVLAType() const { 2267 if (!isVariablyModifiedType()) return false; 2268 2269 if (const PointerType *ptr = getAs<PointerType>()) 2270 return ptr->getPointeeType()->hasSizedVLAType(); 2271 if (const ReferenceType *ref = getAs<ReferenceType>()) 2272 return ref->getPointeeType()->hasSizedVLAType(); 2273 if (const ArrayType *arr = getAsArrayTypeUnsafe()) { 2274 if (isa<VariableArrayType>(arr) && 2275 cast<VariableArrayType>(arr)->getSizeExpr()) 2276 return true; 2277 2278 return arr->getElementType()->hasSizedVLAType(); 2279 } 2280 2281 return false; 2282 } 2283 2284 QualType::DestructionKind QualType::isDestructedTypeImpl(QualType type) { 2285 switch (type.getObjCLifetime()) { 2286 case Qualifiers::OCL_None: 2287 case Qualifiers::OCL_ExplicitNone: 2288 case Qualifiers::OCL_Autoreleasing: 2289 break; 2290 2291 case Qualifiers::OCL_Strong: 2292 return DK_objc_strong_lifetime; 2293 case Qualifiers::OCL_Weak: 2294 return DK_objc_weak_lifetime; 2295 } 2296 2297 /// Currently, the only destruction kind we recognize is C++ objects 2298 /// with non-trivial destructors. 2299 const CXXRecordDecl *record = 2300 type->getBaseElementTypeUnsafe()->getAsCXXRecordDecl(); 2301 if (record && record->hasDefinition() && !record->hasTrivialDestructor()) 2302 return DK_cxx_destructor; 2303 2304 return DK_none; 2305 } 2306 2307 bool QualType::hasTrivialAssignment(ASTContext &Context, bool Copying) const { 2308 switch (getObjCLifetime()) { 2309 case Qualifiers::OCL_None: 2310 break; 2311 2312 case Qualifiers::OCL_ExplicitNone: 2313 return true; 2314 2315 case Qualifiers::OCL_Autoreleasing: 2316 case Qualifiers::OCL_Strong: 2317 case Qualifiers::OCL_Weak: 2318 return !Context.getLangOptions().ObjCAutoRefCount; 2319 } 2320 2321 if (const CXXRecordDecl *Record 2322 = getTypePtr()->getBaseElementTypeUnsafe()->getAsCXXRecordDecl()) 2323 return Copying ? Record->hasTrivialCopyAssignment() : 2324 Record->hasTrivialMoveAssignment(); 2325 2326 return true; 2327 } 2328