9#ifndef LLDB_SOURCE_PLUGINS_EXPRESSIONPARSER_CLANG_ASTUTILS_H
10#define LLDB_SOURCE_PLUGINS_EXPRESSIONPARSER_CLANG_ASTUTILS_H
12#include "clang/Basic/ASTSourceDescriptor.h"
13#include "clang/Sema/Lookup.h"
14#include "clang/Sema/MultiplexExternalSemaSource.h"
15#include "clang/Sema/Sema.h"
16#include "clang/Sema/SemaConsumer.h"
17#include "llvm/ADT/IntrusiveRefCntPtr.h"
18#include "llvm/Support/Casting.h"
33 llvm::IntrusiveRefCntPtr<ExternalASTSource>
m_Source;
38 assert(
m_Source &&
"Can't wrap nullptr ExternalASTSource");
52 return m_Source->GetNumExternalSelectors();
56 return m_Source->GetExternalDeclStmt(Offset);
59 clang::CXXCtorInitializer **
61 return m_Source->GetExternalCXXCtorInitializers(Offset);
64 clang::CXXBaseSpecifier *
66 return m_Source->GetExternalCXXBaseSpecifiers(Offset);
70 m_Source->updateOutOfDateIdentifier(II);
74 const clang::DeclContext *DC, clang::DeclarationName Name,
75 const clang::DeclContext *OriginalDC)
override {
76 return m_Source->FindExternalVisibleDeclsByName(DC, Name, OriginalDC);
80 bool OnlyPartial)
override {
81 return m_Source->LoadExternalSpecializations(D, OnlyPartial);
86 llvm::ArrayRef<clang::TemplateArgument> TemplateArgs)
override {
87 return m_Source->LoadExternalSpecializations(D, TemplateArgs);
91 m_Source->completeVisibleDeclsMap(DC);
98 std::optional<clang::ASTSourceDescriptor>
104 return m_Source->hasExternalDefinitions(D);
108 const clang::DeclContext *DC,
109 llvm::function_ref<
bool(clang::Decl::Kind)> IsKindWeWant,
111 m_Source->FindExternalLexicalDecls(DC, IsKindWeWant, Result);
117 m_Source->FindFileRegionDecls(
File, Offset, Length, Decls);
139 m_Source->StartTranslationUnit(Consumer);
145 const clang::RecordDecl *Record, uint64_t &Size, uint64_t &Alignment,
146 llvm::DenseMap<const clang::FieldDecl *, uint64_t> &FieldOffsets,
147 llvm::DenseMap<const clang::CXXRecordDecl *, clang::CharUnits>
149 llvm::DenseMap<const clang::CXXRecordDecl *, clang::CharUnits>
150 &VirtualBaseOffsets)
override {
151 return m_Source->layoutRecordType(Record, Size, Alignment, FieldOffsets,
152 BaseOffsets, VirtualBaseOffsets);
165 llvm::MapVector<clang::NamedDecl *, clang::SourceLocation> &Undefined)
167 Undefined.remove_if([](
auto const &decl_loc_pair) {
168 const clang::NamedDecl *ND = decl_loc_pair.first;
169 return llvm::isa_and_present<clang::FunctionDecl>(ND);
183 m_sc = llvm::dyn_cast<clang::SemaConsumer>(
m_c);
189 m_c->Initialize(Context);
193 return m_c->HandleTopLevelDecl(D);
197 m_c->HandleInlineFunctionDefinition(D);
201 m_c->HandleInterestingDecl(D);
205 m_c->HandleTranslationUnit(Ctx);
209 m_c->HandleTagDeclDefinition(D);
213 m_c->HandleTagDeclRequiredDefinition(D);
217 m_c->HandleCXXImplicitFunctionInstantiation(D);
221 m_c->HandleTopLevelDeclInObjCContainer(D);
225 m_c->HandleImplicitImportDecl(D);
229 m_c->CompleteTentativeDefinition(D);
233 m_c->AssignInheritanceModel(RD);
237 m_c->HandleCXXStaticMemberVarInstantiation(D);
241 m_c->HandleVTable(RD);
245 return m_c->GetASTMutationListener();
249 return m_c->GetASTDeserializationListener();
256 m_sc->InitializeSema(S);
266 return m_c->shouldSkipFunctionBody(D);
287 llvm::SmallVector<clang::ExternalSemaSource *, 2>
Sources;
296 clang::ExternalSemaSource *low_quality_source) {
297 assert(high_quality_source);
298 assert(low_quality_source);
300 high_quality_source->Retain();
301 low_quality_source->Retain();
303 Sources.push_back(high_quality_source);
304 Sources.push_back(low_quality_source);
314 for (
size_t i = 0; i <
Sources.size(); ++i)
321 bool OnlyPartial)
override {
322 bool newDeclFound =
false;
323 for (
size_t i = 0; i <
Sources.size(); ++i)
329 const clang::Decl *D,
330 llvm::ArrayRef<clang::TemplateArgument> TemplateArgs)
override {
331 bool newDeclFound =
false;
332 for (
size_t i = 0; i <
Sources.size(); ++i)
338 for (
size_t i = 0; i <
Sources.size(); ++i)
344 for (
size_t i = 0; i <
Sources.size(); ++i) {
345 Sel =
Sources[i]->GetExternalSelector(
ID);
353 for (
size_t i = 0; i <
Sources.size(); ++i)
360 for (
size_t i = 0; i <
Sources.size(); ++i)
366 clang::CXXBaseSpecifier *
368 for (
size_t i = 0; i <
Sources.size(); ++i)
369 if (clang::CXXBaseSpecifier *R =
375 clang::CXXCtorInitializer **
378 if (
auto *R = S->GetExternalCXXCtorInitializers(Offset))
385 if (
auto EK = S->hasExternalDefinitions(D))
386 if (EK != EK_ReplyHazy)
392 const clang::DeclContext *DC, clang::DeclarationName Name,
393 const clang::DeclContext *OriginalDC)
override {
394 for (
size_t i = 0; i <
Sources.size(); ++i)
402 for (
size_t i = 0; i <
Sources.size(); ++i)
407 const clang::DeclContext *DC,
408 llvm::function_ref<
bool(clang::Decl::Kind)> IsKindWeWant,
410 for (
size_t i = 0; i <
Sources.size(); ++i) {
411 Sources[i]->FindExternalLexicalDecls(DC, IsKindWeWant, Result);
420 for (
size_t i = 0; i <
Sources.size(); ++i)
425 for (clang::ExternalSemaSource *S :
Sources) {
426 S->CompleteType(Tag);
428 if (Tag->isCompleteDefinition())
434 for (
size_t i = 0; i <
Sources.size(); ++i)
439 for (
size_t i = 0; i <
Sources.size(); ++i)
444 for (
size_t i = 0; i <
Sources.size(); ++i)
449 for (
size_t i = 0; i <
Sources.size(); ++i)
454 for (
size_t i = 0; i <
Sources.size(); ++i)
461 for (
size_t i = 0; i <
Sources.size(); ++i)
468 const clang::RecordDecl *Record, uint64_t &Size, uint64_t &Alignment,
469 llvm::DenseMap<const clang::FieldDecl *, uint64_t> &FieldOffsets,
470 llvm::DenseMap<const clang::CXXRecordDecl *, clang::CharUnits>
472 llvm::DenseMap<const clang::CXXRecordDecl *, clang::CharUnits>
473 &VirtualBaseOffsets)
override {
474 for (
size_t i = 0; i <
Sources.size(); ++i)
476 BaseOffsets, VirtualBaseOffsets))
483 Source->getMemoryBufferSizes(sizes);
492 Source->InitializeSema(S);
502 Source->ReadMethodPool(Sel);
507 Source->updateOutOfDateSelector(Sel);
513 Source->ReadKnownNamespaces(Namespaces);
517 llvm::MapVector<clang::NamedDecl *, clang::SourceLocation> &Undefined)
520 Source->ReadUndefinedButUsed(Undefined);
524 llvm::MapVector<clang::FieldDecl *,
525 llvm::SmallVector<std::pair<clang::SourceLocation, bool>,
526 4>> &Exprs)
override {
528 Source->ReadMismatchingDeleteExpressions(Exprs);
533 Source->LookupUnqualified(R, S);
544 Source->ReadTentativeDefinitions(Defs);
550 Source->ReadUnusedFileScopedDecls(Decls);
556 Source->ReadDelegatingConstructors(Decls);
562 Source->ReadExtVectorDecls(Decls);
566 llvm::SmallSetVector<const clang::TypedefNameDecl *, 4> &Decls)
override {
568 Source->ReadUnusedLocalTypedefNameCandidates(Decls);
575 Source->ReadReferencedSelectors(Sels);
582 Source->ReadWeakUndeclaredIdentifiers(WI);
588 Source->ReadUsedVTables(VTables);
593 std::pair<clang::ValueDecl *, clang::SourceLocation>> &Pending)
596 Source->ReadPendingInstantiations(Pending);
600 llvm::MapVector<
const clang::FunctionDecl *,
601 std::unique_ptr<clang::LateParsedTemplate>> &LPTMap)
604 Source->ReadLateParsedTemplates(LPTMap);
607 clang::TypoCorrection
608 CorrectTypo(
const clang::DeclarationNameInfo &Typo,
int LookupKind,
609 clang::Scope *S, clang::CXXScopeSpec *SS,
610 clang::CorrectionCandidateCallback &CCC,
611 clang::DeclContext *MemberContext,
bool EnteringContext,
612 const clang::ObjCObjectPointerType *OPT)
override {
614 if (clang::TypoCorrection C =
615 Source->CorrectTypo(Typo, LookupKind, S, SS, CCC,
616 MemberContext, EnteringContext, OPT))
619 return clang::TypoCorrection();
623 clang::QualType T)
override {
625 if (
Source->MaybeDiagnoseMissingCompleteType(Loc, T))
Wraps an ASTConsumer into an SemaConsumer.
void HandleTranslationUnit(clang::ASTContext &Ctx) override
void PrintStats() override
void HandleInlineFunctionDefinition(clang::FunctionDecl *D) override
void InitializeSema(clang::Sema &S) override
void HandleInterestingDecl(clang::DeclGroupRef D) override
ASTConsumerForwarder(clang::ASTConsumer *c)
bool shouldSkipFunctionBody(clang::Decl *D) override
void HandleTagDeclDefinition(clang::TagDecl *D) override
void AssignInheritanceModel(clang::CXXRecordDecl *RD) override
~ASTConsumerForwarder() override
clang::SemaConsumer * m_sc
void HandleTopLevelDeclInObjCContainer(clang::DeclGroupRef D) override
clang::ASTDeserializationListener * GetASTDeserializationListener() override
void ForgetSema() override
Inform the semantic consumer that Sema is no longer available.
bool HandleTopLevelDecl(clang::DeclGroupRef D) override
void HandleCXXImplicitFunctionInstantiation(clang::FunctionDecl *D) override
void CompleteTentativeDefinition(clang::VarDecl *D) override
void HandleTagDeclRequiredDefinition(const clang::TagDecl *D) override
void HandleVTable(clang::CXXRecordDecl *RD) override
void HandleCXXStaticMemberVarInstantiation(clang::VarDecl *D) override
void Initialize(clang::ASTContext &Context) override
void HandleImplicitImportDecl(clang::ImportDecl *D) override
clang::ASTMutationListener * GetASTMutationListener() override
Wraps an ExternalASTSource into an ExternalSemaSource.
std::optional< clang::ASTSourceDescriptor > getSourceDescriptor(unsigned ID) override
~ExternalASTSourceWrapper() override
void ReadUndefinedButUsed(llvm::MapVector< clang::NamedDecl *, clang::SourceLocation > &Undefined) override
This gets called when Sema is reconciling undefined but used decls.
clang::Module * getModule(unsigned ID) override
clang::Selector GetExternalSelector(uint32_t ID) override
ExtKind hasExternalDefinitions(const clang::Decl *D) override
void StartedDeserializing() override
clang::Stmt * GetExternalDeclStmt(uint64_t Offset) override
void completeVisibleDeclsMap(const clang::DeclContext *DC) override
llvm::IntrusiveRefCntPtr< ExternalASTSource > m_Source
ExternalASTSourceWrapper(ExternalASTSource *Source)
void FinishedDeserializing() override
void FindFileRegionDecls(clang::FileID File, unsigned Offset, unsigned Length, llvm::SmallVectorImpl< clang::Decl * > &Decls) override
bool FindExternalVisibleDeclsByName(const clang::DeclContext *DC, clang::DeclarationName Name, const clang::DeclContext *OriginalDC) override
void CompleteType(clang::ObjCInterfaceDecl *Class) override
void PrintStats() override
clang::Decl * GetExternalDecl(clang::GlobalDeclID ID) override
uint32_t GetNumExternalSelectors() override
void FindExternalLexicalDecls(const clang::DeclContext *DC, llvm::function_ref< bool(clang::Decl::Kind)> IsKindWeWant, llvm::SmallVectorImpl< clang::Decl * > &Result) override
clang::CXXBaseSpecifier * GetExternalCXXBaseSpecifiers(uint64_t Offset) override
void ReadComments() override
void StartTranslationUnit(clang::ASTConsumer *Consumer) override
bool LoadExternalSpecializations(const clang::Decl *D, bool OnlyPartial) override
void CompleteRedeclChain(const clang::Decl *D) override
clang::CXXCtorInitializer ** GetExternalCXXCtorInitializers(uint64_t Offset) override
bool LoadExternalSpecializations(const clang::Decl *D, llvm::ArrayRef< clang::TemplateArgument > TemplateArgs) override
void updateOutOfDateIdentifier(const clang::IdentifierInfo &II) override
bool layoutRecordType(const clang::RecordDecl *Record, uint64_t &Size, uint64_t &Alignment, llvm::DenseMap< const clang::FieldDecl *, uint64_t > &FieldOffsets, llvm::DenseMap< const clang::CXXRecordDecl *, clang::CharUnits > &BaseOffsets, llvm::DenseMap< const clang::CXXRecordDecl *, clang::CharUnits > &VirtualBaseOffsets) override
void CompleteType(clang::TagDecl *Tag) override
An abstract base class for files.
A ExternalSemaSource multiplexer that prioritizes its sources.
void ReadUndefinedButUsed(llvm::MapVector< clang::NamedDecl *, clang::SourceLocation > &Undefined) override
void ReadKnownNamespaces(llvm::SmallVectorImpl< clang::NamespaceDecl * > &Namespaces) override
void ReadExtVectorDecls(llvm::SmallVectorImpl< clang::TypedefNameDecl * > &Decls) override
uint32_t GetNumExternalSelectors() override
bool MaybeDiagnoseMissingCompleteType(clang::SourceLocation Loc, clang::QualType T) override
void ReadUnusedLocalTypedefNameCandidates(llvm::SmallSetVector< const clang::TypedefNameDecl *, 4 > &Decls) override
clang::Selector GetExternalSelector(uint32_t ID) override
void StartedDeserializing() override
clang::Module * getModule(unsigned ID) override
void FindExternalLexicalDecls(const clang::DeclContext *DC, llvm::function_ref< bool(clang::Decl::Kind)> IsKindWeWant, llvm::SmallVectorImpl< clang::Decl * > &Result) override
bool FindExternalVisibleDeclsByName(const clang::DeclContext *DC, clang::DeclarationName Name, const clang::DeclContext *OriginalDC) override
void FinishedDeserializing() override
void ReadUsedVTables(llvm::SmallVectorImpl< clang::ExternalVTableUse > &VTables) override
clang::TypoCorrection CorrectTypo(const clang::DeclarationNameInfo &Typo, int LookupKind, clang::Scope *S, clang::CXXScopeSpec *SS, clang::CorrectionCandidateCallback &CCC, clang::DeclContext *MemberContext, bool EnteringContext, const clang::ObjCObjectPointerType *OPT) override
SemaSourceWithPriorities(clang::ExternalSemaSource *high_quality_source, clang::ExternalSemaSource *low_quality_source)
Construct a SemaSourceWithPriorities with a 'high quality' source that has the higher priority and a ...
bool LoadExternalSpecializations(const clang::Decl *D, llvm::ArrayRef< clang::TemplateArgument > TemplateArgs) override
void CompleteRedeclChain(const clang::Decl *D) override
clang::Stmt * GetExternalDeclStmt(uint64_t Offset) override
void getMemoryBufferSizes(MemoryBufferSizes &sizes) const override
clang::Decl * GetExternalDecl(clang::GlobalDeclID ID) override
void StartTranslationUnit(clang::ASTConsumer *Consumer) override
clang::CXXCtorInitializer ** GetExternalCXXCtorInitializers(uint64_t Offset) override
void ReadTentativeDefinitions(llvm::SmallVectorImpl< clang::VarDecl * > &Defs) override
void ReadReferencedSelectors(llvm::SmallVectorImpl< std::pair< clang::Selector, clang::SourceLocation > > &Sels) override
void ReadLateParsedTemplates(llvm::MapVector< const clang::FunctionDecl *, std::unique_ptr< clang::LateParsedTemplate > > &LPTMap) override
bool layoutRecordType(const clang::RecordDecl *Record, uint64_t &Size, uint64_t &Alignment, llvm::DenseMap< const clang::FieldDecl *, uint64_t > &FieldOffsets, llvm::DenseMap< const clang::CXXRecordDecl *, clang::CharUnits > &BaseOffsets, llvm::DenseMap< const clang::CXXRecordDecl *, clang::CharUnits > &VirtualBaseOffsets) override
void ReadMethodPool(clang::Selector Sel) override
clang::CXXBaseSpecifier * GetExternalCXXBaseSpecifiers(uint64_t Offset) override
void PrintStats() override
void CompleteType(clang::TagDecl *Tag) override
void ForgetSema() override
llvm::SmallVector< clang::ExternalSemaSource *, 2 > Sources
The sources ordered in decreasing priority.
void FindFileRegionDecls(clang::FileID File, unsigned Offset, unsigned Length, llvm::SmallVectorImpl< clang::Decl * > &Decls) override
bool LoadExternalSpecializations(const clang::Decl *D, bool OnlyPartial) override
void ReadUnusedFileScopedDecls(llvm::SmallVectorImpl< const clang::DeclaratorDecl * > &Decls) override
void CompleteType(clang::ObjCInterfaceDecl *Class) override
void completeVisibleDeclsMap(const clang::DeclContext *DC) override
void ReadPendingInstantiations(llvm::SmallVectorImpl< std::pair< clang::ValueDecl *, clang::SourceLocation > > &Pending) override
void ReadDelegatingConstructors(llvm::SmallVectorImpl< clang::CXXConstructorDecl * > &Decls) override
bool LookupUnqualified(clang::LookupResult &R, clang::Scope *S) override
void updateOutOfDateSelector(clang::Selector Sel) override
void ReadComments() override
void ReadWeakUndeclaredIdentifiers(llvm::SmallVectorImpl< std::pair< clang::IdentifierInfo *, clang::WeakInfo > > &WI) override
void ReadMismatchingDeleteExpressions(llvm::MapVector< clang::FieldDecl *, llvm::SmallVector< std::pair< clang::SourceLocation, bool >, 4 > > &Exprs) override
ExtKind hasExternalDefinitions(const clang::Decl *D) override
~SemaSourceWithPriorities() override
void InitializeSema(clang::Sema &S) override
A class that represents a running process on the host machine.