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");
2790 if (Context.getLangOpts().CPlusPlus11)
2803 if ((*this)->isIncompleteArrayType())
2804 return Context.getBaseElementType(*this).isCXX98PODType(Context);
2806 if ((*this)->isIncompleteType())
2815 if (Context.containsAddressDiscriminatedPointerAuth(CanonicalType))
2822 case Type::VariableArray:
2823 case Type::ConstantArray:
2825 return Context.getBaseElementType(*this).isCXX98PODType(Context);
2827 case Type::ObjCObjectPointer:
2828 case Type::BlockPointer:
2832 case Type::MemberPointer:
2834 case Type::ExtVector:
2836 case Type::OverflowBehavior:
2843 if (
const auto *ClassDecl =
2845 return ClassDecl->isPOD();
2859 if ((*this)->isArrayType())
2860 return Context.getBaseElementType(*this).isTrivialType(Context);
2862 if ((*this)->isSizelessBuiltinType())
2867 if ((*this)->isIncompleteType())
2879 if (Context.containsAddressDiscriminatedPointerAuth(CanonicalType))
2898 return ClassDecl->hasTrivialDefaultConstructor() &&
2899 !ClassDecl->hasNonTrivialDefaultConstructor() &&
2900 ClassDecl->isTriviallyCopyable();
2912 bool IsCopyConstructible) {
2913 if (
type->isArrayType())
2915 Context, IsCopyConstructible);
2917 if (
type.hasNonTrivialObjCLifetime())
2951 if (
const auto *ClassDecl = dyn_cast<CXXRecordDecl>(RD)) {
2952 if (IsCopyConstructible)
2953 return ClassDecl->isTriviallyCopyConstructible();
2954 return ClassDecl->isTriviallyCopyable();
2956 return !RD->isNonTrivialToPrimitiveCopy();
2970 if (CanonicalType.hasNonTrivialObjCLifetime())
2972 if (CanonicalType->isArrayType())
2973 return Context.getBaseElementType(CanonicalType)
2974 .isBitwiseCloneableType(Context);
2976 if (CanonicalType->isIncompleteType())
2981 if (Context.containsAddressDiscriminatedPointerAuth(CanonicalType))
2984 const auto *RD = CanonicalType->getAsRecordDecl();
2988 if (RD->isInvalidDecl())
2994 if (RD->mayInsertExtraPadding())
2997 for (
auto *
const Field : RD->fields()) {
2998 if (!Field->getType().isBitwiseCloneableType(Context))
3002 if (
const auto *CXXRD = dyn_cast<CXXRecordDecl>(RD)) {
3003 for (
auto Base : CXXRD->bases())
3004 if (!
Base.getType().isBitwiseCloneableType(Context))
3006 for (
auto VBase : CXXRD->vbases())
3007 if (!VBase.getType().isBitwiseCloneableType(Context))
3020 return !Context.getLangOpts().ObjCAutoRefCount &&
3021 Context.getLangOpts().ObjCWeak &&
3054 return OBT->getBehaviorKind() ==
3055 OverflowBehaviorType::OverflowBehaviorKind::Wrap;
3062 return OBT->getBehaviorKind() ==
3063 OverflowBehaviorType::OverflowBehaviorKind::Trap;
3070 if (
const auto *RD =
3086 if (
const auto *RD =
3126 assert(BaseTy &&
"NULL element type");
3160 if (
const auto *ClassDecl = dyn_cast<CXXRecordDecl>(RD))
3161 return ClassDecl->isLiteral();
3168 return AT->getValueType()->isLiteralType(Ctx);
3170 if (
const auto *OBT = BaseTy->
getAs<OverflowBehaviorType>())
3171 return OBT->getUnderlyingType()->isLiteralType(Ctx);
3193 return RD->isStructural();
3206 assert(BaseTy &&
"NULL element type");
3217 if (
const auto *ClassDecl = dyn_cast<CXXRecordDecl>(RD);
3218 ClassDecl && !ClassDecl->isStandardLayout())
3246 assert(BaseTy &&
"NULL element type");
3257 if (Context.containsAddressDiscriminatedPointerAuth(*
this))
3264 if (
const auto *ClassDecl = dyn_cast<CXXRecordDecl>(RD)) {
3267 if (!ClassDecl->isTrivial())
3273 if (!ClassDecl->isStandardLayout())
3304 const auto *ED = ET->getDecl();
3306 if (II && II->
isStr(
"align_val_t") && ED->isInStdNamespace())
3314 const auto *ED = ET->getDecl();
3316 if (II && II->
isStr(
"byte") && ED->isInStdNamespace())
3332 case TemplateTypeParm:
3333 case SubstTemplateTypeParm:
3334 case TemplateSpecialization:
3377 llvm_unreachable(
"Type specifier is not a tag type kind.");
3394 llvm_unreachable(
"Unknown tag type kind.");
3412 llvm_unreachable(
"Elaborated type keyword is not a tag type kind.");
3414 llvm_unreachable(
"Unknown elaborated type keyword.");
3429 llvm_unreachable(
"Unknown elaborated type keyword.");
3443 return "__interface";
3450 llvm_unreachable(
"Unknown elaborated type keyword.");
3455 if (
const auto *TST = dyn_cast<TemplateSpecializationType>(
this))
3457 else if (
const auto *DepName = dyn_cast<DependentNameType>(
this))
3458 Keyword = DepName->getKeyword();
3459 else if (
const auto *T = dyn_cast<TagType>(
this))
3461 else if (
const auto *T = dyn_cast<TypedefType>(
this))
3463 else if (
const auto *T = dyn_cast<UnresolvedUsingType>(
this))
3465 else if (
const auto *T = dyn_cast<UsingType>(
this))
3475#define ABSTRACT_TYPE(Derived, Base)
3476#define TYPE(Derived, Base) \
3479#include "clang/AST/TypeNodes.inc"
3482 llvm_unreachable(
"Invalid type class.");
3490 return Policy.
Bool ?
"bool" :
"_Bool";
3496 return "signed char";
3508 return "unsigned char";
3510 return "unsigned short";
3512 return "unsigned int";
3514 return "unsigned long";
3516 return "unsigned long long";
3518 return "unsigned __int128";
3520 return Policy.
Half ?
"half" :
"__fp16";
3528 return "long double";
3530 return "short _Accum";
3534 return "long _Accum";
3536 return "unsigned short _Accum";
3538 return "unsigned _Accum";
3540 return "unsigned long _Accum";
3541 case BuiltinType::ShortFract:
3542 return "short _Fract";
3543 case BuiltinType::Fract:
3545 case BuiltinType::LongFract:
3546 return "long _Fract";
3547 case BuiltinType::UShortFract:
3548 return "unsigned short _Fract";
3549 case BuiltinType::UFract:
3550 return "unsigned _Fract";
3551 case BuiltinType::ULongFract:
3552 return "unsigned long _Fract";
3553 case BuiltinType::SatShortAccum:
3554 return "_Sat short _Accum";
3555 case BuiltinType::SatAccum:
3556 return "_Sat _Accum";
3557 case BuiltinType::SatLongAccum:
3558 return "_Sat long _Accum";
3559 case BuiltinType::SatUShortAccum:
3560 return "_Sat unsigned short _Accum";
3561 case BuiltinType::SatUAccum:
3562 return "_Sat unsigned _Accum";
3563 case BuiltinType::SatULongAccum:
3564 return "_Sat unsigned long _Accum";
3565 case BuiltinType::SatShortFract:
3566 return "_Sat short _Fract";
3567 case BuiltinType::SatFract:
3568 return "_Sat _Fract";
3569 case BuiltinType::SatLongFract:
3570 return "_Sat long _Fract";
3571 case BuiltinType::SatUShortFract:
3572 return "_Sat unsigned short _Fract";
3573 case BuiltinType::SatUFract:
3574 return "_Sat unsigned _Fract";
3575 case BuiltinType::SatULongFract:
3576 return "_Sat unsigned long _Fract";
3580 return "__float128";
3585 return Policy.
MSWChar ?
"__wchar_t" :
"wchar_t";
3595 return "<overloaded function type>";
3597 return "<bound member function type>";
3598 case UnresolvedTemplate:
3599 return "<unresolved template type>";
3601 return "<pseudo-object type>";
3603 return "<dependent type>";
3605 return "<unknown type>";
3606 case ARCUnbridgedCast:
3607 return "<ARC unbridged cast type>";
3609 return "<builtin fn type>";
3616#define IMAGE_TYPE(ImgType, Id, SingletonId, Access, Suffix) \
3618 return "__" #Access " " #ImgType "_t";
3619#include "clang/Basic/OpenCLImageTypes.def"
3625 return "clk_event_t";
3629 return "reserve_id_t";
3630 case IncompleteMatrixIdx:
3631 return "<incomplete matrix index type>";
3633 return "<array section type>";
3634 case OMPArrayShaping:
3635 return "<OpenMP array shaping type>";
3637 return "<OpenMP iterator type>";
3638#define EXT_OPAQUE_TYPE(ExtType, Id, Ext) \
3641#include "clang/Basic/OpenCLExtensionTypes.def"
3642#define SVE_TYPE(Name, Id, SingletonId) \
3645#include "clang/Basic/AArch64ACLETypes.def"
3646#define PPC_VECTOR_TYPE(Name, Id, Size) \
3649#include "clang/Basic/PPCTypes.def"
3650#define RVV_TYPE(Name, Id, SingletonId) \
3653#include "clang/Basic/RISCVVTypes.def"
3654#define WASM_TYPE(Name, Id, SingletonId) \
3657#include "clang/Basic/WebAssemblyReferenceTypes.def"
3658#define AMDGPU_TYPE(Name, Id, SingletonId, Width, Align) \
3661#include "clang/Basic/AMDGPUTypes.def"
3662#define HLSL_INTANGIBLE_TYPE(Name, Id, SingletonId) \
3665#include "clang/Basic/HLSLIntangibleTypes.def"
3668 llvm_unreachable(
"Invalid builtin type.");
3673 if (
auto *PET = dyn_cast<PackExpansionType>(
getTypePtr()))
3674 return PET->getPattern();
3679 if (
const auto *RefType =
getTypePtr()->getAs<ReferenceType>())
3687 if (!Context.getLangOpts().CPlusPlus ||
3696 return FPT->hasCFIUncheckedCallee();
3713 return "vectorcall";
3725 return "aarch64_vector_pcs";
3727 return "aarch64_sve_pcs";
3729 return "intel_ocl_bicc";
3731 return "spir_function";
3733 return "device_kernel";
3737 return "swiftasynccall";
3739 return "preserve_most";
3741 return "preserve_all";
3745 return "preserve_none";
3748#define CC_VLS_CASE(ABI_VLEN) \
3749 case CC_RISCVVLSCall_##ABI_VLEN: return "riscv_vls_cc(" #ABI_VLEN ")";
3766 llvm_unreachable(
"Invalid calling convention.");
3784 assert(
getNumParams() == params.size() &&
"NumParams overflow!");
3793 auto &ExtraBits = *getTrailingObjects<FunctionTypeExtraBitfields>();
3801 auto &ExtraAttrInfo = *getTrailingObjects<FunctionTypeExtraAttributeInfo>();
3805 auto &ExtraBits = *getTrailingObjects<FunctionTypeExtraBitfields>();
3806 ExtraBits.HasExtraAttributeInfo =
true;
3810 auto &ArmTypeAttrs = *getTrailingObjects<FunctionTypeArmAttributes>();
3811 ArmTypeAttrs = FunctionTypeArmAttributes();
3814 auto &ExtraBits = *getTrailingObjects<FunctionTypeExtraBitfields>();
3815 ExtraBits.HasArmTypeAttributes =
true;
3819 auto *argSlot = getTrailingObjects<QualType>();
3822 ~TypeDependence::VariablyModified);
3823 argSlot[i] = params[i];
3828 auto &ArmTypeAttrs = *getTrailingObjects<FunctionTypeArmAttributes>();
3830 "Not enough bits to encode SME attributes");
3836 auto &ExtraBits = *getTrailingObjects<FunctionTypeExtraBitfields>();
3838 assert(NumExceptions <= 1023 &&
"Not enough bits to encode exceptions");
3839 ExtraBits.NumExceptionType = NumExceptions;
3841 assert(hasExtraBitfields() &&
"missing trailing extra bitfields!");
3843 reinterpret_cast<QualType *
>(getTrailingObjects<ExceptionType>());
3851 (TypeDependence::Instantiation | TypeDependence::UnexpandedPack));
3853 exnSlot[I++] = ExceptionType;
3867 (TypeDependence::Instantiation | TypeDependence::UnexpandedPack));
3873 auto **slot = getTrailingObjects<FunctionDecl *>();
3881 auto **slot = getTrailingObjects<FunctionDecl *>();
3900 auto *extParamInfos = getTrailingObjects<ExtParameterInfo>();
3907 *getTrailingObjects<Qualifiers>() = epi.
TypeQuals;
3914 auto &EllipsisLoc = *getTrailingObjects<SourceLocation>();
3919 auto &ExtraBits = *getTrailingObjects<FunctionTypeExtraBitfields>();
3921 ExtraBits.NumFunctionEffects = EffectsCount;
3922 assert(ExtraBits.NumFunctionEffects == EffectsCount &&
3923 "effect bitfield overflow");
3926 auto *DestFX = getTrailingObjects<FunctionEffect>();
3927 llvm::uninitialized_copy(SrcFX, DestFX);
3930 if (!SrcConds.empty()) {
3931 ExtraBits.EffectsHaveConditions =
true;
3932 auto *DestConds = getTrailingObjects<EffectConditionExpr>();
3933 llvm::uninitialized_copy(SrcConds, DestConds);
3934 assert(llvm::any_of(SrcConds,
3935 [](
const EffectConditionExpr &EC) {
3937 return E->isTypeDependent() ||
3938 E->isValueDependent();
3941 "expected a dependent expression among the conditions");
3949 return NE->isValueDependent();
3961 return NE->isInstantiationDependent();
3972 llvm_unreachable(
"should not call this with unresolved exception specs");
3998 llvm_unreachable(
"unexpected exception specification kind");
4002 for (
unsigned ArgIdx =
getNumParams(); ArgIdx; --ArgIdx)
4010 const QualType *ArgTys,
unsigned NumParams,
4011 const ExtProtoInfo &epi,
4035 ID.AddPointer(
Result.getAsOpaquePtr());
4036 for (
unsigned i = 0; i != NumParams; ++i)
4037 ID.AddPointer(ArgTys[i].getAsOpaquePtr());
4041 assert(!(
unsigned(epi.Variadic) & ~1) && !(
unsigned(epi.RefQualifier) & ~3) &&
4042 !(
unsigned(epi.ExceptionSpec.Type) & ~15) &&
4043 "Values larger than expected.");
4044 ID.AddInteger(
unsigned(epi.Variadic) + (epi.RefQualifier << 1) +
4045 (epi.ExceptionSpec.Type << 3));
4046 ID.Add(epi.TypeQuals);
4048 for (
QualType Ex : epi.ExceptionSpec.Exceptions)
4051 epi.ExceptionSpec.NoexceptExpr->Profile(ID, Context, Canonical);
4054 ID.AddPointer(epi.ExceptionSpec.SourceDecl->getCanonicalDecl());
4056 if (epi.ExtParameterInfos) {
4057 for (
unsigned i = 0; i != NumParams; ++i)
4058 ID.AddInteger(epi.ExtParameterInfos[i].getOpaqueValue());
4061 epi.ExtInfo.Profile(ID);
4062 epi.ExtraAttributeInfo.Profile(ID);
4064 unsigned EffectCount = epi.FunctionEffects.size();
4065 bool HasConds = !epi.FunctionEffects.Conditions.empty();
4067 ID.AddInteger((EffectCount << 3) | (HasConds << 2) |
4068 (epi.AArch64SMEAttributes << 1) | epi.HasTrailingReturn);
4069 ID.AddInteger(epi.CFIUncheckedCallee);
4071 for (
unsigned Idx = 0; Idx != EffectCount; ++Idx) {
4072 ID.AddInteger(epi.FunctionEffects.Effects[Idx].toOpaqueInt32());
4074 ID.AddPointer(epi.FunctionEffects.Conditions[Idx].getCondition());
4085 : Data(D, Deref << DerefShift) {}
4088 return Data.getInt() & DerefMask;
4093 return Data.getOpaqueValue();
4100 Data.setFromOpaqueValue(
V);
4103OverflowBehaviorType::OverflowBehaviorType(
4105 OverflowBehaviorType::OverflowBehaviorKind Kind)
4106 :
Type(OverflowBehavior, Canon, Underlying->getDependence()),
4107 UnderlyingType(Underlying), BehaviorKind(Kind) {}
4113CountAttributedType::CountAttributedType(
4117 CountExpr(CountExpr) {
4121 auto *DeclSlot = getTrailingObjects();
4122 llvm::copy(CoupledDecls, DeclSlot);
4131#define ENUMERATE_ATTRS(PREFIX) \
4133 if (isCountInBytes()) { \
4135 return PREFIX "sized_by_or_null"; \
4136 return PREFIX "sized_by"; \
4139 return PREFIX "counted_by_or_null"; \
4140 return PREFIX "counted_by"; \
4143 if (WithMacroPrefix)
4148#undef ENUMERATE_ATTRS
4154 bool HasTypeDifferentFromDecl)
4156 Keyword, TC, UnderlyingType.getCanonicalType(),
4160 ~NestedNameSpecifierDependence::
Dependent)
4164 *getTrailingObjects<NestedNameSpecifier>() = Qualifier;
4165 if ((
TypedefBits.hasTypeDifferentFromDecl = HasTypeDifferentFromDecl))
4166 *getTrailingObjects<QualType>() = UnderlyingType;
4171 : *getTrailingObjects<QualType>();
4177 const Type *CanonicalType)
4183 ~NestedNameSpecifierDependence::
Dependent)
4187 *getTrailingObjects<NestedNameSpecifier>() = Qualifier;
4196 if ((
UsingBits.hasQualifier = !!Qualifier))
4197 *getTrailingObjects() = Qualifier;
4206 while (
auto *InnerMQT = dyn_cast<MacroQualifiedType>(Inner)) {
4209 Inner = InnerMQT->getModifiedType();
4220 ? Context.getUnqualifiedArrayType(Can).getAtomicUnqualifiedType()
4225 TOExpr(E), Context(Context) {
4226 TypeOfBits.Kind =
static_cast<unsigned>(Kind);
4235 ? Context.getUnqualifiedArrayType(QT).getAtomicUnqualifiedType()
4244 E->
Profile(ID, Context,
true);
4245 ID.AddBoolean(IsUnqual);
4252 ? Context.getUnqualifiedArrayType(Can).getAtomicUnqualifiedType()
4254 T->getDependence()),
4255 TOType(T), Context(Context) {
4256 TypeOfBits.Kind =
static_cast<unsigned>(Kind);
4259QualType TypeOfType::desugar()
const {
4262 ? Context.getUnqualifiedArrayType(QT).getAtomicUnqualifiedType()
4270 :
Type(Decltype, can,
4274 (E->
getType()->getDependence() &
4276 E(E), UnderlyingType(underlyingType) {}
4278bool DecltypeType::isSugared()
const {
return !E->isInstantiationDependent(); }
4280QualType DecltypeType::desugar()
const {
4287DependentDecltypeType::DependentDecltypeType(
Expr *E)
4290void DependentDecltypeType::Profile(llvm::FoldingSetNodeID &ID,
4292 E->
Profile(ID, Context,
true);
4296 Expr *IndexExpr,
bool FullySubstituted,
4298 :
Type(PackIndexing, Canonical,
4300 Pattern(Pattern), IndexExpr(IndexExpr),
Size(Expansions.size()),
4301 FullySubstituted(FullySubstituted) {
4303 llvm::uninitialized_copy(Expansions, getTrailingObjects());
4307 if (isInstantiationDependentType())
4308 return std::nullopt;
4310 ConstantExpr *CE = dyn_cast<ConstantExpr>(getIndexExpr());
4312 return std::nullopt;
4314 assert(Index.isNonNegative() &&
"Invalid index");
4315 return static_cast<unsigned>(Index.getExtValue());
4319PackIndexingType::computeDependence(
QualType Pattern,
Expr *IndexExpr,
4324 ? TypeDependence::DependentInstantiation
4325 : TypeDependence::None);
4326 if (Expansions.empty())
4327 TD |= Pattern->
getDependence() & TypeDependence::DependentInstantiation;
4329 for (
const QualType &T : Expansions)
4332 if (!(IndexD & TypeDependence::UnexpandedPack))
4338 TD |= TypeDependence::Error | TypeDependence::DependentInstantiation;
4343void PackIndexingType::Profile(llvm::FoldingSetNodeID &ID,
4345 Profile(ID, Context, getPattern(), getIndexExpr(), isFullySubstituted(),
4349void PackIndexingType::Profile(llvm::FoldingSetNodeID &ID,
4351 Expr *E,
bool FullySubstituted,
4354 E->
Profile(ID, Context,
true);
4355 ID.AddBoolean(FullySubstituted);
4356 if (!Expansions.empty()) {
4357 ID.AddInteger(Expansions.size());
4359 T.getCanonicalType().
Profile(ID);
4365UnaryTransformType::UnaryTransformType(
QualType BaseType,
4366 QualType UnderlyingType, UTTKind UKind,
4368 :
Type(UnaryTransform, CanonicalType, BaseType->getDependence()),
4369 BaseType(BaseType), UnderlyingType(UnderlyingType), UKind(UKind) {}
4373 bool OwnsTag,
bool ISInjected,
const Type *CanonicalType)
4380 ~NestedNameSpecifierDependence::
Dependent)
4384 getTrailingQualifier() = Qualifier;
4389void *TagType::getTrailingPointer()
const {
4390 switch (getTypeClass()) {
4395 case Type::InjectedClassName:
4396 return const_cast<InjectedClassNameType *
>(
4399 llvm_unreachable(
"unexpected type class");
4404 assert(TagTypeBits.HasQualifier);
4406 getTrailingPointer(), llvm::Align::Of<NestedNameSpecifier *>()));
4410 return TagTypeBits.HasQualifier ? getTrailingQualifier() : std::nullopt;
4414 auto *
Decl = dyn_cast<CXXRecordDecl>(
decl);
4417 if (
auto *RD = dyn_cast<ClassTemplateSpecializationDecl>(
Decl))
4418 return RD->getSpecializedTemplate();
4419 return Decl->getDescribedClassTemplate();
4423 auto *TD = getTemplateDecl();
4426 if (isCanonicalUnqualified())
4433TagType::getTemplateArgs(
const ASTContext &Ctx)
const {
4434 auto *
Decl = dyn_cast<CXXRecordDecl>(
decl);
4438 if (
auto *RD = dyn_cast<ClassTemplateSpecializationDecl>(
Decl))
4439 return RD->getTemplateArgs().asArray();
4441 return TD->getTemplateParameters()->getInjectedTemplateArgs(Ctx);
4445bool RecordType::hasConstFields()
const {
4446 std::vector<const RecordType *> RecordTypeList;
4447 RecordTypeList.push_back(
this);
4448 unsigned NextToCheckIndex = 0;
4450 while (RecordTypeList.size() > NextToCheckIndex) {
4451 for (
FieldDecl *FD : RecordTypeList[NextToCheckIndex]
4459 if (
const auto *FieldRecTy = FieldTy->
getAsCanonical<RecordType>()) {
4460 if (!llvm::is_contained(RecordTypeList, FieldRecTy))
4461 RecordTypeList.push_back(FieldRecTy);
4471 const TagDecl *TD,
bool IsInjected,
4472 const Type *CanonicalType)
4474 false, IsInjected, CanonicalType) {}
4483 :
Type(Attributed, canon, equivalent->getDependence()), Attribute(
attr),
4484 ModifiedType(modified), EquivalentType(equivalent) {
4486 assert(!attr ||
attr->getKind() == attrKind);
4489bool AttributedType::isQualifier()
const {
4491 switch (getAttrKind()) {
4496 case attr::ObjCOwnership:
4497 case attr::ObjCInertUnsafeUnretained:
4498 case attr::TypeNonNull:
4499 case attr::TypeNullable:
4500 case attr::TypeNullableResult:
4501 case attr::TypeNullUnspecified:
4502 case attr::LifetimeBound:
4503 case attr::AddressSpace:
4513bool AttributedType::isMSTypeSpec()
const {
4515 switch (getAttrKind()) {
4524 llvm_unreachable(
"invalid attr kind");
4527bool AttributedType::isWebAssemblyFuncrefSpec()
const {
4528 return getAttrKind() == attr::WebAssemblyFuncref;
4531bool AttributedType::isCallingConv()
const {
4533 switch (getAttrKind()) {
4538 case attr::FastCall:
4540 case attr::ThisCall:
4542 case attr::SwiftCall:
4543 case attr::SwiftAsyncCall:
4544 case attr::VectorCall:
4545 case attr::AArch64VectorPcs:
4546 case attr::AArch64SVEPcs:
4547 case attr::DeviceKernel:
4551 case attr::IntelOclBicc:
4552 case attr::PreserveMost:
4553 case attr::PreserveAll:
4555 case attr::PreserveNone:
4556 case attr::RISCVVectorCC:
4557 case attr::RISCVVLSCC:
4560 llvm_unreachable(
"invalid attr kind");
4564 return isCanonicalUnqualified() ?
nullptr : getDecl()->getIdentifier();
4567SubstTemplateTypeParmType::SubstTemplateTypeParmType(
QualType Replacement,
4568 Decl *AssociatedDecl,
4572 :
Type(SubstTemplateTypeParm, Replacement.getCanonicalType(),
4573 Replacement->getDependence()),
4574 AssociatedDecl(AssociatedDecl) {
4578 *getTrailingObjects() = Replacement;
4584 assert(AssociatedDecl !=
nullptr);
4588SubstTemplateTypeParmType::getReplacedParameter()
const {
4593void SubstTemplateTypeParmType::Profile(llvm::FoldingSetNodeID &ID,
4595 const Decl *AssociatedDecl,
4598 Replacement.Profile(ID);
4599 ID.AddPointer(AssociatedDecl);
4600 ID.AddInteger(Index);
4602 ID.AddBoolean(Final);
4605SubstPackType::SubstPackType(TypeClass Derived,
QualType Canon,
4607 :
Type(Derived, Canon,
4611 assert(llvm::all_of(
4613 [](
auto &P) { return P.getKind() == TemplateArgument::Type; }) &&
4614 "non-type argument to SubstPackType?");
4622void SubstPackType::Profile(llvm::FoldingSetNodeID &ID) {
4623 Profile(ID, getArgumentPack());
4626void SubstPackType::Profile(llvm::FoldingSetNodeID &ID,
4630 ID.AddPointer(P.getAsType().getAsOpaquePtr());
4633SubstTemplateTypeParmPackType::SubstTemplateTypeParmPackType(
4634 QualType Canon,
Decl *AssociatedDecl,
unsigned Index,
bool Final,
4636 : SubstPackType(SubstTemplateTypeParmPack, Canon, ArgPack),
4637 AssociatedDeclAndFinal(AssociatedDecl, Final) {
4638 assert(AssociatedDecl !=
nullptr);
4641 assert(getNumArgs() == ArgPack.
pack_size() &&
4642 "Parent bitfields in SubstPackType were overwritten."
4643 "Check NumSubstPackTypeBits.");
4646Decl *SubstTemplateTypeParmPackType::getAssociatedDecl()
const {
4647 return AssociatedDeclAndFinal.getPointer();
4650bool SubstTemplateTypeParmPackType::getFinal()
const {
4651 return AssociatedDeclAndFinal.getInt();
4655SubstTemplateTypeParmPackType::getReplacedParameter()
const {
4660IdentifierInfo *SubstTemplateTypeParmPackType::getIdentifier()
const {
4661 return getReplacedParameter()->getIdentifier();
4664void SubstTemplateTypeParmPackType::Profile(llvm::FoldingSetNodeID &ID) {
4665 Profile(ID, getAssociatedDecl(),
getIndex(), getFinal(), getArgumentPack());
4668void SubstTemplateTypeParmPackType::Profile(llvm::FoldingSetNodeID &ID,
4669 const Decl *AssociatedDecl,
4670 unsigned Index,
bool Final,
4672 ID.AddPointer(AssociatedDecl);
4673 ID.AddInteger(Index);
4674 ID.AddBoolean(Final);
4675 SubstPackType::Profile(ID, ArgPack);
4678SubstBuiltinTemplatePackType::SubstBuiltinTemplatePackType(
4680 : SubstPackType(SubstBuiltinTemplatePack, Canon, ArgPack) {}
4682bool TemplateSpecializationType::anyDependentTemplateArguments(
4685 return anyDependentTemplateArguments(Args.
arguments(), Converted);
4688bool TemplateSpecializationType::anyDependentTemplateArguments(
4691 if (Arg.isDependent())
4696bool TemplateSpecializationType::anyInstantiationDependentTemplateArguments(
4699 if (ArgLoc.getArgument().isInstantiationDependent())
4708 ? TypeDependence::DependentInstantiation
4713 D |= TypeDependence::UnexpandedPack;
4715 D |= (Underlying->
getDependence() & TypeDependence::UnexpandedPack);
4720TemplateSpecializationType::TemplateSpecializationType(
4724 Underlying.isNull() ?
QualType(this, 0)
4725 : Underlying.getCanonicalType(),
4728 TemplateSpecializationTypeBits.NumArgs = Args.size();
4729 TemplateSpecializationTypeBits.TypeAlias = IsAlias;
4731 auto *TemplateArgs =
4743 ~TypeDependence::Dependent);
4745 addDependence(Arg.getAsType()->getDependence() &
4746 TypeDependence::VariablyModified);
4753 *
reinterpret_cast<QualType *
>(TemplateArgs) = Underlying;
4756QualType TemplateSpecializationType::getAliasedType()
const {
4757 assert(isTypeAlias() &&
"not a type alias template specialization");
4758 return *
reinterpret_cast<const QualType *
>(template_arguments().end());
4761bool clang::TemplateSpecializationType::isSugared()
const {
4762 return !isDependentType() || isCurrentInstantiation() || isTypeAlias() ||
4767void TemplateSpecializationType::Profile(llvm::FoldingSetNodeID &ID,
4769 Profile(ID, getKeyword(),
Template, template_arguments(),
4770 isSugared() ? desugar() :
QualType(), Ctx);
4773void TemplateSpecializationType::Profile(llvm::FoldingSetNodeID &ID,
4779 ID.AddInteger(llvm::to_underlying(
Keyword));
4783 ID.AddInteger(Args.size());
4785 Arg.Profile(ID, Context);
4793 return Context.getQualifiedType(QT, *
this);
4797 const Type *T)
const {
4801 return Context.getQualifiedType(T, *
this);
4804void ObjCObjectTypeImpl::Profile(llvm::FoldingSetNodeID &ID,
QualType BaseType,
4808 ID.AddPointer(BaseType.getAsOpaquePtr());
4809 ID.AddInteger(typeArgs.size());
4810 for (
auto typeArg : typeArgs)
4811 ID.AddPointer(typeArg.getAsOpaquePtr());
4812 ID.AddInteger(protocols.size());
4813 for (
auto *proto : protocols)
4814 ID.AddPointer(proto);
4815 ID.AddBoolean(isKindOf);
4818void ObjCObjectTypeImpl::Profile(llvm::FoldingSetNodeID &ID) {
4819 Profile(ID, getBaseType(), getTypeArgsAsWritten(),
4821 isKindOfTypeAsWritten());
4824void ObjCTypeParamType::Profile(llvm::FoldingSetNodeID &ID,
4828 ID.AddPointer(OTPDecl);
4830 ID.AddInteger(protocols.size());
4831 for (
auto *proto : protocols)
4832 ID.AddPointer(proto);
4835void ObjCTypeParamType::Profile(llvm::FoldingSetNodeID &ID) {
4836 Profile(ID, getDecl(), getCanonicalTypeInternal(),
4843class CachedProperties {
4848 CachedProperties(
Linkage L,
bool local) : L(L), local(local) {}
4850 Linkage getLinkage()
const {
return L; }
4851 bool hasLocalOrUnnamedType()
const {
return local; }
4853 friend CachedProperties
merge(CachedProperties L, CachedProperties R) {
4855 return CachedProperties(MergedLinkage, L.hasLocalOrUnnamedType() ||
4856 R.hasLocalOrUnnamedType());
4875 return CachedProperties(T->TypeBits.getLinkage(),
4876 T->TypeBits.hasLocalOrUnnamedType());
4881 if (T->TypeBits.isCacheValid())
4886 if (!T->isCanonicalUnqualified()) {
4889 T->TypeBits.CacheValid =
true;
4890 T->TypeBits.CachedLinkage = CT->
TypeBits.CachedLinkage;
4891 T->TypeBits.CachedLocalOrUnnamed = CT->
TypeBits.CachedLocalOrUnnamed;
4897 T->TypeBits.CacheValid =
true;
4898 T->TypeBits.CachedLinkage = llvm::to_underlying(
Result.getLinkage());
4899 T->TypeBits.CachedLocalOrUnnamed =
Result.hasLocalOrUnnamedType();
4917 switch (T->getTypeClass()) {
4918#define TYPE(Class, Base)
4919#define NON_CANONICAL_TYPE(Class, Base) case Type::Class:
4920#include "clang/AST/TypeNodes.inc"
4921 llvm_unreachable(
"didn't expect a non-canonical type here");
4923#define TYPE(Class, Base)
4924#define DEPENDENT_TYPE(Class, Base) case Type::Class:
4925#define NON_CANONICAL_UNLESS_DEPENDENT_TYPE(Class, Base) case Type::Class:
4926#include "clang/AST/TypeNodes.inc"
4928 assert(T->isInstantiationDependentType());
4932 case Type::DeducedTemplateSpecialization:
4946 const auto *Tag =
cast<TagType>(T)->getDecl()->getDefinitionOrSelf();
4952 Linkage L = Tag->getLinkageInternal();
4953 bool IsLocalOrUnnamed = Tag->getDeclContext()->isFunctionOrMethod() ||
4954 !Tag->hasNameForLinkage();
4955 return CachedProperties(L, IsLocalOrUnnamed);
4965 case Type::BlockPointer:
4967 case Type::LValueReference:
4968 case Type::RValueReference:
4970 case Type::MemberPointer: {
4972 CachedProperties Cls = [&] {
4973 if (MPT->isSugared())
4975 return Cache::get(MPT->getQualifier().getAsType());
4977 return merge(Cls,
Cache::get(MPT->getPointeeType()));
4979 case Type::ConstantArray:
4980 case Type::IncompleteArray:
4981 case Type::VariableArray:
4982 case Type::ArrayParameter:
4985 case Type::ExtVector:
4987 case Type::ConstantMatrix:
4989 case Type::FunctionNoProto:
4991 case Type::FunctionProto: {
4993 CachedProperties result =
Cache::get(FPT->getReturnType());
4994 for (
const auto &ai : FPT->param_types())
4998 case Type::ObjCInterface: {
5000 return CachedProperties(L,
false);
5002 case Type::ObjCObject:
5004 case Type::ObjCObjectPointer:
5010 case Type::HLSLAttributedResource:
5012 case Type::HLSLInlineSpirv:
5014 case Type::OverflowBehavior:
5018 llvm_unreachable(
"unhandled type class");
5029 return TypeBits.hasLocalOrUnnamedType();
5033 switch (T->getTypeClass()) {
5034#define TYPE(Class, Base)
5035#define NON_CANONICAL_TYPE(Class, Base) case Type::Class:
5036#include "clang/AST/TypeNodes.inc"
5037 llvm_unreachable(
"didn't expect a non-canonical type here");
5039#define TYPE(Class, Base)
5040#define DEPENDENT_TYPE(Class, Base) case Type::Class:
5041#define NON_CANONICAL_UNLESS_DEPENDENT_TYPE(Class, Base) case Type::Class:
5042#include "clang/AST/TypeNodes.inc"
5044 assert(T->isInstantiationDependentType());
5052 case Type::DeducedTemplateSpecialization:
5064 case Type::BlockPointer:
5066 case Type::LValueReference:
5067 case Type::RValueReference:
5069 case Type::MemberPointer: {
5072 if (
auto *D = MPT->getMostRecentCXXRecordDecl()) {
5080 case Type::ConstantArray:
5081 case Type::IncompleteArray:
5082 case Type::VariableArray:
5083 case Type::ArrayParameter:
5086 case Type::ExtVector:
5088 case Type::ConstantMatrix:
5091 case Type::FunctionNoProto:
5093 case Type::FunctionProto: {
5096 for (
const auto &ai : FPT->param_types())
5100 case Type::ObjCInterface:
5102 case Type::ObjCObject:
5104 case Type::ObjCObjectPointer:
5111 case Type::OverflowBehavior:
5114 case Type::HLSLAttributedResource:
5116 ->getContainedType()
5117 ->getCanonicalTypeInternal());
5118 case Type::HLSLInlineSpirv:
5122 llvm_unreachable(
"unhandled type class");
5136 if (!T->isCanonicalUnqualified())
5150 while (
const auto *AT =
Type->getAs<AttributedType>()) {
5153 if (
auto Nullability = AT->getImmediateNullability())
5156 Type = AT->getEquivalentType();
5158 return std::nullopt;
5164 switch (
type->getTypeClass()) {
5165#define NON_CANONICAL_TYPE(Class, Parent) \
5168 llvm_unreachable("non-canonical type");
5169#define TYPE(Class, Parent)
5170#include "clang/AST/TypeNodes.inc"
5174 case Type::BlockPointer:
5175 case Type::MemberPointer:
5176 case Type::ObjCObjectPointer:
5180 case Type::UnresolvedUsing:
5181 case Type::TypeOfExpr:
5183 case Type::Decltype:
5184 case Type::PackIndexing:
5185 case Type::UnaryTransform:
5186 case Type::TemplateTypeParm:
5187 case Type::SubstTemplateTypeParmPack:
5188 case Type::SubstBuiltinTemplatePack:
5189 case Type::DependentName:
5191 return ResultIfUnknown;
5194 case Type::TemplateSpecialization:
5199 .getAsTemplateDecl())
5200 if (
auto *CTD = dyn_cast<ClassTemplateDecl>(templateDecl))
5201 return llvm::any_of(
5203 return RTD->getTemplatedDecl()->hasAttr<TypeNullableAttr>();
5205 return ResultIfUnknown;
5210#define SIGNED_TYPE(Id, SingletonId) case BuiltinType::Id:
5211#define UNSIGNED_TYPE(Id, SingletonId) case BuiltinType::Id:
5212#define FLOATING_TYPE(Id, SingletonId) case BuiltinType::Id:
5213#define BUILTIN_TYPE(Id, SingletonId)
5214#include "clang/AST/BuiltinTypes.def"
5217 case BuiltinType::UnresolvedTemplate:
5219 case BuiltinType::Dependent:
5220 case BuiltinType::Overload:
5221 case BuiltinType::BoundMember:
5222 case BuiltinType::PseudoObject:
5223 case BuiltinType::UnknownAny:
5224 case BuiltinType::ARCUnbridgedCast:
5225 return ResultIfUnknown;
5227 case BuiltinType::Void:
5228 case BuiltinType::ObjCId:
5229 case BuiltinType::ObjCClass:
5230 case BuiltinType::ObjCSel:
5231#define IMAGE_TYPE(ImgType, Id, SingletonId, Access, Suffix) \
5232 case BuiltinType::Id:
5233#include "clang/Basic/OpenCLImageTypes.def"
5234#define EXT_OPAQUE_TYPE(ExtType, Id, Ext) case BuiltinType::Id:
5235#include "clang/Basic/OpenCLExtensionTypes.def"
5236 case BuiltinType::OCLSampler:
5237 case BuiltinType::OCLEvent:
5238 case BuiltinType::OCLClkEvent:
5239 case BuiltinType::OCLQueue:
5240 case BuiltinType::OCLReserveID:
5241#define SVE_TYPE(Name, Id, SingletonId) case BuiltinType::Id:
5242#include "clang/Basic/AArch64ACLETypes.def"
5243#define PPC_VECTOR_TYPE(Name, Id, Size) case BuiltinType::Id:
5244#include "clang/Basic/PPCTypes.def"
5245#define RVV_TYPE(Name, Id, SingletonId) case BuiltinType::Id:
5246#include "clang/Basic/RISCVVTypes.def"
5247#define WASM_TYPE(Name, Id, SingletonId) case BuiltinType::Id:
5248#include "clang/Basic/WebAssemblyReferenceTypes.def"
5249#define AMDGPU_TYPE(Name, Id, SingletonId, Width, Align) case BuiltinType::Id:
5250#include "clang/Basic/AMDGPUTypes.def"
5251#define HLSL_INTANGIBLE_TYPE(Name, Id, SingletonId) case BuiltinType::Id:
5252#include "clang/Basic/HLSLIntangibleTypes.def"
5253 case BuiltinType::BuiltinFn:
5254 case BuiltinType::NullPtr:
5255 case BuiltinType::IncompleteMatrixIdx:
5256 case BuiltinType::ArraySection:
5257 case BuiltinType::OMPArrayShaping:
5258 case BuiltinType::OMPIterator:
5261 llvm_unreachable(
"unknown builtin type");
5263 case Type::Record: {
5267 if (
const auto *CTSD = dyn_cast<ClassTemplateSpecializationDecl>(RD))
5268 return llvm::any_of(
5269 CTSD->getSpecializedTemplate()->redecls(),
5271 return RTD->getTemplatedDecl()->hasAttr<TypeNullableAttr>();
5274 return RD->hasAttr<TypeNullableAttr>();
5280 case Type::LValueReference:
5281 case Type::RValueReference:
5282 case Type::ConstantArray:
5283 case Type::IncompleteArray:
5284 case Type::VariableArray:
5285 case Type::DependentSizedArray:
5286 case Type::DependentVector:
5287 case Type::DependentSizedExtVector:
5289 case Type::ExtVector:
5290 case Type::ConstantMatrix:
5291 case Type::DependentSizedMatrix:
5292 case Type::DependentAddressSpace:
5293 case Type::FunctionProto:
5294 case Type::FunctionNoProto:
5295 case Type::DeducedTemplateSpecialization:
5297 case Type::InjectedClassName:
5298 case Type::PackExpansion:
5299 case Type::ObjCObject:
5300 case Type::ObjCInterface:
5304 case Type::DependentBitInt:
5305 case Type::ArrayParameter:
5306 case Type::HLSLAttributedResource:
5307 case Type::HLSLInlineSpirv:
5308 case Type::OverflowBehavior:
5311 llvm_unreachable(
"bad type kind!");
5315 if (getAttrKind() == attr::TypeNonNull)
5317 if (getAttrKind() == attr::TypeNullable)
5319 if (getAttrKind() == attr::TypeNullUnspecified)
5321 if (getAttrKind() == attr::TypeNullableResult)
5323 return std::nullopt;
5328 if (
auto MacroTy = dyn_cast<MacroQualifiedType>(T))
5329 AttrTy = MacroTy->getUnderlyingType();
5331 if (
auto attributed = dyn_cast<AttributedType>(AttrTy)) {
5332 if (
auto nullability = attributed->getImmediateNullability()) {
5333 T = attributed->getModifiedType();
5338 return std::nullopt;
5352 if (objcPtr->isObjCIdType()) {
5363 }
else if (objcPtr->isObjCQualifiedIdType()) {
5388 "cannot query implicit lifetime for non-inferrable type");
5393 while (
const auto *array = dyn_cast<ArrayType>(canon))
5394 canon = array->getElementType().getTypePtr();
5396 if (
const auto *
opt = dyn_cast<ObjCObjectPointerType>(canon)) {
5398 if (
opt->getObjectType()->isObjCClass())
5407 return typedefType->getDecl()->hasAttr<ObjCNSObjectAttr>();
5413 return typedefType->getDecl()->hasAttr<ObjCIndependentClassAttr>();
5426 return OPT->getPointeeType()->isObjCIndirectLifetimeType();
5428 return Ref->getPointeeType()->isObjCIndirectLifetimeType();
5430 return MemPtr->getPointeeType()->isObjCIndirectLifetimeType();
5438 while (
const ArrayType *array =
type->getAsArrayTypeUnsafe())
5439 type = array->getElementType().getTypePtr();
5440 return type->isObjCRetainableType();
5462 return RT->getDecl()
5463 ->getMostRecentDecl()
5464 ->hasAttr<CUDADeviceBuiltinSurfaceTypeAttr>();
5471 return RT->getDecl()
5472 ->getMostRecentDecl()
5473 ->hasAttr<CUDADeviceBuiltinTextureTypeAttr>();
5482 return ptr->getPointeeType()->hasSizedVLAType();
5484 return ref->getPointeeType()->hasSizedVLAType();
5490 return arr->getElementType()->hasSizedVLAType();
5497 return HLSLAttributedResourceType::findHandleTypeOnResource(
this) !=
nullptr;
5520 const RecordType *RT =
5526 assert(RD !=
nullptr &&
5527 "all HLSL structs and classes should be CXXRecordDecl");
5533 switch (
type.getObjCLifetime()) {
5545 if (
const auto *RD =
type->getBaseElementTypeUnsafe()->getAsRecordDecl()) {
5546 if (
const auto *CXXRD = dyn_cast<CXXRecordDecl>(RD)) {
5548 if (CXXRD->hasDefinition() && !CXXRD->hasTrivialDestructor())
5572 Qualifier.Profile(ID);
5584 auto *RD = getCXXRecordDecl();
5591 llvm::APSInt Val,
unsigned Scale) {
5592 llvm::FixedPointSemantics FXSema(Val.getBitWidth(), Scale, Val.isSigned(),
5595 llvm::APFixedPoint(Val, FXSema).toString(Str);
5598DeducedType::DeducedType(TypeClass TC,
DeducedKind DK,
5601 ? DeducedAsTypeOrCanon.getCanonicalType()
5602 : DeducedAsTypeOrCanon,
5604 DeducedTypeBits.Kind = llvm::to_underlying(DK);
5609 assert(!DeducedAsTypeOrCanon.
isNull() &&
"Deduced type cannot be null");
5611 ~TypeDependence::VariablyModified);
5612 DeducedAsType = DeducedAsTypeOrCanon;
5615 addDependence(TypeDependence::UnexpandedPack);
5618 addDependence(TypeDependence::DependentInstantiation);
5621 assert(getDeducedKind() == DK &&
"DeducedKind does not match the type state");
5627 : DeducedType(
Auto, DK, DeducedAsTypeOrCanon) {
5628 AutoTypeBits.Keyword = llvm::to_underlying(
Keyword);
5629 AutoTypeBits.NumArgs = TypeConstraintArgs.size();
5630 this->TypeConstraintConcept = TypeConstraintConcept;
5631 assert(TypeConstraintConcept || AutoTypeBits.NumArgs == 0);
5632 if (TypeConstraintConcept) {
5633 auto Dep = TypeDependence::None;
5634 if (
const auto *TTP =
5635 dyn_cast<TemplateTemplateParmDecl>(TypeConstraintConcept))
5636 Dep = TypeDependence::DependentInstantiation |
5637 (TTP->isParameterPack() ? TypeDependence::UnexpandedPack
5638 : TypeDependence::None);
5653void AutoType::Profile(llvm::FoldingSetNodeID &ID,
const ASTContext &Context,
5657 DeducedType::Profile(ID, DK,
Deduced);
5658 ID.AddInteger(llvm::to_underlying(
Keyword));
5661 Arg.Profile(ID, Context);
5664void AutoType::Profile(llvm::FoldingSetNodeID &ID,
const ASTContext &Context) {
5665 Profile(ID, Context, getDeducedKind(), getDeducedType(), getKeyword(),
5666 getTypeConstraintConcept(), getTypeConstraintArguments());
5680 llvm_unreachable(
"unknown effect kind");
5686 return "nonblocking";
5688 return "nonallocating";
5692 return "allocating";
5694 llvm_unreachable(
"unknown effect kind");
5710 return std::nullopt;
5715 assert(0 &&
"effectProhibitingInference with non-inferable effect kind");
5718 llvm_unreachable(
"unknown effect kind");
5728 const Kind EK = Effect.kind();
5730 if (EK == CallerKind ||
5741 llvm_unreachable(
"unknown effect kind");
5753 unsigned InsertIdx = Effects.size();
5768 Errs.push_back({EC, NewEC});
5779 if (NewCondition || !Conditions.empty()) {
5780 if (Conditions.empty() && !Effects.empty())
5781 Conditions.resize(Effects.size());
5782 Conditions.insert(Conditions.begin() + InsertIdx,
5785 Effects.insert(Effects.begin() + InsertIdx, NewEC.
Effect);
5790 for (
const auto &Item :
Set)
5792 return Errs.empty();
5803 auto IterA = LHS.
begin(), EndA = LHS.
end();
5804 auto IterB = RHS.
begin(), EndB = RHS.
end();
5808 return std::tuple(LHS.Effect,
uintptr_t(LHS.Cond.getCondition())) <
5809 std::tuple(RHS.Effect,
uintptr_t(RHS.Cond.getCondition()));
5812 while (IterA != EndA && IterB != EndB) {
5817 else if (FEWCLess(B, A))
5828 assert(Errs.empty() &&
"conflict shouldn't be possible in getIntersection");
5841 Combined.
insert(RHS, Errs);
5862 llvm::interleaveComma(*
this, OS);
5872 llvm::interleaveComma(*
this, OS);
5879 assert(llvm::is_sorted(FX) &&
"effects should be sorted");
5880 assert((Conds.empty() || Conds.size() == FX.size()) &&
5881 "effects size should match conditions size");
5887 if (
Cond.getCondition() !=
nullptr)
5892const HLSLAttributedResourceType *
5893HLSLAttributedResourceType::findHandleTypeOnResource(
const Type *RT) {
5898 if (!RD->
fields().empty()) {
5899 const auto &FirstFD = RD->
fields().begin();
5900 return dyn_cast<HLSLAttributedResourceType>(
5901 FirstFD->getType().getTypePtr());
5907StringRef PredefinedSugarType::getName(Kind KD) {
5912 return "__signed_size_t";
5914 return "__ptrdiff_t";
5916 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.
static DeclT * getDefinitionOrSelf(DeclT *D)
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)
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 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.
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.