45#include "llvm/ADT/ArrayRef.h"
46#include "llvm/ADT/STLForwardCompat.h"
47#include "llvm/ADT/StringExtras.h"
48#include "llvm/IR/DerivedTypes.h"
49#include "llvm/Support/ErrorHandling.h"
83 bool useExpansionLoc =
true;
84 switch (
attr.getKind()) {
85 case ParsedAttr::AT_ObjCGC:
88 case ParsedAttr::AT_ObjCOwnership:
94 useExpansionLoc =
false;
99 StringRef name =
attr.getAttrName()->getName();
103 attr.isArgIdent(0) ?
attr.getArgAsIdent(0)->getIdentifierInfo() :
nullptr;
104 if (useExpansionLoc && loc.
isMacroID() && II) {
105 if (II->
isStr(
"strong")) {
107 }
else if (II->
isStr(
"weak")) {
112 S.
Diag(loc,
attr.isRegularKeywordAttribute()
113 ? diag::err_type_attribute_wrong_type
114 : diag::warn_type_attribute_wrong_type)
115 << name << WhichType <<
type;
120#define OBJC_POINTER_TYPE_ATTRS_CASELIST \
121 case ParsedAttr::AT_ObjCGC: \
122 case ParsedAttr::AT_ObjCOwnership
125#define CALLING_CONV_ATTRS_CASELIST \
126 case ParsedAttr::AT_CDecl: \
127 case ParsedAttr::AT_FastCall: \
128 case ParsedAttr::AT_StdCall: \
129 case ParsedAttr::AT_ThisCall: \
130 case ParsedAttr::AT_RegCall: \
131 case ParsedAttr::AT_Pascal: \
132 case ParsedAttr::AT_SwiftCall: \
133 case ParsedAttr::AT_SwiftAsyncCall: \
134 case ParsedAttr::AT_VectorCall: \
135 case ParsedAttr::AT_AArch64VectorPcs: \
136 case ParsedAttr::AT_AArch64SVEPcs: \
137 case ParsedAttr::AT_MSABI: \
138 case ParsedAttr::AT_SysVABI: \
139 case ParsedAttr::AT_Pcs: \
140 case ParsedAttr::AT_IntelOclBicc: \
141 case ParsedAttr::AT_PreserveMost: \
142 case ParsedAttr::AT_PreserveAll: \
143 case ParsedAttr::AT_M68kRTD: \
144 case ParsedAttr::AT_PreserveNone: \
145 case ParsedAttr::AT_RISCVVectorCC: \
146 case ParsedAttr::AT_RISCVVLSCC
149#define FUNCTION_TYPE_ATTRS_CASELIST \
150 case ParsedAttr::AT_NSReturnsRetained: \
151 case ParsedAttr::AT_NoReturn: \
152 case ParsedAttr::AT_NonBlocking: \
153 case ParsedAttr::AT_NonAllocating: \
154 case ParsedAttr::AT_Blocking: \
155 case ParsedAttr::AT_Allocating: \
156 case ParsedAttr::AT_Regparm: \
157 case ParsedAttr::AT_CFIUncheckedCallee: \
158 case ParsedAttr::AT_CFISalt: \
159 case ParsedAttr::AT_CmseNSCall: \
160 case ParsedAttr::AT_ArmStreaming: \
161 case ParsedAttr::AT_ArmStreamingCompatible: \
162 case ParsedAttr::AT_ArmPreserves: \
163 case ParsedAttr::AT_ArmIn: \
164 case ParsedAttr::AT_ArmOut: \
165 case ParsedAttr::AT_ArmInOut: \
166 case ParsedAttr::AT_ArmAgnostic: \
167 case ParsedAttr::AT_AnyX86NoCallerSavedRegisters: \
168 case ParsedAttr::AT_AnyX86NoCfCheck: \
169 CALLING_CONV_ATTRS_CASELIST
172#define MS_TYPE_ATTRS_CASELIST \
173 case ParsedAttr::AT_Ptr32: \
174 case ParsedAttr::AT_Ptr64: \
175 case ParsedAttr::AT_SPtr: \
176 case ParsedAttr::AT_UPtr
179#define NULLABILITY_TYPE_ATTRS_CASELIST \
180 case ParsedAttr::AT_TypeNonNull: \
181 case ParsedAttr::AT_TypeNullable: \
182 case ParsedAttr::AT_TypeNullableResult: \
183 case ParsedAttr::AT_TypeNullUnspecified
188 class TypeProcessingState {
212 using TypeAttrPair = std::pair<const AttributedType*, const Attr*>;
214 bool AttrsForTypesSorted =
true;
218 llvm::DenseMap<const MacroQualifiedType *, SourceLocation> LocsForMacros;
226 bool ParsedHLSLParamMod;
230 :
sema(
sema), declarator(declarator),
232 ParsedHLSLParamMod(
false) {}
234 Sema &getSema()
const {
242 bool isProcessingDeclSpec()
const {
246 unsigned getCurrentChunkIndex()
const {
250 void setCurrentChunkIndex(
unsigned idx) {
256 if (isProcessingDeclSpec())
257 return getMutableDeclSpec().getAttributes();
262 void saveDeclSpecAttrs() {
264 if (!savedAttrs.empty())
267 DeclSpec &spec = getMutableDeclSpec();
268 llvm::append_range(savedAttrs,
275 ignoredTypeAttrs.push_back(&
attr);
281 for (
auto *
Attr : ignoredTypeAttrs)
290 sema.Context.getAttributedType(A, ModifiedType, EquivType);
292 AttrsForTypesSorted =
false;
297 QualType getBTFTagAttributedType(
const BTFTypeTagAttr *BTFAttr,
299 return sema.Context.getBTFTagAttributedType(BTFAttr, WrappedType);
305 getOverflowBehaviorType(OverflowBehaviorType::OverflowBehaviorKind Kind,
307 return sema.Context.getOverflowBehaviorType(Kind, UnderlyingType);
314 QualType T =
sema.ReplaceAutoType(TypeWithAuto, Replacement);
315 if (
auto *AttrTy = TypeWithAuto->
getAs<AttributedType>()) {
318 for (TypeAttrPair &A : AttrsForTypes) {
319 if (A.first == AttrTy)
322 AttrsForTypesSorted =
false;
328 const Attr *takeAttrForAttributedType(
const AttributedType *AT) {
329 if (!AttrsForTypesSorted) {
330 llvm::stable_sort(AttrsForTypes, llvm::less_first());
331 AttrsForTypesSorted =
true;
336 for (
auto It = llvm::partition_point(
338 [=](
const TypeAttrPair &A) {
return A.first < AT; });
339 It != AttrsForTypes.end() && It->first == AT; ++It) {
341 const Attr *Result = It->second;
342 It->second =
nullptr;
347 llvm_unreachable(
"no Attr* for AttributedType*");
352 auto FoundLoc = LocsForMacros.find(MQT);
353 assert(FoundLoc != LocsForMacros.end() &&
354 "Unable to find macro expansion location for MacroQualifedType");
355 return FoundLoc->second;
360 LocsForMacros[MQT] = Loc;
363 void setParsedNoDeref(
bool parsed) { parsedNoDeref = parsed; }
365 bool didParseNoDeref()
const {
return parsedNoDeref; }
367 void setParsedHLSLParamMod(
bool Parsed) { ParsedHLSLParamMod = Parsed; }
369 bool didParseHLSLParamMod()
const {
return ParsedHLSLParamMod; }
371 ~TypeProcessingState() {
372 if (savedAttrs.empty())
375 getMutableDeclSpec().getAttributes().clearListOnly();
377 getMutableDeclSpec().getAttributes().addAtEnd(AL);
381 DeclSpec &getMutableDeclSpec()
const {
423 if (
attr.getKind() == ParsedAttr::AT_ObjCGC)
425 assert(
attr.getKind() == ParsedAttr::AT_ObjCOwnership);
440 bool onlyBlockPointers) {
446 for (; i != 0; --i) {
448 switch (fnChunk.
Kind) {
464 for (--i; i != 0; --i) {
466 switch (ptrChunk.
Kind) {
476 if (onlyBlockPointers)
485 llvm_unreachable(
"bad declarator chunk kind");
491 llvm_unreachable(
"bad declarator chunk kind");
508 Declarator &declarator = state.getDeclarator();
511 for (
unsigned i = state.getCurrentChunkIndex(); i != 0; --i) {
513 switch (chunk.
Kind) {
519 if (state.isProcessingDeclSpec() &&
520 attr.getKind() == ParsedAttr::AT_ObjCOwnership)
523 if (!destChunk) destChunk = &chunk;
536 if (state.isProcessingDeclSpec() &&
537 attr.getKind() == ParsedAttr::AT_ObjCOwnership) {
564 Declarator &declarator = state.getDeclarator();
568 unsigned innermost = -1U;
569 bool considerDeclSpec =
true;
572 switch (chunk.
Kind) {
586 considerDeclSpec =
false;
594 if (considerDeclSpec) {
599 state.saveDeclSpecAttrs();
608 if (innermost != -1U) {
616 state.addIgnoredTypeAttr(
attr);
625 Declarator &declarator = state.getDeclarator();
629 for (
unsigned i = state.getCurrentChunkIndex(); i != 0; --i) {
631 switch (chunk.
Kind) {
658 Declarator &declarator = state.getDeclarator();
678 state.saveDeclSpecAttrs();
682 state,
attr, state.getCurrentAttributes(), declSpecType, CFT))
687 state.addIgnoredTypeAttr(
attr);
698 Declarator &declarator = state.getDeclarator();
708 state.addIgnoredTypeAttr(
attr);
733 if (
attr.isStandardAttributeSyntax() ||
attr.isRegularKeywordAttribute())
736 switch (
attr.getKind()) {
753 case ParsedAttr::AT_ObjCKindOf:
766 Declarator &declarator = state.getDeclarator();
812 {}, loc, loc, declarator));
827 typedef std::pair<DeclSpec::TQ, SourceLocation> QualLoc;
832 if (!(RemoveTQs & Qual.first))
836 if (TypeQuals & Qual.first)
837 S.
Diag(Qual.second, DiagID)
842 TypeQuals &= ~Qual.first;
856 if (AL.isInvalid() || !AL.isTypeAttr())
859 diag::warn_block_literal_attributes_on_omitted_return_type)
861 ToBeRemoved.push_back(&AL);
871 diag::warn_block_literal_qualifiers_on_omitted_return_type);
877static OpenCLAccessAttr::Spelling
880 if (AL.getKind() == ParsedAttr::AT_OpenCLAccess)
881 return static_cast<OpenCLAccessAttr::Spelling
>(AL.getSemanticSpelling());
882 return OpenCLAccessAttr::Keyword_read_only;
885static UnaryTransformType::UTTKind
888#define TRANSFORM_TYPE_TRAIT_DEF(Enum, Trait) \
890 return UnaryTransformType::Enum;
891#include "clang/Basic/TransformTypeTraits.def"
893 llvm_unreachable(
"attempted to parse a non-unary transform builtin");
907 Sema &S = state.getSema();
908 Declarator &declarator = state.getDeclarator();
919 Result = Context.VoidTy;
923 Result = Context.CharTy;
925 Result = Context.SignedCharTy;
928 "Unknown TSS value");
929 Result = Context.UnsignedCharTy;
934 Result = Context.WCharTy;
938 Context.getPrintingPolicy());
939 Result = Context.getSignedWCharType();
942 "Unknown TSS value");
945 Context.getPrintingPolicy());
946 Result = Context.getUnsignedWCharType();
951 "Unknown TSS value");
952 Result = Context.Char8Ty;
956 "Unknown TSS value");
957 Result = Context.Char16Ty;
961 "Unknown TSS value");
962 Result = Context.Char32Ty;
972 Result = Context.getAutoDeductType();
976 Context.DependentTy)) {
977 Result = Context.DependentTy;
993 S.
Diag(DeclLoc, diag::warn_missing_type_specifier)
1004 S.
Diag(DeclLoc, diag::err_missing_type_specifier)
1015 S.
Diag(DeclLoc, diag::err_missing_actual_pipe_type)
1021 "implicit int is disabled?");
1022 S.
Diag(DeclLoc, diag::ext_missing_type_specifier)
1033 Result = Context.IntTy;
1036 Result = Context.ShortTy;
1039 Result = Context.LongTy;
1042 Result = Context.LongLongTy;
1049 diag::warn_cxx98_compat_longlong : diag::ext_cxx11_longlong);
1058 Result = Context.UnsignedIntTy;
1061 Result = Context.UnsignedShortTy;
1064 Result = Context.UnsignedLongTy;
1067 Result = Context.UnsignedLongLongTy;
1074 diag::warn_cxx98_compat_longlong : diag::ext_cxx11_longlong);
1089 if (Result.isNull()) {
1090 Result = Context.IntTy;
1098 Result = Context.ShortAccumTy;
1101 Result = Context.AccumTy;
1104 Result = Context.LongAccumTy;
1107 llvm_unreachable(
"Unable to specify long long as _Accum width");
1111 Result = Context.getCorrespondingUnsignedType(Result);
1114 Result = Context.getCorrespondingSaturatedType(Result);
1121 Result = Context.ShortFractTy;
1124 Result = Context.FractTy;
1127 Result = Context.LongFractTy;
1130 llvm_unreachable(
"Unable to specify long long as _Fract width");
1134 Result = Context.getCorrespondingUnsignedType(Result);
1137 Result = Context.getCorrespondingSaturatedType(Result);
1147 Result = Context.UnsignedInt128Ty;
1149 Result = Context.Int128Ty;
1159 Result = Context.Float16Ty;
1167 Result = Context.BFloat16Ty;
1172 Result = Context.LongDoubleTy;
1174 Result = Context.DoubleTy;
1179 << (S.
getLangOpts().getOpenCLCompatibleVersion() == 300
1180 ?
"cl_khr_fp64 and __opencl_c_fp64"
1191 Result = Context.Float128Ty;
1198 Result = Context.Ibm128Ty;
1201 Result = Context.BoolTy;
1207 Result = Context.IntTy;
1218 Result = Context.IntTy;
1229 "No qualifiers on tag names!");
1242 "Can't handle qualifiers on typedef names yet!");
1244 if (Result.isNull()) {
1255 assert(!Result.isNull() &&
"Didn't get a type for typeof?");
1256 if (!Result->isDependentType())
1257 if (
const auto *TT = Result->getAs<TagType>())
1260 Result = Context.getTypeOfType(
1268 assert(E &&
"Didn't get an expression for typeof?");
1274 if (Result.isNull()) {
1275 Result = Context.IntTy;
1282 assert(E &&
"Didn't get an expression for decltype?");
1285 if (Result.isNull()) {
1286 Result = Context.IntTy;
1293 assert(E &&
"Didn't get an expression for pack indexing");
1297 if (Result.isNull()) {
1299 Result = Context.IntTy;
1304#define TRANSFORM_TYPE_TRAIT_DEF(_, Trait) case DeclSpec::TST_##Trait:
1305#include "clang/Basic/TransformTypeTraits.def"
1307 assert(!Result.isNull() &&
"Didn't get a type for the transformation?");
1311 if (Result.isNull()) {
1312 Result = Context.IntTy;
1327 TypeConstraintConcept =
1333 TemplateId->NumArgs);
1335 for (
const auto &ArgLoc : TemplateArgsInfo.
arguments())
1336 TemplateArgs.push_back(ArgLoc.getArgument());
1343 TypeConstraintConcept, TemplateArgs);
1352 Result = Context.UnknownAnyTy;
1357 assert(!Result.isNull() &&
"Didn't get a type for _Atomic?");
1359 if (Result.isNull()) {
1360 Result = Context.IntTy;
1365#define GENERIC_IMAGE_TYPE(ImgType, Id) \
1366 case DeclSpec::TST_##ImgType##_t: \
1367 switch (getImageAccess(DS.getAttributes())) { \
1368 case OpenCLAccessAttr::Keyword_write_only: \
1369 Result = Context.Id##WOTy; \
1371 case OpenCLAccessAttr::Keyword_read_write: \
1372 Result = Context.Id##RWTy; \
1374 case OpenCLAccessAttr::Keyword_read_only: \
1375 Result = Context.Id##ROTy; \
1377 case OpenCLAccessAttr::SpellingNotCalculated: \
1378 llvm_unreachable("Spelling not yet calculated"); \
1381#include "clang/Basic/OpenCLImageTypes.def"
1383#define HLSL_INTANGIBLE_TYPE(Name, Id, SingletonId) \
1384 case DeclSpec::TST_##Name: \
1385 Result = Context.SingletonId; \
1387#include "clang/Basic/HLSLIntangibleTypes.def"
1390 Result = Context.IntTy;
1398 if (Result->containsErrors())
1403 bool IsOpenCLC30Compatible =
1412 if ((Result->isImageType() || Result->isSamplerT()) &&
1413 (IsOpenCLC30Compatible &&
1416 << 0 << Result <<
"__opencl_c_images";
1418 }
else if (Result->isOCLImage3dWOType() &&
1423 << (IsOpenCLC30Compatible
1424 ?
"cl_khr_3d_image_writes and __opencl_c_3d_image_writes"
1425 :
"cl_khr_3d_image_writes");
1437 Context.getPrintingPolicy());
1443 Result = Context.getComplexType(Result);
1445 unsigned typeSize =
static_cast<unsigned>(Context.getTypeSize(Result));
1446 assert(typeSize > 0 &&
"type size for vector must be greater than 0 bits");
1452 Result = Context.getVectorType(Result, 128/typeSize, VecKind);
1477 if (AL.slidesFromDeclToDeclSpecLegacyBehavior()) {
1488 if (AL.isStandardAttributeSyntax() && AL.isClangScope() &&
1489 !(AL.getKind() == ParsedAttr::AT_MatrixType &&
1491 S.
Diag(AL.getLoc(), diag::warn_type_attribute_deprecated_on_decl)
1519 if (Result->isFunctionType()) {
1520 unsigned DiagId = diag::warn_typecheck_function_qualifiers_ignored;
1522 DiagId = diag::ext_typecheck_function_qualifiers_unspecified;
1538 if (TypeQuals && Result->isReferenceType()) {
1540 S, DS, TypeQuals, Result,
1542 diag::warn_typecheck_reference_qualifiers);
1549 && TypeQuals & Result.getCVRQualifiers()) {
1576 if (!Result->isIntegerType()) {
1578 StringRef SpecifierName =
1580 S.
Diag(Loc, diag::err_overflow_behavior_non_integer_type)
1581 << SpecifierName << Result.getAsString() << 1;
1583 OverflowBehaviorType::OverflowBehaviorKind Kind =
1585 ? OverflowBehaviorType::OverflowBehaviorKind::Wrap
1586 : OverflowBehaviorType::OverflowBehaviorKind::Trap;
1587 Result = state.getOverflowBehaviorType(Kind, Result);
1594 assert(!Result.isNull() &&
"This function should not return a null type");
1606 if (T->isDependentType())
1609 const auto *AT = dyn_cast<AutoType>(T);
1610 return AT && AT->isGNUAutoType();
1619 if (T->isReferenceType()) {
1627 unsigned DiagID = 0;
1641 DiagID = diag::err_typecheck_invalid_restrict_invalid_pointee;
1647 DiagID = diag::err_typecheck_invalid_restrict_not_pointer;
1653 Diag(Loc, DiagID) << EltTy;
1656 if (T->isArrayType())
1658 ? diag::warn_c23_compat_restrict_on_array_of_pointers
1659 : diag::ext_restrict_on_array_of_pointers_c23);
1663 return Context.getQualifiedType(T, Qs);
1667 unsigned CVRAU,
const DeclSpec *DS) {
1672 if (T->isReferenceType())
1701 Split.Quals.addCVRQualifiers(CVR);
1711 return Context.getParenType(T);
1719 if (!
type->isObjCLifetimeType() ||
1729 if (
type.isConstQualified()) {
1735 }
else if (
type->isObjCARCImplicitlyUnretainedType()) {
1753 diag::err_arc_indirect_no_ownership,
type, isReference));
1755 S.
Diag(loc, diag::err_arc_indirect_no_ownership) <<
type << isReference;
1759 assert(implicitLifetime &&
"didn't infer any lifetime!");
1800enum QualifiedFunctionKind { QFK_BlockPointer, QFK_Pointer, QFK_Reference };
1806 QualifiedFunctionKind QFK) {
1813 S.
Diag(Loc, diag::err_compound_qualified_function_type)
1814 << QFK << isa<FunctionType>(T.IgnoreParens()) << T
1825 Diag(Loc, diag::err_qualified_function_typeid)
1842 if (T->isReferenceType()) {
1844 Diag(Loc, diag::err_illegal_decl_pointer_to_reference)
1852 Diag(Loc, diag::err_opencl_function_pointer) << 0;
1857 Diag(Loc, diag::err_hlsl_pointers_unsupported) << 0;
1864 if (T->isObjCObjectType())
1865 return Context.getObjCObjectPointerType(T);
1877 if (T.isWebAssemblyReferenceType()) {
1878 Diag(Loc, diag::err_wasm_reference_pr) << 0;
1883 if (T->getUnqualifiedDesugaredType()->isWebAssemblyTableType()) {
1884 Diag(Loc, diag::err_wasm_table_pr) << 0;
1890 return Context.getPointerType(T);
1897 "Unresolved overloaded function type");
1924 if (T->isVoidType()) {
1925 Diag(Loc, diag::err_reference_to_void);
1930 Diag(Loc, diag::err_hlsl_pointers_unsupported) << 1;
1940 Diag(Loc, diag::err_opencl_function_pointer) << 1;
1953 T.isWebAssemblyReferenceType()) {
1954 Diag(Loc, diag::err_wasm_reference_pr) << 1;
1957 if (T->isWebAssemblyTableType()) {
1958 Diag(Loc, diag::err_wasm_table_pr) << 1;
1964 return Context.getLValueReferenceType(T, SpelledAsLValue);
1965 return Context.getRValueReferenceType(T);
1969 return Context.getReadPipeType(T);
1973 return Context.getWritePipeType(T);
1979 return Context.getDependentBitIntType(IsUnsigned, BitWidth);
1981 llvm::APSInt Bits(32);
1988 size_t NumBits = Bits.getZExtValue();
1989 if (!IsUnsigned && NumBits < 2) {
1990 Diag(Loc, diag::err_bit_int_bad_size) << 0;
1994 if (IsUnsigned && NumBits < 1) {
1995 Diag(Loc, diag::err_bit_int_bad_size) << 1;
2001 Diag(Loc, diag::err_bit_int_max_size)
2006 return Context.getBitIntType(IsUnsigned, NumBits);
2015 llvm::APSInt &SizeVal,
unsigned VLADiag,
2040 VLADiagnoser(
unsigned VLADiag,
bool VLAIsError)
2041 : VLADiag(VLADiag), VLAIsError(VLAIsError) {}
2045 return S.
Diag(Loc, diag::err_array_size_non_int) << T;
2050 IsVLA = !VLAIsError;
2051 return S.
Diag(Loc, VLADiag);
2056 return S.
Diag(Loc, diag::ext_vla_folded_to_constant);
2058 } Diagnoser(VLADiag, VLAIsError);
2062 if (Diagnoser.IsVLA)
2068 EltTy =
Context.getBaseElementType(EltTy);
2076 if (Size.isMultipleOf(Alignment))
2079 Diag(Loc, diag::err_array_element_alignment)
2080 << EltTy << Size.getQuantity() << Alignment.
getQuantity();
2085 Expr *ArraySize,
unsigned Quals,
2101 if (T->isReferenceType()) {
2102 Diag(Loc, diag::err_illegal_decl_array_of_references)
2107 if (T->isVoidType() || T->isIncompleteArrayType()) {
2108 Diag(Loc, diag::err_array_incomplete_or_sizeless_type) << 0 << T;
2113 diag::err_array_of_abstract_type))
2118 if (
Context.getTargetInfo().getCXXABI().isMicrosoft())
2120 if (!MPTy->getQualifier().isDependent())
2126 if (!T.isWebAssemblyReferenceType() &&
2128 diag::err_array_incomplete_or_sizeless_type))
2133 if (
Context.getTargetInfo().getTriple().isWasm() && T->isArrayType()) {
2134 const auto *ATy = dyn_cast<ArrayType>(T);
2135 if (ATy && ATy->getElementType().isWebAssemblyReferenceType()) {
2136 Diag(Loc, diag::err_wasm_reftype_multidimensional_array);
2141 if (T->isSizelessType() && !T.isWebAssemblyReferenceType()) {
2142 Diag(Loc, diag::err_array_incomplete_or_sizeless_type) << 1 << T;
2146 if (T->isFunctionType()) {
2147 Diag(Loc, diag::err_illegal_decl_array_of_functions)
2152 if (
const auto *RD = T->getAsRecordDecl()) {
2155 if (RD->hasFlexibleArrayMember())
2156 Diag(Loc, diag::ext_flexible_array_in_array) << T;
2157 }
else if (T->isObjCObjectType()) {
2158 Diag(Loc, diag::err_objc_array_of_interfaces) << T;
2169 ArraySize =
Result.get();
2173 if (ArraySize && !ArraySize->
isPRValue()) {
2178 ArraySize =
Result.get();
2201 if (
const auto *CondExpr = dyn_cast_if_present<ConditionalOperator>(
2203 std::optional<llvm::APSInt> LHS =
2204 CondExpr->getLHS()->getIntegerConstantExpr(
Context);
2205 std::optional<llvm::APSInt> RHS =
2206 CondExpr->getRHS()->getIntegerConstantExpr(
Context);
2207 return LHS && RHS && LHS->isNegative() != RHS->isNegative();
2217 VLADiag = diag::err_opencl_vla;
2220 VLADiag = diag::warn_vla_used;
2223 VLADiag = diag::err_vla_in_sfinae;
2226 VLADiag = diag::err_openmp_vla_in_task_untied;
2231 ? diag::ext_vla_cxx_in_gnu_mode_static_assert
2232 : diag::ext_vla_cxx_static_assert;
2234 VLADiag =
getLangOpts().GNUMode ? diag::ext_vla_cxx_in_gnu_mode
2235 : diag::ext_vla_cxx;
2238 VLADiag = diag::ext_vla;
2242 llvm::APSInt ConstVal(
Context.getTypeSize(
Context.getSizeType()));
2249 T =
Context.getVariableArrayType(T,
nullptr, ASM, Quals);
2251 T =
Context.getIncompleteArrayType(T, ASM, Quals);
2254 T =
Context.getDependentSizedArrayType(T, ArraySize, ASM, Quals);
2265 T =
Context.getVariableArrayType(T, ArraySize, ASM, Quals);
2266 }
else if (!T->isDependentType() && !T->isIncompleteType() &&
2267 !T->isConstantSizeType()) {
2274 T =
Context.getVariableArrayType(T, ArraySize, ASM, Quals);
2279 if (ConstVal.isSigned() && ConstVal.isNegative()) {
2286 diag::err_typecheck_negative_array_size)
2290 if (ConstVal == 0 && !T.isWebAssemblyReferenceType()) {
2295 : diag::ext_typecheck_zero_array_size)
2302 unsigned ActiveSizeBits =
2303 (!T->isDependentType() && !T->isVariablyModifiedType() &&
2304 !T->isIncompleteType() && !T->isUndeducedType())
2306 : ConstVal.getActiveBits();
2309 <<
toString(ConstVal, 10, ConstVal.isSigned(),
2316 T =
Context.getConstantArrayType(T, ConstVal, ArraySize, ASM, Quals);
2320 if (T->isVariableArrayType()) {
2321 if (!
Context.getTargetInfo().isVLASupported()) {
2325 IsCUDADevice ? diag::err_cuda_vla : diag::err_vla_unsupported)
2326 << (IsCUDADevice ? llvm::to_underlying(
CUDA().CurrentTarget()) : 0);
2330 FSI->setHasVLA(Loc);
2338 : diag::ext_c99_array_usage)
2349 Diag(Loc, diag::err_opencl_invalid_type_array) << ArrType;
2359 bool ForMatrixType =
false) {
2362 if (!llvm::isPowerOf2_32(NumBits))
2363 return S.
Diag(AttrLoc, diag::err_attribute_invalid_bitint_vector_type)
2377 Diag(AttrLoc, diag::err_attribute_invalid_vector_type) << CurType;
2386 return Context.getDependentVectorType(CurType, SizeExpr, AttrLoc,
2389 std::optional<llvm::APSInt> VecSize =
2392 Diag(AttrLoc, diag::err_attribute_argument_type)
2398 if (VecSize->isNegative()) {
2399 Diag(SizeExpr->
getExprLoc(), diag::err_attribute_vec_negative_size);
2404 return Context.getDependentVectorType(CurType, SizeExpr, AttrLoc,
2408 if (!VecSize->isIntN(61)) {
2410 Diag(AttrLoc, diag::err_attribute_size_too_large)
2414 uint64_t VectorSizeBits = VecSize->getZExtValue() * 8;
2415 unsigned TypeSize =
static_cast<unsigned>(
Context.getTypeSize(CurType));
2417 if (VectorSizeBits == 0) {
2418 Diag(AttrLoc, diag::err_attribute_zero_size)
2423 if (!TypeSize || VectorSizeBits % TypeSize) {
2424 Diag(AttrLoc, diag::err_attribute_invalid_size)
2429 if (VectorSizeBits / TypeSize > std::numeric_limits<uint32_t>::max()) {
2430 Diag(AttrLoc, diag::err_attribute_size_too_large)
2435 return Context.getVectorType(CurType, VectorSizeBits / TypeSize,
2451 if ((!T->isDependentType() && !T->isIntegerType() &&
2452 !T->isRealFloatingType()) ||
2453 (IsNoBoolVecLang && T->isBooleanType())) {
2454 Diag(AttrLoc, diag::err_attribute_invalid_vector_type) << T;
2458 if (
const auto *BIT = T->getAs<
BitIntType>();
2463 std::optional<llvm::APSInt> VecSize =
2466 Diag(AttrLoc, diag::err_attribute_argument_type)
2472 if (VecSize->isNegative()) {
2473 Diag(SizeExpr->
getExprLoc(), diag::err_attribute_vec_negative_size);
2477 if (!VecSize->isIntN(32)) {
2478 Diag(AttrLoc, diag::err_attribute_size_too_large)
2484 unsigned VectorSize =
static_cast<unsigned>(VecSize->getZExtValue());
2486 if (VectorSize == 0) {
2487 Diag(AttrLoc, diag::err_attribute_zero_size)
2492 return Context.getExtVectorType(T, VectorSize);
2495 return Context.getDependentSizedExtVectorType(T, SizeExpr, AttrLoc);
2500 assert(
Context.getLangOpts().MatrixTypes &&
2501 "Should never build a matrix type when it is disabled");
2506 Diag(AttrLoc, diag::err_attribute_invalid_matrix_type) << ElementTy;
2517 return Context.getDependentSizedMatrixType(ElementTy, NumRows, NumCols,
2520 std::optional<llvm::APSInt> ValueRows =
2522 std::optional<llvm::APSInt> ValueColumns =
2529 if (!ValueRows && !ValueColumns) {
2530 Diag(AttrLoc, diag::err_attribute_argument_type)
2538 Diag(AttrLoc, diag::err_attribute_argument_type)
2544 if (!ValueColumns) {
2545 Diag(AttrLoc, diag::err_attribute_argument_type)
2551 unsigned MatrixRows =
static_cast<unsigned>(ValueRows->getZExtValue());
2552 unsigned MatrixColumns =
static_cast<unsigned>(ValueColumns->getZExtValue());
2553 if (MatrixRows == 0 && MatrixColumns == 0) {
2554 Diag(AttrLoc, diag::err_attribute_zero_size)
2555 <<
"matrix" << RowRange << ColRange;
2558 if (MatrixRows == 0) {
2559 Diag(AttrLoc, diag::err_attribute_zero_size) <<
"matrix" << RowRange;
2562 if (MatrixColumns == 0) {
2563 Diag(AttrLoc, diag::err_attribute_zero_size) <<
"matrix" << ColRange;
2566 if (MatrixRows >
Context.getLangOpts().MaxMatrixDimension &&
2567 MatrixColumns >
Context.getLangOpts().MaxMatrixDimension) {
2568 Diag(AttrLoc, diag::err_attribute_size_too_large)
2569 << RowRange << ColRange <<
"matrix row and column";
2572 if (MatrixRows >
Context.getLangOpts().MaxMatrixDimension) {
2573 Diag(AttrLoc, diag::err_attribute_size_too_large)
2574 << RowRange <<
"matrix row";
2577 if (MatrixColumns >
Context.getLangOpts().MaxMatrixDimension) {
2578 Diag(AttrLoc, diag::err_attribute_size_too_large)
2579 << ColRange <<
"matrix column";
2582 return Context.getConstantMatrixType(ElementTy, MatrixRows, MatrixColumns);
2586 if ((T->isArrayType() && !
getLangOpts().allowArrayReturnTypes()) ||
2587 T->isFunctionType()) {
2588 Diag(Loc, diag::err_func_returning_array_function)
2589 << T->isFunctionType() << T;
2594 if (T->isHalfType() && !
getLangOpts().NativeHalfArgsAndReturns &&
2595 !
Context.getTargetInfo().allowHalfArgsAndReturns()) {
2596 Diag(Loc, diag::err_parameters_retval_cannot_have_fp16_type) << 1 <<
2603 if (T->isObjCObjectType()) {
2604 Diag(Loc, diag::err_object_cannot_be_passed_returned_by_value)
2610 if (T.getPointerAuth()) {
2611 Diag(Loc, diag::err_ptrauth_qualifier_invalid) << T << 0;
2615 if (T.hasNonTrivialToPrimitiveDestructCUnion() ||
2616 T.hasNonTrivialToPrimitiveCopyCUnion())
2623 Diag(Loc, diag::warn_deprecated_volatile_return) << T;
2638 bool emittedError =
false;
2640 enum class RequiredCC { OnlySwift, SwiftOrSwiftAsync };
2641 auto checkCompatible = [&](
unsigned paramIndex, RequiredCC required) {
2643 (required == RequiredCC::OnlySwift)
2646 if (isCompatible || emittedError)
2648 S.
Diag(getParamLoc(paramIndex), diag::err_swift_param_attr_not_swiftcall)
2650 << (required == RequiredCC::OnlySwift);
2651 emittedError =
true;
2653 for (
size_t paramIndex = 0, numParams = paramTypes.size();
2654 paramIndex != numParams; ++paramIndex) {
2665 checkCompatible(paramIndex, RequiredCC::SwiftOrSwiftAsync);
2666 if (paramIndex != 0 &&
2669 S.
Diag(getParamLoc(paramIndex),
2670 diag::err_swift_indirect_result_not_first);
2675 checkCompatible(paramIndex, RequiredCC::SwiftOrSwiftAsync);
2684 checkCompatible(paramIndex, RequiredCC::OnlySwift);
2685 if (paramIndex == 0 ||
2688 S.
Diag(getParamLoc(paramIndex),
2689 diag::err_swift_error_result_not_after_swift_context);
2693 llvm_unreachable(
"bad ABI kind");
2705 for (
unsigned Idx = 0, Cnt = ParamTypes.size(); Idx < Cnt; ++Idx) {
2707 QualType ParamType =
Context.getAdjustedParameterType(ParamTypes[Idx]);
2709 Diag(Loc, diag::err_param_with_void_type);
2712 !
Context.getTargetInfo().allowHalfArgsAndReturns()) {
2714 Diag(Loc, diag::err_parameters_retval_cannot_have_fp16_type) << 0 <<
2718 Diag(Loc, diag::err_wasm_table_as_function_parameter);
2722 Diag(Loc, diag::err_ptrauth_qualifier_invalid) << T << 1;
2729 Diag(Loc, diag::warn_deprecated_volatile_param) << ParamType;
2731 ParamTypes[Idx] = ParamType;
2736 [=](
unsigned i) {
return Loc; });
2747 return Context.getFunctionType(T, ParamTypes, EPI);
2762 D <<
"member pointer";
2770 Diag(Loc, diag::err_distant_exception_spec);
2776 if (T->isReferenceType()) {
2777 Diag(Loc, diag::err_illegal_decl_mempointer_to_reference)
2782 if (T->isVoidType()) {
2783 Diag(Loc, diag::err_illegal_decl_mempointer_to_void)
2791 Diag(Loc, diag::err_opencl_function_pointer) << 0;
2796 Diag(Loc, diag::err_hlsl_pointers_unsupported) << 0;
2805 if (T->isFunctionType())
2814 if (!T->isFunctionType()) {
2815 Diag(Loc, diag::err_nonfunction_block_type);
2825 return Context.getBlockPointerType(T);
2831 if (TInfo) *TInfo =
nullptr;
2836 if (
const LocInfoType *LIT = dyn_cast<LocInfoType>(QT)) {
2837 QT = LIT->getType();
2838 TSI = LIT->getTypeSourceInfo();
2848 unsigned chunkIndex);
2855 Sema &S = state.getSema();
2856 Declarator &declarator = state.getDeclarator();
2862 unsigned outermostPointerIndex = 0;
2864 unsigned numPointers = 0;
2866 unsigned chunkIndex = i;
2868 switch (chunk.
Kind) {
2878 outermostPointerIndex = chunkIndex;
2886 if (numPointers != 1)
return;
2888 outermostPointerIndex = chunkIndex;
2906 if (numPointers == 1) {
2924 }
else if (numPointers == 2) {
2937 if (AL.getKind() == ParsedAttr::AT_ObjCOwnership)
2941 outermostPointerIndex);
2963 }
const QualKinds[5] = {
2977 for (
auto &E : QualKinds) {
2978 if (Quals & E.Mask) {
2979 if (!QualStr.empty()) QualStr +=
' ';
2996 << QualStr <<
NumQuals << FixIts[0] << FixIts[1] << FixIts[2] << FixIts[3];
3002 unsigned FunctionChunkIndex) {
3012 for (
unsigned OuterChunkIndex = FunctionChunkIndex + 1,
3014 OuterChunkIndex != End; ++OuterChunkIndex) {
3016 switch (OuterChunk.
Kind) {
3023 diag::warn_qual_return_type,
3049 llvm_unreachable(
"unknown declarator chunk kind");
3070static std::pair<QualType, TypeSourceInfo *>
3074 Sema &S = state.getSema();
3078 const unsigned AutoParameterPosition = Info.
TemplateParams.size();
3092 TemplateParameterDepth, AutoParameterPosition,
3095 IsParameterPack,
Auto->isConstrained());
3100 if (
Auto->isConstrained()) {
3107 for (
unsigned Idx = 0; Idx < AutoLoc.
getNumArgs(); ++Idx) {
3165 QualType NewT = state.ReplaceAutoType(T, Replacement);
3169 return {NewT, NewTSI};
3178 Sema &SemaRef = state.getSema();
3181 ReturnTypeInfo =
nullptr;
3184 TagDecl *OwnedTagDecl =
nullptr;
3234 DeducedType *Deduced = T->getContainedDeducedType();
3235 bool DeducedIsTrailingReturnType =
false;
3238 Deduced = T.
isNull() ?
nullptr : T->getContainedDeducedType();
3239 DeducedIsTrailingReturnType =
true;
3244 AutoType *
Auto = dyn_cast<AutoType>(Deduced);
3249 bool IsCXXAutoType =
3251 bool IsDeducedReturnType =
false;
3292 assert(Info &&
"No LambdaScopeInfo on the stack!");
3298 if (!DeducedIsTrailingReturnType)
3311 llvm_unreachable(
"unhandled tag kind");
3313 Error = Cxx ? 1 : 2;
3316 Error = Cxx ? 3 : 4;
3361 if (!SemaRef.
getLangOpts().CPlusPlus14 || !IsCXXAutoType)
3363 IsDeducedReturnType =
true;
3366 if (!SemaRef.
getLangOpts().CPlusPlus14 || !IsCXXAutoType)
3368 IsDeducedReturnType =
true;
3373 if (SemaRef.
getLangOpts().CPlusPlus23 && IsCXXAutoType &&
3374 !
Auto->isDecltypeAuto())
3407 (!SemaRef.
getLangOpts().CPlusPlus11 || !IsCXXAutoType))
3417 switch (
Auto->getKeyword()) {
3424 "unknown auto type");
3428 auto *DTST = dyn_cast<DeducedTemplateSpecializationType>(Deduced);
3431 SemaRef.
Diag(AutoRange.
getBegin(), diag::err_auto_not_allowed)
3433 <<
QualType(Deduced, 0) << AutoRange;
3444 unsigned DiagId = 0;
3446 DiagId = diag::warn_cxx11_compat_generic_lambda;
3447 else if (IsDeducedReturnType)
3448 DiagId = diag::warn_cxx11_compat_deduced_return_type;
3450 DiagId = diag::warn_cxx98_compat_auto_type_specifier;
3453 SemaRef.
Diag(AutoRange.
getBegin(), DiagId) << AutoRange;
3461 unsigned DiagID = 0;
3467 llvm_unreachable(
"parser should not have allowed this");
3483 DiagID = diag::err_type_defined_in_alias_template;
3495 DiagID = diag::err_type_defined_in_type_specifier;
3505 DiagID = diag::err_type_defined_in_param_type;
3511 DiagID = diag::err_type_defined_in_condition;
3522 assert(!T.isNull() &&
"This function should not return a null type");
3531 assert(FTI.
isAmbiguous &&
"no direct-initializer / function ambiguity");
3561 FTI.
NumParams ? diag::warn_parens_disambiguated_as_function_declaration
3562 : diag::warn_empty_parens_are_function_decl)
3573 if (Comma.getFileID() != Name.
getFileID() ||
3581 Result.suppressDiagnostics();
3594 S.
Diag(B, diag::note_additional_parens_for_variable_declaration)
3609 S.
Diag(DeclType.
Loc, diag::note_empty_parens_default_ctor)
3617 S.
Diag(DeclType.
Loc, diag::note_empty_parens_zero_initialize)
3628 "do not have redundant top-level parentheses");
3637 bool CouldBeTemporaryObject =
3641 (T->isRecordType() || T->isDependentType()) &&
3644 bool StartsWithDeclaratorId =
true;
3652 StartsWithDeclaratorId =
false;
3657 CouldBeTemporaryObject =
false;
3665 CouldBeTemporaryObject =
false;
3666 StartsWithDeclaratorId =
false;
3676 CouldBeTemporaryObject =
false;
3683 CouldBeTemporaryObject =
false;
3684 StartsWithDeclaratorId =
false;
3694 if (CouldBeTemporaryObject) {
3698 CouldBeTemporaryObject =
false;
3699 Result.suppressDiagnostics();
3704 if (!CouldBeTemporaryObject) {
3728 S.
Diag(
Paren.Loc, diag::warn_redundant_parens_around_declarator)
3734 S.
Diag(
Paren.Loc, diag::warn_parens_disambiguated_as_variable_declaration)
3736 auto *RD = T->getAsCXXRecordDecl();
3737 if (!RD || !RD->hasDefinition() || RD->hasNonTrivialDestructor())
3738 S.
Diag(
Paren.Loc, diag::note_raii_guard_add_name)
3743 S.
Diag(D.
getBeginLoc(), diag::note_function_style_cast_add_parentheses)
3746 S.
Diag(
Paren.Loc, diag::note_remove_parens_for_variable_declaration)
3762 switch (AL.getKind()) {
3781 bool IsCXXInstanceMethod =
false;
3787 unsigned I = ChunkIndex;
3788 bool FoundNonParen =
false;
3789 while (I && !FoundNonParen) {
3792 FoundNonParen =
true;
3795 if (FoundNonParen) {
3798 IsCXXInstanceMethod =
3803 IsCXXInstanceMethod =
3811 IsCXXInstanceMethod =
3819 IsCXXInstanceMethod);
3827 if (Triple.isSPIRV() && Triple.getVendor() != llvm::Triple::AMD) {
3829 if (AL.getKind() == ParsedAttr::AT_CUDAGlobal) {
3837 for (
const ParsedAttr &AL : llvm::concat<ParsedAttr>(
3840 if (AL.getKind() == ParsedAttr::AT_DeviceKernel) {
3851 enum class SimplePointerKind {
3860 switch (nullability) {
3862 if (!Ident__Nonnull)
3863 Ident__Nonnull =
PP.getIdentifierInfo(
"_Nonnull");
3864 return Ident__Nonnull;
3867 if (!Ident__Nullable)
3868 Ident__Nullable =
PP.getIdentifierInfo(
"_Nullable");
3869 return Ident__Nullable;
3872 if (!Ident__Nullable_result)
3873 Ident__Nullable_result =
PP.getIdentifierInfo(
"_Nullable_result");
3874 return Ident__Nullable_result;
3877 if (!Ident__Null_unspecified)
3878 Ident__Null_unspecified =
PP.getIdentifierInfo(
"_Null_unspecified");
3879 return Ident__Null_unspecified;
3881 llvm_unreachable(
"Unknown nullability kind.");
3888 if (AL.getKind() == ParsedAttr::AT_TypeNonNull ||
3889 AL.getKind() == ParsedAttr::AT_TypeNullable ||
3890 AL.getKind() == ParsedAttr::AT_TypeNullableResult ||
3891 AL.getKind() == ParsedAttr::AT_TypeNullUnspecified)
3900 enum class PointerDeclaratorKind {
3908 MaybePointerToCFRef,
3912 NSErrorPointerPointer,
3918 enum class PointerWrappingDeclaratorKind {
3932static PointerDeclaratorKind
3934 PointerWrappingDeclaratorKind &wrappingKind) {
3935 unsigned numNormalPointers = 0;
3938 if (
type->isDependentType())
3939 return PointerDeclaratorKind::NonPointer;
3944 switch (chunk.
Kind) {
3946 if (numNormalPointers == 0)
3947 wrappingKind = PointerWrappingDeclaratorKind::Array;
3956 return numNormalPointers > 0 ? PointerDeclaratorKind::MultiLevelPointer
3957 : PointerDeclaratorKind::SingleLevelPointer;
3963 if (numNormalPointers == 0)
3964 wrappingKind = PointerWrappingDeclaratorKind::Reference;
3968 ++numNormalPointers;
3969 if (numNormalPointers > 2)
3970 return PointerDeclaratorKind::MultiLevelPointer;
3976 unsigned numTypeSpecifierPointers = 0;
3980 ++numNormalPointers;
3982 if (numNormalPointers > 2)
3983 return PointerDeclaratorKind::MultiLevelPointer;
3985 type = ptrType->getPointeeType();
3986 ++numTypeSpecifierPointers;
3992 return numNormalPointers > 0 ? PointerDeclaratorKind::MultiLevelPointer
3993 : PointerDeclaratorKind::SingleLevelPointer;
3998 return numNormalPointers > 0 ? PointerDeclaratorKind::MultiLevelPointer
3999 : PointerDeclaratorKind::SingleLevelPointer;
4004 ++numNormalPointers;
4005 ++numTypeSpecifierPointers;
4008 if (
auto objcClassDecl = objcObjectPtr->getInterfaceDecl()) {
4010 numNormalPointers == 2 && numTypeSpecifierPointers < 2) {
4011 return PointerDeclaratorKind::NSErrorPointerPointer;
4020 if (objcClass->getInterface()->getIdentifier() ==
4022 if (numNormalPointers == 2 && numTypeSpecifierPointers < 2)
4023 return PointerDeclaratorKind::NSErrorPointerPointer;
4030 if (numNormalPointers == 0)
4031 return PointerDeclaratorKind::NonPointer;
4035 if (numNormalPointers == 2 && numTypeSpecifierPointers < 2 &&
4037 return PointerDeclaratorKind::CFErrorRefPointer;
4045 switch (numNormalPointers) {
4047 return PointerDeclaratorKind::NonPointer;
4050 return PointerDeclaratorKind::SingleLevelPointer;
4053 return PointerDeclaratorKind::MaybePointerToCFRef;
4056 return PointerDeclaratorKind::MultiLevelPointer;
4065 if (ctx->isFunctionOrMethod())
4068 if (ctx->isFileContext())
4079 bool invalid =
false;
4081 if (invalid || !sloc.
isFile())
4099template <
typename DiagBuilderT>
4108 if (!FixItLoc.
isValid() || FixItLoc == PointerLoc)
4117 InsertionTextBuf +=
" ";
4118 StringRef InsertionText = InsertionTextBuf.str();
4121 InsertionText = InsertionText.drop_back();
4122 }
else if (NextChar[-1] ==
'[') {
4123 if (NextChar[0] ==
']')
4124 InsertionText = InsertionText.drop_back().drop_front();
4126 InsertionText = InsertionText.drop_front();
4129 InsertionText = InsertionText.drop_back().drop_front();
4136 SimplePointerKind PointerKind,
4141 if (PointerKind == SimplePointerKind::Array) {
4142 S.
Diag(PointerLoc, diag::warn_nullability_missing_array);
4144 S.
Diag(PointerLoc, diag::warn_nullability_missing)
4145 <<
static_cast<unsigned>(PointerKind);
4148 auto FixItLoc = PointerEndLoc.
isValid() ? PointerEndLoc : PointerLoc;
4149 if (FixItLoc.isMacroID())
4153 auto Diag = S.
Diag(FixItLoc, diag::note_nullability_fix_it);
4184 if (pointerKind == SimplePointerKind::Array)
4185 diagKind = diag::warn_nullability_missing_array;
4187 diagKind = diag::warn_nullability_missing;
4193 fileNullability.
PointerKind =
static_cast<unsigned>(pointerKind);
4225 auto kind =
static_cast<SimplePointerKind
>(fileNullability.
PointerKind);
4240 unsigned i = endIndex;
4268template<
typename AttrT>
4271 return ::new (Ctx) AttrT(Ctx, AL);
4289 llvm_unreachable(
"unknown NullabilityKind");
4300 if (ASOld != ASNew) {
4301 S.
Diag(AttrLoc, diag::err_attribute_address_multiple_qualifiers);
4306 diag::warn_attribute_address_multiple_identical_qualifiers);
4315 return T->canHaveNullability(
false) &&
4321 T->getCanonicalTypeInternal());
4331 Sema &S = state.getSema();
4341 bool IsTypedefName =
4347 bool IsQualifiedFunction = T->isFunctionProtoType() &&
4355 if (
auto *DT = T->getAs<DeducedType>()) {
4356 const AutoType *AT = T->getAs<AutoType>();
4358 if ((AT && AT->isDecltypeAuto()) || IsClassTemplateDeduction) {
4360 unsigned Index = E - I - 1;
4362 unsigned DiagId = IsClassTemplateDeduction
4363 ? diag::err_deduced_class_template_compound_type
4364 : diag::err_decltype_auto_compound_type;
4365 unsigned DiagKind = 0;
4366 switch (DeclChunk.
Kind) {
4370 if (IsClassTemplateDeduction) {
4378 DiagId = diag::err_decltype_auto_function_declarator_not_declaration;
4396 S.
Diag(DeclChunk.
Loc, DiagId) << DiagKind;
4404 std::optional<NullabilityKind> inferNullability;
4405 bool inferNullabilityCS =
false;
4406 bool inferNullabilityInnerOnly =
false;
4407 bool inferNullabilityInnerOnlyComplete =
false;
4410 bool inAssumeNonNullRegion =
false;
4412 if (assumeNonNullLoc.
isValid()) {
4413 inAssumeNonNullRegion =
true;
4427 } complainAboutMissingNullability = CAMN_No;
4428 unsigned NumPointersRemaining = 0;
4429 auto complainAboutInferringWithinChunk = PointerWrappingDeclaratorKind::None;
4431 if (IsTypedefName) {
4435 complainAboutMissingNullability = CAMN_InnerPointers;
4439 ++NumPointersRemaining;
4444 switch (chunk.
Kind) {
4452 ++NumPointersRemaining;
4460 ++NumPointersRemaining;
4465 bool isFunctionOrMethod =
false;
4466 switch (
auto context = state.getDeclarator().getContext()) {
4472 isFunctionOrMethod =
true;
4476 if (state.getDeclarator().isObjCIvar() && !isFunctionOrMethod) {
4477 complainAboutMissingNullability = CAMN_No;
4482 if (state.getDeclarator().isObjCWeakProperty()) {
4485 complainAboutMissingNullability = CAMN_No;
4486 if (inAssumeNonNullRegion) {
4496 complainAboutMissingNullability = CAMN_Yes;
4499 auto wrappingKind = PointerWrappingDeclaratorKind::None;
4501 case PointerDeclaratorKind::NonPointer:
4502 case PointerDeclaratorKind::MultiLevelPointer:
4506 case PointerDeclaratorKind::SingleLevelPointer:
4508 if (inAssumeNonNullRegion) {
4509 complainAboutInferringWithinChunk = wrappingKind;
4516 case PointerDeclaratorKind::CFErrorRefPointer:
4517 case PointerDeclaratorKind::NSErrorPointerPointer:
4520 if (isFunctionOrMethod && inAssumeNonNullRegion)
4524 case PointerDeclaratorKind::MaybePointerToCFRef:
4525 if (isFunctionOrMethod) {
4529 auto hasCFReturnsAttr =
4531 return AttrList.hasAttribute(ParsedAttr::AT_CFReturnsRetained) ||
4532 AttrList.hasAttribute(ParsedAttr::AT_CFReturnsNotRetained);
4537 hasCFReturnsAttr(InnermostChunk->getAttrs()) ||
4540 inferNullabilityInnerOnly =
true;
4550 complainAboutMissingNullability = CAMN_Yes;
4578 auto isVaList = [&S](
QualType T) ->
bool {
4584 if (typedefTy->getDecl() == vaListTypedef)
4586 if (
auto *name = typedefTy->getDecl()->getIdentifier())
4587 if (name->isStr(
"va_list"))
4589 typedefTy = typedefTy->desugar()->getAs<
TypedefType>();
4590 }
while (typedefTy);
4596 auto inferPointerNullability =
4601 if (NumPointersRemaining > 0)
4602 --NumPointersRemaining;
4609 if (inferNullability && !inferNullabilityInnerOnlyComplete) {
4612 ? ParsedAttr::Form::ContextSensitiveKeyword()
4613 : ParsedAttr::Form::Keyword(
false ,
4619 attrs.addAtEnd(nullabilityAttr);
4621 if (inferNullabilityCS) {
4622 state.getDeclarator().getMutableDeclSpec().getObjCQualifiers()
4626 if (pointerLoc.isValid() &&
4627 complainAboutInferringWithinChunk !=
4628 PointerWrappingDeclaratorKind::None) {
4630 S.
Diag(pointerLoc, diag::warn_nullability_inferred_on_nested_type);
4635 if (inferNullabilityInnerOnly)
4636 inferNullabilityInnerOnlyComplete =
true;
4637 return nullabilityAttr;
4642 switch (complainAboutMissingNullability) {
4646 case CAMN_InnerPointers:
4647 if (NumPointersRemaining == 0)
4663 if (NumPointersRemaining > 0)
4664 --NumPointersRemaining;
4666 SimplePointerKind pointerKind = SimplePointerKind::Pointer;
4667 if (T->isBlockPointerType())
4668 pointerKind = SimplePointerKind::BlockPointer;
4669 else if (T->isMemberPointerType())
4670 pointerKind = SimplePointerKind::MemberPointer;
4672 if (
auto *
attr = inferPointerNullability(
4677 T = state.getAttributedType(
4683 if (complainAboutMissingNullability == CAMN_Yes && T->isArrayType() &&
4691 bool ExpectNoDerefChunk =
4692 state.getCurrentAttributes().hasAttribute(ParsedAttr::AT_NoDeref);
4702 bool AreDeclaratorChunksValid =
true;
4704 unsigned chunkIndex = e - i - 1;
4705 state.setCurrentChunkIndex(chunkIndex);
4708 switch (DeclType.
Kind) {
4716 if (!LangOpts.Blocks)
4717 S.
Diag(DeclType.
Loc, diag::err_blocks_disable) << LangOpts.OpenCL;
4720 inferPointerNullability(SimplePointerKind::BlockPointer, DeclType.
Loc,
4722 state.getDeclarator().getAttributePool());
4728 if (LangOpts.OpenCL)
4743 inferPointerNullability(SimplePointerKind::Pointer, DeclType.
Loc,
4745 state.getDeclarator().getAttributePool());
4748 T = Context.getObjCObjectPointerType(T);
4757 if (LangOpts.OpenCL) {
4758 if (T->isImageType() || T->isSamplerT() || T->isPipeType() ||
4759 T->isBlockPointerType()) {
4773 diag::err_overflow_behavior_non_integer_type)
4807 if (chunkIndex != 0 && !ArraySize &&
4826 S.
Diag(DeclType.
Loc, diag::err_array_star_outside_prototype);
4837 S.
Diag(DeclType.
Loc, diag::err_array_static_outside_prototype)
4839 :
"type qualifier");
4850 S.
Diag(DeclType.
Loc, diag::err_array_static_not_outermost)
4852 :
"type qualifier");
4862 if (complainAboutMissingNullability == CAMN_Yes &&
4878 IsQualifiedFunction =
4884 return SS.isInvalid() ||
4909 if (
First &&
First->isExplicitObjectParameter() &&
4923 diag::err_explicit_object_parameter_nonmember)
4924 << 2 << 0 <<
First->getSourceRange();
4927 diag::err_explicit_object_parameter_invalid)
4928 <<
First->getSourceRange();
4934 AreDeclaratorChunksValid =
false;
4947 ? diag::err_auto_missing_trailing_return
4948 : diag::err_deduced_return_type);
4951 AreDeclaratorChunksValid =
false;
4954 diag::warn_cxx11_compat_deduced_return_type);
4963 AreDeclaratorChunksValid =
false;
4966 if (T != Context.DependentTy) {
4968 diag::err_deduction_guide_with_complex_decl)
4972 AreDeclaratorChunksValid =
false;
4989 S.
Diag(Loc, diag::err_trailing_return_without_auto) << T << SR;
4992 AreDeclaratorChunksValid =
false;
4999 }
else if (AutoType *
Auto = T->getContainedAutoType()) {
5008 if (InventedParamInfo) {
5010 state, T, TInfo,
Auto, *InventedParamInfo);
5023 T->isFunctionType()) &&
5026 unsigned diagID = diag::err_func_returning_array_function;
5029 if (chunkIndex == 0 &&
5031 diagID = diag::err_block_returning_array_function;
5032 S.
Diag(DeclType.
Loc, diagID) << T->isFunctionType() << T;
5035 AreDeclaratorChunksValid =
false;
5040 if (T->isHalfType()) {
5048 }
else if (!S.
getLangOpts().NativeHalfArgsAndReturns &&
5051 diag::err_parameters_retval_cannot_have_fp16_type) << 1;
5057 if (T.getPointerAuth()) {
5058 S.
Diag(DeclType.
Loc, diag::err_ptrauth_qualifier_invalid) << T << 0;
5061 if (LangOpts.OpenCL) {
5064 if (T->isBlockPointerType() || T->isImageType() || T->isSamplerT() ||
5075 "__cl_clang_variadic_functions", S.
getLangOpts()) &&
5087 if (T->isObjCObjectType()) {
5096 S.
Diag(DiagLoc, diag::err_object_cannot_be_passed_returned_by_value)
5100 T = Context.getObjCObjectPointerType(T);
5108 AreDeclaratorChunksValid =
false;
5116 if ((T.getCVRQualifiers() || T->isAtomicType()) &&
5120 (T->isRecordType() || T->isDependentType() ||
5121 T->isUndeducedAutoType()))) {
5122 if (T->isVoidType() && !S.
getLangOpts().CPlusPlus &&
5128 S.
Diag(DeclType.
Loc, diag::err_func_returning_qualified_void) << T;
5135 if (T.isVolatileQualified() && S.
getLangOpts().CPlusPlus20)
5136 S.
Diag(DeclType.
Loc, diag::warn_deprecated_volatile_return) << T;
5141 if (T.getQualifiers().hasObjCLifetime()) {
5146 if (AL.getKind() == ParsedAttr::AT_ObjCOwnership) {
5147 AttrLoc = AL.getLoc();
5154 if (AL.getKind() == ParsedAttr::AT_ObjCOwnership) {
5155 AttrLoc = AL.getLoc();
5169 S.
Diag(AttrLoc, diag::warn_arc_lifetime_result_type)
5170 << T.getQualifiers().getObjCLifetime();
5178 S.
Diag(Tag->getLocation(), diag::err_type_defined_in_result_type)
5179 << Context.getCanonicalTagType(Tag);
5186 diag::err_exception_spec_in_typedef)
5204 T = Context.getFunctionNoProtoType(T, EI);
5212 diag::warn_c17_compat_ellipsis_only_parameter);
5214 ParsedAttr::AT_Overloadable) &&
5216 ParsedAttr::AT_Overloadable) &&
5218 ParsedAttr::AT_Overloadable))
5226 diag::err_ident_list_in_fn_declaration);
5230 ? Context.getFunctionNoProtoType(T, EI)
5232 AreDeclaratorChunksValid =
false;
5255 bool HasAnyInterestingExtParameterInfos =
false;
5257 for (
unsigned i = 0, e = FTI.
NumParams; i != e; ++i) {
5259 QualType ParamTy = Param->getType();
5260 assert(!ParamTy.
isNull() &&
"Couldn't parse type?");
5271 ParamTy = Context.IntTy;
5272 Param->setType(ParamTy);
5276 ParamTy = Context.IntTy;
5277 Param->setType(ParamTy);
5281 S.
Diag(DeclType.
Loc, diag::err_void_param_qualified);
5283 for (
const auto *A : Param->attrs()) {
5284 S.
Diag(A->getLoc(), diag::warn_attribute_on_void_param)
5285 << A << A->getRange();
5290 if (Param->isExplicitObjectParameter()) {
5291 S.
Diag(Param->getLocation(),
5292 diag::err_void_explicit_object_param);
5305 S.
Diag(Param->getLocation(), diag::err_opencl_invalid_param)
5308 Param->setInvalidDecl();
5310 }
else if (!S.
getLangOpts().NativeHalfArgsAndReturns &&
5312 S.
Diag(Param->getLocation(),
5313 diag::err_parameters_retval_cannot_have_fp16_type) << 0;
5317 if (Context.isPromotableIntegerType(ParamTy)) {
5318 ParamTy = Context.getPromotedIntegerType(ParamTy);
5319 Param->setKNRPromoted(
true);
5321 if (BTy->getKind() == BuiltinType::Float) {
5322 ParamTy = Context.DoubleTy;
5323 Param->setKNRPromoted(
true);
5328 S.
Diag(Param->getLocation(), diag::err_opencl_invalid_param)
5333 if (LangOpts.ObjCAutoRefCount && Param->hasAttr<NSConsumedAttr>()) {
5334 ExtParameterInfos[i] = ExtParameterInfos[i].withIsConsumed(
true);
5335 HasAnyInterestingExtParameterInfos =
true;
5339 ExtParameterInfos[i] =
5340 ExtParameterInfos[i].withABI(
attr->getABI());
5341 HasAnyInterestingExtParameterInfos =
true;
5344 if (Param->hasAttr<PassObjectSizeAttr>()) {
5345 ExtParameterInfos[i] = ExtParameterInfos[i].withHasPassObjectSize();
5346 HasAnyInterestingExtParameterInfos =
true;
5349 if (Param->hasAttr<NoEscapeAttr>()) {
5350 ExtParameterInfos[i] = ExtParameterInfos[i].withIsNoEscape(
true);
5351 HasAnyInterestingExtParameterInfos =
true;
5354 ParamTys.push_back(ParamTy);
5357 if (HasAnyInterestingExtParameterInfos) {
5366 Expr *NoexceptExpr =
nullptr;
5372 DynamicExceptions.reserve(N);
5373 DynamicExceptionRanges.reserve(N);
5374 for (
unsigned I = 0; I != N; ++I) {
5385 DynamicExceptionRanges,
5392 auto IsClassMember = [&]() {
5393 return (!state.getDeclarator().getCXXScopeSpec().isEmpty() &&
5394 state.getDeclarator()
5398 state.getDeclarator().getContext() ==
5400 state.getDeclarator().getContext() ==
5404 if (state.getSema().getLangOpts().OpenCLCPlusPlus && IsClassMember()) {
5424 T = Context.getFunctionType(T, ParamTys, EPI);
5433 inferPointerNullability(SimplePointerKind::MemberPointer, DeclType.
Loc,
5435 state.getDeclarator().getAttributePool());
5440 AreDeclaratorChunksValid =
false;
5449 AreDeclaratorChunksValid =
false;
5467 AreDeclaratorChunksValid =
false;
5476 S.
Diag(DeclType.
Loc, diag::warn_noderef_on_non_pointer_or_array);
5478 ExpectNoDerefChunk = state.didParseNoDeref();
5482 if (ExpectNoDerefChunk)
5483 S.
Diag(state.getDeclarator().getBeginLoc(),
5484 diag::warn_noderef_on_non_pointer_or_array);
5497 bool IsBlock =
false;
5499 switch (DeclType.Kind) {
5511 S.
Diag(DeclType.Loc, diag::warn_strict_prototypes)
5523 assert(!T.isNull() &&
"T must not be null after this point");
5525 if (LangOpts.CPlusPlus && T->isFunctionType()) {
5527 assert(FnTy &&
"Why oh why is there not a FunctionProtoType here?");
5540 ExplicitObjectMember,
5544 Kind = DeductionGuide;
5561 auto *P = dyn_cast_or_null<ParmVarDecl>(Chunk.
Fun.
Params->
Param);
5562 if (P && P->isExplicitObjectParameter())
5563 Kind = ExplicitObjectMember;
5589 if (IsQualifiedFunction &&
5614 if (!RemovalLocs.empty()) {
5615 llvm::sort(RemovalLocs,
5617 RemovalRange =
SourceRange(RemovalLocs.front(), RemovalLocs.back());
5618 Loc = RemovalLocs.front();
5622 S.
Diag(Loc, diag::err_invalid_qualified_function_type)
5646 if (!AL.slidesFromDeclToDeclSpecLegacyBehavior()) {
5654 state.diagnoseIgnoredTypeAttrs(T);
5665 if (T.isVolatileQualified() && S.
getLangOpts().CPlusPlus20 &&
5690 if (!T->containsUnexpandedParameterPack() &&
5691 (!LangOpts.CPlusPlus20 || !T->getContainedAutoType())) {
5693 diag::err_function_parameter_pack_without_parameter_packs)
5697 T = Context.getPackExpansionType(T, std::nullopt,
5710 if (T->containsUnexpandedParameterPack())
5711 T = Context.getPackExpansionType(T, std::nullopt);
5714 LangOpts.CPlusPlus11
5715 ? diag::warn_cxx98_compat_variadic_templates
5716 : diag::ext_variadic_templates);
5746 diag::err_ellipsis_in_declarator_not_parameter);
5752 assert(!T.isNull() &&
"T must not be null at the end of this function");
5753 if (!AreDeclaratorChunksValid)
5754 return Context.getTrivialTypeSourceInfo(T);
5756 if (state.didParseHLSLParamMod() && !T->isConstantArrayType())
5765 TypeProcessingState state(*
this, D);
5788 unsigned chunkIndex) {
5789 Sema &S = state.getSema();
5797 const char *attrStr =
nullptr;
5798 switch (ownership) {
5816 &Args, 1, ParsedAttr::Form::GNU());
5825 Sema &S = state.getSema();
5829 bool hasIndirection =
false;
5832 switch (chunk.
Kind) {
5841 hasIndirection =
true;
5874 TypeProcessingState state(*
this, D);
5889 TypeProcessingState &State) {
5894 TypeProcessingState &State) {
5896 State.getSema().HLSL().TakeLocForHLSLAttribute(TL.
getTypePtr());
5904 if (AL.getKind() == ParsedAttr::AT_MatrixType) {
5913 llvm_unreachable(
"no matrix_type attribute found at the expected location!");
5918 switch (Chunk.
Kind) {
5923 llvm_unreachable(
"cannot be _Atomic qualified");
5941 class TypeSpecLocFiller :
public TypeLocVisitor<TypeSpecLocFiller> {
5943 ASTContext &Context;
5944 TypeProcessingState &State;
5948 TypeSpecLocFiller(Sema &S, ASTContext &Context, TypeProcessingState &State,
5950 : SemaRef(S), Context(Context), State(State), DS(DS) {}
5952 void VisitAttributedTypeLoc(AttributedTypeLoc TL) {
5956 void VisitBTFTagAttributedTypeLoc(BTFTagAttributedTypeLoc TL) {
5959 void VisitOverflowBehaviorTypeLoc(OverflowBehaviorTypeLoc TL) {
5962 void VisitHLSLAttributedResourceTypeLoc(HLSLAttributedResourceTypeLoc TL) {
5966 void VisitHLSLInlineSpirvTypeLoc(HLSLInlineSpirvTypeLoc TL) {}
5967 void VisitMacroQualifiedTypeLoc(MacroQualifiedTypeLoc TL) {
5970 State.getExpansionLocForMacroQualifiedType(TL.
getTypePtr()));
5972 void VisitQualifiedTypeLoc(QualifiedTypeLoc TL) {
5977 void VisitPointerTypeLoc(PointerTypeLoc TL) { Visit(TL.
getNextTypeLoc()); }
5978 void VisitTypedefTypeLoc(TypedefTypeLoc TL) {
5980 TypeSourceInfo *TInfo =
nullptr;
5993 void VisitUnresolvedUsingTypeLoc(UnresolvedUsingTypeLoc TL) {
5995 TypeSourceInfo *TInfo =
nullptr;
6008 void VisitUsingTypeLoc(UsingTypeLoc TL) {
6010 TypeSourceInfo *TInfo =
nullptr;
6023 void VisitObjCInterfaceTypeLoc(ObjCInterfaceTypeLoc TL) {
6030 void VisitObjCObjectTypeLoc(ObjCObjectTypeLoc TL) {
6031 TypeSourceInfo *RepTInfo =
nullptr;
6035 void VisitObjCObjectPointerTypeLoc(ObjCObjectPointerTypeLoc TL) {
6036 TypeSourceInfo *RepTInfo =
nullptr;
6040 void VisitTemplateSpecializationTypeLoc(TemplateSpecializationTypeLoc TL) {
6041 TypeSourceInfo *TInfo =
nullptr;
6052 TL.
copy(OldTL.
castAs<TemplateSpecializationTypeLoc>());
6054 OldTL.
castAs<TemplateSpecializationTypeLoc>().getRAngleLoc());
6056 void VisitTypeOfExprTypeLoc(TypeOfExprTypeLoc TL) {
6062 void VisitTypeOfTypeLoc(TypeOfTypeLoc TL) {
6068 TypeSourceInfo *TInfo =
nullptr;
6072 void VisitDecltypeTypeLoc(DecltypeTypeLoc TL) {
6077 void VisitPackIndexingTypeLoc(PackIndexingTypeLoc TL) {
6081 void VisitUnaryTransformTypeLoc(UnaryTransformTypeLoc TL) {
6086 TypeSourceInfo *TInfo =
nullptr;
6090 void VisitBuiltinTypeLoc(BuiltinTypeLoc TL) {
6103 void VisitDependentNameTypeLoc(DependentNameTypeLoc TL) {
6105 TypeSourceInfo *TInfo =
nullptr;
6110 void VisitAutoTypeLoc(AutoTypeLoc TL) {
6124 NestedNameSpecifierLoc NNS =
6127 : NestedNameSpecifierLoc());
6128 TemplateArgumentListInfo TemplateArgsInfo(TemplateId->
LAngleLoc,
6130 if (TemplateId->
NumArgs > 0) {
6135 DeclarationNameInfo DNI = DeclarationNameInfo(
6136 TL.
getTypePtr()->getTypeConstraintConcept()->getDeclName(),
6139 NamedDecl *FoundDecl;
6144 FoundDecl = cast_if_present<NamedDecl>(TN.getAsTemplateDecl());
6152 void VisitDeducedTemplateSpecializationTypeLoc(
6153 DeducedTemplateSpecializationTypeLoc TL) {
6155 TypeSourceInfo *TInfo =
nullptr;
6161 void VisitTagTypeLoc(TagTypeLoc TL) {
6163 TypeSourceInfo *TInfo =
nullptr;
6171 ElaboratedTypeKeyword::None
6173 : SourceLocation());
6177 void VisitAtomicTypeLoc(AtomicTypeLoc TL) {
6184 TypeSourceInfo *TInfo =
nullptr;
6196 void VisitPipeTypeLoc(PipeTypeLoc TL) {
6199 TypeSourceInfo *TInfo =
nullptr;
6204 void VisitExtIntTypeLoc(BitIntTypeLoc TL) {
6208 void VisitDependentExtIntTypeLoc(DependentBitIntTypeLoc TL) {
6212 void VisitTypeLoc(TypeLoc TL) {
6218 class DeclaratorLocFiller :
public TypeLocVisitor<DeclaratorLocFiller> {
6219 ASTContext &Context;
6220 TypeProcessingState &State;
6221 const DeclaratorChunk &Chunk;
6224 DeclaratorLocFiller(ASTContext &Context, TypeProcessingState &State,
6225 const DeclaratorChunk &Chunk)
6226 : Context(Context), State(State), Chunk(Chunk) {}
6228 void VisitQualifiedTypeLoc(QualifiedTypeLoc TL) {
6229 llvm_unreachable(
"qualified type locs not expected here!");
6231 void VisitDecayedTypeLoc(DecayedTypeLoc TL) {
6232 llvm_unreachable(
"decayed type locs not expected here!");
6234 void VisitArrayParameterTypeLoc(ArrayParameterTypeLoc TL) {
6235 llvm_unreachable(
"array parameter type locs not expected here!");
6238 void VisitAttributedTypeLoc(AttributedTypeLoc TL) {
6241 void VisitCountAttributedTypeLoc(CountAttributedTypeLoc TL) {
6244 void VisitBTFTagAttributedTypeLoc(BTFTagAttributedTypeLoc TL) {
6247 void VisitOverflowBehaviorTypeLoc(OverflowBehaviorTypeLoc TL) {
6250 void VisitAdjustedTypeLoc(AdjustedTypeLoc TL) {
6253 void VisitBlockPointerTypeLoc(BlockPointerTypeLoc TL) {
6257 void VisitPointerTypeLoc(PointerTypeLoc TL) {
6261 void VisitObjCObjectPointerTypeLoc(ObjCObjectPointerTypeLoc TL) {
6265 void VisitMemberPointerTypeLoc(MemberPointerTypeLoc TL) {
6270 void VisitLValueReferenceTypeLoc(LValueReferenceTypeLoc TL) {
6276 void VisitRValueReferenceTypeLoc(RValueReferenceTypeLoc TL) {
6281 void VisitArrayTypeLoc(ArrayTypeLoc TL) {
6287 void VisitFunctionTypeLoc(FunctionTypeLoc TL) {
6292 const DeclaratorChunk::FunctionTypeInfo &FTI = Chunk.
Fun;
6295 for (
unsigned i = 0, e = TL.
getNumParams(), tpi = 0; i != e; ++i) {
6301 void VisitParenTypeLoc(ParenTypeLoc TL) {
6306 void VisitPipeTypeLoc(PipeTypeLoc TL) {
6310 void VisitBitIntTypeLoc(BitIntTypeLoc TL) {
6313 void VisitMacroQualifiedTypeLoc(MacroQualifiedTypeLoc TL) {
6316 void VisitVectorTypeLoc(VectorTypeLoc TL) { TL.
setNameLoc(Chunk.
Loc); }
6317 void VisitDependentVectorTypeLoc(DependentVectorTypeLoc TL) {
6320 void VisitExtVectorTypeLoc(ExtVectorTypeLoc TL) {
6323 void VisitAtomicTypeLoc(AtomicTypeLoc TL) {
6327 VisitDependentSizedExtVectorTypeLoc(DependentSizedExtVectorTypeLoc TL) {
6330 void VisitMatrixTypeLoc(MatrixTypeLoc TL) {
6334 void VisitTypeLoc(TypeLoc TL) {
6335 llvm_unreachable(
"unsupported TypeLoc kind in declarator!");
6344 if (AL.getKind() == ParsedAttr::AT_AddressSpace) {
6353 "no address_space attribute found at the expected location!");
6367 Sema &S = State.getSema();
6393 bool HasDesugaredTypeLoc =
true;
6394 while (HasDesugaredTypeLoc) {
6396 case TypeLoc::MacroQualified: {
6399 State.getExpansionLocForMacroQualifiedType(TL.
getTypePtr()));
6404 case TypeLoc::Attributed: {
6411 case TypeLoc::Adjusted:
6412 case TypeLoc::BTFTagAttributed: {
6417 case TypeLoc::DependentAddressSpace: {
6425 HasDesugaredTypeLoc =
false;
6436 if (ReturnTypeInfo) {
6456 "LocInfoType's TypeClass conflicts with an existing Type class");
6462 llvm_unreachable(
"LocInfoType leaked into the type system; an opaque TypeTy*"
6463 " was used directly instead of getting the QualType through"
6464 " GetTypeFromParser");
6471 "Type name should have no identifier!");
6508 const Expr *AddrSpace,
6511 std::optional<llvm::APSInt> OptAddrSpace =
6513 if (!OptAddrSpace) {
6514 S.
Diag(AttrLoc, diag::err_attribute_argument_type)
6519 llvm::APSInt &addrSpace = *OptAddrSpace;
6522 if (addrSpace.isSigned()) {
6523 if (addrSpace.isNegative()) {
6524 S.
Diag(AttrLoc, diag::err_attribute_address_space_negative)
6528 addrSpace.setIsSigned(
false);
6531 llvm::APSInt
max(addrSpace.getBitWidth());
6535 if (addrSpace >
max) {
6536 S.
Diag(AttrLoc, diag::err_attribute_address_space_too_high)
6558 return Context.getAddrSpaceQualType(T, ASIdx);
6567 Diag(AttrLoc, diag::err_attribute_address_multiple_qualifiers);
6571 return Context.getDependentAddressSpaceType(T, AddrSpace, AttrLoc);
6583 TypeProcessingState &State) {
6584 Sema &S = State.getSema();
6590 if (!
Attr.diagnoseLangOpts(S)) {
6596 if (
Attr.getNumArgs() != 1) {
6597 S.
Diag(
Attr.
getLoc(), diag::err_attribute_wrong_number_arguments)
6604 auto *StrLiteral = dyn_cast<StringLiteral>(
Attr.getArgAsExpr(0));
6613 StringRef BTFTypeTag = StrLiteral->getString();
6614 Type = State.getBTFTagAttributedType(
6615 ::new (Ctx) BTFTypeTagAttr(Ctx,
Attr, BTFTypeTag),
Type);
6623 TypeProcessingState &State) {
6624 Sema &S = State.getSema();
6629 S.
Diag(
Attr.
getLoc(), diag::err_attribute_address_function_type);
6635 if (
Attr.
getKind() == ParsedAttr::AT_AddressSpace) {
6638 if (
Attr.getNumArgs() != 1) {
6645 Expr *ASArgExpr =
Attr.getArgAsExpr(0);
6654 ::new (Ctx) AddressSpaceAttr(Ctx,
Attr,
static_cast<unsigned>(ASIdx));
6666 if (EquivType.
isNull()) {
6670 T = State.getAttributedType(ASAttr,
Type, EquivType);
6672 T = State.getAttributedType(ASAttr,
Type,
Type);
6683 :
Attr.asOpenCLLangAS();
6685 ASIdx =
Attr.asHLSLLangAS();
6688 llvm_unreachable(
"Invalid address space");
6701 TypeProcessingState &State) {
6702 Sema &S = State.getSema();
6706 S.
Diag(
Attr.
getLoc(), diag::warn_overflow_behavior_attribute_disabled)
6713 if (
Attr.getNumArgs() != 1) {
6714 S.
Diag(
Attr.
getLoc(), diag::err_attribute_wrong_number_arguments)
6722 S.
Diag(
Attr.
getLoc(), diag::err_overflow_behavior_non_integer_type)
6723 <<
Attr <<
Type.getAsString() << 0;
6728 StringRef KindName =
"";
6731 if (
Attr.isArgIdent(0)) {
6732 Ident =
Attr.getArgAsIdent(0)->getIdentifierInfo();
6741 auto *Str = dyn_cast<StringLiteral>(
Attr.getArgAsExpr(0));
6743 KindName = Str->getString();
6752 OverflowBehaviorType::OverflowBehaviorKind Kind;
6753 if (KindName ==
"wrap") {
6754 Kind = OverflowBehaviorType::OverflowBehaviorKind::Wrap;
6755 }
else if (KindName ==
"trap") {
6756 Kind = OverflowBehaviorType::OverflowBehaviorKind::Trap;
6759 << KindName <<
Attr;
6765 const DeclSpec &DS = State.getDeclarator().getDeclSpec();
6769 OverflowBehaviorType::OverflowBehaviorKind SpecifierKind =
6770 DS.
isWrapSpecified() ? OverflowBehaviorType::OverflowBehaviorKind::Wrap
6771 : OverflowBehaviorType::OverflowBehaviorKind::Trap;
6773 if (SpecifierKind != Kind) {
6776 << 1 << SpecifierName << KindName;
6780 S.
Diag(
Attr.
getLoc(), diag::warn_redundant_overflow_behaviors_mixed)
6787 if (
const auto *ExistingOBT =
Type->
getAs<OverflowBehaviorType>()) {
6788 OverflowBehaviorType::OverflowBehaviorKind ExistingKind =
6789 ExistingOBT->getBehaviorKind();
6790 if (ExistingKind != Kind) {
6791 S.
Diag(
Attr.
getLoc(), diag::err_conflicting_overflow_behaviors) << 0;
6792 if (Kind == OverflowBehaviorType::OverflowBehaviorKind::Trap) {
6793 Type = State.getOverflowBehaviorType(Kind,
6794 ExistingOBT->getUnderlyingType());
6799 Type = State.getOverflowBehaviorType(Kind,
Type);
6809 bool NonObjCPointer =
false;
6811 if (!
type->isDependentType() && !
type->isUndeducedType()) {
6819 NonObjCPointer =
true;
6820 }
else if (!
type->isObjCRetainableType()) {
6826 if (state.isProcessingDeclSpec()) {
6834 Sema &S = state.getSema();
6840 if (!
attr.isArgIdent(0)) {
6841 S.
Diag(AttrLoc, diag::err_attribute_argument_type) <<
attr
6849 if (II->
isStr(
"none"))
6851 else if (II->
isStr(
"strong"))
6853 else if (II->
isStr(
"weak"))
6855 else if (II->
isStr(
"autoreleasing"))
6858 S.
Diag(AttrLoc, diag::warn_attribute_type_not_supported) <<
attr << II;
6875 =
type.getQualifiers().getObjCLifetime()) {
6878 S.
Diag(AttrLoc, diag::err_attr_objc_ownership_redundant)
6885 if (previousLifetime != lifetime) {
6888 const Type *prevTy =
nullptr;
6889 while (!prevTy || prevTy != underlyingType.
Ty) {
6890 prevTy = underlyingType.
Ty;
6899 if (NonObjCPointer) {
6900 StringRef name =
attr.getAttrName()->getName();
6909 S.
Diag(AttrLoc, diag::warn_type_attribute_wrong_type) << name
6926 type = state.getAttributedType(
6933 if (!NonObjCPointer)
6950 diagnostic,
type, 0));
6952 S.
Diag(loc, diagnostic);
6961 unsigned diagnostic =
6962 (S.
getLangOpts().ObjCWeakRuntime ? diag::err_arc_weak_disabled
6963 : diag::err_arc_weak_no_runtime);
6966 diagnoseOrDelay(S, AttrLoc, diagnostic,
type);
6978 if (Class->isArcWeakrefUnavailable()) {
6979 S.
Diag(AttrLoc, diag::err_arc_unsupported_weak_class);
6980 S.
Diag(ObjT->getInterfaceDecl()->getLocation(),
6981 diag::note_class_declared);
6996 Sema &S = state.getSema();
6999 if (!
type->isPointerType() &&
7000 !
type->isObjCObjectPointerType() &&
7001 !
type->isBlockPointerType())
7005 S.
Diag(
attr.getLoc(), diag::err_attribute_multiple_objc_gc);
7011 if (!
attr.isArgIdent(0)) {
7012 S.
Diag(
attr.getLoc(), diag::err_attribute_argument_type)
7018 if (
attr.getNumArgs() > 1) {
7019 S.
Diag(
attr.getLoc(), diag::err_attribute_wrong_number_arguments) <<
attr
7026 if (II->
isStr(
"weak"))
7028 else if (II->
isStr(
"strong"))
7031 S.
Diag(
attr.getLoc(), diag::warn_attribute_type_not_supported)
7041 if (
attr.getLoc().isValid())
7042 type = state.getAttributedType(
7059 struct FunctionTypeUnwrapper {
7073 const FunctionType *
Fn;
7074 SmallVector<
unsigned char , 8> Stack;
7076 FunctionTypeUnwrapper(Sema &S, QualType T) : Original(T) {
7088 Stack.push_back(Array);
7094 Stack.push_back(BlockPointer);
7097 Stack.push_back(MemberPointer);
7103 Stack.push_back(Attributed);
7106 Stack.push_back(MacroQualified);
7114 T = QualType(DTy, 0);
7115 Stack.push_back(Desugar);
7120 bool isFunctionType()
const {
return (Fn !=
nullptr); }
7121 const FunctionType *get()
const {
return Fn; }
7123 QualType wrap(Sema &S,
const FunctionType *
New) {
7125 if (
New == get())
return Original;
7128 return wrap(S.
Context, Original, 0);
7132 QualType wrap(ASTContext &
C, QualType Old,
unsigned I) {
7133 if (I == Stack.size())
7138 SplitQualType SplitOld = Old.
split();
7142 return wrap(
C, SplitOld.
Ty, I);
7143 return C.getQualifiedType(wrap(
C, SplitOld.
Ty, I), SplitOld.
Quals);
7146 QualType wrap(ASTContext &
C,
const Type *Old,
unsigned I) {
7147 if (I == Stack.size())
return QualType(Fn, 0);
7149 switch (
static_cast<WrapKind
>(Stack[I++])) {
7160 return C.getParenType(
New);
7163 case MacroQualified:
7167 if (
const auto *CAT = dyn_cast<ConstantArrayType>(Old)) {
7168 QualType
New = wrap(
C, CAT->getElementType(), I);
7169 return C.getConstantArrayType(
New, CAT->getSize(), CAT->getSizeExpr(),
7170 CAT->getSizeModifier(),
7171 CAT->getIndexTypeCVRQualifiers());
7174 if (
const auto *VAT = dyn_cast<VariableArrayType>(Old)) {
7175 QualType
New = wrap(
C, VAT->getElementType(), I);
7176 return C.getVariableArrayType(
New, VAT->getSizeExpr(),
7177 VAT->getSizeModifier(),
7178 VAT->getIndexTypeCVRQualifiers());
7182 QualType
New = wrap(
C, IAT->getElementType(), I);
7183 return C.getIncompleteArrayType(
New, IAT->getSizeModifier(),
7184 IAT->getIndexTypeCVRQualifiers());
7189 return C.getPointerType(
New);
7192 case BlockPointer: {
7194 return C.getBlockPointerType(
New);
7197 case MemberPointer: {
7210 return C.getRValueReferenceType(
New);
7214 llvm_unreachable(
"unknown wrapping kind");
7221 Sema &S = State.getSema();
7225 default: llvm_unreachable(
"Unknown attribute kind");
7226 case ParsedAttr::AT_Ptr32:
7229 case ParsedAttr::AT_Ptr64:
7232 case ParsedAttr::AT_SPtr:
7235 case ParsedAttr::AT_UPtr:
7240 std::bitset<attr::LastAttr> Attrs;
7243 if (
const TypedefType *TT = dyn_cast<TypedefType>(Desugared)) {
7244 Desugared = TT->desugar();
7247 const AttributedType *AT = dyn_cast<AttributedType>(Desugared);
7250 Attrs[AT->getAttrKind()] =
true;
7251 Desugared = AT->getModifiedType();
7257 if (Attrs[NewAttrKind]) {
7258 S.
Diag(PAttr.
getLoc(), diag::warn_duplicate_attribute_exact) << PAttr;
7261 Attrs[NewAttrKind] =
true;
7265 if (Attrs[attr::Ptr32] && Attrs[attr::Ptr64]) {
7266 S.
Diag(PAttr.
getLoc(), diag::err_attributes_are_not_compatible)
7268 <<
"'__ptr64'" << 0;
7270 }
else if (Attrs[attr::SPtr] && Attrs[attr::UPtr]) {
7271 S.
Diag(PAttr.
getLoc(), diag::err_attributes_are_not_compatible)
7283 S.
Diag(PAttr.
getLoc(), diag::err_attribute_no_member_pointers) << PAttr;
7285 S.
Diag(PAttr.
getLoc(), diag::err_attribute_pointers_only) << PAttr << 0;
7293 if (PtrWidth == 32) {
7294 if (Attrs[attr::Ptr64])
7296 else if (Attrs[attr::UPtr])
7298 }
else if (PtrWidth == 64 && Attrs[attr::Ptr32]) {
7315 assert(PAttr.
getKind() == ParsedAttr::AT_WebAssemblyFuncref);
7317 Sema &S = State.getSema();
7320 std::bitset<attr::LastAttr> Attrs;
7322 const auto *AT = dyn_cast<AttributedType>(QT);
7324 Attrs[AT->getAttrKind()] =
true;
7325 AT = dyn_cast<AttributedType>(AT->getModifiedType());
7330 if (Attrs[NewAttrKind]) {
7331 S.
Diag(PAttr.
getLoc(), diag::warn_duplicate_attribute_exact) << PAttr;
7337 const auto *Ptr = dyn_cast<PointerType>(Desugared);
7338 if (!Ptr || !Ptr->getPointeeType()->isFunctionType()) {
7339 S.
Diag(PAttr.
getLoc(), diag::err_attribute_webassembly_funcref);
7357 Sema &S = State.getSema();
7358 auto &D = State.getDeclarator();
7364 if (State.isProcessingDeclSpec()) {
7365 if (!(D.isPrototypeContext() ||
7369 if (
auto *chunk = D.getInnermostNonParenChunk()) {
7392 auto chunkIdx = State.getCurrentChunkIndex();
7393 if (chunkIdx >= 1 &&
7396 D.getTypeObject(chunkIdx - 1).getAttrs());
7401 auto *A = ::new (S.
Context) SwiftAttrAttr(S.
Context, PAttr, Str);
7402 QT = State.getAttributedType(A, QT, QT);
7409 auto Attributed = dyn_cast<AttributedType>(
Type.getTypePtr());
7414 if (Attributed->getImmediateNullability())
7415 return Attributed->getModifiedType();
7419 Ctx, Attributed->getModifiedType());
7420 assert(Modified.
getTypePtr() != Attributed->getModifiedType().getTypePtr());
7422 Attributed->getEquivalentType(),
7423 Attributed->getAttr());
7429 case ParsedAttr::AT_TypeNonNull:
7432 case ParsedAttr::AT_TypeNullable:
7435 case ParsedAttr::AT_TypeNullableResult:
7438 case ParsedAttr::AT_TypeNullUnspecified:
7442 llvm_unreachable(
"not a nullability attribute kind");
7449 bool IsContextSensitive,
bool AllowOnArrayType,
bool OverrideExisting) {
7450 bool Implicit = (State ==
nullptr);
7456 while (
auto *Attributed = dyn_cast<AttributedType>(Desugared.
getTypePtr())) {
7458 if (
auto ExistingNullability = Attributed->getImmediateNullability()) {
7460 if (Nullability == *ExistingNullability) {
7464 S.
Diag(NullabilityLoc, diag::warn_nullability_duplicate)
7471 if (!OverrideExisting) {
7473 S.
Diag(NullabilityLoc, diag::err_nullability_conflicting)
7483 Desugared = Attributed->getModifiedType();
7491 if (Nullability != *ExistingNullability && !
Implicit) {
7492 S.
Diag(NullabilityLoc, diag::err_nullability_conflicting)
7500 if (
auto typedefNullability =
7501 AttributedType::stripOuterNullability(underlyingType)) {
7502 if (*typedefNullability == *ExistingNullability) {
7515 !(AllowOnArrayType && Desugared->
isArrayType())) {
7517 S.
Diag(NullabilityLoc, diag::err_nullability_nonpointer)
7525 if (IsContextSensitive) {
7527 const Type *pointeeType =
nullptr;
7536 S.
Diag(NullabilityLoc, diag::err_nullability_cs_multilevel)
7538 S.
Diag(NullabilityLoc, diag::note_nullability_type_specifier)
7550 QT = State->getAttributedType(A, QT, QT);
7559 bool AllowOnArrayType) {
7565 Nullability, NullabilityLoc,
7566 IsContextSensitive, AllowOnArrayType,
7573 bool AllowArrayTypes,
7574 bool OverrideExisting) {
7576 *
this,
nullptr,
nullptr,
Type, Nullability, DiagLoc,
7577 false, AllowArrayTypes, OverrideExisting);
7585 llvm::APInt MaxSizeForAddrSpace =
7586 llvm::APInt::getMaxValue(
Context.getTargetInfo().getPointerWidth(AS));
7587 std::optional<CharUnits> TSizeInChars =
Context.getTypeSizeInCharsIfKnown(T);
7588 if (TSizeInChars &&
static_cast<uint64_t
>(TSizeInChars->getQuantity()) >
7589 MaxSizeForAddrSpace.getZExtValue()) {
7591 << T << MaxSizeForAddrSpace;
7602 Sema &S = state.getSema();
7606 type = state.getAttributedType(
7619 S.
Diag(
attr.getLoc(), diag::err_objc_kindof_nonobject)
7628 objType->getBaseType(), objType->getTypeArgsAsWritten(),
7629 objType->getProtocols(),
7630 objType->isObjCUnqualifiedId() ?
false :
true);
7635 if (
auto nullability =
type->getNullability()) {
7638 assert(
attr.getAttributeSpellingListIndex() == 0 &&
7639 "multiple spellings for __kindof?");
7642 equivType = state.getAttributedType(A, equivType, equivType);
7647 type = state.getAttributedType(
7660 Declarator &declarator = state.getDeclarator();
7663 auto moveToChunk = [&](
DeclaratorChunk &chunk,
bool inFunction) ->
bool {
7676 PK_MemberFunctionPointer,
7681 : inFunction? PK_MemberFunctionPointer : PK_MemberPointer;
7683 auto diag = state.getSema().Diag(
attr.getLoc(),
7684 diag::warn_nullability_declspec)
7686 attr.isContextSensitiveKeywordAttribute())
7688 <<
static_cast<unsigned>(pointerKind);
7694 state.getSema().getPreprocessor().getLocForEndOfToken(
7696 " " +
attr.getAttrName()->getName().str() +
" ");
7706 for (
unsigned i = state.getCurrentChunkIndex(); i != 0; --i) {
7708 switch (chunk.
Kind) {
7712 return moveToChunk(chunk,
false);
7724 return moveToChunk(*dest,
true);
7740 assert(!
Attr.isInvalid());
7743 llvm_unreachable(
"not a calling convention attribute");
7744 case ParsedAttr::AT_CDecl:
7746 case ParsedAttr::AT_FastCall:
7748 case ParsedAttr::AT_StdCall:
7750 case ParsedAttr::AT_ThisCall:
7752 case ParsedAttr::AT_RegCall:
7754 case ParsedAttr::AT_Pascal:
7756 case ParsedAttr::AT_SwiftCall:
7758 case ParsedAttr::AT_SwiftAsyncCall:
7760 case ParsedAttr::AT_VectorCall:
7762 case ParsedAttr::AT_AArch64VectorPcs:
7764 case ParsedAttr::AT_AArch64SVEPcs:
7766 case ParsedAttr::AT_ArmStreaming:
7768 case ParsedAttr::AT_Pcs: {
7773 if (
Attr.isArgExpr(0))
7776 Str =
Attr.getArgAsIdent(0)->getIdentifierInfo()->getName();
7777 PcsAttr::PCSType
Type;
7778 if (!PcsAttr::ConvertStrToPCSType(Str,
Type))
7779 llvm_unreachable(
"already validated the attribute");
7780 return ::new (Ctx) PcsAttr(Ctx,
Attr,
Type);
7782 case ParsedAttr::AT_IntelOclBicc:
7784 case ParsedAttr::AT_MSABI:
7786 case ParsedAttr::AT_SysVABI:
7788 case ParsedAttr::AT_PreserveMost:
7790 case ParsedAttr::AT_PreserveAll:
7792 case ParsedAttr::AT_M68kRTD:
7794 case ParsedAttr::AT_PreserveNone:
7796 case ParsedAttr::AT_RISCVVectorCC:
7798 case ParsedAttr::AT_RISCVVLSCC: {
7801 unsigned ABIVLen = 128;
7802 if (
Attr.getNumArgs()) {
7803 std::optional<llvm::APSInt> MaybeABIVLen =
7804 Attr.getArgAsExpr(0)->getIntegerConstantExpr(Ctx);
7806 llvm_unreachable(
"Invalid RISC-V ABI VLEN");
7807 ABIVLen = MaybeABIVLen->getZExtValue();
7810 return ::new (Ctx) RISCVVLSCCAttr(Ctx,
Attr, ABIVLen);
7813 llvm_unreachable(
"unexpected attribute kind!");
7816std::optional<FunctionEffectMode>
7821 std::optional<llvm::APSInt> ConditionValue =
7823 if (!ConditionValue) {
7829 return std::nullopt;
7838 FunctionTypeUnwrapper &Unwrapped) {
7840 if (!Unwrapped.isFunctionType())
7843 Sema &S = TPState.getSema();
7847 if (FPT ==
nullptr) {
7848 S.
Diag(PAttr.
getLoc(), diag::err_func_with_effects_no_prototype)
7855 bool IsNonBlocking = PAttr.
getKind() == ParsedAttr::AT_NonBlocking ||
7856 PAttr.
getKind() == ParsedAttr::AT_Blocking;
7859 Expr *CondExpr =
nullptr;
7861 if (PAttr.
getKind() == ParsedAttr::AT_NonBlocking ||
7862 PAttr.
getKind() == ParsedAttr::AT_NonAllocating) {
7871 std::optional<FunctionEffectMode> MaybeMode =
7877 NewMode = *MaybeMode;
7912 assert(
Success &&
"effect conflicts should have been diagnosed above");
7916 FPT->getParamTypes(), EPI);
7925 auto OtherAttr = llvm::find_if(
7926 state.getCurrentAttributes(),
7927 [OtherKind](
const ParsedAttr &A) { return A.getKind() == OtherKind; });
7928 if (OtherAttr == state.getCurrentAttributes().end() || OtherAttr->isInvalid())
7931 Sema &S = state.getSema();
7933 << *OtherAttr <<
Attr
7934 << (OtherAttr->isRegularKeywordAttribute() ||
7936 S.
Diag(OtherAttr->getLoc(), diag::note_conflicting_attribute);
7944 if (!
Attr.getNumArgs()) {
7950 for (
unsigned I = 0; I <
Attr.getNumArgs(); ++I) {
7951 StringRef StateName;
7956 if (StateName !=
"sme_za_state") {
7957 S.
Diag(LiteralLoc, diag::err_unknown_arm_state) << StateName;
7964 S.
Diag(
Attr.
getLoc(), diag::err_conflicting_attributes_arm_agnostic);
7979 if (!
Attr.getNumArgs()) {
7985 for (
unsigned I = 0; I <
Attr.getNumArgs(); ++I) {
7986 StringRef StateName;
7993 if (StateName ==
"za") {
7996 }
else if (StateName ==
"zt0") {
8000 S.
Diag(LiteralLoc, diag::err_unknown_arm_state) << StateName;
8006 S.
Diag(LiteralLoc, diag::err_conflicting_attributes_arm_agnostic);
8015 S.
Diag(LiteralLoc, diag::err_conflicting_attributes_arm_state)
8031 Sema &S = state.getSema();
8033 FunctionTypeUnwrapper unwrapped(S,
type);
8035 if (
attr.getKind() == ParsedAttr::AT_NoReturn) {
8040 if (!unwrapped.isFunctionType())
8049 if (
attr.getKind() == ParsedAttr::AT_CFIUncheckedCallee) {
8051 if (!unwrapped.isFunctionType())
8054 if (!unwrapped.get()->isFunctionProtoType()) {
8055 S.
Diag(
attr.getLoc(), diag::warn_attribute_wrong_decl_type)
8056 <<
attr <<
attr.isRegularKeywordAttribute()
8064 FPT->getReturnType(), FPT->getParamTypes(),
8065 FPT->getExtProtoInfo().withCFIUncheckedCallee(
true));
8070 if (
attr.getKind() == ParsedAttr::AT_CmseNSCall) {
8072 if (!unwrapped.isFunctionType())
8077 S.
Diag(
attr.getLoc(), diag::warn_attribute_ignored) <<
attr;
8084 unwrapped.get()->getExtInfo().withCmseNSCall(
true);
8091 if (
attr.getKind() == ParsedAttr::AT_NSReturnsRetained) {
8092 if (
attr.getNumArgs())
return true;
8095 if (!unwrapped.isFunctionType())
8100 attr.getLoc(), unwrapped.get()->getReturnType()))
8105 if (state.getSema().getLangOpts().ObjCAutoRefCount) {
8107 = unwrapped.get()->getExtInfo().withProducesResult(
true);
8110 type = state.getAttributedType(
8116 if (
attr.getKind() == ParsedAttr::AT_AnyX86NoCallerSavedRegisters) {
8121 if (!unwrapped.isFunctionType())
8125 unwrapped.get()->getExtInfo().withNoCallerSavedRegs(
true);
8130 if (
attr.getKind() == ParsedAttr::AT_AnyX86NoCfCheck) {
8132 S.
Diag(
attr.getLoc(), diag::warn_nocf_check_attribute_ignored);
8142 if (!unwrapped.isFunctionType())
8146 unwrapped.get()->getExtInfo().withNoCfCheck(
true);
8151 if (
attr.getKind() == ParsedAttr::AT_Regparm) {
8157 if (!unwrapped.isFunctionType())
8164 S.
Diag(
attr.getLoc(), diag::err_attributes_are_not_compatible)
8166 <<
attr.isRegularKeywordAttribute();
8172 unwrapped.get()->getExtInfo().withRegParm(value);
8177 if (
attr.getKind() == ParsedAttr::AT_CFISalt) {
8178 if (
attr.getNumArgs() != 1)
8186 if (!unwrapped.isFunctionType())
8191 S.
Diag(
attr.getLoc(), diag::err_attribute_wrong_decl_type)
8192 <<
attr <<
attr.isRegularKeywordAttribute()
8202 FnTy->getParamTypes(), EPI);
8207 if (
attr.getKind() == ParsedAttr::AT_ArmStreaming ||
8208 attr.getKind() == ParsedAttr::AT_ArmStreamingCompatible ||
8209 attr.getKind() == ParsedAttr::AT_ArmPreserves ||
8210 attr.getKind() == ParsedAttr::AT_ArmIn ||
8211 attr.getKind() == ParsedAttr::AT_ArmOut ||
8212 attr.getKind() == ParsedAttr::AT_ArmInOut ||
8213 attr.getKind() == ParsedAttr::AT_ArmAgnostic) {
8217 if (
attr.getKind() == ParsedAttr::AT_ArmStreaming ||
8218 attr.getKind() == ParsedAttr::AT_ArmStreamingCompatible)
8222 if (!unwrapped.isFunctionType())
8229 S.
Diag(
attr.getLoc(), diag::warn_attribute_wrong_decl_type)
8230 <<
attr <<
attr.isRegularKeywordAttribute()
8237 switch (
attr.getKind()) {
8238 case ParsedAttr::AT_ArmStreaming:
8240 ParsedAttr::AT_ArmStreamingCompatible))
8244 case ParsedAttr::AT_ArmStreamingCompatible:
8249 case ParsedAttr::AT_ArmPreserves:
8253 case ParsedAttr::AT_ArmIn:
8257 case ParsedAttr::AT_ArmOut:
8261 case ParsedAttr::AT_ArmInOut:
8265 case ParsedAttr::AT_ArmAgnostic:
8270 llvm_unreachable(
"Unsupported attribute");
8274 FnTy->getParamTypes(), EPI);
8279 if (
attr.getKind() == ParsedAttr::AT_NoThrow) {
8281 if (!unwrapped.isFunctionType())
8294 if (Proto->hasExceptionSpec()) {
8295 switch (Proto->getExceptionSpecType()) {
8297 llvm_unreachable(
"This doesn't have an exception spec!");
8315 S.
Diag(
attr.getLoc(), diag::warn_nothrow_attribute_ignored);
8321 type = unwrapped.wrap(
8330 if (
attr.getKind() == ParsedAttr::AT_NonBlocking ||
8331 attr.getKind() == ParsedAttr::AT_NonAllocating ||
8332 attr.getKind() == ParsedAttr::AT_Blocking ||
8333 attr.getKind() == ParsedAttr::AT_Allocating) {
8338 if (!unwrapped.isFunctionType())
return false;
8353 S.
Diag(
attr.getLoc(), diag::err_attributes_are_not_compatible)
8356 <<
attr.isRegularKeywordAttribute();
8375 return S.
Diag(
attr.getLoc(), diag::warn_cconv_unsupported)
8380 return S.
Diag(
attr.getLoc(), diag::err_cconv_varargs)
8387 S.
Diag(
attr.getLoc(), diag::err_attributes_are_not_compatible)
8389 <<
attr.isRegularKeywordAttribute();
8401 auto EI = unwrapped.get()->getExtInfo().withCallingConv(CC);
8410 const AttributedType *AT;
8414 while ((AT = T->getAs<AttributedType>()) &&
8416 if (AT->isCallingConv())
8418 T = AT->getModifiedType();
8425 FunctionTypeUnwrapper Unwrapped(*
this, T);
8431 Context.getDefaultCallingConvention(IsVariadic, HasThisPointer);
8438 if (
Context.getTargetInfo().getCXXABI().isMicrosoft() && IsCtorOrDtor) {
8442 Diag(Loc, diag::warn_cconv_unsupported)
8451 Context.getDefaultCallingConvention(IsVariadic, !HasThisPointer);
8453 if (CurCC != DefaultCC)
8461 QualType Wrapped = Unwrapped.wrap(*
this, FT);
8462 T =
Context.getAdjustedType(T, Wrapped);
8475 if (
Attr.getNumArgs() != 1) {
8482 Expr *SizeExpr =
Attr.getArgAsExpr(0);
8495 if (
Attr.getNumArgs() != 1) {
8501 Expr *SizeExpr =
Attr.getArgAsExpr(0);
8516 bool IsPolyUnsigned = Triple.getArch() == llvm::Triple::aarch64 ||
8517 Triple.getArch() == llvm::Triple::aarch64_32 ||
8518 Triple.getArch() == llvm::Triple::aarch64_be;
8520 if (IsPolyUnsigned) {
8522 return BTy->
getKind() == BuiltinType::UChar ||
8523 BTy->
getKind() == BuiltinType::UShort ||
8524 BTy->
getKind() == BuiltinType::ULong ||
8525 BTy->
getKind() == BuiltinType::ULongLong;
8528 return BTy->
getKind() == BuiltinType::SChar ||
8529 BTy->
getKind() == BuiltinType::Short ||
8530 BTy->
getKind() == BuiltinType::LongLong;
8536 if ((Triple.isArch64Bit() || Triple.getArch() == llvm::Triple::aarch64_32) &&
8537 BTy->
getKind() == BuiltinType::Double)
8540 return BTy->
getKind() == BuiltinType::SChar ||
8541 BTy->
getKind() == BuiltinType::UChar ||
8542 BTy->
getKind() == BuiltinType::Short ||
8543 BTy->
getKind() == BuiltinType::UShort ||
8544 BTy->
getKind() == BuiltinType::Int ||
8545 BTy->
getKind() == BuiltinType::UInt ||
8546 BTy->
getKind() == BuiltinType::Long ||
8547 BTy->
getKind() == BuiltinType::ULong ||
8548 BTy->
getKind() == BuiltinType::LongLong ||
8549 BTy->
getKind() == BuiltinType::ULongLong ||
8550 BTy->
getKind() == BuiltinType::Float ||
8551 BTy->
getKind() == BuiltinType::Half ||
8552 BTy->
getKind() == BuiltinType::BFloat16 ||
8553 BTy->
getKind() == BuiltinType::MFloat8;
8557 llvm::APSInt &Result) {
8558 const auto *AttrExpr =
Attr.getArgAsExpr(0);
8559 if (!AttrExpr->isTypeDependent()) {
8560 if (std::optional<llvm::APSInt> Res =
8561 AttrExpr->getIntegerConstantExpr(S.
Context)) {
8603 if (
Attr.getNumArgs() != 1) {
8604 S.
Diag(
Attr.
getLoc(), diag::err_attribute_wrong_number_arguments)
8610 llvm::APSInt numEltsInt(32);
8616 S.
Diag(
Attr.
getLoc(), diag::err_attribute_invalid_vector_type) << CurType;
8623 unsigned numElts =
static_cast<unsigned>(numEltsInt.getZExtValue());
8624 unsigned vecSize = typeSize * numElts;
8625 if (vecSize != 64 && vecSize != 128) {
8626 S.
Diag(
Attr.
getLoc(), diag::err_attribute_bad_neon_vector_size) << CurType;
8638 assert((
Attr.getNumArgs() > 0 &&
Attr.getNumArgs() <= 3) &&
8639 "__ptrauth qualifier takes between 1 and 3 arguments");
8640 Expr *KeyArg =
Attr.getArgAsExpr(0);
8641 Expr *IsAddressDiscriminatedArg =
8642 Attr.getNumArgs() >= 2 ?
Attr.getArgAsExpr(1) :
nullptr;
8643 Expr *ExtraDiscriminatorArg =
8644 Attr.getNumArgs() >= 3 ?
Attr.getArgAsExpr(2) :
nullptr;
8653 bool IsInvalid =
false;
8654 unsigned IsAddressDiscriminated, ExtraDiscriminator;
8657 IsAddressDiscriminated);
8666 if (!T->isSignableType(Ctx) && !T->isDependentType()) {
8667 S.
Diag(
Attr.
getLoc(), diag::err_ptrauth_qualifier_invalid_target) << T;
8672 if (T.getPointerAuth()) {
8673 S.
Diag(
Attr.
getLoc(), diag::err_ptrauth_qualifier_redundant) << T;
8684 assert((!IsAddressDiscriminatedArg || IsAddressDiscriminated <= 1) &&
8685 "address discriminator arg should be either 0 or 1");
8687 Key, IsAddressDiscriminated, ExtraDiscriminator,
8709 S.
Diag(
Attr.
getLoc(), diag::err_attribute_arm_feature_sve_bits_unsupported)
8716 if (
Attr.getNumArgs() != 1) {
8717 S.
Diag(
Attr.
getLoc(), diag::err_attribute_wrong_number_arguments)
8724 llvm::APSInt SveVectorSizeInBits(32);
8728 unsigned VecSize =
static_cast<unsigned>(SveVectorSizeInBits.getZExtValue());
8751 if (BT->getKind() == BuiltinType::SveBool) {
8756 VecSize /= TypeSize;
8763 const VectorType *VT = dyn_cast<VectorType>(CurType);
8766 diag::err_attribute_arm_mve_polymorphism);
8773 State.getSema().Context,
Attr),
8785 <<
Attr <<
"'zve32x'";
8792 if (!VScale || !VScale->first || VScale->first != VScale->second) {
8793 S.
Diag(
Attr.
getLoc(), diag::err_attribute_riscv_rvv_bits_unsupported)
8800 if (
Attr.getNumArgs() != 1) {
8801 S.
Diag(
Attr.
getLoc(), diag::err_attribute_wrong_number_arguments)
8808 llvm::APSInt RVVVectorSizeInBits(32);
8820 unsigned VecSize =
static_cast<unsigned>(RVVVectorSizeInBits.getZExtValue());
8824 unsigned MinElts = Info.
EC.getKnownMinValue();
8827 unsigned ExpectedSize = VScale->first * MinElts;
8849 ExpectedSize *= EltSize;
8850 NumElts = VecSize / EltSize;
8854 if (VecSize != ExpectedSize) {
8856 << VecSize << ExpectedSize;
8869 S.
Diag(
Attr.
getLoc(), diag::err_opencl_invalid_access_qualifier);
8875 QualType BaseTy = TypedefTy->desugar();
8877 std::string PrevAccessQual;
8879 if (TypedefTy->getDecl()->hasAttr<OpenCLAccessAttr>()) {
8880 OpenCLAccessAttr *
Attr =
8881 TypedefTy->getDecl()->getAttr<OpenCLAccessAttr>();
8884 PrevAccessQual =
"read_only";
8888 switch (ImgType->getKind()) {
8889 #define IMAGE_TYPE(ImgType, Id, SingletonId, Access, Suffix) \
8890 case BuiltinType::Id: \
8891 PrevAccessQual = #Access; \
8893 #include "clang/Basic/OpenCLImageTypes.def"
8895 llvm_unreachable(
"Unable to find corresponding image type.");
8898 llvm_unreachable(
"unexpected type");
8901 if (PrevAccessQual == AttrName.ltrim(
"_")) {
8907 S.
Diag(
Attr.
getLoc(), diag::err_opencl_multiple_access_qualifiers);
8910 S.
Diag(TypedefTy->getDecl()->getBeginLoc(),
8911 diag::note_opencl_typedef_access_qualifier) << PrevAccessQual;
8913 if (
Attr.getSemanticSpelling() == OpenCLAccessAttr::Keyword_write_only) {
8928 if (
Attr.getNumArgs() != 2) {
8929 S.
Diag(
Attr.
getLoc(), diag::err_attribute_wrong_number_arguments)
8934 Expr *RowsExpr =
Attr.getArgAsExpr(0);
8935 Expr *ColsExpr =
Attr.getArgAsExpr(1);
8943 Sema &S = State.getSema();
8946 S.
Diag(PA.
getLoc(), diag::err_attribute_too_few_arguments) << PA << 1;
8958 for (
unsigned Idx = 1; Idx < PA.
getNumArgs(); Idx++) {
8964 auto *AnnotateTypeAttr =
8965 AnnotateTypeAttr::Create(S.
Context, Str, Args.data(), Args.size(), PA);
8966 CurType = State.getAttributedType(AnnotateTypeAttr, CurType, CurType);
8972 if (State.getDeclarator().isDeclarationOfFunction()) {
8973 CurType = State.getAttributedType(
8978 State.getSema().Diag(
Attr.
getLoc(), diag::err_attribute_wrong_decl_type)
8985 if (State.getDeclarator().isDeclarationOfFunction()) {
8986 auto *
Attr = State.getSema().ParseLifetimeCaptureByAttr(PA,
"this");
8988 CurType = State.getAttributedType(
Attr, CurType, CurType);
9000 if (
Attr.getSemanticSpelling() == HLSLParamModifierAttr::Keyword_inout ||
9001 Attr.getSemanticSpelling() == HLSLParamModifierAttr::Keyword_out) {
9002 State.setParsedHLSLParamMod(
true);
9011 state.setParsedNoDeref(
false);
9027 if (
attr.isInvalid())
9030 if (
attr.isStandardAttributeSyntax() ||
attr.isRegularKeywordAttribute()) {
9035 if (
attr.isGNUScope()) {
9036 assert(
attr.isStandardAttributeSyntax());
9037 bool IsTypeAttr =
attr.isTypeAttr();
9039 state.getSema().Diag(
attr.getLoc(),
9041 ? diag::warn_gcc_ignores_type_attr
9042 : diag::warn_cxx11_gnu_attribute_on_type)
9048 !
attr.isTypeAttr()) {
9061 switch (
attr.getKind()) {
9064 if ((
attr.isStandardAttributeSyntax() ||
9065 attr.isRegularKeywordAttribute()) &&
9067 state.getSema().Diag(
attr.getLoc(), diag::err_attribute_not_type_attr)
9068 <<
attr <<
attr.isRegularKeywordAttribute();
9069 attr.setUsedAsTypeAttr();
9074 if (
attr.isStandardAttributeSyntax()) {
9075 state.getSema().DiagnoseUnknownAttribute(
attr);
9085 case ParsedAttr::AT_BTFTypeTag:
9087 attr.setUsedAsTypeAttr();
9090 case ParsedAttr::AT_MayAlias:
9093 attr.setUsedAsTypeAttr();
9095 case ParsedAttr::AT_OpenCLPrivateAddressSpace:
9096 case ParsedAttr::AT_OpenCLGlobalAddressSpace:
9097 case ParsedAttr::AT_OpenCLGlobalDeviceAddressSpace:
9098 case ParsedAttr::AT_OpenCLGlobalHostAddressSpace:
9099 case ParsedAttr::AT_OpenCLLocalAddressSpace:
9100 case ParsedAttr::AT_OpenCLConstantAddressSpace:
9101 case ParsedAttr::AT_OpenCLGenericAddressSpace:
9102 case ParsedAttr::AT_AddressSpace:
9104 attr.setUsedAsTypeAttr();
9106 case ParsedAttr::AT_HLSLGroupSharedAddressSpace:
9109 if (state.getSema().getLangOpts().getHLSLVersion() <
9111 state.getSema().Diag(
attr.getLoc(), diag::warn_hlsl_groupshared_202x);
9118 attr.setUsedAsTypeAttr();
9123 attr.setUsedAsTypeAttr();
9125 case ParsedAttr::AT_VectorSize:
9127 attr.setUsedAsTypeAttr();
9129 case ParsedAttr::AT_ExtVectorType:
9131 attr.setUsedAsTypeAttr();
9133 case ParsedAttr::AT_NeonVectorType:
9135 attr.setUsedAsTypeAttr();
9137 case ParsedAttr::AT_NeonPolyVectorType:
9140 attr.setUsedAsTypeAttr();
9142 case ParsedAttr::AT_ArmSveVectorBits:
9144 attr.setUsedAsTypeAttr();
9146 case ParsedAttr::AT_ArmMveStrictPolymorphism: {
9148 attr.setUsedAsTypeAttr();
9151 case ParsedAttr::AT_RISCVRVVVectorBits:
9153 attr.setUsedAsTypeAttr();
9155 case ParsedAttr::AT_OpenCLAccess:
9157 attr.setUsedAsTypeAttr();
9159 case ParsedAttr::AT_PointerAuth:
9162 attr.setUsedAsTypeAttr();
9164 case ParsedAttr::AT_LifetimeBound:
9168 case ParsedAttr::AT_LifetimeCaptureBy:
9172 case ParsedAttr::AT_OverflowBehavior:
9174 attr.setUsedAsTypeAttr();
9177 case ParsedAttr::AT_NoDeref: {
9182 if (
attr.isStandardAttributeSyntax()) {
9183 state.getSema().Diag(
attr.getLoc(), diag::warn_attribute_ignored)
9190 attr.setUsedAsTypeAttr();
9191 state.setParsedNoDeref(
true);
9195 case ParsedAttr::AT_MatrixType:
9197 attr.setUsedAsTypeAttr();
9200 case ParsedAttr::AT_WebAssemblyFuncref: {
9202 attr.setUsedAsTypeAttr();
9206 case ParsedAttr::AT_HLSLParamModifier: {
9208 if (attrs.
hasAttribute(ParsedAttr::AT_HLSLGroupSharedAddressSpace)) {
9209 state.getSema().Diag(
attr.getLoc(), diag::err_hlsl_attr_incompatible)
9210 <<
attr <<
"'groupshared'";
9214 attr.setUsedAsTypeAttr();
9218 case ParsedAttr::AT_SwiftAttr: {
9225 attr.setUsedAsTypeAttr();
9233 if (
type->canHaveNullability() ||
type->isDependentType() ||
9234 type->isArrayType() ||
9238 endIndex = state.getCurrentChunkIndex();
9240 endIndex = state.getDeclarator().getNumTypeObjects();
9241 bool allowOnArrayType =
9242 state.getDeclarator().isPrototypeContext() &&
9245 allowOnArrayType)) {
9249 attr.setUsedAsTypeAttr();
9253 case ParsedAttr::AT_ObjCKindOf:
9261 state.getSema().Diag(
attr.getLoc(),
9262 diag::err_objc_kindof_wrong_position)
9265 state.getDeclarator().getDeclSpec().getBeginLoc(),
9275 case ParsedAttr::AT_NoThrow:
9278 if (!state.getSema().getLangOpts().CPlusPlus)
9283 attr.setUsedAsTypeAttr();
9287 if (
attr.isStandardAttributeSyntax() ||
9288 attr.isRegularKeywordAttribute()) {
9305 case ParsedAttr::AT_AcquireHandle: {
9306 if (!
type->isFunctionType())
9309 if (
attr.getNumArgs() != 1) {
9310 state.getSema().Diag(
attr.getLoc(),
9311 diag::err_attribute_wrong_number_arguments)
9317 StringRef HandleType;
9318 if (!state.getSema().checkStringLiteralArgumentAttr(
attr, 0, HandleType))
9320 type = state.getAttributedType(
9321 AcquireHandleAttr::Create(state.getSema().Context, HandleType,
attr),
9323 attr.setUsedAsTypeAttr();
9326 case ParsedAttr::AT_AnnotateType: {
9328 attr.setUsedAsTypeAttr();
9331 case ParsedAttr::AT_HLSLResourceClass:
9332 case ParsedAttr::AT_HLSLROV:
9333 case ParsedAttr::AT_HLSLRawBuffer:
9334 case ParsedAttr::AT_HLSLContainedType: {
9339 state.getSema().HLSL().handleResourceTypeAttr(
type,
attr))
9340 attr.setUsedAsTypeAttr();
9348 !
type.getQualifiers().hasObjCLifetime() &&
9349 !
type.getQualifiers().hasObjCGCAttr() &&
9350 attr.getKind() != ParsedAttr::AT_ObjCGC &&
9351 attr.getKind() != ParsedAttr::AT_ObjCOwnership) {
9353 type = state.getSema().Context.getMacroQualifiedType(
type, MacroII);
9354 state.setExpansionLocForMacroQualifiedType(
9356 attr.getMacroExpansionLoc());
9363 if (
VarDecl *Var = dyn_cast<VarDecl>(DRE->getDecl())) {
9365 auto *Def = Var->getDefinition();
9371 Def = Var->getDefinition();
9378 if (Var->getPointOfInstantiation().isInvalid() && Def) {
9379 assert(Var->getTemplateSpecializationKind() ==
9381 "explicit instantiation with no point of instantiation");
9382 Var->setTemplateSpecializationKind(
9383 Var->getTemplateSpecializationKind(), PointOfInstantiation);
9403 if (
const auto CastE = dyn_cast<ExplicitCastExpr>(E)) {
9404 QualType DestType = CastE->getTypeAsWritten();
9405 if (
const auto *IAT =
Context.getAsIncompleteArrayType(DestType)) {
9410 IAT->getElementType(),
9447 if (RequireCompleteTypeImpl(Loc, T, Kind, &Diagnoser))
9449 if (
auto *TD = T->getAsTagDecl(); TD && !TD->isCompleteDefinitionRequired()) {
9450 TD->setCompleteDefinitionRequired();
9451 Consumer.HandleTagDeclRequiredDefinition(TD);
9484 auto DefinitionIsAcceptable = [&](
NamedDecl *D) {
9504 if (
auto *RD = dyn_cast<CXXRecordDecl>(D))
9505 return RD->isThisDeclarationADefinition();
9506 if (
auto *ED = dyn_cast<EnumDecl>(D))
9507 return ED->isThisDeclarationADefinition();
9508 if (
auto *FD = dyn_cast<FunctionDecl>(D))
9509 return FD->isThisDeclarationADefinition();
9510 if (
auto *VD = dyn_cast<VarDecl>(D))
9512 llvm_unreachable(
"unexpected decl type");
9514 auto FoundAcceptableDefinition = [&](
NamedDecl *D) {
9516 return DefinitionIsAcceptable(D);
9524 return DefinitionIsAcceptable(D);
9526 for (
auto *RD : D->
redecls()) {
9528 if (!IsDefinition(ND))
9530 if (DefinitionIsAcceptable(ND)) {
9539 if (
auto *RD = dyn_cast<CXXRecordDecl>(D)) {
9540 if (
auto *Pattern = RD->getTemplateInstantiationPattern())
9542 D = RD->getDefinition();
9543 }
else if (
auto *ED = dyn_cast<EnumDecl>(D)) {
9544 if (
auto *Pattern = ED->getTemplateInstantiationPattern())
9546 if (OnlyNeedComplete && (ED->isFixed() ||
getLangOpts().MSVCCompat)) {
9552 *Suggested =
nullptr;
9553 for (
auto *Redecl : ED->redecls()) {
9556 if (Redecl->isThisDeclarationADefinition() ||
9557 (Redecl->isCanonicalDecl() && !*Suggested))
9558 *Suggested = Redecl;
9563 D = ED->getDefinition();
9564 }
else if (
auto *FD = dyn_cast<FunctionDecl>(D)) {
9565 if (
auto *Pattern = FD->getTemplateInstantiationPattern())
9567 D = FD->getDefinition();
9568 }
else if (
auto *VD = dyn_cast<VarDecl>(D)) {
9569 if (
auto *Pattern = VD->getTemplateInstantiationPattern())
9571 D = VD->getDefinition();
9574 assert(D &&
"missing definition for pattern of instantiated definition");
9578 if (FoundAcceptableDefinition(D))
9583 if (
auto *Source =
Context.getExternalSource()) {
9584 Source->CompleteRedeclChain(D);
9585 return FoundAcceptableDefinition(D);
9601 bool OnlyNeedComplete) {
9618 bool OnlyNeedComplete) {
9626 if (!RD->
hasAttr<MSInheritanceAttr>()) {
9628 bool BestCase =
false;
9648 RD->
addAttr(MSInheritanceAttr::CreateImplicit(
9649 S.
getASTContext(), BestCase, Loc, MSInheritanceAttr::Spelling(IM)));
9655 CompleteTypeKind Kind,
9656 TypeDiagnoser *Diagnoser) {
9665 if (
const auto *MPTy = dyn_cast<MemberPointerType>(T.
getCanonicalType())) {
9666 if (CXXRecordDecl *RD = MPTy->getMostRecentCXXRecordDecl();
9667 RD && !RD->isDependentType()) {
9669 if (
getLangOpts().CompleteMemberPointers && !RD->isBeingDefined() &&
9675 if (
Context.getTargetInfo().getCXXABI().isMicrosoft()) {
9682 NamedDecl *Def =
nullptr;
9684 bool Incomplete = (T->isIncompleteType(&Def) ||
9694 NamedDecl *Suggested =
nullptr;
9700 if (Diagnoser && Suggested)
9703 return !TreatAsComplete;
9707 TempInst.Template = Def;
9708 TempInst.Entity = Def;
9709 TempInst.PointOfInstantiation = Loc;
9717 TagDecl *
Tag = dyn_cast_or_null<TagDecl>(Def);
9718 ObjCInterfaceDecl *IFace = dyn_cast_or_null<ObjCInterfaceDecl>(Def);
9730 if (
auto *Source =
Context.getExternalSource()) {
9731 if (Tag &&
Tag->hasExternalLexicalStorage())
9732 Source->CompleteType(Tag);
9734 Source->CompleteType(IFace);
9737 if (!T->isIncompleteType())
9738 return RequireCompleteTypeImpl(Loc, T, Kind, Diagnoser);
9745 if (
auto *RD = dyn_cast_or_null<CXXRecordDecl>(Tag)) {
9746 bool Instantiated =
false;
9747 bool Diagnosed =
false;
9748 if (RD->isDependentContext()) {
9752 }
else if (
auto *ClassTemplateSpec =
9753 dyn_cast<ClassTemplateSpecializationDecl>(RD)) {
9754 if (ClassTemplateSpec->getSpecializationKind() ==
TSK_Undeclared) {
9758 Diagnoser, ClassTemplateSpec->hasStrictPackMatch());
9760 Instantiated =
true;
9763 CXXRecordDecl *Pattern = RD->getInstantiatedFromMemberClass();
9764 if (!RD->isBeingDefined() && Pattern) {
9765 MemberSpecializationInfo *MSI = RD->getMemberSpecializationInfo();
9766 assert(MSI &&
"Missing member specialization information?");
9776 Instantiated =
true;
9784 if (Diagnoser && Diagnosed)
9789 if (!T->isIncompleteType())
9790 return RequireCompleteTypeImpl(Loc, T, Kind, Diagnoser);
9800 Diagnoser->diagnose(*
this, Loc, T);
9804 if (Tag && !
Tag->isInvalidDecl() && !
Tag->getLocation().isInvalid())
9805 Diag(
Tag->getLocation(),
Tag->isBeingDefined()
9806 ? diag::note_type_being_defined
9807 : diag::note_forward_declaration)
9808 <<
Context.getCanonicalTagType(Tag);
9841 default: llvm_unreachable(
"Invalid tag kind for literal type diagnostic!");
9847 assert(!T->isDependentType() &&
"type should not be dependent");
9856 if (T->isVariableArrayType())
9872 Diag(RD->getLocation(), diag::note_non_literal_lambda);
9880 if (RD->getNumVBases()) {
9881 Diag(RD->getLocation(), diag::note_non_literal_virtual_base)
9883 for (
const auto &I : RD->vbases())
9884 Diag(I.getBeginLoc(), diag::note_constexpr_virtual_base_here)
9885 << I.getSourceRange();
9886 }
else if (!RD->isAggregate() && !RD->hasConstexprNonCopyMoveConstructor() &&
9887 !RD->hasTrivialDefaultConstructor()) {
9888 Diag(RD->getLocation(), diag::note_non_literal_no_constexpr_ctors) << RD;
9889 }
else if (RD->hasNonLiteralTypeFieldsOrBases()) {
9890 for (
const auto &I : RD->bases()) {
9891 if (!I.getType()->isLiteralType(
Context)) {
9892 Diag(I.getBeginLoc(), diag::note_non_literal_base_class)
9893 << RD << I.getType() << I.getSourceRange();
9897 for (
const auto *I : RD->fields()) {
9898 if (!I->getType()->isLiteralType(
Context) ||
9899 I->getType().isVolatileQualified()) {
9900 Diag(I->getLocation(), diag::note_non_literal_field)
9901 << RD << I << I->getType()
9902 << I->getType().isVolatileQualified();
9907 : !RD->hasTrivialDestructor()) {
9912 assert(Dtor &&
"class has literal fields and bases but no dtor?");
9921 ? diag::note_non_literal_user_provided_dtor
9922 : diag::note_non_literal_nontrivial_dtor)
9948 if (
const TagType *TT = T->getAs<TagType>())
9951 return Context.getTypeOfExprType(E, Kind);
9972 return Context.getCountAttributedType(WrappedTy, CountExpr, CountInBytes,
9982 if (
auto *ImplCastExpr = dyn_cast<ImplicitCastExpr>(E))
9983 IDExpr = ImplCastExpr->getSubExpr();
9985 if (
auto *PackExpr = dyn_cast<PackIndexingExpr>(E)) {
9987 IDExpr = PackExpr->getPackIdExpression();
9989 IDExpr = PackExpr->getSelectedExpr();
10005 if (
const auto *SNTTPE = dyn_cast<SubstNonTypeTemplateParmExpr>(IDExpr))
10006 return SNTTPE->getParameterType(
Context);
10014 if (
const auto *DRE = dyn_cast<DeclRefExpr>(IDExpr)) {
10019 if (
const auto *ME = dyn_cast<MemberExpr>(IDExpr)) {
10020 if (
const auto *VD = ME->getMemberDecl())
10022 return VD->getType();
10023 }
else if (
const auto *IR = dyn_cast<ObjCIvarRefExpr>(IDExpr)) {
10024 return IR->getDecl()->getType();
10025 }
else if (
const auto *PR = dyn_cast<ObjCPropertyRefExpr>(IDExpr)) {
10026 if (PR->isExplicitProperty())
10027 return PR->getExplicitProperty()->getType();
10028 }
else if (
const auto *PE = dyn_cast<PredefinedExpr>(IDExpr)) {
10029 return PE->getType();
10040 if (
auto *DRE = dyn_cast<DeclRefExpr>(IDExpr->
IgnoreParens())) {
10041 if (
auto *Var = dyn_cast<VarDecl>(DRE->getDecl())) {
10044 return Context.getLValueReferenceType(T);
10049 return Context.getReferenceQualifiedType(E);
10061 Diag(E->
getExprLoc(), diag::warn_side_effects_unevaluated_context);
10074 Diag(Loc, diag::err_expected_name_of_pack) << Pattern;
10078 if (!
Type.isNull())
10080 : diag::ext_pack_indexing);
10087 bool FullySubstituted,
10098 IndexExpr = Res.
get();
10099 int64_t
V =
Value.getExtValue();
10100 if (FullySubstituted && (
V < 0 || V >= int64_t(Expansions.size()))) {
10102 <<
V << Pattern << Expansions.size();
10105 Index =
static_cast<unsigned>(
V);
10108 return Context.getPackIndexingType(Pattern, IndexExpr, FullySubstituted,
10109 Expansions, Index);
10114 assert(BaseType->isEnumeralType());
10115 EnumDecl *ED = BaseType->castAs<EnumType>()->getDecl();
10120 if (Underlying.
isNull()) {
10122 assert(!Underlying.
isNull());
10130 if (!BaseType->isEnumeralType()) {
10131 Diag(Loc, diag::err_only_enums_have_underlying_types);
10138 if (BaseType->isIncompleteType(&FwdDecl)) {
10139 Diag(Loc, diag::err_underlying_type_of_incomplete_enum) << BaseType;
10140 Diag(FwdDecl->
getLocation(), diag::note_forward_declaration) << FwdDecl;
10148 QualType Pointer = BaseType.isReferenceable() || BaseType->isVoidType()
10157 if (!BaseType->isAnyPointerType())
10166 return Context.getDecayedType(Underlying);
10175 Split.Quals.removeCVRQualifiers();
10176 return Context.getQualifiedType(Split);
10183 BaseType.isReferenceable()
10185 UKind == UnaryTransformType::AddLvalueReference,
10193 if (UKind == UnaryTransformType::RemoveAllExtents)
10194 return Context.getBaseElementType(BaseType);
10196 if (
const auto *AT =
Context.getAsArrayType(BaseType))
10197 return AT->getElementType();
10206 if (UKind == UTTKind::RemoveCVRef &&
10207 (T.isConstQualified() || T.isVolatileQualified())) {
10212 T =
Context.getQualifiedType(Unqual, Quals);
10219 if ((BaseType->isReferenceType() && UKind != UTTKind::RemoveRestrict) ||
10220 BaseType->isFunctionType())
10226 if (UKind == UTTKind::RemoveConst || UKind == UTTKind::RemoveCV)
10228 if (UKind == UTTKind::RemoveVolatile || UKind == UTTKind::RemoveCV)
10230 if (UKind == UTTKind::RemoveRestrict)
10233 return Context.getQualifiedType(Unqual, Quals);
10239 if (BaseType->isEnumeralType()) {
10241 if (
auto *
BitInt = dyn_cast<BitIntType>(Underlying)) {
10242 unsigned int Bits =
BitInt->getNumBits();
10246 S.
Diag(Loc, diag::err_make_signed_integral_only)
10247 << IsMakeSigned <<
true << BaseType << 1 << Underlying;
10251 S.
Diag(Loc, diag::err_make_signed_integral_only)
10252 << IsMakeSigned <<
false << BaseType << 1
10259 std::array<CanQualType *, 6> AllSignedIntegers = {
10263 AllSignedIntegers.data(), AllSignedIntegers.size() - Int128Unsupported);
10264 std::array<CanQualType *, 6> AllUnsignedIntegers = {
10269 AllUnsignedIntegers.size() -
10270 Int128Unsupported);
10272 IsMakeSigned ? &AvailableSignedIntegers : &AvailableUnsignedIntegers;
10276 llvm::find_if(*Consider, [&S, BaseSize](
const CanQual<Type> *T) {
10280 assert(Result != Consider->end());
10281 return QualType((*Result)->getTypePtr(), 0);
10286 bool IsMakeSigned = UKind == UnaryTransformType::MakeSigned;
10287 if ((!BaseType->isIntegerType() && !BaseType->isEnumeralType()) ||
10288 BaseType->isBooleanType() ||
10289 (BaseType->isBitIntType() &&
10291 Diag(Loc, diag::err_make_signed_integral_only)
10292 << IsMakeSigned << BaseType->isBitIntType() << BaseType << 0;
10296 bool IsNonIntIntegral =
10297 BaseType->
isChar16Type() || BaseType->isChar32Type() ||
10298 BaseType->isWideCharType() || BaseType->isEnumeralType();
10303 : IsMakeSigned ?
Context.getCorrespondingSignedType(BaseType)
10304 :
Context.getCorrespondingUnsignedType(BaseType);
10305 if (Underlying.
isNull())
10312 if (BaseType->isDependentType())
10313 return Context.getUnaryTransformType(BaseType, BaseType, UKind);
10316 case UnaryTransformType::EnumUnderlyingType: {
10320 case UnaryTransformType::AddPointer: {
10324 case UnaryTransformType::RemovePointer: {
10328 case UnaryTransformType::Decay: {
10332 case UnaryTransformType::AddLvalueReference:
10333 case UnaryTransformType::AddRvalueReference: {
10337 case UnaryTransformType::RemoveAllExtents:
10338 case UnaryTransformType::RemoveExtent: {
10342 case UnaryTransformType::RemoveCVRef:
10343 case UnaryTransformType::RemoveReference: {
10347 case UnaryTransformType::RemoveConst:
10348 case UnaryTransformType::RemoveCV:
10349 case UnaryTransformType::RemoveRestrict:
10350 case UnaryTransformType::RemoveVolatile: {
10354 case UnaryTransformType::MakeSigned:
10355 case UnaryTransformType::MakeUnsigned: {
10373 int DisallowedKind = -1;
10374 if (T->isArrayType())
10375 DisallowedKind = 1;
10376 else if (T->isFunctionType())
10377 DisallowedKind = 2;
10378 else if (T->isReferenceType())
10379 DisallowedKind = 3;
10380 else if (T->isAtomicType())
10381 DisallowedKind = 4;
10382 else if (T.hasQualifiers())
10383 DisallowedKind = 5;
10384 else if (T->isSizelessType())
10385 DisallowedKind = 6;
10388 DisallowedKind = 7;
10389 else if (T->isBitIntType())
10390 DisallowedKind = 8;
10393 DisallowedKind = 9;
10395 if (DisallowedKind != -1) {
10396 Diag(Loc, diag::err_atomic_specifier_bad_type) << DisallowedKind << T;
10404 return Context.getAtomicType(T);
Defines the clang::ASTContext interface.
This file defines the classes used to store parsed information about declaration-specifiers and decla...
Defines the C++ template declaration subclasses.
Defines the classes clang::DelayedDiagnostic and clang::AccessedEntity.
Defines the clang::LangOptions interface.
static DiagnosticBuilder Diag(DiagnosticsEngine *Diags, const LangOptions &Features, FullSourceLoc TokLoc, const char *TokBegin, const char *TokRangeBegin, const char *TokRangeEnd, unsigned DiagID)
Produce a diagnostic highlighting some portion of a literal.
*collection of selector each with an associated kind and an ordered *collection of selectors A selector has a kind
Defines the clang::Preprocessor interface.
static QualType getUnderlyingType(const SubRegion *R)
static std::string toString(const clang::SanitizerSet &Sanitizers)
Produce a string containing comma-separated names of sanitizers in Sanitizers set.
This file declares semantic analysis for CUDA constructs.
This file declares semantic analysis for HLSL constructs.
This file declares semantic analysis for Objective-C.
This file declares semantic analysis for OpenMP constructs and clauses.
static void HandleNeonVectorTypeAttr(QualType &CurType, const ParsedAttr &Attr, Sema &S, VectorKind VecKind)
HandleNeonVectorTypeAttr - The "neon_vector_type" and "neon_polyvector_type" attributes are used to c...
static QualType deduceOpenCLPointeeAddrSpace(Sema &S, QualType PointeeType)
static bool isPermittedNeonBaseType(QualType &Ty, VectorKind VecKind, Sema &S)
static void distributeObjCPointerTypeAttr(TypeProcessingState &state, ParsedAttr &attr, QualType type)
Given that an objc_gc attribute was written somewhere on a declaration other than on the declarator i...
static void maybeSynthesizeBlockSignature(TypeProcessingState &state, QualType declSpecType)
Add a synthetic '()' to a block-literal declarator if it is required, given the return type.
#define MS_TYPE_ATTRS_CASELIST
#define CALLING_CONV_ATTRS_CASELIST
static void emitNullabilityConsistencyWarning(Sema &S, SimplePointerKind PointerKind, SourceLocation PointerLoc, SourceLocation PointerEndLoc)
static void fixItNullability(Sema &S, DiagBuilderT &Diag, SourceLocation PointerLoc, NullabilityKind Nullability)
Creates a fix-it to insert a C-style nullability keyword at pointerLoc, taking into account whitespac...
static ExprResult checkArraySize(Sema &S, Expr *&ArraySize, llvm::APSInt &SizeVal, unsigned VLADiag, bool VLAIsError)
Check whether the specified array bound can be evaluated using the relevant language rules.
static Attr * createNullabilityAttr(ASTContext &Ctx, ParsedAttr &Attr, NullabilityKind NK)
static void HandleVectorSizeAttr(QualType &CurType, const ParsedAttr &Attr, Sema &S)
HandleVectorSizeAttribute - this attribute is only applicable to integral and float scalars,...
static void inferARCWriteback(TypeProcessingState &state, QualType &declSpecType)
Given that this is the declaration of a parameter under ARC, attempt to infer attributes and such for...
static TypeSourceInfo * GetTypeSourceInfoForDeclarator(TypeProcessingState &State, QualType T, TypeSourceInfo *ReturnTypeInfo)
Create and instantiate a TypeSourceInfo with type source information.
static bool BuildAddressSpaceIndex(Sema &S, LangAS &ASIdx, const Expr *AddrSpace, SourceLocation AttrLoc)
Build an AddressSpace index from a constant expression and diagnose any errors related to invalid add...
static void HandleBTFTypeTagAttribute(QualType &Type, const ParsedAttr &Attr, TypeProcessingState &State)
static void transferARCOwnershipToDeclaratorChunk(TypeProcessingState &state, Qualifiers::ObjCLifetime ownership, unsigned chunkIndex)
static bool handleObjCGCTypeAttr(TypeProcessingState &state, ParsedAttr &attr, QualType &type)
handleObjCGCTypeAttr - Process the attribute((objc_gc)) type attribute on the specified type.
static void fillAtomicQualLoc(AtomicTypeLoc ATL, const DeclaratorChunk &Chunk)
static void HandleExtVectorTypeAttr(QualType &CurType, const ParsedAttr &Attr, Sema &S)
Process the OpenCL-like ext_vector_type attribute when it occurs on a type.
static void HandleHLSLParamModifierAttr(TypeProcessingState &State, QualType &CurType, const ParsedAttr &Attr, Sema &S)
static void HandleLifetimeBoundAttr(TypeProcessingState &State, QualType &CurType, ParsedAttr &Attr)
static bool handleArmStateAttribute(Sema &S, FunctionProtoType::ExtProtoInfo &EPI, ParsedAttr &Attr, FunctionType::ArmStateValue State)
static bool handleArmAgnosticAttribute(Sema &S, FunctionProtoType::ExtProtoInfo &EPI, ParsedAttr &Attr)
static void distributeFunctionTypeAttrFromDeclSpec(TypeProcessingState &state, ParsedAttr &attr, QualType &declSpecType, CUDAFunctionTarget CFT)
A function type attribute was written in the decl spec.
static bool handleObjCPointerTypeAttr(TypeProcessingState &state, ParsedAttr &attr, QualType &type)
static QualType inferARCLifetimeForPointee(Sema &S, QualType type, SourceLocation loc, bool isReference)
Given that we're building a pointer or reference to the given.
static bool handleNonBlockingNonAllocatingTypeAttr(TypeProcessingState &TPState, ParsedAttr &PAttr, QualType &QT, FunctionTypeUnwrapper &Unwrapped)
static QualType ChangeIntegralSignedness(Sema &S, QualType BaseType, bool IsMakeSigned, SourceLocation Loc)
static bool CheckNullabilityTypeSpecifier(Sema &S, TypeProcessingState *State, ParsedAttr *PAttr, QualType &QT, NullabilityKind Nullability, SourceLocation NullabilityLoc, bool IsContextSensitive, bool AllowOnArrayType, bool OverrideExisting)
#define OBJC_POINTER_TYPE_ATTRS_CASELIST
static void diagnoseBadTypeAttribute(Sema &S, const ParsedAttr &attr, QualType type)
diagnoseBadTypeAttribute - Diagnoses a type attribute which doesn't apply to the given type.
static PointerDeclaratorKind classifyPointerDeclarator(Sema &S, QualType type, Declarator &declarator, PointerWrappingDeclaratorKind &wrappingKind)
Classify the given declarator, whose type-specified is type, based on what kind of pointer it refers ...
static bool verifyValidIntegerConstantExpr(Sema &S, const ParsedAttr &Attr, llvm::APSInt &Result)
static void HandleSwiftAttr(TypeProcessingState &State, TypeAttrLocation TAL, QualType &QT, ParsedAttr &PAttr)
static bool handleMSPointerTypeQualifierAttr(TypeProcessingState &state, ParsedAttr &attr, QualType &type)
static bool shouldHaveNullability(QualType T)
static void HandleArmMveStrictPolymorphismAttr(TypeProcessingState &State, QualType &CurType, ParsedAttr &Attr)
static void warnAboutAmbiguousFunction(Sema &S, Declarator &D, DeclaratorChunk &DeclType, QualType RT)
Produce an appropriate diagnostic for an ambiguity between a function declarator and a C++ direct-ini...
static void distributeObjCPointerTypeAttrFromDeclarator(TypeProcessingState &state, ParsedAttr &attr, QualType &declSpecType)
Distribute an objc_gc type attribute that was written on the declarator.
static FileID getNullabilityCompletenessCheckFileID(Sema &S, SourceLocation loc)
static void HandleOverflowBehaviorAttr(QualType &Type, const ParsedAttr &Attr, TypeProcessingState &State)
static void HandleArmSveVectorBitsTypeAttr(QualType &CurType, ParsedAttr &Attr, Sema &S)
HandleArmSveVectorBitsTypeAttr - The "arm_sve_vector_bits" attribute is used to create fixed-length v...
#define FUNCTION_TYPE_ATTRS_CASELIST
static void HandleLifetimeCaptureByAttr(TypeProcessingState &State, QualType &CurType, ParsedAttr &PA)
static bool distributeNullabilityTypeAttr(TypeProcessingState &state, QualType type, ParsedAttr &attr)
Distribute a nullability type attribute that cannot be applied to the type specifier to a pointer,...
static void distributeTypeAttrsFromDeclarator(TypeProcessingState &state, QualType &declSpecType, CUDAFunctionTarget CFT)
Given that there are attributes written on the declarator or declaration itself, try to distribute an...
static void fillHLSLAttributedResourceTypeLoc(HLSLAttributedResourceTypeLoc TL, TypeProcessingState &State)
static bool isDependentOrGNUAutoType(QualType T)
static void distributeFunctionTypeAttr(TypeProcessingState &state, ParsedAttr &attr, QualType type)
A function type attribute was written somewhere in a declaration other than on the declarator itself ...
static void HandleMatrixTypeAttr(QualType &CurType, const ParsedAttr &Attr, Sema &S)
HandleMatrixTypeAttr - "matrix_type" attribute, like ext_vector_type.
static bool HandleWebAssemblyFuncrefAttr(TypeProcessingState &State, QualType &QT, ParsedAttr &PAttr)
static bool hasOuterPointerLikeChunk(const Declarator &D, unsigned endIndex)
Returns true if any of the declarator chunks before endIndex include a level of indirection: array,...
static void HandleOpenCLAccessAttr(QualType &CurType, const ParsedAttr &Attr, Sema &S)
Handle OpenCL Access Qualifier Attribute.
static NullabilityKind mapNullabilityAttrKind(ParsedAttr::Kind kind)
Map a nullability attribute kind to a nullability kind.
static bool distributeFunctionTypeAttrToInnermost(TypeProcessingState &state, ParsedAttr &attr, ParsedAttributesView &attrList, QualType &declSpecType, CUDAFunctionTarget CFT)
Try to distribute a function type attribute to the innermost function chunk or type.
#define NULLABILITY_TYPE_ATTRS_CASELIST
static QualType GetDeclSpecTypeForDeclarator(TypeProcessingState &state, TypeSourceInfo *&ReturnTypeInfo)
static void checkNullabilityConsistency(Sema &S, SimplePointerKind pointerKind, SourceLocation pointerLoc, SourceLocation pointerEndLoc=SourceLocation())
Complains about missing nullability if the file containing pointerLoc has other uses of nullability (...
static void transferARCOwnership(TypeProcessingState &state, QualType &declSpecTy, Qualifiers::ObjCLifetime ownership)
Used for transferring ownership in casts resulting in l-values.
static std::string getPrintableNameForEntity(DeclarationName Entity)
static std::string getFunctionQualifiersAsString(const FunctionProtoType *FnTy)
static QualType rebuildAttributedTypeWithoutNullability(ASTContext &Ctx, QualType Type)
Rebuild an attributed type without the nullability attribute on it.
static DeclaratorChunk * maybeMovePastReturnType(Declarator &declarator, unsigned i, bool onlyBlockPointers)
Given the index of a declarator chunk, check whether that chunk directly specifies the return type of...
static OpenCLAccessAttr::Spelling getImageAccess(const ParsedAttributesView &Attrs)
static void fillMatrixTypeLoc(MatrixTypeLoc MTL, const ParsedAttributesView &Attrs)
static UnaryTransformType::UTTKind TSTToUnaryTransformType(DeclSpec::TST SwitchTST)
static void HandleRISCVRVVVectorBitsTypeAttr(QualType &CurType, ParsedAttr &Attr, Sema &S)
HandleRISCVRVVVectorBitsTypeAttr - The "riscv_rvv_vector_bits" attribute is used to create fixed-leng...
static void HandleAddressSpaceTypeAttribute(QualType &Type, const ParsedAttr &Attr, TypeProcessingState &State)
HandleAddressSpaceTypeAttribute - Process an address_space attribute on the specified type.
static bool checkQualifiedFunction(Sema &S, QualType T, SourceLocation Loc, QualifiedFunctionKind QFK)
Check whether the type T is a qualified function type, and if it is, diagnose that it cannot be conta...
static bool checkOmittedBlockReturnType(Sema &S, Declarator &declarator, QualType Result)
Return true if this is omitted block return type.
static void HandlePtrAuthQualifier(ASTContext &Ctx, QualType &T, const ParsedAttr &Attr, Sema &S)
Handle the __ptrauth qualifier.
static bool DiagnoseMultipleAddrSpaceAttributes(Sema &S, LangAS ASOld, LangAS ASNew, SourceLocation AttrLoc)
static void warnAboutRedundantParens(Sema &S, Declarator &D, QualType T)
Produce an appropriate diagnostic for a declarator with top-level parentheses.
static QualType ConvertDeclSpecToType(TypeProcessingState &state)
Convert the specified declspec to the appropriate type object.
static std::pair< QualType, TypeSourceInfo * > InventTemplateParameter(TypeProcessingState &state, QualType T, TypeSourceInfo *TrailingTSI, AutoType *Auto, InventedTemplateParameterInfo &Info)
static void distributeFunctionTypeAttrFromDeclarator(TypeProcessingState &state, ParsedAttr &attr, QualType &declSpecType, CUDAFunctionTarget CFT)
A function type attribute was written on the declarator or declaration.
static void diagnoseAndRemoveTypeQualifiers(Sema &S, const DeclSpec &DS, unsigned &TypeQuals, QualType TypeSoFar, unsigned RemoveTQs, unsigned DiagID)
static CallingConv getCCForDeclaratorChunk(Sema &S, Declarator &D, const ParsedAttributesView &AttrList, const DeclaratorChunk::FunctionTypeInfo &FTI, unsigned ChunkIndex)
Helper for figuring out the default CC for a function declarator type.
static unsigned getLiteralDiagFromTagKind(TagTypeKind Tag)
Get diagnostic select index for tag kind for literal type diagnostic message.
static void recordNullabilitySeen(Sema &S, SourceLocation loc)
Marks that a nullability feature has been used in the file containing loc.
static bool CheckBitIntElementType(Sema &S, SourceLocation AttrLoc, const BitIntType *BIT, bool ForMatrixType=false)
static void checkExtParameterInfos(Sema &S, ArrayRef< QualType > paramTypes, const FunctionProtoType::ExtProtoInfo &EPI, llvm::function_ref< SourceLocation(unsigned)> getParamLoc)
Check the extended parameter information.
static bool handleFunctionTypeAttr(TypeProcessingState &state, ParsedAttr &attr, QualType &type, CUDAFunctionTarget CFT)
Process an individual function attribute.
static void transferARCOwnershipToDeclSpec(Sema &S, QualType &declSpecTy, Qualifiers::ObjCLifetime ownership)
static void BuildTypeCoupledDecls(Expr *E, llvm::SmallVectorImpl< TypeCoupledDeclRefInfo > &Decls)
static void assignInheritanceModel(Sema &S, CXXRecordDecl *RD)
Locks in the inheritance model for the given class and all of its bases.
static bool checkObjCKindOfType(TypeProcessingState &state, QualType &type, ParsedAttr &attr)
Check the application of the Objective-C '__kindof' qualifier to the given type.
static bool hasNullabilityAttr(const ParsedAttributesView &attrs)
Check whether there is a nullability attribute of any kind in the given attribute list.
static bool handleObjCOwnershipTypeAttr(TypeProcessingState &state, ParsedAttr &attr, QualType &type)
handleObjCOwnershipTypeAttr - Process an objc_ownership attribute on the specified type.
static void moveAttrFromListToList(ParsedAttr &attr, ParsedAttributesView &fromList, ParsedAttributesView &toList)
static void HandleAnnotateTypeAttr(TypeProcessingState &State, QualType &CurType, const ParsedAttr &PA)
static void fillAttributedTypeLoc(AttributedTypeLoc TL, TypeProcessingState &State)
static void fillDependentAddressSpaceTypeLoc(DependentAddressSpaceTypeLoc DASTL, const ParsedAttributesView &Attrs)
TypeAttrLocation
The location of a type attribute.
@ TAL_DeclChunk
The attribute is part of a DeclaratorChunk.
@ TAL_DeclSpec
The attribute is in the decl-specifier-seq.
@ TAL_DeclName
The attribute is immediately after the declaration's name.
static bool isOmittedBlockReturnType(const Declarator &D)
isOmittedBlockReturnType - Return true if this declarator is missing a return type because this is a ...
static TypeSourceInfo * GetFullTypeForDeclarator(TypeProcessingState &state, QualType declSpecType, TypeSourceInfo *TInfo)
static QualType GetEnumUnderlyingType(Sema &S, QualType BaseType, SourceLocation Loc)
static bool IsNoDerefableChunk(const DeclaratorChunk &Chunk)
static AttrT * createSimpleAttr(ASTContext &Ctx, ParsedAttr &AL)
static void diagnoseRedundantReturnTypeQualifiers(Sema &S, QualType RetTy, Declarator &D, unsigned FunctionChunkIndex)
static void processTypeAttrs(TypeProcessingState &state, QualType &type, TypeAttrLocation TAL, const ParsedAttributesView &attrs, CUDAFunctionTarget CFT=CUDAFunctionTarget::HostDevice)
static bool checkMutualExclusion(TypeProcessingState &state, const FunctionProtoType::ExtProtoInfo &EPI, ParsedAttr &Attr, AttributeCommonInfo::Kind OtherKind)
static Attr * getCCTypeAttr(ASTContext &Ctx, ParsedAttr &Attr)
Defines the clang::SourceLocation class and associated facilities.
Defines various enumerations that describe declaration and type specifiers.
static QualType getPointeeType(const MemRegion *R)
Defines the clang::TypeLoc interface and its subclasses.
C Language Family Type Representation.
__DEVICE__ void * memcpy(void *__a, const void *__b, size_t __c)
__DEVICE__ int max(int __a, int __b)
virtual void AssignInheritanceModel(CXXRecordDecl *RD)
Callback invoked when an MSInheritanceAttr has been attached to a CXXRecordDecl.
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...
TranslationUnitDecl * getTranslationUnitDecl() const
const FunctionType * adjustFunctionType(const FunctionType *Fn, FunctionType::ExtInfo EInfo)
Change the ExtInfo on a function type.
QualType getAttributedType(attr::Kind attrKind, QualType modifiedType, QualType equivalentType, const Attr *attr=nullptr) const
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 getPointerType(QualType T) const
Return the uniqued reference to the type for a pointer to the specified type.
CallingConv getDefaultCallingConvention(bool IsVariadic, bool IsCXXMethod) const
Retrieves the default calling convention for the current context.
QualType getFunctionTypeWithExceptionSpec(QualType Orig, const FunctionProtoType::ExceptionSpecInfo &ESI) const
Get a function type and produce the equivalent function type with the specified exception specificati...
CanQualType UnsignedLongTy
QualType removeAddrSpaceQualType(QualType T) const
Remove any existing address space on the type and returns the type with qualifiers intact (or that's ...
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.
LangAS getDefaultOpenCLPointeeAddrSpace()
Returns default address space based on OpenCL version and enabled features.
QualType getWritePipeType(QualType T) const
Return a write_only pipe type for the specified type.
uint64_t getTypeSize(QualType T) const
Return the size of the specified (complete) type T, in bits.
CanQualType UnsignedInt128Ty
QualType getAutoType(QualType DeducedType, AutoTypeKeyword Keyword, bool IsDependent, bool IsPack=false, TemplateDecl *TypeConstraintConcept=nullptr, ArrayRef< TemplateArgument > TypeConstraintArgs={}) const
C++11 deduced auto type.
TypedefDecl * getBuiltinVaListDecl() const
Retrieve the C type declaration corresponding to the predefined __builtin_va_list type.
CanQualType UnsignedCharTy
CanQualType UnsignedIntTy
TypeSourceInfo * CreateTypeSourceInfo(QualType T, unsigned Size=0) const
Allocate an uninitialized TypeSourceInfo.
CanQualType UnsignedLongLongTy
CanQualType UnsignedShortTy
QualType getFunctionType(QualType ResultTy, ArrayRef< QualType > Args, const FunctionProtoType::ExtProtoInfo &EPI) const
Return a normal function type with a typed argument list.
bool hasDirectOwnershipQualifier(QualType Ty) const
Return true if the type has been explicitly qualified with ObjC ownership.
DiagnosticsEngine & getDiagnostics() const
QualType getSizeType() const
Return the unique type for "size_t" (C99 7.17), defined in <stddef.h>.
const TargetInfo & getTargetInfo() const
QualType getAddrSpaceQualType(QualType T, LangAS AddressSpace) const
Return the uniqued reference to the type for an address space qualified type with the specified type ...
CanQualType getCanonicalTagType(const TagDecl *TD) const
QualType getObjCGCQualType(QualType T, Qualifiers::GC gcAttr) const
Return the uniqued reference to the type for an Objective-C gc-qualified type.
QualType getPointerAuthType(QualType Ty, PointerAuthQualifier PointerAuth)
Return a type with the given __ptrauth qualifier.
uint64_t getCharWidth() const
Return the size of the character type, in bits.
QualType getBitIntType(bool Unsigned, unsigned NumBits) const
Return a bit-precise integer type with the specified signedness and bit count.
void setLBracketLoc(SourceLocation Loc)
void setRBracketLoc(SourceLocation Loc)
void setSizeExpr(Expr *Size)
TypeLoc getValueLoc() const
void setKWLoc(SourceLocation Loc)
void setParensRange(SourceRange Range)
Attr - This represents one attribute.
attr::Kind getKind() const
const char * getSpelling() const
SourceRange getRange() const
bool isContextSensitiveKeywordAttribute() const
bool isRegularKeywordAttribute() const
SourceLocation getLoc() const
const IdentifierInfo * getAttrName() const
ParsedAttr * create(IdentifierInfo *attrName, SourceRange attrRange, AttributeScopeInfo scope, ArgsUnion *args, unsigned numArgs, ParsedAttr::Form form, SourceLocation ellipsisLoc=SourceLocation())
Type source information for an attributed type.
TypeLoc getModifiedLoc() const
The modified type, which is generally canonically different from the attribute type.
void setAttr(const Attr *A)
bool hasExplicitTemplateArgs() const
const NestedNameSpecifierLoc getNestedNameSpecifierLoc() const
SourceLocation getRAngleLoc() const
SourceLocation getLAngleLoc() const
void setConceptReference(ConceptReference *CR)
NamedDecl * getFoundDecl() const
TemplateArgumentLoc getArgLoc(unsigned i) const
unsigned getNumArgs() const
TemplateDecl * getNamedConcept() const
DeclarationNameInfo getConceptNameInfo() const
void setRParenLoc(SourceLocation Loc)
TypeLoc getWrappedLoc() const
Comparison function object.
A fixed int type of a specified bitwidth.
unsigned getNumBits() const
void setCaretLoc(SourceLocation Loc)
TypeSpecifierWidth getWrittenWidthSpec() const
bool needsExtraLocalData() const
void setBuiltinLoc(SourceLocation Loc)
WrittenBuiltinSpecs & getWrittenBuiltinSpecs()
TypeSpecifierSign getWrittenSignSpec() const
void expandBuiltinRange(SourceRange Range)
This class is used for builtin types like 'int'.
Represents a C++ destructor within a class.
Represents a C++ struct/union/class.
CXXRecordDecl * getMostRecentDecl()
bool hasUserProvidedDefaultConstructor() const
Whether this class has a user-provided default constructor per C++11.
bool hasDefinition() const
MSInheritanceModel calculateInheritanceModel() const
Calculate what the inheritance model would be for this class.
bool isEmpty() const
Determine whether this is an empty class in the sense of (C++11 [meta.unary.prop]).
Represents a C++ nested-name-specifier or a global scope specifier.
bool isValid() const
A scope specifier is present, and it refers to a real scope.
SourceRange getRange() const
SourceLocation getBeginLoc() const
bool isSet() const
Deprecated.
NestedNameSpecifier getScopeRep() const
Retrieve the representation of the nested-name-specifier.
NestedNameSpecifierLoc getWithLocInContext(ASTContext &Context) const
Retrieve a nested-name-specifier with location information, copied into the given AST context.
bool isInvalid() const
An error occurred during parsing of the scope specifier.
Represents a canonical, potentially-qualified type.
SourceLocation getBegin() const
CharUnits - This is an opaque type for sizes expressed in character units.
QuantityType getQuantity() const
getQuantity - Get the raw integer representation of this quantity.
static ConceptReference * Create(const ASTContext &C, NestedNameSpecifierLoc NNS, SourceLocation TemplateKWLoc, DeclarationNameInfo ConceptNameInfo, NamedDecl *FoundDecl, TemplateDecl *NamedConcept, const ASTTemplateArgumentListInfo *ArgsAsWritten)
const TypeClass * getTypePtr() const
TypeLoc getNextTypeLoc() const
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...
DeclContext - This is used only as base class of specific decl types that can act as declaration cont...
DeclContext * getParent()
getParent - Returns the containing DeclContext.
bool hasExternalLexicalStorage() const
Whether this DeclContext has external storage containing additional declarations that are lexically i...
bool isFunctionOrMethod() const
A reference to a declared variable, function, enum, etc.
Captures information about "declaration specifiers".
const WrittenBuiltinSpecs & getWrittenBuiltinSpecs() const
bool isTypeSpecPipe() const
static const TST TST_typeof_unqualType
SourceLocation getTypeSpecSignLoc() const
bool hasAutoTypeSpec() const
static const TST TST_typename
SourceLocation getEndLoc() const LLVM_READONLY
bool hasTypeSpecifier() const
Return true if any type-specifier has been found.
static const TST TST_char8
static const TST TST_BFloat16
Expr * getPackIndexingExpr() const
TST getTypeSpecType() const
SCS getStorageClassSpec() const
SourceLocation getOverflowBehaviorLoc() const
SourceLocation getBeginLoc() const LLVM_READONLY
bool isTypeSpecSat() const
SourceRange getSourceRange() const LLVM_READONLY
static const TST TST_auto_type
static const TST TST_interface
static const TST TST_double
static const TST TST_typeofExpr
unsigned getTypeQualifiers() const
getTypeQualifiers - Return a set of TQs.
TemplateIdAnnotation * getRepAsTemplateId() const
static const TST TST_union
static const TST TST_typename_pack_indexing
static const TST TST_char
static const TST TST_bool
static const TST TST_char16
static const TST TST_unknown_anytype
TSC getTypeSpecComplex() const
ParsedType getRepAsType() const
static const TST TST_accum
static const TST TST_half
ParsedAttributes & getAttributes()
SourceLocation getEllipsisLoc() const
bool isTypeAltiVecPixel() const
void ClearTypeQualifiers()
Clear out all of the type qualifiers.
SourceLocation getConstSpecLoc() const
static const TST TST_ibm128
Expr * getRepAsExpr() const
static const TST TST_enum
AttributePool & getAttributePool() const
bool isWrapSpecified() const
static const TST TST_float128
static const TST TST_decltype
SourceRange getTypeSpecWidthRange() const
SourceLocation getTypeSpecTypeNameLoc() const
SourceLocation getTypeSpecWidthLoc() const
SourceLocation getRestrictSpecLoc() const
static const TST TST_typeof_unqualExpr
static const TST TST_class
bool isOverflowBehaviorSpecified() const
bool hasTagDefinition() const
static const TST TST_decimal64
unsigned getParsedSpecifiers() const
Return a bitmask of which flavors of specifiers this DeclSpec includes.
bool isTypeAltiVecBool() const
bool isConstrainedAuto() const
static const TST TST_wchar
SourceLocation getTypeSpecComplexLoc() const
static const TST TST_void
bool isTypeAltiVecVector() const
static const TST TST_bitint
static const char * getSpecifierName(DeclSpec::TST T, const PrintingPolicy &Policy)
Turn a type-specifier-type into a string like "_Bool" or "union".
static const TST TST_float
static const TST TST_atomic
bool isTrapSpecified() const
static const TST TST_fract
Decl * getRepAsDecl() const
static const TST TST_float16
static bool isTransformTypeTrait(TST T)
static const TST TST_unspecified
SourceLocation getAtomicSpecLoc() const
TypeSpecifierSign getTypeSpecSign() const
CXXScopeSpec & getTypeSpecScope()
SourceLocation getTypeSpecTypeLoc() const
OverflowBehaviorState getOverflowBehaviorState() const
static const TST TST_decltype_auto
static const TST TST_error
void forEachQualifier(llvm::function_ref< void(TQ, StringRef, SourceLocation)> Handle)
This method calls the passed in handler on each qual being set.
static const TST TST_decimal32
TypeSpecifierWidth getTypeSpecWidth() const
static const TST TST_char32
static const TST TST_decimal128
bool isTypeSpecOwned() const
SourceLocation getTypeSpecSatLoc() const
SourceRange getTypeofParensRange() const
SourceLocation getUnalignedSpecLoc() const
static const TST TST_int128
SourceLocation getVolatileSpecLoc() const
FriendSpecified isFriendSpecified() const
static const TST TST_typeofType
static const TST TST_auto
ConstexprSpecKind getConstexprSpecifier() const
static const TST TST_struct
Decl - This represents one declaration (or definition), e.g.
ASTContext & getASTContext() const LLVM_READONLY
Module * getOwningModule() const
Get the module that owns this declaration (for visibility purposes).
bool isInvalidDecl() const
SourceLocation getLocation() const
void setImplicit(bool I=true)
redecl_range redecls() const
Returns an iterator range for all the redeclarations of the same decl.
virtual SourceRange getSourceRange() const LLVM_READONLY
Source range that this declaration covers.
void setVisibleDespiteOwningModule()
Set that this declaration is globally visible, even if it came from a module that is not visible.
The name of a declaration.
IdentifierInfo * getAsIdentifierInfo() const
Retrieve the IdentifierInfo * stored in this declaration name, or null if this declaration name isn't...
std::string getAsString() const
Retrieve the human-readable string for this name.
NameKind getNameKind() const
Determine what kind of name this is.
Information about one declarator, including the parsed type information and the identifier.
bool isFunctionDeclarator(unsigned &idx) const
isFunctionDeclarator - This method returns true if the declarator is a function declarator (looking t...
const DeclaratorChunk & getTypeObject(unsigned i) const
Return the specified TypeInfo from this declarator.
const DeclSpec & getDeclSpec() const
getDeclSpec - Return the declaration-specifier that this declarator was declared with.
const DeclaratorChunk * getInnermostNonParenChunk() const
Return the innermost (closest to the declarator) chunk of this declarator that is not a parens chunk,...
void AddInnermostTypeInfo(const DeclaratorChunk &TI)
Add a new innermost chunk to this declarator.
bool isFunctionDeclarationContext() const
Return true if this declaration appears in a context where a function declarator would be a function ...
FunctionDefinitionKind getFunctionDefinitionKind() const
const ParsedAttributes & getAttributes() const
SourceLocation getIdentifierLoc() const
bool hasTrailingReturnType() const
Determine whether a trailing return type was written (at any level) within this declarator.
SourceLocation getEndLoc() const LLVM_READONLY
bool isExpressionContext() const
Determine whether this declaration appears in a context where an expression could appear.
type_object_range type_objects() const
Returns the range of type objects, from the identifier outwards.
void setInvalidType(bool Val=true)
unsigned getNumTypeObjects() const
Return the number of types applied to this declarator.
const ParsedAttributesView & getDeclarationAttributes() const
SourceLocation getEllipsisLoc() const
DeclaratorContext getContext() const
SourceLocation getBeginLoc() const LLVM_READONLY
UnqualifiedId & getName()
Retrieve the name specified by this declarator.
bool isFirstDeclarator() const
SourceLocation getCommaLoc() const
AttributePool & getAttributePool() const
const CXXScopeSpec & getCXXScopeSpec() const
getCXXScopeSpec - Return the C++ scope specifier (global scope or nested-name-specifier) that is part...
ParsedType getTrailingReturnType() const
Get the trailing return type appearing (at any level) within this declarator.
bool isInvalidType() const
bool isExplicitObjectMemberFunction()
SourceRange getSourceRange() const LLVM_READONLY
Get the source range that spans this declarator.
bool isFirstDeclarationOfMember()
Returns true if this declares a real member and not a friend.
bool isPrototypeContext() const
bool isStaticMember()
Returns true if this declares a static member.
DeclSpec & getMutableDeclSpec()
getMutableDeclSpec - Return a non-const version of the DeclSpec.
DeclaratorChunk::FunctionTypeInfo & getFunctionTypeInfo()
getFunctionTypeInfo - Retrieves the function type info object (looking through parentheses).
void setEllipsisLoc(SourceLocation EL)
const IdentifierInfo * getIdentifier() const
void setRParenLoc(SourceLocation Loc)
void setDecltypeLoc(SourceLocation Loc)
void setAttrNameLoc(SourceLocation loc)
void setAttrOperandParensRange(SourceRange range)
void setAttrExprOperand(Expr *e)
Represents an extended address space qualifier where the input address space value is dependent.
void copy(DependentNameTypeLoc Loc)
void setNameLoc(SourceLocation Loc)
void setNameLoc(SourceLocation Loc)
bool isIgnored(unsigned DiagID, SourceLocation Loc) const
Determine whether the diagnostic is known to be ignored.
bool getSuppressSystemWarnings() const
Wrap a function effect's condition expression in another struct so that FunctionProtoType's TrailingO...
void set(SourceLocation ElaboratedKeywordLoc, NestedNameSpecifierLoc QualifierLoc, SourceLocation NameLoc)
QualType getIntegerType() const
Return the integer type this enum decl corresponds to.
EnumDecl * getDefinition() const
This represents one expression.
bool isValueDependent() const
Determines whether the value of this expression depends on.
bool isTypeDependent() const
Determines whether the type of this expression depends on.
Expr * IgnoreParenImpCasts() LLVM_READONLY
Skip past any parentheses and implicit casts which might surround this expression until reaching a fi...
Expr * IgnoreParens() LLVM_READONLY
Skip past any parentheses which might surround this expression until reaching a fixed point.
std::optional< llvm::APSInt > getIntegerConstantExpr(const ASTContext &Ctx) const
isIntegerConstantExpr - Return the value if this expression is a valid integer constant expression.
bool HasSideEffects(const ASTContext &Ctx, bool IncludePossibleEffects=true) const
HasSideEffects - This routine returns true for all those expressions which have any effect other than...
bool isInstantiationDependent() const
Whether this expression is instantiation-dependent, meaning that it depends in some way on.
SourceLocation getExprLoc() const LLVM_READONLY
getExprLoc - Return the preferred location for the arrow when diagnosing a problem with a generic exp...
bool refersToBitField() const
Returns true if this expression is a gl-value that potentially refers to a bit-field.
bool hasPlaceholderType() const
Returns whether this expression has a placeholder type.
An opaque identifier used by SourceManager which refers to a source file (MemoryBuffer) along with it...
Annotates a diagnostic with some code that should be inserted, removed, or replaced to fix the proble...
static FixItHint CreateReplacement(CharSourceRange RemoveRange, StringRef Code)
Create a code modification hint that replaces the given source range with the given code string.
static FixItHint CreateRemoval(CharSourceRange RemoveRange)
Create a code modification hint that removes the given source range.
static FixItHint CreateInsertion(SourceLocation InsertionLoc, StringRef Code, bool BeforePreviousInsertions=false)
Create a code modification hint that inserts the given code string at a specific location.
A SourceLocation and its associated SourceManager.
unsigned getSpellingLineNumber(bool *Invalid=nullptr) const
bool isUserProvided() const
True if this method is user-declared and was not deleted or defaulted on its first declaration.
A mutable set of FunctionEffects and possibly conditions attached to them.
bool insert(const FunctionEffectWithCondition &NewEC, Conflicts &Errs)
SmallVector< Conflict > Conflicts
Represents an abstract function effect, using just an enumeration describing its kind.
Kind
Identifies the particular effect.
An immutable set of FunctionEffects and possibly conditions attached to them.
Represents a prototype with parameter type info, e.g.
Qualifiers getMethodQuals() const
bool isVariadic() const
Whether this function prototype is variadic.
ExtProtoInfo getExtProtoInfo() const
ArrayRef< QualType > getParamTypes() const
RefQualifierKind getRefQualifier() const
Retrieve the ref-qualifier associated with this function type.
unsigned getNumParams() const
void setLocalRangeBegin(SourceLocation L)
void setLParenLoc(SourceLocation Loc)
void setParam(unsigned i, ParmVarDecl *VD)
void setRParenLoc(SourceLocation Loc)
void setLocalRangeEnd(SourceLocation L)
void setExceptionSpecRange(SourceRange R)
A class which abstracts out some details necessary for making a call.
ExtInfo withCallingConv(CallingConv cc) const
CallingConv getCC() const
bool getProducesResult() const
ParameterABI getABI() const
Return the ABI treatment of this parameter.
FunctionType - C99 6.7.5.3 - Function Declarators.
ExtInfo getExtInfo() const
static StringRef getNameForCallConv(CallingConv CC)
AArch64SMETypeAttributes
The AArch64 SME ACLE (Arm C/C++ Language Extensions) define a number of function type attributes that...
@ SME_PStateSMEnabledMask
@ SME_PStateSMCompatibleMask
@ SME_AgnosticZAStateMask
static ArmStateValue getArmZT0State(unsigned AttrBits)
static ArmStateValue getArmZAState(unsigned AttrBits)
CallingConv getCallConv() const
QualType getReturnType() const
bool getHasRegParm() const
Type source information for HLSL attributed resource type.
TypeLoc getWrappedLoc() const
void setContainedTypeSourceInfo(TypeSourceInfo *TSI) const
void setSourceRange(const SourceRange &R)
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.
StringRef getName() const
Return the actual identifier string.
A simple pair of identifier info and location.
void setIdentifierInfo(IdentifierInfo *Ident)
IdentifierInfo & get(StringRef Name)
Return the identifier token info for the specified named identifier.
ElaboratedTypeKeyword getKeyword() const
void setAmpLoc(SourceLocation Loc)
An lvalue reference type, per C++11 [dcl.ref].
@ PPTMK_FullGeneralityMultipleInheritance
@ PPTMK_FullGeneralityVirtualInheritance
@ PPTMK_FullGeneralitySingleInheritance
Keeps track of the various options that can be enabled, which controls the dialect of C or C++ that i...
bool requiresStrictPrototypes() const
Returns true if functions without prototypes or functions with an identifier list (aka K&R C function...
bool isImplicitIntAllowed() const
Returns true if implicit int is supported at all.
bool allowArrayReturnTypes() const
bool isTargetDevice() const
True when compiling for an offloading target device.
bool isImplicitIntRequired() const
Returns true if implicit int is part of the language requirements.
unsigned getOpenCLCompatibleVersion() const
Return the OpenCL version that kernel language is compatible with.
Holds a QualType and a TypeSourceInfo* that came out of a declarator parsing.
void getAsStringInternal(std::string &Str, const PrintingPolicy &Policy) const
Represents the results of name lookup.
TypeLoc getInnerLoc() const
void setExpansionLoc(SourceLocation Loc)
Sugar type that represents a type that was qualified by a qualifier written as a macro invocation.
void setAttrRowOperand(Expr *e)
void setAttrColumnOperand(Expr *e)
void setAttrOperandParensRange(SourceRange range)
void setAttrNameLoc(SourceLocation loc)
static bool isValidElementType(QualType T, const LangOptions &LangOpts)
Valid elements types are the following:
void setStarLoc(SourceLocation Loc)
void setQualifierLoc(NestedNameSpecifierLoc QualifierLoc)
A pointer to member type per C++ 8.3.3 - Pointers to members.
NestedNameSpecifier getQualifier() const
CXXRecordDecl * getMostRecentCXXRecordDecl() const
Note: this can trigger extra deserialization when external AST sources are used.
QualType getPointeeType() const
TemplateSpecializationKind getTemplateSpecializationKind() const
Determine what kind of template specialization this is.
bool isHeaderLikeModule() const
Is this module have similar semantics as headers.
This represents a decl that may have a name.
bool isModulePrivate() const
Whether this declaration was marked as being private to the module in which it was defined.
Represents a C++ nested name specifier, such as "\::std::vector<int>::".
NamespaceAndPrefix getAsNamespaceAndPrefix() const
const Type * getAsType() const
@ Global
The global specifier '::'. There is no stored value.
@ Type
A type, stored as a Type*.
@ Namespace
A namespace-like entity, stored as a NamespaceBaseDecl*.
Represents an ObjC class declaration.
void setNameLoc(SourceLocation Loc)
void setNameEndLoc(SourceLocation Loc)
Represents typeof(type), a C23 feature and GCC extension, or `typeof_unqual(type),...
Wraps an ObjCPointerType with source location information.
void setStarLoc(SourceLocation Loc)
Represents a pointer to an Objective C object.
const ObjCObjectType * getObjectType() const
Gets the type pointed to by this ObjC pointer.
static OpaquePtr make(QualType P)
OpenCL supported extensions and optional core features.
bool isAvailableOption(llvm::StringRef Ext, const LangOptions &LO) const
bool isSupported(llvm::StringRef Ext, const LangOptions &LO) const
TypeLoc getWrappedLoc() const
void setEllipsisLoc(SourceLocation Loc)
A parameter attribute which changes the argument-passing ABI rule for the parameter.
void setRParenLoc(SourceLocation Loc)
void setLParenLoc(SourceLocation Loc)
Represents a parameter to a function.
ParsedAttr - Represents a syntactic attribute.
void setInvalid(bool b=true) const
unsigned getNumArgs() const
getNumArgs - Return the number of actual arguments to this attribute.
bool isArgIdent(unsigned Arg) const
Expr * getArgAsExpr(unsigned Arg) const
AttributeCommonInfo::Kind getKind() const
void setUsedAsTypeAttr(bool Used=true)
bool checkAtMostNumArgs(class Sema &S, unsigned Num) const
Check if the attribute has at most as many args as Num.
bool hasMSPropertyAttr() const
void addAtEnd(ParsedAttr *newAttr)
bool hasAttribute(ParsedAttr::Kind K) const
void remove(ParsedAttr *ToBeRemoved)
void takeOneFrom(ParsedAttributes &Other, ParsedAttr *PA)
TypeLoc getValueLoc() const
void setKWLoc(SourceLocation Loc)
Pointer-authentication qualifiers.
static PointerAuthQualifier Create(unsigned Key, bool IsAddressDiscriminated, unsigned ExtraDiscriminator, PointerAuthenticationMode AuthenticationMode, bool IsIsaPointer, bool AuthenticatesNullValues)
@ MaxKey
The maximum supported pointer-authentication key.
void setStarLoc(SourceLocation Loc)
PointerType - C99 6.7.5.1 - Pointer Declarators.
SourceLocation getPragmaAssumeNonNullLoc() const
The location of the currently-active #pragma clang assume_nonnull begin.
A (possibly-)qualified type.
bool isVolatileQualified() const
Determine whether this type is volatile-qualified.
bool hasQualifiers() const
Determine whether this type has any qualifiers.
PointerAuthQualifier getPointerAuth() const
QualType getDesugaredType(const ASTContext &Context) const
Return the specified type with any "sugar" removed from the type.
bool isNull() const
Return true if this QualType doesn't point to a type yet.
const Type * getTypePtr() const
Retrieves a pointer to the underlying (unqualified) type.
Qualifiers getQualifiers() const
Retrieve the set of qualifiers applied to this type.
Qualifiers::ObjCLifetime getObjCLifetime() const
Returns lifetime attribute of this type.
QualType getNonReferenceType() const
If Type is a reference type (e.g., const int&), returns the type that the reference refers to ("const...
QualType getCanonicalType() const
unsigned getLocalCVRQualifiers() const
Retrieve the set of CVR (const-volatile-restrict) qualifiers local to this particular QualType instan...
SplitQualType split() const
Divides a QualType into its unqualified type and a set of local qualifiers.
SplitQualType getSplitUnqualifiedType() const
Retrieve the unqualified variant of the given type, removing as little sugar as possible.
bool hasAddressSpace() const
Check if this type has any address space qualifier.
unsigned getCVRQualifiers() const
Retrieve the set of CVR (const-volatile-restrict) qualifiers applied to this type.
UnqualTypeLoc getUnqualifiedLoc() const
The collection of all-type qualifiers we support.
void removeCVRQualifiers(unsigned mask)
void addAddressSpace(LangAS space)
@ 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.
void removeObjCLifetime()
void addCVRUQualifiers(unsigned mask)
static Qualifiers fromCVRMask(unsigned CVR)
void setUnaligned(bool flag)
std::string getAsString() const
@ MaxAddressSpace
The maximum supported address space number.
void addObjCLifetime(ObjCLifetime type)
void setAmpAmpLoc(SourceLocation Loc)
QualType getPointeeType() const
bool isSpelledAsLValue() const
bool isFunctionDeclarationScope() const
isFunctionDeclarationScope - Return true if this scope is a function prototype scope.
A generic diagnostic builder for errors which may or may not be deferred.
SemaDiagnosticBuilder Diag(SourceLocation Loc, unsigned DiagID)
Emit a diagnostic.
CUDAFunctionTarget IdentifyTarget(const FunctionDecl *D, bool IgnoreImplicitHDAttr=false)
Determines whether the given function is a CUDA device/host/kernel/etc.
QualType ProcessResourceTypeAttributes(QualType Wrapped)
QualType getInoutParameterType(QualType Ty)
bool isCFError(RecordDecl *D)
IdentifierInfo * getNSErrorIdent()
Retrieve the identifier "NSError".
bool checkNSReturnsRetainedReturnType(SourceLocation loc, QualType type)
bool shouldDelayDiagnostics()
Determines whether diagnostics should be delayed.
void add(const sema::DelayedDiagnostic &diag)
Adds a delayed diagnostic.
Abstract base class used for diagnosing integer constant expression violations.
Sema - This implements semantic analysis and AST building for C.
bool hasReachableDefinition(NamedDecl *D, NamedDecl **Suggested, bool OnlyNeedComplete=false)
Determine if D has a reachable definition.
QualType BuildParenType(QualType T)
Build a paren type including T.
ParsedType CreateParsedType(QualType T, TypeSourceInfo *TInfo)
Package the given type and TSI into a ParsedType.
bool ConstantFoldAttrArgs(const AttributeCommonInfo &CI, MutableArrayRef< Expr * > Args)
ConstantFoldAttrArgs - Folds attribute arguments into ConstantExprs (unless they are value dependent ...
SmallVector< CodeSynthesisContext, 16 > CodeSynthesisContexts
List of active code synthesis contexts.
Scope * getCurScope() const
Retrieve the parser's current scope.
bool hasStructuralCompatLayout(Decl *D, Decl *Suggested)
Determine if D and Suggested have a structurally compatible layout as described in C11 6....
bool checkArrayElementAlignment(QualType EltTy, SourceLocation Loc)
bool RequireCompleteSizedType(SourceLocation Loc, QualType T, unsigned DiagID, const Ts &...Args)
@ LookupOrdinaryName
Ordinary name lookup, which finds ordinary names (functions, variables, typedefs, etc....
UnaryTransformType::UTTKind UTTKind
QualType BuildAddressSpaceAttr(QualType &T, LangAS ASIdx, Expr *AddrSpace, SourceLocation AttrLoc)
BuildAddressSpaceAttr - Builds a DependentAddressSpaceType if an expression is uninstantiated.
bool checkPointerAuthDiscriminatorArg(Expr *Arg, PointerAuthDiscArgKind Kind, unsigned &IntVal)
QualType BuildVectorType(QualType T, Expr *VecSize, SourceLocation AttrLoc)
std::optional< FunctionEffectMode > ActOnEffectExpression(Expr *CondExpr, StringRef AttributeName)
Try to parse the conditional expression attached to an effect attribute (e.g.
@ AcceptSizeless
Relax the normal rules for complete types so that they include sizeless built-in types.
class clang::Sema::DelayedDiagnostics DelayedDiagnostics
QualType BuildExtVectorType(QualType T, Expr *ArraySize, SourceLocation AttrLoc)
Build an ext-vector type.
bool CheckVarDeclSizeAddressSpace(const VarDecl *VD, LangAS AS)
Check whether the given variable declaration has a size that fits within the address space it is decl...
const AttributedType * getCallingConvAttributedType(QualType T) const
Get the outermost AttributedType node that sets a calling convention.
bool hasMergedDefinitionInCurrentModule(const NamedDecl *Def)
bool InstantiateClassTemplateSpecialization(SourceLocation PointOfInstantiation, ClassTemplateSpecializationDecl *ClassTemplateSpec, TemplateSpecializationKind TSK, bool Complain, bool PrimaryStrictPackMatch)
bool DiagnoseUseOfDecl(NamedDecl *D, ArrayRef< SourceLocation > Locs, const ObjCInterfaceDecl *UnknownObjCClass=nullptr, bool ObjCPropertyAccess=false, bool AvoidPartialAvailabilityChecks=false, ObjCInterfaceDecl *ClassReceiver=nullptr, bool SkipTrailingRequiresClause=false)
Determine whether the use of this declaration is valid, and emit any corresponding diagnostics.
QualType BuildFunctionType(QualType T, MutableArrayRef< QualType > ParamTypes, SourceLocation Loc, DeclarationName Entity, const FunctionProtoType::ExtProtoInfo &EPI)
Build a function type.
bool SpecialMemberIsTrivial(CXXMethodDecl *MD, CXXSpecialMemberKind CSM, TrivialABIHandling TAH=TrivialABIHandling::IgnoreTrivialABI, bool Diagnose=false)
Determine whether a defaulted or deleted special member function is trivial, as specified in C++11 [c...
void checkSpecializationReachability(SourceLocation Loc, NamedDecl *Spec)
ASTContext & getASTContext() const
void translateTemplateArguments(const ASTTemplateArgsPtr &In, TemplateArgumentListInfo &Out)
Translates template arguments as provided by the parser into template arguments used by semantic anal...
void checkExceptionSpecification(bool IsTopLevel, ExceptionSpecificationType EST, ArrayRef< ParsedType > DynamicExceptions, ArrayRef< SourceRange > DynamicExceptionRanges, Expr *NoexceptExpr, SmallVectorImpl< QualType > &Exceptions, FunctionProtoType::ExceptionSpecInfo &ESI)
Check the given exception-specification and update the exception specification information with the r...
void InstantiateVariableDefinition(SourceLocation PointOfInstantiation, VarDecl *Var, bool Recursive=false, bool DefinitionRequired=false, bool AtEndOfTU=false)
Instantiate the definition of the given variable from its template.
bool CheckCallingConvAttr(const ParsedAttr &attr, CallingConv &CC, const FunctionDecl *FD=nullptr, CUDAFunctionTarget CFT=CUDAFunctionTarget::InvalidTarget)
Check validaty of calling convention attribute attr.
bool RequireLiteralType(SourceLocation Loc, QualType T, TypeDiagnoser &Diagnoser)
Ensure that the type T is a literal type.
QualType BuildCountAttributedArrayOrPointerType(QualType WrappedTy, Expr *CountExpr, bool CountInBytes, bool OrNull)
std::string getFixItZeroInitializerForType(QualType T, SourceLocation Loc) const
Get a string to suggest for zero-initialization of a type.
bool CheckAttrNoArgs(const ParsedAttr &CurrAttr)
ExprResult CheckConvertedConstantExpression(Expr *From, QualType T, llvm::APSInt &Value, CCEKind CCE)
QualType BuildBitIntType(bool IsUnsigned, Expr *BitWidth, SourceLocation Loc)
Build a bit-precise integer type.
LangAS getDefaultCXXMethodAddrSpace() const
Returns default addr space for method qualifiers.
QualType BuiltinRemoveReference(QualType BaseType, UTTKind UKind, SourceLocation Loc)
QualType BuildQualifiedType(QualType T, SourceLocation Loc, Qualifiers Qs, const DeclSpec *DS=nullptr)
bool CheckFunctionReturnType(QualType T, SourceLocation Loc)
SourceLocation getLocForEndOfToken(SourceLocation Loc, unsigned Offset=0)
Calls Lexer::getLocForEndOfToken()
@ UPPC_TypeConstraint
A type constraint.
const LangOptions & getLangOpts() const
bool RequireCompleteExprType(Expr *E, CompleteTypeKind Kind, TypeDiagnoser &Diagnoser)
Ensure that the type of the given expression is complete.
void NoteTemplateLocation(const NamedDecl &Decl, std::optional< SourceRange > ParamRange={})
QualType BuiltinEnumUnderlyingType(QualType BaseType, SourceLocation Loc)
bool DiagnoseUnexpandedParameterPack(SourceLocation Loc, TypeSourceInfo *T, UnexpandedParameterPackContext UPPC)
If the given type contains an unexpanded parameter pack, diagnose the error.
bool RequireNonAbstractType(SourceLocation Loc, QualType T, TypeDiagnoser &Diagnoser)
void CheckExtraCXXDefaultArguments(Declarator &D)
CheckExtraCXXDefaultArguments - Check for any extra default arguments in the declarator,...
const LangOptions & LangOpts
sema::LambdaScopeInfo * getCurLambda(bool IgnoreNonLambdaCapturingScope=false)
Retrieve the current lambda scope info, if any.
IdentifierInfo * InventAbbreviatedTemplateParameterTypeName(const IdentifierInfo *ParamName, unsigned Index)
Invent a new identifier for parameters of abbreviated templates.
bool checkConstantPointerAuthKey(Expr *keyExpr, unsigned &key)
SourceLocation ImplicitMSInheritanceAttrLoc
Source location for newly created implicit MSInheritanceAttrs.
SmallVector< InventedTemplateParameterInfo, 4 > InventedParameterInfos
Stack containing information needed when in C++2a an 'auto' is encountered in a function declaration ...
std::vector< std::unique_ptr< TemplateInstantiationCallback > > TemplateInstCallbacks
The template instantiation callbacks to trace or track instantiations (objects can be chained).
void completeExprArrayBound(Expr *E)
bool hasExplicitCallingConv(QualType T)
bool CheckRegparmAttr(const ParsedAttr &attr, unsigned &value)
Checks a regparm attribute, returning true if it is ill-formed and otherwise setting numParams to the...
FileNullabilityMap NullabilityMap
A mapping that describes the nullability we've seen in each header file.
sema::FunctionScopeInfo * getCurFunction() const
QualType BuildReferenceType(QualType T, bool LValueRef, SourceLocation Loc, DeclarationName Entity)
Build a reference type.
bool findMacroSpelling(SourceLocation &loc, StringRef name)
Looks through the macro-expansion chain for the given location, looking for a macro expansion with th...
QualType BuildMemberPointerType(QualType T, const CXXScopeSpec &SS, CXXRecordDecl *Cls, SourceLocation Loc, DeclarationName Entity)
Build a member pointer type T Class::*.
ExprResult DefaultLvalueConversion(Expr *E)
DeclContext * CurContext
CurContext - This is the current declaration context of parsing.
MultiLevelTemplateArgumentList getTemplateInstantiationArgs(const NamedDecl *D, const DeclContext *DC=nullptr, bool Final=false, std::optional< ArrayRef< TemplateArgument > > Innermost=std::nullopt, bool RelativeToPrimary=false, const FunctionDecl *Pattern=nullptr, bool ForConstraintInstantiation=false, bool SkipForSpecialization=false, bool ForDefaultArgumentSubstitution=false)
Retrieve the template argument list(s) that should be used to instantiate the definition of the given...
QualType BuiltinDecay(QualType BaseType, SourceLocation Loc)
IdentifierInfo * getNullabilityKeyword(NullabilityKind nullability)
Retrieve the keyword associated.
bool isUnevaluatedContext() const
Determines whether we are currently in a context that is not evaluated as per C++ [expr] p5.
TemplateNameKindForDiagnostics getTemplateNameKindForDiagnostics(TemplateName Name)
bool isAcceptable(const NamedDecl *D, AcceptableKind Kind)
Determine whether a declaration is acceptable (visible/reachable).
QualType getDecltypeForExpr(Expr *E)
getDecltypeForExpr - Given an expr, will return the decltype for that expression, according to the ru...
ExprResult CheckPlaceholderExpr(Expr *E)
Check for operands with placeholder types and complain if found.
bool hasVisibleDefinition(NamedDecl *D, NamedDecl **Suggested, bool OnlyNeedComplete=false)
Determine if D has a visible definition.
bool inTemplateInstantiation() const
Determine whether we are currently performing template instantiation.
SourceManager & getSourceManager() const
QualType BuiltinAddReference(QualType BaseType, UTTKind UKind, SourceLocation Loc)
bool hasVisibleMergedDefinition(const NamedDecl *Def)
QualType BuildPackIndexingType(QualType Pattern, Expr *IndexExpr, SourceLocation Loc, SourceLocation EllipsisLoc, bool FullySubstituted=false, ArrayRef< QualType > Expansions={})
DeclContext * computeDeclContext(QualType T)
Compute the DeclContext that is associated with the given type.
QualType BuildAtomicType(QualType T, SourceLocation Loc)
void diagnoseMissingImport(SourceLocation Loc, const NamedDecl *Decl, MissingImportKind MIK, bool Recover=true)
Diagnose that the specified declaration needs to be visible but isn't, and suggest a module import th...
bool AttachTypeConstraint(NestedNameSpecifierLoc NS, DeclarationNameInfo NameInfo, TemplateDecl *NamedConcept, NamedDecl *FoundDecl, const TemplateArgumentListInfo *TemplateArgs, TemplateTypeParmDecl *ConstrainedParameter, SourceLocation EllipsisLoc)
Attach a type-constraint to a template parameter.
bool diagnoseConflictingFunctionEffect(const FunctionEffectsRef &FX, const FunctionEffectWithCondition &EC, SourceLocation NewAttrLoc)
Warn and return true if adding a function effect to a set would create a conflict.
TypeSourceInfo * ReplaceAutoTypeSourceInfo(TypeSourceInfo *TypeWithAuto, QualType Replacement)
TypeResult ActOnTypeName(Declarator &D)
bool isSFINAEContext() const
bool isCompleteType(SourceLocation Loc, QualType T, CompleteTypeKind Kind=CompleteTypeKind::Default)
bool InstantiateClass(SourceLocation PointOfInstantiation, CXXRecordDecl *Instantiation, CXXRecordDecl *Pattern, const MultiLevelTemplateArgumentList &TemplateArgs, TemplateSpecializationKind TSK, bool Complain=true)
Instantiate the definition of a class from a given pattern.
void checkUnusedDeclAttributes(Declarator &D)
checkUnusedDeclAttributes - Given a declarator which is not being used to build a declaration,...
QualType BuildPointerType(QualType T, SourceLocation Loc, DeclarationName Entity)
Build a pointer type.
bool CheckAttrTarget(const ParsedAttr &CurrAttr)
QualType BuiltinAddPointer(QualType BaseType, SourceLocation Loc)
ExprResult VerifyIntegerConstantExpression(Expr *E, llvm::APSInt *Result, VerifyICEDiagnoser &Diagnoser, AllowFoldKind CanFold=AllowFoldKind::No)
VerifyIntegerConstantExpression - Verifies that an expression is an ICE, and reports the appropriate ...
IntrusiveRefCntPtr< ExternalSemaSource > ExternalSource
Source of additional semantic information.
bool CheckImplicitNullabilityTypeSpecifier(QualType &Type, NullabilityKind Nullability, SourceLocation DiagLoc, bool AllowArrayTypes, bool OverrideExisting)
Check whether a nullability type specifier can be added to the given type through some means not writ...
void CheckConstrainedAuto(const AutoType *AutoT, SourceLocation Loc)
bool CheckDistantExceptionSpec(QualType T)
CheckDistantExceptionSpec - Check if the given type is a pointer or pointer to member to a function w...
QualType BuildDecltypeType(Expr *E, bool AsUnevaluated=true)
If AsUnevaluated is false, E is treated as though it were an evaluated context, such as when building...
QualType BuildUnaryTransformType(QualType BaseType, UTTKind UKind, SourceLocation Loc)
TypeSourceInfo * GetTypeForDeclarator(Declarator &D)
GetTypeForDeclarator - Convert the type for the specified declarator to Type instances.
TypeSourceInfo * GetTypeForDeclaratorCast(Declarator &D, QualType FromTy)
bool RequireCompleteType(SourceLocation Loc, QualType T, CompleteTypeKind Kind, TypeDiagnoser &Diagnoser)
Ensure that the type T is a complete type.
QualType getCapturedDeclRefType(ValueDecl *Var, SourceLocation Loc)
Given a variable, determine the type that a reference to that variable will have in the given scope.
QualType BuiltinRemoveExtent(QualType BaseType, UTTKind UKind, SourceLocation Loc)
QualType getCompletedType(Expr *E)
Get the type of expression E, triggering instantiation to complete the type if necessary – that is,...
QualType BuiltinChangeCVRQualifiers(QualType BaseType, UTTKind UKind, SourceLocation Loc)
bool isDependentScopeSpecifier(const CXXScopeSpec &SS)
SourceManager & SourceMgr
DiagnosticsEngine & Diags
OpenCLOptions & getOpenCLOptions()
QualType BuiltinRemovePointer(QualType BaseType, SourceLocation Loc)
QualType BuildArrayType(QualType T, ArraySizeModifier ASM, Expr *ArraySize, unsigned Quals, SourceRange Brackets, DeclarationName Entity)
Build an array type.
bool CheckQualifiedFunctionForTypeId(QualType T, SourceLocation Loc)
QualType BuildReadPipeType(QualType T, SourceLocation Loc)
Build a Read-only Pipe type.
void diagnoseIgnoredQualifiers(unsigned DiagID, unsigned Quals, SourceLocation FallbackLoc, SourceLocation ConstQualLoc=SourceLocation(), SourceLocation VolatileQualLoc=SourceLocation(), SourceLocation RestrictQualLoc=SourceLocation(), SourceLocation AtomicQualLoc=SourceLocation(), SourceLocation UnalignedQualLoc=SourceLocation())
LangOptions::PragmaMSPointersToMembersKind MSPointerToMemberRepresentationMethod
Controls member pointer representation format under the MS ABI.
llvm::BumpPtrAllocator BumpAlloc
QualType BuildWritePipeType(QualType T, SourceLocation Loc)
Build a Write-only Pipe type.
QualType ActOnPackIndexingType(QualType Pattern, Expr *IndexExpr, SourceLocation Loc, SourceLocation EllipsisLoc)
QualType BuildTypeofExprType(Expr *E, TypeOfKind Kind)
void runWithSufficientStackSpace(SourceLocation Loc, llvm::function_ref< void()> Fn)
Run some code with "sufficient" stack space.
QualType BuildMatrixType(QualType T, Expr *NumRows, Expr *NumColumns, SourceLocation AttrLoc)
SemaDiagnosticBuilder targetDiag(SourceLocation Loc, unsigned DiagID, const FunctionDecl *FD=nullptr)
bool hasAcceptableDefinition(NamedDecl *D, NamedDecl **Suggested, AcceptableKind Kind, bool OnlyNeedComplete=false)
QualType BuiltinChangeSignedness(QualType BaseType, UTTKind UKind, SourceLocation Loc)
void adjustMemberFunctionCC(QualType &T, bool HasThisPointer, bool IsCtorOrDtor, SourceLocation Loc)
Adjust the calling convention of a method to be the ABI default if it wasn't specified explicitly.
bool LookupName(LookupResult &R, Scope *S, bool AllowBuiltinCreation=false, bool ForceNoCPlusPlus=false)
Perform unqualified name lookup starting from a given scope.
static QualType GetTypeFromParser(ParsedType Ty, TypeSourceInfo **TInfo=nullptr)
void checkNonTrivialCUnion(QualType QT, SourceLocation Loc, NonTrivialCUnionContext UseContext, unsigned NonTrivialKind)
Emit diagnostics if a non-trivial C union type or a struct that contains a non-trivial C union is use...
bool checkStringLiteralArgumentAttr(const AttributeCommonInfo &CI, const Expr *E, StringRef &Str, SourceLocation *ArgLocation=nullptr)
Check if the argument E is a ASCII string literal.
QualType BuildBlockPointerType(QualType T, SourceLocation Loc, DeclarationName Entity)
Build a block pointer type.
Encodes a location in the source.
bool isValid() const
Return true if this is a valid SourceLocation object.
FileID getFileID(SourceLocation SpellingLoc) const
Return the FileID for a SourceLocation.
const char * getCharacterData(SourceLocation SL, bool *Invalid=nullptr) const
Return a pointer to the start of the specified location in the appropriate spelling MemoryBuffer.
CharSourceRange getImmediateExpansionRange(SourceLocation Loc) const
Return the start/end of the expansion information for an expansion location.
SourceLocation getExpansionLoc(SourceLocation Loc) const
Given a SourceLocation object Loc, return the expansion location referenced by the ID.
const SrcMgr::SLocEntry & getSLocEntry(FileID FID, bool *Invalid=nullptr) const
A trivial tuple used to represent a source range.
SourceLocation getEnd() const
SourceLocation getBegin() const
Information about a FileID, basically just the logical file that it represents and include stack info...
CharacteristicKind getFileCharacteristic() const
Return whether this is a system header or not.
SourceLocation getIncludeLoc() const
This is a discriminated union of FileInfo and ExpansionInfo.
const FileInfo & getFile() const
SourceRange getSourceRange() const LLVM_READONLY
SourceLocation tokens are not useful in isolation - they are low level value objects created/interpre...
SourceLocation getBeginLoc() const LLVM_READONLY
Represents the declaration of a struct/union/class/enum.
void setEmbeddedInDeclarator(bool isInDeclarator)
True if this tag declaration is "embedded" (i.e., defined or declared for the very first time) in the...
bool isCompleteDefinition() const
Return true if this decl has its body fully specified.
SourceRange getSourceRange() const override LLVM_READONLY
Source range that this declaration covers.
void setQualifierLoc(NestedNameSpecifierLoc QualifierLoc)
void setNameLoc(SourceLocation Loc)
void setElaboratedKeywordLoc(SourceLocation Loc)
Exposes information about the current target.
virtual bool hasBitIntType() const
Determine whether the _BitInt type is supported on this target.
const llvm::Triple & getTriple() const
Returns the target triple of the primary target.
virtual size_t getMaxBitIntWidth() const
virtual std::optional< std::pair< unsigned, unsigned > > getVScaleRange(const LangOptions &LangOpts, ArmStreamingKind Mode, llvm::StringMap< bool > *FeatureMap=nullptr) const
Returns target-specific min and max values VScale_Range.
uint64_t getPointerWidth(LangAS AddrSpace) const
Return the width of pointers on this target, for the specified address space.
virtual bool allowHalfArgsAndReturns() const
Whether half args and returns are supported.
virtual bool hasInt128Type() const
Determine whether the __int128 type is supported on this target.
virtual bool hasFloat16Type() const
Determine whether the _Float16 type is supported on this target.
virtual bool hasIbm128Type() const
Determine whether the __ibm128 type is supported on this target.
virtual bool hasFloat128Type() const
Determine whether the __float128 type is supported on this target.
virtual bool hasBFloat16Type() const
Determine whether the _BFloat16 type is supported on this target.
virtual bool hasFeature(StringRef Feature) const
Determine whether the given target has the given feature.
A convenient class for passing around template argument information.
void setLAngleLoc(SourceLocation Loc)
void setRAngleLoc(SourceLocation Loc)
void addArgument(const TemplateArgumentLoc &Loc)
ArrayRef< TemplateArgumentLoc > arguments() const
Location wrapper for a TemplateArgument.
The base class of all kinds of template declarations (e.g., class, function, etc.).
Represents a C++ template name within the type system.
TemplateDecl * getAsTemplateDecl(bool IgnoreDeduced=false) const
Retrieve the underlying template declaration that this template name refers to, if known.
UsingShadowDecl * getAsUsingShadowDecl() const
Retrieve the using shadow declaration through which the underlying template declaration is introduced...
SourceLocation getRAngleLoc() const
void copy(TemplateSpecializationTypeLoc Loc)
Declaration of a template type parameter.
static TemplateTypeParmDecl * Create(const ASTContext &C, DeclContext *DC, SourceLocation KeyLoc, SourceLocation NameLoc, unsigned D, unsigned P, IdentifierInfo *Id, bool Typename, bool ParameterPack, bool HasTypeConstraint=false, UnsignedOrNone NumExpanded=std::nullopt)
[BoundsSafety] Represents information of declarations referenced by the arguments of the counted_by a...
const Type * getTypeForDecl() const
TyLocType push(QualType T)
Pushes space for a new TypeLoc of the given type.
void pushFullCopy(TypeLoc L)
Pushes a copy of the given TypeLoc onto this builder.
TypeSourceInfo * getTypeSourceInfo(ASTContext &Context, QualType T)
Creates a TypeSourceInfo for the given type.
Base wrapper for a particular "section" of type source info.
UnqualTypeLoc getUnqualifiedLoc() const
Skips past any qualifiers, if this is qualified.
TypeLoc getNextTypeLoc() const
Get the next TypeLoc pointed by this TypeLoc, e.g for "int*" the TypeLoc is a PointerLoc and next Typ...
T getAs() const
Convert to the specified TypeLoc type, returning a null TypeLoc if this TypeLoc is not of the desired...
T castAs() const
Convert to the specified TypeLoc type, asserting that this TypeLoc is of the desired type.
void initializeFullCopy(TypeLoc Other)
Initializes this by copying its information from another TypeLoc of the same type.
unsigned getFullDataSize() const
Returns the size of the type source info data block.
AutoTypeLoc getContainedAutoTypeLoc() const
Get the typeloc of an AutoType whose type will be deduced for a variable with an initializer of this ...
void * getOpaqueData() const
Get the pointer where source information is stored.
void copy(TypeLoc other)
Copies the other type loc into this one.
void initialize(ASTContext &Context, SourceLocation Loc) const
Initializes this to state that every location in this type is the given location.
SourceLocation getEndLoc() const
Get the end source location.
SourceLocation getBeginLoc() const
Get the begin source location.
void setUnmodifiedTInfo(TypeSourceInfo *TI) const
A container of type source information.
TypeLoc getTypeLoc() const
Return the TypeLoc wrapper for the type source info.
QualType getType() const
Return the type wrapped by this type source info.
void setNameLoc(SourceLocation Loc)
The base class of the type hierarchy.
bool isIncompleteOrObjectType() const
Return true if this is an incomplete or object type, in other words, not a function type.
bool isBlockPointerType() const
bool isBooleanType() const
QualType getRVVEltType(const ASTContext &Ctx) const
Returns the representative type for the element of an RVV builtin type.
bool isIncompleteArrayType() const
bool isIntegralOrUnscopedEnumerationType() const
Determine whether this type is an integral or unscoped enumeration type.
bool isUndeducedAutoType() const
CXXRecordDecl * getAsCXXRecordDecl() const
Retrieves the CXXRecordDecl that this type refers to, either because the type is a RecordType or beca...
CXXRecordDecl * castAsCXXRecordDecl() const
bool isPointerType() const
bool isIntegerType() const
isIntegerType() does not include complex integers (a GCC extension).
const T * castAs() const
Member-template castAs<specific type>.
bool isReferenceType() const
NestedNameSpecifier getPrefix() const
If this type represents a qualified-id, this returns its nested name specifier.
bool isSveVLSBuiltinType() const
Determines if this is a sizeless type supported by the 'arm_sve_vector_bits' type attribute,...
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.
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 isBitIntType() const
bool isBuiltinType() const
Helper methods to distinguish type categories.
bool isDependentType() const
Whether this type is a dependent type, meaning that its definition somehow depends on a template para...
bool isChar16Type() const
bool containsUnexpandedParameterPack() const
Whether this type is or contains an unexpanded parameter pack, used to support C++0x variadic templat...
bool isWebAssemblyTableType() const
Returns true if this is a WebAssembly table type: either an array of reference types,...
bool isMemberPointerType() const
bool isAtomicType() const
bool isObjCObjectType() const
bool isUndeducedType() const
Determine whether this type is an undeduced type, meaning that it somehow involves a C++11 'auto' typ...
bool isIncompleteType(NamedDecl **Def=nullptr) const
Types are partitioned into 3 broad categories (C99 6.2.5p1): object types, function types,...
bool isFunctionType() const
bool isObjCObjectPointerType() 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 isAnyPointerType() const
TypeClass getTypeClass() const
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 isObjCRetainableType() const
std::optional< NullabilityKind > getNullability() const
Determine the nullability of the given type.
Represents the declaration of a typedef-name via the 'typedef' type specifier.
Base class for declarations which introduce a typedef-name.
void setParensRange(SourceRange range)
void setTypeofLoc(SourceLocation Loc)
Wrapper of type source information for a type with no direct qualifiers.
TypeLocClass getTypeLocClass() const
UnionParsedType ConversionFunctionId
When Kind == IK_ConversionFunctionId, the type that the conversion function names.
SourceRange getSourceRange() const LLVM_READONLY
Return the source range that covers this unqualified-id.
UnqualifiedIdKind getKind() const
Determine what kind of name we have.
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 ...
Represents a variable declaration or definition.
@ Definition
This declaration is definitely a definition.
void setNameLoc(SourceLocation Loc)
Represents a GCC generic vector type.
VectorKind getVectorKind() const
static DelayedDiagnostic makeForbiddenType(SourceLocation loc, unsigned diagnostic, QualType type, unsigned argument)
Retains information about a function, method, or block that is currently being parsed.
Defines the clang::TargetInfo interface.
const internal::VariadicDynCastAllOfMatcher< Decl, TypedefDecl > typedefDecl
Matches typedef declarations.
const internal::VariadicAllOfMatcher< Type > type
Matches Types in the clang AST.
const internal::VariadicDynCastAllOfMatcher< Decl, RecordDecl > recordDecl
Matches class, struct, and union declarations.
unsigned kind
All of the diagnostics that can be emitted by the frontend.
The JSON file list parser is used to communicate input to InstallAPI.
CanQual< Type > CanQualType
Represents a canonical, potentially-qualified type.
void atTemplateEnd(TemplateInstantiationCallbackPtrs &Callbacks, const Sema &TheSema, const Sema::CodeSynthesisContext &Inst)
bool isa(CodeGen::Address addr)
bool isTemplateInstantiation(TemplateSpecializationKind Kind)
Determine whether this template specialization kind refers to an instantiation of an entity (as oppos...
@ ExpectedParameterOrImplicitObjectParameter
@ ExpectedFunctionWithProtoType
void atTemplateBegin(TemplateInstantiationCallbackPtrs &Callbacks, const Sema &TheSema, const Sema::CodeSynthesisContext &Inst)
@ GNUAutoType
__auto_type (GNU extension)
@ DecltypeAuto
decltype(auto)
llvm::StringRef getParameterABISpelling(ParameterABI kind)
FunctionEffectMode
Used with attributes/effects with a boolean condition, e.g. nonblocking.
LLVM_READONLY bool isAsciiIdentifierContinue(unsigned char c)
NullabilityKind
Describes the nullability of a particular type.
@ 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.
@ RQ_None
No ref-qualifier was provided.
@ RQ_LValue
An lvalue ref-qualifier was provided (&).
@ RQ_RValue
An rvalue ref-qualifier was provided (&&).
llvm::PointerUnion< Expr *, IdentifierLoc * > ArgsUnion
A union of the various pointer types that can be passed to an ParsedAttr as an argument.
@ Success
Annotation was successful.
@ TemplateName
The identifier is a template name. FIXME: Add an annotation for that.
@ IK_DeductionGuideName
A deduction-guide name (a template-name)
@ IK_ImplicitSelfParam
An implicit 'self' parameter.
@ IK_TemplateId
A template-id, e.g., f<int>.
@ IK_ConstructorTemplateId
A constructor named via a template-id.
@ IK_ConstructorName
A constructor name.
@ IK_LiteralOperatorId
A user-defined literal name, e.g., operator "" _i.
@ IK_Identifier
An identifier.
@ IK_DestructorName
A destructor name.
@ IK_OperatorFunctionId
An overloaded operator name, e.g., operator+.
@ IK_ConversionFunctionId
A conversion function name, e.g., operator int.
TypeOfKind
The kind of 'typeof' expression we're after.
nullptr
This class represents a compute construct, representing a 'Kind' of ‘parallel’, 'serial',...
std::pair< NullabilityKind, bool > DiagNullabilityKind
A nullability kind paired with a bit indicating whether it used a context-sensitive keyword.
@ AANT_ArgumentIntegerConstant
@ Result
The result type of a method or function.
ActionResult< ParsedType > TypeResult
llvm::StringRef getNullabilitySpelling(NullabilityKind kind, bool isContextSensitive=false)
Retrieve the spelling of the given nullability kind.
ArraySizeModifier
Capture whether this is a normal array (e.g.
@ SwiftAsyncContext
This parameter (which must have pointer type) uses the special Swift asynchronous context-pointer ABI...
@ SwiftErrorResult
This parameter (which must have pointer-to-pointer type) uses the special Swift error-result ABI trea...
@ Ordinary
This parameter uses ordinary ABI rules for its type.
@ SwiftIndirectResult
This parameter (which must have pointer type) is a Swift indirect result parameter.
@ SwiftContext
This parameter (which must have pointer type) uses the special Swift context-pointer ABI treatment.
bool supportsVariadicCall(CallingConv CC)
Checks whether the given calling convention supports variadic calls.
bool isComputedNoexcept(ExceptionSpecificationType ESpecType)
static bool isBlockPointer(Expr *Arg)
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.
LLVM_READONLY bool isWhitespace(unsigned char c)
Return true if this character is horizontal or vertical ASCII whitespace: ' ', '\t',...
@ 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.
@ FirstTargetAddressSpace
MutableArrayRef< ParsedTemplateArgument > ASTTemplateArgsPtr
MSInheritanceModel
Assigned inheritance model for a class in the MS C++ ABI.
@ IgnoreTrivialABI
The triviality of a method unaffected by "trivial_abi".
@ Incomplete
Template argument deduction did not deduce a value for every template parameter.
@ TSK_ExplicitSpecialization
This template specialization was declared or defined by an explicit specialization (C++ [temp....
@ TSK_ImplicitInstantiation
This template specialization was implicitly instantiated from a template.
@ TSK_Undeclared
This template specialization was formed from a template-id but has not yet been declared,...
CallingConv
CallingConv - Specifies the calling convention that a function uses.
@ AltiVecBool
is AltiVec 'vector bool ...'
@ SveFixedLengthData
is AArch64 SVE fixed-length data vector
@ AltiVecVector
is AltiVec vector
@ AltiVecPixel
is AltiVec 'vector Pixel'
@ Generic
not a target-specific vector type
@ RVVFixedLengthData
is RISC-V RVV fixed-length data vector
@ RVVFixedLengthMask
is RISC-V RVV fixed-length mask vector
@ NeonPoly
is ARM Neon polynomial vector
@ SveFixedLengthPredicate
is AArch64 SVE fixed-length predicate vector
U cast(CodeGen::Address addr)
LangAS getLangASFromTargetAS(unsigned TargetAS)
@ None
The alignment was not explicit in code.
@ ArrayBound
Array bound in array declarator or new-expression.
OpaquePtr< QualType > ParsedType
An opaque type for threading parsed type information through the parser.
ElaboratedTypeKeyword
The elaboration keyword that precedes a qualified type name or introduces an elaborated-type-specifie...
ActionResult< Expr * > ExprResult
@ Parens
New-expression has a C++98 paren-delimited initializer.
@ 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)
@ Implicit
An implicit conversion.
static const ASTTemplateArgumentListInfo * Create(const ASTContext &C, const TemplateArgumentListInfo &List)
DeclarationNameInfo - A collector data type for bundling together a DeclarationName and the correspon...
unsigned isStar
True if this dimension was [*]. In this case, NumElts is null.
unsigned TypeQuals
The type qualifiers for the array: const/volatile/restrict/__unaligned/_Atomic.
unsigned hasStatic
True if this dimension included the 'static' keyword.
Expr * NumElts
This is the size of the array, or null if [] or [*] was specified.
unsigned TypeQuals
For now, sema will catch these as invalid.
unsigned isVariadic
isVariadic - If this function has a prototype, and if that proto ends with ',...)',...
SourceLocation getTrailingReturnTypeLoc() const
Get the trailing-return-type location for this function declarator.
SourceLocation getLParenLoc() const
bool hasTrailingReturnType() const
Determine whether this function declarator had a trailing-return-type.
TypeAndRange * Exceptions
Pointer to a new[]'d array of TypeAndRange objects that contain the types in the function's dynamic e...
ParamInfo * Params
Params - This is a pointer to a new[]'d array of ParamInfo objects that describe the parameters speci...
ParsedType getTrailingReturnType() const
Get the trailing-return-type for this function declarator.
unsigned RefQualifierIsLValueRef
Whether the ref-qualifier (if any) is an lvalue reference.
SourceLocation getExceptionSpecLocBeg() const
DeclSpec * MethodQualifiers
DeclSpec for the function with the qualifier related info.
SourceLocation getRefQualifierLoc() const
Retrieve the location of the ref-qualifier, if any.
SourceLocation getRParenLoc() const
SourceLocation getEllipsisLoc() const
unsigned NumParams
NumParams - This is the number of formal parameters specified by the declarator.
unsigned getNumExceptions() const
Get the number of dynamic exception specifications.
bool hasMethodTypeQualifiers() const
Determine whether this method has qualifiers.
unsigned isAmbiguous
Can this declaration be a constructor-style initializer?
unsigned hasPrototype
hasPrototype - This is true if the function had at least one typed parameter.
bool hasRefQualifier() const
Determine whether this function declaration contains a ref-qualifier.
SourceRange getExceptionSpecRange() const
ExceptionSpecificationType getExceptionSpecType() const
Get the type of exception specification this function has.
Expr * NoexceptExpr
Pointer to the expression in the noexcept-specifier of this function, if it has one.
unsigned TypeQuals
The type qualifiers: const/volatile/restrict/__unaligned/_Atomic.
SourceLocation StarLoc
Location of the '*' token.
const IdentifierInfo * Ident
SourceLocation OverflowBehaviorLoc
The location of an __ob_wrap or __ob_trap qualifier, if any.
SourceLocation RestrictQualLoc
The location of the restrict-qualifier, if any.
SourceLocation ConstQualLoc
The location of the const-qualifier, if any.
SourceLocation VolatileQualLoc
The location of the volatile-qualifier, if any.
SourceLocation UnalignedQualLoc
The location of the __unaligned-qualifier, if any.
unsigned TypeQuals
The type qualifiers: const/volatile/restrict/unaligned/atomic.
SourceLocation AtomicQualLoc
The location of the _Atomic-qualifier, if any.
unsigned OverflowBehaviorIsWrap
Whether the overflow behavior qualifier is wrap (true) or trap (false).
bool LValueRef
True if this is an lvalue reference, false if it's an rvalue reference.
bool HasRestrict
The type qualifier: restrict. [GNU] C++ extension.
One instance of this struct is used for each type in a declarator that is parsed.
const ParsedAttributesView & getAttrs() const
If there are attributes applied to this declaratorchunk, return them.
SourceLocation EndLoc
EndLoc - If valid, the place where this chunck ends.
static DeclaratorChunk getFunction(bool HasProto, bool IsAmbiguous, SourceLocation LParenLoc, ParamInfo *Params, unsigned NumParams, SourceLocation EllipsisLoc, SourceLocation RParenLoc, bool RefQualifierIsLvalueRef, SourceLocation RefQualifierLoc, SourceLocation MutableLoc, ExceptionSpecificationType ESpecType, SourceRange ESpecRange, ParsedType *Exceptions, SourceRange *ExceptionRanges, unsigned NumExceptions, Expr *NoexceptExpr, CachedTokens *ExceptionSpecTokens, ArrayRef< NamedDecl * > DeclsInPrototype, SourceLocation LocalRangeBegin, SourceLocation LocalRangeEnd, Declarator &TheDeclarator, TypeResult TrailingReturnType=TypeResult(), SourceLocation TrailingReturnTypeLoc=SourceLocation(), DeclSpec *MethodQualifiers=nullptr)
DeclaratorChunk::getFunction - Return a DeclaratorChunk for a function.
MemberPointerTypeInfo Mem
SourceLocation Loc
Loc - The place where this type was defined.
enum clang::DeclaratorChunk::@340323374315200305336204205154073066142310370142 Kind
Describes whether we've seen any nullability information for the given file.
SourceLocation PointerEndLoc
The end location for the first pointer declarator in the file.
SourceLocation PointerLoc
The first pointer declarator (of any pointer kind) in the file that does not have a corresponding nul...
bool SawTypeNullability
Whether we saw any type nullability annotations in the given file.
uint8_t PointerKind
Which kind of pointer declarator we saw.
A FunctionEffect plus a potential boolean expression determining whether the effect is declared (e....
Holds information about the various types of exception specification.
Extra information about a function prototype.
ExceptionSpecInfo ExceptionSpec
FunctionTypeExtraAttributeInfo ExtraAttributeInfo
unsigned AArch64SMEAttributes
SourceLocation EllipsisLoc
FunctionEffectsRef FunctionEffects
const ExtParameterInfo * ExtParameterInfos
RefQualifierKind RefQualifier
unsigned HasTrailingReturn
void setArmSMEAttribute(AArch64SMETypeAttributes Kind, bool Enable=true)
FunctionType::ExtInfo ExtInfo
TypeSourceInfo * ContainedTyInfo
SmallVector< NamedDecl *, 4 > TemplateParams
Store the list of the template parameters for a generic lambda or an abbreviated function template.
unsigned AutoTemplateParameterDepth
If this is a generic lambda or abbreviated function template, use this as the depth of each 'auto' pa...
static ElaboratedTypeKeyword getKeywordForTypeSpec(unsigned TypeSpec)
Converts a type specifier (DeclSpec::TST) into an elaborated type keyword.
NestedNameSpecifier Prefix
Describes how types, statements, expressions, and declarations should be printed.
A context in which code is being synthesized (where a source location alone is not sufficient to iden...
enum clang::Sema::CodeSynthesisContext::SynthesisKind Kind
@ Memoization
Added for Template instantiation observation.
Abstract class used to diagnose incomplete types.
virtual void diagnose(Sema &S, SourceLocation Loc, QualType T)=0
A std::pair-like structure for storing a qualified type split into its local qualifiers and its local...
SplitQualType getSingleStepDesugaredType() const
const Type * Ty
The locally-unqualified type.
Qualifiers Quals
The local qualifiers.
llvm::DenseSet< std::tuple< Decl *, Decl *, int > > NonEquivalentDeclSet
Store declaration pairs already found to be non-equivalent.
bool IsEquivalent(Decl *D1, Decl *D2)
Determine whether the two declarations are structurally equivalent.
Information about a template-id annotation token.
const IdentifierInfo * Name
FIXME: Temporarily stores the name of a specialization.
unsigned NumArgs
NumArgs - The number of template arguments.
SourceLocation TemplateNameLoc
TemplateNameLoc - The location of the template name within the source.
ParsedTemplateArgument * getTemplateArgs()
Retrieves a pointer to the template arguments.
SourceLocation RAngleLoc
The location of the '>' after the template argument list.
SourceLocation LAngleLoc
The location of the '<' before the template argument list.
SourceLocation TemplateKWLoc
TemplateKWLoc - The location of the template keyword.
ParsedTemplateTy Template
The declaration of the template corresponding to the template-name.