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 clang::DeclarationName Name)
override {
75 return m_Source->FindExternalVisibleDeclsByName(DC, Name);
79 bool OnlyPartial)
override {
80 return m_Source->LoadExternalSpecializations(D, OnlyPartial);
85 llvm::ArrayRef<clang::TemplateArgument> TemplateArgs)
override {
86 return m_Source->LoadExternalSpecializations(D, TemplateArgs);
90 m_Source->completeVisibleDeclsMap(DC);
97 std::optional<clang::ASTSourceDescriptor>
103 return m_Source->hasExternalDefinitions(D);
107 const clang::DeclContext *DC,
108 llvm::function_ref<
bool(clang::Decl::Kind)> IsKindWeWant,
110 m_Source->FindExternalLexicalDecls(DC, IsKindWeWant, Result);
116 m_Source->FindFileRegionDecls(
File, Offset, Length, Decls);
138 m_Source->StartTranslationUnit(Consumer);
144 const clang::RecordDecl *Record, uint64_t &Size, uint64_t &Alignment,
145 llvm::DenseMap<const clang::FieldDecl *, uint64_t> &FieldOffsets,
146 llvm::DenseMap<const clang::CXXRecordDecl *, clang::CharUnits>
148 llvm::DenseMap<const clang::CXXRecordDecl *, clang::CharUnits>
149 &VirtualBaseOffsets)
override {
150 return m_Source->layoutRecordType(Record, Size, Alignment, FieldOffsets,
151 BaseOffsets, VirtualBaseOffsets);
164 llvm::MapVector<clang::NamedDecl *, clang::SourceLocation> &Undefined)
166 Undefined.remove_if([](
auto const &decl_loc_pair) {
167 const clang::NamedDecl *ND = decl_loc_pair.first;
168 return llvm::isa_and_present<clang::FunctionDecl>(ND);
182 m_sc = llvm::dyn_cast<clang::SemaConsumer>(
m_c);
188 m_c->Initialize(Context);
192 return m_c->HandleTopLevelDecl(D);
196 m_c->HandleInlineFunctionDefinition(D);
200 m_c->HandleInterestingDecl(D);
204 m_c->HandleTranslationUnit(Ctx);
208 m_c->HandleTagDeclDefinition(D);
212 m_c->HandleTagDeclRequiredDefinition(D);
216 m_c->HandleCXXImplicitFunctionInstantiation(D);
220 m_c->HandleTopLevelDeclInObjCContainer(D);
224 m_c->HandleImplicitImportDecl(D);
228 m_c->CompleteTentativeDefinition(D);
232 m_c->AssignInheritanceModel(RD);
236 m_c->HandleCXXStaticMemberVarInstantiation(D);
240 m_c->HandleVTable(RD);
244 return m_c->GetASTMutationListener();
248 return m_c->GetASTDeserializationListener();
255 m_sc->InitializeSema(S);
265 return m_c->shouldSkipFunctionBody(D);
286 llvm::SmallVector<clang::ExternalSemaSource *, 2>
Sources;
295 clang::ExternalSemaSource *low_quality_source) {
296 assert(high_quality_source);
297 assert(low_quality_source);
299 high_quality_source->Retain();
300 low_quality_source->Retain();
302 Sources.push_back(high_quality_source);
303 Sources.push_back(low_quality_source);
313 for (
size_t i = 0; i <
Sources.size(); ++i)
320 bool OnlyPartial)
override {
321 bool newDeclFound =
false;
322 for (
size_t i = 0; i <
Sources.size(); ++i)
328 const clang::Decl *D,
329 llvm::ArrayRef<clang::TemplateArgument> TemplateArgs)
override {
330 bool newDeclFound =
false;
331 for (
size_t i = 0; i <
Sources.size(); ++i)
337 for (
size_t i = 0; i <
Sources.size(); ++i)
343 for (
size_t i = 0; i <
Sources.size(); ++i) {
344 Sel =
Sources[i]->GetExternalSelector(
ID);
352 for (
size_t i = 0; i <
Sources.size(); ++i)
359 for (
size_t i = 0; i <
Sources.size(); ++i)
365 clang::CXXBaseSpecifier *
367 for (
size_t i = 0; i <
Sources.size(); ++i)
368 if (clang::CXXBaseSpecifier *R =
374 clang::CXXCtorInitializer **
377 if (
auto *R = S->GetExternalCXXCtorInitializers(Offset))
384 if (
auto EK = S->hasExternalDefinitions(D))
385 if (EK != EK_ReplyHazy)
391 clang::DeclarationName Name)
override {
392 for (
size_t i = 0; i <
Sources.size(); ++i)
400 for (
size_t i = 0; i <
Sources.size(); ++i)
405 const clang::DeclContext *DC,
406 llvm::function_ref<
bool(clang::Decl::Kind)> IsKindWeWant,
408 for (
size_t i = 0; i <
Sources.size(); ++i) {
409 Sources[i]->FindExternalLexicalDecls(DC, IsKindWeWant, Result);
418 for (
size_t i = 0; i <
Sources.size(); ++i)
423 for (clang::ExternalSemaSource *S :
Sources) {
424 S->CompleteType(Tag);
426 if (Tag->isCompleteDefinition())
432 for (
size_t i = 0; i <
Sources.size(); ++i)
437 for (
size_t i = 0; i <
Sources.size(); ++i)
442 for (
size_t i = 0; i <
Sources.size(); ++i)
447 for (
size_t i = 0; i <
Sources.size(); ++i)
452 for (
size_t i = 0; i <
Sources.size(); ++i)
459 for (
size_t i = 0; i <
Sources.size(); ++i)
466 const clang::RecordDecl *Record, uint64_t &Size, uint64_t &Alignment,
467 llvm::DenseMap<const clang::FieldDecl *, uint64_t> &FieldOffsets,
468 llvm::DenseMap<const clang::CXXRecordDecl *, clang::CharUnits>
470 llvm::DenseMap<const clang::CXXRecordDecl *, clang::CharUnits>
471 &VirtualBaseOffsets)
override {
472 for (
size_t i = 0; i <
Sources.size(); ++i)
474 BaseOffsets, VirtualBaseOffsets))
481 Source->getMemoryBufferSizes(sizes);
490 Source->InitializeSema(S);
500 Source->ReadMethodPool(Sel);
505 Source->updateOutOfDateSelector(Sel);
511 Source->ReadKnownNamespaces(Namespaces);
515 llvm::MapVector<clang::NamedDecl *, clang::SourceLocation> &Undefined)
518 Source->ReadUndefinedButUsed(Undefined);
522 llvm::MapVector<clang::FieldDecl *,
523 llvm::SmallVector<std::pair<clang::SourceLocation, bool>,
524 4>> &Exprs)
override {
526 Source->ReadMismatchingDeleteExpressions(Exprs);
531 Source->LookupUnqualified(R, S);
542 Source->ReadTentativeDefinitions(Defs);
548 Source->ReadUnusedFileScopedDecls(Decls);
554 Source->ReadDelegatingConstructors(Decls);
560 Source->ReadExtVectorDecls(Decls);
564 llvm::SmallSetVector<const clang::TypedefNameDecl *, 4> &Decls)
override {
566 Source->ReadUnusedLocalTypedefNameCandidates(Decls);
573 Source->ReadReferencedSelectors(Sels);
580 Source->ReadWeakUndeclaredIdentifiers(WI);
586 Source->ReadUsedVTables(VTables);
591 std::pair<clang::ValueDecl *, clang::SourceLocation>> &Pending)
594 Source->ReadPendingInstantiations(Pending);
598 llvm::MapVector<
const clang::FunctionDecl *,
599 std::unique_ptr<clang::LateParsedTemplate>> &LPTMap)
602 Source->ReadLateParsedTemplates(LPTMap);
605 clang::TypoCorrection
606 CorrectTypo(
const clang::DeclarationNameInfo &Typo,
int LookupKind,
607 clang::Scope *S, clang::CXXScopeSpec *SS,
608 clang::CorrectionCandidateCallback &CCC,
609 clang::DeclContext *MemberContext,
bool EnteringContext,
610 const clang::ObjCObjectPointerType *OPT)
override {
612 if (clang::TypoCorrection C =
613 Source->CorrectTypo(Typo, LookupKind, S, SS, CCC,
614 MemberContext, EnteringContext, OPT))
617 return clang::TypoCorrection();
621 clang::QualType T)
override {
623 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
bool FindExternalVisibleDeclsByName(const clang::DeclContext *DC, clang::DeclarationName Name) override
void FindFileRegionDecls(clang::FileID File, unsigned Offset, unsigned Length, llvm::SmallVectorImpl< clang::Decl * > &Decls) 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
void FinishedDeserializing() override
bool FindExternalVisibleDeclsByName(const clang::DeclContext *DC, clang::DeclarationName Name) 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.