41#include "llvm/ADT/APInt.h"
42#include "llvm/ADT/APSInt.h"
43#include "llvm/ADT/ArrayRef.h"
44#include "llvm/ADT/FoldingSet.h"
45#include "llvm/ADT/STLExtras.h"
46#include "llvm/ADT/SmallVector.h"
47#include "llvm/Support/ErrorHandling.h"
48#include "llvm/Support/MathExtras.h"
58 return (*
this !=
Other) &&
114 if (
const auto *DNT = ty->
getAs<DependentNameType>())
118 if (
const auto *TT = ty->
getAs<TagType>())
136 switch (T->getTypeClass()) {
142 case Type::BlockPointer:
145 case Type::MemberPointer:
148 case Type::LValueReference:
149 case Type::RValueReference:
152 case Type::PackExpansion:
156 case Type::ConstantArray:
157 case Type::DependentSizedArray:
158 case Type::IncompleteArray:
159 case Type::VariableArray:
160 case Type::FunctionProto:
161 case Type::FunctionNoProto:
178 if (T.isConstQualified())
182 return AT->getElementType().isConstant(Ctx);
187std::optional<QualType::NonConstantStorageReason>
190 if (!
isConstant(Ctx) && !(*this)->isReferenceType())
198 if (
Record->hasMutableFields())
200 if (!
Record->hasTrivialDestructor() && !ExcludeDtor)
226 (tc == DependentSizedArray
236 const llvm::APInt &Sz,
const Expr *SzExpr,
238 bool NeedsExternalSize = SzExpr !=
nullptr || Sz.ugt(0x0FFFFFFFFFFFFFFF) ||
239 Sz.getBitWidth() > 0xFF;
240 if (!NeedsExternalSize)
242 ET, Can, Sz.getBitWidth(), Sz.getZExtValue(), SzMod, Qual);
244 auto *SzPtr =
new (Ctx,
alignof(ConstantArrayType::ExternalSize))
245 ConstantArrayType::ExternalSize(Sz, SzExpr);
253 const llvm::APInt &NumElements) {
254 uint64_t ElementSize = Context.getTypeSizeInChars(ElementType).getQuantity();
262 if (llvm::isPowerOf2_64(ElementSize)) {
263 return NumElements.getActiveBits() + llvm::Log2_64(ElementSize);
268 if ((ElementSize >> 32) == 0 && NumElements.getBitWidth() <= 64 &&
269 (NumElements.getZExtValue() >> 32) == 0) {
270 uint64_t TotalSize = NumElements.getZExtValue() * ElementSize;
271 return llvm::bit_width(TotalSize);
275 llvm::APSInt SizeExtended(NumElements,
true);
276 unsigned SizeTypeBits = Context.getTypeSize(Context.getSizeType());
277 SizeExtended = SizeExtended.extend(
278 std::max(SizeTypeBits, SizeExtended.getBitWidth()) * 2);
280 llvm::APSInt TotalSize(llvm::APInt(SizeExtended.getBitWidth(), ElementSize));
281 TotalSize *= SizeExtended;
283 return TotalSize.getActiveBits();
292 unsigned Bits = Context.getTypeSize(Context.getSizeType());
305 uint64_t ArraySize,
const Expr *SizeExpr,
308 ID.AddInteger(ArraySize);
309 ID.AddInteger(llvm::to_underlying(SizeMod));
310 ID.AddInteger(TypeQuals);
311 ID.AddBoolean(SizeExpr !=
nullptr);
313 SizeExpr->
Profile(ID, Context,
true);
325 :
ArrayType(DependentSizedArray, et, can, sm, tq, e), SizeExpr((
Stmt *)e) {}
330 unsigned TypeQuals,
Expr *E) {
332 ID.AddInteger(llvm::to_underlying(SizeMod));
333 ID.AddInteger(TypeQuals);
338DependentVectorType::DependentVectorType(
QualType ElementType,
341 :
Type(DependentVector, CanonType,
343 ElementType->getDependence() |
346 ElementType(ElementType), SizeExpr(SizeExpr), Loc(Loc) {
354 ID.AddPointer(ElementType.getAsOpaquePtr());
355 ID.AddInteger(llvm::to_underlying(VecKind));
356 SizeExpr->Profile(ID, Context,
true);
359DependentSizedExtVectorType::DependentSizedExtVectorType(
QualType ElementType,
363 :
Type(DependentSizedExtVector, can,
365 ElementType->getDependence() |
368 SizeExpr(SizeExpr), ElementType(ElementType), loc(loc) {}
374 ID.AddPointer(ElementType.getAsOpaquePtr());
375 SizeExpr->Profile(ID, Context,
true);
378DependentAddressSpaceType::DependentAddressSpaceType(
QualType PointeeType,
382 :
Type(DependentAddressSpace, can,
384 PointeeType->getDependence() |
387 AddrSpaceExpr(AddrSpaceExpr), PointeeType(PointeeType), loc(loc) {}
392 Expr *AddrSpaceExpr) {
393 ID.AddPointer(PointeeType.getAsOpaquePtr());
394 AddrSpaceExpr->Profile(ID, Context,
true);
398 const Expr *RowExpr,
const Expr *ColumnExpr)
399 :
Type(tc, canonType,
416 unsigned nColumns,
QualType canonType)
421 unsigned nRows,
unsigned nColumns,
426DependentSizedMatrixType::DependentSizedMatrixType(
QualType ElementType,
431 :
MatrixType(DependentSizedMatrix, ElementType, CanonicalType, RowExpr,
433 RowExpr(RowExpr), ColumnExpr(ColumnExpr), loc(loc) {}
440 RowExpr->Profile(ID, CTX,
true);
441 ColumnExpr->Profile(ID, CTX,
true);
468 ExprAndUnsigned(NumBitsExpr, IsUnsigned) {}
471 return ExprAndUnsigned.getInt();
475 return ExprAndUnsigned.getPointer();
481 ID.AddBoolean(IsUnsigned);
482 NumBitsExpr->
Profile(ID, Context,
true);
494 bool CountInBytes,
bool OrNull) {
495 ID.AddPointer(WrappedTy.getAsOpaquePtr());
496 ID.AddBoolean(CountInBytes);
497 ID.AddBoolean(OrNull);
502 ID.AddPointer(CountExpr);
510 if (
const auto *ATy = dyn_cast<ArrayType>(
this))
511 return ATy->getElementType().getTypePtr();
539 return Context.getQualifiedType(desugar,
split.
Quals);
545#define TYPE(CLASS, BASE) \
546 static_assert(!std::is_polymorphic<CLASS##Type>::value, \
547 #CLASS "Type should not be polymorphic!");
548#include "clang/AST/TypeNodes.inc"
553#define TYPE(CLASS, BASE) \
554 static_assert(std::is_trivially_destructible<CLASS##Type>::value, \
555 #CLASS "Type should be trivially destructible!");
556#include "clang/AST/TypeNodes.inc"
560#define ABSTRACT_TYPE(Class, Parent)
561#define TYPE(Class, Parent) \
562 case Type::Class: { \
563 const auto *ty = cast<Class##Type>(this); \
564 if (!ty->isSugared()) \
565 return QualType(ty, 0); \
566 return ty->desugar(); \
568#include "clang/AST/TypeNodes.inc"
570 llvm_unreachable(
"bad type kind!");
580#define ABSTRACT_TYPE(Class, Parent)
581#define TYPE(Class, Parent) \
582 case Type::Class: { \
583 const auto *Ty = cast<Class##Type>(CurTy); \
584 if (!Ty->isSugared()) \
585 return SplitQualType(Ty, Qs); \
586 Cur = Ty->desugar(); \
589#include "clang/AST/TypeNodes.inc"
598 Qualifiers quals =
split.Quals;
601 const Type *lastTypeWithQuals =
split.Ty;
608 switch (
split.Ty->getTypeClass()) {
609#define ABSTRACT_TYPE(Class, Parent)
610#define TYPE(Class, Parent) \
611 case Type::Class: { \
612 const auto *ty = cast<Class##Type>(split.Ty); \
613 if (!ty->isSugared()) \
615 next = ty->desugar(); \
618#include "clang/AST/TypeNodes.inc"
624 if (!
split.Quals.empty()) {
625 lastTypeWithQuals =
split.Ty;
631 return SplitQualType(lastTypeWithQuals, quals);
636 while (
const auto *PT = T->
getAs<ParenType>())
637 T = PT->getInnerType();
646 if (
const auto *Sugar = dyn_cast<T>(Cur))
649#define ABSTRACT_TYPE(Class, Parent)
650#define TYPE(Class, Parent) \
651 case Type::Class: { \
652 const auto *Ty = cast<Class##Type>(Cur); \
653 if (!Ty->isSugared()) \
655 Cur = Ty->desugar().getTypePtr(); \
658#include "clang/AST/TypeNodes.inc"
671template <>
const TemplateSpecializationType *
Type::getAs()
const {
691 const Type *Cur =
this;
695#define ABSTRACT_TYPE(Class, Parent)
696#define TYPE(Class, Parent) \
698 const auto *Ty = cast<Class##Type>(Cur); \
699 if (!Ty->isSugared()) \
701 Cur = Ty->desugar().getTypePtr(); \
704#include "clang/AST/TypeNodes.inc"
711 return RT->getDecl()->isClass();
717 return RT->getDecl()->isStruct();
725 const auto *
Decl = RT->getDecl();
726 if (!
Decl->isStruct())
728 return Decl->getDefinitionOrSelf()->hasFlexibleArrayMember();
733 return RD->hasAttr<ObjCBoxableAttr>();
739 return RT->getDecl()->isInterface();
745 return RT->getDecl()->isStructureOrClass();
751 return PT->getPointeeType()->isVoidType();
757 return RT->getDecl()->isUnion();
763 return CT->getElementType()->isFloatingType();
774 return ET->getDecl()->isScoped();
784 if (
Complex->getElementType()->isIntegerType())
807 if (
const auto *RT = dyn_cast<RecordType>(
this)) {
808 if (RT->getDecl()->isStruct())
813 if (
const auto *RT = dyn_cast<RecordType>(CanonicalType)) {
814 if (!RT->getDecl()->isStruct())
826 if (
const auto *RT = dyn_cast<RecordType>(
this)) {
827 if (RT->getDecl()->isUnion())
832 if (
const auto *RT = dyn_cast<RecordType>(CanonicalType)) {
833 if (!RT->getDecl()->isUnion())
853 if (OPT->isObjCIdType())
857 if (!OPT->isKindOfType())
861 if (OPT->isObjCClassType() || OPT->isObjCQualifiedClassType())
865 bound = OPT->getObjectType()
866 ->stripObjCKindOfTypeAndQuals(ctx)
877 if (OPT->isObjCClassType())
881 if (!OPT->isKindOfType())
885 return OPT->isObjCClassType() || OPT->isObjCQualifiedClassType();
899 :
Type(ObjCObject, Canonical,
Base->getDependence()), BaseType(
Base) {
903 assert(getTypeArgsAsWritten().size() == typeArgs.size() &&
904 "bitfield overflow in type argument count");
905 if (!typeArgs.empty())
906 memcpy(getTypeArgStorage(), typeArgs.data(),
907 typeArgs.size() *
sizeof(
QualType));
909 for (
auto typeArg : typeArgs) {
910 addDependence(typeArg->getDependence() & ~TypeDependence::VariablyModified);
917bool ObjCObjectType::isSpecialized()
const {
919 if (ObjCObjectTypeBits.NumTypeArgs > 0)
923 if (
const auto objcObject =
getBaseType()->getAs<ObjCObjectType>()) {
928 return objcObject->isSpecialized();
937 if (isSpecializedAsWritten())
938 return getTypeArgsAsWritten();
941 if (
const auto objcObject =
getBaseType()->getAs<ObjCObjectType>()) {
946 return objcObject->getTypeArgs();
953bool ObjCObjectType::isKindOfType()
const {
954 if (isKindOfTypeAsWritten())
958 if (
const auto objcObject =
getBaseType()->getAs<ObjCObjectType>()) {
963 return objcObject->isKindOfType();
971ObjCObjectType::stripObjCKindOfTypeAndQuals(
const ASTContext &ctx)
const {
972 if (!isKindOfType() && qual_empty())
978 if (
const auto *baseObj = splitBaseType.
Ty->
getAs<ObjCObjectType>())
979 baseType = baseObj->stripObjCKindOfTypeAndQuals(ctx);
983 getTypeArgsAsWritten(),
1008template <
typename Derived>
1009struct SimpleTransformVisitor :
public TypeVisitor<Derived, QualType> {
1017 QualType result =
static_cast<Derived *
>(
this)->Visit(splitType.
Ty);
1027 explicit SimpleTransformVisitor(
ASTContext &ctx) : Ctx(ctx) {}
1031#define TYPE(Class, Base)
1032#define DEPENDENT_TYPE(Class, Base) \
1033 QualType Visit##Class##Type(const Class##Type *T) { return QualType(T, 0); }
1034#include "clang/AST/TypeNodes.inc"
1036#define TRIVIAL_TYPE_CLASS(Class) \
1037 QualType Visit##Class##Type(const Class##Type *T) { return QualType(T, 0); }
1038#define SUGARED_TYPE_CLASS(Class) \
1039 QualType Visit##Class##Type(const Class##Type *T) { \
1040 if (!T->isSugared()) \
1041 return QualType(T, 0); \
1042 QualType desugaredType = recurse(T->desugar()); \
1043 if (desugaredType.isNull()) \
1045 if (desugaredType.getAsOpaquePtr() == T->desugar().getAsOpaquePtr()) \
1046 return QualType(T, 0); \
1047 return desugaredType; \
1053 QualType elementType = recurse(T->getElementType());
1054 if (elementType.
isNull())
1057 if (elementType.
getAsOpaquePtr() == T->getElementType().getAsOpaquePtr())
1063 QualType VisitPointerType(
const PointerType *T) {
1065 if (pointeeType.
isNull())
1069 return QualType(T, 0);
1074 QualType VisitBlockPointerType(
const BlockPointerType *T) {
1076 if (pointeeType.
isNull())
1080 return QualType(T, 0);
1085 QualType VisitLValueReferenceType(
const LValueReferenceType *T) {
1087 if (pointeeType.
isNull())
1092 return QualType(T, 0);
1097 QualType VisitRValueReferenceType(
const RValueReferenceType *T) {
1099 if (pointeeType.
isNull())
1104 return QualType(T, 0);
1109 QualType VisitMemberPointerType(
const MemberPointerType *T) {
1111 if (pointeeType.
isNull())
1115 return QualType(T, 0);
1121 QualType VisitConstantArrayType(
const ConstantArrayType *T) {
1123 if (elementType.
isNull())
1127 return QualType(T, 0);
1134 QualType VisitVariableArrayType(
const VariableArrayType *T) {
1136 if (elementType.
isNull())
1140 return QualType(T, 0);
1147 QualType VisitIncompleteArrayType(
const IncompleteArrayType *T) {
1149 if (elementType.
isNull())
1153 return QualType(T, 0);
1159 QualType VisitVectorType(
const VectorType *T) {
1161 if (elementType.
isNull())
1165 return QualType(T, 0);
1171 QualType VisitExtVectorType(
const ExtVectorType *T) {
1173 if (elementType.
isNull())
1177 return QualType(T, 0);
1182 QualType VisitConstantMatrixType(
const ConstantMatrixType *T) {
1184 if (elementType.
isNull())
1187 return QualType(T, 0);
1193 QualType VisitOverflowBehaviorType(
const OverflowBehaviorType *T) {
1194 QualType UnderlyingType = recurse(T->getUnderlyingType());
1195 if (UnderlyingType.
isNull())
1199 T->getUnderlyingType().getAsOpaquePtr())
1200 return QualType(T, 0);
1205 QualType VisitFunctionNoProtoType(
const FunctionNoProtoType *T) {
1211 return QualType(T, 0);
1216 QualType VisitFunctionProtoType(
const FunctionProtoType *T) {
1222 SmallVector<QualType, 4> paramTypes;
1223 bool paramChanged =
false;
1225 QualType newParamType = recurse(paramType);
1226 if (newParamType.
isNull())
1230 paramChanged =
true;
1232 paramTypes.push_back(newParamType);
1237 bool exceptionChanged =
false;
1239 SmallVector<QualType, 4> exceptionTypes;
1241 QualType newExceptionType = recurse(exceptionType);
1242 if (newExceptionType.
isNull())
1245 if (newExceptionType.
getAsOpaquePtr() != exceptionType.getAsOpaquePtr())
1246 exceptionChanged =
true;
1248 exceptionTypes.push_back(newExceptionType);
1251 if (exceptionChanged) {
1253 llvm::ArrayRef(exceptionTypes).copy(Ctx);
1258 !paramChanged && !exceptionChanged)
1259 return QualType(T, 0);
1264 QualType VisitParenType(
const ParenType *T) {
1270 return QualType(T, 0);
1279 QualType VisitAdjustedType(
const AdjustedType *T) {
1281 if (originalType.
isNull())
1285 if (adjustedType.
isNull())
1291 return QualType(T, 0);
1296 QualType VisitDecayedType(
const DecayedType *T) {
1298 if (originalType.
isNull())
1302 return QualType(T, 0);
1307 QualType VisitArrayParameterType(
const ArrayParameterType *T) {
1308 QualType ArrTy = VisitConstantArrayType(T);
1322 QualType VisitAttributedType(
const AttributedType *T) {
1323 QualType modifiedType = recurse(T->getModifiedType());
1324 if (modifiedType.
isNull())
1327 QualType equivalentType = recurse(T->getEquivalentType());
1328 if (equivalentType.
isNull())
1332 T->getModifiedType().getAsOpaquePtr() &&
1334 T->getEquivalentType().getAsOpaquePtr())
1335 return QualType(T, 0);
1341 QualType VisitSubstTemplateTypeParmType(
const SubstTemplateTypeParmType *T) {
1342 QualType replacementType = recurse(T->getReplacementType());
1343 if (replacementType.
isNull())
1347 T->getReplacementType().getAsOpaquePtr())
1348 return QualType(T, 0);
1351 replacementType, T->getAssociatedDecl(), T->getIndex(),
1352 T->getPackIndex(), T->getFinal());
1358 QualType VisitAutoType(
const AutoType *T) {
1359 if (!T->isDeduced())
1360 return QualType(T, 0);
1362 QualType deducedType = recurse(T->getDeducedType());
1363 if (deducedType.
isNull())
1366 if (deducedType == T->getDeducedType())
1367 return QualType(T, 0);
1369 return Ctx.
getAutoType(T->getDeducedKind(), deducedType, T->getKeyword(),
1370 T->getTypeConstraintConcept(),
1371 T->getTypeConstraintArguments());
1374 QualType VisitObjCObjectType(
const ObjCObjectType *T) {
1375 QualType baseType = recurse(T->getBaseType());
1380 bool typeArgChanged =
false;
1381 SmallVector<QualType, 4> typeArgs;
1382 for (
auto typeArg : T->getTypeArgsAsWritten()) {
1383 QualType newTypeArg = recurse(typeArg);
1388 typeArgChanged =
true;
1390 typeArgs.push_back(newTypeArg);
1393 if (baseType.
getAsOpaquePtr() == T->getBaseType().getAsOpaquePtr() &&
1395 return QualType(T, 0);
1399 llvm::ArrayRef(T->qual_begin(), T->getNumProtocols()),
1400 T->isKindOfTypeAsWritten());
1405 QualType VisitObjCObjectPointerType(
const ObjCObjectPointerType *T) {
1407 if (pointeeType.
isNull())
1411 return QualType(T, 0);
1416 QualType VisitAtomicType(
const AtomicType *T) {
1422 return QualType(T, 0);
1427#undef TRIVIAL_TYPE_CLASS
1428#undef SUGARED_TYPE_CLASS
1431struct SubstObjCTypeArgsVisitor
1432 :
public SimpleTransformVisitor<SubstObjCTypeArgsVisitor> {
1433 using BaseType = SimpleTransformVisitor<SubstObjCTypeArgsVisitor>;
1435 ArrayRef<QualType> TypeArgs;
1438 SubstObjCTypeArgsVisitor(ASTContext &ctx, ArrayRef<QualType> typeArgs,
1440 : BaseType(ctx), TypeArgs(typeArgs), SubstContext(context) {}
1442 QualType VisitObjCTypeParamType(
const ObjCTypeParamType *OTPTy) {
1445 ObjCTypeParamDecl *typeParam = OTPTy->getDecl();
1447 if (!TypeArgs.empty()) {
1448 QualType argType = TypeArgs[typeParam->
getIndex()];
1449 if (OTPTy->qual_empty())
1454 SmallVector<ObjCProtocolDecl *, 8> protocolsVec;
1455 protocolsVec.append(OTPTy->qual_begin(), OTPTy->qual_end());
1456 ArrayRef<ObjCProtocolDecl *> protocolsToApply = protocolsVec;
1458 argType, protocolsToApply, hasError,
true );
1461 switch (SubstContext) {
1462 case ObjCSubstitutionContext::Ordinary:
1463 case ObjCSubstitutionContext::Parameter:
1464 case ObjCSubstitutionContext::Superclass:
1468 case ObjCSubstitutionContext::Result:
1469 case ObjCSubstitutionContext::Property: {
1471 const auto *objPtr =
1476 if (objPtr->isKindOfType() || objPtr->isObjCIdOrClassType())
1480 const auto *obj = objPtr->getObjectType();
1482 obj->getBaseType(), obj->getTypeArgsAsWritten(), obj->getProtocols(),
1489 llvm_unreachable(
"Unexpected ObjCSubstitutionContext!");
1492 QualType VisitFunctionType(
const FunctionType *funcType) {
1498 Ctx, TypeArgs, ObjCSubstitutionContext::Result);
1508 return BaseType::VisitFunctionType(funcType);
1517 SmallVector<QualType, 4> paramTypes;
1518 bool paramChanged =
false;
1519 for (
auto paramType : funcProtoType->getParamTypes()) {
1521 Ctx, TypeArgs, ObjCSubstitutionContext::Parameter);
1522 if (newParamType.
isNull())
1526 paramChanged =
true;
1528 paramTypes.push_back(newParamType);
1532 FunctionProtoType::ExtProtoInfo info = funcProtoType->getExtProtoInfo();
1533 bool exceptionChanged =
false;
1535 SmallVector<QualType, 4> exceptionTypes;
1538 Ctx, TypeArgs, ObjCSubstitutionContext::Ordinary);
1539 if (newExceptionType.
isNull())
1542 if (newExceptionType.
getAsOpaquePtr() != exceptionType.getAsOpaquePtr())
1543 exceptionChanged =
true;
1545 exceptionTypes.push_back(newExceptionType);
1548 if (exceptionChanged) {
1550 llvm::ArrayRef(exceptionTypes).copy(Ctx);
1555 funcProtoType->getReturnType().getAsOpaquePtr() &&
1556 !paramChanged && !exceptionChanged)
1557 return BaseType::VisitFunctionType(funcType);
1562 QualType VisitObjCObjectType(
const ObjCObjectType *objcObjectType) {
1565 if (objcObjectType->isSpecializedAsWritten()) {
1566 SmallVector<QualType, 4> newTypeArgs;
1567 bool anyChanged =
false;
1568 for (
auto typeArg : objcObjectType->getTypeArgsAsWritten()) {
1570 Ctx, TypeArgs, ObjCSubstitutionContext::Ordinary);
1577 ArrayRef<ObjCProtocolDecl *> protocols(
1578 objcObjectType->qual_begin(), objcObjectType->getNumProtocols());
1579 if (TypeArgs.empty() &&
1580 SubstContext != ObjCSubstitutionContext::Superclass) {
1582 objcObjectType->getBaseType(), {}, protocols,
1583 objcObjectType->isKindOfTypeAsWritten());
1589 newTypeArgs.push_back(newTypeArg);
1593 ArrayRef<ObjCProtocolDecl *> protocols(
1594 objcObjectType->qual_begin(), objcObjectType->getNumProtocols());
1597 objcObjectType->isKindOfTypeAsWritten());
1601 return BaseType::VisitObjCObjectType(objcObjectType);
1604 QualType VisitAttributedType(
const AttributedType *attrType) {
1605 QualType newType = BaseType::VisitAttributedType(attrType);
1609 const auto *newAttrType = dyn_cast<AttributedType>(newType.
getTypePtr());
1610 if (!newAttrType || newAttrType->getAttrKind() != attr::ObjCKindOf)
1614 QualType newEquivType = newAttrType->getEquivalentType();
1615 const ObjCObjectPointerType *ptrType =
1616 newEquivType->
getAs<ObjCObjectPointerType>();
1617 const ObjCObjectType *objType = ptrType
1619 : newEquivType->
getAs<ObjCObjectType>();
1626 objType->getBaseType(), objType->getTypeArgsAsWritten(),
1627 objType->getProtocols(),
1629 objType->isObjCUnqualifiedId() ?
false :
true);
1637 newAttrType->getModifiedType(), newEquivType,
1638 newAttrType->getAttr());
1642struct StripObjCKindOfTypeVisitor
1643 :
public SimpleTransformVisitor<StripObjCKindOfTypeVisitor> {
1644 using BaseType = SimpleTransformVisitor<StripObjCKindOfTypeVisitor>;
1646 explicit StripObjCKindOfTypeVisitor(ASTContext &ctx) : BaseType(ctx) {}
1648 QualType VisitObjCObjectType(
const ObjCObjectType *objType) {
1649 if (!objType->isKindOfType())
1650 return BaseType::VisitObjCObjectType(objType);
1652 QualType baseType = objType->getBaseType().stripObjCKindOfType(Ctx);
1654 objType->getProtocols(),
1671 case BuiltinType::Kind::Float16: {
1679 case BuiltinType::Kind::BFloat16: {
1699 SubstObjCTypeArgsVisitor visitor(ctx, typeArgs, context);
1700 return visitor.recurse(*
this);
1714 auto &ctx =
const_cast<ASTContext &
>(constCtx);
1715 StripObjCKindOfTypeVisitor visitor(ctx);
1716 return visitor.recurse(*
this);
1721 if (
const auto AT = T.getTypePtr()->getAs<
AtomicType>())
1722 T = AT->getValueType();
1723 return T.getUnqualifiedType();
1726std::optional<ArrayRef<QualType>>
1729 if (
const auto method = dyn_cast<ObjCMethodDecl>(dc))
1730 dc = method->getDeclContext();
1734 const auto *dcClassDecl = dyn_cast<ObjCInterfaceDecl>(dc);
1740 dcTypeParams = dcClassDecl->getTypeParamList();
1742 return std::nullopt;
1746 dcCategoryDecl = dyn_cast<ObjCCategoryDecl>(dc);
1747 if (!dcCategoryDecl)
1748 return std::nullopt;
1754 return std::nullopt;
1758 return std::nullopt;
1760 assert(dcTypeParams &&
"No substitutions to perform");
1761 assert(dcClassDecl &&
"No class context");
1766 objectType = objectPointerType->getObjectType();
1777 objectType ? objectType->getInterface() :
nullptr;
1778 if (!curClassDecl) {
1786 while (curClassDecl != dcClassDecl) {
1788 QualType superType = objectType->getSuperClassType();
1789 if (superType.
isNull()) {
1790 objectType =
nullptr;
1795 curClassDecl = objectType->getInterface();
1800 if (!objectType || objectType->isUnspecialized()) {
1805 return objectType->getTypeArgs();
1810 if (
auto *ID = IfaceT->getInterface()) {
1811 if (ID->getTypeParamList())
1819void ObjCObjectType::computeSuperClassTypeSlow()
const {
1825 CachedSuperClassType.setInt(
true);
1831 if (!superClassObjTy) {
1832 CachedSuperClassType.setInt(
true);
1837 if (!superClassDecl) {
1838 CachedSuperClassType.setInt(
true);
1844 QualType superClassType(superClassObjTy, 0);
1846 if (!superClassTypeParams) {
1847 CachedSuperClassType.setPointerAndInt(
1848 superClassType->castAs<ObjCObjectType>(),
true);
1853 if (superClassObjTy->isUnspecialized()) {
1854 CachedSuperClassType.setPointerAndInt(superClassObjTy,
true);
1862 CachedSuperClassType.setPointerAndInt(
1863 superClassType->castAs<ObjCObjectType>(),
true);
1869 if (isUnspecialized()) {
1872 superClassObjTy->getInterface());
1873 CachedSuperClassType.setPointerAndInt(
1874 unspecializedSuper->
castAs<ObjCObjectType>(),
true);
1880 assert(typeArgs.size() == typeParams->
size());
1881 CachedSuperClassType.setPointerAndInt(
1885 ->castAs<ObjCObjectType>(),
1891 return interfaceDecl->getASTContext()
1892 .getObjCInterfaceType(interfaceDecl)
1901 if (superObjectType.
isNull())
1902 return superObjectType;
1913 if (T->getNumProtocols() && T->getInterface())
1926 if (OPT->isObjCQualifiedIdType())
1936 if (OPT->isObjCQualifiedClassType())
1944 if (OT->getInterface())
1952 if (OPT->getInterfaceType())
1969const TemplateSpecializationType *
1972 while (TST && TST->isTypeAlias())
1973 TST = TST->desugar()->getAs<TemplateSpecializationType>();
1979 case Type::DependentName:
1981 case Type::TemplateSpecialization:
1987 case Type::InjectedClassName:
1991 case Type::UnresolvedUsing:
1996 return std::nullopt;
2001 const Type *Cur =
this;
2002 while (
const auto *AT = Cur->
getAs<AttributedType>()) {
2003 if (AT->getAttrKind() == AK)
2005 Cur = AT->getEquivalentType().getTypePtr();
2012class GetContainedDeducedTypeVisitor
2013 :
public TypeVisitor<GetContainedDeducedTypeVisitor, Type *> {
2017 GetContainedDeducedTypeVisitor(
bool Syntactic =
false)
2018 : Syntactic(Syntactic) {}
2025 return Visit(T.getTypePtr());
2029 Type *VisitDeducedType(
const DeducedType *AT) {
2030 return const_cast<DeducedType *
>(AT);
2034 Type *VisitSubstTemplateTypeParmType(
const SubstTemplateTypeParmType *T) {
2035 return Visit(T->getReplacementType());
2038 Type *VisitPointerType(
const PointerType *T) {
2042 Type *VisitBlockPointerType(
const BlockPointerType *T) {
2046 Type *VisitReferenceType(
const ReferenceType *T) {
2050 Type *VisitMemberPointerType(
const MemberPointerType *T) {
2054 Type *VisitArrayType(
const ArrayType *T) {
2058 Type *VisitDependentSizedExtVectorType(
const DependentSizedExtVectorType *T) {
2062 Type *VisitVectorType(
const VectorType *T) {
2066 Type *VisitDependentSizedMatrixType(
const DependentSizedMatrixType *T) {
2070 Type *VisitConstantMatrixType(
const ConstantMatrixType *T) {
2074 Type *VisitFunctionProtoType(
const FunctionProtoType *T) {
2076 return const_cast<FunctionProtoType *
>(T);
2077 return VisitFunctionType(T);
2080 Type *VisitFunctionType(
const FunctionType *T) {
2084 Type *VisitParenType(
const ParenType *T) {
return Visit(T->
getInnerType()); }
2086 Type *VisitAttributedType(
const AttributedType *T) {
2087 return Visit(T->getModifiedType());
2090 Type *VisitMacroQualifiedType(
const MacroQualifiedType *T) {
2094 Type *VisitOverflowBehaviorType(
const OverflowBehaviorType *T) {
2095 return Visit(T->getUnderlyingType());
2098 Type *VisitAdjustedType(
const AdjustedType *T) {
2102 Type *VisitPackExpansionType(
const PackExpansionType *T) {
2103 return Visit(T->getPattern());
2110 return cast_or_null<DeducedType>(
2111 GetContainedDeducedTypeVisitor().Visit(
this));
2115 return isa_and_nonnull<FunctionType>(
2116 GetContainedDeducedTypeVisitor(
true).Visit(
this));
2120 if (
const auto *VT = dyn_cast<VectorType>(CanonicalType))
2121 return VT->getElementType()->isIntegerType();
2122 if (CanonicalType->isSveVLSBuiltinType()) {
2124 return VT->getKind() == BuiltinType::SveBool ||
2125 (VT->getKind() >= BuiltinType::SveInt8 &&
2126 VT->getKind() <= BuiltinType::SveUint64);
2128 if (CanonicalType->isRVVVLSBuiltinType()) {
2130 return (VT->getKind() >= BuiltinType::RvvInt8mf8 &&
2131 VT->getKind() <= BuiltinType::RvvUint64m8);
2157 if (
const auto *BT = dyn_cast<BuiltinType>(CanonicalType))
2158 return BT->isInteger();
2162 if (
const auto *ET = dyn_cast<EnumType>(CanonicalType))
2165 if (
const OverflowBehaviorType *OBT =
2166 dyn_cast<OverflowBehaviorType>(CanonicalType))
2167 return OBT->getUnderlyingType()->isIntegralOrEnumerationType();
2174 if (
const auto *BT = dyn_cast<BuiltinType>(CanonicalType))
2175 return BT->isInteger();
2177 if (
const auto *OBT = dyn_cast<OverflowBehaviorType>(CanonicalType))
2178 return OBT->getUnderlyingType()->isIntegerType();
2187 if (
const auto *ET = dyn_cast<EnumType>(CanonicalType))
2188 return !ET->getDecl()->isScoped();
2194 if (
const auto *BT = dyn_cast<BuiltinType>(CanonicalType))
2195 return BT->getKind() == BuiltinType::Char_U ||
2196 BT->getKind() == BuiltinType::UChar ||
2197 BT->getKind() == BuiltinType::Char_S ||
2198 BT->getKind() == BuiltinType::SChar;
2203 if (
const auto *BT = dyn_cast<BuiltinType>(CanonicalType))
2204 return BT->getKind() == BuiltinType::WChar_S ||
2205 BT->getKind() == BuiltinType::WChar_U;
2210 if (
const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType))
2211 return BT->getKind() == BuiltinType::Char8;
2216 if (
const auto *BT = dyn_cast<BuiltinType>(CanonicalType))
2217 return BT->getKind() == BuiltinType::Char16;
2222 if (
const auto *BT = dyn_cast<BuiltinType>(CanonicalType))
2223 return BT->getKind() == BuiltinType::Char32;
2230 const auto *BT = dyn_cast<BuiltinType>(CanonicalType);
2233 switch (BT->getKind()) {
2236 case BuiltinType::Char_U:
2237 case BuiltinType::UChar:
2238 case BuiltinType::WChar_U:
2239 case BuiltinType::Char8:
2240 case BuiltinType::Char16:
2241 case BuiltinType::Char32:
2242 case BuiltinType::Char_S:
2243 case BuiltinType::SChar:
2244 case BuiltinType::WChar_S:
2250 const auto *BT = dyn_cast<BuiltinType>(CanonicalType);
2253 switch (BT->getKind()) {
2256 case BuiltinType::Char8:
2257 case BuiltinType::Char16:
2258 case BuiltinType::Char32:
2267 if (
const auto *BT = dyn_cast<BuiltinType>(CanonicalType))
2268 return BT->isSignedInteger();
2273 if (!ED->isComplete() || ED->isScoped())
2275 return ED->getIntegerType()->isSignedIntegerType();
2278 if (
const auto *IT = dyn_cast<BitIntType>(CanonicalType))
2279 return IT->isSigned();
2280 if (
const auto *IT = dyn_cast<DependentBitIntType>(CanonicalType))
2281 return IT->isSigned();
2283 if (
const auto *OBT = dyn_cast<OverflowBehaviorType>(CanonicalType))
2284 return OBT->getUnderlyingType()->isSignedIntegerType();
2290 if (
const auto *BT = dyn_cast<BuiltinType>(CanonicalType))
2291 return BT->isSignedInteger();
2294 if (!ED->isComplete())
2296 return ED->getIntegerType()->isSignedIntegerType();
2299 if (
const auto *IT = dyn_cast<BitIntType>(CanonicalType))
2300 return IT->isSigned();
2301 if (
const auto *IT = dyn_cast<DependentBitIntType>(CanonicalType))
2302 return IT->isSigned();
2304 if (
const auto *OBT = dyn_cast<OverflowBehaviorType>(CanonicalType))
2305 return OBT->getUnderlyingType()->isSignedIntegerOrEnumerationType();
2311 if (
const auto *VT = dyn_cast<VectorType>(CanonicalType))
2312 return VT->getElementType()->isSignedIntegerOrEnumerationType();
2314 if (
const auto *BT = dyn_cast<BuiltinType>(CanonicalType)) {
2315 switch (BT->getKind()) {
2316#define SVE_VECTOR_TYPE_INT(Name, MangledName, Id, SingletonId, NumEls, \
2317 ElBits, NF, IsSigned) \
2318 case BuiltinType::Id: \
2320#include "clang/Basic/AArch64ACLETypes.def"
2333 if (
const auto *BT = dyn_cast<BuiltinType>(CanonicalType))
2334 return BT->isUnsignedInteger();
2339 if (!ED->isComplete() || ED->isScoped())
2341 return ED->getIntegerType()->isUnsignedIntegerType();
2344 if (
const auto *IT = dyn_cast<BitIntType>(CanonicalType))
2345 return IT->isUnsigned();
2346 if (
const auto *IT = dyn_cast<DependentBitIntType>(CanonicalType))
2347 return IT->isUnsigned();
2349 if (
const auto *OBT = dyn_cast<OverflowBehaviorType>(CanonicalType))
2350 return OBT->getUnderlyingType()->isUnsignedIntegerType();
2356 if (
const auto *BT = dyn_cast<BuiltinType>(CanonicalType))
2357 return BT->isUnsignedInteger();
2360 if (!ED->isComplete())
2362 return ED->getIntegerType()->isUnsignedIntegerType();
2365 if (
const auto *IT = dyn_cast<BitIntType>(CanonicalType))
2366 return IT->isUnsigned();
2367 if (
const auto *IT = dyn_cast<DependentBitIntType>(CanonicalType))
2368 return IT->isUnsigned();
2370 if (
const auto *OBT = dyn_cast<OverflowBehaviorType>(CanonicalType))
2371 return OBT->getUnderlyingType()->isUnsignedIntegerOrEnumerationType();
2377 if (
const auto *VT = dyn_cast<VectorType>(CanonicalType))
2378 return VT->getElementType()->isUnsignedIntegerOrEnumerationType();
2379 if (
const auto *VT = dyn_cast<MatrixType>(CanonicalType))
2380 return VT->getElementType()->isUnsignedIntegerOrEnumerationType();
2381 if (CanonicalType->isSveVLSBuiltinType()) {
2383 return VT->getKind() >= BuiltinType::SveUint8 &&
2384 VT->getKind() <= BuiltinType::SveUint64;
2390 if (
const auto *BT = dyn_cast<BuiltinType>(CanonicalType))
2391 return BT->isFloatingPoint();
2392 if (
const auto *CT = dyn_cast<ComplexType>(CanonicalType))
2393 return CT->getElementType()->isFloatingType();
2398 if (
const auto *VT = dyn_cast<VectorType>(CanonicalType))
2399 return VT->getElementType()->isFloatingType();
2400 if (
const auto *MT = dyn_cast<MatrixType>(CanonicalType))
2401 return MT->getElementType()->isFloatingType();
2406 if (
const auto *BT = dyn_cast<BuiltinType>(CanonicalType))
2407 return BT->isFloatingPoint();
2412 if (
const auto *BT = dyn_cast<BuiltinType>(CanonicalType))
2413 return BT->getKind() >= BuiltinType::Bool &&
2414 BT->getKind() <= BuiltinType::Ibm128;
2415 if (
const auto *ET = dyn_cast<EnumType>(CanonicalType)) {
2416 const auto *ED = ET->getDecl();
2417 return !ED->isScoped() && ED->getDefinitionOrSelf()->isComplete();
2423 if (
const auto *BT = dyn_cast<BuiltinType>(CanonicalType))
2424 return BT->getKind() >= BuiltinType::Bool &&
2425 BT->getKind() <= BuiltinType::Ibm128;
2426 if (
const auto *ET = dyn_cast<EnumType>(CanonicalType)) {
2433 const auto *ED = ET->getDecl();
2434 return !ED->isScoped() && ED->getDefinitionOrSelf()->isComplete();
2445 if (
const auto *VT = dyn_cast<VectorType>(CanonicalType))
2446 return VT->getElementType()->isBooleanType();
2448 return ED->isComplete() && ED->getIntegerType()->isBooleanType();
2449 if (
const auto *IT = dyn_cast<BitIntType>(CanonicalType))
2450 return IT->getNumBits() == 1;
2457 const Type *T = CanonicalType.getTypePtr();
2458 if (
const auto *BT = dyn_cast<BuiltinType>(T)) {
2459 if (BT->getKind() == BuiltinType::Bool)
2461 if (BT->getKind() == BuiltinType::NullPtr)
2463 if (BT->isInteger())
2465 if (BT->isFloatingPoint())
2467 if (BT->isFixedPointType())
2469 llvm_unreachable(
"unknown scalar builtin type");
2479 assert(T->castAsEnumDecl()->isComplete());
2481 }
else if (
const auto *CT = dyn_cast<ComplexType>(T)) {
2482 if (CT->getElementType()->isRealFloatingType())
2491 llvm_unreachable(
"unknown scalar type");
2504 if (
const auto *
Record = dyn_cast<RecordType>(CanonicalType)) {
2505 if (
const auto *ClassDecl = dyn_cast<CXXRecordDecl>(
Record->getDecl()))
2506 return ClassDecl->isAggregate();
2518 assert(!
isIncompleteType() &&
"This doesn't make sense for incomplete types");
2519 assert(!
isDependentType() &&
"This doesn't make sense for dependent types");
2531 switch (CanonicalType->getTypeClass()) {
2542 return !EnumD->isComplete();
2550 return !Rec->isCompleteDefinition();
2552 case InjectedClassName: {
2554 if (!Rec->isBeingDefined())
2568 ->isIncompleteType(Def);
2569 case IncompleteArray:
2572 case MemberPointer: {
2585 if (!Context.getTargetInfo().getCXXABI().isMicrosoft())
2588 if (RD->
hasAttr<MSInheritanceAttr>())
2595 ->isIncompleteType(Def);
2596 case ObjCInterface: {
2628 switch (BT->getKind()) {
2630#define WASM_TYPE(Name, Id, SingletonId) case BuiltinType::Id:
2631#include "clang/Basic/WebAssemblyReferenceTypes.def"
2633#define HLSL_INTANGIBLE_TYPE(Name, Id, SingletonId) case BuiltinType::Id:
2634#include "clang/Basic/HLSLIntangibleTypes.def"
2636 case BuiltinType::AMDGPUFeaturePredicate:
2647 return BT->getKind() == BuiltinType::WasmExternRef;
2652 if (
const auto *ATy = dyn_cast<ArrayType>(
this))
2653 return ATy->getElementType().isWebAssemblyReferenceType();
2655 if (
const auto *PTy = dyn_cast<PointerType>(
this))
2656 return PTy->getPointeeType().isWebAssemblyReferenceType();
2669 switch (BT->getKind()) {
2671#define SVE_VECTOR_TYPE(Name, MangledName, Id, SingletonId) \
2672 case BuiltinType::Id: \
2674#define SVE_OPAQUE_TYPE(Name, MangledName, Id, SingletonId) \
2675 case BuiltinType::Id: \
2677#define SVE_PREDICATE_TYPE(Name, MangledName, Id, SingletonId) \
2678 case BuiltinType::Id: \
2680#include "clang/Basic/AArch64ACLETypes.def"
2690 switch (BT->getKind()) {
2691#define RVV_TYPE(Name, Id, SingletonId) case BuiltinType::Id:
2692#include "clang/Basic/RISCVVTypes.def"
2703 switch (BT->getKind()) {
2704 case BuiltinType::SveInt8:
2705 case BuiltinType::SveInt16:
2706 case BuiltinType::SveInt32:
2707 case BuiltinType::SveInt64:
2708 case BuiltinType::SveUint8:
2709 case BuiltinType::SveUint16:
2710 case BuiltinType::SveUint32:
2711 case BuiltinType::SveUint64:
2712 case BuiltinType::SveFloat16:
2713 case BuiltinType::SveFloat32:
2714 case BuiltinType::SveFloat64:
2715 case BuiltinType::SveBFloat16:
2716 case BuiltinType::SveBool:
2717 case BuiltinType::SveBoolx2:
2718 case BuiltinType::SveBoolx4:
2719 case BuiltinType::SveMFloat8:
2737 llvm_unreachable(
"Unhandled type");
2744 if (BTy->
getKind() == BuiltinType::SveBool)
2755 switch (BT->getKind()) {
2756#define RVV_VECTOR_TYPE(Name, Id, SingletonId, NumEls, ElBits, NF, IsSigned, \
2758 case BuiltinType::Id: \
2760#define RVV_PREDICATE_TYPE(Name, Id, SingletonId, NumEls) \
2761 case BuiltinType::Id: \
2763#include "clang/Basic/RISCVVTypes.def"
2777#define RVV_PREDICATE_TYPE(Name, Id, SingletonId, NumEls) \
2778 case BuiltinType::Id: \
2779 return Ctx.UnsignedCharTy;
2782#include "clang/Basic/RISCVVTypes.def"
2785 llvm_unreachable(
"Unhandled type");
2789 if (Context.getLangOpts().HLSL &&
2790 getTypePtr()->isHLSLStandardLayoutRecordOrArrayOf())
2794 if (Context.getLangOpts().CPlusPlus11)
2807 if ((*this)->isIncompleteArrayType())
2808 return Context.getBaseElementType(*this).isCXX98PODType(Context);
2810 if ((*this)->isIncompleteType())
2819 if (Context.containsAddressDiscriminatedPointerAuth(CanonicalType))
2826 case Type::VariableArray:
2827 case Type::ConstantArray:
2829 return Context.getBaseElementType(*this).isCXX98PODType(Context);
2831 case Type::ObjCObjectPointer:
2832 case Type::BlockPointer:
2836 case Type::MemberPointer:
2838 case Type::ExtVector:
2840 case Type::OverflowBehavior:
2847 if (
const auto *ClassDecl =
2849 return ClassDecl->isPOD();
2863 if ((*this)->isArrayType())
2864 return Context.getBaseElementType(*this).isTrivialType(Context);
2866 if ((*this)->isSizelessBuiltinType())
2871 if ((*this)->isIncompleteType())
2883 if (Context.containsAddressDiscriminatedPointerAuth(CanonicalType))
2902 return ClassDecl->hasTrivialDefaultConstructor() &&
2903 !ClassDecl->hasNonTrivialDefaultConstructor() &&
2904 ClassDecl->isTriviallyCopyable();
2916 bool IsCopyConstructible) {
2917 if (
type->isArrayType())
2919 Context, IsCopyConstructible);
2921 if (
type.hasNonTrivialObjCLifetime())
2955 if (
const auto *ClassDecl = dyn_cast<CXXRecordDecl>(RD)) {
2956 if (IsCopyConstructible)
2957 return ClassDecl->isTriviallyCopyConstructible();
2958 return ClassDecl->isTriviallyCopyable();
2960 return !RD->isNonTrivialToPrimitiveCopy();
2974 if (CanonicalType.hasNonTrivialObjCLifetime())
2976 if (CanonicalType->isArrayType())
2977 return Context.getBaseElementType(CanonicalType)
2978 .isBitwiseCloneableType(Context);
2980 if (CanonicalType->isIncompleteType())
2985 if (Context.containsAddressDiscriminatedPointerAuth(CanonicalType))
2988 const auto *RD = CanonicalType->getAsRecordDecl();
2992 if (RD->isInvalidDecl())
2998 if (RD->mayInsertExtraPadding())
3001 for (
auto *
const Field : RD->fields()) {
3002 if (!Field->getType().isBitwiseCloneableType(Context))
3006 if (
const auto *CXXRD = dyn_cast<CXXRecordDecl>(RD)) {
3007 for (
auto Base : CXXRD->bases())
3008 if (!
Base.getType().isBitwiseCloneableType(Context))
3010 for (
auto VBase : CXXRD->vbases())
3011 if (!VBase.getType().isBitwiseCloneableType(Context))
3024 return !Context.getLangOpts().ObjCAutoRefCount &&
3025 Context.getLangOpts().ObjCWeak &&
3058 return OBT->getBehaviorKind() ==
3059 OverflowBehaviorType::OverflowBehaviorKind::Wrap;
3066 return OBT->getBehaviorKind() ==
3067 OverflowBehaviorType::OverflowBehaviorKind::Trap;
3074 if (
const auto *RD =
3090 if (
const auto *RD =
3130 assert(BaseTy &&
"NULL element type");
3164 if (
const auto *ClassDecl = dyn_cast<CXXRecordDecl>(RD))
3165 return ClassDecl->isLiteral();
3172 return AT->getValueType()->isLiteralType(Ctx);
3174 if (
const auto *OBT = BaseTy->
getAs<OverflowBehaviorType>())
3175 return OBT->getUnderlyingType()->isLiteralType(Ctx);
3197 return RD->isStructural();
3210 assert(BaseTy &&
"NULL element type");
3221 if (
const auto *ClassDecl = dyn_cast<CXXRecordDecl>(RD);
3222 ClassDecl && !ClassDecl->isStandardLayout())
3250 assert(BaseTy &&
"NULL element type");
3261 if (Context.containsAddressDiscriminatedPointerAuth(*
this))
3268 if (
const auto *ClassDecl = dyn_cast<CXXRecordDecl>(RD)) {
3271 if (!ClassDecl->isTrivial())
3277 if (!ClassDecl->isStandardLayout())
3308 const auto *ED = ET->getDecl();
3310 if (II && II->
isStr(
"align_val_t") && ED->isInStdNamespace())
3318 const auto *ED = ET->getDecl();
3320 if (II && II->
isStr(
"byte") && ED->isInStdNamespace())
3336 case TemplateTypeParm:
3337 case SubstTemplateTypeParm:
3338 case TemplateSpecialization:
3381 llvm_unreachable(
"Type specifier is not a tag type kind.");
3398 llvm_unreachable(
"Unknown tag type kind.");
3416 llvm_unreachable(
"Elaborated type keyword is not a tag type kind.");
3418 llvm_unreachable(
"Unknown elaborated type keyword.");
3433 llvm_unreachable(
"Unknown elaborated type keyword.");
3447 return "__interface";
3454 llvm_unreachable(
"Unknown elaborated type keyword.");
3459 if (
const auto *TST = dyn_cast<TemplateSpecializationType>(
this))
3461 else if (
const auto *DepName = dyn_cast<DependentNameType>(
this))
3462 Keyword = DepName->getKeyword();
3463 else if (
const auto *T = dyn_cast<TagType>(
this))
3465 else if (
const auto *T = dyn_cast<TypedefType>(
this))
3467 else if (
const auto *T = dyn_cast<UnresolvedUsingType>(
this))
3469 else if (
const auto *T = dyn_cast<UsingType>(
this))
3479#define ABSTRACT_TYPE(Derived, Base)
3480#define TYPE(Derived, Base) \
3483#include "clang/AST/TypeNodes.inc"
3486 llvm_unreachable(
"Invalid type class.");
3494 return Policy.
Bool ?
"bool" :
"_Bool";
3500 return "signed char";
3512 return "unsigned char";
3514 return "unsigned short";
3516 return "unsigned int";
3518 return "unsigned long";
3520 return "unsigned long long";
3522 return "unsigned __int128";
3524 return Policy.
Half ?
"half" :
"__fp16";
3532 return "long double";
3534 return "short _Accum";
3538 return "long _Accum";
3540 return "unsigned short _Accum";
3542 return "unsigned _Accum";
3544 return "unsigned long _Accum";
3545 case BuiltinType::ShortFract:
3546 return "short _Fract";
3547 case BuiltinType::Fract:
3549 case BuiltinType::LongFract:
3550 return "long _Fract";
3551 case BuiltinType::UShortFract:
3552 return "unsigned short _Fract";
3553 case BuiltinType::UFract:
3554 return "unsigned _Fract";
3555 case BuiltinType::ULongFract:
3556 return "unsigned long _Fract";
3557 case BuiltinType::SatShortAccum:
3558 return "_Sat short _Accum";
3559 case BuiltinType::SatAccum:
3560 return "_Sat _Accum";
3561 case BuiltinType::SatLongAccum:
3562 return "_Sat long _Accum";
3563 case BuiltinType::SatUShortAccum:
3564 return "_Sat unsigned short _Accum";
3565 case BuiltinType::SatUAccum:
3566 return "_Sat unsigned _Accum";
3567 case BuiltinType::SatULongAccum:
3568 return "_Sat unsigned long _Accum";
3569 case BuiltinType::SatShortFract:
3570 return "_Sat short _Fract";
3571 case BuiltinType::SatFract:
3572 return "_Sat _Fract";
3573 case BuiltinType::SatLongFract:
3574 return "_Sat long _Fract";
3575 case BuiltinType::SatUShortFract:
3576 return "_Sat unsigned short _Fract";
3577 case BuiltinType::SatUFract:
3578 return "_Sat unsigned _Fract";
3579 case BuiltinType::SatULongFract:
3580 return "_Sat unsigned long _Fract";
3584 return "__float128";
3589 return Policy.
MSWChar ?
"__wchar_t" :
"wchar_t";
3599 return "<overloaded function type>";
3601 return "<bound member function type>";
3602 case UnresolvedTemplate:
3603 return "<unresolved template type>";
3605 return "<pseudo-object type>";
3607 return "<dependent type>";
3609 return "<unknown type>";
3610 case ARCUnbridgedCast:
3611 return "<ARC unbridged cast type>";
3613 return "<builtin fn type>";
3620#define IMAGE_TYPE(ImgType, Id, SingletonId, Access, Suffix) \
3622 return "__" #Access " " #ImgType "_t";
3623#include "clang/Basic/OpenCLImageTypes.def"
3629 return "clk_event_t";
3633 return "reserve_id_t";
3634 case IncompleteMatrixIdx:
3635 return "<incomplete matrix index type>";
3637 return "<array section type>";
3638 case OMPArrayShaping:
3639 return "<OpenMP array shaping type>";
3641 return "<OpenMP iterator type>";
3642#define EXT_OPAQUE_TYPE(ExtType, Id, Ext) \
3645#include "clang/Basic/OpenCLExtensionTypes.def"
3646#define SVE_TYPE(Name, Id, SingletonId) \
3649#include "clang/Basic/AArch64ACLETypes.def"
3650#define PPC_VECTOR_TYPE(Name, Id, Size) \
3653#include "clang/Basic/PPCTypes.def"
3654#define RVV_TYPE(Name, Id, SingletonId) \
3657#include "clang/Basic/RISCVVTypes.def"
3658#define WASM_TYPE(Name, Id, SingletonId) \
3661#include "clang/Basic/WebAssemblyReferenceTypes.def"
3662#define AMDGPU_TYPE(Name, Id, SingletonId, Width, Align) \
3665#include "clang/Basic/AMDGPUTypes.def"
3666#define HLSL_INTANGIBLE_TYPE(Name, Id, SingletonId) \
3669#include "clang/Basic/HLSLIntangibleTypes.def"
3672 llvm_unreachable(
"Invalid builtin type.");
3677 if (
auto *PET = dyn_cast<PackExpansionType>(
getTypePtr()))
3678 return PET->getPattern();
3683 if (
const auto *RefType =
getTypePtr()->getAs<ReferenceType>())
3691 if (!Context.getLangOpts().CPlusPlus ||
3700 return FPT->hasCFIUncheckedCallee();
3717 return "vectorcall";
3729 return "aarch64_vector_pcs";
3731 return "aarch64_sve_pcs";
3733 return "intel_ocl_bicc";
3735 return "spir_function";
3737 return "device_kernel";
3741 return "swiftasynccall";
3743 return "preserve_most";
3745 return "preserve_all";
3749 return "preserve_none";
3752#define CC_VLS_CASE(ABI_VLEN) \
3753 case CC_RISCVVLSCall_##ABI_VLEN: return "riscv_vls_cc(" #ABI_VLEN ")";
3770 llvm_unreachable(
"Invalid calling convention.");
3788 assert(
getNumParams() == params.size() &&
"NumParams overflow!");
3797 auto &ExtraBits = *getTrailingObjects<FunctionTypeExtraBitfields>();
3805 auto &ExtraAttrInfo = *getTrailingObjects<FunctionTypeExtraAttributeInfo>();
3809 auto &ExtraBits = *getTrailingObjects<FunctionTypeExtraBitfields>();
3810 ExtraBits.HasExtraAttributeInfo =
true;
3814 auto &ArmTypeAttrs = *getTrailingObjects<FunctionTypeArmAttributes>();
3815 ArmTypeAttrs = FunctionTypeArmAttributes();
3818 auto &ExtraBits = *getTrailingObjects<FunctionTypeExtraBitfields>();
3819 ExtraBits.HasArmTypeAttributes =
true;
3823 auto *argSlot = getTrailingObjects<QualType>();
3826 ~TypeDependence::VariablyModified);
3827 argSlot[i] = params[i];
3832 auto &ArmTypeAttrs = *getTrailingObjects<FunctionTypeArmAttributes>();
3834 "Not enough bits to encode SME attributes");
3840 auto &ExtraBits = *getTrailingObjects<FunctionTypeExtraBitfields>();
3842 assert(NumExceptions <= 1023 &&
"Not enough bits to encode exceptions");
3843 ExtraBits.NumExceptionType = NumExceptions;
3845 assert(hasExtraBitfields() &&
"missing trailing extra bitfields!");
3847 reinterpret_cast<QualType *
>(getTrailingObjects<ExceptionType>());
3855 (TypeDependence::Instantiation | TypeDependence::UnexpandedPack));
3857 exnSlot[I++] = ExceptionType;
3871 (TypeDependence::Instantiation | TypeDependence::UnexpandedPack));
3877 auto **slot = getTrailingObjects<FunctionDecl *>();
3885 auto **slot = getTrailingObjects<FunctionDecl *>();
3904 auto *extParamInfos = getTrailingObjects<ExtParameterInfo>();
3911 *getTrailingObjects<Qualifiers>() = epi.
TypeQuals;
3918 auto &EllipsisLoc = *getTrailingObjects<SourceLocation>();
3923 auto &ExtraBits = *getTrailingObjects<FunctionTypeExtraBitfields>();
3925 ExtraBits.NumFunctionEffects = EffectsCount;
3926 assert(ExtraBits.NumFunctionEffects == EffectsCount &&
3927 "effect bitfield overflow");
3930 auto *DestFX = getTrailingObjects<FunctionEffect>();
3931 llvm::uninitialized_copy(SrcFX, DestFX);
3934 if (!SrcConds.empty()) {
3935 ExtraBits.EffectsHaveConditions =
true;
3936 auto *DestConds = getTrailingObjects<EffectConditionExpr>();
3937 llvm::uninitialized_copy(SrcConds, DestConds);
3938 assert(llvm::any_of(SrcConds,
3939 [](
const EffectConditionExpr &EC) {
3941 return E->isTypeDependent() ||
3942 E->isValueDependent();
3945 "expected a dependent expression among the conditions");
3953 return NE->isValueDependent();
3965 return NE->isInstantiationDependent();
3976 llvm_unreachable(
"should not call this with unresolved exception specs");
4002 llvm_unreachable(
"unexpected exception specification kind");
4006 for (
unsigned ArgIdx =
getNumParams(); ArgIdx; --ArgIdx)
4014 const QualType *ArgTys,
unsigned NumParams,
4015 const ExtProtoInfo &epi,
4039 ID.AddPointer(
Result.getAsOpaquePtr());
4040 for (
unsigned i = 0; i != NumParams; ++i)
4041 ID.AddPointer(ArgTys[i].getAsOpaquePtr());
4045 assert(!(
unsigned(epi.Variadic) & ~1) && !(
unsigned(epi.RefQualifier) & ~3) &&
4046 !(
unsigned(epi.ExceptionSpec.Type) & ~15) &&
4047 "Values larger than expected.");
4048 ID.AddInteger(
unsigned(epi.Variadic) + (epi.RefQualifier << 1) +
4049 (epi.ExceptionSpec.Type << 3));
4050 ID.Add(epi.TypeQuals);
4052 for (
QualType Ex : epi.ExceptionSpec.Exceptions)
4055 epi.ExceptionSpec.NoexceptExpr->Profile(ID, Context, Canonical);
4058 ID.AddPointer(epi.ExceptionSpec.SourceDecl->getCanonicalDecl());
4060 if (epi.ExtParameterInfos) {
4061 for (
unsigned i = 0; i != NumParams; ++i)
4062 ID.AddInteger(epi.ExtParameterInfos[i].getOpaqueValue());
4065 epi.ExtInfo.Profile(ID);
4066 epi.ExtraAttributeInfo.Profile(ID);
4068 unsigned EffectCount = epi.FunctionEffects.size();
4069 bool HasConds = !epi.FunctionEffects.Conditions.empty();
4071 ID.AddInteger((EffectCount << 3) | (HasConds << 2) |
4072 (epi.AArch64SMEAttributes << 1) | epi.HasTrailingReturn);
4073 ID.AddInteger(epi.CFIUncheckedCallee);
4075 for (
unsigned Idx = 0; Idx != EffectCount; ++Idx) {
4076 ID.AddInteger(epi.FunctionEffects.Effects[Idx].toOpaqueInt32());
4078 ID.AddPointer(epi.FunctionEffects.Conditions[Idx].getCondition());
4089 : Data(D, Deref << DerefShift) {}
4092 return Data.getInt() & DerefMask;
4097 return Data.getOpaqueValue();
4104 Data.setFromOpaqueValue(
V);
4107OverflowBehaviorType::OverflowBehaviorType(
4109 OverflowBehaviorType::OverflowBehaviorKind Kind)
4110 :
Type(OverflowBehavior, Canon, Underlying->getDependence()),
4111 UnderlyingType(Underlying), BehaviorKind(Kind) {}
4117CountAttributedType::CountAttributedType(
4121 CountExpr(CountExpr) {
4125 auto *DeclSlot = getTrailingObjects();
4126 llvm::copy(CoupledDecls, DeclSlot);
4135#define ENUMERATE_ATTRS(PREFIX) \
4137 if (isCountInBytes()) { \
4139 return PREFIX "sized_by_or_null"; \
4140 return PREFIX "sized_by"; \
4143 return PREFIX "counted_by_or_null"; \
4144 return PREFIX "counted_by"; \
4147 if (WithMacroPrefix)
4152#undef ENUMERATE_ATTRS
4158 bool HasTypeDifferentFromDecl)
4160 Keyword, TC, UnderlyingType.getCanonicalType(),
4164 ~NestedNameSpecifierDependence::
Dependent)
4168 *getTrailingObjects<NestedNameSpecifier>() = Qualifier;
4169 if ((
TypedefBits.hasTypeDifferentFromDecl = HasTypeDifferentFromDecl))
4170 *getTrailingObjects<QualType>() = UnderlyingType;
4175 : *getTrailingObjects<QualType>();
4181 const Type *CanonicalType)
4187 ~NestedNameSpecifierDependence::
Dependent)
4191 *getTrailingObjects<NestedNameSpecifier>() = Qualifier;
4200 if ((
UsingBits.hasQualifier = !!Qualifier))
4201 *getTrailingObjects() = Qualifier;
4210 while (
auto *InnerMQT = dyn_cast<MacroQualifiedType>(Inner)) {
4213 Inner = InnerMQT->getModifiedType();
4224 ? Context.getUnqualifiedArrayType(Can).getAtomicUnqualifiedType()
4229 TOExpr(E), Context(Context) {
4230 TypeOfBits.Kind =
static_cast<unsigned>(Kind);
4239 ? Context.getUnqualifiedArrayType(QT).getAtomicUnqualifiedType()
4248 E->
Profile(ID, Context,
true);
4249 ID.AddBoolean(IsUnqual);
4256 ? Context.getUnqualifiedArrayType(Can).getAtomicUnqualifiedType()
4258 T->getDependence()),
4259 TOType(T), Context(Context) {
4260 TypeOfBits.Kind =
static_cast<unsigned>(Kind);
4263QualType TypeOfType::desugar()
const {
4266 ? Context.getUnqualifiedArrayType(QT).getAtomicUnqualifiedType()
4274 :
Type(Decltype, can,
4278 (E->
getType()->getDependence() &
4280 E(E), UnderlyingType(underlyingType) {}
4282bool DecltypeType::isSugared()
const {
return !E->isInstantiationDependent(); }
4284QualType DecltypeType::desugar()
const {
4291DependentDecltypeType::DependentDecltypeType(
Expr *E)
4294void DependentDecltypeType::Profile(llvm::FoldingSetNodeID &ID,
4296 E->
Profile(ID, Context,
true);
4300 Expr *IndexExpr,
bool FullySubstituted,
4302 :
Type(PackIndexing, Canonical,
4304 Pattern(Pattern), IndexExpr(IndexExpr),
Size(Expansions.size()),
4305 FullySubstituted(FullySubstituted) {
4307 llvm::uninitialized_copy(Expansions, getTrailingObjects());
4311 if (isInstantiationDependentType())
4312 return std::nullopt;
4314 ConstantExpr *CE = dyn_cast<ConstantExpr>(getIndexExpr());
4316 return std::nullopt;
4318 assert(Index.isNonNegative() &&
"Invalid index");
4319 return static_cast<unsigned>(Index.getExtValue());
4323PackIndexingType::computeDependence(
QualType Pattern,
Expr *IndexExpr,
4328 ? TypeDependence::DependentInstantiation
4329 : TypeDependence::None);
4330 if (Expansions.empty())
4331 TD |= Pattern->
getDependence() & TypeDependence::DependentInstantiation;
4333 for (
const QualType &T : Expansions)
4336 if (!(IndexD & TypeDependence::UnexpandedPack))
4342 TD |= TypeDependence::Error | TypeDependence::DependentInstantiation;
4347void PackIndexingType::Profile(llvm::FoldingSetNodeID &ID,
4349 Profile(ID, Context, getPattern(), getIndexExpr(), isFullySubstituted(),
4353void PackIndexingType::Profile(llvm::FoldingSetNodeID &ID,
4355 Expr *E,
bool FullySubstituted,
4358 E->
Profile(ID, Context,
true);
4359 ID.AddBoolean(FullySubstituted);
4360 if (!Expansions.empty()) {
4361 ID.AddInteger(Expansions.size());
4363 T.getCanonicalType().
Profile(ID);
4369UnaryTransformType::UnaryTransformType(
QualType BaseType,
4370 QualType UnderlyingType, UTTKind UKind,
4372 :
Type(UnaryTransform, CanonicalType, BaseType->getDependence()),
4373 BaseType(BaseType), UnderlyingType(UnderlyingType), UKind(UKind) {}
4377 bool OwnsTag,
bool ISInjected,
const Type *CanonicalType)
4384 ~NestedNameSpecifierDependence::
Dependent)
4388 getTrailingQualifier() = Qualifier;
4393void *TagType::getTrailingPointer()
const {
4394 switch (getTypeClass()) {
4399 case Type::InjectedClassName:
4400 return const_cast<InjectedClassNameType *
>(
4403 llvm_unreachable(
"unexpected type class");
4408 assert(TagTypeBits.HasQualifier);
4410 getTrailingPointer(), llvm::Align::Of<NestedNameSpecifier *>()));
4414 return TagTypeBits.HasQualifier ? getTrailingQualifier() : std::nullopt;
4418 auto *
Decl = dyn_cast<CXXRecordDecl>(
decl);
4421 if (
auto *RD = dyn_cast<ClassTemplateSpecializationDecl>(
Decl))
4422 return RD->getSpecializedTemplate();
4423 return Decl->getDescribedClassTemplate();
4427 auto *TD = getTemplateDecl();
4430 if (isCanonicalUnqualified())
4437TagType::getTemplateArgs(
const ASTContext &Ctx)
const {
4438 auto *
Decl = dyn_cast<CXXRecordDecl>(
decl);
4442 if (
auto *RD = dyn_cast<ClassTemplateSpecializationDecl>(
Decl))
4443 return RD->getTemplateArgs().asArray();
4445 return TD->getTemplateParameters()->getInjectedTemplateArgs(Ctx);
4449bool RecordType::hasConstFields()
const {
4450 std::vector<const RecordType *> RecordTypeList;
4451 RecordTypeList.push_back(
this);
4452 unsigned NextToCheckIndex = 0;
4454 while (RecordTypeList.size() > NextToCheckIndex) {
4455 for (
FieldDecl *FD : RecordTypeList[NextToCheckIndex]
4457 ->getDefinitionOrSelf()
4463 if (
const auto *FieldRecTy = FieldTy->
getAsCanonical<RecordType>()) {
4464 if (!llvm::is_contained(RecordTypeList, FieldRecTy))
4465 RecordTypeList.push_back(FieldRecTy);
4475 const TagDecl *TD,
bool IsInjected,
4476 const Type *CanonicalType)
4478 false, IsInjected, CanonicalType) {}
4487 :
Type(Attributed, canon, equivalent->getDependence()), Attribute(
attr),
4488 ModifiedType(modified), EquivalentType(equivalent) {
4490 assert(!attr ||
attr->getKind() == attrKind);
4493bool AttributedType::isQualifier()
const {
4495 switch (getAttrKind()) {
4500 case attr::ObjCOwnership:
4501 case attr::ObjCInertUnsafeUnretained:
4502 case attr::TypeNonNull:
4503 case attr::TypeNullable:
4504 case attr::TypeNullableResult:
4505 case attr::TypeNullUnspecified:
4506 case attr::LifetimeBound:
4507 case attr::AddressSpace:
4517bool AttributedType::isMSTypeSpec()
const {
4519 switch (getAttrKind()) {
4528 llvm_unreachable(
"invalid attr kind");
4531bool AttributedType::isWebAssemblyFuncrefSpec()
const {
4532 return getAttrKind() == attr::WebAssemblyFuncref;
4535bool AttributedType::isCallingConv()
const {
4537 switch (getAttrKind()) {
4542 case attr::FastCall:
4544 case attr::ThisCall:
4546 case attr::SwiftCall:
4547 case attr::SwiftAsyncCall:
4548 case attr::VectorCall:
4549 case attr::AArch64VectorPcs:
4550 case attr::AArch64SVEPcs:
4551 case attr::DeviceKernel:
4555 case attr::IntelOclBicc:
4556 case attr::PreserveMost:
4557 case attr::PreserveAll:
4559 case attr::PreserveNone:
4560 case attr::RISCVVectorCC:
4561 case attr::RISCVVLSCC:
4564 llvm_unreachable(
"invalid attr kind");
4568 return isCanonicalUnqualified() ?
nullptr : getDecl()->getIdentifier();
4571SubstTemplateTypeParmType::SubstTemplateTypeParmType(
QualType Replacement,
4572 Decl *AssociatedDecl,
4576 :
Type(SubstTemplateTypeParm, Replacement.getCanonicalType(),
4577 Replacement->getDependence()),
4578 AssociatedDecl(AssociatedDecl) {
4582 *getTrailingObjects() = Replacement;
4588 assert(AssociatedDecl !=
nullptr);
4592SubstTemplateTypeParmType::getReplacedParameter()
const {
4597void SubstTemplateTypeParmType::Profile(llvm::FoldingSetNodeID &ID,
4599 const Decl *AssociatedDecl,
4602 Replacement.Profile(ID);
4603 ID.AddPointer(AssociatedDecl);
4604 ID.AddInteger(Index);
4606 ID.AddBoolean(Final);
4609SubstPackType::SubstPackType(TypeClass Derived,
QualType Canon,
4611 :
Type(Derived, Canon,
4615 assert(llvm::all_of(
4617 [](
auto &P) { return P.getKind() == TemplateArgument::Type; }) &&
4618 "non-type argument to SubstPackType?");
4626void SubstPackType::Profile(llvm::FoldingSetNodeID &ID) {
4627 Profile(ID, getArgumentPack());
4630void SubstPackType::Profile(llvm::FoldingSetNodeID &ID,
4634 ID.AddPointer(P.getAsType().getAsOpaquePtr());
4637SubstTemplateTypeParmPackType::SubstTemplateTypeParmPackType(
4638 QualType Canon,
Decl *AssociatedDecl,
unsigned Index,
bool Final,
4640 : SubstPackType(SubstTemplateTypeParmPack, Canon, ArgPack),
4641 AssociatedDeclAndFinal(AssociatedDecl, Final) {
4642 assert(AssociatedDecl !=
nullptr);
4645 assert(getNumArgs() == ArgPack.
pack_size() &&
4646 "Parent bitfields in SubstPackType were overwritten."
4647 "Check NumSubstPackTypeBits.");
4650Decl *SubstTemplateTypeParmPackType::getAssociatedDecl()
const {
4651 return AssociatedDeclAndFinal.getPointer();
4654bool SubstTemplateTypeParmPackType::getFinal()
const {
4655 return AssociatedDeclAndFinal.getInt();
4659SubstTemplateTypeParmPackType::getReplacedParameter()
const {
4664IdentifierInfo *SubstTemplateTypeParmPackType::getIdentifier()
const {
4665 return getReplacedParameter()->getIdentifier();
4668void SubstTemplateTypeParmPackType::Profile(llvm::FoldingSetNodeID &ID) {
4669 Profile(ID, getAssociatedDecl(),
getIndex(), getFinal(), getArgumentPack());
4672void SubstTemplateTypeParmPackType::Profile(llvm::FoldingSetNodeID &ID,
4673 const Decl *AssociatedDecl,
4674 unsigned Index,
bool Final,
4676 ID.AddPointer(AssociatedDecl);
4677 ID.AddInteger(Index);
4678 ID.AddBoolean(Final);
4679 SubstPackType::Profile(ID, ArgPack);
4682SubstBuiltinTemplatePackType::SubstBuiltinTemplatePackType(
4684 : SubstPackType(SubstBuiltinTemplatePack, Canon, ArgPack) {}
4686bool TemplateSpecializationType::anyDependentTemplateArguments(
4689 return anyDependentTemplateArguments(Args.
arguments(), Converted);
4692bool TemplateSpecializationType::anyDependentTemplateArguments(
4695 if (Arg.isDependent())
4700bool TemplateSpecializationType::anyInstantiationDependentTemplateArguments(
4703 if (ArgLoc.getArgument().isInstantiationDependent())
4712 ? TypeDependence::DependentInstantiation
4717 D |= TypeDependence::UnexpandedPack;
4719 D |= (Underlying->
getDependence() & TypeDependence::UnexpandedPack);
4724TemplateSpecializationType::TemplateSpecializationType(
4728 Underlying.isNull() ?
QualType(this, 0)
4729 : Underlying.getCanonicalType(),
4732 TemplateSpecializationTypeBits.NumArgs = Args.size();
4733 TemplateSpecializationTypeBits.TypeAlias = IsAlias;
4735 auto *TemplateArgs =
4747 ~TypeDependence::Dependent);
4749 addDependence(Arg.getAsType()->getDependence() &
4750 TypeDependence::VariablyModified);
4757 *
reinterpret_cast<QualType *
>(TemplateArgs) = Underlying;
4760QualType TemplateSpecializationType::getAliasedType()
const {
4761 assert(isTypeAlias() &&
"not a type alias template specialization");
4762 return *
reinterpret_cast<const QualType *
>(template_arguments().end());
4765bool clang::TemplateSpecializationType::isSugared()
const {
4766 return !isDependentType() || isCurrentInstantiation() || isTypeAlias() ||
4771void TemplateSpecializationType::Profile(llvm::FoldingSetNodeID &ID,
4773 Profile(ID, getKeyword(),
Template, template_arguments(),
4774 isSugared() ? desugar() :
QualType(), Ctx);
4777void TemplateSpecializationType::Profile(llvm::FoldingSetNodeID &ID,
4783 ID.AddInteger(llvm::to_underlying(
Keyword));
4787 ID.AddInteger(Args.size());
4789 Arg.Profile(ID, Context);
4797 return Context.getQualifiedType(QT, *
this);
4801 const Type *T)
const {
4805 return Context.getQualifiedType(T, *
this);
4808void ObjCObjectTypeImpl::Profile(llvm::FoldingSetNodeID &ID,
QualType BaseType,
4812 ID.AddPointer(BaseType.getAsOpaquePtr());
4813 ID.AddInteger(typeArgs.size());
4814 for (
auto typeArg : typeArgs)
4815 ID.AddPointer(typeArg.getAsOpaquePtr());
4816 ID.AddInteger(protocols.size());
4817 for (
auto *proto : protocols)
4818 ID.AddPointer(proto);
4819 ID.AddBoolean(isKindOf);
4822void ObjCObjectTypeImpl::Profile(llvm::FoldingSetNodeID &ID) {
4823 Profile(ID, getBaseType(), getTypeArgsAsWritten(),
4825 isKindOfTypeAsWritten());
4828void ObjCTypeParamType::Profile(llvm::FoldingSetNodeID &ID,
4832 ID.AddPointer(OTPDecl);
4834 ID.AddInteger(protocols.size());
4835 for (
auto *proto : protocols)
4836 ID.AddPointer(proto);
4839void ObjCTypeParamType::Profile(llvm::FoldingSetNodeID &ID) {
4840 Profile(ID, getDecl(), getCanonicalTypeInternal(),
4847class CachedProperties {
4852 CachedProperties(
Linkage L,
bool local) : L(L), local(local) {}
4854 Linkage getLinkage()
const {
return L; }
4855 bool hasLocalOrUnnamedType()
const {
return local; }
4857 friend CachedProperties
merge(CachedProperties L, CachedProperties R) {
4859 return CachedProperties(MergedLinkage, L.hasLocalOrUnnamedType() ||
4860 R.hasLocalOrUnnamedType());
4879 return CachedProperties(T->TypeBits.getLinkage(),
4880 T->TypeBits.hasLocalOrUnnamedType());
4885 if (T->TypeBits.isCacheValid())
4890 if (!T->isCanonicalUnqualified()) {
4893 T->TypeBits.CacheValid =
true;
4894 T->TypeBits.CachedLinkage = CT->
TypeBits.CachedLinkage;
4895 T->TypeBits.CachedLocalOrUnnamed = CT->
TypeBits.CachedLocalOrUnnamed;
4901 T->TypeBits.CacheValid =
true;
4902 T->TypeBits.CachedLinkage = llvm::to_underlying(
Result.getLinkage());
4903 T->TypeBits.CachedLocalOrUnnamed =
Result.hasLocalOrUnnamedType();
4921 switch (T->getTypeClass()) {
4922#define TYPE(Class, Base)
4923#define NON_CANONICAL_TYPE(Class, Base) case Type::Class:
4924#include "clang/AST/TypeNodes.inc"
4925 llvm_unreachable(
"didn't expect a non-canonical type here");
4927#define TYPE(Class, Base)
4928#define DEPENDENT_TYPE(Class, Base) case Type::Class:
4929#define NON_CANONICAL_UNLESS_DEPENDENT_TYPE(Class, Base) case Type::Class:
4930#include "clang/AST/TypeNodes.inc"
4932 assert(T->isInstantiationDependentType());
4936 case Type::DeducedTemplateSpecialization:
4950 const auto *Tag =
cast<TagType>(T)->getDecl()->getDefinitionOrSelf();
4956 Linkage L = Tag->getLinkageInternal();
4957 bool IsLocalOrUnnamed = Tag->getDeclContext()->isFunctionOrMethod() ||
4958 !Tag->hasNameForLinkage();
4959 return CachedProperties(L, IsLocalOrUnnamed);
4969 case Type::BlockPointer:
4971 case Type::LValueReference:
4972 case Type::RValueReference:
4974 case Type::MemberPointer: {
4976 CachedProperties Cls = [&] {
4977 if (MPT->isSugared())
4979 return Cache::get(MPT->getQualifier().getAsType());
4981 return merge(Cls,
Cache::get(MPT->getPointeeType()));
4983 case Type::ConstantArray:
4984 case Type::IncompleteArray:
4985 case Type::VariableArray:
4986 case Type::ArrayParameter:
4989 case Type::ExtVector:
4991 case Type::ConstantMatrix:
4993 case Type::FunctionNoProto:
4995 case Type::FunctionProto: {
4997 CachedProperties result =
Cache::get(FPT->getReturnType());
4998 for (
const auto &ai : FPT->param_types())
5002 case Type::ObjCInterface: {
5004 return CachedProperties(L,
false);
5006 case Type::ObjCObject:
5008 case Type::ObjCObjectPointer:
5014 case Type::HLSLAttributedResource:
5016 case Type::HLSLInlineSpirv:
5018 case Type::OverflowBehavior:
5022 llvm_unreachable(
"unhandled type class");
5033 return TypeBits.hasLocalOrUnnamedType();
5037 switch (T->getTypeClass()) {
5038#define TYPE(Class, Base)
5039#define NON_CANONICAL_TYPE(Class, Base) case Type::Class:
5040#include "clang/AST/TypeNodes.inc"
5041 llvm_unreachable(
"didn't expect a non-canonical type here");
5043#define TYPE(Class, Base)
5044#define DEPENDENT_TYPE(Class, Base) case Type::Class:
5045#define NON_CANONICAL_UNLESS_DEPENDENT_TYPE(Class, Base) case Type::Class:
5046#include "clang/AST/TypeNodes.inc"
5048 assert(T->isInstantiationDependentType());
5056 case Type::DeducedTemplateSpecialization:
5068 case Type::BlockPointer:
5070 case Type::LValueReference:
5071 case Type::RValueReference:
5073 case Type::MemberPointer: {
5076 if (
auto *D = MPT->getMostRecentCXXRecordDecl()) {
5084 case Type::ConstantArray:
5085 case Type::IncompleteArray:
5086 case Type::VariableArray:
5087 case Type::ArrayParameter:
5090 case Type::ExtVector:
5092 case Type::ConstantMatrix:
5095 case Type::FunctionNoProto:
5097 case Type::FunctionProto: {
5100 for (
const auto &ai : FPT->param_types())
5104 case Type::ObjCInterface:
5106 case Type::ObjCObject:
5108 case Type::ObjCObjectPointer:
5115 case Type::OverflowBehavior:
5118 case Type::HLSLAttributedResource:
5120 ->getContainedType()
5121 ->getCanonicalTypeInternal());
5122 case Type::HLSLInlineSpirv:
5126 llvm_unreachable(
"unhandled type class");
5140 if (!T->isCanonicalUnqualified())
5154 while (
const auto *AT =
Type->getAs<AttributedType>()) {
5157 if (
auto Nullability = AT->getImmediateNullability())
5160 Type = AT->getEquivalentType();
5162 return std::nullopt;
5168 switch (
type->getTypeClass()) {
5169#define NON_CANONICAL_TYPE(Class, Parent) \
5172 llvm_unreachable("non-canonical type");
5173#define TYPE(Class, Parent)
5174#include "clang/AST/TypeNodes.inc"
5178 case Type::BlockPointer:
5179 case Type::MemberPointer:
5180 case Type::ObjCObjectPointer:
5184 case Type::UnresolvedUsing:
5185 case Type::TypeOfExpr:
5187 case Type::Decltype:
5188 case Type::PackIndexing:
5189 case Type::UnaryTransform:
5190 case Type::TemplateTypeParm:
5191 case Type::SubstTemplateTypeParmPack:
5192 case Type::SubstBuiltinTemplatePack:
5193 case Type::DependentName:
5195 return ResultIfUnknown;
5198 case Type::TemplateSpecialization:
5203 .getAsTemplateDecl())
5204 if (
auto *CTD = dyn_cast<ClassTemplateDecl>(templateDecl))
5205 return llvm::any_of(
5207 return RTD->getTemplatedDecl()->hasAttr<TypeNullableAttr>();
5209 return ResultIfUnknown;
5214#define SIGNED_TYPE(Id, SingletonId) case BuiltinType::Id:
5215#define UNSIGNED_TYPE(Id, SingletonId) case BuiltinType::Id:
5216#define FLOATING_TYPE(Id, SingletonId) case BuiltinType::Id:
5217#define BUILTIN_TYPE(Id, SingletonId)
5218#include "clang/AST/BuiltinTypes.def"
5221 case BuiltinType::UnresolvedTemplate:
5223 case BuiltinType::Dependent:
5224 case BuiltinType::Overload:
5225 case BuiltinType::BoundMember:
5226 case BuiltinType::PseudoObject:
5227 case BuiltinType::UnknownAny:
5228 case BuiltinType::ARCUnbridgedCast:
5229 return ResultIfUnknown;
5231 case BuiltinType::Void:
5232 case BuiltinType::ObjCId:
5233 case BuiltinType::ObjCClass:
5234 case BuiltinType::ObjCSel:
5235#define IMAGE_TYPE(ImgType, Id, SingletonId, Access, Suffix) \
5236 case BuiltinType::Id:
5237#include "clang/Basic/OpenCLImageTypes.def"
5238#define EXT_OPAQUE_TYPE(ExtType, Id, Ext) case BuiltinType::Id:
5239#include "clang/Basic/OpenCLExtensionTypes.def"
5240 case BuiltinType::OCLSampler:
5241 case BuiltinType::OCLEvent:
5242 case BuiltinType::OCLClkEvent:
5243 case BuiltinType::OCLQueue:
5244 case BuiltinType::OCLReserveID:
5245#define SVE_TYPE(Name, Id, SingletonId) case BuiltinType::Id:
5246#include "clang/Basic/AArch64ACLETypes.def"
5247#define PPC_VECTOR_TYPE(Name, Id, Size) case BuiltinType::Id:
5248#include "clang/Basic/PPCTypes.def"
5249#define RVV_TYPE(Name, Id, SingletonId) case BuiltinType::Id:
5250#include "clang/Basic/RISCVVTypes.def"
5251#define WASM_TYPE(Name, Id, SingletonId) case BuiltinType::Id:
5252#include "clang/Basic/WebAssemblyReferenceTypes.def"
5253#define AMDGPU_TYPE(Name, Id, SingletonId, Width, Align) case BuiltinType::Id:
5254#include "clang/Basic/AMDGPUTypes.def"
5255#define HLSL_INTANGIBLE_TYPE(Name, Id, SingletonId) case BuiltinType::Id:
5256#include "clang/Basic/HLSLIntangibleTypes.def"
5257 case BuiltinType::BuiltinFn:
5258 case BuiltinType::NullPtr:
5259 case BuiltinType::IncompleteMatrixIdx:
5260 case BuiltinType::ArraySection:
5261 case BuiltinType::OMPArrayShaping:
5262 case BuiltinType::OMPIterator:
5265 llvm_unreachable(
"unknown builtin type");
5267 case Type::Record: {
5271 if (
const auto *CTSD = dyn_cast<ClassTemplateSpecializationDecl>(RD))
5272 return llvm::any_of(
5273 CTSD->getSpecializedTemplate()->redecls(),
5275 return RTD->getTemplatedDecl()->hasAttr<TypeNullableAttr>();
5278 return RD->hasAttr<TypeNullableAttr>();
5284 case Type::LValueReference:
5285 case Type::RValueReference:
5286 case Type::ConstantArray:
5287 case Type::IncompleteArray:
5288 case Type::VariableArray:
5289 case Type::DependentSizedArray:
5290 case Type::DependentVector:
5291 case Type::DependentSizedExtVector:
5293 case Type::ExtVector:
5294 case Type::ConstantMatrix:
5295 case Type::DependentSizedMatrix:
5296 case Type::DependentAddressSpace:
5297 case Type::FunctionProto:
5298 case Type::FunctionNoProto:
5299 case Type::DeducedTemplateSpecialization:
5301 case Type::InjectedClassName:
5302 case Type::PackExpansion:
5303 case Type::ObjCObject:
5304 case Type::ObjCInterface:
5308 case Type::DependentBitInt:
5309 case Type::ArrayParameter:
5310 case Type::HLSLAttributedResource:
5311 case Type::HLSLInlineSpirv:
5312 case Type::OverflowBehavior:
5315 llvm_unreachable(
"bad type kind!");
5319 if (getAttrKind() == attr::TypeNonNull)
5321 if (getAttrKind() == attr::TypeNullable)
5323 if (getAttrKind() == attr::TypeNullUnspecified)
5325 if (getAttrKind() == attr::TypeNullableResult)
5327 return std::nullopt;
5332 if (
auto MacroTy = dyn_cast<MacroQualifiedType>(T))
5333 AttrTy = MacroTy->getUnderlyingType();
5335 if (
auto attributed = dyn_cast<AttributedType>(AttrTy)) {
5336 if (
auto nullability = attributed->getImmediateNullability()) {
5337 T = attributed->getModifiedType();
5342 return std::nullopt;
5345void AttributedType::Profile(llvm::FoldingSetNodeID &ID,
const ASTContext &Ctx,
5348 ID.AddInteger(attrKind);
5352 attr->Profile(ID, Ctx);
5366 if (objcPtr->isObjCIdType()) {
5377 }
else if (objcPtr->isObjCQualifiedIdType()) {
5402 "cannot query implicit lifetime for non-inferrable type");
5407 while (
const auto *array = dyn_cast<ArrayType>(canon))
5408 canon = array->getElementType().getTypePtr();
5410 if (
const auto *
opt = dyn_cast<ObjCObjectPointerType>(canon)) {
5412 if (
opt->getObjectType()->isObjCClass())
5421 return typedefType->getDecl()->hasAttr<ObjCNSObjectAttr>();
5427 return typedefType->getDecl()->hasAttr<ObjCIndependentClassAttr>();
5440 return OPT->getPointeeType()->isObjCIndirectLifetimeType();
5442 return Ref->getPointeeType()->isObjCIndirectLifetimeType();
5444 return MemPtr->getPointeeType()->isObjCIndirectLifetimeType();
5452 while (
const ArrayType *array =
type->getAsArrayTypeUnsafe())
5453 type = array->getElementType().getTypePtr();
5454 return type->isObjCRetainableType();
5476 return RT->getDecl()
5477 ->getMostRecentDecl()
5478 ->hasAttr<CUDADeviceBuiltinSurfaceTypeAttr>();
5485 return RT->getDecl()
5486 ->getMostRecentDecl()
5487 ->hasAttr<CUDADeviceBuiltinTextureTypeAttr>();
5496 return ptr->getPointeeType()->hasSizedVLAType();
5498 return ref->getPointeeType()->hasSizedVLAType();
5504 return arr->getElementType()->hasSizedVLAType();
5511 return HLSLAttributedResourceType::findHandleTypeOnResource(
this) !=
nullptr;
5534 const RecordType *RT =
5540 assert(RD !=
nullptr &&
5541 "all HLSL structs and classes should be CXXRecordDecl");
5548 if (
const auto *RD =
5550 if (!RD->isHLSLBuiltinRecord() && RD->isStandardLayout())
5557 switch (
type.getObjCLifetime()) {
5569 if (
const auto *RD =
type->getBaseElementTypeUnsafe()->getAsRecordDecl()) {
5570 if (
const auto *CXXRD = dyn_cast<CXXRecordDecl>(RD)) {
5572 if (CXXRD->hasDefinition() && !CXXRD->hasTrivialDestructor())
5587 llvm::SmallPtrSetImpl<const Decl *> &Seen) {
5588 if (
const auto *Arr = Context.getAsArrayType(Ty))
5589 Ty = Context.getBaseElementType(Arr);
5591 if (
const auto *AttrTy = Ty->
getAs<AttributedType>())
5592 Ty = AttrTy->getModifiedType();
5595 "Incomplete types cannot be evaluated for laundering");
5602 if (!Seen.insert(
Record).second)
5605 if (
Record->isDynamicClass())
5631 Qualifier.Profile(ID);
5643 auto *RD = getCXXRecordDecl();
5650 llvm::APSInt Val,
unsigned Scale) {
5651 llvm::FixedPointSemantics FXSema(Val.getBitWidth(), Scale, Val.isSigned(),
5654 llvm::APFixedPoint(Val, FXSema).toString(Str);
5657DeducedType::DeducedType(TypeClass TC,
DeducedKind DK,
5660 ? DeducedAsTypeOrCanon.getCanonicalType()
5661 : DeducedAsTypeOrCanon,
5663 DeducedTypeBits.Kind = llvm::to_underlying(DK);
5668 assert(!DeducedAsTypeOrCanon.
isNull() &&
"Deduced type cannot be null");
5670 ~TypeDependence::VariablyModified);
5671 DeducedAsType = DeducedAsTypeOrCanon;
5674 addDependence(TypeDependence::UnexpandedPack);
5677 addDependence(TypeDependence::DependentInstantiation);
5680 assert(getDeducedKind() == DK &&
"DeducedKind does not match the type state");
5686 : DeducedType(
Auto, DK, DeducedAsTypeOrCanon) {
5687 AutoTypeBits.Keyword = llvm::to_underlying(
Keyword);
5688 AutoTypeBits.NumArgs = TypeConstraintArgs.size();
5689 this->TypeConstraintConcept = TypeConstraintConcept;
5690 assert(TypeConstraintConcept || AutoTypeBits.NumArgs == 0);
5691 if (TypeConstraintConcept) {
5692 auto Dep = TypeDependence::None;
5693 if (
const auto *TTP =
5694 dyn_cast<TemplateTemplateParmDecl>(TypeConstraintConcept))
5695 Dep = TypeDependence::DependentInstantiation |
5696 (TTP->isParameterPack() ? TypeDependence::UnexpandedPack
5697 : TypeDependence::None);
5712void AutoType::Profile(llvm::FoldingSetNodeID &ID,
const ASTContext &Context,
5716 DeducedType::Profile(ID, DK,
Deduced);
5717 ID.AddInteger(llvm::to_underlying(
Keyword));
5720 Arg.Profile(ID, Context);
5723void AutoType::Profile(llvm::FoldingSetNodeID &ID,
const ASTContext &Context) {
5724 Profile(ID, Context, getDeducedKind(), getDeducedType(), getKeyword(),
5725 getTypeConstraintConcept(), getTypeConstraintArguments());
5739 llvm_unreachable(
"unknown effect kind");
5745 return "nonblocking";
5747 return "nonallocating";
5751 return "allocating";
5753 llvm_unreachable(
"unknown effect kind");
5769 return std::nullopt;
5774 assert(0 &&
"effectProhibitingInference with non-inferable effect kind");
5777 llvm_unreachable(
"unknown effect kind");
5787 const Kind EK = Effect.kind();
5789 if (EK == CallerKind ||
5800 llvm_unreachable(
"unknown effect kind");
5812 unsigned InsertIdx = Effects.size();
5827 Errs.push_back({EC, NewEC});
5838 if (NewCondition || !Conditions.empty()) {
5839 if (Conditions.empty() && !Effects.empty())
5840 Conditions.resize(Effects.size());
5841 Conditions.insert(Conditions.begin() + InsertIdx,
5844 Effects.insert(Effects.begin() + InsertIdx, NewEC.
Effect);
5849 for (
const auto &Item :
Set)
5851 return Errs.empty();
5862 auto IterA = LHS.
begin(), EndA = LHS.
end();
5863 auto IterB = RHS.
begin(), EndB = RHS.
end();
5867 return std::tuple(LHS.Effect,
uintptr_t(LHS.Cond.getCondition())) <
5868 std::tuple(RHS.Effect,
uintptr_t(RHS.Cond.getCondition()));
5871 while (IterA != EndA && IterB != EndB) {
5876 else if (FEWCLess(B, A))
5887 assert(Errs.empty() &&
"conflict shouldn't be possible in getIntersection");
5900 Combined.
insert(RHS, Errs);
5921 llvm::interleaveComma(*
this, OS);
5931 llvm::interleaveComma(*
this, OS);
5938 assert(llvm::is_sorted(FX) &&
"effects should be sorted");
5939 assert((Conds.empty() || Conds.size() == FX.size()) &&
5940 "effects size should match conditions size");
5946 if (
Cond.getCondition() !=
nullptr)
5951const HLSLAttributedResourceType *
5952HLSLAttributedResourceType::findHandleTypeOnResource(
const Type *RT) {
5957 if (!RD->
fields().empty()) {
5958 const auto &FirstFD = RD->
fields().begin();
5959 return dyn_cast<HLSLAttributedResourceType>(
5960 FirstFD->getType().getTypePtr());
5966StringRef PredefinedSugarType::getName(Kind KD) {
5971 return "__signed_size_t";
5973 return "__ptrdiff_t";
5975 llvm_unreachable(
"unexpected kind");
Defines the clang::ASTContext interface.
Provides definitions for the various language-specific address spaces.
static std::optional< NonLoc > getIndex(ProgramStateRef State, const ElementRegion *ER, CharKind CK)
static Decl::Kind getKind(const Decl *D)
Defines the C++ Decl subclasses, other than those for templates (found in DeclTemplate....
Defines the C++ template declaration subclasses.
Defines the ExceptionSpecificationType enumeration and various utility functions.
Defines the clang::IdentifierInfo, clang::IdentifierTable, and clang::Selector interfaces.
#define CC_VLS_CASE(ABI_VLEN)
Forward-declares and imports various common LLVM datatypes that clang wants to use unqualified.
Defines the clang::LangOptions interface.
llvm::MachO::Record Record
static QualType getUnderlyingType(const SubRegion *R)
static RecordDecl * getAsRecordDecl(QualType BaseType, HeuristicResolver &Resolver)
static bool isRecordType(QualType T)
Defines various enumerations that describe declaration and type specifiers.
static QualType getPointeeType(const MemRegion *R)
Defines the TargetCXXABI class, which abstracts details of the C++ ABI that we're targeting.
static TypeDependence getTemplateSpecializationTypeDependence(QualType Underlying, TemplateName T)
#define ENUMERATE_ATTRS(PREFIX)
#define SUGARED_TYPE_CLASS(Class)
static bool requiresBuiltinLaunderImpl(const ASTContext &Context, QualType Ty, llvm::SmallPtrSetImpl< const Decl * > &Seen)
TypePropertyCache< Private > Cache
static bool isTriviallyCopyableTypeImpl(const QualType &type, const ASTContext &Context, bool IsCopyConstructible)
static const T * getAsSugar(const Type *Cur)
This will check for a T (which should be a Type which can act as sugar, such as a TypedefType) by rem...
#define TRIVIAL_TYPE_CLASS(Class)
static CachedProperties computeCachedProperties(const Type *T)
C Language Family Type Representation.
Defines the clang::Visibility enumeration and various utility functions.
__DEVICE__ void * memcpy(void *__a, const void *__b, size_t __c)
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
BuiltinVectorTypeInfo getBuiltinVectorTypeInfo(const BuiltinType *VecTy) const
Returns the element type, element count and number of vectors (in case of tuple) for a builtin vector...
QualType getAtomicType(QualType T) const
Return the uniqued reference to the atomic type for the specified type.
QualType getParenType(QualType NamedType) const
QualType getRValueReferenceType(QualType T) const
Return the uniqued reference to the type for an rvalue reference to the specified type.
QualType getObjCInterfaceType(const ObjCInterfaceDecl *Decl, ObjCInterfaceDecl *PrevDecl=nullptr) const
getObjCInterfaceType - Return the unique reference to the type for the specified ObjC interface decl.
QualType getBlockPointerType(QualType T) const
Return the uniqued reference to the type for a block of the specified type.
QualType getAttributedType(attr::Kind attrKind, QualType modifiedType, QualType equivalentType, const Attr *attr=nullptr) const
QualType getFunctionNoProtoType(QualType ResultTy, const FunctionType::ExtInfo &Info) const
Return a K&R style C function type like 'int()'.
QualType getArrayParameterType(QualType Ty) const
Return the uniqued reference to a specified array parameter type from the original array type.
QualType getVectorType(QualType VectorType, unsigned NumElts, VectorKind VecKind) const
Return the unique reference to a vector type of the specified element type and size.
QualType getSubstTemplateTypeParmType(QualType Replacement, Decl *AssociatedDecl, unsigned Index, UnsignedOrNone PackIndex, bool Final) const
Retrieve a substitution-result type.
QualType getPointerType(QualType T) const
Return the uniqued reference to the type for a pointer to the specified type.
QualType getLValueReferenceType(QualType T, bool SpelledAsLValue=true) const
Return the uniqued reference to the type for an lvalue reference to the specified type.
QualType getConstantArrayType(QualType EltTy, const llvm::APInt &ArySize, const Expr *SizeExpr, ArraySizeModifier ASM, unsigned IndexTypeQuals) const
Return the unique reference to the type for a constant array of the specified element type.
const LangOptions & getLangOpts() const
QualType applyObjCProtocolQualifiers(QualType type, ArrayRef< ObjCProtocolDecl * > protocols, bool &hasError, bool allowOnPointerType=false) const
Apply Objective-C protocol qualifiers to the given type.
QualType getDecayedType(QualType T) const
Return the uniqued reference to the decayed version of the given type.
QualType getAutoType(DeducedKind DK, QualType DeducedAsType, AutoTypeKeyword Keyword, TemplateDecl *TypeConstraintConcept=nullptr, ArrayRef< TemplateArgument > TypeConstraintArgs={}) const
C++11 deduced auto type.
QualType getBaseElementType(const ArrayType *VAT) const
Return the innermost element type of an array type.
CanQualType ObjCBuiltinIdTy
IdentifierInfo * getNSObjectName() const
Retrieve the identifier 'NSObject'.
QualType getAdjustedType(QualType Orig, QualType New) const
Return the uniqued reference to a type adjusted from the original type to a new type.
QualType getQualifiedType(SplitQualType split) const
Un-split a SplitQualType.
QualType getObjCObjectPointerType(QualType OIT) const
Return a ObjCObjectPointerType type for the given ObjCObjectType.
QualType getObjCObjectType(QualType Base, ObjCProtocolDecl *const *Protocols, unsigned NumProtocols) const
Legacy interface: cannot provide type arguments or __kindof.
QualType getVariableArrayType(QualType EltTy, Expr *NumElts, ArraySizeModifier ASM, unsigned IndexTypeQuals) const
Return a non-unique reference to the type for a variable array of the specified element type.
const ArrayType * getAsArrayType(QualType T) const
Type Query functions.
uint64_t getTypeSize(QualType T) const
Return the size of the specified (complete) type T, in bits.
CanQualType UnsignedCharTy
TemplateName getQualifiedTemplateName(NestedNameSpecifier Qualifier, bool TemplateKeyword, TemplateName Template) const
Retrieve the template name that represents a qualified template name such as std::vector.
QualType getFunctionType(QualType ResultTy, ArrayRef< QualType > Args, const FunctionProtoType::ExtProtoInfo &EPI) const
Return a normal function type with a typed argument list.
QualType getMemberPointerType(QualType T, NestedNameSpecifier Qualifier, const CXXRecordDecl *Cls) const
Return the uniqued reference to the type for a member pointer to the specified type in the specified ...
QualType getComplexType(QualType T) const
Return the uniqued reference to the type for a complex number with the specified element type.
QualType getExtVectorType(QualType VectorType, unsigned NumElts) const
Return the unique reference to an extended vector type of the specified element type and size.
const TargetInfo & getTargetInfo() const
QualType getOverflowBehaviorType(const OverflowBehaviorAttr *Attr, QualType Wrapped) const
QualType getIncompleteArrayType(QualType EltTy, ArraySizeModifier ASM, unsigned IndexTypeQuals) const
Return a unique reference to the type for an incomplete array of the specified element type.
QualType getConstantMatrixType(QualType ElementType, unsigned NumRows, unsigned NumColumns) const
Return the unique reference to the matrix type of the specified element type and size.
IdentifierInfo * getNSCopyingName()
Retrieve the identifier 'NSCopying'.
QualType getAdjustedType() const
QualType getOriginalType() const
QualType getConstantArrayType(const ASTContext &Ctx) const
Represents an array type, per C99 6.7.5.2 - Array Declarators.
ArraySizeModifier getSizeModifier() const
Qualifiers getIndexTypeQualifiers() const
QualType getElementType() const
ArrayType(TypeClass tc, QualType et, QualType can, ArraySizeModifier sm, unsigned tq, const Expr *sz=nullptr)
unsigned getIndexTypeCVRQualifiers() const
QualType getValueType() const
Gets the type contained by this atomic type, i.e.
void Profile(llvm::FoldingSetNodeID &ID)
Attr - This represents one attribute.
BitIntType(bool isUnsigned, unsigned NumBits)
QualType getPointeeType() const
[BoundsSafety] Represents a parent type class for CountAttributedType and similar sugar types that wi...
BoundsAttributedType(TypeClass TC, QualType Wrapped, QualType Canon)
decl_range dependent_decls() const
bool referencesFieldDecls() const
This class is used for builtin types like 'int'.
StringRef getName(const PrintingPolicy &Policy) const
Represents a C++ struct/union/class.
bool isHLSLIntangible() const
Returns true if the class contains HLSL intangible type, either as a field or in base class.
bool mayBeNonDynamicClass() const
bool mayBeDynamicClass() const
CXXRecordDecl * getCanonicalDecl() override
Retrieves the "canonical" declaration of the given declaration.
Declaration of a class template.
Complex values, per C99 6.2.5p11.
Represents the canonical version of C arrays with a specified constant size.
static unsigned getNumAddressingBits(const ASTContext &Context, QualType ElementType, const llvm::APInt &NumElements)
Determine the number of bits required to address a member of.
static unsigned getMaxSizeBits(const ASTContext &Context)
Determine the maximum number of active bits that an array's size can require, which limits the maximu...
const Expr * getSizeExpr() const
Return a pointer to the size expression.
llvm::APInt getSize() const
Return the constant array size as an APInt.
void Profile(llvm::FoldingSetNodeID &ID, const ASTContext &Ctx)
ConstantExpr - An expression that occurs in a constant context and optionally the result of evaluatin...
llvm::APSInt getResultAsAPSInt() const
unsigned getNumColumns() const
Returns the number of columns in the matrix.
unsigned getNumRows() const
Returns the number of rows in the matrix.
ConstantMatrixType(QualType MatrixElementType, unsigned NRows, unsigned NColumns, QualType CanonElementType)
unsigned NumRows
Number of rows and columns.
Represents a sugar type with __counted_by or __sized_by annotations, including their _or_null variant...
void Profile(llvm::FoldingSetNodeID &ID)
StringRef getAttributeName(bool WithMacroPrefix) const
DeclContext - This is used only as base class of specific decl types that can act as declaration cont...
ASTContext & getParentASTContext() const
Decl - This represents one declaration (or definition), e.g.
bool isInStdNamespace() const
ASTContext & getASTContext() const LLVM_READONLY
void Profile(llvm::FoldingSetNodeID &ID, const ASTContext &Context)
Expr * getNumBitsExpr() const
void Profile(llvm::FoldingSetNodeID &ID, const ASTContext &Context)
DependentBitIntType(bool IsUnsigned, Expr *NumBits)
void Profile(llvm::FoldingSetNodeID &ID, const ASTContext &Context)
void Profile(llvm::FoldingSetNodeID &ID, const ASTContext &Context)
QualType getElementType() const
void Profile(llvm::FoldingSetNodeID &ID, const ASTContext &Context)
void Profile(llvm::FoldingSetNodeID &ID, const ASTContext &Context)
void Profile(llvm::FoldingSetNodeID &ID, const ASTContext &Context)
Expr * getCondition() const
This represents one expression.
bool isValueDependent() const
Determines whether the value of this expression depends on.
bool isInstantiationDependent() const
Whether this expression is instantiation-dependent, meaning that it depends in some way on.
ExprDependence getDependence() const
Represents a member of a struct/union/class.
A mutable set of FunctionEffect::Kind.
void dump(llvm::raw_ostream &OS) const
FunctionEffectSet()=default
bool insert(const FunctionEffectWithCondition &NewEC, Conflicts &Errs)
SmallVector< Conflict > Conflicts
static FunctionEffectSet getIntersection(FunctionEffectsRef LHS, FunctionEffectsRef RHS)
void dump(llvm::raw_ostream &OS) const
static FunctionEffectSet getUnion(FunctionEffectsRef LHS, FunctionEffectsRef RHS, Conflicts &Errs)
Kind kind() const
The kind of the effect.
Kind
Identifies the particular effect.
bool shouldDiagnoseFunctionCall(bool Direct, FunctionEffectKindSet CalleeFX) const
StringRef name() const
The description printed in diagnostics, e.g. 'nonblocking'.
Kind oppositeKind() const
Return the opposite kind, for effects which have opposites.
std::optional< FunctionEffect > effectProhibitingInference(const Decl &Callee, FunctionEffectKindSet CalleeFX) const
Determine whether the effect is allowed to be inferred on the callee, which is either a FunctionDecl ...
An immutable set of FunctionEffects and possibly conditions attached to them.
void dump(llvm::raw_ostream &OS) const
ArrayRef< FunctionEffect > effects() const
ArrayRef< EffectConditionExpr > conditions() const
static FunctionEffectsRef create(ArrayRef< FunctionEffect > FX, ArrayRef< EffectConditionExpr > Conds)
Asserts invariants.
FunctionEffectsRef()=default
bool hasDependentExceptionSpec() const
Return whether this function has a dependent exception spec.
param_type_iterator param_type_begin() const
ExceptionSpecificationType getExceptionSpecType() const
Get the kind of exception specification on this function.
bool isTemplateVariadic() const
Determines whether this function prototype contains a parameter pack at the end.
unsigned getNumParams() const
bool hasTrailingReturn() const
Whether this function prototype has a trailing return type.
QualType getParamType(unsigned i) const
QualType getExceptionType(unsigned i) const
Return the ith exception type, where 0 <= i < getNumExceptions().
void Profile(llvm::FoldingSetNodeID &ID, const ASTContext &Ctx)
unsigned getNumExceptions() const
Return the number of types in the exception specification.
CanThrowResult canThrow() const
Determine whether this function type has a non-throwing exception specification.
ExtProtoInfo getExtProtoInfo() const
Expr * getNoexceptExpr() const
Return the expression inside noexcept(expression), or a null pointer if there is none (because the ex...
ArrayRef< QualType > getParamTypes() const
ArrayRef< QualType > exceptions() const
bool hasInstantiationDependentExceptionSpec() const
Return whether this function has an instantiation-dependent exception spec.
A class which abstracts out some details necessary for making a call.
ExtInfo getExtInfo() const
static StringRef getNameForCallConv(CallingConv CC)
bool getCFIUncheckedCalleeAttr() const
Determine whether this is a function prototype that includes the cfi_unchecked_callee attribute.
QualType getReturnType() const
FunctionType(TypeClass tc, QualType res, QualType Canonical, TypeDependence Dependence, ExtInfo Info)
One of these records is kept for each identifier that is lexed.
bool isStr(const char(&Str)[StrLen]) const
Return true if this is the identifier for the specified string.
LinkageInfo computeTypeLinkageInfo(const Type *T)
LinkageInfo getTypeLinkageAndVisibility(const Type *T)
LinkageInfo getDeclLinkageAndVisibility(const NamedDecl *D)
static LinkageInfo external()
Linkage getLinkage() const
void merge(LinkageInfo other)
Merge both linkage and visibility.
QualType getModifiedType() const
Return this attributed type's modified type with no qualifiers attached to it.
QualType getUnderlyingType() const
const IdentifierInfo * getMacroIdentifier() const
Represents a matrix type, as defined in the Matrix Types clang extensions.
QualType getElementType() const
Returns type of the elements being stored in the matrix.
MatrixType(QualType ElementTy, QualType CanonElementTy)
QualType ElementType
The element type of the matrix.
NestedNameSpecifier getQualifier() const
void Profile(llvm::FoldingSetNodeID &ID)
CXXRecordDecl * getMostRecentCXXRecordDecl() const
Note: this can trigger extra deserialization when external AST sources are used.
QualType getPointeeType() const
This represents a decl that may have a name.
IdentifierInfo * getIdentifier() const
Get the identifier that names this declaration, if there is one.
Represents a C++ nested name specifier, such as "\::std::vector<int>::".
CXXRecordDecl * getAsRecordDecl() const
Retrieve the record declaration stored in this nested name specifier, or null.
ObjCCategoryDecl - Represents a category declaration.
ObjCInterfaceDecl * getClassInterface()
ObjCTypeParamList * getTypeParamList() const
Retrieve the type parameter list associated with this category or extension.
Represents an ObjC class declaration.
ObjCTypeParamList * getTypeParamList() const
Retrieve the type parameters of this class.
const ObjCObjectType * getSuperClassType() const
Retrieve the superclass type.
ObjCInterfaceDecl * getCanonicalDecl() override
Retrieves the canonical declaration of this Objective-C class.
ObjCInterfaceDecl * getDefinition()
Retrieve the definition of this class, or NULL if this class has been forward-declared (with @class) ...
Represents typeof(type), a C23 feature and GCC extension, or `typeof_unqual(type),...
ObjCInterfaceDecl * getDecl() const
Get the declaration of this interface.
Represents a pointer to an Objective C object.
const ObjCObjectPointerType * stripObjCKindOfTypeAndQuals(const ASTContext &ctx) const
Strip off the Objective-C "kindof" type and (with it) any protocol qualifiers.
const ObjCObjectType * getObjectType() const
Gets the type pointed to by this ObjC pointer.
QualType getSuperClassType() const
Retrieve the type of the superclass of this object pointer type.
QualType getPointeeType() const
Gets the type pointed to by this ObjC pointer.
ObjCInterfaceDecl * getInterfaceDecl() const
If this pointer points to an Objective @interface type, gets the declaration for that interface.
const ObjCInterfaceType * getInterfaceType() const
If this pointer points to an Objective C @interface type, gets the type for that interface.
bool isKindOfType() const
Whether this is a "__kindof" type.
Represents an Objective-C protocol declaration.
Represents the declaration of an Objective-C type parameter.
unsigned getIndex() const
Retrieve the index into its type parameter list.
Stores a list of Objective-C type parameters for a parameterized class or a category/extension thereo...
unsigned size() const
Determine the number of type parameters in this list.
QualType getInnerType() const
QualType getPointeeType() const
A (possibly-)qualified type.
bool hasAddressDiscriminatedPointerAuth() const
bool isTriviallyCopyableType(const ASTContext &Context) const
Return true if this is a trivially copyable type (C++0x [basic.types]p9)
QualType IgnoreParens() const
Returns the specified type after dropping any outer-level parentheses.
QualType withFastQualifiers(unsigned TQs) const
bool hasNonTrivialToPrimitiveCopyCUnion() const
Check if this is or contains a C union that is non-trivial to copy, which is a union that has a membe...
bool isWebAssemblyFuncrefType() const
Returns true if it is a WebAssembly Funcref Type.
QualType getNonLValueExprType(const ASTContext &Context) const
Determine the type of a (typically non-lvalue) expression with the specified result type.
@ DK_objc_strong_lifetime
PrimitiveDefaultInitializeKind
@ PDIK_ARCWeak
The type is an Objective-C retainable pointer type that is qualified with the ARC __weak qualifier.
@ PDIK_Trivial
The type does not fall into any of the following categories.
@ PDIK_ARCStrong
The type is an Objective-C retainable pointer type that is qualified with the ARC __strong qualifier.
@ PDIK_Struct
The type is a struct containing a field whose type is not PCK_Trivial.
bool mayBeDynamicClass() const
Returns true if it is a class and it might be dynamic.
bool isNonWeakInMRRWithObjCWeak(const ASTContext &Context) const
const IdentifierInfo * getBaseTypeIdentifier() const
Retrieves a pointer to the name of the base type.
bool isBitwiseCloneableType(const ASTContext &Context) const
Return true if the type is safe to bitwise copy using memcpy/memmove.
void Profile(llvm::FoldingSetNodeID &ID) const
QualType getDesugaredType(const ASTContext &Context) const
Return the specified type with any "sugar" removed from the type.
bool isTriviallyCopyConstructibleType(const ASTContext &Context) const
Return true if this is a trivially copyable type.
bool isTrivialType(const ASTContext &Context) const
Return true if this is a trivial type per (C++0x [basic.types]p9)
bool isNull() const
Return true if this QualType doesn't point to a type yet.
PrimitiveCopyKind isNonTrivialToPrimitiveCopy() const
Check if this is a non-trivial type that would cause a C struct transitively containing this type to ...
const Type * getTypePtr() const
Retrieves a pointer to the underlying (unqualified) type.
LangAS getAddressSpace() const
Return the address space of this type.
bool isConstant(const ASTContext &Ctx) const
bool hasNonTrivialToPrimitiveDestructCUnion() const
Check if this is or contains a C union that is non-trivial to destruct, which is a union that has a m...
Qualifiers getQualifiers() const
Retrieve the set of qualifiers applied to this type.
bool isCXX98PODType(const ASTContext &Context) const
Return true if this is a POD type according to the rules of the C++98 standard, regardless of the cur...
bool hasPostfixDeclaratorSyntax() const
Returns true if the type uses postfix declarator syntax, i.e.
Qualifiers::ObjCLifetime getObjCLifetime() const
Returns lifetime attribute of this type.
QualType stripObjCKindOfType(const ASTContext &ctx) const
Strip Objective-C "__kindof" types from the given type.
QualType getCanonicalType() const
QualType getUnqualifiedType() const
Retrieve the unqualified variant of the given type, removing as little sugar as possible.
QualType substObjCMemberType(QualType objectType, const DeclContext *dc, ObjCSubstitutionContext context) const
Substitute type arguments from an object type for the Objective-C type parameters used in the subject...
bool isWebAssemblyReferenceType() const
Returns true if it is a WebAssembly Reference Type.
SplitQualType getSplitDesugaredType() const
std::optional< NonConstantStorageReason > isNonConstantStorage(const ASTContext &Ctx, bool ExcludeCtor, bool ExcludeDtor)
Determine whether instances of this type can be placed in immutable storage.
bool isTrapType() const
Returns true if it is a OverflowBehaviorType of Trap kind.
SplitQualType split() const
Divides a QualType into its unqualified type and a set of local qualifiers.
bool UseExcessPrecision(const ASTContext &Ctx)
PrimitiveDefaultInitializeKind isNonTrivialToPrimitiveDefaultInitialize() const
Functions to query basic properties of non-trivial C struct types.
void * getAsOpaquePtr() const
bool isWebAssemblyExternrefType() const
Returns true if it is a WebAssembly Externref Type.
QualType getNonPackExpansionType() const
Remove an outer pack expansion type (if any) from this type.
bool isCXX11PODType(const ASTContext &Context) const
Return true if this is a POD type according to the more relaxed rules of the C++11 standard,...
bool mayBeNotDynamicClass() const
Returns true if it is not a class or if the class might not be dynamic.
bool isConstQualified() const
Determine whether this type is const-qualified.
QualType substObjCTypeArgs(ASTContext &ctx, ArrayRef< QualType > typeArgs, ObjCSubstitutionContext context) const
Substitute type arguments for the Objective-C type parameters used in the subject type.
QualType getAtomicUnqualifiedType() const
Remove all qualifiers including _Atomic.
bool requiresBuiltinLaunder(const ASTContext &Context) const
Returns true if this type requires laundering by checking if it is a dynamic class type,...
bool isWrapType() const
Returns true if it is a OverflowBehaviorType of Wrap kind.
bool hasNonTrivialObjCLifetime() const
bool isPODType(const ASTContext &Context) const
Determine whether this is a Plain Old Data (POD) type (C++ 3.9p10).
PrimitiveCopyKind isNonTrivialToPrimitiveDestructiveMove() const
Check if this is a non-trivial type that would cause a C struct transitively containing this type to ...
@ NonConstNonReferenceType
@ PCK_Struct
The type is a struct containing a field whose type is neither PCK_Trivial nor PCK_VolatileTrivial.
@ PCK_Trivial
The type does not fall into any of the following categories.
@ PCK_ARCStrong
The type is an Objective-C retainable pointer type that is qualified with the ARC __strong qualifier.
@ PCK_VolatileTrivial
The type would be trivial except that it is volatile-qualified.
@ PCK_PtrAuth
The type is an address-discriminated signed pointer type.
@ PCK_ARCWeak
The type is an Objective-C retainable pointer type that is qualified with the ARC __weak qualifier.
bool hasNonTrivialToPrimitiveDefaultInitializeCUnion() const
Check if this is or contains a C union that is non-trivial to default-initialize, which is a union th...
A qualifier set is used to build a set of qualifiers.
const Type * strip(QualType type)
Collect any qualifiers on the given type and return an unqualified type.
QualType apply(const ASTContext &Context, QualType QT) const
Apply the collected qualifiers to the given type.
The collection of all-type qualifiers we support.
@ OCL_Strong
Assigning into this object requires the old value to be released and the new value to be retained.
@ OCL_ExplicitNone
This object can be modified without requiring retains or releases.
@ OCL_None
There is no lifetime qualification on this type.
@ OCL_Weak
Reading or writing from this object requires a barrier call.
@ OCL_Autoreleasing
Assigning into this object requires a lifetime extension.
bool isStrictSupersetOf(Qualifiers Other) const
Determine whether this set of qualifiers is a strict superset of another set of qualifiers,...
bool hasNonFastQualifiers() const
Return true if the set contains any qualifiers which require an ExtQuals node to be allocated.
void addConsistentQualifiers(Qualifiers qs)
Add the qualifiers from the given set to this set, given that they don't conflict.
static bool isTargetAddressSpaceSupersetOf(LangAS A, LangAS B, const ASTContext &Ctx)
bool hasAddressSpace() const
unsigned getFastQualifiers() const
bool hasObjCGCAttr() const
bool hasObjCLifetime() const
ObjCLifetime getObjCLifetime() const
LangAS getAddressSpace() const
Represents a struct/union/class.
bool hasNonTrivialToPrimitiveDestructCUnion() const
bool hasNonTrivialToPrimitiveCopyCUnion() const
bool hasNonTrivialToPrimitiveDefaultInitializeCUnion() const
bool isNonTrivialToPrimitiveDestroy() const
bool isNonTrivialToPrimitiveCopy() const
field_range fields() const
RecordDecl * getMostRecentDecl()
bool isNonTrivialToPrimitiveDefaultInitialize() const
Functions to query basic properties of non-trivial C structs.
Declaration of a redeclarable template.
QualType getPointeeTypeAsWritten() const
bool isSpelledAsLValue() const
Encodes a location in the source.
Stmt - This represents one statement.
void Profile(llvm::FoldingSetNodeID &ID, const ASTContext &Context, bool Canonical, bool ProfileLambdaExpr=false) const
Produce a unique representation of the given statement.
void dump() const
Dumps the specified AST fragment and all subtrees to llvm::errs().
Represents the declaration of a struct/union/class/enum.
redecl_range redecls() const
Returns an iterator range for all the redeclarations of the same decl.
bool isCompleteDefinition() const
Return true if this decl has its body fully specified.
NestedNameSpecifier getQualifier() const
Retrieve the nested-name-specifier that qualifies the name of this declaration, if it was present in ...
bool isDependentType() const
Whether this declaration declares a type that is dependent, i.e., a type that somehow depends on temp...
Exposes information about the current target.
virtual bool hasFullBFloat16Type() const
Determine whether the BFloat type is fully supported on this target, i.e arithemtic operations.
virtual bool hasFastHalfType() const
Determine whether the target has fast native support for operations on half types.
virtual bool hasFloat16Type() const
Determine whether the _Float16 type is supported on this target.
virtual bool hasBFloat16Type() const
Determine whether the _BFloat16 type is supported on this target.
virtual bool isAddressSpaceSupersetOf(LangAS A, LangAS B) const
Returns true if an address space can be safely converted to another.
A convenient class for passing around template argument information.
ArrayRef< TemplateArgumentLoc > arguments() const
Location wrapper for a TemplateArgument.
Represents a template argument.
unsigned pack_size() const
The number of template arguments in the given template argument pack.
ArrayRef< TemplateArgument > pack_elements() const
Iterator range referencing all of the elements of a template argument pack.
@ Type
The template argument is a type.
The base class of all kinds of template declarations (e.g., class, function, etc.).
Represents a C++ template name within the type system.
Declaration of a template type parameter.
[BoundsSafety] Represents information of declarations referenced by the arguments of the counted_by a...
ValueDecl * getDecl() const
bool operator==(const TypeCoupledDeclRefInfo &Other) const
void * getOpaqueValue() const
TypeCoupledDeclRefInfo(ValueDecl *D=nullptr, bool Deref=false)
D is to a declaration referenced by the argument of attribute.
void setFromOpaqueValue(void *V)
bool isSugared() const
Returns whether this type directly provides sugar.
TypeOfKind getKind() const
Returns the kind of 'typeof' type this is.
TypeOfExprType(const ASTContext &Context, Expr *E, TypeOfKind Kind, QualType Can=QualType())
Expr * getUnderlyingExpr() const
QualType desugar() const
Remove a single level of sugar.
static void ensure(const Type *T)
static CachedProperties get(QualType T)
static CachedProperties get(const Type *T)
A helper class for Type nodes having an ElaboratedTypeKeyword.
The base class of the type hierarchy.
bool isSizelessType() const
As an extension, we classify types as one of "sized" or "sizeless"; every type is one or the other.
bool isStructureType() const
bool isBlockPointerType() const
const ObjCObjectPointerType * getAsObjCQualifiedClassType() const
bool isLinkageValid() const
True if the computed linkage is valid.
TypedefBitfields TypedefBits
bool isBooleanType() const
const ObjCObjectType * getAsObjCQualifiedInterfaceType() const
const ObjCObjectPointerType * getAsObjCQualifiedIdType() const
const TemplateSpecializationType * getAsNonAliasTemplateSpecializationType() const
Look through sugar for an instance of TemplateSpecializationType which is not a type alias,...
bool isMFloat8Type() const
bool isSignedIntegerOrEnumerationType() const
Determines whether this is an integer type that is signed or an enumeration types whose underlying ty...
bool isPackedVectorBoolType(const ASTContext &ctx) const
bool hasAttr(attr::Kind AK) const
Determine whether this type had the specified attribute applied to it (looking through top-level type...
bool isAlwaysIncompleteType() const
QualType getRVVEltType(const ASTContext &Ctx) const
Returns the representative type for the element of an RVV builtin type.
const RecordType * getAsUnionType() const
NOTE: getAs*ArrayType are methods on ASTContext.
bool isLiteralType(const ASTContext &Ctx) const
Return true if this is a literal type (C++11 [basic.types]p10)
bool isSignedIntegerType() const
Return true if this is an integer type that is signed, according to C99 6.2.5p4 [char,...
bool isComplexType() const
isComplexType() does not include complex integers (a GCC extension).
ArrayTypeBitfields ArrayTypeBits
const ArrayType * castAsArrayTypeUnsafe() const
A variant of castAs<> for array type which silently discards qualifiers from the outermost type.
bool isUnsignedIntegerOrEnumerationType() const
Determines whether this is an integer type that is unsigned or an enumeration types whose underlying ...
bool isIntegralOrUnscopedEnumerationType() const
Determine whether this type is an integral or unscoped enumeration type.
CXXRecordDecl * getAsCXXRecordDecl() const
Retrieves the CXXRecordDecl that this type refers to, either because the type is a RecordType or beca...
VectorTypeBitfields VectorTypeBits
SubstPackTypeBitfields SubstPackTypeBits
RecordDecl * getAsRecordDecl() const
Retrieves the RecordDecl this type refers to.
bool hasIntegerRepresentation() const
Determine whether this type has an integer representation of some sort, e.g., it is an integer type o...
bool isVoidPointerType() const
const ComplexType * getAsComplexIntegerType() const
bool isConstantSizeType() const
Return true if this is not a variable sized type, according to the rules of C99 6....
QualType getLocallyUnqualifiedSingleStepDesugaredType() const
Pull a single level of sugar off of this locally-unqualified type.
bool isFunctionPointerType() const
bool isCountAttributedType() const
bool isObjCARCBridgableType() const
Determine whether the given type T is a "bridgable" Objective-C type, which is either an Objective-C ...
CXXRecordDecl * castAsCXXRecordDecl() const
bool isArithmeticType() const
bool isConstantMatrixType() const
bool isHLSLBuiltinIntangibleType() const
TypeOfBitfields TypeOfBits
bool isIntegerType() const
isIntegerType() does not include complex integers (a GCC extension).
bool isSVESizelessBuiltinType() const
Returns true for SVE scalable vector types.
const T * castAs() const
Member-template castAs<specific type>.
bool isReferenceType() const
bool isHLSLIntangibleType() const
bool isEnumeralType() const
void addDependence(TypeDependence D)
bool isObjCNSObjectType() const
Type(TypeClass tc, QualType canon, TypeDependence Dependence)
const ObjCObjectPointerType * getAsObjCInterfacePointerType() const
NestedNameSpecifier getPrefix() const
If this type represents a qualified-id, this returns its nested name specifier.
bool isScalarType() const
const CXXRecordDecl * getPointeeCXXRecordDecl() const
If this is a pointer or reference to a RecordType, return the CXXRecordDecl that the type refers to.
bool isInterfaceType() const
bool isVariableArrayType() const
bool isSizelessBuiltinType() const
bool isCUDADeviceBuiltinSurfaceType() const
Check if the type is the CUDA device builtin surface type.
bool isSveVLSBuiltinType() const
Determines if this is a sizeless type supported by the 'arm_sve_vector_bits' type attribute,...
bool isIntegralType(const ASTContext &Ctx) const
Determine whether this type is an integral type.
bool isElaboratedTypeSpecifier() const
Determine wither this type is a C++ elaborated-type-specifier.
CountAttributedTypeBitfields CountAttributedTypeBits
const Type * getArrayElementTypeNoTypeQual() const
If this is an array type, return the element type of the array, potentially with type qualifiers miss...
QualType getPointeeType() const
If this is a pointer, ObjC object pointer, or block pointer, this returns the respective pointee.
LinkageInfo getLinkageAndVisibility() const
Determine the linkage and visibility of this type.
bool hasUnsignedIntegerRepresentation() const
Determine whether this type has an unsigned integer representation of some sort, e....
bool isAnyCharacterType() const
Determine whether this type is any of the built-in character types.
bool isExtVectorBoolType() const
bool isWebAssemblyExternrefType() const
Check if this is a WebAssembly Externref Type.
bool canHaveNullability(bool ResultIfUnknown=true) const
Determine whether the given type can have a nullability specifier applied to it, i....
QualType getSveEltType(const ASTContext &Ctx) const
Returns the representative type for the element of an SVE builtin type.
bool isInstantiationDependentType() const
Determine whether this type is an instantiation-dependent type, meaning that the type involves a temp...
bool isLValueReferenceType() const
bool isBitIntType() const
bool isBuiltinType() const
Helper methods to distinguish type categories.
bool isStructuralType() const
Determine if this type is a structural type, per C++20 [temp.param]p7.
bool isDependentType() const
Whether this type is a dependent type, meaning that its definition somehow depends on a template para...
bool isAggregateType() const
Determines whether the type is a C++ aggregate type or C aggregate or union type.
bool isCARCBridgableType() const
Determine whether the given type T is a "bridgeable" C type.
bool isSignableIntegerType(const ASTContext &Ctx) const
RecordDecl * castAsRecordDecl() const
bool isChar16Type() const
bool isAnyComplexType() const
DeducedType * getContainedDeducedType() const
Get the DeducedType whose type will be deduced for a variable with an initializer of this type.
bool containsUnexpandedParameterPack() const
Whether this type is or contains an unexpanded parameter pack, used to support C++0x variadic templat...
ScalarTypeKind getScalarTypeKind() const
Given that this is a scalar type, classify it.
bool hasSignedIntegerRepresentation() const
Determine whether this type has an signed integer representation of some sort, e.g....
QualType getCanonicalTypeInternal() const
const RecordType * getAsStructureType() const
const char * getTypeClassName() const
bool isWebAssemblyTableType() const
Returns true if this is a WebAssembly table type: either an array of reference types,...
@ PtrdiffT
The "ptrdiff_t" type.
@ SizeT
The "size_t" type.
@ SignedSizeT
The signed integer type corresponding to "size_t".
const Type * getBaseElementTypeUnsafe() const
Get the base element type of this type, potentially discarding type qualifiers.
bool isHLSLStandardLayoutRecordOrArrayOf() const
AttributedTypeBitfields AttributedTypeBits
bool isObjCBoxableRecordType() const
bool isMatrixType() const
bool isChar32Type() const
bool isStandardLayoutType() const
Test if this type is a standard-layout type.
TagTypeBitfields TagTypeBits
bool isOverflowBehaviorType() const
EnumDecl * castAsEnumDecl() const
bool isVariablyModifiedType() const
Whether this type is a variably-modified type (C99 6.7.5).
bool isComplexIntegerType() const
bool isUnscopedEnumerationType() const
bool isStdByteType() const
UnresolvedUsingBitfields UnresolvedUsingBits
bool isCUDADeviceBuiltinTextureType() const
Check if the type is the CUDA device builtin texture type.
bool isBlockCompatibleObjCPointerType(ASTContext &ctx) const
bool isObjCClassOrClassKindOfType() const
Whether the type is Objective-C 'Class' or a __kindof type of an Class type, e.g.,...
const ArrayType * getAsArrayTypeUnsafe() const
A variant of getAs<> for array types which silently discards qualifiers from the outermost type.
bool isObjCLifetimeType() const
Returns true if objects of this type have lifetime semantics under ARC.
bool isHLSLResourceRecord() const
EnumDecl * getAsEnumDecl() const
Retrieves the EnumDecl this type refers to.
bool isObjCIndirectLifetimeType() const
bool hasUnnamedOrLocalType() const
Whether this type is or contains a local or unnamed type.
bool isPointerOrReferenceType() const
Qualifiers::ObjCLifetime getObjCARCImplicitLifetime() const
Return the implicit lifetime for this type, which must not be dependent.
FunctionTypeBitfields FunctionTypeBits
bool isObjCQualifiedInterfaceType() const
bool isSpecifierType() const
Returns true if this type can be represented by some set of type specifiers.
bool isIncompleteType(NamedDecl **Def=nullptr) const
Types are partitioned into 3 broad categories (C99 6.2.5p1): object types, function types,...
bool isObjCObjectPointerType() const
SubstTemplateTypeParmTypeBitfields SubstTemplateTypeParmTypeBits
bool isStructureTypeWithFlexibleArrayMember() const
TypeDependence getDependence() const
bool hasFloatingRepresentation() const
Determine whether this type has a floating-point representation of some sort, e.g....
bool isStructureOrClassType() const
bool isVectorType() const
bool isRVVVLSBuiltinType() const
Determines if this is a sizeless type supported by the 'riscv_rvv_vector_bits' type attribute,...
bool isRealFloatingType() const
Floating point categories.
bool isRVVSizelessBuiltinType() const
Returns true for RVV scalable vector types.
std::optional< ArrayRef< QualType > > getObjCSubstitutions(const DeclContext *dc) const
Retrieve the set of substitutions required when accessing a member of the Objective-C receiver type t...
const T * getAsCanonical() const
If this type is canonically the specified type, return its canonical type cast to that specified type...
Linkage getLinkage() const
Determine the linkage of this type.
ObjCObjectTypeBitfields ObjCObjectTypeBits
bool isFloatingType() const
const ObjCObjectType * getAsObjCInterfaceType() const
bool isWideCharType() const
bool isUnsignedIntegerType() const
Return true if this is an integer type that is unsigned, according to C99 6.2.5p6 [which returns true...
bool hasSizedVLAType() const
Whether this type involves a variable-length array type with a definite size.
TypeClass getTypeClass() const
bool isCanonicalUnqualified() const
Determines if this type would be canonical if it had no further qualification.
bool hasAutoForTrailingReturnType() const
Determine whether this type was written with a leading 'auto' corresponding to a trailing return type...
bool isObjCIdOrObjectKindOfType(const ASTContext &ctx, const ObjCObjectType *&bound) const
Whether the type is Objective-C 'id' or a __kindof type of an object type, e.g., __kindof NSView * or...
const T * getAs() const
Member-template getAs<specific type>'.
const Type * getUnqualifiedDesugaredType() const
Return the specified type with any "sugar" removed from the type, removing any typedefs,...
bool isObjCARCImplicitlyUnretainedType() const
Determines if this type, which must satisfy isObjCLifetimeType(), is implicitly __unsafe_unretained r...
bool isRecordType() const
bool isHLSLResourceRecordArray() const
bool isObjCRetainableType() const
bool isObjCIndependentClassType() const
bool isSizelessVectorType() const
Returns true for all scalable vector types.
bool isScopedEnumeralType() const
Determine whether this type is a scoped enumeration type.
NullabilityKindOrNone getNullability() const
Determine the nullability of the given type.
bool acceptsObjCTypeParams() const
Determines if this is an ObjC interface type that may accept type parameters.
QualType getSizelessVectorEltType(const ASTContext &Ctx) const
Returns the representative type for the element of a sizeless vector builtin type.
bool isUnicodeCharacterType() const
bool hasBooleanRepresentation() const
Determine whether this type has a boolean representation – i.e., it is a boolean type,...
Base class for declarations which introduce a typedef-name.
QualType getUnderlyingType() const
bool typeMatchesDecl() const
Represents a dependent using declaration which was marked with typename.
Represents a shadow declaration implicitly introduced into a scope by a (resolved) using-declaration ...
Represent the declaration of a variable (in which case it is an lvalue) a function (in which case it ...
Expr * getSizeExpr() const
Represents a GCC generic vector type.
unsigned getNumElements() const
VectorType(QualType vecType, unsigned nElements, QualType canonType, VectorKind vecKind)
VectorKind getVectorKind() const
QualType ElementType
The element type of the vector.
QualType getElementType() const
Defines the Linkage enumeration and various utility functions.
Defines the clang::TargetInfo interface.
mlir::Type getBaseType(mlir::Value varPtr)
@ AttributedType
The l-value was considered opaque, so the alignment was determined from a type, but that type was an ...
const internal::VariadicAllOfMatcher< Attr > attr
const internal::VariadicAllOfMatcher< Type > type
Matches Types in the clang AST.
const internal::VariadicAllOfMatcher< Decl > decl
Matches declarations.
const AstTypeMatcher< TypedefType > typedefType
The JSON file list parser is used to communicate input to InstallAPI.
@ Overload
This is a legitimate overload: the existing declarations are functions or function templates with dif...
bool isa(CodeGen::Address addr)
if(T->getSizeExpr()) TRY_TO(TraverseStmt(const_cast< Expr * >(T -> getSizeExpr())))
AutoTypeKeyword
Which keyword(s) were used to create an AutoType.
CanThrowResult
Possible results from evaluation of a noexcept expression.
TypeDependenceScope::TypeDependence TypeDependence
void initialize(TemplateInstantiationCallbackPtrs &Callbacks, const Sema &TheSema)
Linkage minLinkage(Linkage L1, Linkage L2)
Compute the minimum linkage given two linkages.
@ Nullable
Values of this type can be null.
@ Unspecified
Whether values of this type can be null is (explicitly) unspecified.
@ NonNull
Values of this type can never be null.
@ TemplateName
The identifier is a template name. FIXME: Add an annotation for that.
bool IsEnumDeclComplete(EnumDecl *ED)
Check if the given decl is complete.
bool isPackProducingBuiltinTemplateName(TemplateName N)
ExprDependence computeDependence(FullExpr *E)
@ Private
'private' clause, allowed on 'parallel', 'serial', 'loop', 'parallel loop', and 'serial loop' constru...
@ Vector
'vector' clause, allowed on 'loop', Combined, and 'routine' directives.
TypeOfKind
The kind of 'typeof' expression we're after.
nullptr
This class represents a compute construct, representing a 'Kind' of ‘parallel’, 'serial',...
TypeDependence toTypeDependence(ExprDependence D)
ExprDependence turnValueToTypeDependence(ExprDependence D)
@ Dependent
Parse the block as a dependent block, which may be used in some template instantiations but not other...
Linkage
Describes the different kinds of linkage (C++ [basic.link], C99 6.2.2) that an entity may have.
@ External
External linkage, which indicates that the entity can be referred to from other translation units.
ObjCSubstitutionContext
The kind of type we are substituting Objective-C type arguments into.
@ Superclass
The superclass of a type.
@ Result
The result type of a method or function.
ArraySizeModifier
Capture whether this is a normal array (e.g.
OptionalUnsigned< unsigned > UnsignedOrNone
bool isComputedNoexcept(ExceptionSpecificationType ESpecType)
@ Template
We are parsing a template declaration.
TagTypeKind
The kind of a tag type.
@ Interface
The "__interface" keyword.
@ Struct
The "struct" keyword.
@ Class
The "class" keyword.
@ Union
The "union" keyword.
@ Enum
The "enum" keyword.
@ Keyword
The name has been typo-corrected to a keyword.
@ Type
The name was classified as a type.
LangAS
Defines the address space values used by the address space qualifier of QualType.
void FixedPointValueToString(SmallVectorImpl< char > &Str, llvm::APSInt Val, unsigned Scale)
@ Deduced
The normal deduced case.
@ Undeduced
Not deduced yet. This is for example an 'auto' which was just parsed.
@ DeducedAsPack
Same as above, but additionally this represents a case where the deduced entity itself is a pack.
@ DeducedAsDependent
This is a special case where the initializer is dependent, so we can't deduce a type yet.
std::tuple< NamedDecl *, TemplateArgument > getReplacedTemplateParameter(Decl *D, unsigned Index)
Internal helper used by Subst* nodes to retrieve a parameter from the AssociatedDecl,...
bool isPtrSizeAddressSpace(LangAS AS)
const StreamingDiagnostic & operator<<(const StreamingDiagnostic &DB, const ConceptReference *C)
Insertion operator for diagnostics.
CallingConv
CallingConv - Specifies the calling convention that a function uses.
U cast(CodeGen::Address addr)
@ None
The alignment was not explicit in code.
ElaboratedTypeKeyword
The elaboration keyword that precedes a qualified type name or introduces an elaborated-type-specifie...
@ Interface
The "__interface" keyword introduces the elaborated-type-specifier.
@ None
No keyword precedes the qualified type name.
@ Struct
The "struct" keyword introduces the elaborated-type-specifier.
@ Class
The "class" keyword introduces the elaborated-type-specifier.
@ Union
The "union" keyword introduces the elaborated-type-specifier.
@ Enum
The "enum" keyword introduces the elaborated-type-specifier.
@ Typename
The "typename" keyword precedes the qualified type name, e.g., typename T::type.
TypeDependence toSemanticDependence(TypeDependence D)
TypeDependence toSyntacticDependence(TypeDependence D)
@ Other
Other implicit parameter.
@ EST_DependentNoexcept
noexcept(expression), value-dependent
@ EST_Uninstantiated
not instantiated yet
@ EST_Unparsed
not parsed yet
@ EST_NoThrow
Microsoft __declspec(nothrow) extension.
@ EST_None
no exception specification
@ EST_MSAny
Microsoft throw(...) extension.
@ EST_BasicNoexcept
noexcept
@ EST_NoexceptFalse
noexcept(expression), evals to 'false'
@ EST_Unevaluated
not evaluated yet, for special member function
@ EST_NoexceptTrue
noexcept(expression), evals to 'true'
@ EST_Dynamic
throw(T1, T2)
OptionalUnsigned< NullabilityKind > NullabilityKindOrNone
__UINTPTR_TYPE__ uintptr_t
An unsigned integer type with the property that any valid pointer to void can be converted to this ty...
A FunctionEffect plus a potential boolean expression determining whether the effect is declared (e....
FunctionEffectWithCondition(FunctionEffect E, const EffectConditionExpr &C)
std::string description() const
Return a textual description of the effect, and its condition, if any.
FunctionDecl * SourceDecl
The function whose exception specification this is, for EST_Unevaluated and EST_Uninstantiated.
FunctionDecl * SourceTemplate
The function template whose exception specification this is instantiated from, for EST_Uninstantiated...
ExceptionSpecificationType Type
The kind of exception specification this is.
ArrayRef< QualType > Exceptions
Explicitly-specified list of exception types.
Expr * NoexceptExpr
Noexcept expression, if this is a computed noexcept specification.
Extra information about a function prototype.
ExceptionSpecInfo ExceptionSpec
FunctionTypeExtraAttributeInfo ExtraAttributeInfo
bool requiresFunctionProtoTypeArmAttributes() const
unsigned AArch64SMEAttributes
SourceLocation EllipsisLoc
FunctionEffectsRef FunctionEffects
unsigned CFIUncheckedCallee
const ExtParameterInfo * ExtParameterInfos
RefQualifierKind RefQualifier
bool requiresFunctionProtoTypeExtraAttributeInfo() const
unsigned HasTrailingReturn
bool requiresFunctionProtoTypeExtraBitfields() const
static StringRef getKeywordName(ElaboratedTypeKeyword Keyword)
static ElaboratedTypeKeyword getKeywordForTagTypeKind(TagTypeKind Tag)
Converts a TagTypeKind into an elaborated type keyword.
static TagTypeKind getTagTypeKindForKeyword(ElaboratedTypeKeyword Keyword)
Converts an elaborated type keyword into a TagTypeKind.
static TagTypeKind getTagTypeKindForTypeSpec(unsigned TypeSpec)
Converts a type specifier (DeclSpec::TST) into a tag type kind.
static bool KeywordIsTagTypeKind(ElaboratedTypeKeyword Keyword)
static ElaboratedTypeKeyword getKeywordForTypeSpec(unsigned TypeSpec)
Converts a type specifier (DeclSpec::TST) into an elaborated type keyword.
constexpr underlying_type toInternalRepresentation() const
Describes how types, statements, expressions, and declarations should be printed.
unsigned Bool
Whether we can use 'bool' rather than '_Bool' (even if the language doesn't actually have 'bool',...
unsigned NullptrTypeInNamespace
Whether 'nullptr_t' is in namespace 'std' or not.
unsigned Half
When true, print the half-precision floating-point type as 'half' instead of '__fp16'.
unsigned MSWChar
When true, print the built-in wchar_t type as __wchar_t.
A std::pair-like structure for storing a qualified type split into its local qualifiers and its local...
const Type * Ty
The locally-unqualified type.
Qualifiers Quals
The local qualifiers.