clang 22.0.0git
ASTContext.h
Go to the documentation of this file.
1//===- ASTContext.h - Context to hold long-lived AST nodes ------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9/// \file
10/// Defines the clang::ASTContext interface.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_CLANG_AST_ASTCONTEXT_H
15#define LLVM_CLANG_AST_ASTCONTEXT_H
16
17#include "clang/AST/ASTFwd.h"
21#include "clang/AST/Decl.h"
29#include "clang/Basic/LLVM.h"
32#include "llvm/ADT/DenseMap.h"
33#include "llvm/ADT/DenseMapInfo.h"
34#include "llvm/ADT/DenseSet.h"
35#include "llvm/ADT/FoldingSet.h"
36#include "llvm/ADT/IntrusiveRefCntPtr.h"
37#include "llvm/ADT/MapVector.h"
38#include "llvm/ADT/PointerIntPair.h"
39#include "llvm/ADT/PointerUnion.h"
40#include "llvm/ADT/SetVector.h"
41#include "llvm/ADT/SmallVector.h"
42#include "llvm/ADT/StringMap.h"
43#include "llvm/ADT/StringRef.h"
44#include "llvm/ADT/StringSet.h"
45#include "llvm/ADT/TinyPtrVector.h"
46#include "llvm/Support/TypeSize.h"
47#include <optional>
48
49namespace llvm {
50
51class APFixedPoint;
53struct fltSemantics;
54template <typename T, unsigned N> class SmallPtrSet;
55
58 unsigned NumElts;
59 unsigned NumFields;
60
61 bool operator==(const ScalableVecTyKey &RHS) const {
62 return EltTy == RHS.EltTy && NumElts == RHS.NumElts &&
63 NumFields == RHS.NumFields;
64 }
65};
66
67// Provide a DenseMapInfo specialization so that ScalableVecTyKey can be used
68// as a key in DenseMap.
69template <> struct DenseMapInfo<ScalableVecTyKey> {
70 static inline ScalableVecTyKey getEmptyKey() {
71 return {DenseMapInfo<clang::QualType>::getEmptyKey(), ~0U, ~0U};
72 }
74 return {DenseMapInfo<clang::QualType>::getTombstoneKey(), ~0U, ~0U};
75 }
76 static unsigned getHashValue(const ScalableVecTyKey &Val) {
77 return hash_combine(DenseMapInfo<clang::QualType>::getHashValue(Val.EltTy),
78 Val.NumElts, Val.NumFields);
79 }
80 static bool isEqual(const ScalableVecTyKey &LHS,
81 const ScalableVecTyKey &RHS) {
82 return LHS == RHS;
83 }
84};
85
86} // namespace llvm
87
88namespace clang {
89
90class APValue;
92class ASTRecordLayout;
93class AtomicExpr;
94class BlockExpr;
95struct BlockVarCopyInit;
97class CharUnits;
98class ConceptDecl;
99class CXXABI;
101class CXXMethodDecl;
102class CXXRecordDecl;
104class DynTypedNodeList;
105class Expr;
106enum class FloatModeKind;
107class GlobalDecl;
108class IdentifierTable;
109class LangOptions;
110class MangleContext;
113class Module;
114struct MSGuidDeclParts;
116class NoSanitizeList;
117class ObjCCategoryDecl;
120class ObjCImplDecl;
123class ObjCIvarDecl;
124class ObjCMethodDecl;
125class ObjCPropertyDecl;
127class ObjCProtocolDecl;
129class OMPTraitInfo;
130class ParentMapContext;
131struct ParsedTargetAttr;
132class Preprocessor;
133class ProfileList;
134class StoredDeclsMap;
135class TargetAttr;
136class TargetInfo;
137class TemplateDecl;
141class TypeConstraint;
143class UsingShadowDecl;
144class VarTemplateDecl;
147
148/// A simple array of base specifiers.
150
151namespace Builtin {
152
153class Context;
154
155} // namespace Builtin
156
158enum OpenCLTypeKind : uint8_t;
159
160namespace comments {
161
162class FullComment;
163
164} // namespace comments
165
166namespace interp {
167
168class Context;
169
170} // namespace interp
171
172namespace serialization {
173template <class> class AbstractTypeReader;
174} // namespace serialization
175
177 /// The alignment was not explicit in code.
179
180 /// The alignment comes from an alignment attribute on a typedef.
182
183 /// The alignment comes from an alignment attribute on a record type.
185
186 /// The alignment comes from an alignment attribute on a enum type.
188};
189
203
217
218/// Holds long-lived AST nodes (such as types and decls) that can be
219/// referred to throughout the semantic analysis of a file.
220class ASTContext : public RefCountedBase<ASTContext> {
222
223 mutable SmallVector<Type *, 0> Types;
224 mutable llvm::FoldingSet<ExtQuals> ExtQualNodes;
225 mutable llvm::FoldingSet<ComplexType> ComplexTypes;
226 mutable llvm::FoldingSet<PointerType> PointerTypes{GeneralTypesLog2InitSize};
227 mutable llvm::FoldingSet<AdjustedType> AdjustedTypes;
228 mutable llvm::FoldingSet<BlockPointerType> BlockPointerTypes;
229 mutable llvm::FoldingSet<LValueReferenceType> LValueReferenceTypes;
230 mutable llvm::FoldingSet<RValueReferenceType> RValueReferenceTypes;
231 mutable llvm::FoldingSet<MemberPointerType> MemberPointerTypes;
232 mutable llvm::ContextualFoldingSet<ConstantArrayType, ASTContext &>
233 ConstantArrayTypes;
234 mutable llvm::FoldingSet<IncompleteArrayType> IncompleteArrayTypes;
235 mutable std::vector<VariableArrayType*> VariableArrayTypes;
236 mutable llvm::ContextualFoldingSet<DependentSizedArrayType, ASTContext &>
237 DependentSizedArrayTypes;
238 mutable llvm::ContextualFoldingSet<DependentSizedExtVectorType, ASTContext &>
239 DependentSizedExtVectorTypes;
240 mutable llvm::ContextualFoldingSet<DependentAddressSpaceType, ASTContext &>
241 DependentAddressSpaceTypes;
242 mutable llvm::FoldingSet<VectorType> VectorTypes;
243 mutable llvm::ContextualFoldingSet<DependentVectorType, ASTContext &>
244 DependentVectorTypes;
245 mutable llvm::FoldingSet<ConstantMatrixType> MatrixTypes;
246 mutable llvm::ContextualFoldingSet<DependentSizedMatrixType, ASTContext &>
247 DependentSizedMatrixTypes;
248 mutable llvm::FoldingSet<FunctionNoProtoType> FunctionNoProtoTypes;
249 mutable llvm::ContextualFoldingSet<FunctionProtoType, ASTContext&>
250 FunctionProtoTypes;
251 mutable llvm::ContextualFoldingSet<DependentTypeOfExprType, ASTContext &>
252 DependentTypeOfExprTypes;
253 mutable llvm::ContextualFoldingSet<DependentDecltypeType, ASTContext &>
254 DependentDecltypeTypes;
255
256 mutable llvm::ContextualFoldingSet<PackIndexingType, ASTContext &>
257 DependentPackIndexingTypes;
258
259 mutable llvm::FoldingSet<TemplateTypeParmType> TemplateTypeParmTypes;
260 mutable llvm::FoldingSet<ObjCTypeParamType> ObjCTypeParamTypes;
261 mutable llvm::FoldingSet<SubstTemplateTypeParmType>
262 SubstTemplateTypeParmTypes;
263 mutable llvm::FoldingSet<SubstTemplateTypeParmPackType>
264 SubstTemplateTypeParmPackTypes;
265 mutable llvm::FoldingSet<SubstBuiltinTemplatePackType>
266 SubstBuiltinTemplatePackTypes;
267 mutable llvm::ContextualFoldingSet<TemplateSpecializationType, ASTContext&>
268 TemplateSpecializationTypes;
269 mutable llvm::FoldingSet<ParenType> ParenTypes{GeneralTypesLog2InitSize};
270 mutable llvm::FoldingSet<TagTypeFoldingSetPlaceholder> TagTypes;
271 mutable llvm::FoldingSet<FoldingSetPlaceholder<UnresolvedUsingType>>
272 UnresolvedUsingTypes;
273 mutable llvm::FoldingSet<UsingType> UsingTypes;
274 mutable llvm::FoldingSet<FoldingSetPlaceholder<TypedefType>> TypedefTypes;
275 mutable llvm::FoldingSet<DependentNameType> DependentNameTypes;
276 mutable llvm::FoldingSet<PackExpansionType> PackExpansionTypes;
277 mutable llvm::FoldingSet<ObjCObjectTypeImpl> ObjCObjectTypes;
278 mutable llvm::FoldingSet<ObjCObjectPointerType> ObjCObjectPointerTypes;
279 mutable llvm::FoldingSet<UnaryTransformType> UnaryTransformTypes;
280 // An AutoType can have a dependency on another AutoType via its template
281 // arguments. Since both dependent and dependency are on the same set,
282 // we can end up in an infinite recursion when looking for a node if we used
283 // a `FoldingSet`, since both could end up in the same bucket.
284 mutable llvm::DenseMap<llvm::FoldingSetNodeID, AutoType *> AutoTypes;
285 mutable llvm::FoldingSet<DeducedTemplateSpecializationType>
286 DeducedTemplateSpecializationTypes;
287 mutable llvm::FoldingSet<AtomicType> AtomicTypes;
288 mutable llvm::FoldingSet<AttributedType> AttributedTypes;
289 mutable llvm::FoldingSet<PipeType> PipeTypes;
290 mutable llvm::FoldingSet<BitIntType> BitIntTypes;
291 mutable llvm::ContextualFoldingSet<DependentBitIntType, ASTContext &>
292 DependentBitIntTypes;
293 mutable llvm::FoldingSet<BTFTagAttributedType> BTFTagAttributedTypes;
294 llvm::FoldingSet<HLSLAttributedResourceType> HLSLAttributedResourceTypes;
295 llvm::FoldingSet<HLSLInlineSpirvType> HLSLInlineSpirvTypes;
296
297 mutable llvm::FoldingSet<CountAttributedType> CountAttributedTypes;
298
299 mutable llvm::FoldingSet<QualifiedTemplateName> QualifiedTemplateNames;
300 mutable llvm::FoldingSet<DependentTemplateName> DependentTemplateNames;
301 mutable llvm::FoldingSet<SubstTemplateTemplateParmStorage>
302 SubstTemplateTemplateParms;
303 mutable llvm::ContextualFoldingSet<SubstTemplateTemplateParmPackStorage,
304 ASTContext&>
305 SubstTemplateTemplateParmPacks;
306 mutable llvm::ContextualFoldingSet<DeducedTemplateStorage, ASTContext &>
307 DeducedTemplates;
308
309 mutable llvm::ContextualFoldingSet<ArrayParameterType, ASTContext &>
310 ArrayParameterTypes;
311
312 /// Store the unique Type corresponding to each Kind.
313 mutable std::array<Type *,
314 llvm::to_underlying(PredefinedSugarType::Kind::Last) + 1>
315 PredefinedSugarTypes{};
316
317 /// Internal storage for NestedNameSpecifiers.
318 ///
319 /// This set is managed by the NestedNameSpecifier class.
320 mutable llvm::FoldingSet<NamespaceAndPrefixStorage>
321 NamespaceAndPrefixStorages;
322
323 /// A cache mapping from RecordDecls to ASTRecordLayouts.
324 ///
325 /// This is lazily created. This is intentionally not serialized.
326 mutable llvm::DenseMap<const RecordDecl*, const ASTRecordLayout*>
327 ASTRecordLayouts;
328 mutable llvm::DenseMap<const ObjCInterfaceDecl *, const ASTRecordLayout *>
329 ObjCLayouts;
330
331 /// A cache from types to size and alignment information.
332 using TypeInfoMap = llvm::DenseMap<const Type *, struct TypeInfo>;
333 mutable TypeInfoMap MemoizedTypeInfo;
334
335 /// A cache from types to unadjusted alignment information. Only ARM and
336 /// AArch64 targets need this information, keeping it separate prevents
337 /// imposing overhead on TypeInfo size.
338 using UnadjustedAlignMap = llvm::DenseMap<const Type *, unsigned>;
339 mutable UnadjustedAlignMap MemoizedUnadjustedAlign;
340
341 /// A cache mapping from CXXRecordDecls to key functions.
342 llvm::DenseMap<const CXXRecordDecl*, LazyDeclPtr> KeyFunctions;
343
344 /// Mapping from ObjCContainers to their ObjCImplementations.
345 llvm::DenseMap<ObjCContainerDecl*, ObjCImplDecl*> ObjCImpls;
346
347 /// Mapping from ObjCMethod to its duplicate declaration in the same
348 /// interface.
349 llvm::DenseMap<const ObjCMethodDecl*,const ObjCMethodDecl*> ObjCMethodRedecls;
350
351 /// Mapping from __block VarDecls to BlockVarCopyInit.
352 llvm::DenseMap<const VarDecl *, BlockVarCopyInit> BlockVarCopyInits;
353
354 /// Mapping from GUIDs to the corresponding MSGuidDecl.
355 mutable llvm::FoldingSet<MSGuidDecl> MSGuidDecls;
356
357 /// Mapping from APValues to the corresponding UnnamedGlobalConstantDecl.
358 mutable llvm::FoldingSet<UnnamedGlobalConstantDecl>
359 UnnamedGlobalConstantDecls;
360
361 /// Mapping from APValues to the corresponding TemplateParamObjects.
362 mutable llvm::FoldingSet<TemplateParamObjectDecl> TemplateParamObjectDecls;
363
364 /// A cache mapping a string value to a StringLiteral object with the same
365 /// value.
366 ///
367 /// This is lazily created. This is intentionally not serialized.
368 mutable llvm::StringMap<StringLiteral *> StringLiteralCache;
369
370 mutable llvm::DenseSet<const FunctionDecl *> DestroyingOperatorDeletes;
371 mutable llvm::DenseSet<const FunctionDecl *> TypeAwareOperatorNewAndDeletes;
372
373 /// Global and array operators delete are only required for MSVC deleting
374 /// destructors support. Store them here to avoid keeping 4 pointers that are
375 /// not always used in each redeclaration of the destructor.
376 mutable llvm::DenseMap<const CXXDestructorDecl *, FunctionDecl *>
377 OperatorDeletesForVirtualDtor;
378 mutable llvm::DenseMap<const CXXDestructorDecl *, FunctionDecl *>
379 GlobalOperatorDeletesForVirtualDtor;
380 mutable llvm::DenseMap<const CXXDestructorDecl *, FunctionDecl *>
381 ArrayOperatorDeletesForVirtualDtor;
382 mutable llvm::DenseMap<const CXXDestructorDecl *, FunctionDecl *>
383 GlobalArrayOperatorDeletesForVirtualDtor;
384
385 /// The next string literal "version" to allocate during constant evaluation.
386 /// This is used to distinguish between repeated evaluations of the same
387 /// string literal.
388 ///
389 /// We don't need to serialize this because constants get re-evaluated in the
390 /// current file before they are compared locally.
391 unsigned NextStringLiteralVersion = 0;
392
393 /// MD5 hash of CUID. It is calculated when first used and cached by this
394 /// data member.
395 mutable std::string CUIDHash;
396
397 /// Representation of a "canonical" template template parameter that
398 /// is used in canonical template names.
399 class CanonicalTemplateTemplateParm : public llvm::FoldingSetNode {
400 TemplateTemplateParmDecl *Parm;
401
402 public:
403 CanonicalTemplateTemplateParm(TemplateTemplateParmDecl *Parm)
404 : Parm(Parm) {}
405
406 TemplateTemplateParmDecl *getParam() const { return Parm; }
407
408 void Profile(llvm::FoldingSetNodeID &ID, const ASTContext &C) {
409 Profile(ID, C, Parm);
410 }
411
412 static void Profile(llvm::FoldingSetNodeID &ID,
413 const ASTContext &C,
414 TemplateTemplateParmDecl *Parm);
415 };
416 mutable llvm::ContextualFoldingSet<CanonicalTemplateTemplateParm,
417 const ASTContext&>
418 CanonTemplateTemplateParms;
419
420 /// The typedef for the __int128_t type.
421 mutable TypedefDecl *Int128Decl = nullptr;
422
423 /// The typedef for the __uint128_t type.
424 mutable TypedefDecl *UInt128Decl = nullptr;
425
426 /// The typedef for the target specific predefined
427 /// __builtin_va_list type.
428 mutable TypedefDecl *BuiltinVaListDecl = nullptr;
429
430 /// The typedef for the predefined \c __builtin_ms_va_list type.
431 mutable TypedefDecl *BuiltinMSVaListDecl = nullptr;
432
433 /// The typedef for the predefined \c id type.
434 mutable TypedefDecl *ObjCIdDecl = nullptr;
435
436 /// The typedef for the predefined \c SEL type.
437 mutable TypedefDecl *ObjCSelDecl = nullptr;
438
439 /// The typedef for the predefined \c Class type.
440 mutable TypedefDecl *ObjCClassDecl = nullptr;
441
442 /// The typedef for the predefined \c Protocol class in Objective-C.
443 mutable ObjCInterfaceDecl *ObjCProtocolClassDecl = nullptr;
444
445 /// The typedef for the predefined 'BOOL' type.
446 mutable TypedefDecl *BOOLDecl = nullptr;
447
448 // Typedefs which may be provided defining the structure of Objective-C
449 // pseudo-builtins
450 QualType ObjCIdRedefinitionType;
451 QualType ObjCClassRedefinitionType;
452 QualType ObjCSelRedefinitionType;
453
454 /// The identifier 'bool'.
455 mutable IdentifierInfo *BoolName = nullptr;
456
457 /// The identifier 'NSObject'.
458 mutable IdentifierInfo *NSObjectName = nullptr;
459
460 /// The identifier 'NSCopying'.
461 IdentifierInfo *NSCopyingName = nullptr;
462
463#define BuiltinTemplate(BTName) mutable IdentifierInfo *Name##BTName = nullptr;
464#include "clang/Basic/BuiltinTemplates.inc"
465
466 QualType ObjCConstantStringType;
467 mutable RecordDecl *CFConstantStringTagDecl = nullptr;
468 mutable TypedefDecl *CFConstantStringTypeDecl = nullptr;
469
470 mutable QualType ObjCSuperType;
471
472 QualType ObjCNSStringType;
473
474 /// The typedef declaration for the Objective-C "instancetype" type.
475 TypedefDecl *ObjCInstanceTypeDecl = nullptr;
476
477 /// The type for the C FILE type.
478 TypeDecl *FILEDecl = nullptr;
479
480 /// The type for the C jmp_buf type.
481 TypeDecl *jmp_bufDecl = nullptr;
482
483 /// The type for the C sigjmp_buf type.
484 TypeDecl *sigjmp_bufDecl = nullptr;
485
486 /// The type for the C ucontext_t type.
487 TypeDecl *ucontext_tDecl = nullptr;
488
489 /// Type for the Block descriptor for Blocks CodeGen.
490 ///
491 /// Since this is only used for generation of debug info, it is not
492 /// serialized.
493 mutable RecordDecl *BlockDescriptorType = nullptr;
494
495 /// Type for the Block descriptor for Blocks CodeGen.
496 ///
497 /// Since this is only used for generation of debug info, it is not
498 /// serialized.
499 mutable RecordDecl *BlockDescriptorExtendedType = nullptr;
500
501 /// Declaration for the CUDA cudaConfigureCall function.
502 FunctionDecl *cudaConfigureCallDecl = nullptr;
503
504 /// Keeps track of all declaration attributes.
505 ///
506 /// Since so few decls have attrs, we keep them in a hash map instead of
507 /// wasting space in the Decl class.
508 llvm::DenseMap<const Decl*, AttrVec*> DeclAttrs;
509
510 /// A mapping from non-redeclarable declarations in modules that were
511 /// merged with other declarations to the canonical declaration that they were
512 /// merged into.
513 llvm::DenseMap<Decl*, Decl*> MergedDecls;
514
515 /// A mapping from a defining declaration to a list of modules (other
516 /// than the owning module of the declaration) that contain merged
517 /// definitions of that entity.
518 llvm::DenseMap<NamedDecl*, llvm::TinyPtrVector<Module*>> MergedDefModules;
519
520 /// Initializers for a module, in order. Each Decl will be either
521 /// something that has a semantic effect on startup (such as a variable with
522 /// a non-constant initializer), or an ImportDecl (which recursively triggers
523 /// initialization of another module).
524 struct PerModuleInitializers {
525 llvm::SmallVector<Decl*, 4> Initializers;
526 llvm::SmallVector<GlobalDeclID, 4> LazyInitializers;
527
528 void resolve(ASTContext &Ctx);
529 };
530 llvm::DenseMap<Module*, PerModuleInitializers*> ModuleInitializers;
531
532 /// This is the top-level (C++20) Named module we are building.
533 Module *CurrentCXXNamedModule = nullptr;
534
535 /// Help structures to decide whether two `const Module *` belongs
536 /// to the same conceptual module to avoid the expensive to string comparison
537 /// if possible.
538 ///
539 /// Not serialized intentionally.
540 mutable llvm::StringMap<const Module *> PrimaryModuleNameMap;
541 mutable llvm::DenseMap<const Module *, const Module *> SameModuleLookupSet;
542
543 static constexpr unsigned ConstantArrayTypesLog2InitSize = 8;
544 static constexpr unsigned GeneralTypesLog2InitSize = 9;
545 static constexpr unsigned FunctionProtoTypesLog2InitSize = 12;
546
547 /// A mapping from an ObjC class to its subclasses.
548 llvm::DenseMap<const ObjCInterfaceDecl *,
549 SmallVector<const ObjCInterfaceDecl *, 4>>
550 ObjCSubClasses;
551
552 // A mapping from Scalable Vector Type keys to their corresponding QualType.
553 mutable llvm::DenseMap<llvm::ScalableVecTyKey, QualType> ScalableVecTyMap;
554
555 ASTContext &this_() { return *this; }
556
557public:
558 /// A type synonym for the TemplateOrInstantiation mapping.
560 llvm::PointerUnion<VarTemplateDecl *, MemberSpecializationInfo *>;
561
562private:
563 friend class ASTDeclReader;
564 friend class ASTReader;
565 friend class ASTWriter;
566 template <class> friend class serialization::AbstractTypeReader;
567 friend class CXXRecordDecl;
568 friend class IncrementalParser;
569
570 /// A mapping to contain the template or declaration that
571 /// a variable declaration describes or was instantiated from,
572 /// respectively.
573 ///
574 /// For non-templates, this value will be NULL. For variable
575 /// declarations that describe a variable template, this will be a
576 /// pointer to a VarTemplateDecl. For static data members
577 /// of class template specializations, this will be the
578 /// MemberSpecializationInfo referring to the member variable that was
579 /// instantiated or specialized. Thus, the mapping will keep track of
580 /// the static data member templates from which static data members of
581 /// class template specializations were instantiated.
582 ///
583 /// Given the following example:
584 ///
585 /// \code
586 /// template<typename T>
587 /// struct X {
588 /// static T value;
589 /// };
590 ///
591 /// template<typename T>
592 /// T X<T>::value = T(17);
593 ///
594 /// int *x = &X<int>::value;
595 /// \endcode
596 ///
597 /// This mapping will contain an entry that maps from the VarDecl for
598 /// X<int>::value to the corresponding VarDecl for X<T>::value (within the
599 /// class template X) and will be marked TSK_ImplicitInstantiation.
600 llvm::DenseMap<const VarDecl *, TemplateOrSpecializationInfo>
601 TemplateOrInstantiation;
602
603 /// Keeps track of the declaration from which a using declaration was
604 /// created during instantiation.
605 ///
606 /// The source and target declarations are always a UsingDecl, an
607 /// UnresolvedUsingValueDecl, or an UnresolvedUsingTypenameDecl.
608 ///
609 /// For example:
610 /// \code
611 /// template<typename T>
612 /// struct A {
613 /// void f();
614 /// };
615 ///
616 /// template<typename T>
617 /// struct B : A<T> {
618 /// using A<T>::f;
619 /// };
620 ///
621 /// template struct B<int>;
622 /// \endcode
623 ///
624 /// This mapping will contain an entry that maps from the UsingDecl in
625 /// B<int> to the UnresolvedUsingDecl in B<T>.
626 llvm::DenseMap<NamedDecl *, NamedDecl *> InstantiatedFromUsingDecl;
627
628 /// Like InstantiatedFromUsingDecl, but for using-enum-declarations. Maps
629 /// from the instantiated using-enum to the templated decl from whence it
630 /// came.
631 /// Note that using-enum-declarations cannot be dependent and
632 /// thus will never be instantiated from an "unresolved"
633 /// version thereof (as with using-declarations), so each mapping is from
634 /// a (resolved) UsingEnumDecl to a (resolved) UsingEnumDecl.
635 llvm::DenseMap<UsingEnumDecl *, UsingEnumDecl *>
636 InstantiatedFromUsingEnumDecl;
637
638 /// Similarly maps instantiated UsingShadowDecls to their origin.
639 llvm::DenseMap<UsingShadowDecl*, UsingShadowDecl*>
640 InstantiatedFromUsingShadowDecl;
641
642 llvm::DenseMap<FieldDecl *, FieldDecl *> InstantiatedFromUnnamedFieldDecl;
643
644 /// Mapping that stores the methods overridden by a given C++
645 /// member function.
646 ///
647 /// Since most C++ member functions aren't virtual and therefore
648 /// don't override anything, we store the overridden functions in
649 /// this map on the side rather than within the CXXMethodDecl structure.
650 using CXXMethodVector = llvm::TinyPtrVector<const CXXMethodDecl *>;
651 llvm::DenseMap<const CXXMethodDecl *, CXXMethodVector> OverriddenMethods;
652
653 /// Mapping from each declaration context to its corresponding
654 /// mangling numbering context (used for constructs like lambdas which
655 /// need to be consistently numbered for the mangler).
656 llvm::DenseMap<const DeclContext *, std::unique_ptr<MangleNumberingContext>>
657 MangleNumberingContexts;
658 llvm::DenseMap<const Decl *, std::unique_ptr<MangleNumberingContext>>
659 ExtraMangleNumberingContexts;
660
661 /// Side-table of mangling numbers for declarations which rarely
662 /// need them (like static local vars).
663 llvm::MapVector<const NamedDecl *, unsigned> MangleNumbers;
664 llvm::MapVector<const VarDecl *, unsigned> StaticLocalNumbers;
665 /// Mapping the associated device lambda mangling number if present.
666 mutable llvm::DenseMap<const CXXRecordDecl *, unsigned>
667 DeviceLambdaManglingNumbers;
668
669 /// Mapping that stores parameterIndex values for ParmVarDecls when
670 /// that value exceeds the bitfield size of ParmVarDeclBits.ParameterIndex.
671 using ParameterIndexTable = llvm::DenseMap<const VarDecl *, unsigned>;
672 ParameterIndexTable ParamIndices;
673
674public:
679 std::optional<CXXRecordDeclRelocationInfo>
683
684 /// Examines a given type, and returns whether the type itself
685 /// is address discriminated, or any transitively embedded types
686 /// contain data that is address discriminated. This includes
687 /// implicitly authenticated values like vtable pointers, as well as
688 /// explicitly qualified fields.
690 if (!isPointerAuthenticationAvailable())
691 return false;
692 return findPointerAuthContent(T) != PointerAuthContent::None;
693 }
694
695 /// Examines a given type, and returns whether the type itself
696 /// or any data it transitively contains has a pointer authentication
697 /// schema that is not safely relocatable. e.g. any data or fields
698 /// with address discrimination other than any otherwise similar
699 /// vtable pointers.
701 if (!isPointerAuthenticationAvailable())
702 return false;
703 return findPointerAuthContent(T) != PointerAuthContent::None;
704 }
705
706private:
707 llvm::DenseMap<const CXXRecordDecl *, CXXRecordDeclRelocationInfo>
708 RelocatableClasses;
709
710 // FIXME: store in RecordDeclBitfields in future?
711 enum class PointerAuthContent : uint8_t {
712 None,
713 AddressDiscriminatedVTable,
714 AddressDiscriminatedData
715 };
716
717 // A simple helper function to short circuit pointer auth checks.
718 bool isPointerAuthenticationAvailable() const {
719 return LangOpts.PointerAuthCalls || LangOpts.PointerAuthIntrinsics;
720 }
721 PointerAuthContent findPointerAuthContent(QualType T) const;
722 mutable llvm::DenseMap<const RecordDecl *, PointerAuthContent>
723 RecordContainsAddressDiscriminatedPointerAuth;
724
725 ImportDecl *FirstLocalImport = nullptr;
726 ImportDecl *LastLocalImport = nullptr;
727
728 TranslationUnitDecl *TUDecl = nullptr;
729 mutable ExternCContextDecl *ExternCContext = nullptr;
730
731#define BuiltinTemplate(BTName) \
732 mutable BuiltinTemplateDecl *Decl##BTName = nullptr;
733#include "clang/Basic/BuiltinTemplates.inc"
734
735 /// The associated SourceManager object.
736 SourceManager &SourceMgr;
737
738 /// The language options used to create the AST associated with
739 /// this ASTContext object.
740 LangOptions &LangOpts;
741
742 /// NoSanitizeList object that is used by sanitizers to decide which
743 /// entities should not be instrumented.
744 std::unique_ptr<NoSanitizeList> NoSanitizeL;
745
746 /// Function filtering mechanism to determine whether a given function
747 /// should be imbued with the XRay "always" or "never" attributes.
748 std::unique_ptr<XRayFunctionFilter> XRayFilter;
749
750 /// ProfileList object that is used by the profile instrumentation
751 /// to decide which entities should be instrumented.
752 std::unique_ptr<ProfileList> ProfList;
753
754 /// The allocator used to create AST objects.
755 ///
756 /// AST objects are never destructed; rather, all memory associated with the
757 /// AST objects will be released when the ASTContext itself is destroyed.
758 mutable llvm::BumpPtrAllocator BumpAlloc;
759
760 /// Allocator for partial diagnostics.
762
763 /// The current C++ ABI.
764 std::unique_ptr<CXXABI> ABI;
765 CXXABI *createCXXABI(const TargetInfo &T);
766
767 /// Address space map mangling must be used with language specific
768 /// address spaces (e.g. OpenCL/CUDA)
769 bool AddrSpaceMapMangling;
770
771 /// For performance, track whether any function effects are in use.
772 mutable bool AnyFunctionEffects = false;
773
774 const TargetInfo *Target = nullptr;
775 const TargetInfo *AuxTarget = nullptr;
776 clang::PrintingPolicy PrintingPolicy;
777 std::unique_ptr<interp::Context> InterpContext;
778 std::unique_ptr<ParentMapContext> ParentMapCtx;
779
780 /// Keeps track of the deallocated DeclListNodes for future reuse.
781 DeclListNode *ListNodeFreeList = nullptr;
782
783public:
791
792 /// Returns the clang bytecode interpreter context.
794
796 /// Do not allow wrong-sided variables in constant expressions.
797 bool NoWrongSidedVars = false;
808
809 /// Returns the dynamic AST node parent map context.
811
812 // A traversal scope limits the parts of the AST visible to certain analyses.
813 // RecursiveASTVisitor only visits specified children of TranslationUnitDecl.
814 // getParents() will only observe reachable parent edges.
815 //
816 // The scope is defined by a set of "top-level" declarations which will be
817 // visible under the TranslationUnitDecl.
818 // Initially, it is the entire TU, represented by {getTranslationUnitDecl()}.
819 //
820 // After setTraversalScope({foo, bar}), the exposed AST looks like:
821 // TranslationUnitDecl
822 // - foo
823 // - ...
824 // - bar
825 // - ...
826 // All other siblings of foo and bar are pruned from the tree.
827 // (However they are still accessible via TranslationUnitDecl->decls())
828 //
829 // Changing the scope clears the parent cache, which is expensive to rebuild.
830 ArrayRef<Decl *> getTraversalScope() const { return TraversalScope; }
831 void setTraversalScope(const std::vector<Decl *> &);
832
833 /// Forwards to get node parents from the ParentMapContext. New callers should
834 /// use ParentMapContext::getParents() directly.
835 template <typename NodeT> DynTypedNodeList getParents(const NodeT &Node);
836
838 return PrintingPolicy;
839 }
840
842 PrintingPolicy = Policy;
843 }
844
845 SourceManager& getSourceManager() { return SourceMgr; }
846 const SourceManager& getSourceManager() const { return SourceMgr; }
847
848 // Cleans up some of the data structures. This allows us to do cleanup
849 // normally done in the destructor earlier. Renders much of the ASTContext
850 // unusable, mostly the actual AST nodes, so should be called when we no
851 // longer need access to the AST.
852 void cleanup();
853
854 llvm::BumpPtrAllocator &getAllocator() const {
855 return BumpAlloc;
856 }
857
858 void *Allocate(size_t Size, unsigned Align = 8) const {
859 return BumpAlloc.Allocate(Size, Align);
860 }
861 template <typename T> T *Allocate(size_t Num = 1) const {
862 return static_cast<T *>(Allocate(Num * sizeof(T), alignof(T)));
863 }
864 void Deallocate(void *Ptr) const {}
865
866 llvm::StringRef backupStr(llvm::StringRef S) const {
867 char *Buf = new (*this) char[S.size()];
868 llvm::copy(S, Buf);
869 return llvm::StringRef(Buf, S.size());
870 }
871
872 /// Allocates a \c DeclListNode or returns one from the \c ListNodeFreeList
873 /// pool.
875 if (DeclListNode *Alloc = ListNodeFreeList) {
876 ListNodeFreeList = dyn_cast_if_present<DeclListNode *>(Alloc->Rest);
877 Alloc->D = ND;
878 Alloc->Rest = nullptr;
879 return Alloc;
880 }
881 return new (*this) DeclListNode(ND);
882 }
883 /// Deallocates a \c DeclListNode by returning it to the \c ListNodeFreeList
884 /// pool.
886 N->Rest = ListNodeFreeList;
887 ListNodeFreeList = N;
888 }
889
890 /// Return the total amount of physical memory allocated for representing
891 /// AST nodes and type information.
892 size_t getASTAllocatedMemory() const {
893 return BumpAlloc.getTotalMemory();
894 }
895
896 /// Return the total memory used for various side tables.
897 size_t getSideTableAllocatedMemory() const;
898
900 return DiagAllocator;
901 }
902
903 const TargetInfo &getTargetInfo() const { return *Target; }
904 const TargetInfo *getAuxTargetInfo() const { return AuxTarget; }
905
906 const QualType GetHigherPrecisionFPType(QualType ElementType) const {
907 const auto *CurrentBT = cast<BuiltinType>(ElementType);
908 switch (CurrentBT->getKind()) {
909 case BuiltinType::Kind::Half:
910 case BuiltinType::Kind::Float16:
911 return FloatTy;
912 case BuiltinType::Kind::Float:
913 case BuiltinType::Kind::BFloat16:
914 return DoubleTy;
915 case BuiltinType::Kind::Double:
916 return LongDoubleTy;
917 default:
918 return ElementType;
919 }
920 return ElementType;
921 }
922
923 /// getIntTypeForBitwidth -
924 /// sets integer QualTy according to specified details:
925 /// bitwidth, signed/unsigned.
926 /// Returns empty type if there is no appropriate target types.
927 QualType getIntTypeForBitwidth(unsigned DestWidth,
928 unsigned Signed) const;
929
930 /// getRealTypeForBitwidth -
931 /// sets floating point QualTy according to specified bitwidth.
932 /// Returns empty type if there is no appropriate target types.
933 QualType getRealTypeForBitwidth(unsigned DestWidth,
934 FloatModeKind ExplicitType) const;
935
936 bool AtomicUsesUnsupportedLibcall(const AtomicExpr *E) const;
937
938 const LangOptions& getLangOpts() const { return LangOpts; }
939
940 // If this condition is false, typo correction must be performed eagerly
941 // rather than delayed in many places, as it makes use of dependent types.
942 // the condition is false for clang's C-only codepath, as it doesn't support
943 // dependent types yet.
944 bool isDependenceAllowed() const {
945 return LangOpts.CPlusPlus || LangOpts.RecoveryAST;
946 }
947
948 const NoSanitizeList &getNoSanitizeList() const { return *NoSanitizeL; }
949
951 const QualType &Ty) const;
952
954 return *XRayFilter;
955 }
956
957 const ProfileList &getProfileList() const { return *ProfList; }
958
960
962 return FullSourceLoc(Loc,SourceMgr);
963 }
964
965 /// Return the C++ ABI kind that should be used. The C++ ABI can be overriden
966 /// at compile time with `-fc++-abi=`. If this is not provided, we instead use
967 /// the default ABI set by the target.
969
970 /// All comments in this translation unit.
972
973 /// True if comments are already loaded from ExternalASTSource.
974 mutable bool CommentsLoaded = false;
975
976 /// Mapping from declaration to directly attached comment.
977 ///
978 /// Raw comments are owned by Comments list. This mapping is populated
979 /// lazily.
980 mutable llvm::DenseMap<const Decl *, const RawComment *> DeclRawComments;
981
982 /// Mapping from canonical declaration to the first redeclaration in chain
983 /// that has a comment attached.
984 ///
985 /// Raw comments are owned by Comments list. This mapping is populated
986 /// lazily.
987 mutable llvm::DenseMap<const Decl *, const Decl *> RedeclChainComments;
988
989 /// Keeps track of redeclaration chains that don't have any comment attached.
990 /// Mapping from canonical declaration to redeclaration chain that has no
991 /// comments attached to any redeclaration. Specifically it's mapping to
992 /// the last redeclaration we've checked.
993 ///
994 /// Shall not contain declarations that have comments attached to any
995 /// redeclaration in their chain.
996 mutable llvm::DenseMap<const Decl *, const Decl *> CommentlessRedeclChains;
997
998 /// Mapping from declarations to parsed comments attached to any
999 /// redeclaration.
1000 mutable llvm::DenseMap<const Decl *, comments::FullComment *> ParsedComments;
1001
1002 /// Attaches \p Comment to \p OriginalD and to its redeclaration chain
1003 /// and removes the redeclaration chain from the set of commentless chains.
1004 ///
1005 /// Don't do anything if a comment has already been attached to \p OriginalD
1006 /// or its redeclaration chain.
1007 void cacheRawCommentForDecl(const Decl &OriginalD,
1008 const RawComment &Comment) const;
1009
1010 /// \returns searches \p CommentsInFile for doc comment for \p D.
1011 ///
1012 /// \p RepresentativeLocForDecl is used as a location for searching doc
1013 /// comments. \p CommentsInFile is a mapping offset -> comment of files in the
1014 /// same file where \p RepresentativeLocForDecl is.
1016 const Decl *D, const SourceLocation RepresentativeLocForDecl,
1017 const std::map<unsigned, RawComment *> &CommentsInFile) const;
1018
1019 /// Return the documentation comment attached to a given declaration,
1020 /// without looking into cache.
1022
1023public:
1024 void addComment(const RawComment &RC);
1025
1026 /// Return the documentation comment attached to a given declaration.
1027 /// Returns nullptr if no comment is attached.
1028 ///
1029 /// \param OriginalDecl if not nullptr, is set to declaration AST node that
1030 /// had the comment, if the comment we found comes from a redeclaration.
1031 const RawComment *
1033 const Decl **OriginalDecl = nullptr) const;
1034
1035 /// Searches existing comments for doc comments that should be attached to \p
1036 /// Decls. If any doc comment is found, it is parsed.
1037 ///
1038 /// Requirement: All \p Decls are in the same file.
1039 ///
1040 /// If the last comment in the file is already attached we assume
1041 /// there are not comments left to be attached to \p Decls.
1043 const Preprocessor *PP);
1044
1045 /// Return parsed documentation comment attached to a given declaration.
1046 /// Returns nullptr if no comment is attached.
1047 ///
1048 /// \param PP the Preprocessor used with this TU. Could be nullptr if
1049 /// preprocessor is not available.
1051 const Preprocessor *PP) const;
1052
1053 /// Return parsed documentation comment attached to a given declaration.
1054 /// Returns nullptr if no comment is attached. Does not look at any
1055 /// redeclarations of the declaration.
1057
1059 const Decl *D) const;
1060
1061private:
1062 mutable comments::CommandTraits CommentCommandTraits;
1063
1064 /// Iterator that visits import declarations.
1065 class import_iterator {
1066 ImportDecl *Import = nullptr;
1067
1068 public:
1069 using value_type = ImportDecl *;
1070 using reference = ImportDecl *;
1071 using pointer = ImportDecl *;
1072 using difference_type = int;
1073 using iterator_category = std::forward_iterator_tag;
1074
1075 import_iterator() = default;
1076 explicit import_iterator(ImportDecl *Import) : Import(Import) {}
1077
1078 reference operator*() const { return Import; }
1079 pointer operator->() const { return Import; }
1080
1081 import_iterator &operator++() {
1082 Import = ASTContext::getNextLocalImport(Import);
1083 return *this;
1084 }
1085
1086 import_iterator operator++(int) {
1087 import_iterator Other(*this);
1088 ++(*this);
1089 return Other;
1090 }
1091
1092 friend bool operator==(import_iterator X, import_iterator Y) {
1093 return X.Import == Y.Import;
1094 }
1095
1096 friend bool operator!=(import_iterator X, import_iterator Y) {
1097 return X.Import != Y.Import;
1098 }
1099 };
1100
1101public:
1103 return CommentCommandTraits;
1104 }
1105
1106 /// Retrieve the attributes for the given declaration.
1107 AttrVec& getDeclAttrs(const Decl *D);
1108
1109 /// Erase the attributes corresponding to the given declaration.
1110 void eraseDeclAttrs(const Decl *D);
1111
1112 /// If this variable is an instantiated static data member of a
1113 /// class template specialization, returns the templated static data member
1114 /// from which it was instantiated.
1115 // FIXME: Remove ?
1117 const VarDecl *Var);
1118
1119 /// Note that the static data member \p Inst is an instantiation of
1120 /// the static data member template \p Tmpl of a class template.
1123 SourceLocation PointOfInstantiation = SourceLocation());
1124
1127
1130
1131 /// If the given using decl \p Inst is an instantiation of
1132 /// another (possibly unresolved) using decl, return it.
1134
1135 /// Remember that the using decl \p Inst is an instantiation
1136 /// of the using decl \p Pattern of a class template.
1137 void setInstantiatedFromUsingDecl(NamedDecl *Inst, NamedDecl *Pattern);
1138
1139 /// If the given using-enum decl \p Inst is an instantiation of
1140 /// another using-enum decl, return it.
1142
1143 /// Remember that the using enum decl \p Inst is an instantiation
1144 /// of the using enum decl \p Pattern of a class template.
1146 UsingEnumDecl *Pattern);
1147
1150 UsingShadowDecl *Pattern);
1151
1153
1155
1156 // Access to the set of methods overridden by the given C++ method.
1157 using overridden_cxx_method_iterator = CXXMethodVector::const_iterator;
1160
1163
1164 unsigned overridden_methods_size(const CXXMethodDecl *Method) const;
1165
1167 llvm::iterator_range<overridden_cxx_method_iterator>;
1168
1170
1171 /// Note that the given C++ \p Method overrides the given \p
1172 /// Overridden method.
1174 const CXXMethodDecl *Overridden);
1175
1176 /// Return C++ or ObjC overridden methods for the given \p Method.
1177 ///
1178 /// An ObjC method is considered to override any method in the class's
1179 /// base classes, its protocols, or its categories' protocols, that has
1180 /// the same selector and is of the same kind (class or instance).
1181 /// A method in an implementation is not considered as overriding the same
1182 /// method in the interface or its categories.
1184 const NamedDecl *Method,
1185 SmallVectorImpl<const NamedDecl *> &Overridden) const;
1186
1187 /// Notify the AST context that a new import declaration has been
1188 /// parsed or implicitly created within this translation unit.
1189 void addedLocalImportDecl(ImportDecl *Import);
1190
1192 return Import->getNextLocalImport();
1193 }
1194
1195 using import_range = llvm::iterator_range<import_iterator>;
1196
1198 return import_range(import_iterator(FirstLocalImport), import_iterator());
1199 }
1200
1202 Decl *Result = MergedDecls.lookup(D);
1203 return Result ? Result : D;
1204 }
1205 void setPrimaryMergedDecl(Decl *D, Decl *Primary) {
1206 MergedDecls[D] = Primary;
1207 }
1208
1209 /// Note that the definition \p ND has been merged into module \p M,
1210 /// and should be visible whenever \p M is visible.
1212 bool NotifyListeners = true);
1213
1214 /// Clean up the merged definition list. Call this if you might have
1215 /// added duplicates into the list.
1217
1218 /// Get the additional modules in which the definition \p Def has
1219 /// been merged.
1221
1222 /// Add a declaration to the list of declarations that are initialized
1223 /// for a module. This will typically be a global variable (with internal
1224 /// linkage) that runs module initializers, such as the iostream initializer,
1225 /// or an ImportDecl nominating another module that has initializers.
1227
1229
1230 /// Get the initializations to perform when importing a module, if any.
1232
1233 /// Set the (C++20) module we are building.
1235
1236 /// Get module under construction, nullptr if this is not a C++20 module.
1237 Module *getCurrentNamedModule() const { return CurrentCXXNamedModule; }
1238
1239 /// If the two module \p M1 and \p M2 are in the same module.
1240 ///
1241 /// FIXME: The signature may be confusing since `clang::Module` means to
1242 /// a module fragment or a module unit but not a C++20 module.
1243 bool isInSameModule(const Module *M1, const Module *M2) const;
1244
1246 assert(TUDecl->getMostRecentDecl() == TUDecl &&
1247 "The active TU is not current one!");
1248 return TUDecl->getMostRecentDecl();
1249 }
1251 assert(!TUDecl || TUKind == TU_Incremental);
1253 if (TraversalScope.empty() || TraversalScope.back() == TUDecl)
1254 TraversalScope = {NewTUDecl};
1255 if (TUDecl)
1256 NewTUDecl->setPreviousDecl(TUDecl);
1257 TUDecl = NewTUDecl;
1258 }
1259
1261
1262#define BuiltinTemplate(BTName) BuiltinTemplateDecl *get##BTName##Decl() const;
1263#include "clang/Basic/BuiltinTemplates.inc"
1264
1265 // Builtin Types.
1269 CanQualType WCharTy; // [C++ 3.9.1p5].
1270 CanQualType WideCharTy; // Same as WCharTy in C++, integer type in C99.
1271 CanQualType WIntTy; // [C99 7.24.1], integer type unchanged by default promotions.
1272 CanQualType Char8Ty; // [C++20 proposal]
1273 CanQualType Char16Ty; // [C++0x 3.9.1p5], integer type in C99.
1274 CanQualType Char32Ty; // [C++0x 3.9.1p5], integer type in C99.
1280 LongAccumTy; // ISO/IEC JTC1 SC22 WG14 N1169 Extension
1290 CanQualType HalfTy; // [OpenCL 6.1.1.1], ARM NEON
1292 CanQualType Float16Ty; // C11 extension ISO/IEC TS 18661-3
1300#define IMAGE_TYPE(ImgType, Id, SingletonId, Access, Suffix) \
1301 CanQualType SingletonId;
1302#include "clang/Basic/OpenCLImageTypes.def"
1308#define EXT_OPAQUE_TYPE(ExtType, Id, Ext) \
1309 CanQualType Id##Ty;
1310#include "clang/Basic/OpenCLExtensionTypes.def"
1311#define SVE_TYPE(Name, Id, SingletonId) \
1312 CanQualType SingletonId;
1313#include "clang/Basic/AArch64ACLETypes.def"
1314#define PPC_VECTOR_TYPE(Name, Id, Size) \
1315 CanQualType Id##Ty;
1316#include "clang/Basic/PPCTypes.def"
1317#define RVV_TYPE(Name, Id, SingletonId) \
1318 CanQualType SingletonId;
1319#include "clang/Basic/RISCVVTypes.def"
1320#define WASM_TYPE(Name, Id, SingletonId) CanQualType SingletonId;
1321#include "clang/Basic/WebAssemblyReferenceTypes.def"
1322#define AMDGPU_TYPE(Name, Id, SingletonId, Width, Align) \
1323 CanQualType SingletonId;
1324#include "clang/Basic/AMDGPUTypes.def"
1325#define HLSL_INTANGIBLE_TYPE(Name, Id, SingletonId) CanQualType SingletonId;
1326#include "clang/Basic/HLSLIntangibleTypes.def"
1327
1328 // Types for deductions in C++0x [stmt.ranged]'s desugaring. Built on demand.
1329 mutable QualType AutoDeductTy; // Deduction against 'auto'.
1330 mutable QualType AutoRRefDeductTy; // Deduction against 'auto &&'.
1331
1332 // Decl used to help define __builtin_va_list for some targets.
1333 // The decl is built when constructing 'BuiltinVaListDecl'.
1334 mutable Decl *VaListTagDecl = nullptr;
1335
1336 // Implicitly-declared type 'struct _GUID'.
1337 mutable TagDecl *MSGuidTagDecl = nullptr;
1338
1339 // Implicitly-declared type 'struct type_info'.
1340 mutable TagDecl *MSTypeInfoTagDecl = nullptr;
1341
1342 /// Keep track of CUDA/HIP device-side variables ODR-used by host code.
1343 /// This does not include extern shared variables used by device host
1344 /// functions as addresses of shared variables are per warp, therefore
1345 /// cannot be accessed by host code.
1346 llvm::DenseSet<const VarDecl *> CUDADeviceVarODRUsedByHost;
1347
1348 /// Keep track of CUDA/HIP external kernels or device variables ODR-used by
1349 /// host code. SetVector is used to maintain the order.
1350 llvm::SetVector<const ValueDecl *> CUDAExternalDeviceDeclODRUsedByHost;
1351
1352 /// Keep track of CUDA/HIP implicit host device functions used on device side
1353 /// in device compilation.
1354 llvm::DenseSet<const FunctionDecl *> CUDAImplicitHostDeviceFunUsedByDevice;
1355
1356 /// Map of SYCL kernels indexed by the unique type used to name the kernel.
1357 /// Entries are not serialized but are recreated on deserialization of a
1358 /// sycl_kernel_entry_point attributed function declaration.
1359 llvm::DenseMap<CanQualType, SYCLKernelInfo> SYCLKernels;
1360
1361 /// For capturing lambdas with an explicit object parameter whose type is
1362 /// derived from the lambda type, we need to perform derived-to-base
1363 /// conversion so we can access the captures; the cast paths for that
1364 /// are stored here.
1365 llvm::DenseMap<const CXXMethodDecl *, CXXCastPath> LambdaCastPaths;
1366
1368 SelectorTable &sels, Builtin::Context &builtins,
1370 ASTContext(const ASTContext &) = delete;
1371 ASTContext &operator=(const ASTContext &) = delete;
1372 ~ASTContext();
1373
1374 /// Attach an external AST source to the AST context.
1375 ///
1376 /// The external AST source provides the ability to load parts of
1377 /// the abstract syntax tree as needed from some external storage,
1378 /// e.g., a precompiled header.
1380
1381 /// Retrieve a pointer to the external AST source associated
1382 /// with this AST context, if any.
1384 return ExternalSource.get();
1385 }
1386
1387 /// Retrieve a pointer to the external AST source associated
1388 /// with this AST context, if any. Returns as an IntrusiveRefCntPtr.
1392
1393 /// Attach an AST mutation listener to the AST context.
1394 ///
1395 /// The AST mutation listener provides the ability to track modifications to
1396 /// the abstract syntax tree entities committed after they were initially
1397 /// created.
1399 this->Listener = Listener;
1400 }
1401
1402 /// Retrieve a pointer to the AST mutation listener associated
1403 /// with this AST context, if any.
1405
1406 void PrintStats() const;
1407 const SmallVectorImpl<Type *>& getTypes() const { return Types; }
1408
1410 const IdentifierInfo *II) const;
1411
1412 /// Create a new implicit TU-level CXXRecordDecl or RecordDecl
1413 /// declaration.
1415 StringRef Name,
1416 RecordDecl::TagKind TK = RecordDecl::TagKind::Struct) const;
1417
1418 /// Create a new implicit TU-level typedef declaration.
1419 TypedefDecl *buildImplicitTypedef(QualType T, StringRef Name) const;
1420
1421 /// Retrieve the declaration for the 128-bit signed integer type.
1422 TypedefDecl *getInt128Decl() const;
1423
1424 /// Retrieve the declaration for the 128-bit unsigned integer type.
1425 TypedefDecl *getUInt128Decl() const;
1426
1427 //===--------------------------------------------------------------------===//
1428 // Type Constructors
1429 //===--------------------------------------------------------------------===//
1430
1431private:
1432 /// Return a type with extended qualifiers.
1433 QualType getExtQualType(const Type *Base, Qualifiers Quals) const;
1434
1435 QualType getPipeType(QualType T, bool ReadOnly) const;
1436
1437public:
1438 /// Return the uniqued reference to the type for an address space
1439 /// qualified type with the specified type and address space.
1440 ///
1441 /// The resulting type has a union of the qualifiers from T and the address
1442 /// space. If T already has an address space specifier, it is silently
1443 /// replaced.
1444 QualType getAddrSpaceQualType(QualType T, LangAS AddressSpace) const;
1445
1446 /// Remove any existing address space on the type and returns the type
1447 /// with qualifiers intact (or that's the idea anyway)
1448 ///
1449 /// The return type should be T with all prior qualifiers minus the address
1450 /// space.
1452
1453 /// Return the "other" discriminator used for the pointer auth schema used for
1454 /// vtable pointers in instances of the requested type.
1455 uint16_t
1457
1458 /// Return the "other" type-specific discriminator for the given type.
1460
1461 /// Apply Objective-C protocol qualifiers to the given type.
1462 /// \param allowOnPointerType specifies if we can apply protocol
1463 /// qualifiers on ObjCObjectPointerType. It can be set to true when
1464 /// constructing the canonical type of a Objective-C type parameter.
1466 ArrayRef<ObjCProtocolDecl *> protocols, bool &hasError,
1467 bool allowOnPointerType = false) const;
1468
1469 /// Return the uniqued reference to the type for an Objective-C
1470 /// gc-qualified type.
1471 ///
1472 /// The resulting type has a union of the qualifiers from T and the gc
1473 /// attribute.
1475
1476 /// Remove the existing address space on the type if it is a pointer size
1477 /// address space and return the type with qualifiers intact.
1479
1480 /// Return the uniqued reference to the type for a \c restrict
1481 /// qualified type.
1482 ///
1483 /// The resulting type has a union of the qualifiers from \p T and
1484 /// \c restrict.
1486 return T.withFastQualifiers(Qualifiers::Restrict);
1487 }
1488
1489 /// Return the uniqued reference to the type for a \c volatile
1490 /// qualified type.
1491 ///
1492 /// The resulting type has a union of the qualifiers from \p T and
1493 /// \c volatile.
1495 return T.withFastQualifiers(Qualifiers::Volatile);
1496 }
1497
1498 /// Return the uniqued reference to the type for a \c const
1499 /// qualified type.
1500 ///
1501 /// The resulting type has a union of the qualifiers from \p T and \c const.
1502 ///
1503 /// It can be reasonably expected that this will always be equivalent to
1504 /// calling T.withConst().
1505 QualType getConstType(QualType T) const { return T.withConst(); }
1506
1507 /// Rebuild a type, preserving any existing type sugar. For function types,
1508 /// you probably want to just use \c adjustFunctionResultType and friends
1509 /// instead.
1511 llvm::function_ref<QualType(QualType)> Adjust) const;
1512
1513 /// Change the ExtInfo on a function type.
1515 FunctionType::ExtInfo EInfo);
1516
1517 /// Change the result type of a function type, preserving sugar such as
1518 /// attributed types.
1520 QualType NewResultType);
1521
1522 /// Adjust the given function result type.
1524
1525 /// Change the result type of a function type once it is deduced.
1527
1528 /// Get a function type and produce the equivalent function type with the
1529 /// specified exception specification. Type sugar that can be present on a
1530 /// declaration of a function with an exception specification is permitted
1531 /// and preserved. Other type sugar (for instance, typedefs) is not.
1533 QualType Orig, const FunctionProtoType::ExceptionSpecInfo &ESI) const;
1534
1535 /// Determine whether two function types are the same, ignoring
1536 /// exception specifications in cases where they're part of the type.
1538
1539 /// Change the exception specification on a function once it is
1540 /// delay-parsed, instantiated, or computed.
1543 bool AsWritten = false);
1544
1545 /// Get a function type and produce the equivalent function type where
1546 /// pointer size address spaces in the return type and parameter types are
1547 /// replaced with the default address space.
1549
1550 /// Determine whether two function types are the same, ignoring pointer sizes
1551 /// in the return type and parameter types.
1553
1554 /// Get or construct a function type that is equivalent to the input type
1555 /// except that the parameter ABI annotations are stripped.
1557
1558 /// Determine if two function types are the same, ignoring parameter ABI
1559 /// annotations.
1561
1562 /// Return the uniqued reference to the type for a complex
1563 /// number with the specified element type.
1568
1569 /// Return the uniqued reference to the type for a pointer to
1570 /// the specified type.
1575
1576 QualType
1577 getCountAttributedType(QualType T, Expr *CountExpr, bool CountInBytes,
1578 bool OrNull,
1579 ArrayRef<TypeCoupledDeclRefInfo> DependentDecls) const;
1580
1581 /// Return the uniqued reference to a type adjusted from the original
1582 /// type to a new type.
1588
1589 /// Return the uniqued reference to the decayed version of the given
1590 /// type. Can only be called on array and function types which decay to
1591 /// pointer types.
1596 /// Return the uniqued reference to a specified decay from the original
1597 /// type to the decayed type.
1598 QualType getDecayedType(QualType Orig, QualType Decayed) const;
1599
1600 /// Return the uniqued reference to a specified array parameter type from the
1601 /// original array type.
1603
1604 /// Return the uniqued reference to the atomic type for the specified
1605 /// type.
1607
1608 /// Return the uniqued reference to the type for a block of the
1609 /// specified type.
1611
1612 /// Gets the struct used to keep track of the descriptor for pointer to
1613 /// blocks.
1615
1616 /// Return a read_only pipe type for the specified type.
1618
1619 /// Return a write_only pipe type for the specified type.
1621
1622 /// Return a bit-precise integer type with the specified signedness and bit
1623 /// count.
1624 QualType getBitIntType(bool Unsigned, unsigned NumBits) const;
1625
1626 /// Return a dependent bit-precise integer type with the specified signedness
1627 /// and bit count.
1628 QualType getDependentBitIntType(bool Unsigned, Expr *BitsExpr) const;
1629
1631
1632 /// Gets the struct used to keep track of the extended descriptor for
1633 /// pointer to blocks.
1635
1636 /// Map an AST Type to an OpenCLTypeKind enum value.
1637 OpenCLTypeKind getOpenCLTypeKind(const Type *T) const;
1638
1639 /// Get address space for OpenCL type.
1640 LangAS getOpenCLTypeAddrSpace(const Type *T) const;
1641
1642 /// Returns default address space based on OpenCL version and enabled features
1644 return LangOpts.OpenCLGenericAddressSpace ? LangAS::opencl_generic
1646 }
1647
1649 cudaConfigureCallDecl = FD;
1650 }
1651
1653 return cudaConfigureCallDecl;
1654 }
1655
1656 /// Returns true iff we need copy/dispose helpers for the given type.
1657 bool BlockRequiresCopying(QualType Ty, const VarDecl *D);
1658
1659 /// Returns true, if given type has a known lifetime. HasByrefExtendedLayout
1660 /// is set to false in this case. If HasByrefExtendedLayout returns true,
1661 /// byref variable has extended lifetime.
1662 bool getByrefLifetime(QualType Ty,
1663 Qualifiers::ObjCLifetime &Lifetime,
1664 bool &HasByrefExtendedLayout) const;
1665
1666 /// Return the uniqued reference to the type for an lvalue reference
1667 /// to the specified type.
1668 QualType getLValueReferenceType(QualType T, bool SpelledAsLValue = true)
1669 const;
1670
1671 /// Return the uniqued reference to the type for an rvalue reference
1672 /// to the specified type.
1674
1675 /// Return the uniqued reference to the type for a member pointer to
1676 /// the specified type in the specified nested name.
1678 const CXXRecordDecl *Cls) const;
1679
1680 /// Return a non-unique reference to the type for a variable array of
1681 /// the specified element type.
1684 unsigned IndexTypeQuals) const;
1685
1686 /// Return a non-unique reference to the type for a dependently-sized
1687 /// array of the specified element type.
1688 ///
1689 /// FIXME: We will need these to be uniqued, or at least comparable, at some
1690 /// point.
1693 unsigned IndexTypeQuals) const;
1694
1695 /// Return a unique reference to the type for an incomplete array of
1696 /// the specified element type.
1698 unsigned IndexTypeQuals) const;
1699
1700 /// Return the unique reference to the type for a constant array of
1701 /// the specified element type.
1702 QualType getConstantArrayType(QualType EltTy, const llvm::APInt &ArySize,
1703 const Expr *SizeExpr, ArraySizeModifier ASM,
1704 unsigned IndexTypeQuals) const;
1705
1706 /// Return a type for a constant array for a string literal of the
1707 /// specified element type and length.
1708 QualType getStringLiteralArrayType(QualType EltTy, unsigned Length) const;
1709
1710 /// Returns a vla type where known sizes are replaced with [*].
1712
1713 // Convenience struct to return information about a builtin vector type.
1722
1723 /// Returns the element type, element count and number of vectors
1724 /// (in case of tuple) for a builtin vector type.
1725 BuiltinVectorTypeInfo
1726 getBuiltinVectorTypeInfo(const BuiltinType *VecTy) const;
1727
1728 /// Return the unique reference to a scalable vector type of the specified
1729 /// element type and scalable number of elements.
1730 /// For RISC-V, number of fields is also provided when it fetching for
1731 /// tuple type.
1732 ///
1733 /// \pre \p EltTy must be a built-in type.
1734 QualType getScalableVectorType(QualType EltTy, unsigned NumElts,
1735 unsigned NumFields = 1) const;
1736
1737 /// Return a WebAssembly externref type.
1739
1740 /// Return the unique reference to a vector type of the specified
1741 /// element type and size.
1742 ///
1743 /// \pre \p VectorType must be a built-in type.
1744 QualType getVectorType(QualType VectorType, unsigned NumElts,
1745 VectorKind VecKind) const;
1746 /// Return the unique reference to the type for a dependently sized vector of
1747 /// the specified element type.
1749 SourceLocation AttrLoc,
1750 VectorKind VecKind) const;
1751
1752 /// Return the unique reference to an extended vector type
1753 /// of the specified element type and size.
1754 ///
1755 /// \pre \p VectorType must be a built-in type.
1756 QualType getExtVectorType(QualType VectorType, unsigned NumElts) const;
1757
1758 /// \pre Return a non-unique reference to the type for a dependently-sized
1759 /// vector of the specified element type.
1760 ///
1761 /// FIXME: We will need these to be uniqued, or at least comparable, at some
1762 /// point.
1764 Expr *SizeExpr,
1765 SourceLocation AttrLoc) const;
1766
1767 /// Return the unique reference to the matrix type of the specified element
1768 /// type and size
1769 ///
1770 /// \pre \p ElementType must be a valid matrix element type (see
1771 /// MatrixType::isValidElementType).
1772 QualType getConstantMatrixType(QualType ElementType, unsigned NumRows,
1773 unsigned NumColumns) const;
1774
1775 /// Return the unique reference to the matrix type of the specified element
1776 /// type and size
1777 QualType getDependentSizedMatrixType(QualType ElementType, Expr *RowExpr,
1778 Expr *ColumnExpr,
1779 SourceLocation AttrLoc) const;
1780
1782 Expr *AddrSpaceExpr,
1783 SourceLocation AttrLoc) const;
1784
1785 /// Return a K&R style C function type like 'int()'.
1787 const FunctionType::ExtInfo &Info) const;
1788
1792
1793 /// Return a normal function type with a typed argument list.
1795 const FunctionProtoType::ExtProtoInfo &EPI) const {
1796 return getFunctionTypeInternal(ResultTy, Args, EPI, false);
1797 }
1798
1800
1801private:
1802 /// Return a normal function type with a typed argument list.
1803 QualType getFunctionTypeInternal(QualType ResultTy, ArrayRef<QualType> Args,
1805 bool OnlyWantCanonical) const;
1806 QualType
1807 getAutoTypeInternal(QualType DeducedType, AutoTypeKeyword Keyword,
1808 bool IsDependent, bool IsPack = false,
1809 TemplateDecl *TypeConstraintConcept = nullptr,
1810 ArrayRef<TemplateArgument> TypeConstraintArgs = {},
1811 bool IsCanon = false) const;
1812
1813public:
1815 NestedNameSpecifier Qualifier,
1816 const TypeDecl *Decl) const;
1817
1818 /// Return the unique reference to the type for the specified type
1819 /// declaration.
1820 QualType getTypeDeclType(const TypeDecl *Decl) const;
1821
1822 /// Use the normal 'getFooBarType' constructors to obtain these types.
1823 QualType getTypeDeclType(const TagDecl *) const = delete;
1824 QualType getTypeDeclType(const TypedefDecl *) const = delete;
1825 QualType getTypeDeclType(const TypeAliasDecl *) const = delete;
1827
1829
1831 NestedNameSpecifier Qualifier, const UsingShadowDecl *D,
1832 QualType UnderlyingType = QualType()) const;
1833
1834 /// Return the unique reference to the type for the specified
1835 /// typedef-name decl.
1836 /// FIXME: TypeMatchesDeclOrNone is a workaround for a serialization issue:
1837 /// The decl underlying type might still not be available.
1840 const TypedefNameDecl *Decl, QualType UnderlyingType = QualType(),
1841 std::optional<bool> TypeMatchesDeclOrNone = std::nullopt) const;
1842
1843 CanQualType getCanonicalTagType(const TagDecl *TD) const;
1845 NestedNameSpecifier Qualifier, const TagDecl *TD,
1846 bool OwnsTag) const;
1847
1848private:
1849 UnresolvedUsingType *getUnresolvedUsingTypeInternal(
1851 const UnresolvedUsingTypenameDecl *D, void *InsertPos,
1852 const Type *CanonicalType) const;
1853
1854 TagType *getTagTypeInternal(ElaboratedTypeKeyword Keyword,
1855 NestedNameSpecifier Qualifier, const TagDecl *Tag,
1856 bool OwnsTag, bool IsInjected,
1857 const Type *CanonicalType,
1858 bool WithFoldingSetNode) const;
1859
1860public:
1861 /// Compute BestType and BestPromotionType for an enum based on the highest
1862 /// number of negative and positive bits of its elements.
1863 /// Returns true if enum width is too large.
1864 bool computeBestEnumTypes(bool IsPacked, unsigned NumNegativeBits,
1865 unsigned NumPositiveBits, QualType &BestType,
1866 QualType &BestPromotionType);
1867
1868 /// Determine whether the given integral value is representable within
1869 /// the given type T.
1870 bool isRepresentableIntegerValue(llvm::APSInt &Value, QualType T);
1871
1872 /// Compute NumNegativeBits and NumPositiveBits for an enum based on
1873 /// the constant values of its enumerators.
1874 template <typename RangeT>
1875 bool computeEnumBits(RangeT EnumConstants, unsigned &NumNegativeBits,
1876 unsigned &NumPositiveBits) {
1877 NumNegativeBits = 0;
1878 NumPositiveBits = 0;
1879 bool MembersRepresentableByInt = true;
1880 for (auto *Elem : EnumConstants) {
1881 EnumConstantDecl *ECD = cast_or_null<EnumConstantDecl>(Elem);
1882 if (!ECD)
1883 continue; // Already issued a diagnostic.
1884
1885 llvm::APSInt InitVal = ECD->getInitVal();
1886 if (InitVal.isUnsigned() || InitVal.isNonNegative()) {
1887 // If the enumerator is zero that should still be counted as a positive
1888 // bit since we need a bit to store the value zero.
1889 unsigned ActiveBits = InitVal.getActiveBits();
1890 NumPositiveBits = std::max({NumPositiveBits, ActiveBits, 1u});
1891 } else {
1892 NumNegativeBits =
1893 std::max(NumNegativeBits, InitVal.getSignificantBits());
1894 }
1895
1896 MembersRepresentableByInt &= isRepresentableIntegerValue(InitVal, IntTy);
1897 }
1898
1899 // If we have an empty set of enumerators we still need one bit.
1900 // From [dcl.enum]p8
1901 // If the enumerator-list is empty, the values of the enumeration are as if
1902 // the enumeration had a single enumerator with value 0
1903 if (!NumPositiveBits && !NumNegativeBits)
1904 NumPositiveBits = 1;
1905
1906 return MembersRepresentableByInt;
1907 }
1908
1912 NestedNameSpecifier Qualifier,
1913 const UnresolvedUsingTypenameDecl *D) const;
1914
1915 QualType getAttributedType(attr::Kind attrKind, QualType modifiedType,
1916 QualType equivalentType,
1917 const Attr *attr = nullptr) const;
1918
1919 QualType getAttributedType(const Attr *attr, QualType modifiedType,
1920 QualType equivalentType) const;
1921
1922 QualType getAttributedType(NullabilityKind nullability, QualType modifiedType,
1923 QualType equivalentType);
1924
1925 QualType getBTFTagAttributedType(const BTFTypeTagAttr *BTFAttr,
1926 QualType Wrapped) const;
1927
1929 QualType Wrapped, QualType Contained,
1930 const HLSLAttributedResourceType::Attributes &Attrs);
1931
1932 QualType getHLSLInlineSpirvType(uint32_t Opcode, uint32_t Size,
1933 uint32_t Alignment,
1934 ArrayRef<SpirvOperand> Operands);
1935
1937 Decl *AssociatedDecl, unsigned Index,
1938 UnsignedOrNone PackIndex,
1939 bool Final) const;
1941 unsigned Index, bool Final,
1942 const TemplateArgument &ArgPack);
1944
1945 QualType
1946 getTemplateTypeParmType(unsigned Depth, unsigned Index,
1947 bool ParameterPack,
1948 TemplateTypeParmDecl *ParmDecl = nullptr) const;
1949
1952 ArrayRef<TemplateArgument> CanonicalArgs) const;
1953
1954 QualType
1956 ArrayRef<TemplateArgument> SpecifiedArgs,
1957 ArrayRef<TemplateArgument> CanonicalArgs,
1958 QualType Underlying = QualType()) const;
1959
1960 QualType
1962 ArrayRef<TemplateArgumentLoc> SpecifiedArgs,
1963 ArrayRef<TemplateArgument> CanonicalArgs,
1964 QualType Canon = QualType()) const;
1965
1967 ElaboratedTypeKeyword Keyword, SourceLocation ElaboratedKeywordLoc,
1968 NestedNameSpecifierLoc QualifierLoc, SourceLocation TemplateKeywordLoc,
1970 const TemplateArgumentListInfo &SpecifiedArgs,
1971 ArrayRef<TemplateArgument> CanonicalArgs,
1972 QualType Canon = QualType()) const;
1973
1974 QualType getParenType(QualType NamedType) const;
1975
1977 const IdentifierInfo *MacroII) const;
1978
1981 const IdentifierInfo *Name) const;
1982
1984
1985 /// Form a pack expansion type with the given pattern.
1986 /// \param NumExpansions The number of expansions for the pack, if known.
1987 /// \param ExpectPackInType If \c false, we should not expect \p Pattern to
1988 /// contain an unexpanded pack. This only makes sense if the pack
1989 /// expansion is used in a context where the arity is inferred from
1990 /// elsewhere, such as if the pattern contains a placeholder type or
1991 /// if this is the canonical type of another pack expansion type.
1993 bool ExpectPackInType = true) const;
1994
1996 ObjCInterfaceDecl *PrevDecl = nullptr) const;
1997
1998 /// Legacy interface: cannot provide type arguments or __kindof.
2000 ObjCProtocolDecl * const *Protocols,
2001 unsigned NumProtocols) const;
2002
2004 ArrayRef<QualType> typeArgs,
2006 bool isKindOf) const;
2007
2009 ArrayRef<ObjCProtocolDecl *> protocols) const;
2011 ObjCTypeParamDecl *New) const;
2012
2014
2015 /// QIdProtocolsAdoptObjCObjectProtocols - Checks that protocols in
2016 /// QT's qualified-id protocol list adopt all protocols in IDecl's list
2017 /// of protocols.
2019 ObjCInterfaceDecl *IDecl);
2020
2021 /// Return a ObjCObjectPointerType type for the given ObjCObjectType.
2023
2024 /// C23 feature and GCC extension.
2025 QualType getTypeOfExprType(Expr *E, TypeOfKind Kind) const;
2026 QualType getTypeOfType(QualType QT, TypeOfKind Kind) const;
2027
2028 QualType getReferenceQualifiedType(const Expr *e) const;
2029
2030 /// C++11 decltype.
2031 QualType getDecltypeType(Expr *e, QualType UnderlyingType) const;
2032
2033 QualType getPackIndexingType(QualType Pattern, Expr *IndexExpr,
2034 bool FullySubstituted = false,
2035 ArrayRef<QualType> Expansions = {},
2036 UnsignedOrNone Index = std::nullopt) const;
2037
2038 /// Unary type transforms
2039 QualType getUnaryTransformType(QualType BaseType, QualType UnderlyingType,
2040 UnaryTransformType::UTTKind UKind) const;
2041
2042 /// C++11 deduced auto type.
2043 QualType
2044 getAutoType(QualType DeducedType, AutoTypeKeyword Keyword, bool IsDependent,
2045 bool IsPack = false,
2046 TemplateDecl *TypeConstraintConcept = nullptr,
2047 ArrayRef<TemplateArgument> TypeConstraintArgs = {}) const;
2048
2049 /// C++11 deduction pattern for 'auto' type.
2050 QualType getAutoDeductType() const;
2051
2052 /// C++11 deduction pattern for 'auto &&' type.
2053 QualType getAutoRRefDeductType() const;
2054
2055 /// Remove any type constraints from a template parameter type, for
2056 /// equivalence comparison of template parameters.
2057 QualType getUnconstrainedType(QualType T) const;
2058
2059 /// C++17 deduced class template specialization type.
2062 QualType DeducedType,
2063 bool IsDependent) const;
2064
2065private:
2066 QualType getDeducedTemplateSpecializationTypeInternal(
2068 QualType DeducedType, bool IsDependent, QualType Canon) const;
2069
2070public:
2071 /// Return the unique type for "size_t" (C99 7.17), defined in
2072 /// <stddef.h>.
2073 ///
2074 /// The sizeof operator requires this (C99 6.5.3.4p4).
2075 QualType getSizeType() const;
2076
2078
2079 /// Return the unique signed counterpart of
2080 /// the integer type corresponding to size_t.
2081 QualType getSignedSizeType() const;
2082
2083 /// Return the unique type for "intmax_t" (C99 7.18.1.5), defined in
2084 /// <stdint.h>.
2085 CanQualType getIntMaxType() const;
2086
2087 /// Return the unique type for "uintmax_t" (C99 7.18.1.5), defined in
2088 /// <stdint.h>.
2090
2091 /// Return the unique wchar_t type available in C++ (and available as
2092 /// __wchar_t as a Microsoft extension).
2093 QualType getWCharType() const { return WCharTy; }
2094
2095 /// Return the type of wide characters. In C++, this returns the
2096 /// unique wchar_t type. In C99, this returns a type compatible with the type
2097 /// defined in <stddef.h> as defined by the target.
2099
2100 /// Return the type of "signed wchar_t".
2101 ///
2102 /// Used when in C++, as a GCC extension.
2104
2105 /// Return the type of "unsigned wchar_t".
2106 ///
2107 /// Used when in C++, as a GCC extension.
2109
2110 /// In C99, this returns a type compatible with the type
2111 /// defined in <stddef.h> as defined by the target.
2112 QualType getWIntType() const { return WIntTy; }
2113
2114 /// Return a type compatible with "intptr_t" (C99 7.18.1.4),
2115 /// as defined by the target.
2116 QualType getIntPtrType() const;
2117
2118 /// Return a type compatible with "uintptr_t" (C99 7.18.1.4),
2119 /// as defined by the target.
2120 QualType getUIntPtrType() const;
2121
2122 /// Return the unique type for "ptrdiff_t" (C99 7.17) defined in
2123 /// <stddef.h>. Pointer - pointer requires this (C99 6.5.6p9).
2125
2126 /// Return the unique unsigned counterpart of "ptrdiff_t"
2127 /// integer type. The standard (C11 7.21.6.1p7) refers to this type
2128 /// in the definition of %tu format specifier.
2130
2131 /// Return the unique type for "pid_t" defined in
2132 /// <sys/types.h>. We need this to compute the correct type for vfork().
2133 QualType getProcessIDType() const;
2134
2135 /// Return the C structure type used to represent constant CFStrings.
2137
2138 /// Returns the C struct type for objc_super
2139 QualType getObjCSuperType() const;
2140 void setObjCSuperType(QualType ST) { ObjCSuperType = ST; }
2141
2142 /// Get the structure type used to representation CFStrings, or NULL
2143 /// if it hasn't yet been built.
2145 if (CFConstantStringTypeDecl)
2147 /*Qualifier=*/std::nullopt,
2148 CFConstantStringTypeDecl);
2149 return QualType();
2150 }
2154
2155 // This setter/getter represents the ObjC type for an NSConstantString.
2158 return ObjCConstantStringType;
2159 }
2160
2162 return ObjCNSStringType;
2163 }
2164
2166 ObjCNSStringType = T;
2167 }
2168
2169 /// Retrieve the type that \c id has been defined to, which may be
2170 /// different from the built-in \c id if \c id has been typedef'd.
2172 if (ObjCIdRedefinitionType.isNull())
2173 return getObjCIdType();
2174 return ObjCIdRedefinitionType;
2175 }
2176
2177 /// Set the user-written type that redefines \c id.
2179 ObjCIdRedefinitionType = RedefType;
2180 }
2181
2182 /// Retrieve the type that \c Class has been defined to, which may be
2183 /// different from the built-in \c Class if \c Class has been typedef'd.
2185 if (ObjCClassRedefinitionType.isNull())
2186 return getObjCClassType();
2187 return ObjCClassRedefinitionType;
2188 }
2189
2190 /// Set the user-written type that redefines 'SEL'.
2192 ObjCClassRedefinitionType = RedefType;
2193 }
2194
2195 /// Retrieve the type that 'SEL' has been defined to, which may be
2196 /// different from the built-in 'SEL' if 'SEL' has been typedef'd.
2198 if (ObjCSelRedefinitionType.isNull())
2199 return getObjCSelType();
2200 return ObjCSelRedefinitionType;
2201 }
2202
2203 /// Set the user-written type that redefines 'SEL'.
2205 ObjCSelRedefinitionType = RedefType;
2206 }
2207
2208 /// Retrieve the identifier 'NSObject'.
2210 if (!NSObjectName) {
2211 NSObjectName = &Idents.get("NSObject");
2212 }
2213
2214 return NSObjectName;
2215 }
2216
2217 /// Retrieve the identifier 'NSCopying'.
2219 if (!NSCopyingName) {
2220 NSCopyingName = &Idents.get("NSCopying");
2221 }
2222
2223 return NSCopyingName;
2224 }
2225
2227
2229
2230 /// Retrieve the identifier 'bool'.
2232 if (!BoolName)
2233 BoolName = &Idents.get("bool");
2234 return BoolName;
2235 }
2236
2237#define BuiltinTemplate(BTName) \
2238 IdentifierInfo *get##BTName##Name() const { \
2239 if (!Name##BTName) \
2240 Name##BTName = &Idents.get(#BTName); \
2241 return Name##BTName; \
2242 }
2243#include "clang/Basic/BuiltinTemplates.inc"
2244
2245 /// Retrieve the Objective-C "instancetype" type.
2248 /*Qualifier=*/std::nullopt,
2250 }
2251
2252 /// Retrieve the typedef declaration corresponding to the Objective-C
2253 /// "instancetype" type.
2255
2256 /// Set the type for the C FILE type.
2257 void setFILEDecl(TypeDecl *FILEDecl) { this->FILEDecl = FILEDecl; }
2258
2259 /// Retrieve the C FILE type.
2261 if (FILEDecl)
2263 /*Qualifier=*/std::nullopt, FILEDecl);
2264 return QualType();
2265 }
2266
2267 /// Set the type for the C jmp_buf type.
2268 void setjmp_bufDecl(TypeDecl *jmp_bufDecl) {
2269 this->jmp_bufDecl = jmp_bufDecl;
2270 }
2271
2272 /// Retrieve the C jmp_buf type.
2274 if (jmp_bufDecl)
2276 /*Qualifier=*/std::nullopt, jmp_bufDecl);
2277 return QualType();
2278 }
2279
2280 /// Set the type for the C sigjmp_buf type.
2281 void setsigjmp_bufDecl(TypeDecl *sigjmp_bufDecl) {
2282 this->sigjmp_bufDecl = sigjmp_bufDecl;
2283 }
2284
2285 /// Retrieve the C sigjmp_buf type.
2287 if (sigjmp_bufDecl)
2289 /*Qualifier=*/std::nullopt, sigjmp_bufDecl);
2290 return QualType();
2291 }
2292
2293 /// Set the type for the C ucontext_t type.
2294 void setucontext_tDecl(TypeDecl *ucontext_tDecl) {
2295 this->ucontext_tDecl = ucontext_tDecl;
2296 }
2297
2298 /// Retrieve the C ucontext_t type.
2300 if (ucontext_tDecl)
2302 /*Qualifier=*/std::nullopt, ucontext_tDecl);
2303 return QualType();
2304 }
2305
2306 /// The result type of logical operations, '<', '>', '!=', etc.
2308 return getLangOpts().CPlusPlus ? BoolTy : IntTy;
2309 }
2310
2311 /// Emit the Objective-CC type encoding for the given type \p T into
2312 /// \p S.
2313 ///
2314 /// If \p Field is specified then record field names are also encoded.
2315 void getObjCEncodingForType(QualType T, std::string &S,
2316 const FieldDecl *Field=nullptr,
2317 QualType *NotEncodedT=nullptr) const;
2318
2319 /// Emit the Objective-C property type encoding for the given
2320 /// type \p T into \p S.
2321 void getObjCEncodingForPropertyType(QualType T, std::string &S) const;
2322
2324
2325 /// Put the string version of the type qualifiers \p QT into \p S.
2327 std::string &S) const;
2328
2329 /// Emit the encoded type for the function \p Decl into \p S.
2330 ///
2331 /// This is in the same format as Objective-C method encodings.
2332 ///
2333 /// \returns true if an error occurred (e.g., because one of the parameter
2334 /// types is incomplete), false otherwise.
2335 std::string getObjCEncodingForFunctionDecl(const FunctionDecl *Decl) const;
2336
2337 /// Emit the encoded type for the method declaration \p Decl into
2338 /// \p S.
2340 bool Extended = false) const;
2341
2342 /// Return the encoded type for this block declaration.
2343 std::string getObjCEncodingForBlock(const BlockExpr *blockExpr) const;
2344
2345 /// getObjCEncodingForPropertyDecl - Return the encoded type for
2346 /// this method declaration. If non-NULL, Container must be either
2347 /// an ObjCCategoryImplDecl or ObjCImplementationDecl; it should
2348 /// only be NULL when getting encodings for protocol properties.
2350 const Decl *Container) const;
2351
2353 ObjCProtocolDecl *rProto) const;
2354
2356 const ObjCPropertyDecl *PD,
2357 const Decl *Container) const;
2358
2359 /// Return the size of type \p T for Objective-C encoding purpose,
2360 /// in characters.
2362
2363 /// Retrieve the typedef corresponding to the predefined \c id type
2364 /// in Objective-C.
2365 TypedefDecl *getObjCIdDecl() const;
2366
2367 /// Represents the Objective-CC \c id type.
2368 ///
2369 /// This is set up lazily, by Sema. \c id is always a (typedef for a)
2370 /// pointer type, a pointer to a struct.
2373 /*Qualifier=*/std::nullopt, getObjCIdDecl());
2374 }
2375
2376 /// Retrieve the typedef corresponding to the predefined 'SEL' type
2377 /// in Objective-C.
2378 TypedefDecl *getObjCSelDecl() const;
2379
2380 /// Retrieve the type that corresponds to the predefined Objective-C
2381 /// 'SEL' type.
2384 /*Qualifier=*/std::nullopt, getObjCSelDecl());
2385 }
2386
2388
2389 /// Retrieve the typedef declaration corresponding to the predefined
2390 /// Objective-C 'Class' type.
2392
2393 /// Represents the Objective-C \c Class type.
2394 ///
2395 /// This is set up lazily, by Sema. \c Class is always a (typedef for a)
2396 /// pointer type, a pointer to a struct.
2399 /*Qualifier=*/std::nullopt, getObjCClassDecl());
2400 }
2401
2402 /// Retrieve the Objective-C class declaration corresponding to
2403 /// the predefined \c Protocol class.
2405
2406 /// Retrieve declaration of 'BOOL' typedef
2408 return BOOLDecl;
2409 }
2410
2411 /// Save declaration of 'BOOL' typedef
2413 BOOLDecl = TD;
2414 }
2415
2416 /// type of 'BOOL' type.
2419 /*Qualifier=*/std::nullopt, getBOOLDecl());
2420 }
2421
2422 /// Retrieve the type of the Objective-C \c Protocol class.
2426
2427 /// Retrieve the C type declaration corresponding to the predefined
2428 /// \c __builtin_va_list type.
2430
2431 /// Retrieve the type of the \c __builtin_va_list type.
2434 /*Qualifier=*/std::nullopt, getBuiltinVaListDecl());
2435 }
2436
2437 /// Retrieve the C type declaration corresponding to the predefined
2438 /// \c __va_list_tag type used to help define the \c __builtin_va_list type
2439 /// for some targets.
2440 Decl *getVaListTagDecl() const;
2441
2442 /// Retrieve the C type declaration corresponding to the predefined
2443 /// \c __builtin_ms_va_list type.
2445
2446 /// Retrieve the type of the \c __builtin_ms_va_list type.
2449 /*Qualifier=*/std::nullopt, getBuiltinMSVaListDecl());
2450 }
2451
2452 /// Retrieve the implicitly-predeclared 'struct _GUID' declaration.
2454
2455 /// Retrieve the implicitly-predeclared 'struct _GUID' type.
2457 assert(MSGuidTagDecl && "asked for GUID type but MS extensions disabled");
2459 }
2460
2461 /// Retrieve the implicitly-predeclared 'struct type_info' declaration.
2463 // Lazily create this type on demand - it's only needed for MS builds.
2464 if (!MSTypeInfoTagDecl)
2466 return MSTypeInfoTagDecl;
2467 }
2468
2469 /// Return whether a declaration to a builtin is allowed to be
2470 /// overloaded/redeclared.
2471 bool canBuiltinBeRedeclared(const FunctionDecl *) const;
2472
2473 /// Return a type with additional \c const, \c volatile, or
2474 /// \c restrict qualifiers.
2477 }
2478
2479 /// Un-split a SplitQualType.
2481 return getQualifiedType(split.Ty, split.Quals);
2482 }
2483
2484 /// Return a type with additional qualifiers.
2486 if (!Qs.hasNonFastQualifiers())
2487 return T.withFastQualifiers(Qs.getFastQualifiers());
2488 QualifierCollector Qc(Qs);
2489 const Type *Ptr = Qc.strip(T);
2490 return getExtQualType(Ptr, Qc);
2491 }
2492
2493 /// Return a type with additional qualifiers.
2495 if (!Qs.hasNonFastQualifiers())
2496 return QualType(T, Qs.getFastQualifiers());
2497 return getExtQualType(T, Qs);
2498 }
2499
2500 /// Return a type with the given lifetime qualifier.
2501 ///
2502 /// \pre Neither type.ObjCLifetime() nor \p lifetime may be \c OCL_None.
2504 Qualifiers::ObjCLifetime lifetime) {
2505 assert(type.getObjCLifetime() == Qualifiers::OCL_None);
2506 assert(lifetime != Qualifiers::OCL_None);
2507
2508 Qualifiers qs;
2509 qs.addObjCLifetime(lifetime);
2510 return getQualifiedType(type, qs);
2511 }
2512
2513 /// getUnqualifiedObjCPointerType - Returns version of
2514 /// Objective-C pointer type with lifetime qualifier removed.
2516 if (!type.getTypePtr()->isObjCObjectPointerType() ||
2517 !type.getQualifiers().hasObjCLifetime())
2518 return type;
2519 Qualifiers Qs = type.getQualifiers();
2520 Qs.removeObjCLifetime();
2521 return getQualifiedType(type.getUnqualifiedType(), Qs);
2522 }
2523
2524 /// \brief Return a type with the given __ptrauth qualifier.
2526 assert(!Ty.getPointerAuth());
2527 assert(PointerAuth);
2528
2529 Qualifiers Qs;
2530 Qs.setPointerAuth(PointerAuth);
2531 return getQualifiedType(Ty, Qs);
2532 }
2533
2534 unsigned char getFixedPointScale(QualType Ty) const;
2535 unsigned char getFixedPointIBits(QualType Ty) const;
2536 llvm::FixedPointSemantics getFixedPointSemantics(QualType Ty) const;
2537 llvm::APFixedPoint getFixedPointMax(QualType Ty) const;
2538 llvm::APFixedPoint getFixedPointMin(QualType Ty) const;
2539
2541 SourceLocation NameLoc) const;
2542
2544 UnresolvedSetIterator End) const;
2546
2548 bool TemplateKeyword,
2549 TemplateName Template) const;
2552
2554 Decl *AssociatedDecl,
2555 unsigned Index,
2556 UnsignedOrNone PackIndex,
2557 bool Final) const;
2559 Decl *AssociatedDecl,
2560 unsigned Index,
2561 bool Final) const;
2562
2563 /// Represents a TemplateName which had some of its default arguments
2564 /// deduced. This both represents this default argument deduction as sugar,
2565 /// and provides the support for it's equivalences through canonicalization.
2566 /// For example DeducedTemplateNames which have the same set of default
2567 /// arguments are equivalent, and are also equivalent to the underlying
2568 /// template when the deduced template arguments are the same.
2570 DefaultArguments DefaultArgs) const;
2571
2573 /// No error
2575
2576 /// Missing a type
2578
2579 /// Missing a type from <stdio.h>
2581
2582 /// Missing a type from <setjmp.h>
2584
2585 /// Missing a type from <ucontext.h>
2587 };
2588
2589 QualType DecodeTypeStr(const char *&Str, const ASTContext &Context,
2591 bool &RequireICE, bool AllowTypeModifiers) const;
2592
2593 /// Return the type for the specified builtin.
2594 ///
2595 /// If \p IntegerConstantArgs is non-null, it is filled in with a bitmask of
2596 /// arguments to the builtin that are required to be integer constant
2597 /// expressions.
2599 unsigned *IntegerConstantArgs = nullptr) const;
2600
2601 /// Types and expressions required to build C++2a three-way comparisons
2602 /// using operator<=>, including the values return by builtin <=> operators.
2604
2605private:
2606 CanQualType getFromTargetType(unsigned Type) const;
2607 TypeInfo getTypeInfoImpl(const Type *T) const;
2608
2609 //===--------------------------------------------------------------------===//
2610 // Type Predicates.
2611 //===--------------------------------------------------------------------===//
2612
2613public:
2614 /// Return one of the GCNone, Weak or Strong Objective-C garbage
2615 /// collection attributes.
2617
2618 /// Return true if the given vector types are of the same unqualified
2619 /// type or if they are equivalent to the same GCC vector type.
2620 ///
2621 /// \note This ignores whether they are target-specific (AltiVec or Neon)
2622 /// types.
2623 bool areCompatibleVectorTypes(QualType FirstVec, QualType SecondVec);
2624
2625 /// Return true if the given types are an RISC-V vector builtin type and a
2626 /// VectorType that is a fixed-length representation of the RISC-V vector
2627 /// builtin type for a specific vector-length.
2628 bool areCompatibleRVVTypes(QualType FirstType, QualType SecondType);
2629
2630 /// Return true if the given vector types are lax-compatible RISC-V vector
2631 /// types as defined by -flax-vector-conversions=, which permits implicit
2632 /// conversions between vectors with different number of elements and/or
2633 /// incompatible element types, false otherwise.
2634 bool areLaxCompatibleRVVTypes(QualType FirstType, QualType SecondType);
2635
2636 /// Return true if the type has been explicitly qualified with ObjC ownership.
2637 /// A type may be implicitly qualified with ownership under ObjC ARC, and in
2638 /// some cases the compiler treats these differently.
2640
2641 /// Return true if this is an \c NSObject object with its \c NSObject
2642 /// attribute set.
2644 return Ty->isObjCNSObjectType();
2645 }
2646
2647 //===--------------------------------------------------------------------===//
2648 // Type Sizing and Analysis
2649 //===--------------------------------------------------------------------===//
2650
2651 /// Return the APFloat 'semantics' for the specified scalar floating
2652 /// point type.
2653 const llvm::fltSemantics &getFloatTypeSemantics(QualType T) const;
2654
2655 /// Get the size and alignment of the specified complete type in bits.
2656 TypeInfo getTypeInfo(const Type *T) const;
2657 TypeInfo getTypeInfo(QualType T) const { return getTypeInfo(T.getTypePtr()); }
2658
2659 /// Get default simd alignment of the specified complete type in bits.
2660 unsigned getOpenMPDefaultSimdAlign(QualType T) const;
2661
2662 /// Return the size of the specified (complete) type \p T, in bits.
2663 uint64_t getTypeSize(QualType T) const { return getTypeInfo(T).Width; }
2664 uint64_t getTypeSize(const Type *T) const { return getTypeInfo(T).Width; }
2665
2666 /// Return the size of the character type, in bits.
2667 uint64_t getCharWidth() const {
2668 return getTypeSize(CharTy);
2669 }
2670
2671 /// Convert a size in bits to a size in characters.
2672 CharUnits toCharUnitsFromBits(int64_t BitSize) const;
2673
2674 /// Convert a size in characters to a size in bits.
2675 int64_t toBits(CharUnits CharSize) const;
2676
2677 /// Return the size of the specified (complete) type \p T, in
2678 /// characters.
2680 CharUnits getTypeSizeInChars(const Type *T) const;
2681
2682 std::optional<CharUnits> getTypeSizeInCharsIfKnown(QualType Ty) const {
2683 if (Ty->isIncompleteType() || Ty->isDependentType())
2684 return std::nullopt;
2685 return getTypeSizeInChars(Ty);
2686 }
2687
2688 std::optional<CharUnits> getTypeSizeInCharsIfKnown(const Type *Ty) const {
2689 return getTypeSizeInCharsIfKnown(QualType(Ty, 0));
2690 }
2691
2692 /// Return the ABI-specified alignment of a (complete) type \p T, in
2693 /// bits.
2694 unsigned getTypeAlign(QualType T) const { return getTypeInfo(T).Align; }
2695 unsigned getTypeAlign(const Type *T) const { return getTypeInfo(T).Align; }
2696
2697 /// Return the ABI-specified natural alignment of a (complete) type \p T,
2698 /// before alignment adjustments, in bits.
2699 ///
2700 /// This alignment is currently used only by ARM and AArch64 when passing
2701 /// arguments of a composite type.
2703 return getTypeUnadjustedAlign(T.getTypePtr());
2704 }
2705 unsigned getTypeUnadjustedAlign(const Type *T) const;
2706
2707 /// Return the alignment of a type, in bits, or 0 if
2708 /// the type is incomplete and we cannot determine the alignment (for
2709 /// example, from alignment attributes). The returned alignment is the
2710 /// Preferred alignment if NeedsPreferredAlignment is true, otherwise is the
2711 /// ABI alignment.
2713 bool NeedsPreferredAlignment = false) const;
2714
2715 /// Return the ABI-specified alignment of a (complete) type \p T, in
2716 /// characters.
2718 CharUnits getTypeAlignInChars(const Type *T) const;
2719
2720 /// Return the PreferredAlignment of a (complete) type \p T, in
2721 /// characters.
2725
2726 /// getTypeUnadjustedAlignInChars - Return the ABI-specified alignment of a type,
2727 /// in characters, before alignment adjustments. This method does not work on
2728 /// incomplete types.
2731
2732 // getTypeInfoDataSizeInChars - Return the size of a type, in chars. If the
2733 // type is a record, its data size is returned.
2735
2736 TypeInfoChars getTypeInfoInChars(const Type *T) const;
2738
2739 /// Determine if the alignment the type has was required using an
2740 /// alignment attribute.
2741 bool isAlignmentRequired(const Type *T) const;
2742 bool isAlignmentRequired(QualType T) const;
2743
2744 /// More type predicates useful for type checking/promotion
2745 bool isPromotableIntegerType(QualType T) const; // C99 6.3.1.1p2
2746
2747 /// Return the "preferred" alignment of the specified type \p T for
2748 /// the current target, in bits.
2749 ///
2750 /// This can be different than the ABI alignment in cases where it is
2751 /// beneficial for performance or backwards compatibility preserving to
2752 /// overalign a data type. (Note: despite the name, the preferred alignment
2753 /// is ABI-impacting, and not an optimization.)
2755 return getPreferredTypeAlign(T.getTypePtr());
2756 }
2757 unsigned getPreferredTypeAlign(const Type *T) const;
2758
2759 /// Return the default alignment for __attribute__((aligned)) on
2760 /// this target, to be used if no alignment value is specified.
2762
2763 /// Return the alignment in bits that should be given to a
2764 /// global variable with type \p T. If \p VD is non-null it will be
2765 /// considered specifically for the query.
2766 unsigned getAlignOfGlobalVar(QualType T, const VarDecl *VD) const;
2767
2768 /// Return the alignment in characters that should be given to a
2769 /// global variable with type \p T. If \p VD is non-null it will be
2770 /// considered specifically for the query.
2772
2773 /// Return the minimum alignment as specified by the target. If \p VD is
2774 /// non-null it may be used to identify external or weak variables.
2775 unsigned getMinGlobalAlignOfVar(uint64_t Size, const VarDecl *VD) const;
2776
2777 /// Return a conservative estimate of the alignment of the specified
2778 /// decl \p D.
2779 ///
2780 /// \pre \p D must not be a bitfield type, as bitfields do not have a valid
2781 /// alignment.
2782 ///
2783 /// If \p ForAlignof, references are treated like their underlying type
2784 /// and large arrays don't get any special treatment. If not \p ForAlignof
2785 /// it computes the value expected by CodeGen: references are treated like
2786 /// pointers and large arrays get extra alignment.
2787 CharUnits getDeclAlign(const Decl *D, bool ForAlignof = false) const;
2788
2789 /// Return the alignment (in bytes) of the thrown exception object. This is
2790 /// only meaningful for targets that allocate C++ exceptions in a system
2791 /// runtime, such as those using the Itanium C++ ABI.
2793
2794 /// Get or compute information about the layout of the specified
2795 /// record (struct/union/class) \p D, which indicates its size and field
2796 /// position information.
2797 const ASTRecordLayout &getASTRecordLayout(const RecordDecl *D) const;
2798
2799 /// Get or compute information about the layout of the specified
2800 /// Objective-C interface.
2802 const;
2803
2804 void DumpRecordLayout(const RecordDecl *RD, raw_ostream &OS,
2805 bool Simple = false) const;
2806
2807 /// Get our current best idea for the key function of the
2808 /// given record decl, or nullptr if there isn't one.
2809 ///
2810 /// The key function is, according to the Itanium C++ ABI section 5.2.3:
2811 /// ...the first non-pure virtual function that is not inline at the
2812 /// point of class definition.
2813 ///
2814 /// Other ABIs use the same idea. However, the ARM C++ ABI ignores
2815 /// virtual functions that are defined 'inline', which means that
2816 /// the result of this computation can change.
2818
2819 /// Observe that the given method cannot be a key function.
2820 /// Checks the key-function cache for the method's class and clears it
2821 /// if matches the given declaration.
2822 ///
2823 /// This is used in ABIs where out-of-line definitions marked
2824 /// inline are not considered to be key functions.
2825 ///
2826 /// \param method should be the declaration from the class definition
2827 void setNonKeyFunction(const CXXMethodDecl *method);
2828
2829 /// Loading virtual member pointers using the virtual inheritance model
2830 /// always results in an adjustment using the vbtable even if the index is
2831 /// zero.
2832 ///
2833 /// This is usually OK because the first slot in the vbtable points
2834 /// backwards to the top of the MDC. However, the MDC might be reusing a
2835 /// vbptr from an nv-base. In this case, the first slot in the vbtable
2836 /// points to the start of the nv-base which introduced the vbptr and *not*
2837 /// the MDC. Modify the NonVirtualBaseAdjustment to account for this.
2839
2840 /// Get the offset of a FieldDecl or IndirectFieldDecl, in bits.
2841 uint64_t getFieldOffset(const ValueDecl *FD) const;
2842
2843 /// Get the offset of an ObjCIvarDecl in bits.
2844 uint64_t lookupFieldBitOffset(const ObjCInterfaceDecl *OID,
2845 const ObjCIvarDecl *Ivar) const;
2846
2847 /// Find the 'this' offset for the member path in a pointer-to-member
2848 /// APValue.
2850
2851 bool isNearlyEmpty(const CXXRecordDecl *RD) const;
2852
2854
2855 /// If \p T is null pointer, assume the target in ASTContext.
2856 MangleContext *createMangleContext(const TargetInfo *T = nullptr);
2857
2858 /// Creates a device mangle context to correctly mangle lambdas in a mixed
2859 /// architecture compile by setting the lambda mangling number source to the
2860 /// DeviceLambdaManglingNumber. Currently this asserts that the TargetInfo
2861 /// (from the AuxTargetInfo) is a an itanium target.
2863
2864 void DeepCollectObjCIvars(const ObjCInterfaceDecl *OI, bool leafClass,
2866
2867 unsigned CountNonClassIvars(const ObjCInterfaceDecl *OI) const;
2868 void CollectInheritedProtocols(const Decl *CDecl,
2870
2871 /// Return true if the specified type has unique object representations
2872 /// according to (C++17 [meta.unary.prop]p9)
2873 bool
2875 bool CheckIfTriviallyCopyable = true) const;
2876
2877 //===--------------------------------------------------------------------===//
2878 // Type Operators
2879 //===--------------------------------------------------------------------===//
2880
2881 /// Return the canonical (structural) type corresponding to the
2882 /// specified potentially non-canonical type \p T.
2883 ///
2884 /// The non-canonical version of a type may have many "decorated" versions of
2885 /// types. Decorators can include typedefs, 'typeof' operators, etc. The
2886 /// returned type is guaranteed to be free of any of these, allowing two
2887 /// canonical types to be compared for exact equality with a simple pointer
2888 /// comparison.
2890 return CanQualType::CreateUnsafe(T.getCanonicalType());
2891 }
2892
2893 static const Type *getCanonicalType(const Type *T) {
2894 return T->getCanonicalTypeInternal().getTypePtr();
2895 }
2896
2897 /// Return the canonical parameter type corresponding to the specific
2898 /// potentially non-canonical one.
2899 ///
2900 /// Qualifiers are stripped off, functions are turned into function
2901 /// pointers, and arrays decay one level into pointers.
2903
2904 /// Determine whether the given types \p T1 and \p T2 are equivalent.
2905 static bool hasSameType(QualType T1, QualType T2) {
2906 return getCanonicalType(T1) == getCanonicalType(T2);
2907 }
2908 static bool hasSameType(const Type *T1, const Type *T2) {
2909 return getCanonicalType(T1) == getCanonicalType(T2);
2910 }
2911
2912 /// Determine whether the given expressions \p X and \p Y are equivalent.
2913 bool hasSameExpr(const Expr *X, const Expr *Y) const;
2914
2915 /// Return this type as a completely-unqualified array type,
2916 /// capturing the qualifiers in \p Quals.
2917 ///
2918 /// This will remove the minimal amount of sugaring from the types, similar
2919 /// to the behavior of QualType::getUnqualifiedType().
2920 ///
2921 /// \param T is the qualified type, which may be an ArrayType
2922 ///
2923 /// \param Quals will receive the full set of qualifiers that were
2924 /// applied to the array.
2925 ///
2926 /// \returns if this is an array type, the completely unqualified array type
2927 /// that corresponds to it. Otherwise, returns T.getUnqualifiedType().
2930 Qualifiers Quals;
2931 return getUnqualifiedArrayType(T, Quals);
2932 }
2933
2934 /// Determine whether the given types are equivalent after
2935 /// cvr-qualifiers have been removed.
2937 return getCanonicalType(T1).getTypePtr() ==
2939 }
2940
2942 bool IsParam) const {
2943 auto SubTnullability = SubT->getNullability();
2944 auto SuperTnullability = SuperT->getNullability();
2945 if (SubTnullability.has_value() == SuperTnullability.has_value()) {
2946 // Neither has nullability; return true
2947 if (!SubTnullability)
2948 return true;
2949 // Both have nullability qualifier.
2950 if (*SubTnullability == *SuperTnullability ||
2951 *SubTnullability == NullabilityKind::Unspecified ||
2952 *SuperTnullability == NullabilityKind::Unspecified)
2953 return true;
2954
2955 if (IsParam) {
2956 // Ok for the superclass method parameter to be "nonnull" and the subclass
2957 // method parameter to be "nullable"
2958 return (*SuperTnullability == NullabilityKind::NonNull &&
2959 *SubTnullability == NullabilityKind::Nullable);
2960 }
2961 // For the return type, it's okay for the superclass method to specify
2962 // "nullable" and the subclass method specify "nonnull"
2963 return (*SuperTnullability == NullabilityKind::Nullable &&
2964 *SubTnullability == NullabilityKind::NonNull);
2965 }
2966 return true;
2967 }
2968
2969 bool ObjCMethodsAreEqual(const ObjCMethodDecl *MethodDecl,
2970 const ObjCMethodDecl *MethodImp);
2971
2972 bool UnwrapSimilarTypes(QualType &T1, QualType &T2,
2973 bool AllowPiMismatch = true) const;
2975 bool AllowPiMismatch = true) const;
2976
2977 /// Determine if two types are similar, according to the C++ rules. That is,
2978 /// determine if they are the same other than qualifiers on the initial
2979 /// sequence of pointer / pointer-to-member / array (and in Clang, object
2980 /// pointer) types and their element types.
2981 ///
2982 /// Clang offers a number of qualifiers in addition to the C++ qualifiers;
2983 /// those qualifiers are also ignored in the 'similarity' check.
2984 bool hasSimilarType(QualType T1, QualType T2) const;
2985
2986 /// Determine if two types are similar, ignoring only CVR qualifiers.
2987 bool hasCvrSimilarType(QualType T1, QualType T2);
2988
2989 /// Retrieves the default calling convention for the current context.
2990 ///
2991 /// The context's default calling convention may differ from the current
2992 /// target's default calling convention if the -fdefault-calling-conv option
2993 /// is used; to get the target's default calling convention, e.g. for built-in
2994 /// functions, call getTargetInfo().getDefaultCallingConv() instead.
2996 bool IsCXXMethod) const;
2997
2998 /// Retrieves the "canonical" template name that refers to a
2999 /// given template.
3000 ///
3001 /// The canonical template name is the simplest expression that can
3002 /// be used to refer to a given template. For most templates, this
3003 /// expression is just the template declaration itself. For example,
3004 /// the template std::vector can be referred to via a variety of
3005 /// names---std::vector, \::std::vector, vector (if vector is in
3006 /// scope), etc.---but all of these names map down to the same
3007 /// TemplateDecl, which is used to form the canonical template name.
3008 ///
3009 /// Dependent template names are more interesting. Here, the
3010 /// template name could be something like T::template apply or
3011 /// std::allocator<T>::template rebind, where the nested name
3012 /// specifier itself is dependent. In this case, the canonical
3013 /// template name uses the shortest form of the dependent
3014 /// nested-name-specifier, which itself contains all canonical
3015 /// types, values, and templates.
3017 bool IgnoreDeduced = false) const;
3018
3019 /// Determine whether the given template names refer to the same
3020 /// template.
3021 bool hasSameTemplateName(const TemplateName &X, const TemplateName &Y,
3022 bool IgnoreDeduced = false) const;
3023
3024 /// Determine whether the two declarations refer to the same entity.
3025 bool isSameEntity(const NamedDecl *X, const NamedDecl *Y) const;
3026
3027 /// Determine whether two template parameter lists are similar enough
3028 /// that they may be used in declarations of the same template.
3030 const TemplateParameterList *Y) const;
3031
3032 /// Determine whether two template parameters are similar enough
3033 /// that they may be used in declarations of the same template.
3034 bool isSameTemplateParameter(const NamedDecl *X, const NamedDecl *Y) const;
3035
3036 /// Determine whether two 'requires' expressions are similar enough that they
3037 /// may be used in re-declarations.
3038 ///
3039 /// Use of 'requires' isn't mandatory, works with constraints expressed in
3040 /// other ways too.
3042 const AssociatedConstraint &ACY) const;
3043
3044 /// Determine whether two 'requires' expressions are similar enough that they
3045 /// may be used in re-declarations.
3046 ///
3047 /// Use of 'requires' isn't mandatory, works with constraints expressed in
3048 /// other ways too.
3049 bool isSameConstraintExpr(const Expr *XCE, const Expr *YCE) const;
3050
3051 /// Determine whether two type contraint are similar enough that they could
3052 /// used in declarations of the same template.
3053 bool isSameTypeConstraint(const TypeConstraint *XTC,
3054 const TypeConstraint *YTC) const;
3055
3056 /// Determine whether two default template arguments are similar enough
3057 /// that they may be used in declarations of the same template.
3059 const NamedDecl *Y) const;
3060
3061 /// Retrieve the "canonical" template argument.
3062 ///
3063 /// The canonical template argument is the simplest template argument
3064 /// (which may be a type, value, expression, or declaration) that
3065 /// expresses the value of the argument.
3067 const;
3068
3069 /// Canonicalize the given template argument list.
3070 ///
3071 /// Returns true if any arguments were non-canonical, false otherwise.
3072 bool
3074
3075 /// Canonicalize the given TemplateTemplateParmDecl.
3078
3080 TemplateTemplateParmDecl *TTP) const;
3082 TemplateTemplateParmDecl *CanonTTP) const;
3083
3084 /// Determine whether the given template arguments \p Arg1 and \p Arg2 are
3085 /// equivalent.
3087 const TemplateArgument &Arg2) const;
3088
3089 /// Type Query functions. If the type is an instance of the specified class,
3090 /// return the Type pointer for the underlying maximally pretty type. This
3091 /// is a member of ASTContext because this may need to do some amount of
3092 /// canonicalization, e.g. to move type qualifiers into the element type.
3093 const ArrayType *getAsArrayType(QualType T) const;
3095 return dyn_cast_or_null<ConstantArrayType>(getAsArrayType(T));
3096 }
3098 return dyn_cast_or_null<VariableArrayType>(getAsArrayType(T));
3099 }
3101 return dyn_cast_or_null<IncompleteArrayType>(getAsArrayType(T));
3102 }
3104 const {
3105 return dyn_cast_or_null<DependentSizedArrayType>(getAsArrayType(T));
3106 }
3107
3108 /// Return the innermost element type of an array type.
3109 ///
3110 /// For example, will return "int" for int[m][n]
3111 QualType getBaseElementType(const ArrayType *VAT) const;
3112
3113 /// Return the innermost element type of a type (which needn't
3114 /// actually be an array type).
3116
3117 /// Return number of constant array elements.
3118 uint64_t getConstantArrayElementCount(const ConstantArrayType *CA) const;
3119
3120 /// Return number of elements initialized in an ArrayInitLoopExpr.
3121 uint64_t
3123
3124 /// Perform adjustment on the parameter type of a function.
3125 ///
3126 /// This routine adjusts the given parameter type @p T to the actual
3127 /// parameter type used by semantic analysis (C99 6.7.5.3p[7,8],
3128 /// C++ [dcl.fct]p3). The adjusted parameter type is returned.
3130
3131 /// Retrieve the parameter type as adjusted for use in the signature
3132 /// of a function, decaying array and function types and removing top-level
3133 /// cv-qualifiers.
3135
3137
3138 /// Return the properly qualified result of decaying the specified
3139 /// array type to a pointer.
3140 ///
3141 /// This operation is non-trivial when handling typedefs etc. The canonical
3142 /// type of \p T must be an array type, this returns a pointer to a properly
3143 /// qualified element of the array.
3144 ///
3145 /// See C99 6.7.5.3p7 and C99 6.3.2.1p3.
3147
3148 /// Return the type that \p PromotableType will promote to: C99
3149 /// 6.3.1.1p2, assuming that \p PromotableType is a promotable integer type.
3150 QualType getPromotedIntegerType(QualType PromotableType) const;
3151
3152 /// Recurses in pointer/array types until it finds an Objective-C
3153 /// retainable type and returns its ownership.
3155
3156 /// Whether this is a promotable bitfield reference according
3157 /// to C99 6.3.1.1p2, bullet 2 (and GCC extensions).
3158 ///
3159 /// \returns the type this bit-field will promote to, or NULL if no
3160 /// promotion occurs.
3162
3163 /// Return the highest ranked integer type, see C99 6.3.1.8p1.
3164 ///
3165 /// If \p LHS > \p RHS, returns 1. If \p LHS == \p RHS, returns 0. If
3166 /// \p LHS < \p RHS, return -1.
3167 int getIntegerTypeOrder(QualType LHS, QualType RHS) const;
3168
3169 /// Compare the rank of the two specified floating point types,
3170 /// ignoring the domain of the type (i.e. 'double' == '_Complex double').
3171 ///
3172 /// If \p LHS > \p RHS, returns 1. If \p LHS == \p RHS, returns 0. If
3173 /// \p LHS < \p RHS, return -1.
3174 int getFloatingTypeOrder(QualType LHS, QualType RHS) const;
3175
3176 /// Compare the rank of two floating point types as above, but compare equal
3177 /// if both types have the same floating-point semantics on the target (i.e.
3178 /// long double and double on AArch64 will return 0).
3180
3181 unsigned getTargetAddressSpace(LangAS AS) const;
3182
3183 LangAS getLangASForBuiltinAddressSpace(unsigned AS) const;
3184
3185 /// Get target-dependent integer value for null pointer which is used for
3186 /// constant folding.
3187 uint64_t getTargetNullPointerValue(QualType QT) const;
3188
3190 return AddrSpaceMapMangling || isTargetAddressSpace(AS);
3191 }
3192
3193 bool hasAnyFunctionEffects() const { return AnyFunctionEffects; }
3194
3195 // Merges two exception specifications, such that the resulting
3196 // exception spec is the union of both. For example, if either
3197 // of them can throw something, the result can throw it as well.
3201 SmallVectorImpl<QualType> &ExceptionTypeStorage,
3202 bool AcceptDependent) const;
3203
3204 // For two "same" types, return a type which has
3205 // the common sugar between them. If Unqualified is true,
3206 // both types need only be the same unqualified type.
3207 // The result will drop the qualifiers which do not occur
3208 // in both types.
3210 bool Unqualified = false) const;
3211
3212private:
3213 // Helper for integer ordering
3214 unsigned getIntegerRank(const Type *T) const;
3215
3216public:
3217 //===--------------------------------------------------------------------===//
3218 // Type Compatibility Predicates
3219 //===--------------------------------------------------------------------===//
3220
3221 /// Compatibility predicates used to check assignment expressions.
3223 bool CompareUnqualified = false); // C99 6.2.7p1
3224
3227
3228 bool isObjCIdType(QualType T) const { return T == getObjCIdType(); }
3229
3230 bool isObjCClassType(QualType T) const { return T == getObjCClassType(); }
3231
3232 bool isObjCSelType(QualType T) const { return T == getObjCSelType(); }
3233
3235 const ObjCObjectPointerType *RHS,
3236 bool ForCompare);
3237
3239 const ObjCObjectPointerType *RHS);
3240
3241 // Check the safety of assignment from LHS to RHS
3243 const ObjCObjectPointerType *RHSOPT);
3245 const ObjCObjectType *RHS);
3247 const ObjCObjectPointerType *LHSOPT,
3248 const ObjCObjectPointerType *RHSOPT,
3249 bool BlockReturnType);
3252 const ObjCObjectPointerType *RHSOPT);
3254
3255 // Functions for calculating composite types
3256 QualType mergeTypes(QualType, QualType, bool OfBlockPointer = false,
3257 bool Unqualified = false, bool BlockReturnType = false,
3258 bool IsConditionalOperator = false);
3259 QualType mergeFunctionTypes(QualType, QualType, bool OfBlockPointer = false,
3260 bool Unqualified = false, bool AllowCXX = false,
3261 bool IsConditionalOperator = false);
3263 bool OfBlockPointer = false,
3264 bool Unqualified = false);
3266 bool OfBlockPointer=false,
3267 bool Unqualified = false);
3269
3271
3272 /// This function merges the ExtParameterInfo lists of two functions. It
3273 /// returns true if the lists are compatible. The merged list is returned in
3274 /// NewParamInfos.
3275 ///
3276 /// \param FirstFnType The type of the first function.
3277 ///
3278 /// \param SecondFnType The type of the second function.
3279 ///
3280 /// \param CanUseFirst This flag is set to true if the first function's
3281 /// ExtParameterInfo list can be used as the composite list of
3282 /// ExtParameterInfo.
3283 ///
3284 /// \param CanUseSecond This flag is set to true if the second function's
3285 /// ExtParameterInfo list can be used as the composite list of
3286 /// ExtParameterInfo.
3287 ///
3288 /// \param NewParamInfos The composite list of ExtParameterInfo. The list is
3289 /// empty if none of the flags are set.
3290 ///
3292 const FunctionProtoType *FirstFnType,
3293 const FunctionProtoType *SecondFnType,
3294 bool &CanUseFirst, bool &CanUseSecond,
3296
3297 void ResetObjCLayout(const ObjCInterfaceDecl *D);
3298
3300 const ObjCInterfaceDecl *SubClass) {
3301 ObjCSubClasses[D].push_back(SubClass);
3302 }
3303
3304 //===--------------------------------------------------------------------===//
3305 // Integer Predicates
3306 //===--------------------------------------------------------------------===//
3307
3308 // The width of an integer, as defined in C99 6.2.6.2. This is the number
3309 // of bits in an integer type excluding any padding bits.
3310 unsigned getIntWidth(QualType T) const;
3311
3312 // Per C99 6.2.5p6, for every signed integer type, there is a corresponding
3313 // unsigned integer type. This method takes a signed type, and returns the
3314 // corresponding unsigned integer type.
3315 // With the introduction of fixed point types in ISO N1169, this method also
3316 // accepts fixed point types and returns the corresponding unsigned type for
3317 // a given fixed point type.
3319
3320 // Per C99 6.2.5p6, for every signed integer type, there is a corresponding
3321 // unsigned integer type. This method takes an unsigned type, and returns the
3322 // corresponding signed integer type.
3323 // With the introduction of fixed point types in ISO N1169, this method also
3324 // accepts fixed point types and returns the corresponding signed type for
3325 // a given fixed point type.
3327
3328 // Per ISO N1169, this method accepts fixed point types and returns the
3329 // corresponding saturated type for a given fixed point type.
3331
3332 // Per ISO N1169, this method accepts fixed point types and returns the
3333 // corresponding non-saturated type for a given fixed point type.
3335
3336 // This method accepts fixed point types and returns the corresponding signed
3337 // type. Unlike getCorrespondingUnsignedType(), this only accepts unsigned
3338 // fixed point types because there are unsigned integer types like bool and
3339 // char8_t that don't have signed equivalents.
3341
3342 //===--------------------------------------------------------------------===//
3343 // Integer Values
3344 //===--------------------------------------------------------------------===//
3345
3346 /// Make an APSInt of the appropriate width and signedness for the
3347 /// given \p Value and integer \p Type.
3348 llvm::APSInt MakeIntValue(uint64_t Value, QualType Type) const {
3349 // If Type is a signed integer type larger than 64 bits, we need to be sure
3350 // to sign extend Res appropriately.
3351 llvm::APSInt Res(64, !Type->isSignedIntegerOrEnumerationType());
3352 Res = Value;
3353 unsigned Width = getIntWidth(Type);
3354 if (Width != Res.getBitWidth())
3355 return Res.extOrTrunc(Width);
3356 return Res;
3357 }
3358
3359 bool isSentinelNullExpr(const Expr *E);
3360
3361 /// Get the implementation of the ObjCInterfaceDecl \p D, or nullptr if
3362 /// none exists.
3364
3365 /// Get the implementation of the ObjCCategoryDecl \p D, or nullptr if
3366 /// none exists.
3368
3369 /// Return true if there is at least one \@implementation in the TU.
3371 return !ObjCImpls.empty();
3372 }
3373
3374 /// Set the implementation of ObjCInterfaceDecl.
3376 ObjCImplementationDecl *ImplD);
3377
3378 /// Set the implementation of ObjCCategoryDecl.
3380 ObjCCategoryImplDecl *ImplD);
3381
3382 /// Get the duplicate declaration of a ObjCMethod in the same
3383 /// interface, or null if none exists.
3384 const ObjCMethodDecl *
3386
3388 const ObjCMethodDecl *Redecl);
3389
3390 /// Returns the Objective-C interface that \p ND belongs to if it is
3391 /// an Objective-C method/property/ivar etc. that is part of an interface,
3392 /// otherwise returns null.
3394
3395 /// Set the copy initialization expression of a block var decl. \p CanThrow
3396 /// indicates whether the copy expression can throw or not.
3397 void setBlockVarCopyInit(const VarDecl* VD, Expr *CopyExpr, bool CanThrow);
3398
3399 /// Get the copy initialization expression of the VarDecl \p VD, or
3400 /// nullptr if none exists.
3402
3403 /// Allocate an uninitialized TypeSourceInfo.
3404 ///
3405 /// The caller should initialize the memory held by TypeSourceInfo using
3406 /// the TypeLoc wrappers.
3407 ///
3408 /// \param T the type that will be the basis for type source info. This type
3409 /// should refer to how the declarator was written in source code, not to
3410 /// what type semantic analysis resolved the declarator to.
3411 ///
3412 /// \param Size the size of the type info to create, or 0 if the size
3413 /// should be calculated based on the type.
3414 TypeSourceInfo *CreateTypeSourceInfo(QualType T, unsigned Size = 0) const;
3415
3416 /// Allocate a TypeSourceInfo where all locations have been
3417 /// initialized to a given location, which defaults to the empty
3418 /// location.
3421 SourceLocation Loc = SourceLocation()) const;
3422
3423 /// Add a deallocation callback that will be invoked when the
3424 /// ASTContext is destroyed.
3425 ///
3426 /// \param Callback A callback function that will be invoked on destruction.
3427 ///
3428 /// \param Data Pointer data that will be provided to the callback function
3429 /// when it is called.
3430 void AddDeallocation(void (*Callback)(void *), void *Data) const;
3431
3432 /// If T isn't trivially destructible, calls AddDeallocation to register it
3433 /// for destruction.
3434 template <typename T> void addDestruction(T *Ptr) const {
3435 if (!std::is_trivially_destructible<T>::value) {
3436 auto DestroyPtr = [](void *V) { static_cast<T *>(V)->~T(); };
3437 AddDeallocation(DestroyPtr, Ptr);
3438 }
3439 }
3440
3443
3444 /// Determines if the decl can be CodeGen'ed or deserialized from PCH
3445 /// lazily, only when used; this is only relevant for function or file scoped
3446 /// var definitions.
3447 ///
3448 /// \returns true if the function/var must be CodeGen'ed/deserialized even if
3449 /// it is not used.
3450 bool DeclMustBeEmitted(const Decl *D);
3451
3452 /// Visits all versions of a multiversioned function with the passed
3453 /// predicate.
3455 const FunctionDecl *FD,
3456 llvm::function_ref<void(FunctionDecl *)> Pred) const;
3457
3458 const CXXConstructorDecl *
3460
3462 CXXConstructorDecl *CD);
3463
3465
3467
3469
3471
3472 void setManglingNumber(const NamedDecl *ND, unsigned Number);
3473 unsigned getManglingNumber(const NamedDecl *ND,
3474 bool ForAuxTarget = false) const;
3475
3476 void setStaticLocalNumber(const VarDecl *VD, unsigned Number);
3477 unsigned getStaticLocalNumber(const VarDecl *VD) const;
3478
3480 return !TypeAwareOperatorNewAndDeletes.empty();
3481 }
3482 void setIsDestroyingOperatorDelete(const FunctionDecl *FD, bool IsDestroying);
3483 bool isDestroyingOperatorDelete(const FunctionDecl *FD) const;
3485 bool IsTypeAware);
3486 bool isTypeAwareOperatorNewOrDelete(const FunctionDecl *FD) const;
3487
3489
3491 FunctionDecl *OperatorDelete,
3492 OperatorDeleteKind K) const;
3494 OperatorDeleteKind K) const;
3496 OperatorDeleteKind K) const;
3497
3498 /// Retrieve the context for computing mangling numbers in the given
3499 /// DeclContext.
3503 const Decl *D);
3504
3505 std::unique_ptr<MangleNumberingContext> createMangleNumberingContext() const;
3506
3507 /// Used by ParmVarDecl to store on the side the
3508 /// index of the parameter when it exceeds the size of the normal bitfield.
3509 void setParameterIndex(const ParmVarDecl *D, unsigned index);
3510
3511 /// Used by ParmVarDecl to retrieve on the side the
3512 /// index of the parameter when it exceeds the size of the normal bitfield.
3513 unsigned getParameterIndex(const ParmVarDecl *D) const;
3514
3515 /// Return a string representing the human readable name for the specified
3516 /// function declaration or file name. Used by SourceLocExpr and
3517 /// PredefinedExpr to cache evaluated results.
3519
3520 /// Return the next version number to be used for a string literal evaluated
3521 /// as part of constant evaluation.
3522 unsigned getNextStringLiteralVersion() { return NextStringLiteralVersion++; }
3523
3524 /// Return a declaration for the global GUID object representing the given
3525 /// GUID value.
3527
3528 /// Return a declaration for a uniquified anonymous global constant
3529 /// corresponding to a given APValue.
3532
3533 /// Return the template parameter object of the given type with the given
3534 /// value.
3536 const APValue &V) const;
3537
3538 /// Parses the target attributes passed in, and returns only the ones that are
3539 /// valid feature names.
3540 ParsedTargetAttr filterFunctionTargetAttrs(const TargetAttr *TD) const;
3541
3542 void getFunctionFeatureMap(llvm::StringMap<bool> &FeatureMap,
3543 const FunctionDecl *) const;
3544 void getFunctionFeatureMap(llvm::StringMap<bool> &FeatureMap,
3545 GlobalDecl GD) const;
3546
3547 /// Generates and stores SYCL kernel metadata for the provided
3548 /// SYCL kernel entry point function. The provided function must have
3549 /// an attached sycl_kernel_entry_point attribute that specifies a unique
3550 /// type for the name of a SYCL kernel. Callers are required to detect
3551 /// conflicting SYCL kernel names and issue a diagnostic prior to calling
3552 /// this function.
3554
3555 /// Given a type used as a SYCL kernel name, returns a reference to the
3556 /// metadata generated from the corresponding SYCL kernel entry point.
3557 /// Aborts if the provided type is not a registered SYCL kernel name.
3559
3560 /// Returns a pointer to the metadata generated from the corresponding
3561 /// SYCLkernel entry point if the provided type corresponds to a registered
3562 /// SYCL kernel name. Returns a null pointer otherwise.
3564
3565 //===--------------------------------------------------------------------===//
3566 // Statistics
3567 //===--------------------------------------------------------------------===//
3568
3569 /// The number of implicitly-declared default constructors.
3571
3572 /// The number of implicitly-declared default constructors for
3573 /// which declarations were built.
3575
3576 /// The number of implicitly-declared copy constructors.
3578
3579 /// The number of implicitly-declared copy constructors for
3580 /// which declarations were built.
3582
3583 /// The number of implicitly-declared move constructors.
3585
3586 /// The number of implicitly-declared move constructors for
3587 /// which declarations were built.
3589
3590 /// The number of implicitly-declared copy assignment operators.
3592
3593 /// The number of implicitly-declared copy assignment operators for
3594 /// which declarations were built.
3596
3597 /// The number of implicitly-declared move assignment operators.
3599
3600 /// The number of implicitly-declared move assignment operators for
3601 /// which declarations were built.
3603
3604 /// The number of implicitly-declared destructors.
3606
3607 /// The number of implicitly-declared destructors for which
3608 /// declarations were built.
3610
3611public:
3612 /// Initialize built-in types.
3613 ///
3614 /// This routine may only be invoked once for a given ASTContext object.
3615 /// It is normally invoked after ASTContext construction.
3616 ///
3617 /// \param Target The target
3618 void InitBuiltinTypes(const TargetInfo &Target,
3619 const TargetInfo *AuxTarget = nullptr);
3620
3621private:
3622 void InitBuiltinType(CanQualType &R, BuiltinType::Kind K);
3623
3624 class ObjCEncOptions {
3625 unsigned Bits;
3626
3627 ObjCEncOptions(unsigned Bits) : Bits(Bits) {}
3628
3629 public:
3630 ObjCEncOptions() : Bits(0) {}
3631
3632#define OPT_LIST(V) \
3633 V(ExpandPointedToStructures, 0) \
3634 V(ExpandStructures, 1) \
3635 V(IsOutermostType, 2) \
3636 V(EncodingProperty, 3) \
3637 V(IsStructField, 4) \
3638 V(EncodeBlockParameters, 5) \
3639 V(EncodeClassNames, 6) \
3640
3641#define V(N,I) ObjCEncOptions& set##N() { Bits |= 1 << I; return *this; }
3642OPT_LIST(V)
3643#undef V
3644
3645#define V(N,I) bool N() const { return Bits & 1 << I; }
3646OPT_LIST(V)
3647#undef V
3648
3649#undef OPT_LIST
3650
3651 [[nodiscard]] ObjCEncOptions keepingOnly(ObjCEncOptions Mask) const {
3652 return Bits & Mask.Bits;
3653 }
3654
3655 [[nodiscard]] ObjCEncOptions forComponentType() const {
3656 ObjCEncOptions Mask = ObjCEncOptions()
3657 .setIsOutermostType()
3658 .setIsStructField();
3659 return Bits & ~Mask.Bits;
3660 }
3661 };
3662
3663 // Return the Objective-C type encoding for a given type.
3664 void getObjCEncodingForTypeImpl(QualType t, std::string &S,
3665 ObjCEncOptions Options,
3666 const FieldDecl *Field,
3667 QualType *NotEncodedT = nullptr) const;
3668
3669 // Adds the encoding of the structure's members.
3670 void getObjCEncodingForStructureImpl(RecordDecl *RD, std::string &S,
3671 const FieldDecl *Field,
3672 bool includeVBases = true,
3673 QualType *NotEncodedT=nullptr) const;
3674
3675public:
3676 // Adds the encoding of a method parameter or return type.
3678 QualType T, std::string& S,
3679 bool Extended) const;
3680
3681 /// Returns true if this is an inline-initialized static data member
3682 /// which is treated as a definition for MSVC compatibility.
3683 bool isMSStaticDataMemberInlineDefinition(const VarDecl *VD) const;
3684
3686 /// Not an inline variable.
3687 None,
3688
3689 /// Weak definition of inline variable.
3691
3692 /// Weak for now, might become strong later in this TU.
3694
3695 /// Strong definition.
3697 };
3698
3699 /// Determine whether a definition of this inline variable should
3700 /// be treated as a weak or strong definition. For compatibility with
3701 /// C++14 and before, for a constexpr static data member, if there is an
3702 /// out-of-line declaration of the member, we may promote it from weak to
3703 /// strong.
3706
3707private:
3709 friend class DeclContext;
3710
3711 const ASTRecordLayout &getObjCLayout(const ObjCInterfaceDecl *D) const;
3712
3713 /// A set of deallocations that should be performed when the
3714 /// ASTContext is destroyed.
3715 // FIXME: We really should have a better mechanism in the ASTContext to
3716 // manage running destructors for types which do variable sized allocation
3717 // within the AST. In some places we thread the AST bump pointer allocator
3718 // into the datastructures which avoids this mess during deallocation but is
3719 // wasteful of memory, and here we require a lot of error prone book keeping
3720 // in order to track and run destructors while we're tearing things down.
3721 using DeallocationFunctionsAndArguments =
3722 llvm::SmallVector<std::pair<void (*)(void *), void *>, 16>;
3723 mutable DeallocationFunctionsAndArguments Deallocations;
3724
3725 // FIXME: This currently contains the set of StoredDeclMaps used
3726 // by DeclContext objects. This probably should not be in ASTContext,
3727 // but we include it here so that ASTContext can quickly deallocate them.
3728 llvm::PointerIntPair<StoredDeclsMap *, 1> LastSDM;
3729
3730 std::vector<Decl *> TraversalScope;
3731
3732 std::unique_ptr<VTableContextBase> VTContext;
3733
3734 void ReleaseDeclContextMaps();
3735
3736public:
3737 enum PragmaSectionFlag : unsigned {
3744 PSF_Invalid = 0x80000000U,
3745 };
3746
3758
3759 llvm::StringMap<SectionInfo> SectionInfos;
3760
3761 /// Return a new OMPTraitInfo object owned by this context.
3763
3764 /// Whether a C++ static variable or CUDA/HIP kernel may be externalized.
3765 bool mayExternalize(const Decl *D) const;
3766
3767 /// Whether a C++ static variable or CUDA/HIP kernel should be externalized.
3768 bool shouldExternalize(const Decl *D) const;
3769
3770 /// Resolve the root record to be used to derive the vtable pointer
3771 /// authentication policy for the specified record.
3772 const CXXRecordDecl *
3773 baseForVTableAuthentication(const CXXRecordDecl *ThisClass) const;
3774
3775 bool useAbbreviatedThunkName(GlobalDecl VirtualMethodDecl,
3776 StringRef MangledName);
3777
3778 StringRef getCUIDHash() const;
3779
3780private:
3781 /// All OMPTraitInfo objects live in this collection, one per
3782 /// `pragma omp [begin] declare variant` directive.
3783 SmallVector<std::unique_ptr<OMPTraitInfo>, 4> OMPTraitInfoVector;
3784
3785 llvm::DenseMap<GlobalDecl, llvm::StringSet<>> ThunksToBeAbbreviated;
3786};
3787
3788/// Insertion operator for diagnostics.
3790 const ASTContext::SectionInfo &Section);
3791
3792/// Utility function for constructing a nullary selector.
3793inline Selector GetNullarySelector(StringRef name, ASTContext &Ctx) {
3794 const IdentifierInfo *II = &Ctx.Idents.get(name);
3795 return Ctx.Selectors.getSelector(0, &II);
3796}
3797
3798/// Utility function for constructing an unary selector.
3799inline Selector GetUnarySelector(StringRef name, ASTContext &Ctx) {
3800 const IdentifierInfo *II = &Ctx.Idents.get(name);
3801 return Ctx.Selectors.getSelector(1, &II);
3802}
3803
3804} // namespace clang
3805
3806// operator new and delete aren't allowed inside namespaces.
3807
3808/// Placement new for using the ASTContext's allocator.
3809///
3810/// This placement form of operator new uses the ASTContext's allocator for
3811/// obtaining memory.
3812///
3813/// IMPORTANT: These are also declared in clang/AST/ASTContextAllocate.h!
3814/// Any changes here need to also be made there.
3815///
3816/// We intentionally avoid using a nothrow specification here so that the calls
3817/// to this operator will not perform a null check on the result -- the
3818/// underlying allocator never returns null pointers.
3819///
3820/// Usage looks like this (assuming there's an ASTContext 'Context' in scope):
3821/// @code
3822/// // Default alignment (8)
3823/// IntegerLiteral *Ex = new (Context) IntegerLiteral(arguments);
3824/// // Specific alignment
3825/// IntegerLiteral *Ex2 = new (Context, 4) IntegerLiteral(arguments);
3826/// @endcode
3827/// Memory allocated through this placement new operator does not need to be
3828/// explicitly freed, as ASTContext will free all of this memory when it gets
3829/// destroyed. Please note that you cannot use delete on the pointer.
3830///
3831/// @param Bytes The number of bytes to allocate. Calculated by the compiler.
3832/// @param C The ASTContext that provides the allocator.
3833/// @param Alignment The alignment of the allocated memory (if the underlying
3834/// allocator supports it).
3835/// @return The allocated memory. Could be nullptr.
3836inline void *operator new(size_t Bytes, const clang::ASTContext &C,
3837 size_t Alignment /* = 8 */) {
3838 return C.Allocate(Bytes, Alignment);
3839}
3840
3841/// Placement delete companion to the new above.
3842///
3843/// This operator is just a companion to the new above. There is no way of
3844/// invoking it directly; see the new operator for more details. This operator
3845/// is called implicitly by the compiler if a placement new expression using
3846/// the ASTContext throws in the object constructor.
3847inline void operator delete(void *Ptr, const clang::ASTContext &C, size_t) {
3848 C.Deallocate(Ptr);
3849}
3850
3851/// This placement form of operator new[] uses the ASTContext's allocator for
3852/// obtaining memory.
3853///
3854/// We intentionally avoid using a nothrow specification here so that the calls
3855/// to this operator will not perform a null check on the result -- the
3856/// underlying allocator never returns null pointers.
3857///
3858/// Usage looks like this (assuming there's an ASTContext 'Context' in scope):
3859/// @code
3860/// // Default alignment (8)
3861/// char *data = new (Context) char[10];
3862/// // Specific alignment
3863/// char *data = new (Context, 4) char[10];
3864/// @endcode
3865/// Memory allocated through this placement new[] operator does not need to be
3866/// explicitly freed, as ASTContext will free all of this memory when it gets
3867/// destroyed. Please note that you cannot use delete on the pointer.
3868///
3869/// @param Bytes The number of bytes to allocate. Calculated by the compiler.
3870/// @param C The ASTContext that provides the allocator.
3871/// @param Alignment The alignment of the allocated memory (if the underlying
3872/// allocator supports it).
3873/// @return The allocated memory. Could be nullptr.
3874inline void *operator new[](size_t Bytes, const clang::ASTContext& C,
3875 size_t Alignment /* = 8 */) {
3876 return C.Allocate(Bytes, Alignment);
3877}
3878
3879/// Placement delete[] companion to the new[] above.
3880///
3881/// This operator is just a companion to the new[] above. There is no way of
3882/// invoking it directly; see the new[] operator for more details. This operator
3883/// is called implicitly by the compiler if a placement new[] expression using
3884/// the ASTContext throws in the object constructor.
3885inline void operator delete[](void *Ptr, const clang::ASTContext &C, size_t) {
3886 C.Deallocate(Ptr);
3887}
3888
3889/// Create the representation of a LazyGenerationalUpdatePtr.
3890template <typename Owner, typename T,
3891 void (clang::ExternalASTSource::*Update)(Owner)>
3894 const clang::ASTContext &Ctx, T Value) {
3895 // Note, this is implemented here so that ExternalASTSource.h doesn't need to
3896 // include ASTContext.h. We explicitly instantiate it for all relevant types
3897 // in ASTContext.cpp.
3898 if (auto *Source = Ctx.getExternalSource())
3899 return new (Ctx) LazyData(Source, Value);
3900 return Value;
3901}
3902template <> struct llvm::DenseMapInfo<llvm::FoldingSetNodeID> {
3903 static FoldingSetNodeID getEmptyKey() { return FoldingSetNodeID{}; }
3904
3905 static FoldingSetNodeID getTombstoneKey() {
3906 FoldingSetNodeID ID;
3907 for (size_t I = 0; I < sizeof(ID) / sizeof(unsigned); ++I) {
3908 ID.AddInteger(std::numeric_limits<unsigned>::max());
3909 }
3910 return ID;
3911 }
3912
3913 static unsigned getHashValue(const FoldingSetNodeID &Val) {
3914 return Val.ComputeHash();
3915 }
3916
3917 static bool isEqual(const FoldingSetNodeID &LHS,
3918 const FoldingSetNodeID &RHS) {
3919 return LHS == RHS;
3920 }
3921};
3922
3923#endif // LLVM_CLANG_AST_ASTCONTEXT_H
#define OPT_LIST(V)
#define V(N, I)
Forward declaration of all AST node types.
static bool CanThrow(Expr *E, ASTContext &Ctx)
Definition CFG.cpp:2777
clang::CharUnits operator*(clang::CharUnits::QuantityType Scale, const clang::CharUnits &CU)
Definition CharUnits.h:225
#define X(type, name)
Definition Value.h:97
Forward-declares and imports various common LLVM datatypes that clang wants to use unqualified.
#define SM(sm)
Implements a partial diagnostic that can be emitted anwyhere in a DiagnosticBuilder stream.
This file declares types used to describe SYCL kernels.
Defines the clang::SourceLocation class and associated facilities.
#define CXXABI(Name, Str)
Allows QualTypes to be sorted and hence used in maps and sets.
__SIZE_TYPE__ size_t
The unsigned integer type of the result of the sizeof operator.
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
Definition ASTContext.h:220
ASTContext(LangOptions &LOpts, SourceManager &SM, IdentifierTable &idents, SelectorTable &sels, Builtin::Context &builtins, TranslationUnitKind TUKind)
APValue - This class implements a discriminated union of [uninitialized] [APSInt] [APFloat],...
Definition APValue.h:122
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
Definition ASTContext.h:220
bool getByrefLifetime(QualType Ty, Qualifiers::ObjCLifetime &Lifetime, bool &HasByrefExtendedLayout) const
Returns true, if given type has a known lifetime.
MSGuidDecl * getMSGuidDecl(MSGuidDeclParts Parts) const
Return a declaration for the global GUID object representing the given GUID value.
CanQualType AccumTy
BuiltinVectorTypeInfo getBuiltinVectorTypeInfo(const BuiltinType *VecTy) const
Returns the element type, element count and number of vectors (in case of tuple) for a builtin vector...
bool ObjCMethodsAreEqual(const ObjCMethodDecl *MethodDecl, const ObjCMethodDecl *MethodImp)
CanQualType ObjCBuiltinSelTy
SourceManager & getSourceManager()
Definition ASTContext.h:845
TranslationUnitDecl * getTranslationUnitDecl() const
const ConstantArrayType * getAsConstantArrayType(QualType T) const
CanQualType getCanonicalFunctionResultType(QualType ResultType) const
Adjust the given function result type.
QualType getAtomicType(QualType T) const
Return the uniqued reference to the atomic type for the specified type.
LangAS getOpenCLTypeAddrSpace(const Type *T) const
Get address space for OpenCL type.
friend class ASTWriter
Definition ASTContext.h:565
CharUnits getTypeAlignInChars(QualType T) const
Return the ABI-specified alignment of a (complete) type T, in characters.
void InitBuiltinTypes(const TargetInfo &Target, const TargetInfo *AuxTarget=nullptr)
Initialize built-in types.
ParentMapContext & getParentMapContext()
Returns the dynamic AST node parent map context.
QualType getParenType(QualType NamedType) const
size_t getSideTableAllocatedMemory() const
Return the total memory used for various side tables.
MemberSpecializationInfo * getInstantiatedFromStaticDataMember(const VarDecl *Var)
If this variable is an instantiated static data member of a class template specialization,...
QualType getRValueReferenceType(QualType T) const
Return the uniqued reference to the type for an rvalue reference to the specified type.
CanQualType ARCUnbridgedCastTy
uint64_t getTypeSize(const Type *T) const
QualType getDependentSizedMatrixType(QualType ElementType, Expr *RowExpr, Expr *ColumnExpr, SourceLocation AttrLoc) const
Return the unique reference to the matrix type of the specified element type and size.
QualType getBTFTagAttributedType(const BTFTypeTagAttr *BTFAttr, QualType Wrapped) const
llvm::DenseMap< const Decl *, comments::FullComment * > ParsedComments
Mapping from declarations to parsed comments attached to any redeclaration.
unsigned getManglingNumber(const NamedDecl *ND, bool ForAuxTarget=false) const
static const Type * getCanonicalType(const Type *T)
CanQualType LongTy
const SmallVectorImpl< Type * > & getTypes() const
unsigned getIntWidth(QualType T) const
CanQualType getCanonicalParamType(QualType T) const
Return the canonical parameter type corresponding to the specific potentially non-canonical one.
const FunctionType * adjustFunctionType(const FunctionType *Fn, FunctionType::ExtInfo EInfo)
Change the ExtInfo on a function type.
TemplateOrSpecializationInfo getTemplateOrSpecializationInfo(const VarDecl *Var)
CanQualType WIntTy
@ Weak
Weak definition of inline variable.
@ WeakUnknown
Weak for now, might become strong later in this TU.
bool dtorHasOperatorDelete(const CXXDestructorDecl *Dtor, OperatorDeleteKind K) const
const ProfileList & getProfileList() const
Definition ASTContext.h:957
void setObjCConstantStringInterface(ObjCInterfaceDecl *Decl)
TypedefDecl * getObjCClassDecl() const
Retrieve the typedef declaration corresponding to the predefined Objective-C 'Class' type.
TypedefNameDecl * getTypedefNameForUnnamedTagDecl(const TagDecl *TD)
QualType getTypeDeclType(const UnresolvedUsingTypenameDecl *) const =delete
TypedefDecl * getCFConstantStringDecl() const
CanQualType Int128Ty
CanQualType SatUnsignedFractTy
CanQualType getAdjustedType(CanQualType Orig, CanQualType New) const
void setInstantiatedFromUsingDecl(NamedDecl *Inst, NamedDecl *Pattern)
Remember that the using decl Inst is an instantiation of the using decl Pattern of a class template.
bool areCompatibleRVVTypes(QualType FirstType, QualType SecondType)
Return true if the given types are an RISC-V vector builtin type and a VectorType that is a fixed-len...
ExternCContextDecl * getExternCContextDecl() const
const llvm::fltSemantics & getFloatTypeSemantics(QualType T) const
Return the APFloat 'semantics' for the specified scalar floating point type.
ParsedTargetAttr filterFunctionTargetAttrs(const TargetAttr *TD) const
Parses the target attributes passed in, and returns only the ones that are valid feature names.
QualType areCommonBaseCompatible(const ObjCObjectPointerType *LHSOPT, const ObjCObjectPointerType *RHSOPT)
TypedefDecl * getObjCSelDecl() const
Retrieve the typedef corresponding to the predefined 'SEL' type in Objective-C.
llvm::iterator_range< import_iterator > import_range
bool AnyObjCImplementation()
Return true if there is at least one @implementation in the TU.
CanQualType UnsignedShortAccumTy
TypedefDecl * getObjCInstanceTypeDecl()
Retrieve the typedef declaration corresponding to the Objective-C "instancetype" type.
uint64_t getFieldOffset(const ValueDecl *FD) const
Get the offset of a FieldDecl or IndirectFieldDecl, in bits.
void DeallocateDeclListNode(DeclListNode *N)
Deallocates a DeclListNode by returning it to the ListNodeFreeList pool.
Definition ASTContext.h:885
DeclListNode * AllocateDeclListNode(clang::NamedDecl *ND)
Allocates a DeclListNode or returns one from the ListNodeFreeList pool.
Definition ASTContext.h:874
QualType adjustFunctionResultType(QualType FunctionType, QualType NewResultType)
Change the result type of a function type, preserving sugar such as attributed types.
void setTemplateOrSpecializationInfo(VarDecl *Inst, TemplateOrSpecializationInfo TSI)
bool isTypeAwareOperatorNewOrDelete(const FunctionDecl *FD) const
bool ProtocolCompatibleWithProtocol(ObjCProtocolDecl *lProto, ObjCProtocolDecl *rProto) const
ProtocolCompatibleWithProtocol - return 'true' if 'lProto' is in the inheritance hierarchy of 'rProto...
TypedefDecl * buildImplicitTypedef(QualType T, StringRef Name) const
Create a new implicit TU-level typedef declaration.
unsigned getTypeAlign(const Type *T) const
QualType getCanonicalTemplateSpecializationType(ElaboratedTypeKeyword Keyword, TemplateName T, ArrayRef< TemplateArgument > CanonicalArgs) const
QualType getObjCInterfaceType(const ObjCInterfaceDecl *Decl, ObjCInterfaceDecl *PrevDecl=nullptr) const
getObjCInterfaceType - Return the unique reference to the type for the specified ObjC interface decl.
void adjustObjCTypeParamBoundType(const ObjCTypeParamDecl *Orig, ObjCTypeParamDecl *New) const
llvm::StringMap< SectionInfo > SectionInfos
QualType getBlockPointerType(QualType T) const
Return the uniqued reference to the type for a block of the specified type.
TemplateArgument getCanonicalTemplateArgument(const TemplateArgument &Arg) const
Retrieve the "canonical" template argument.
QualType getAutoRRefDeductType() const
C++11 deduction pattern for 'auto &&' type.
TypedefDecl * getBuiltinMSVaListDecl() const
Retrieve the C type declaration corresponding to the predefined __builtin_ms_va_list type.
bool ObjCQualifiedIdTypesAreCompatible(const ObjCObjectPointerType *LHS, const ObjCObjectPointerType *RHS, bool ForCompare)
ObjCQualifiedIdTypesAreCompatible - We know that one of lhs/rhs is an ObjCQualifiedIDType.
static CanQualType getCanonicalType(QualType T)
Return the canonical (structural) type corresponding to the specified potentially non-canonical type ...
QualType getBuiltinVaListType() const
Retrieve the type of the __builtin_va_list type.
QualType mergeFunctionTypes(QualType, QualType, bool OfBlockPointer=false, bool Unqualified=false, bool AllowCXX=false, bool IsConditionalOperator=false)
NamedDecl * getInstantiatedFromUsingDecl(NamedDecl *Inst)
If the given using decl Inst is an instantiation of another (possibly unresolved) using decl,...
DeclarationNameTable DeclarationNames
Definition ASTContext.h:788
comments::FullComment * cloneFullComment(comments::FullComment *FC, const Decl *D) const
bool containsNonRelocatablePointerAuth(QualType T)
Examines a given type, and returns whether the type itself or any data it transitively contains has a...
Definition ASTContext.h:700
CharUnits getObjCEncodingTypeSize(QualType T) const
Return the size of type T for Objective-C encoding purpose, in characters.
int getIntegerTypeOrder(QualType LHS, QualType RHS) const
Return the highest ranked integer type, see C99 6.3.1.8p1.
QualType getObjCClassType() const
Represents the Objective-C Class type.
QualType getAttributedType(attr::Kind attrKind, QualType modifiedType, QualType equivalentType, const Attr *attr=nullptr) const
TypedefDecl * getObjCIdDecl() const
Retrieve the typedef corresponding to the predefined id type in Objective-C.
void setCurrentNamedModule(Module *M)
Set the (C++20) module we are building.
QualType getRawCFConstantStringType() const
Get the structure type used to representation CFStrings, or NULL if it hasn't yet been built.
QualType getProcessIDType() const
Return the unique type for "pid_t" defined in <sys/types.h>.
CharUnits getMemberPointerPathAdjustment(const APValue &MP) const
Find the 'this' offset for the member path in a pointer-to-member APValue.
bool mayExternalize(const Decl *D) const
Whether a C++ static variable or CUDA/HIP kernel may be externalized.
std::unique_ptr< MangleNumberingContext > createMangleNumberingContext() const
CanQualType SatAccumTy
QualType getUnsignedPointerDiffType() const
Return the unique unsigned counterpart of "ptrdiff_t" integer type.
QualType getucontext_tType() const
Retrieve the C ucontext_t type.
std::optional< CharUnits > getTypeSizeInCharsIfKnown(const Type *Ty) const
QualType getScalableVectorType(QualType EltTy, unsigned NumElts, unsigned NumFields=1) const
Return the unique reference to a scalable vector type of the specified element type and scalable numb...
bool hasSameExpr(const Expr *X, const Expr *Y) const
Determine whether the given expressions X and Y are equivalent.
void getObjCEncodingForType(QualType T, std::string &S, const FieldDecl *Field=nullptr, QualType *NotEncodedT=nullptr) const
Emit the Objective-CC type encoding for the given type T into S.
QualType getBuiltinMSVaListType() const
Retrieve the type of the __builtin_ms_va_list type.
MangleContext * createMangleContext(const TargetInfo *T=nullptr)
If T is null pointer, assume the target in ASTContext.
QualType getRealTypeForBitwidth(unsigned DestWidth, FloatModeKind ExplicitType) const
getRealTypeForBitwidth - sets floating point QualTy according to specified bitwidth.
ArrayRef< Decl * > getTraversalScope() const
Definition ASTContext.h:830
QualType getFunctionNoProtoType(QualType ResultTy, const FunctionType::ExtInfo &Info) const
Return a K&R style C function type like 'int()'.
CanQualType ShortAccumTy
ASTMutationListener * getASTMutationListener() const
Retrieve a pointer to the AST mutation listener associated with this AST context, if any.
unsigned NumImplicitCopyAssignmentOperatorsDeclared
The number of implicitly-declared copy assignment operators for which declarations were built.
uint64_t getTargetNullPointerValue(QualType QT) const
Get target-dependent integer value for null pointer which is used for constant folding.
unsigned getTypeUnadjustedAlign(QualType T) const
Return the ABI-specified natural alignment of a (complete) type T, before alignment adjustments,...
unsigned char getFixedPointIBits(QualType Ty) const
QualType getSubstBuiltinTemplatePack(const TemplateArgument &ArgPack)
QualType getCorrespondingSignedFixedPointType(QualType Ty) const
IntrusiveRefCntPtr< ExternalASTSource > ExternalSource
Definition ASTContext.h:789
CanQualType FloatTy
QualType getArrayParameterType(QualType Ty) const
Return the uniqued reference to a specified array parameter type from the original array type.
QualType getCountAttributedType(QualType T, Expr *CountExpr, bool CountInBytes, bool OrNull, ArrayRef< TypeCoupledDeclRefInfo > DependentDecls) const
void setObjCIdRedefinitionType(QualType RedefType)
Set the user-written type that redefines id.
bool isObjCIdType(QualType T) const
const ASTRecordLayout & getASTRecordLayout(const RecordDecl *D) const
Get or compute information about the layout of the specified record (struct/union/class) D,...
DynTypedNodeList getParents(const NodeT &Node)
Forwards to get node parents from the ParentMapContext.
friend class IncrementalParser
Definition ASTContext.h:568
unsigned NumImplicitDestructorsDeclared
The number of implicitly-declared destructors for which declarations were built.
bool isObjCClassType(QualType T) const
void setObjCNSStringType(QualType T)
bool mergeExtParameterInfo(const FunctionProtoType *FirstFnType, const FunctionProtoType *SecondFnType, bool &CanUseFirst, bool &CanUseSecond, SmallVectorImpl< FunctionProtoType::ExtParameterInfo > &NewParamInfos)
This function merges the ExtParameterInfo lists of two functions.
bool ObjCQualifiedClassTypesAreCompatible(const ObjCObjectPointerType *LHS, const ObjCObjectPointerType *RHS)
ObjCQualifiedClassTypesAreCompatible - compare Class<pr,...> and Class<pr1, ...>.
bool shouldExternalize(const Decl *D) const
Whether a C++ static variable or CUDA/HIP kernel should be externalized.
FullSourceLoc getFullLoc(SourceLocation Loc) const
Definition ASTContext.h:961
bool propertyTypesAreCompatible(QualType, QualType)
void setInstantiatedFromUsingShadowDecl(UsingShadowDecl *Inst, UsingShadowDecl *Pattern)
CanQualType DoubleTy
QualType getDependentVectorType(QualType VectorType, Expr *SizeExpr, SourceLocation AttrLoc, VectorKind VecKind) const
Return the unique reference to the type for a dependently sized vector of the specified element type.
comments::CommandTraits & getCommentCommandTraits() const
CanQualType SatLongAccumTy
const XRayFunctionFilter & getXRayFilter() const
Definition ASTContext.h:953
CanQualType getIntMaxType() const
Return the unique type for "intmax_t" (C99 7.18.1.5), defined in <stdint.h>.
QualType getVectorType(QualType VectorType, unsigned NumElts, VectorKind VecKind) const
Return the unique reference to a vector type of the specified element type and size.
OpenCLTypeKind getOpenCLTypeKind(const Type *T) const
Map an AST Type to an OpenCLTypeKind enum value.
TemplateName getDependentTemplateName(const DependentTemplateStorage &Name) const
Retrieve the template name that represents a dependent template name such as MetaFun::template operat...
QualType getFILEType() const
Retrieve the C FILE type.
ArrayRef< Decl * > getModuleInitializers(Module *M)
Get the initializations to perform when importing a module, if any.
void getObjCEncodingForTypeQualifier(Decl::ObjCDeclQualifier QT, std::string &S) const
Put the string version of the type qualifiers QT into S.
unsigned getPreferredTypeAlign(QualType T) const
Return the "preferred" alignment of the specified type T for the current target, in bits.
void setsigjmp_bufDecl(TypeDecl *sigjmp_bufDecl)
Set the type for the C sigjmp_buf type.
std::string getObjCEncodingForMethodDecl(const ObjCMethodDecl *Decl, bool Extended=false) const
Emit the encoded type for the method declaration Decl into S.
void DumpRecordLayout(const RecordDecl *RD, raw_ostream &OS, bool Simple=false) const
bool DeclMustBeEmitted(const Decl *D)
Determines if the decl can be CodeGen'ed or deserialized from PCH lazily, only when used; this is onl...
CanQualType LongDoubleTy
CanQualType OMPArrayShapingTy
ASTContext(LangOptions &LOpts, SourceManager &SM, IdentifierTable &idents, SelectorTable &sels, Builtin::Context &builtins, TranslationUnitKind TUKind)
QualType getReadPipeType(QualType T) const
Return a read_only pipe type for the specified type.
std::string getObjCEncodingForPropertyDecl(const ObjCPropertyDecl *PD, const Decl *Container) const
getObjCEncodingForPropertyDecl - Return the encoded type for this method declaration.
CanQualType Char16Ty
TemplateName getCanonicalTemplateName(TemplateName Name, bool IgnoreDeduced=false) const
Retrieves the "canonical" template name that refers to a given template.
unsigned getStaticLocalNumber(const VarDecl *VD) const
QualType getObjCSelRedefinitionType() const
Retrieve the type that 'SEL' has been defined to, which may be different from the built-in 'SEL' if '...
void addComment(const RawComment &RC)
void getLegacyIntegralTypeEncoding(QualType &t) const
getLegacyIntegralTypeEncoding - Another legacy compatibility encoding: 32-bit longs are encoded as 'l...
bool isSameTypeConstraint(const TypeConstraint *XTC, const TypeConstraint *YTC) const
Determine whether two type contraint are similar enough that they could used in declarations of the s...
void setRelocationInfoForCXXRecord(const CXXRecordDecl *, CXXRecordDeclRelocationInfo)
QualType getSubstTemplateTypeParmType(QualType Replacement, Decl *AssociatedDecl, unsigned Index, UnsignedOrNone PackIndex, bool Final) const
Retrieve a substitution-result type.
RecordDecl * buildImplicitRecord(StringRef Name, RecordDecl::TagKind TK=RecordDecl::TagKind::Struct) const
Create a new implicit TU-level CXXRecordDecl or RecordDecl declaration.
void setObjCSelRedefinitionType(QualType RedefType)
Set the user-written type that redefines 'SEL'.
void setFILEDecl(TypeDecl *FILEDecl)
Set the type for the C FILE type.
QualType getPointerType(QualType T) const
Return the uniqued reference to the type for a pointer to the specified type.
const IncompleteArrayType * getAsIncompleteArrayType(QualType T) const
const CXXMethodDecl * getCurrentKeyFunction(const CXXRecordDecl *RD)
Get our current best idea for the key function of the given record decl, or nullptr if there isn't on...
CanQualType UnsignedLongFractTy
QualType mergeTagDefinitions(QualType, QualType)
overridden_method_range overridden_methods(const CXXMethodDecl *Method) const
void setIsTypeAwareOperatorNewOrDelete(const FunctionDecl *FD, bool IsTypeAware)
bool hasSeenTypeAwareOperatorNewOrDelete() const
QualType getDependentBitIntType(bool Unsigned, Expr *BitsExpr) const
Return a dependent bit-precise integer type with the specified signedness and bit count.
void setObjCImplementation(ObjCInterfaceDecl *IFaceD, ObjCImplementationDecl *ImplD)
Set the implementation of ObjCInterfaceDecl.
StringRef getCUIDHash() const
bool isMSStaticDataMemberInlineDefinition(const VarDecl *VD) const
Returns true if this is an inline-initialized static data member which is treated as a definition for...
bool canAssignObjCInterfaces(const ObjCObjectPointerType *LHSOPT, const ObjCObjectPointerType *RHSOPT)
canAssignObjCInterfaces - Return true if the two interface types are compatible for assignment from R...
CanQualType VoidPtrTy
QualType getReferenceQualifiedType(const Expr *e) const
getReferenceQualifiedType - Given an expr, will return the type for that expression,...
bool hasSameFunctionTypeIgnoringExceptionSpec(QualType T, QualType U) const
Determine whether two function types are the same, ignoring exception specifications in cases where t...
bool isObjCSelType(QualType T) const
QualType getBlockDescriptorExtendedType() const
Gets the struct used to keep track of the extended descriptor for pointer to blocks.
void Deallocate(void *Ptr) const
Definition ASTContext.h:864
QualType getLValueReferenceType(QualType T, bool SpelledAsLValue=true) const
Return the uniqued reference to the type for an lvalue reference to the specified type.
CanQualType DependentTy
bool QIdProtocolsAdoptObjCObjectProtocols(QualType QT, ObjCInterfaceDecl *IDecl)
QIdProtocolsAdoptObjCObjectProtocols - Checks that protocols in QT's qualified-id protocol list adopt...
FunctionProtoType::ExceptionSpecInfo mergeExceptionSpecs(FunctionProtoType::ExceptionSpecInfo ESI1, FunctionProtoType::ExceptionSpecInfo ESI2, SmallVectorImpl< QualType > &ExceptionTypeStorage, bool AcceptDependent) const
void addLazyModuleInitializers(Module *M, ArrayRef< GlobalDeclID > IDs)
bool isSameConstraintExpr(const Expr *XCE, const Expr *YCE) const
Determine whether two 'requires' expressions are similar enough that they may be used in re-declarati...
bool BlockRequiresCopying(QualType Ty, const VarDecl *D)
Returns true iff we need copy/dispose helpers for the given type.
QualType getTypeDeclType(const TypeAliasDecl *) const =delete
CanQualType NullPtrTy
QualType getUsingType(ElaboratedTypeKeyword Keyword, NestedNameSpecifier Qualifier, const UsingShadowDecl *D, QualType UnderlyingType=QualType()) const
CanQualType WideCharTy
CanQualType OMPIteratorTy
IdentifierTable & Idents
Definition ASTContext.h:784
Builtin::Context & BuiltinInfo
Definition ASTContext.h:786
bool computeEnumBits(RangeT EnumConstants, unsigned &NumNegativeBits, unsigned &NumPositiveBits)
Compute NumNegativeBits and NumPositiveBits for an enum based on the constant values of its enumerato...
QualType getConstantArrayType(QualType EltTy, const llvm::APInt &ArySize, const Expr *SizeExpr, ArraySizeModifier ASM, unsigned IndexTypeQuals) const
Return the unique reference to the type for a constant array of the specified element type.
void addModuleInitializer(Module *M, Decl *Init)
Add a declaration to the list of declarations that are initialized for a module.
const LangOptions & getLangOpts() const
Definition ASTContext.h:938
QualType getConstType(QualType T) const
Return the uniqued reference to the type for a const qualified type.
bool containsAddressDiscriminatedPointerAuth(QualType T) const
Examines a given type, and returns whether the type itself is address discriminated,...
Definition ASTContext.h:689
QualType getFunctionTypeWithoutPtrSizes(QualType T)
Get a function type and produce the equivalent function type where pointer size address spaces in the...
uint64_t lookupFieldBitOffset(const ObjCInterfaceDecl *OID, const ObjCIvarDecl *Ivar) const
Get the offset of an ObjCIvarDecl in bits.
CanQualType getLogicalOperationType() const
The result type of logical operations, '<', '>', '!=', etc.
SelectorTable & Selectors
Definition ASTContext.h:785
bool isTypeIgnoredBySanitizer(const SanitizerMask &Mask, const QualType &Ty) const
Check if a type can have its sanitizer instrumentation elided based on its presence within an ignorel...
unsigned getMinGlobalAlignOfVar(uint64_t Size, const VarDecl *VD) const
Return the minimum alignment as specified by the target.
RawCommentList Comments
All comments in this translation unit.
Definition ASTContext.h:971
bool isSameDefaultTemplateArgument(const NamedDecl *X, const NamedDecl *Y) const
Determine whether two default template arguments are similar enough that they may be used in declarat...
QualType applyObjCProtocolQualifiers(QualType type, ArrayRef< ObjCProtocolDecl * > protocols, bool &hasError, bool allowOnPointerType=false) const
Apply Objective-C protocol qualifiers to the given type.
QualType getMacroQualifiedType(QualType UnderlyingTy, const IdentifierInfo *MacroII) const
QualType removePtrSizeAddrSpace(QualType T) const
Remove the existing address space on the type if it is a pointer size address space and return the ty...
bool areLaxCompatibleRVVTypes(QualType FirstType, QualType SecondType)
Return true if the given vector types are lax-compatible RISC-V vector types as defined by -flax-vect...
void setObjCSuperType(QualType ST)
TagDecl * MSTypeInfoTagDecl
TypedefDecl * getBOOLDecl() const
Retrieve declaration of 'BOOL' typedef.
CanQualType SatShortFractTy
QualType getDecayedType(QualType T) const
Return the uniqued reference to the decayed version of the given type.
CallingConv getDefaultCallingConvention(bool IsVariadic, bool IsCXXMethod) const
Retrieves the default calling convention for the current context.
bool canBindObjCObjectType(QualType To, QualType From)
unsigned getNextStringLiteralVersion()
Return the next version number to be used for a string literal evaluated as part of constant evaluati...
TemplateTemplateParmDecl * insertCanonicalTemplateTemplateParmDeclInternal(TemplateTemplateParmDecl *CanonTTP) const
int getFloatingTypeSemanticOrder(QualType LHS, QualType RHS) const
Compare the rank of two floating point types as above, but compare equal if both types have the same ...
QualType getUIntPtrType() const
Return a type compatible with "uintptr_t" (C99 7.18.1.4), as defined by the target.
void setParameterIndex(const ParmVarDecl *D, unsigned index)
Used by ParmVarDecl to store on the side the index of the parameter when it exceeds the size of the n...
QualType getFunctionTypeWithExceptionSpec(QualType Orig, const FunctionProtoType::ExceptionSpecInfo &ESI) const
Get a function type and produce the equivalent function type with the specified exception specificati...
QualType getObjCInstanceType()
Retrieve the Objective-C "instancetype" type.
QualType getDependentNameType(ElaboratedTypeKeyword Keyword, NestedNameSpecifier NNS, const IdentifierInfo *Name) const
Qualifiers::GC getObjCGCAttrKind(QualType Ty) const
Return one of the GCNone, Weak or Strong Objective-C garbage collection attributes.
PartialDiagnostic::DiagStorageAllocator & getDiagAllocator()
Definition ASTContext.h:899
static bool hasSameType(const Type *T1, const Type *T2)
CanQualType Ibm128Ty
void setASTMutationListener(ASTMutationListener *Listener)
Attach an AST mutation listener to the AST context.
bool hasUniqueObjectRepresentations(QualType Ty, bool CheckIfTriviallyCopyable=true) const
Return true if the specified type has unique object representations according to (C++17 [meta....
const QualType GetHigherPrecisionFPType(QualType ElementType) const
Definition ASTContext.h:906
CanQualType getCanonicalSizeType() const
bool typesAreBlockPointerCompatible(QualType, QualType)
CanQualType SatUnsignedAccumTy
bool useAbbreviatedThunkName(GlobalDecl VirtualMethodDecl, StringRef MangledName)
const ASTRecordLayout & getASTObjCInterfaceLayout(const ObjCInterfaceDecl *D) const
Get or compute information about the layout of the specified Objective-C interface.
friend class ASTReader
Definition ASTContext.h:564
QualType getObjCProtoType() const
Retrieve the type of the Objective-C Protocol class.
void forEachMultiversionedFunctionVersion(const FunctionDecl *FD, llvm::function_ref< void(FunctionDecl *)> Pred) const
Visits all versions of a multiversioned function with the passed predicate.
void setInstantiatedFromUsingEnumDecl(UsingEnumDecl *Inst, UsingEnumDecl *Pattern)
Remember that the using enum decl Inst is an instantiation of the using enum decl Pattern of a class ...
QualType getBaseElementType(const ArrayType *VAT) const
Return the innermost element type of an array type.
QualType getPointerDiffType() const
Return the unique type for "ptrdiff_t" (C99 7.17) defined in <stddef.h>.
Decl * getPrimaryMergedDecl(Decl *D)
QualType getSignatureParameterType(QualType T) const
Retrieve the parameter type as adjusted for use in the signature of a function, decaying array and fu...
CanQualType ArraySectionTy
CanQualType ObjCBuiltinIdTy
overridden_cxx_method_iterator overridden_methods_end(const CXXMethodDecl *Method) const
VTableContextBase * getVTableContext()
void setBOOLDecl(TypedefDecl *TD)
Save declaration of 'BOOL' typedef.
llvm::SetVector< const ValueDecl * > CUDAExternalDeviceDeclODRUsedByHost
Keep track of CUDA/HIP external kernels or device variables ODR-used by host code.
ComparisonCategories CompCategories
Types and expressions required to build C++2a three-way comparisons using operator<=>,...
int getFloatingTypeOrder(QualType LHS, QualType RHS) const
Compare the rank of the two specified floating point types, ignoring the domain of the type (i....
unsigned CountNonClassIvars(const ObjCInterfaceDecl *OI) const
ASTContext(const ASTContext &)=delete
ObjCPropertyImplDecl * getObjCPropertyImplDeclForPropertyDecl(const ObjCPropertyDecl *PD, const Decl *Container) const
bool isNearlyEmpty(const CXXRecordDecl *RD) const
PointerAuthQualifier getObjCMemberSelTypePtrAuth()
QualType AutoDeductTy
CanQualType BoolTy
void cacheRawCommentForDecl(const Decl &OriginalD, const RawComment &Comment) const
Attaches Comment to OriginalD and to its redeclaration chain and removes the redeclaration chain from...
void attachCommentsToJustParsedDecls(ArrayRef< Decl * > Decls, const Preprocessor *PP)
Searches existing comments for doc comments that should be attached to Decls.
QualType getIntTypeForBitwidth(unsigned DestWidth, unsigned Signed) const
getIntTypeForBitwidth - sets integer QualTy according to specified details: bitwidth,...
llvm::BumpPtrAllocator & getAllocator() const
Definition ASTContext.h:854
void setStaticLocalNumber(const VarDecl *VD, unsigned Number)
friend class ASTDeclReader
Definition ASTContext.h:563
QualType getCFConstantStringType() const
Return the C structure type used to represent constant CFStrings.
void eraseDeclAttrs(const Decl *D)
Erase the attributes corresponding to the given declaration.
const NoSanitizeList & getNoSanitizeList() const
Definition ASTContext.h:948
struct clang::ASTContext::CUDAConstantEvalContext CUDAConstantEvalCtx
IdentifierInfo * getNSObjectName() const
Retrieve the identifier 'NSObject'.
UsingEnumDecl * getInstantiatedFromUsingEnumDecl(UsingEnumDecl *Inst)
If the given using-enum decl Inst is an instantiation of another using-enum decl, return it.
RecordDecl * getCFConstantStringTagDecl() const
QualType getObjCSelType() const
Retrieve the type that corresponds to the predefined Objective-C 'SEL' type.
std::string getObjCEncodingForFunctionDecl(const FunctionDecl *Decl) const
Emit the encoded type for the function Decl into S.
TypeSourceInfo * getTemplateSpecializationTypeInfo(ElaboratedTypeKeyword Keyword, SourceLocation ElaboratedKeywordLoc, NestedNameSpecifierLoc QualifierLoc, SourceLocation TemplateKeywordLoc, TemplateName T, SourceLocation TLoc, const TemplateArgumentListInfo &SpecifiedArgs, ArrayRef< TemplateArgument > CanonicalArgs, QualType Canon=QualType()) const
QualType getTemplateTypeParmType(unsigned Depth, unsigned Index, bool ParameterPack, TemplateTypeParmDecl *ParmDecl=nullptr) const
Retrieve the template type parameter type for a template parameter or parameter pack with the given d...
bool addressSpaceMapManglingFor(LangAS AS) const
CanQualType UnsignedFractTy
QualType getjmp_bufType() const
Retrieve the C jmp_buf type.
GVALinkage GetGVALinkageForFunction(const FunctionDecl *FD) const
QualType mergeFunctionParameterTypes(QualType, QualType, bool OfBlockPointer=false, bool Unqualified=false)
mergeFunctionParameterTypes - merge two types which appear as function parameter types
QualType getsigjmp_bufType() const
Retrieve the C sigjmp_buf type.
void addOverriddenMethod(const CXXMethodDecl *Method, const CXXMethodDecl *Overridden)
Note that the given C++ Method overrides the given Overridden method.
TemplateTemplateParmDecl * findCanonicalTemplateTemplateParmDeclInternal(TemplateTemplateParmDecl *TTP) const
const TargetInfo * getAuxTargetInfo() const
Definition ASTContext.h:904
CanQualType Float128Ty
CanQualType ObjCBuiltinClassTy
unsigned NumImplicitDefaultConstructorsDeclared
The number of implicitly-declared default constructors for which declarations were built.
CanQualType UnresolvedTemplateTy
void setucontext_tDecl(TypeDecl *ucontext_tDecl)
Set the type for the C ucontext_t type.
OMPTraitInfo & getNewOMPTraitInfo()
Return a new OMPTraitInfo object owned by this context.
friend class CXXRecordDecl
Definition ASTContext.h:567
CanQualType UnsignedLongTy
llvm::DenseSet< const FunctionDecl * > CUDAImplicitHostDeviceFunUsedByDevice
Keep track of CUDA/HIP implicit host device functions used on device side in device compilation.
void DeepCollectObjCIvars(const ObjCInterfaceDecl *OI, bool leafClass, SmallVectorImpl< const ObjCIvarDecl * > &Ivars) const
DeepCollectObjCIvars - This routine first collects all declared, but not synthesized,...
bool computeBestEnumTypes(bool IsPacked, unsigned NumNegativeBits, unsigned NumPositiveBits, QualType &BestType, QualType &BestPromotionType)
Compute BestType and BestPromotionType for an enum based on the highest number of negative and positi...
llvm::APFixedPoint getFixedPointMin(QualType Ty) const
TypeSourceInfo * getTrivialTypeSourceInfo(QualType T, SourceLocation Loc=SourceLocation()) const
Allocate a TypeSourceInfo where all locations have been initialized to a given location,...
QualType adjustType(QualType OldType, llvm::function_ref< QualType(QualType)> Adjust) const
Rebuild a type, preserving any existing type sugar.
void addedLocalImportDecl(ImportDecl *Import)
Notify the AST context that a new import declaration has been parsed or implicitly created within thi...
bool hasAnyFunctionEffects() const
const TranslationUnitKind TUKind
Definition ASTContext.h:787
QualType getQualifiedType(const Type *T, Qualifiers Qs) const
Return a type with additional qualifiers.
CanQualType UnsignedLongAccumTy
QualType AutoRRefDeductTy
QualType getRestrictType(QualType T) const
Return the uniqued reference to the type for a restrict qualified type.
TypeInfo getTypeInfo(const Type *T) const
Get the size and alignment of the specified complete type in bits.
CanQualType ShortFractTy
QualType getStringLiteralArrayType(QualType EltTy, unsigned Length) const
Return a type for a constant array for a string literal of the specified element type and length.
QualType getCorrespondingSaturatedType(QualType Ty) const
bool isSameEntity(const NamedDecl *X, const NamedDecl *Y) const
Determine whether the two declarations refer to the same entity.
QualType getBOOLType() const
type of 'BOOL' type.
QualType getSubstTemplateTypeParmPackType(Decl *AssociatedDecl, unsigned Index, bool Final, const TemplateArgument &ArgPack)
llvm::DenseMap< const CXXMethodDecl *, CXXCastPath > LambdaCastPaths
For capturing lambdas with an explicit object parameter whose type is derived from the lambda type,...
CanQualType BoundMemberTy
CanQualType SatUnsignedShortFractTy
CanQualType CharTy
QualType removeAddrSpaceQualType(QualType T) const
Remove any existing address space on the type and returns the type with qualifiers intact (or that's ...
bool hasSameFunctionTypeIgnoringParamABI(QualType T, QualType U) const
Determine if two function types are the same, ignoring parameter ABI annotations.
TypedefDecl * getInt128Decl() const
Retrieve the declaration for the 128-bit signed integer type.
unsigned getOpenMPDefaultSimdAlign(QualType T) const
Get default simd alignment of the specified complete type in bits.
QualType getObjCSuperType() const
Returns the C struct type for objc_super.
QualType getBlockDescriptorType() const
Gets the struct used to keep track of the descriptor for pointer to blocks.
bool CommentsLoaded
True if comments are already loaded from ExternalASTSource.
Definition ASTContext.h:974
BlockVarCopyInit getBlockVarCopyInit(const VarDecl *VD) const
Get the copy initialization expression of the VarDecl VD, or nullptr if none exists.
QualType getHLSLInlineSpirvType(uint32_t Opcode, uint32_t Size, uint32_t Alignment, ArrayRef< SpirvOperand > Operands)
unsigned NumImplicitMoveConstructorsDeclared
The number of implicitly-declared move constructors for which declarations were built.
bool isInSameModule(const Module *M1, const Module *M2) const
If the two module M1 and M2 are in the same module.
unsigned NumImplicitCopyConstructorsDeclared
The number of implicitly-declared copy constructors for which declarations were built.
CanQualType IntTy
llvm::DenseSet< const VarDecl * > CUDADeviceVarODRUsedByHost
Keep track of CUDA/HIP device-side variables ODR-used by host code.
CanQualType PseudoObjectTy
QualType getWebAssemblyExternrefType() const
Return a WebAssembly externref type.
void setTraversalScope(const std::vector< Decl * > &)
CharUnits getTypeUnadjustedAlignInChars(QualType T) const
getTypeUnadjustedAlignInChars - Return the ABI-specified alignment of a type, in characters,...
QualType getAdjustedType(QualType Orig, QualType New) const
Return the uniqued reference to a type adjusted from the original type to a new type.
CanQualType getComplexType(CanQualType T) const
friend class NestedNameSpecifier
Definition ASTContext.h:221
void PrintStats() const
unsigned getAlignOfGlobalVar(QualType T, const VarDecl *VD) const
Return the alignment in bits that should be given to a global variable with type T.
TypeInfoChars getTypeInfoDataSizeInChars(QualType T) const
MangleNumberingContext & getManglingNumberContext(const DeclContext *DC)
Retrieve the context for computing mangling numbers in the given DeclContext.
comments::FullComment * getLocalCommentForDeclUncached(const Decl *D) const
Return parsed documentation comment attached to a given declaration.
unsigned NumImplicitDestructors
The number of implicitly-declared destructors.
CanQualType Float16Ty
QualType getQualifiedType(SplitQualType split) const
Un-split a SplitQualType.
bool isAlignmentRequired(const Type *T) const
Determine if the alignment the type has was required using an alignment attribute.
TagDecl * MSGuidTagDecl
bool areComparableObjCPointerTypes(QualType LHS, QualType RHS)
MangleContext * createDeviceMangleContext(const TargetInfo &T)
Creates a device mangle context to correctly mangle lambdas in a mixed architecture compile by settin...
CharUnits getExnObjectAlignment() const
Return the alignment (in bytes) of the thrown exception object.
CanQualType SignedCharTy
QualType getObjCObjectPointerType(QualType OIT) const
Return a ObjCObjectPointerType type for the given ObjCObjectType.
ASTMutationListener * Listener
Definition ASTContext.h:790
void setNonKeyFunction(const CXXMethodDecl *method)
Observe that the given method cannot be a key function.
CanQualType ObjCBuiltinBoolTy
TypeInfoChars getTypeInfoInChars(const Type *T) const
QualType getPredefinedSugarType(PredefinedSugarType::Kind KD) const
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.
TemplateParamObjectDecl * getTemplateParamObjectDecl(QualType T, const APValue &V) const
Return the template parameter object of the given type with the given value.
const SourceManager & getSourceManager() const
Definition ASTContext.h:846
CanQualType OverloadTy
CharUnits getDeclAlign(const Decl *D, bool ForAlignof=false) const
Return a conservative estimate of the alignment of the specified decl D.
int64_t toBits(CharUnits CharSize) const
Convert a size in characters to a size in bits.
TemplateTemplateParmDecl * getCanonicalTemplateTemplateParmDecl(TemplateTemplateParmDecl *TTP) const
Canonicalize the given TemplateTemplateParmDecl.
CanQualType OCLClkEventTy
void adjustExceptionSpec(FunctionDecl *FD, const FunctionProtoType::ExceptionSpecInfo &ESI, bool AsWritten=false)
Change the exception specification on a function once it is delay-parsed, instantiated,...
TypedefDecl * getUInt128Decl() const
Retrieve the declaration for the 128-bit unsigned integer type.
CharUnits getPreferredTypeAlignInChars(QualType T) const
Return the PreferredAlignment of a (complete) type T, in characters.
const clang::PrintingPolicy & getPrintingPolicy() const
Definition ASTContext.h:837
void ResetObjCLayout(const ObjCInterfaceDecl *D)
ArrayRef< Module * > getModulesWithMergedDefinition(const NamedDecl *Def)
Get the additional modules in which the definition Def has been merged.
static ImportDecl * getNextLocalImport(ImportDecl *Import)
llvm::FixedPointSemantics getFixedPointSemantics(QualType Ty) const
CanQualType SatUnsignedShortAccumTy
QualType mergeTypes(QualType, QualType, bool OfBlockPointer=false, bool Unqualified=false, bool BlockReturnType=false, bool IsConditionalOperator=false)
const RawComment * getRawCommentForAnyRedecl(const Decl *D, const Decl **OriginalDecl=nullptr) const
Return the documentation comment attached to a given declaration.
CharUnits getAlignOfGlobalVarInChars(QualType T, const VarDecl *VD) const
Return the alignment in characters that should be given to a global variable with type T.
const ObjCMethodDecl * getObjCMethodRedeclaration(const ObjCMethodDecl *MD) const
Get the duplicate declaration of a ObjCMethod in the same interface, or null if none exists.
QualType getPackIndexingType(QualType Pattern, Expr *IndexExpr, bool FullySubstituted=false, ArrayRef< QualType > Expansions={}, UnsignedOrNone Index=std::nullopt) const
static bool isObjCNSObjectType(QualType Ty)
Return true if this is an NSObject object with its NSObject attribute set.
GVALinkage GetGVALinkageForVariable(const VarDecl *VD) const
llvm::PointerUnion< VarTemplateDecl *, MemberSpecializationInfo * > TemplateOrSpecializationInfo
A type synonym for the TemplateOrInstantiation mapping.
Definition ASTContext.h:559
UsingShadowDecl * getInstantiatedFromUsingShadowDecl(UsingShadowDecl *Inst)
QualType getWCharType() const
Return the unique wchar_t type available in C++ (and available as __wchar_t as a Microsoft extension)...
QualType getVariableArrayType(QualType EltTy, Expr *NumElts, ArraySizeModifier ASM, unsigned IndexTypeQuals) const
Return a non-unique reference to the type for a variable array of the specified element type.
QualType getObjCIdType() const
Represents the Objective-CC id type.
Decl * getVaListTagDecl() const
Retrieve the C type declaration corresponding to the predefined __va_list_tag type used to help defin...
QualType getUnsignedWCharType() const
Return the type of "unsigned wchar_t".
QualType getFunctionTypeWithoutParamABIs(QualType T) const
Get or construct a function type that is equivalent to the input type except that the parameter ABI a...
QualType getCorrespondingUnsaturatedType(QualType Ty) const
comments::FullComment * getCommentForDecl(const Decl *D, const Preprocessor *PP) const
Return parsed documentation comment attached to a given declaration.
TemplateArgument getInjectedTemplateArg(NamedDecl *ParamDecl) const
unsigned getTargetDefaultAlignForAttributeAligned() const
Return the default alignment for attribute((aligned)) on this target, to be used if no alignment valu...
const ArrayType * getAsArrayType(QualType T) const
Type Query functions.
llvm::DenseMap< CanQualType, SYCLKernelInfo > SYCLKernels
Map of SYCL kernels indexed by the unique type used to name the kernel.
bool isSameTemplateParameterList(const TemplateParameterList *X, const TemplateParameterList *Y) const
Determine whether two template parameter lists are similar enough that they may be used in declaratio...
QualType getWritePipeType(QualType T) const
Return a write_only pipe type for the specified type.
QualType getTypeDeclType(ElaboratedTypeKeyword Keyword, NestedNameSpecifier Qualifier, const TypeDecl *Decl) const
bool isDestroyingOperatorDelete(const FunctionDecl *FD) const
uint64_t getTypeSize(QualType T) const
Return the size of the specified (complete) type T, in bits.
CanQualType UnsignedInt128Ty
CanQualType BuiltinFnTy
ObjCInterfaceDecl * getObjCProtocolDecl() const
Retrieve the Objective-C class declaration corresponding to the predefined Protocol class.
unsigned NumImplicitDefaultConstructors
The number of implicitly-declared default constructors.
CharUnits getTypeSizeInChars(QualType T) const
Return the size of the specified (complete) type T, in characters.
llvm::iterator_range< overridden_cxx_method_iterator > overridden_method_range
unsigned NumImplicitMoveAssignmentOperatorsDeclared
The number of implicitly-declared move assignment operators for which declarations were built.
void setManglingNumber(const NamedDecl *ND, unsigned Number)
llvm::DenseMap< const Decl *, const RawComment * > DeclRawComments
Mapping from declaration to directly attached comment.
Definition ASTContext.h:980
CanQualType OCLSamplerTy
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.
TypeInfo getTypeInfo(QualType T) const
CanQualType getCanonicalTypeDeclType(const TypeDecl *TD) const
CanQualType VoidTy
QualType getPackExpansionType(QualType Pattern, UnsignedOrNone NumExpansions, bool ExpectPackInType=true) const
Form a pack expansion type with the given pattern.
CanQualType UnsignedCharTy
CanQualType UnsignedShortFractTy
BuiltinTemplateDecl * buildBuiltinTemplateDecl(BuiltinTemplateKind BTK, const IdentifierInfo *II) const
void * Allocate(size_t Size, unsigned Align=8) const
Definition ASTContext.h:858
bool canBuiltinBeRedeclared(const FunctionDecl *) const
Return whether a declaration to a builtin is allowed to be overloaded/redeclared.
CanQualType UnsignedIntTy
unsigned NumImplicitMoveConstructors
The number of implicitly-declared move constructors.
QualType getTypedefType(ElaboratedTypeKeyword Keyword, NestedNameSpecifier Qualifier, const TypedefNameDecl *Decl, QualType UnderlyingType=QualType(), std::optional< bool > TypeMatchesDeclOrNone=std::nullopt) const
Return the unique reference to the type for the specified typedef-name decl.
QualType getObjCTypeParamType(const ObjCTypeParamDecl *Decl, ArrayRef< ObjCProtocolDecl * > protocols) const
QualType getVolatileType(QualType T) const
Return the uniqued reference to the type for a volatile qualified type.
void getObjCEncodingForMethodParameter(Decl::ObjCDeclQualifier QT, QualType T, std::string &S, bool Extended) const
getObjCEncodingForMethodParameter - Return the encoded type for a single method parameter or return t...
void addDeclaratorForUnnamedTagDecl(TagDecl *TD, DeclaratorDecl *DD)
unsigned overridden_methods_size(const CXXMethodDecl *Method) const
std::string getObjCEncodingForBlock(const BlockExpr *blockExpr) const
Return the encoded type for this block declaration.
QualType getTemplateSpecializationType(ElaboratedTypeKeyword Keyword, TemplateName T, ArrayRef< TemplateArgument > SpecifiedArgs, ArrayRef< TemplateArgument > CanonicalArgs, QualType Underlying=QualType()) const
TypeSourceInfo * CreateTypeSourceInfo(QualType T, unsigned Size=0) const
Allocate an uninitialized TypeSourceInfo.
TagDecl * getMSTypeInfoTagDecl() const
Retrieve the implicitly-predeclared 'struct type_info' declaration.
TemplateName getQualifiedTemplateName(NestedNameSpecifier Qualifier, bool TemplateKeyword, TemplateName Template) const
Retrieve the template name that represents a qualified template name such as std::vector.
QualType getObjCClassRedefinitionType() const
Retrieve the type that Class has been defined to, which may be different from the built-in Class if C...
TagDecl * getMSGuidTagDecl() const
Retrieve the implicitly-predeclared 'struct _GUID' declaration.
bool isSameAssociatedConstraint(const AssociatedConstraint &ACX, const AssociatedConstraint &ACY) const
Determine whether two 'requires' expressions are similar enough that they may be used in re-declarati...
QualType getExceptionObjectType(QualType T) const
CanQualType UnknownAnyTy
void setInstantiatedFromStaticDataMember(VarDecl *Inst, VarDecl *Tmpl, TemplateSpecializationKind TSK, SourceLocation PointOfInstantiation=SourceLocation())
Note that the static data member Inst is an instantiation of the static data member template Tmpl of ...
FieldDecl * getInstantiatedFromUnnamedFieldDecl(FieldDecl *Field) const
DeclaratorDecl * getDeclaratorForUnnamedTagDecl(const TagDecl *TD)
bool ObjCObjectAdoptsQTypeProtocols(QualType QT, ObjCInterfaceDecl *Decl)
ObjCObjectAdoptsQTypeProtocols - Checks that protocols in IC's protocol list adopt all protocols in Q...
QualType getFunctionNoProtoType(QualType ResultTy) const
CanQualType UnsignedLongLongTy
QualType GetBuiltinType(unsigned ID, GetBuiltinTypeError &Error, unsigned *IntegerConstantArgs=nullptr) const
Return the type for the specified builtin.
CanQualType OCLReserveIDTy
bool isSameTemplateParameter(const NamedDecl *X, const NamedDecl *Y) const
Determine whether two template parameters are similar enough that they may be used in declarations of...
void registerSYCLEntryPointFunction(FunctionDecl *FD)
Generates and stores SYCL kernel metadata for the provided SYCL kernel entry point function.
QualType getTypeDeclType(const TagDecl *) const =delete
Use the normal 'getFooBarType' constructors to obtain these types.
size_t getASTAllocatedMemory() const
Return the total amount of physical memory allocated for representing AST nodes and type information.
Definition ASTContext.h:892
QualType getArrayDecayedType(QualType T) const
Return the properly qualified result of decaying the specified array type to a pointer.
overridden_cxx_method_iterator overridden_methods_begin(const CXXMethodDecl *Method) const
CanQualType UnsignedShortTy
FunctionDecl * getOperatorDeleteForVDtor(const CXXDestructorDecl *Dtor, OperatorDeleteKind K) const
unsigned getTypeAlignIfKnown(QualType T, bool NeedsPreferredAlignment=false) const
Return the alignment of a type, in bits, or 0 if the type is incomplete and we cannot determine the a...
void UnwrapSimilarArrayTypes(QualType &T1, QualType &T2, bool AllowPiMismatch=true) const
Attempt to unwrap two types that may both be array types with the same bound (or both be array types ...
QualType getObjCConstantStringInterface() const
bool isRepresentableIntegerValue(llvm::APSInt &Value, QualType T)
Determine whether the given integral value is representable within the given type T.
bool AtomicUsesUnsupportedLibcall(const AtomicExpr *E) const
QualType getFunctionType(QualType ResultTy, ArrayRef< QualType > Args, const FunctionProtoType::ExtProtoInfo &EPI) const
Return a normal function type with a typed argument list.
const SYCLKernelInfo & getSYCLKernelInfo(QualType T) const
Given a type used as a SYCL kernel name, returns a reference to the metadata generated from the corre...
bool canAssignObjCInterfacesInBlockPointer(const ObjCObjectPointerType *LHSOPT, const ObjCObjectPointerType *RHSOPT, bool BlockReturnType)
canAssignObjCInterfacesInBlockPointer - This routine is specifically written for providing type-safet...
CanQualType SatUnsignedLongFractTy
QualType getMemberPointerType(QualType T, NestedNameSpecifier Qualifier, const CXXRecordDecl *Cls) const
Return the uniqued reference to the type for a member pointer to the specified type in the specified ...
void setcudaConfigureCallDecl(FunctionDecl *FD)
CanQualType getDecayedType(CanQualType T) const
static bool hasSameType(QualType T1, QualType T2)
Determine whether the given types T1 and T2 are equivalent.
QualType getObjCIdRedefinitionType() const
Retrieve the type that id has been defined to, which may be different from the built-in id if id has ...
const CXXConstructorDecl * getCopyConstructorForExceptionObject(CXXRecordDecl *RD)
QualType getDependentAddressSpaceType(QualType PointeeType, Expr *AddrSpaceExpr, SourceLocation AttrLoc) const
RawComment * getRawCommentForDeclNoCache(const Decl *D) const
Return the documentation comment attached to a given declaration, without looking into cache.
QualType getTagType(ElaboratedTypeKeyword Keyword, NestedNameSpecifier Qualifier, const TagDecl *TD, bool OwnsTag) const
QualType getPromotedIntegerType(QualType PromotableType) const
Return the type that PromotableType will promote to: C99 6.3.1.1p2, assuming that PromotableType is a...
llvm::APSInt MakeIntValue(uint64_t Value, QualType Type) const
Make an APSInt of the appropriate width and signedness for the given Value and integer Type.
CanQualType getMSGuidType() const
Retrieve the implicitly-predeclared 'struct _GUID' type.
const VariableArrayType * getAsVariableArrayType(QualType T) const
QualType getUnaryTransformType(QualType BaseType, QualType UnderlyingType, UnaryTransformType::UTTKind UKind) const
Unary type transforms.
void setExternalSource(IntrusiveRefCntPtr< ExternalASTSource > Source)
Attach an external AST source to the AST context.
const ObjCInterfaceDecl * getObjContainingInterface(const NamedDecl *ND) const
Returns the Objective-C interface that ND belongs to if it is an Objective-C method/property/ivar etc...
CanQualType ShortTy
StringLiteral * getPredefinedStringLiteralFromCache(StringRef Key) const
Return a string representing the human readable name for the specified function declaration or file n...
CanQualType getCanonicalUnresolvedUsingType(const UnresolvedUsingTypenameDecl *D) const
bool hasSimilarType(QualType T1, QualType T2) const
Determine if two types are similar, according to the C++ rules.
llvm::APFixedPoint getFixedPointMax(QualType Ty) const
QualType getComplexType(QualType T) const
Return the uniqued reference to the type for a complex number with the specified element type.
void setObjCClassRedefinitionType(QualType RedefType)
Set the user-written type that redefines 'SEL'.
bool hasDirectOwnershipQualifier(QualType Ty) const
Return true if the type has been explicitly qualified with ObjC ownership.
CanQualType FractTy
Qualifiers::ObjCLifetime getInnerObjCOwnership(QualType T) const
Recurses in pointer/array types until it finds an Objective-C retainable type and returns its ownersh...
void addCopyConstructorForExceptionObject(CXXRecordDecl *RD, CXXConstructorDecl *CD)
void deduplicateMergedDefinitionsFor(NamedDecl *ND)
Clean up the merged definition list.
FunctionDecl * getcudaConfigureCallDecl()
DiagnosticsEngine & getDiagnostics() const
llvm::StringRef backupStr(llvm::StringRef S) const
Definition ASTContext.h:866
QualType getAdjustedParameterType(QualType T) const
Perform adjustment on the parameter type of a function.
QualType getUnqualifiedObjCPointerType(QualType type) const
getUnqualifiedObjCPointerType - Returns version of Objective-C pointer type with lifetime qualifier r...
CanQualType LongAccumTy
interp::Context & getInterpContext()
Returns the clang bytecode interpreter context.
CanQualType Char32Ty
QualType getSizeType() const
Return the unique type for "size_t" (C99 7.17), defined in <stddef.h>.
QualType getCVRQualifiedType(QualType T, unsigned CVR) const
Return a type with additional const, volatile, or restrict qualifiers.
UnnamedGlobalConstantDecl * getUnnamedGlobalConstantDecl(QualType Ty, const APValue &Value) const
Return a declaration for a uniquified anonymous global constant corresponding to a given APValue.
CanQualType SatFractTy
QualType getExtVectorType(QualType VectorType, unsigned NumElts) const
Return the unique reference to an extended vector type of the specified element type and size.
QualType getUnresolvedUsingType(ElaboratedTypeKeyword Keyword, NestedNameSpecifier Qualifier, const UnresolvedUsingTypenameDecl *D) const
bool areCompatibleVectorTypes(QualType FirstVec, QualType SecondVec)
Return true if the given vector types are of the same unqualified type or if they are equivalent to t...
void getOverriddenMethods(const NamedDecl *Method, SmallVectorImpl< const NamedDecl * > &Overridden) const
Return C++ or ObjC overridden methods for the given Method.
DeclarationNameInfo getNameForTemplate(TemplateName Name, SourceLocation NameLoc) const
bool hasSameTemplateName(const TemplateName &X, const TemplateName &Y, bool IgnoreDeduced=false) const
Determine whether the given template names refer to the same template.
CanQualType SatLongFractTy
const TargetInfo & getTargetInfo() const
Definition ASTContext.h:903
void setInstantiatedFromUnnamedFieldDecl(FieldDecl *Inst, FieldDecl *Tmpl)
CanQualType OCLQueueTy
CanQualType LongFractTy
CanQualType SatShortAccumTy
QualType getAutoDeductType() const
C++11 deduction pattern for 'auto' type.
CanQualType BFloat16Ty
unsigned NumImplicitCopyConstructors
The number of implicitly-declared copy constructors.
CharUnits toCharUnitsFromBits(int64_t BitSize) const
Convert a size in bits to a size in characters.
CanQualType IncompleteMatrixIdxTy
std::optional< CharUnits > getTypeSizeInCharsIfKnown(QualType Ty) const
friend class DeclarationNameTable
void getFunctionFeatureMap(llvm::StringMap< bool > &FeatureMap, const FunctionDecl *) const
CanQualType getNSIntegerType() const
QualType getCorrespondingUnsignedType(QualType T) const
void setBlockVarCopyInit(const VarDecl *VD, Expr *CopyExpr, bool CanThrow)
Set the copy initialization expression of a block var decl.
QualType getLifetimeQualifiedType(QualType type, Qualifiers::ObjCLifetime lifetime)
Return a type with the given lifetime qualifier.
TemplateName getOverloadedTemplateName(UnresolvedSetIterator Begin, UnresolvedSetIterator End) const
Retrieve the template name that corresponds to a non-empty lookup.
bool typesAreCompatible(QualType T1, QualType T2, bool CompareUnqualified=false)
Compatibility predicates used to check assignment expressions.
TemplateName getSubstTemplateTemplateParmPack(const TemplateArgument &ArgPack, Decl *AssociatedDecl, unsigned Index, bool Final) const
QualType getObjCNSStringType() const
QualType getDeducedTemplateSpecializationType(ElaboratedTypeKeyword Keyword, TemplateName Template, QualType DeducedType, bool IsDependent) const
C++17 deduced class template specialization type.
TargetCXXABI::Kind getCXXABIKind() const
Return the C++ ABI kind that should be used.
void setjmp_bufDecl(TypeDecl *jmp_bufDecl)
Set the type for the C jmp_buf type.
QualType getHLSLAttributedResourceType(QualType Wrapped, QualType Contained, const HLSLAttributedResourceType::Attributes &Attrs)
void addDestruction(T *Ptr) const
If T isn't trivially destructible, calls AddDeallocation to register it for destruction.
bool UnwrapSimilarTypes(QualType &T1, QualType &T2, bool AllowPiMismatch=true) const
Attempt to unwrap two types that may be similar (C++ [conv.qual]).
IntrusiveRefCntPtr< ExternalASTSource > getExternalSourcePtr() const
Retrieve a pointer to the external AST source associated with this AST context, if any.
QualType getAddrSpaceQualType(QualType T, LangAS AddressSpace) const
Return the uniqued reference to the type for an address space qualified type with the specified type ...
QualType getSignedSizeType() const
Return the unique signed counterpart of the integer type corresponding to size_t.
ExternalASTSource * getExternalSource() const
Retrieve a pointer to the external AST source associated with this AST context, if any.
uint64_t getConstantArrayElementCount(const ConstantArrayType *CA) const
Return number of constant array elements.
CanQualType SatUnsignedLongAccumTy
QualType getUnconstrainedType(QualType T) const
Remove any type constraints from a template parameter type, for equivalence comparison of template pa...
CanQualType LongLongTy
CanQualType getCanonicalTagType(const TagDecl *TD) const
bool isSameTemplateArgument(const TemplateArgument &Arg1, const TemplateArgument &Arg2) const
Determine whether the given template arguments Arg1 and Arg2 are equivalent.
QualType getTypeOfType(QualType QT, TypeOfKind Kind) const
getTypeOfType - Unlike many "get<Type>" functions, we don't unique TypeOfType nodes.
QualType getCorrespondingSignedType(QualType T) const
QualType mergeObjCGCQualifiers(QualType, QualType)
mergeObjCGCQualifiers - This routine merges ObjC's GC attribute of 'LHS' and 'RHS' attributes and ret...
QualType getQualifiedType(QualType T, Qualifiers Qs) const
Return a type with additional qualifiers.
llvm::DenseMap< const Decl *, const Decl * > CommentlessRedeclChains
Keeps track of redeclaration chains that don't have any comment attached.
Definition ASTContext.h:996
uint64_t getArrayInitLoopExprElementCount(const ArrayInitLoopExpr *AILE) const
Return number of elements initialized in an ArrayInitLoopExpr.
unsigned getTargetAddressSpace(LangAS AS) const
QualType getWideCharType() const
Return the type of wide characters.
QualType getIntPtrType() const
Return a type compatible with "intptr_t" (C99 7.18.1.4), as defined by the target.
void mergeDefinitionIntoModule(NamedDecl *ND, Module *M, bool NotifyListeners=true)
Note that the definition ND has been merged into module M, and should be visible whenever M is visibl...
QualType getDependentSizedArrayType(QualType EltTy, Expr *NumElts, ArraySizeModifier ASM, unsigned IndexTypeQuals) const
Return a non-unique reference to the type for a dependently-sized array of the specified element type...
void addTranslationUnitDecl()
CanQualType WCharTy
bool hasSameNullabilityTypeQualifier(QualType SubT, QualType SuperT, bool IsParam) const
void getObjCEncodingForPropertyType(QualType T, std::string &S) const
Emit the Objective-C property type encoding for the given type T into S.
unsigned NumImplicitCopyAssignmentOperators
The number of implicitly-declared copy assignment operators.
void CollectInheritedProtocols(const Decl *CDecl, llvm::SmallPtrSet< ObjCProtocolDecl *, 8 > &Protocols)
CollectInheritedProtocols - Collect all protocols in current class and those inherited by it.
bool isPromotableIntegerType(QualType T) const
More type predicates useful for type checking/promotion.
T * Allocate(size_t Num=1) const
Definition ASTContext.h:861
llvm::DenseMap< const Decl *, const Decl * > RedeclChainComments
Mapping from canonical declaration to the first redeclaration in chain that has a comment attached.
Definition ASTContext.h:987
void adjustDeducedFunctionResultType(FunctionDecl *FD, QualType ResultType)
Change the result type of a function type once it is deduced.
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.
QualType getDecltypeType(Expr *e, QualType UnderlyingType) const
C++11 decltype.
std::optional< CXXRecordDeclRelocationInfo > getRelocationInfoForCXXRecord(const CXXRecordDecl *) const
static bool hasSameUnqualifiedType(QualType T1, QualType T2)
Determine whether the given types are equivalent after cvr-qualifiers have been removed.
InlineVariableDefinitionKind getInlineVariableDefinitionKind(const VarDecl *VD) const
Determine whether a definition of this inline variable should be treated as a weak or strong definiti...
void setPrimaryMergedDecl(Decl *D, Decl *Primary)
TemplateName getSubstTemplateTemplateParm(TemplateName replacement, Decl *AssociatedDecl, unsigned Index, UnsignedOrNone PackIndex, bool Final) const
CanQualType getUIntMaxType() const
Return the unique type for "uintmax_t" (C99 7.18.1.5), defined in <stdint.h>.
IdentifierInfo * getBoolName() const
Retrieve the identifier 'bool'.
friend class DeclContext
uint16_t getPointerAuthVTablePointerDiscriminator(const CXXRecordDecl *RD)
Return the "other" discriminator used for the pointer auth schema used for vtable pointers in instanc...
CharUnits getOffsetOfBaseWithVBPtr(const CXXRecordDecl *RD) const
Loading virtual member pointers using the virtual inheritance model always results in an adjustment u...
LangAS getLangASForBuiltinAddressSpace(unsigned AS) const
bool hasSameFunctionTypeIgnoringPtrSizes(QualType T, QualType U)
Determine whether two function types are the same, ignoring pointer sizes in the return type and para...
void addOperatorDeleteForVDtor(const CXXDestructorDecl *Dtor, FunctionDecl *OperatorDelete, OperatorDeleteKind K) const
unsigned char getFixedPointScale(QualType Ty) const
QualType getIncompleteArrayType(QualType EltTy, ArraySizeModifier ASM, unsigned IndexTypeQuals) const
Return a unique reference to the type for an incomplete array of the specified element type.
QualType getDependentSizedExtVectorType(QualType VectorType, Expr *SizeExpr, SourceLocation AttrLoc) const
QualType DecodeTypeStr(const char *&Str, const ASTContext &Context, ASTContext::GetBuiltinTypeError &Error, bool &RequireICE, bool AllowTypeModifiers) const
void addObjCSubClass(const ObjCInterfaceDecl *D, const ObjCInterfaceDecl *SubClass)
TemplateName getAssumedTemplateName(DeclarationName Name) const
Retrieve a template name representing an unqualified-id that has been assumed to name a template for ...
@ GE_None
No error.
@ GE_Missing_stdio
Missing a type from <stdio.h>
@ GE_Missing_type
Missing a type.
@ GE_Missing_ucontext
Missing a type from <ucontext.h>
@ GE_Missing_setjmp
Missing a type from <setjmp.h>
QualType adjustStringLiteralBaseType(QualType StrLTy) const
uint16_t getPointerAuthTypeDiscriminator(QualType T)
Return the "other" type-specific discriminator for the given type.
bool canonicalizeTemplateArguments(MutableArrayRef< TemplateArgument > Args) const
Canonicalize the given template argument list.
QualType getTypeOfExprType(Expr *E, TypeOfKind Kind) const
C23 feature and GCC extension.
CanQualType Char8Ty
QualType getSignedWCharType() const
Return the type of "signed wchar_t".
QualType getUnqualifiedArrayType(QualType T, Qualifiers &Quals) const
Return this type as a completely-unqualified array type, capturing the qualifiers in Quals.
QualType getTypeDeclType(const TypedefDecl *) const =delete
bool hasCvrSimilarType(QualType T1, QualType T2)
Determine if two types are similar, ignoring only CVR qualifiers.
TemplateName getDeducedTemplateName(TemplateName Underlying, DefaultArguments DefaultArgs) const
Represents a TemplateName which had some of its default arguments deduced.
ObjCImplementationDecl * getObjCImplementation(ObjCInterfaceDecl *D)
Get the implementation of the ObjCInterfaceDecl D, or nullptr if none exists.
CanQualType HalfTy
CanQualType UnsignedAccumTy
void setObjCMethodRedeclaration(const ObjCMethodDecl *MD, const ObjCMethodDecl *Redecl)
void addTypedefNameForUnnamedTagDecl(TagDecl *TD, TypedefNameDecl *TND)
bool isDependenceAllowed() const
Definition ASTContext.h:944
QualType getConstantMatrixType(QualType ElementType, unsigned NumRows, unsigned NumColumns) const
Return the unique reference to the matrix type of the specified element type and size.
QualType getWIntType() const
In C99, this returns a type compatible with the type defined in <stddef.h> as defined by the target.
const CXXRecordDecl * baseForVTableAuthentication(const CXXRecordDecl *ThisClass) const
Resolve the root record to be used to derive the vtable pointer authentication policy for the specifi...
QualType getVariableArrayDecayedType(QualType Ty) const
Returns a vla type where known sizes are replaced with [*].
void setCFConstantStringType(QualType T)
const SYCLKernelInfo * findSYCLKernelInfo(QualType T) const
Returns a pointer to the metadata generated from the corresponding SYCLkernel entry point if the prov...
ASTContext & operator=(const ASTContext &)=delete
Module * getCurrentNamedModule() const
Get module under construction, nullptr if this is not a C++20 module.
unsigned getParameterIndex(const ParmVarDecl *D) const
Used by ParmVarDecl to retrieve on the side the index of the parameter when it exceeds the size of th...
QualType getCommonSugaredType(QualType X, QualType Y, bool Unqualified=false) const
CanQualType OCLEventTy
void setPrintingPolicy(const clang::PrintingPolicy &Policy)
Definition ASTContext.h:841
void AddDeallocation(void(*Callback)(void *), void *Data) const
Add a deallocation callback that will be invoked when the ASTContext is destroyed.
AttrVec & getDeclAttrs(const Decl *D)
Retrieve the attributes for the given declaration.
CXXMethodVector::const_iterator overridden_cxx_method_iterator
RawComment * getRawCommentForDeclNoCacheImpl(const Decl *D, const SourceLocation RepresentativeLocForDecl, const std::map< unsigned, RawComment * > &CommentsInFile) const
unsigned getTypeAlign(QualType T) const
Return the ABI-specified alignment of a (complete) type T, in bits.
QualType mergeTransparentUnionType(QualType, QualType, bool OfBlockPointer=false, bool Unqualified=false)
mergeTransparentUnionType - if T is a transparent union type and a member of T is compatible with Sub...
QualType isPromotableBitField(Expr *E) const
Whether this is a promotable bitfield reference according to C99 6.3.1.1p2, bullet 2 (and GCC extensi...
bool isSentinelNullExpr(const Expr *E)
CanQualType getNSUIntegerType() const
IdentifierInfo * getNSCopyingName()
Retrieve the identifier 'NSCopying'.
void setIsDestroyingOperatorDelete(const FunctionDecl *FD, bool IsDestroying)
uint64_t getCharWidth() const
Return the size of the character type, in bits.
CanQualType getPointerType(CanQualType T) const
QualType getUnqualifiedArrayType(QualType T) const
import_range local_imports() const
QualType getBitIntType(bool Unsigned, unsigned NumBits) const
Return a bit-precise integer type with the specified signedness and bit count.
const DependentSizedArrayType * getAsDependentSizedArrayType(QualType T) const
unsigned NumImplicitMoveAssignmentOperators
The number of implicitly-declared move assignment operators.
An abstract interface that should be implemented by listeners that want to be notified when an AST en...
ASTRecordLayout - This class contains layout information for one RecordDecl, which is a struct/union/...
Represents a loop initializing the elements of an array.
Definition Expr.h:5902
Represents an array type, per C99 6.7.5.2 - Array Declarators.
Definition TypeBase.h:3722
AtomicExpr - Variadic atomic builtins: __atomic_exchange, __atomic_fetch_*, __atomic_load,...
Definition Expr.h:6814
Attr - This represents one attribute.
Definition Attr.h:45
BlockExpr - Adaptor class for mixing a BlockDecl with expressions.
Definition Expr.h:6558
Represents the builtin template declaration which is used to implement __make_integer_seq and other b...
This class is used for builtin types like 'int'.
Definition TypeBase.h:3164
Holds information about both target-independent and target-specific builtins, allowing easy queries b...
Definition Builtins.h:229
Implements C++ ABI-specific semantic analysis functions.
Definition CXXABI.h:29
Represents a C++ constructor within a class.
Definition DeclCXX.h:2604
Represents a C++ destructor within a class.
Definition DeclCXX.h:2869
Represents a static or instance method of a struct/union/class.
Definition DeclCXX.h:2129
Represents a C++ struct/union/class.
Definition DeclCXX.h:258
static CanQual< Type > CreateUnsafe(QualType Other)
const T * getTypePtr() const
Retrieve the underlying type pointer, which refers to a canonical type.
CharUnits - This is an opaque type for sizes expressed in character units.
Definition CharUnits.h:38
Declaration of a C++20 concept.
Represents the canonical version of C arrays with a specified constant size.
Definition TypeBase.h:3760
DeclContext - This is used only as base class of specific decl types that can act as declaration cont...
Definition DeclBase.h:1449
A list storing NamedDecls in the lookup tables.
Definition DeclBase.h:1329
Decl - This represents one declaration (or definition), e.g.
Definition DeclBase.h:86
ObjCDeclQualifier
ObjCDeclQualifier - 'Qualifiers' written next to the return and parameter types in method declaration...
Definition DeclBase.h:198
The name of a declaration.
Represents a ValueDecl that came out of a declarator.
Definition Decl.h:780
Represents an array type in C++ whose size is a value-dependent expression.
Definition TypeBase.h:4011
Represents a dependent template name that cannot be resolved prior to template instantiation.
Concrete class used by the front-end to report problems and issues.
Definition Diagnostic.h:232
Container for either a single DynTypedNode or for an ArrayRef to DynTypedNode.
An instance of this object exists for each enum constant that is defined.
Definition Decl.h:3423
llvm::APSInt getInitVal() const
Definition Decl.h:3443
This represents one expression.
Definition Expr.h:112
Declaration context for names declared as extern "C" in C++.
Definition Decl.h:247
Abstract interface for external sources of AST nodes.
Represents a member of a struct/union/class.
Definition Decl.h:3160
A SourceLocation and its associated SourceManager.
Represents a function declaration or definition.
Definition Decl.h:2000
Represents a prototype with parameter type info, e.g.
Definition TypeBase.h:5254
A class which abstracts out some details necessary for making a call.
Definition TypeBase.h:4561
FunctionType - C99 6.7.5.3 - Function Declarators.
Definition TypeBase.h:4450
GlobalDecl - represents a global declaration.
Definition GlobalDecl.h:57
One of these records is kept for each identifier that is lexed.
Implements an efficient mapping from strings to IdentifierInfo nodes.
IdentifierInfo & get(StringRef Name)
Return the identifier token info for the specified named identifier.
Describes a module import declaration, which makes the contents of the named module visible in the cu...
Definition Decl.h:5035
Represents a C array with an unspecified size.
Definition TypeBase.h:3909
Keeps track of the various options that can be enabled, which controls the dialect of C or C++ that i...
A global _GUID constant.
Definition DeclCXX.h:4394
MangleContext - Context for tracking state which persists across multiple calls to the C++ name mangl...
Definition Mangle.h:52
Keeps track of the mangled names of lambda expressions and block literals within a particular context...
Provides information a specialization of a member of a class template, which may be a member function...
Describes a module or submodule.
Definition Module.h:144
This represents a decl that may have a name.
Definition Decl.h:274
A C++ nested-name-specifier augmented with source location information.
Represents a C++ nested name specifier, such as "\::std::vector<int>::".
Helper data structure representing the traits in a match clause of an declare variant or metadirectiv...
ObjCCategoryDecl - Represents a category declaration.
Definition DeclObjC.h:2329
ObjCCategoryImplDecl - An object of this class encapsulates a category @implementation declaration.
Definition DeclObjC.h:2545
ObjCContainerDecl - Represents a container for method declarations.
Definition DeclObjC.h:948
ObjCImplementationDecl - Represents a class definition - this is where method definitions are specifi...
Definition DeclObjC.h:2597
Represents an ObjC class declaration.
Definition DeclObjC.h:1154
ObjCIvarDecl - Represents an ObjC instance variable.
Definition DeclObjC.h:1952
ObjCMethodDecl - Represents an instance or class method declaration.
Definition DeclObjC.h:140
Represents a pointer to an Objective C object.
Definition TypeBase.h:7896
Represents one property declaration in an Objective-C interface.
Definition DeclObjC.h:731
ObjCPropertyImplDecl - Represents implementation declaration of a property in a class or category imp...
Definition DeclObjC.h:2805
Represents an Objective-C protocol declaration.
Definition DeclObjC.h:2084
Represents the declaration of an Objective-C type parameter.
Definition DeclObjC.h:578
Represents a parameter to a function.
Definition Decl.h:1790
Pointer-authentication qualifiers.
Definition TypeBase.h:152
PredefinedSugarKind Kind
Definition TypeBase.h:8189
Engages in a tight little dance with the lexer to efficiently preprocess tokens.
A (possibly-)qualified type.
Definition TypeBase.h:937
PointerAuthQualifier getPointerAuth() const
Definition TypeBase.h:1453
A qualifier set is used to build a set of qualifiers.
Definition TypeBase.h:8218
const Type * strip(QualType type)
Collect any qualifiers on the given type and return an unqualified type.
Definition TypeBase.h:8225
The collection of all-type qualifiers we support.
Definition TypeBase.h:331
@ OCL_None
There is no lifetime qualification on this type.
Definition TypeBase.h:350
void removeObjCLifetime()
Definition TypeBase.h:551
bool hasNonFastQualifiers() const
Return true if the set contains any qualifiers which require an ExtQuals node to be allocated.
Definition TypeBase.h:638
unsigned getFastQualifiers() const
Definition TypeBase.h:619
static Qualifiers fromCVRMask(unsigned CVR)
Definition TypeBase.h:435
void setPointerAuth(PointerAuthQualifier Q)
Definition TypeBase.h:606
void addObjCLifetime(ObjCLifetime type)
Definition TypeBase.h:552
This class represents all comments included in the translation unit, sorted in order of appearance in...
Represents a struct/union/class.
Definition Decl.h:4312
void setPreviousDecl(decl_type *PrevDecl)
Set the previous declaration.
Definition Decl.h:5312
This table allows us to fully hide how we implement multi-keyword caching.
Selector getSelector(unsigned NumArgs, const IdentifierInfo **IIV)
Can create any sort of selector.
Smart pointer class that efficiently represents Objective-C method names.
Encodes a location in the source.
This class handles loading and caching of source files into memory.
The streaming interface shared between DiagnosticBuilder and PartialDiagnostic.
clang::DiagStorageAllocator DiagStorageAllocator
StringLiteral - This represents a string literal expression, e.g.
Definition Expr.h:1799
Represents the declaration of a struct/union/class/enum.
Definition Decl.h:3717
TagTypeKind TagKind
Definition Decl.h:3722
Kind
The basic C++ ABI kind.
Exposes information about the current target.
Definition TargetInfo.h:226
A convenient class for passing around template argument information.
Represents a template argument.
The base class of all kinds of template declarations (e.g., class, function, etc.).
Represents a C++ template name within the type system.
A template parameter object.
Stores a list of template parameters for a TemplateDecl and its derived classes.
TemplateTemplateParmDecl - Declares a template template parameter, e.g., "T" in.
Declaration of a template type parameter.
The top declaration context.
Definition Decl.h:105
static TranslationUnitDecl * Create(ASTContext &C)
Definition Decl.cpp:5409
Represents the declaration of a typedef-name via a C++11 alias-declaration.
Definition Decl.h:3688
Models the abbreviated syntax to constrain a template type parameter: template <convertible_to<string...
Definition ASTConcept.h:227
Represents a declaration of a type.
Definition Decl.h:3513
A container of type source information.
Definition TypeBase.h:8249
The base class of the type hierarchy.
Definition TypeBase.h:1833
bool isSignedIntegerOrEnumerationType() const
Determines whether this is an integer type that is signed or an enumeration types whose underlying ty...
Definition Type.cpp:2225
bool isObjCNSObjectType() const
Definition Type.cpp:5271
bool isDependentType() const
Whether this type is a dependent type, meaning that its definition somehow depends on a template para...
Definition TypeBase.h:2782
bool isIncompleteType(NamedDecl **Def=nullptr) const
Types are partitioned into 3 broad categories (C99 6.2.5p1): object types, function types,...
Definition Type.cpp:2435
std::optional< NullabilityKind > getNullability() const
Determine the nullability of the given type.
Definition Type.cpp:5014
Represents the declaration of a typedef-name via the 'typedef' type specifier.
Definition Decl.h:3667
Base class for declarations which introduce a typedef-name.
Definition Decl.h:3562
An artificial decl, representing a global anonymous constant value which is uniquified by value withi...
Definition DeclCXX.h:4451
The iterator over UnresolvedSets.
Represents the dependent type named by a dependently-scoped typename using declaration,...
Definition TypeBase.h:5970
Represents a dependent using declaration which was marked with typename.
Definition DeclCXX.h:4033
Represents a C++ using-enum-declaration.
Definition DeclCXX.h:3788
Represents a shadow declaration implicitly introduced into a scope by a (resolved) using-declaration ...
Definition DeclCXX.h:3395
Represent the declaration of a variable (in which case it is an lvalue) a function (in which case it ...
Definition Decl.h:712
Represents a variable declaration or definition.
Definition Decl.h:926
Declaration of a variable template.
Represents a C array with a specified size that is not an integer-constant-expression.
Definition TypeBase.h:3966
Represents a GCC generic vector type.
Definition TypeBase.h:4175
This class provides information about commands that can be used in comments.
A full comment attached to a declaration, contains block content.
Definition Comment.h:1104
Holds all information required to evaluate constexpr code in a module.
Definition Context.h:41
const internal::VariadicAllOfMatcher< Type > type
Matches Types in the clang AST.
const internal::VariadicDynCastAllOfMatcher< Stmt, BlockExpr > blockExpr
Matches a reference to a block.
llvm::FixedPointSemantics FixedPointSemantics
Definition Interp.h:42
The JSON file list parser is used to communicate input to InstallAPI.
CanQual< Type > CanQualType
Represents a canonical, potentially-qualified type.
GVALinkage
A more specific kind of linkage than enum Linkage.
Definition Linkage.h:72
AutoTypeKeyword
Which keyword(s) were used to create an AutoType.
Definition TypeBase.h:1792
bool isTargetAddressSpace(LangAS AS)
OpenCLTypeKind
OpenCL type kinds.
Definition TargetInfo.h:212
NullabilityKind
Describes the nullability of a particular type.
Definition Specifiers.h:348
@ Nullable
Values of this type can be null.
Definition Specifiers.h:352
@ Unspecified
Whether values of this type can be null is (explicitly) unspecified.
Definition Specifiers.h:357
@ NonNull
Values of this type can never be null.
Definition Specifiers.h:350
@ TemplateName
The identifier is a template name. FIXME: Add an annotation for that.
Definition Parser.h:61
TypeOfKind
The kind of 'typeof' expression we're after.
Definition TypeBase.h:918
SmallVector< Attr *, 4 > AttrVec
AttrVec - A vector of Attr, which is how they are stored on the AST.
@ Module
Module linkage, which indicates that the entity can be referred to from other translation units withi...
Definition Linkage.h:54
Selector GetUnarySelector(StringRef name, ASTContext &Ctx)
Utility function for constructing an unary selector.
@ Result
The result type of a method or function.
Definition TypeBase.h:905
ArraySizeModifier
Capture whether this is a normal array (e.g.
Definition TypeBase.h:3719
const FunctionProtoType * T
@ Template
We are parsing a template declaration.
Definition Parser.h:81
Selector GetNullarySelector(StringRef name, ASTContext &Ctx)
Utility function for constructing a nullary selector.
@ Class
The "class" keyword.
Definition TypeBase.h:5889
BuiltinTemplateKind
Kinds of BuiltinTemplateDecl.
Definition Builtins.h:479
@ Keyword
The name has been typo-corrected to a keyword.
Definition Sema.h:560
LangAS
Defines the address space values used by the address space qualifier of QualType.
TranslationUnitKind
Describes the kind of translation unit being processed.
@ TU_Incremental
The translation unit is a is a complete translation unit that we might incrementally extend later.
FloatModeKind
Definition TargetInfo.h:75
SmallVector< CXXBaseSpecifier *, 4 > CXXCastPath
A simple array of base specifiers.
Definition ASTContext.h:149
const StreamingDiagnostic & operator<<(const StreamingDiagnostic &DB, const ConceptReference *C)
Insertion operator for diagnostics.
TemplateSpecializationKind
Describes the kind of template specialization that a particular template specialization declaration r...
Definition Specifiers.h:188
CallingConv
CallingConv - Specifies the calling convention that a function uses.
Definition Specifiers.h:278
U cast(CodeGen::Address addr)
Definition Address.h:327
AlignRequirementKind
Definition ASTContext.h:176
@ None
The alignment was not explicit in code.
Definition ASTContext.h:178
@ RequiredByEnum
The alignment comes from an alignment attribute on a enum type.
Definition ASTContext.h:187
@ RequiredByTypedef
The alignment comes from an alignment attribute on a typedef.
Definition ASTContext.h:181
@ RequiredByRecord
The alignment comes from an alignment attribute on a record type.
Definition ASTContext.h:184
ElaboratedTypeKeyword
The elaboration keyword that precedes a qualified type name or introduces an elaborated-type-specifie...
Definition TypeBase.h:5853
@ None
No keyword precedes the qualified type name.
Definition TypeBase.h:5874
@ Other
Other implicit parameter.
Definition Decl.h:1746
Diagnostic wrappers for TextAPI types for error reporting.
Definition Dominators.h:30
BuiltinVectorTypeInfo(QualType ElementType, llvm::ElementCount EC, unsigned NumVectors)
CUDAConstantEvalContextRAII(ASTContext &Ctx_, bool NoWrongSidedVars)
Definition ASTContext.h:802
BuiltinVectorTypeInfo(QualType ElementType, llvm::ElementCount EC, unsigned NumVectors)
CUDAConstantEvalContextRAII(ASTContext &Ctx_, bool NoWrongSidedVars)
Definition ASTContext.h:802
bool NoWrongSidedVars
Do not allow wrong-sided variables in constant expressions.
Definition ASTContext.h:797
SourceLocation PragmaSectionLocation
SectionInfo(NamedDecl *Decl, SourceLocation PragmaSectionLocation, int SectionFlags)
Copy initialization expr of a __block variable and a boolean flag that indicates whether the expressi...
Definition Expr.h:6604
DeclarationNameInfo - A collector data type for bundling together a DeclarationName and the correspon...
Holds information about the various types of exception specification.
Definition TypeBase.h:5311
Extra information about a function prototype.
Definition TypeBase.h:5339
A cache of the value of this pointer, in the most recent generation in which we queried it.
static ValueType makeValue(const ASTContext &Ctx, T Value)
Create the representation of a LazyGenerationalUpdatePtr.
llvm::PointerUnion< T, LazyData * > ValueType
Parts of a decomposed MSGuidDecl.
Definition DeclCXX.h:4369
Contains information gathered from parsing the contents of TargetAttr.
Definition TargetInfo.h:60
Describes how types, statements, expressions, and declarations should be printed.
A std::pair-like structure for storing a qualified type split into its local qualifiers and its local...
Definition TypeBase.h:870
const Type * Ty
The locally-unqualified type.
Definition TypeBase.h:872
Qualifiers Quals
The local qualifiers.
Definition TypeBase.h:875
AlignRequirementKind AlignRequirement
Definition ASTContext.h:207
TypeInfoChars(CharUnits Width, CharUnits Align, AlignRequirementKind AlignRequirement)
Definition ASTContext.h:210
bool isAlignRequired()
Definition ASTContext.h:199
AlignRequirementKind AlignRequirement
Definition ASTContext.h:193
TypeInfo(uint64_t Width, unsigned Align, AlignRequirementKind AlignRequirement)
Definition ASTContext.h:196
static ScalableVecTyKey getTombstoneKey()
Definition ASTContext.h:73
static ScalableVecTyKey getEmptyKey()
Definition ASTContext.h:70
static bool isEqual(const ScalableVecTyKey &LHS, const ScalableVecTyKey &RHS)
Definition ASTContext.h:80
static unsigned getHashValue(const ScalableVecTyKey &Val)
Definition ASTContext.h:76
static bool isEqual(const FoldingSetNodeID &LHS, const FoldingSetNodeID &RHS)
static FoldingSetNodeID getTombstoneKey()
static unsigned getHashValue(const FoldingSetNodeID &Val)
clang::QualType EltTy
Definition ASTContext.h:57
bool operator==(const ScalableVecTyKey &RHS) const
Definition ASTContext.h:61