38#include "llvm/ADT/PointerIntPair.h"
39#include "llvm/ADT/StringRef.h"
40#include "llvm/Support/ErrorHandling.h"
41#include "llvm/Support/MathExtras.h"
42#include "llvm/Support/VersionTuple.h"
43#include "llvm/Support/raw_ostream.h"
57#define DECL(DERIVED, BASE) static int n##DERIVED##s = 0;
58#define ABSTRACT_DECL(DECL)
59#include "clang/AST/DeclNodes.inc"
61#define DECL(DERIVED, BASE) \
62 static_assert(alignof(Decl) >= alignof(DERIVED##Decl), \
63 "Alignment sufficient after objects prepended to " #DERIVED);
64#define ABSTRACT_DECL(DECL)
65#include "clang/AST/DeclNodes.inc"
67void *Decl::operator
new(std::size_t Size,
const ASTContext &Context,
71 static_assert(
sizeof(uint64_t) >=
alignof(
Decl),
"Decl won't be misaligned");
72 void *Start = Context.Allocate(Size +
Extra + 8);
73 void *
Result = (
char*)Start + 8;
75 uint64_t *PrefixPtr = (uint64_t *)
Result - 1;
77 *PrefixPtr = ID.getRawValue();
82 assert((*PrefixPtr < llvm::maskTrailingOnes<uint64_t>(48)) &&
83 "Current Implementation limits the number of module files to not "
84 "exceed 2^16. Contact Clang Developers to remove the limitation.");
89void *Decl::operator
new(std::size_t Size,
const ASTContext &Ctx,
91 assert(!Parent || &Parent->getParentASTContext() == &Ctx);
95 if (Ctx.getLangOpts().trackLocalOwningModule() || !Parent) {
99 llvm::offsetToAlignment(
sizeof(
Module *), llvm::Align(
alignof(
Decl)));
100 auto *Buffer =
reinterpret_cast<char *
>(
101 ::operator
new(ExtraAlign +
sizeof(
Module *) + Size +
Extra, Ctx));
102 Buffer += ExtraAlign;
104 Parent ?
cast<Decl>(Parent)->getOwningModule() :
nullptr;
105 return new (Buffer)
Module*(ParentModule) + 1;
107 return ::operator
new(Size +
Extra, Ctx);
114 uint64_t ID = *((
const uint64_t *)
this - 1);
115 return GlobalDeclID(ID & llvm::maskTrailingOnes<uint64_t>(48));
122 uint64_t ID = *((
const uint64_t *)
this - 1);
127 assert(
isFromASTFile() &&
"Only works on a deserialized declaration");
144 assert((ID < llvm::maskTrailingOnes<unsigned>(16)) &&
145 "Current Implementation limits the number of modules to not exceed "
146 "2^16. Contact Clang Developers to remove the limitation.");
147 uint64_t *IDAddress = (uint64_t *)
this - 1;
148 *IDAddress &= llvm::maskTrailingOnes<uint64_t>(48);
149 *IDAddress |= (uint64_t)ID << 48;
160Module *Decl::getOwningModuleSlow()
const {
171 default: llvm_unreachable(
"Declaration not in DeclNodes.inc!");
172#define DECL(DERIVED, BASE) case DERIVED: return #DERIVED;
173#define ABSTRACT_DECL(DECL)
174#include "clang/AST/DeclNodes.inc"
194 if (
auto *DD = dyn_cast<DecompositionDecl>(
this)) {
195 for (
auto *Binding : DD->bindings()) {
196 Binding->setInvalidDecl();
203#define DECL(DERIVED, BASE) case Decl::DERIVED: return true;
204#define ABSTRACT_DECL(DECL)
205#include "clang/AST/DeclNodes.inc"
212#define DECL(DERIVED, BASE) case Decl::DERIVED: return #DERIVED;
213#define ABSTRACT_DECL(DECL)
214#include "clang/AST/DeclNodes.inc"
216 llvm_unreachable(
"Declaration context not in DeclNodes.inc!");
219bool Decl::StatisticsEnabled =
false;
221 StatisticsEnabled =
true;
225 llvm::errs() <<
"\n*** Decl Stats:\n";
228#define DECL(DERIVED, BASE) totalDecls += n##DERIVED##s;
229#define ABSTRACT_DECL(DECL)
230#include "clang/AST/DeclNodes.inc"
231 llvm::errs() <<
" " << totalDecls <<
" decls total.\n";
234#define DECL(DERIVED, BASE) \
235 if (n##DERIVED##s > 0) { \
236 totalBytes += (int)(n##DERIVED##s * sizeof(DERIVED##Decl)); \
237 llvm::errs() << " " << n##DERIVED##s << " " #DERIVED " decls, " \
238 << sizeof(DERIVED##Decl) << " each (" \
239 << n##DERIVED##s * sizeof(DERIVED##Decl) \
242#define ABSTRACT_DECL(DECL)
243#include "clang/AST/DeclNodes.inc"
245 llvm::errs() <<
"Total bytes = " << totalBytes <<
"\n";
250#define DECL(DERIVED, BASE) case DERIVED: ++n##DERIVED##s; break;
251#define ABSTRACT_DECL(DECL)
252#include "clang/AST/DeclNodes.inc"
257 if (
const auto *TTP = dyn_cast<TemplateTypeParmDecl>(
this))
258 return TTP->isParameterPack();
259 if (
const auto *NTTP = dyn_cast<NonTypeTemplateParmDecl>(
this))
260 return NTTP->isParameterPack();
261 if (
const auto *TTP = dyn_cast<TemplateTemplateParmDecl>(
this))
262 return TTP->isParameterPack();
267 if (
const auto *Var = dyn_cast<ValueDecl>(
this))
268 return Var->isParameterPack();
274 if (
auto *FD = dyn_cast<FunctionDecl>(
this))
276 if (
const auto *FTD = dyn_cast<FunctionTemplateDecl>(
this))
277 return FTD->getTemplatedDecl();
286 if (
auto *FD = dyn_cast<FunctionDecl>(
this))
287 return FD->getDescribedFunctionTemplate();
288 if (
auto *RD = dyn_cast<CXXRecordDecl>(
this))
289 return RD->getDescribedClassTemplate();
290 if (
auto *VD = dyn_cast<VarDecl>(
this))
291 return VD->getDescribedVarTemplate();
292 if (
auto *AD = dyn_cast<TypeAliasDecl>(
this))
293 return AD->getDescribedAliasTemplate();
300 return TD->getTemplateParameters();
301 if (
auto *CTPSD = dyn_cast<ClassTemplatePartialSpecializationDecl>(
this))
302 return CTPSD->getTemplateParameters();
303 if (
auto *VTPSD = dyn_cast<VarTemplatePartialSpecializationDecl>(
this))
304 return VTPSD->getTemplateParameters();
312 if (
auto *AsDC = dyn_cast<DeclContext>(
this))
313 return AsDC->isDependentContext();
321 if (
auto *DC = dyn_cast<DeclContext>(
this))
322 if (DC->isFileContext())
326 return TPL->getDepth() + 1;
331 auto *RD = dyn_cast<CXXRecordDecl>(
this);
332 if (RD && RD->isDependentLambda())
333 if (
Decl *Context = RD->getLambdaContextDecl())
334 return Context->getTemplateDepth();
345 if (DC->isFunctionOrMethod())
358 TheLoc = TheDecl->getLocation();
361 TheLoc.
print(OS, SM);
367 if (
const auto *DN = dyn_cast_or_null<NamedDecl>(TheDecl)) {
369 DN->printQualifiedName(OS);
393 getMultipleDC()->LexicalDC = DC;
408 "hidden declaration has no owning module");
413 if (SemaDC == LexicalDC) {
416 auto *MDC =
new (Ctx) Decl::MultipleDC();
417 MDC->SemanticDC = SemaDC;
418 MDC->LexicalDC = LexicalDC;
432 if (
const auto *CRD = dyn_cast<CXXRecordDecl>(LDC))
442 if (
const auto *ND = dyn_cast<NamespaceDecl>(DC))
443 if (ND->isAnonymousNamespace())
456 const auto *DC = dyn_cast<DeclContext>(
this);
457 return DC && DC->isFileContext();
463 bool IgnoreTemplateOrMacroSubstitution) {
470 llvm::APInt Size = CAT->getSize();
471 if (StrictFlexArraysLevel == FAMKind::IncompleteOnly)
478 if (StrictFlexArraysLevel == FAMKind::ZeroOrIncomplete && Size.uge(1))
481 if (StrictFlexArraysLevel == FAMKind::OneZeroOrIncomplete && Size.uge(2))
487 if (
const auto *OID = dyn_cast_if_present<ObjCIvarDecl>(D))
488 return OID->getNextIvar() ==
nullptr;
490 const auto *FD = dyn_cast_if_present<FieldDecl>(D);
497 llvm::APInt Size = CAT->getSize();
498 if (FD->getParent()->isUnion() && (Size.isZero() || Size.isOne()))
504 if (IgnoreTemplateOrMacroSubstitution) {
511 TInfo = TTL.getDecl()->getTypeSourceInfo();
516 if (
const Expr *SizeExpr =
517 dyn_cast_if_present<IntegerLiteral>(CTL.getSizeExpr());
529 return ++FI == FD->getParent()->field_end();
533 if (
auto *TUD = dyn_cast<TranslationUnitDecl>(
this))
537 assert(DC &&
"This decl is not contained in a translation unit!");
541 assert(DC &&
"This decl is not contained in a translation unit!");
569 for (; I != E; ++I) {
570 if (!I->isAlignmentErrorDependent())
571 Align = std::max(Align, I->getAlignment(Ctx));
595 if (
C.getASTMutationListener())
596 C.getASTMutationListener()->DeclarationMarkedUsed(
this);
606 for (
const auto *I :
redecls())
615 if (
auto *ID = dyn_cast<ObjCInterfaceDecl>(
this)) {
617 }
else if (
auto *PD = dyn_cast<ObjCProtocolDecl>(
this)) {
619 }
else if (
auto *TD = dyn_cast<TagDecl>(
this)) {
628 return dcd->getAttr<ExternalSourceSymbolAttr>();
653 StringRef RealizedPlatform = A->getPlatform()->getName();
654 if (!Context.getLangOpts().AppExt)
655 return RealizedPlatform;
656 size_t suffix = RealizedPlatform.rfind(
"_app_extension");
657 if (suffix != StringRef::npos)
658 return RealizedPlatform.slice(0, suffix);
659 return RealizedPlatform;
672 const AvailabilityAttr *A,
673 std::string *Message,
674 VersionTuple EnclosingVersion) {
675 if (EnclosingVersion.empty())
676 EnclosingVersion = Context.getTargetInfo().getPlatformMinVersion();
678 if (EnclosingVersion.empty())
681 StringRef ActualPlatform = A->getPlatform()->getName();
682 StringRef TargetPlatform = Context.getTargetInfo().getPlatformName();
688 StringRef PrettyPlatformName
689 = AvailabilityAttr::getPrettyPlatformName(ActualPlatform);
691 if (PrettyPlatformName.empty())
692 PrettyPlatformName = ActualPlatform;
694 std::string HintMessage;
695 if (!A->getMessage().empty()) {
697 HintMessage += A->getMessage();
701 if (A->getUnavailable()) {
704 llvm::raw_string_ostream Out(*Message);
705 Out <<
"not available on " << PrettyPlatformName
713 if (!A->getIntroduced().empty() &&
714 EnclosingVersion < A->getIntroduced()) {
716 auto &Triple = Context.getTargetInfo().getTriple();
717 StringRef TargetEnv = Triple.getEnvironmentName();
719 llvm::Triple::getEnvironmentTypeName(Triple.getEnvironment());
721 if (!IIEnv || (Triple.hasEnvironment() && IIEnv->
getName() == TargetEnv)) {
724 llvm::raw_string_ostream Out(*Message);
725 VersionTuple VTI(A->getIntroduced());
726 Out <<
"introduced in " << PrettyPlatformName <<
" " << VTI;
727 if (Triple.hasEnvironment())
728 Out <<
" " << EnvName;
736 llvm::raw_string_ostream Out(*Message);
737 Out <<
"not available on " << PrettyPlatformName;
738 if (Triple.hasEnvironment())
739 Out <<
" " << EnvName;
748 if (!A->getObsoleted().empty() && EnclosingVersion >= A->getObsoleted()) {
751 llvm::raw_string_ostream Out(*Message);
752 VersionTuple VTO(A->getObsoleted());
753 Out <<
"obsoleted in " << PrettyPlatformName <<
' '
754 << VTO << HintMessage;
761 if (!A->getDeprecated().empty() && EnclosingVersion >= A->getDeprecated()) {
764 llvm::raw_string_ostream Out(*Message);
765 VersionTuple VTD(A->getDeprecated());
766 Out <<
"first deprecated in " << PrettyPlatformName <<
' '
767 << VTD << HintMessage;
777 VersionTuple EnclosingVersion,
778 StringRef *RealizedPlatform)
const {
779 if (
auto *FTD = dyn_cast<FunctionTemplateDecl>(
this))
780 return FTD->getTemplatedDecl()->getAvailability(Message, EnclosingVersion,
784 std::string ResultMessage;
786 for (
const auto *A :
attrs()) {
787 if (
const auto *Deprecated = dyn_cast<DeprecatedAttr>(A)) {
792 ResultMessage = std::string(Deprecated->getMessage());
798 if (
const auto *Unavailable = dyn_cast<UnavailableAttr>(A)) {
800 *Message = std::string(Unavailable->getMessage());
804 if (
const auto *Availability = dyn_cast<AvailabilityAttr>(A)) {
805 Availability = Availability->getEffectiveAttr();
807 Message, EnclosingVersion);
810 if (RealizedPlatform)
811 *RealizedPlatform = Availability->getPlatform()->getName();
818 ResultMessage.swap(*Message);
825 Message->swap(ResultMessage);
831 StringRef TargetPlatform = Context.getTargetInfo().getPlatformName();
832 for (
const auto *A :
attrs()) {
833 if (
const auto *Availability = dyn_cast<AvailabilityAttr>(A)) {
834 Availability = Availability->getEffectiveAttr();
836 if (!Availability->getIntroduced().empty())
837 return Availability->getIntroduced();
845 IsDefinition =
false;
848 if (
const auto *Var = dyn_cast<VarDecl>(
this)) {
849 if (Var->isThisDeclarationADefinition()) {
856 if (
const auto *FD = dyn_cast<FunctionDecl>(
this)) {
882 if (
const auto *Availability = dyn_cast<AvailabilityAttr>(A)) {
883 Availability = Availability->getEffectiveAttr();
896 case CXXDeductionGuide:
899 case ConstructorUsingShadow:
910 case HLSLRootSignature:
916 case NonTypeTemplateParm:
923 case ObjCCompatibleAlias:
929 case TemplateTypeParm:
933 case UnresolvedUsingTypename:
939 case UnresolvedUsingValue:
952 case ObjCAtDefsField:
969 case TemplateTemplateParm:
973 case UnresolvedUsingIfExists:
976 case OMPDeclareReduction:
979 case OMPDeclareMapper:
991 case ObjCPropertyImpl:
993 case PragmaDetectMismatch:
996 case OutlinedFunction:
997 case TranslationUnit:
1001 case UnnamedGlobalConstant:
1002 case TemplateParamObject:
1004 case UsingDirective:
1006 case ClassTemplateSpecialization:
1007 case ClassTemplatePartialSpecialization:
1008 case VarTemplateSpecialization:
1009 case VarTemplatePartialSpecialization:
1010 case ObjCImplementation:
1012 case ObjCCategoryImpl:
1014 case OMPThreadPrivate:
1015 case OMPGroupPrivate:
1018 case OMPCapturedExpr:
1020 case LifetimeExtendedTemporary:
1021 case RequiresExprBody:
1022 case ImplicitConceptSpecialization:
1023 case OpenACCDeclare:
1024 case OpenACCRoutine:
1030 llvm_unreachable(
"Invalid DeclKind!");
1034 assert(!HasAttrs &&
"Decl already contains attrs.");
1037 assert(AttrBlank.empty() &&
"HasAttrs was wrong?");
1044 if (!HasAttrs)
return;
1065 auto I = Attrs.begin(), E = Attrs.end();
1066 for (; I != E; ++I) {
1067 if (!(*I)->isInherited())
1074 assert(HasAttrs &&
"No attrs to get!");
1081#define DECL(NAME, BASE)
1082#define DECL_CONTEXT(NAME) \
1084 return static_cast<NAME##Decl *>(const_cast<DeclContext *>(D));
1085#include "clang/AST/DeclNodes.inc"
1087 llvm_unreachable(
"a decl that inherits DeclContext isn't handled");
1094#define DECL(NAME, BASE)
1095#define DECL_CONTEXT(NAME) \
1097 return static_cast<NAME##Decl *>(const_cast<Decl *>(D));
1098#include "clang/AST/DeclNodes.inc"
1100 llvm_unreachable(
"a decl that inherits DeclContext isn't handled");
1107 if (
const auto *FD = dyn_cast<FunctionDecl>(
this)) {
1110 return Definition->getSourceRange().getEnd();
1115 return Body->getSourceRange().getEnd();
1120bool Decl::AccessDeclContextCheck()
const {
1144 "Access specifier is AS_none inside a record decl");
1155 return isa_and_nonnull<ExportDecl>(DC);
1162 return M && M->isNamedModule() &&
1180 M = M->getTopLevelModule();
1181 if (!M->isNamedModule())
1190 if (!M || !M->isNamedModule())
1229 if (
const auto *D = dyn_cast<ValueDecl>(
this))
1231 else if (
const auto *D = dyn_cast<TypedefNameDecl>(
this))
1232 Ty = D->getUnderlyingType();
1257 if (
const auto *D = dyn_cast<ValueDecl>(
this))
1259 else if (
const auto *D = dyn_cast<TypedefNameDecl>(
this))
1260 Ty = D->getUnderlyingType();
1275 if (
getKind(D) == Decl::CXXMethod) {
1277 if (MD->getOverloadedOperator() == OO_Call &&
1278 MD->getParent()->isLambda())
1282 if (
auto *FD = dyn_cast<FunctionDecl>(D))
1284 if (
auto *MD = dyn_cast<ObjCMethodDecl>(D))
1286 if (
auto *BD = dyn_cast<BlockDecl>(D))
1288 if (
auto *CD = dyn_cast<CapturedDecl>(D))
1290 if (
auto *OFD = dyn_cast<OutlinedFunctionDecl>(D))
1296 return ::getNonClosureContext(
this);
1300 return ::getNonClosureContext(
this);
1311 setNeedToReconcileExternalVisibleStorage(
false);
1312 setHasLazyLocalLexicalLookups(
false);
1313 setHasLazyExternalLexicalLookups(
false);
1320#define DECL(NAME, BASE)
1321#define DECL_CONTEXT(NAME) case Decl::NAME:
1322#include "clang/AST/DeclNodes.inc"
1375 if (ND->isInline()) {
1376 return ND->getParent()->isStdNamespace();
1383 return II && II->
isStr(
"std");
1393 if (
const auto *
Record = dyn_cast<CXXRecordDecl>(
this)) {
1394 if (
Record->getDescribedClassTemplate())
1397 if (
Record->isDependentLambda())
1399 if (
Record->isNeverDependentLambda())
1403 if (
const auto *
Function = dyn_cast<FunctionDecl>(
this)) {
1404 if (
Function->getDescribedFunctionTemplate())
1429 while (DC->
getDeclKind() != Decl::TranslationUnit) {
1443 while (DC->
getDeclKind() != Decl::TranslationUnit) {
1482 assert(DC &&
"All transparent contexts should have a parent!");
1489 case Decl::ExternCContext:
1490 case Decl::LinkageSpec:
1492 case Decl::TopLevelStmt:
1494 case Decl::Captured:
1495 case Decl::OutlinedFunction:
1496 case Decl::OMPDeclareReduction:
1497 case Decl::OMPDeclareMapper:
1498 case Decl::RequiresExprBody:
1502 case Decl::HLSLBuffer:
1511 case Decl::TranslationUnit:
1513 case Decl::Namespace:
1516 case Decl::ObjCMethod:
1519 case Decl::ObjCInterface:
1520 if (
auto *OID = dyn_cast<ObjCInterfaceDecl>(
this))
1521 if (
auto *Def = OID->getDefinition())
1525 case Decl::ObjCProtocol:
1526 if (
auto *OPD = dyn_cast<ObjCProtocolDecl>(
this))
1527 if (
auto *Def = OPD->getDefinition())
1531 case Decl::ObjCCategory:
1534 case Decl::ObjCImplementation:
1535 case Decl::ObjCCategoryImpl:
1540 case Decl::ClassTemplatePartialSpecialization:
1541 case Decl::ClassTemplateSpecialization:
1542 case Decl::CXXRecord:
1550 getDeclKind() <= Decl::lastFunction &&
"Unknown DeclContext kind");
1555template <
typename T>
1558 for (T *D =
Self->getMostRecentDecl(); D; D = D->getPreviousDecl())
1559 Contexts.push_back(D);
1561 std::reverse(Contexts.begin(), Contexts.end());
1569 if (Kind == Decl::TranslationUnit)
1571 else if (Kind == Decl::Namespace)
1574 Contexts.push_back(
this);
1577std::pair<Decl *, Decl *>
1579 bool FieldsAlreadyLoaded) {
1581 Decl *FirstNewDecl =
nullptr;
1582 Decl *PrevDecl =
nullptr;
1583 for (
auto *D : Decls) {
1595 return std::make_pair(FirstNewDecl, PrevDecl);
1601void DeclContext::reconcileExternalVisibleStorage()
const {
1602 assert(hasNeedToReconcileExternalVisibleStorage() &&
LookupPtr);
1603 setNeedToReconcileExternalVisibleStorage(
false);
1606 Lookup.second.setHasExternalDecls();
1613DeclContext::LoadLexicalDeclsFromExternalStorage()
const {
1623 Source->FindExternalLexicalDecls(
this, Decls);
1630 bool FieldsAlreadyLoaded =
false;
1631 if (
const auto *RD = dyn_cast<RecordDecl>(
this))
1632 FieldsAlreadyLoaded = RD->hasLoadedFieldsFromExternalStorage();
1636 Decl *ExternalFirst, *ExternalLast;
1637 std::tie(ExternalFirst, ExternalLast) =
1652 Map = DC->CreateStoredDeclsMap(Context);
1653 if (DC->hasNeedToReconcileExternalVisibleStorage())
1654 DC->reconcileExternalVisibleStorage();
1656 (*Map)[Name].removeExternalDecls();
1668 Map = DC->CreateStoredDeclsMap(Context);
1669 if (DC->hasNeedToReconcileExternalVisibleStorage())
1670 DC->reconcileExternalVisibleStorage();
1679 LoadLexicalDeclsFromExternalStorage();
1685 LoadLexicalDeclsFromExternalStorage();
1697 LoadLexicalDeclsFromExternalStorage();
1726 if (
auto *FD = dyn_cast<FunctionDecl>(D))
1727 if (FD->isFunctionTemplateSpecialization())
1742 "decl being removed from non-lexical context");
1744 "decl is not in decls list");
1753 for (
Decl *I =
FirstDecl;
true; I = I->NextInContextAndBits.getPointer()) {
1754 assert(I &&
"decl not found in linked list");
1755 if (I->NextInContextAndBits.getPointer() == D) {
1776 if (!ND->getDeclName())
1783 StoredDeclsMap::iterator Pos = Map->find(ND->getDeclName());
1784 assert(Pos != Map->end() &&
"no lookup entry for decl");
1791 }
while (DC->isTransparentContext() && (DC = DC->getParent()));
1797 "Decl inserted into wrong lexical context");
1799 "Decl already inserted into a DeclContext");
1802 LastDecl->NextInContextAndBits.setPointer(D);
1810 if (
auto *
Record = dyn_cast<CXXRecordDecl>(
this))
1816 if (
auto *Import = dyn_cast<ImportDecl>(D))
1824 if (
auto *ND = dyn_cast<NamedDecl>(D))
1825 ND->getDeclContext()->getPrimaryContext()->
1826 makeDeclVisibleInContextWithFlags(ND,
false,
true);
1832 if (
auto *ND = dyn_cast<NamedDecl>(D))
1833 ND->getDeclContext()->getPrimaryContext()->
1834 makeDeclVisibleInContextWithFlags(ND,
true,
true);
1847 if (!hasLazyLocalLexicalLookups() &&
1848 !hasLazyExternalLexicalLookups())
1854 if (hasLazyExternalLexicalLookups()) {
1855 setHasLazyExternalLexicalLookups(
false);
1856 for (
auto *DC : Contexts) {
1857 if (DC->hasExternalLexicalStorage()) {
1858 bool LoadedDecls = DC->LoadLexicalDeclsFromExternalStorage();
1859 setHasLazyLocalLexicalLookups(
1860 hasLazyLocalLexicalLookups() | LoadedDecls );
1864 if (!hasLazyLocalLexicalLookups())
1868 for (
auto *DC : Contexts)
1872 setHasLazyLocalLexicalLookups(
false);
1890 if (
auto *ND = dyn_cast<NamedDecl>(D))
1892 (!ND->isFromASTFile() ||
1895 makeDeclVisibleInContextImpl(ND,
Internal);
1900 if (
auto *InnerCtx = dyn_cast<DeclContext>(D))
1901 if (InnerCtx->isTransparentContext() || InnerCtx->isInlineNamespace())
1902 buildLookupImpl(InnerCtx,
Internal);
1919 "lookupImpl should only be called with primary DC!");
1921 "We shouldn't lookup in transparent DC.");
1931 assert(Source &&
"external visible storage but no external source?");
1933 if (hasNeedToReconcileExternalVisibleStorage())
1934 reconcileExternalVisibleStorage();
1938 if (hasLazyLocalLexicalLookups() ||
1939 hasLazyExternalLexicalLookups())
1947 std::pair<StoredDeclsMap::iterator, bool> R = Map->try_emplace(Name);
1948 if (!R.second && !R.first->second.hasExternalDecls())
1949 return R.first->second.getLookupResult();
1951 if (Source->FindExternalVisibleDeclsByName(
this, Name, OriginalLookupDC) ||
1954 StoredDeclsMap::iterator I = Map->find(Name);
1955 if (I != Map->end())
1956 return I->second.getLookupResult();
1964 if (hasLazyLocalLexicalLookups() ||
1965 hasLazyExternalLexicalLookups())
1971 StoredDeclsMap::iterator I = Map->find(Name);
1972 if (I == Map->end())
1975 return I->second.getLookupResult();
1985 if (PrimaryContext !=
this)
1988 loadLazyLocalLexicalLookups();
1993 StoredDeclsMap::iterator I = Map->find(Name);
1994 return I != Map->end() ? I->second.getLookupResult()
2001void DeclContext::loadLazyLocalLexicalLookups() {
2002 if (hasLazyLocalLexicalLookups()) {
2005 for (
auto *Context : Contexts)
2007 setHasLazyLocalLexicalLookups(
false);
2019 llvm::append_range(Results, LookupResults);
2020 if (!Results.empty())
2026 if (Name && !hasLazyLocalLexicalLookups() &&
2027 !hasLazyExternalLexicalLookups()) {
2029 StoredDeclsMap::iterator Pos = Map->find(Name);
2030 if (Pos != Map->end()) {
2031 Results.insert(Results.end(),
2032 Pos->second.getLookupResult().begin(),
2033 Pos->second.getLookupResult().end());
2043 for (
Decl *D =
FirstDecl; D; D = D->getNextDeclInContext()) {
2044 if (
auto *ND = dyn_cast<NamedDecl>(D))
2045 if (ND->getDeclName() == Name)
2046 Results.push_back(ND);
2058 bool SkipRecords =
getDeclKind() == Decl::Kind::Enum &&
2096 const auto *NS = dyn_cast<NamespaceDecl>(O);
2097 if (!NS || !NS->isInline())
2110 PrimaryDC->makeDeclVisibleInContextWithFlags(D,
false, PrimaryDC == DeclDC);
2120 ->makeDeclVisibleInContextWithFlags(D,
Internal, Recoverable);
2144 makeDeclVisibleInContextImpl(D,
Internal);
2146 setHasLazyLocalLexicalLookups(
true);
2153 makeDeclVisibleInContextWithFlags(D,
Internal, Recoverable);
2158 if (ASTMutationListener *L = DCAsDecl->getASTMutationListener())
2159 L->AddedVisibleDecl(
this, D);
2167 Map = CreateStoredDeclsMap(*
C);
2181 StoredDeclsList &DeclNameEntries = (*Map)[D->
getDeclName()];
2214 assert(!
LookupPtr &&
"context already has a decls map");
2216 "creating decls map on non-primary context");
2224 M->Previous =
C.LastSDM;
2225 C.LastSDM = llvm::PointerIntPair<StoredDeclsMap*,1>(M,
Dependent);
2230void ASTContext::ReleaseDeclContextMaps() {
2235 LastSDM.setPointer(
nullptr);
2241 llvm::PointerIntPair<StoredDeclsMap*,1>
Next = Map->Previous;
2248 Map =
Next.getPointer();
2257 &&
"cannot iterate dependent diagnostics of non-dependent context");
2260 Parent->CreateStoredDeclsMap(
C);
2273 DD->NextDiagnostic = Map->FirstDiagnostic;
2274 Map->FirstDiagnostic = DD;
2280 return ID & llvm::maskTrailingOnes<DeclID>(32);
Defines the clang::ASTContext interface.
#define BuiltinTemplate(BTName)
This file provides some common utility functions for processing Lambda related AST Constructs.
static bool shouldBeHidden(NamedDecl *D)
shouldBeHidden - Determine whether a declaration which was declared within its semantic context shoul...
static void collectAllContextsImpl(T *Self, SmallVectorImpl< DeclContext * > &Contexts)
static bool isLinkageSpecContext(const DeclContext *DC, LinkageSpecLanguageIDs ID)
static Decl::Kind getKind(const Decl *D)
static Decl * getNonClosureContext(T *D)
Starting at a given context (a Decl or DeclContext), look for a code context that is not a closure (a...
static AvailabilityResult CheckAvailability(ASTContext &Context, const AvailabilityAttr *A, std::string *Message, VersionTuple EnclosingVersion)
Determine the availability of the given declaration based on the target platform.
static StringRef getRealizedPlatform(const AvailabilityAttr *A, const ASTContext &Context)
Defines the C++ Decl subclasses, other than those for templates (found in DeclTemplate....
This file defines OpenACC nodes for declarative directives.
This file defines OpenMP nodes for declarative directives.
Defines the C++ template declaration subclasses.
Defines the clang::IdentifierInfo, clang::IdentifierTable, and clang::Selector interfaces.
Forward-declares and imports various common LLVM datatypes that clang wants to use unqualified.
llvm::MachO::Record Record
Defines the clang::Module class, which describes a module in the source code.
Defines types useful for describing an Objective-C runtime.
Implements a partial diagnostic that can be emitted anwyhere in a DiagnosticBuilder stream.
Defines the clang::SourceLocation class and associated facilities.
static QualType getPointeeType(const MemRegion *R)
C Language Family Type Representation.
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
const ConstantArrayType * getAsConstantArrayType(QualType T) const
ASTMutationListener * getASTMutationListener() const
Retrieve a pointer to the AST mutation listener associated with this AST context, if any.
const IncompleteArrayType * getAsIncompleteArrayType(QualType T) const
const LangOptions & getLangOpts() const
llvm::BumpPtrAllocator & getAllocator() const
void eraseDeclAttrs(const Decl *D)
Erase the attributes corresponding to the given declaration.
void addedLocalImportDecl(ImportDecl *Import)
Notify the AST context that a new import declaration has been parsed or implicitly created within thi...
ExternalASTSource * getExternalSource() const
Retrieve a pointer to the external AST source associated with this AST context, if any.
Module * getCurrentNamedModule() const
Get module under construction, nullptr if this is not a C++20 module.
AttrVec & getDeclAttrs(const Decl *D)
Retrieve the attributes for the given declaration.
An abstract interface that should be implemented by listeners that want to be notified when an AST en...
Attr - This represents one attribute.
Represents a block literal declaration, which is like an unnamed FunctionDecl.
decl_iterator - Iterates through the declarations stored within this context.
DeclContext - This is used only as base class of specific decl types that can act as declaration cont...
DeclContext * getParent()
getParent - Returns the containing DeclContext.
udir_range using_directives() const
Returns iterator range [First, Last) of UsingDirectiveDecls stored within this context.
bool Equals(const DeclContext *DC) const
Determine whether this declaration context is equivalent to the declaration context DC.
bool isFileContext() const
void setHasExternalVisibleStorage(bool ES=true) const
State whether this DeclContext has external storage for declarations visible in this context.
void makeDeclVisibleInContext(NamedDecl *D)
Makes a declaration visible within this context.
DeclContextLookupResult lookup_result
static std::pair< Decl *, Decl * > BuildDeclChain(ArrayRef< Decl * > Decls, bool FieldsAlreadyLoaded)
Build up a chain of declarations.
bool isTransparentContext() const
isTransparentContext - Determines whether this context is a "transparent" context,...
Decl * getNonClosureAncestor()
Find the nearest non-closure ancestor of this context, i.e.
ASTContext & getParentASTContext() const
bool isExternCXXContext() const
Determines whether this context or some of its ancestors is a linkage specification context that spec...
bool isDependentContext() const
Determines whether this context is dependent on a template parameter.
bool InEnclosingNamespaceSetOf(const DeclContext *NS) const
Test if this context is part of the enclosing namespace set of the context NS, as defined in C++0x [n...
DeclContext * getLexicalParent()
getLexicalParent - Returns the containing lexical DeclContext.
lookup_result lookup(DeclarationName Name) const
lookup - Find the declarations (if any) with the given Name in this context.
bool isLookupContext() const
Test whether the context supports looking up names.
const BlockDecl * getInnermostBlockDecl() const
Return this DeclContext if it is a BlockDecl.
bool hasExternalVisibleStorage() const
Whether this DeclContext has external storage containing additional declarations that are visible in ...
const char * getDeclKindName() const
bool isTranslationUnit() const
void collectAllContexts(SmallVectorImpl< DeclContext * > &Contexts)
Collects all of the declaration contexts that are semantically connected to this declaration context.
DeclContext * getRedeclContext()
getRedeclContext - Retrieve the context in which an entity conflicts with other entities of the same ...
llvm::iterator_range< udir_iterator > udir_range
Decl * FirstDecl
FirstDecl - The first declaration stored within this declaration context.
DeclContext(Decl::Kind K)
void addDeclInternal(Decl *D)
Add the declaration D into this context, but suppress searches for external declarations with the sam...
bool containsDeclAndLoad(Decl *D) const
Checks whether a declaration is in this context.
void removeDecl(Decl *D)
Removes a declaration from this context.
void addDecl(Decl *D)
Add the declaration D into this context.
StoredDeclsMap * buildLookup()
Ensure the lookup structure is fully-built and return it.
bool hasValidDeclKind() const
bool isStdNamespace() const
lookup_result noload_lookup(DeclarationName Name)
Find the declarations with the given name that are visible within this context; don't attempt to retr...
static bool classof(const Decl *D)
bool containsDecl(Decl *D) const
Checks whether a declaration is in this context.
bool hasExternalLexicalStorage() const
Whether this DeclContext has external storage containing additional declarations that are lexically i...
void setUseQualifiedLookup(bool use=true) const
DeclContext * getEnclosingNamespaceContext()
Retrieve the nearest enclosing namespace context.
friend class ExternalASTSource
For reconcileExternalVisibleStorage, CreateStoredDeclsMap, hasNeedToReconcileExternalVisibleStorage.
Decl * LastDecl
LastDecl - The last declaration stored within this declaration context.
decl_range noload_decls() const
noload_decls_begin/end - Iterate over the declarations stored in this context that are currently load...
friend class DependentDiagnostic
For CreateStoredDeclsMap.
DeclContext * getPrimaryContext()
getPrimaryContext - There may be many different declarations of the same entity (including forward de...
RecordDecl * getOuterLexicalRecordContext()
Retrieve the outermost lexically enclosing record context.
bool isInlineNamespace() const
DeclContextBitfields DeclContextBits
bool isFunctionOrMethod() const
void setHasExternalLexicalStorage(bool ES=true) const
State whether this DeclContext has external storage for declarations lexically in this context.
DeclContext * getLookupParent()
Find the parent context of this context that will be used for unqualified name lookup.
StoredDeclsMap * LookupPtr
Pointer to the data structure used to lookup declarations within this context (or a DependentStoredDe...
bool isExternCContext() const
Determines whether this context or some of its ancestors is a linkage specification context that spec...
const LinkageSpecDecl * getExternCContext() const
Retrieve the nearest enclosing C linkage specification context.
bool Encloses(const DeclContext *DC) const
Determine whether this declaration context semantically encloses the declaration context DC.
void addHiddenDecl(Decl *D)
Add the declaration D to this context without modifying any lookup tables.
void localUncachedLookup(DeclarationName Name, SmallVectorImpl< NamedDecl * > &Results)
A simplistic name lookup mechanism that performs name lookup into this declaration context without co...
Decl::Kind getDeclKind() const
DeclContext * getNonTransparentContext()
decl_iterator decls_begin() const
bool LexicallyEncloses(const DeclContext *DC) const
Determine whether this declaration context lexically encloses the declaration context DC.
unsigned getLocalDeclIndex() const
Decl - This represents one declaration (or definition), e.g.
Decl * getMostRecentDecl()
Retrieve the most recent declaration that declares the same entity as this declaration (which may be ...
const DeclContext * getParentFunctionOrMethod(bool LexicalParent=false) const
If this decl is defined inside a function/method/block it returns the corresponding DeclContext,...
bool isInStdNamespace() const
bool isInCurrentModuleUnit() const
Whether this declaration comes from the same module unit being compiled.
TemplateDecl * getDescribedTemplate() const
If this is a declaration that describes some template, this method returns that template declaration.
bool isTemplateDecl() const
returns true if this declaration is a template
Module * getTopLevelOwningNamedModule() const
Get the top level owning named module that owns this declaration if any.
FriendObjectKind getFriendObjectKind() const
Determines whether this declaration is the object of a friend declaration and, if so,...
bool isModuleLocal() const
Whether this declaration was a local declaration to a C++20 named module.
bool isFromGlobalModule() const
Whether this declaration comes from global module.
static bool isFlexibleArrayMemberLike(const ASTContext &Context, const Decl *D, QualType Ty, LangOptions::StrictFlexArraysLevelKind StrictFlexArraysLevel, bool IgnoreTemplateOrMacroSubstitution)
Whether it resembles a flexible array member.
ASTContext & getASTContext() const LLVM_READONLY
void setOwningModuleID(unsigned ID)
Set the owning module ID.
void setAttrs(const AttrVec &Attrs)
bool hasLocalOwningModuleStorage() const
bool isFunctionPointerType() const
bool isInNamedModule() const
Whether this declaration comes from a named module.
ExternalSourceSymbolAttr * getExternalSourceSymbolAttr() const
Looks on this and related declarations for an applicable external source symbol attribute.
bool isWeakImported() const
Determine whether this is a weak-imported symbol.
ModuleOwnershipKind getModuleOwnershipKind() const
Get the kind of module ownership for this declaration.
bool isParameterPack() const
Whether this declaration is a parameter pack.
ASTMutationListener * getASTMutationListener() const
unsigned getMaxAlignment() const
getMaxAlignment - return the maximum alignment specified by attributes on this decl,...
AvailabilityResult getAvailability(std::string *Message=nullptr, VersionTuple EnclosingVersion=VersionTuple(), StringRef *RealizedPlatform=nullptr) const
Determine the availability of the given declaration.
void setInvalidDecl(bool Invalid=true)
setInvalidDecl - Indicates the Decl had a semantic error.
Kind
Lists the kind of concrete classes of Decl.
static unsigned getIdentifierNamespaceForKind(Kind DK)
virtual Stmt * getBody() const
getBody - If this Decl represents a declaration for a body of code, such as a function or method defi...
void markUsed(ASTContext &C)
Mark the declaration used, in the sense of odr-use.
bool isFileContextDecl() const
static Decl * castFromDeclContext(const DeclContext *)
Decl * getNextDeclInContext()
bool isTemplated() const
Determine whether this declaration is a templated entity (whether it is.
bool isInExportDeclContext() const
Whether this declaration was exported in a lexical context.
SourceLocation getBodyRBrace() const
getBodyRBrace - Gets the right brace of the body, if a body exists.
bool isReferenced() const
Whether any declaration of this entity was referenced.
const FunctionType * getFunctionType(bool BlocksToo=true) const
Looks through the Decl's underlying type to extract a FunctionType when possible.
bool isInAnotherModuleUnit() const
Whether this declaration comes from another module unit.
llvm::PointerIntPair< Decl *, 3, ModuleOwnershipKind > NextInContextAndBits
The next declaration within the same lexical DeclContext.
Module * getOwningModule() const
Get the module that owns this declaration (for visibility purposes).
unsigned getTemplateDepth() const
Determine the number of levels of template parameter surrounding this declaration.
bool isFromExplicitGlobalModule() const
Whether this declaration comes from explicit global module.
FunctionDecl * getAsFunction() LLVM_READONLY
Returns the function itself, or the templated function if this is a function template.
bool canBeWeakImported(bool &IsDefinition) const
Determines whether this symbol can be weak-imported, e.g., whether it would be well-formed to add the...
static DeclContext * castToDeclContext(const Decl *)
const TemplateParameterList * getDescribedTemplateParams() const
If this is a declaration that describes some template or partial specialization, this returns the cor...
bool isFromASTFile() const
Determine whether this declaration came from an AST file (such as a precompiled header or module) rat...
bool isInLocalScopeForInstantiation() const
Determine whether a substitution into this declaration would occur as part of a substitution into a d...
const Attr * getDefiningAttr() const
Return this declaration's defining attribute if it has one.
bool isTemplateParameter() const
isTemplateParameter - Determines whether this declaration is a template parameter.
DeclContext * getNonTransparentDeclContext()
Return the non transparent context.
Decl * getNonClosureContext()
Find the innermost non-closure ancestor of this declaration, walking up through blocks,...
bool isInvalidDecl() const
unsigned getIdentifierNamespace() const
bool hasDefiningAttr() const
Return true if this declaration has an attribute which acts as definition of the entity,...
bool isLocalExternDecl() const
Determine whether this is a block-scope declaration with linkage.
void setAccess(AccessSpecifier AS)
const char * getDeclKindName() const
@ IDNS_Ordinary
Ordinary names.
@ IDNS_Type
Types, declared with 'struct foo', typedefs, etc.
@ IDNS_OMPReduction
This declaration is an OpenMP user defined reduction construction.
@ IDNS_Label
Labels, declared with 'x:' and referenced with 'goto x'.
@ IDNS_Member
Members, declared with object declarations within tag definitions.
@ IDNS_OMPMapper
This declaration is an OpenMP user defined mapper.
@ IDNS_ObjCProtocol
Objective C @protocol.
@ IDNS_Namespace
Namespaces, declared with 'namespace foo {}'.
@ IDNS_Using
This declaration is a using declaration.
@ IDNS_Tag
Tags, declared with 'struct foo;' and referenced with 'struct foo'.
bool isTemplateParameterPack() const
isTemplateParameter - Determines whether this declaration is a template parameter pack.
void setLocalOwningModule(Module *M)
redecl_range redecls() const
Returns an iterator range for all the redeclarations of the same decl.
void setIsUsed()
Set whether the declaration is used, in the sense of odr-use.
unsigned Access
Access - Used by C++ decls for the access specifier.
bool isUsed(bool CheckUsedAttr=true) const
Whether any (re-)declaration of the entity was used, meaning that a definition is required.
DeclContext * getDeclContext()
bool isInAnonymousNamespace() const
static void EnableStatistics()
TranslationUnitDecl * getTranslationUnitDecl()
VersionTuple getVersionIntroduced() const
Retrieve the version of the target platform in which this declaration was introduced.
bool hasOwningModule() const
Is this declaration owned by some module?
bool isFromHeaderUnit() const
Whether this declaration comes from a header unit.
void setDeclContext(DeclContext *DC)
setDeclContext - Set both the semantic and lexical DeclContext to DC.
DeclContext * getLexicalDeclContext()
getLexicalDeclContext - The declaration context where this Decl was lexically declared (LexicalDC).
void setLexicalDeclContext(DeclContext *DC)
virtual Decl * getCanonicalDecl()
Retrieves the "canonical" declaration of the given declaration.
@ VisiblePromoted
This declaration has an owning module, and is not visible to the current TU but we promoted it to be ...
@ VisibleWhenImported
This declaration has an owning module, and is visible when that module is imported.
@ ReachableWhenImported
This declaration has an owning module, and is visible to lookups that occurs within that module.
void setModuleOwnershipKind(ModuleOwnershipKind MOK)
Set whether this declaration is hidden from name lookup.
const LangOptions & getLangOpts() const LLVM_READONLY
Helper to get the language options from the ASTContext.
GlobalDeclID getGlobalID() const
Retrieve the global declaration ID associated with this declaration, which specifies where this Decl ...
unsigned getOwningModuleID() const
Retrieve the global ID of the module that owns this particular declaration.
bool shouldEmitInExternalSource() const
Whether the definition of the declaration should be emitted in external sources.
The name of a declaration.
A dependently-generated diagnostic.
static DependentDiagnostic * Create(ASTContext &Context, DeclContext *Parent, AccessNonce _, SourceLocation Loc, bool IsMemberAccess, AccessSpecifier AS, NamedDecl *TargetDecl, CXXRecordDecl *NamingClass, QualType BaseObjectType, const PartialDiagnostic &PDiag)
This represents one expression.
SourceLocation getExprLoc() const LLVM_READONLY
getExprLoc - Return the preferred location for the arrow when diagnosing a problem with a generic exp...
RAII class for safely pairing a StartedDeserializing call with FinishedDeserializing.
Abstract interface for external sources of AST nodes.
virtual ExtKind hasExternalDefinitions(const Decl *D)
static DeclContextLookupResult SetExternalVisibleDeclsForName(const DeclContext *DC, DeclarationName Name, ArrayRef< NamedDecl * > Decls)
static DeclContextLookupResult SetNoExternalVisibleDeclsForName(const DeclContext *DC, DeclarationName Name)
virtual Module * getModule(unsigned ID)
Retrieve the module that corresponds to the given module ID.
virtual bool FindExternalVisibleDeclsByName(const DeclContext *DC, DeclarationName Name, const DeclContext *OriginalDC)
Find all declarations with the given name in the given context, and add them to the context by callin...
Represents a member of a struct/union/class.
Represents a function declaration or definition.
FunctionType - C99 6.7.5.3 - Function Declarators.
One of these records is kept for each identifier that is lexed.
bool isStr(const char(&Str)[StrLen]) const
Return true if this is the identifier for the specified string.
StringRef getName() const
Return the actual identifier string.
StrictFlexArraysLevelKind
Keeps track of the various options that can be enabled, which controls the dialect of C or C++ that i...
bool trackLocalOwningModule() const
Do we need to track the owning module for a local declaration?
Represents a linkage specification.
A pointer to member type per C++ 8.3.3 - Pointers to members.
Describes a module or submodule.
bool isExplicitGlobalModule() const
bool isGlobalModule() const
Does this Module scope describe a fragment of the global module within some C++ module.
bool isHeaderUnit() const
Is this module a header unit.
bool isNamedModule() const
Does this Module is a named module of a standard named module?
Module * getTopLevelModule()
Retrieve the top-level module for this (sub)module, which may be this module.
This represents a decl that may have a name.
DeclarationName getDeclName() const
Get the actual, stored name of the declaration, which may be a special name.
Represent a C++ namespace.
The basic abstraction for the target Objective-C runtime.
bool hasWeakClassImport() const
Does this runtime support weakly importing classes?
PointerType - C99 6.7.5.1 - Pointer Declarators.
void print(raw_ostream &OS) const override
A (possibly-)qualified type.
bool isNull() const
Return true if this QualType doesn't point to a type yet.
QualType getCanonicalType() const
Represents a struct/union/class.
specific_decl_iterator< FieldDecl > field_iterator
Base for LValueReferenceType and RValueReferenceType.
Encodes a location in the source.
bool isValid() const
Return true if this is a valid SourceLocation object.
void print(raw_ostream &OS, const SourceManager &SM) const
Stmt - This represents one statement.
An array of decls optimized for the common case of only containing one entry.
void setHasExternalDecls()
void addOrReplaceDecl(NamedDecl *D)
If this is a redeclaration of an existing decl, replace the old one with D.
void prependDeclNoReplace(NamedDecl *D)
Add a declaration to the list without checking if it replaces anything.
void replaceExternalDecls(ArrayRef< NamedDecl * > Decls)
void remove(NamedDecl *D)
DeclContext::lookup_result getLookupResult() const
Return the list of all the decls.
static void DestroyAll(StoredDeclsMap *Map, bool Dependent)
The base class of all kinds of template declarations (e.g., class, function, etc.).
Stores a list of template parameters for a TemplateDecl and its derived classes.
The top declaration context.
ASTContext & getASTContext() const
Base wrapper for a particular "section" of type source info.
T getAs() const
Convert to the specified TypeLoc type, returning a null TypeLoc if this TypeLoc is not of the desired...
T getAsAdjusted() const
Convert to the specified TypeLoc type, returning a null TypeLoc if this TypeLoc is not of the desired...
A container of type source information.
TypeLoc getTypeLoc() const
Return the TypeLoc wrapper for the type source info.
bool isBlockPointerType() const
bool isFunctionReferenceType() const
bool isFunctionPointerType() const
const T * castAs() const
Member-template castAs<specific type>.
bool isMemberFunctionPointerType() const
const T * getAs() const
Member-template getAs<specific type>'.
Wrapper for source info for typedefs.
Represents C++ using-directive.
specific_attr_iterator - Iterates over a subrange of an AttrVec, only providing attributes that are o...
Defines the clang::TargetInfo interface.
The JSON file list parser is used to communicate input to InstallAPI.
bool isa(CodeGen::Address addr)
LinkageSpecLanguageIDs
Represents the language in a linkage specification.
@ Self
'self' clause, allowed on Compute and Combined Constructs, plus 'update'.
SmallVector< Attr *, 4 > AttrVec
AttrVec - A vector of Attr, which is how they are stored on the AST.
@ Dependent
Parse the block as a dependent block, which may be used in some template instantiations but not other...
@ Internal
Internal linkage, which indicates that the entity can be referred to from within the translation unit...
bool isLambdaCallOperator(const CXXMethodDecl *MD)
@ Result
The result type of a method or function.
@ ExplicitInstantiation
We are parsing an explicit instantiation.
@ FunctionTemplate
The name was classified as a function template name.
@ Concept
The name was classified as a concept name.
@ VarTemplate
The name was classified as a variable template name.
AvailabilityResult
Captures the result of checking the availability of a declaration.
U cast(CodeGen::Address addr)
@ Enum
The "enum" keyword introduces the elaborated-type-specifier.
UsingDirectiveDecl * operator*() const