clang
7.0.0
|
Imports selected nodes from one AST context into another context, merging AST nodes where appropriate. More...
#include "clang/AST/ASTImporter.h"
Public Types | |
using | NonEquivalentDeclSet = llvm::DenseSet< std::pair< Decl *, Decl * > > |
using | ImportedCXXBaseSpecifierMap = llvm::DenseMap< const CXXBaseSpecifier *, CXXBaseSpecifier * > |
Public Member Functions | |
ASTImporter (ASTContext &ToContext, FileManager &ToFileManager, ASTContext &FromContext, FileManager &FromFileManager, bool MinimalImport) | |
Create a new AST importer. More... | |
virtual | ~ASTImporter () |
bool | isMinimalImport () const |
Whether the importer will perform a minimal import, creating to-be-completed forward declarations when possible. More... | |
QualType | Import (QualType FromT) |
Import the given type from the "from" context into the "to" context. More... | |
TypeSourceInfo * | Import (TypeSourceInfo *FromTSI) |
Import the given type source information from the "from" context into the "to" context. More... | |
Attr * | Import (const Attr *FromAttr) |
Import the given attribute from the "from" context into the "to" context. More... | |
Decl * | Import (Decl *FromD) |
Import the given declaration from the "from" context into the "to" context. More... | |
Decl * | Import (const Decl *FromD) |
Decl * | GetAlreadyImportedOrNull (Decl *FromD) |
Return the copy of the given declaration in the "to" context if it has already been imported from the "from" context. More... | |
DeclContext * | ImportContext (DeclContext *FromDC) |
Import the given declaration context from the "from" AST context into the "to" AST context. More... | |
Expr * | Import (Expr *FromE) |
Import the given expression from the "from" context into the "to" context. More... | |
Stmt * | Import (Stmt *FromS) |
Import the given statement from the "from" context into the "to" context. More... | |
NestedNameSpecifier * | Import (NestedNameSpecifier *FromNNS) |
Import the given nested-name-specifier from the "from" context into the "to" context. More... | |
NestedNameSpecifierLoc | Import (NestedNameSpecifierLoc FromNNS) |
Import the given nested-name-specifier from the "from" context into the "to" context. More... | |
TemplateName | Import (TemplateName From) |
Import the goven template name from the "from" context into the "to" context. More... | |
SourceLocation | Import (SourceLocation FromLoc) |
Import the given source location from the "from" context into the "to" context. More... | |
SourceRange | Import (SourceRange FromRange) |
Import the given source range from the "from" context into the "to" context. More... | |
DeclarationName | Import (DeclarationName FromName) |
Import the given declaration name from the "from" context into the "to" context. More... | |
IdentifierInfo * | Import (const IdentifierInfo *FromId) |
Import the given identifier from the "from" context into the "to" context. More... | |
Selector | Import (Selector FromSel) |
Import the given Objective-C selector from the "from" context into the "to" context. More... | |
FileID | Import (FileID) |
Import the given file ID from the "from" context into the "to" context. More... | |
CXXCtorInitializer * | Import (CXXCtorInitializer *FromInit) |
Import the given C++ constructor initializer from the "from" context into the "to" context. More... | |
CXXBaseSpecifier * | Import (const CXXBaseSpecifier *FromSpec) |
Import the given CXXBaseSpecifier from the "from" context into the "to" context. More... | |
void | ImportDefinition (Decl *From) |
Import the definition of the given declaration, including all of the declarations it contains. More... | |
virtual DeclarationName | HandleNameConflict (DeclarationName Name, DeclContext *DC, unsigned IDNS, NamedDecl **Decls, unsigned NumDecls) |
Cope with a name conflict when importing a declaration into the given context. More... | |
ASTContext & | getToContext () const |
Retrieve the context that AST nodes are being imported into. More... | |
ASTContext & | getFromContext () const |
Retrieve the context that AST nodes are being imported from. More... | |
FileManager & | getToFileManager () const |
Retrieve the file manager that AST nodes are being imported into. More... | |
FileManager & | getFromFileManager () const |
Retrieve the file manager that AST nodes are being imported from. More... | |
DiagnosticBuilder | ToDiag (SourceLocation Loc, unsigned DiagID) |
Report a diagnostic in the "to" context. More... | |
DiagnosticBuilder | FromDiag (SourceLocation Loc, unsigned DiagID) |
Report a diagnostic in the "from" context. More... | |
NonEquivalentDeclSet & | getNonEquivalentDecls () |
Return the set of declarations that we know are not equivalent. More... | |
virtual void | CompleteDecl (Decl *D) |
Called for ObjCInterfaceDecl, ObjCProtocolDecl, and TagDecl. More... | |
virtual Decl * | Imported (Decl *From, Decl *To) |
Subclasses can override this function to observe all of the From -> To declaration mappings as they are imported. More... | |
Decl * | MapImported (Decl *From, Decl *To) |
Store and assign the imported declaration to its counterpart. More... | |
virtual Decl * | GetOriginalDecl (Decl *To) |
Called by StructuralEquivalenceContext. More... | |
bool | IsStructurallyEquivalent (QualType From, QualType To, bool Complain=true) |
Determine whether the given types are structurally equivalent. More... | |
Imports selected nodes from one AST context into another context, merging AST nodes where appropriate.
Definition at line 57 of file ASTImporter.h.
using clang::ASTImporter::ImportedCXXBaseSpecifierMap = llvm::DenseMap<const CXXBaseSpecifier *, CXXBaseSpecifier *> |
Definition at line 61 of file ASTImporter.h.
using clang::ASTImporter::NonEquivalentDeclSet = llvm::DenseSet<std::pair<Decl *, Decl *> > |
Definition at line 59 of file ASTImporter.h.
ASTImporter::ASTImporter | ( | ASTContext & | ToContext, |
FileManager & | ToFileManager, | ||
ASTContext & | FromContext, | ||
FileManager & | FromFileManager, | ||
bool | MinimalImport | ||
) |
Create a new AST importer.
ToContext | The context we'll be importing into. |
ToFileManager | The file manager we'll be importing into. |
FromContext | The context we'll be importing from. |
FromFileManager | The file manager we'll be importing into. |
MinimalImport | If true, the importer will attempt to import as little as it can, e.g., by importing declarations as forward declarations that can be completed at a later point. |
Definition at line 6929 of file ASTImporter.cpp.
References clang::ASTContext::getTranslationUnitDecl(), and ~ASTImporter().
|
virtualdefault |
Referenced by ASTImporter().
|
virtual |
Called for ObjCInterfaceDecl, ObjCProtocolDecl, and TagDecl.
Mark the Decl as complete, filling it in as much as possible.
D | A declaration in the "to" context. |
Definition at line 7606 of file ASTImporter.cpp.
Referenced by getNonEquivalentDecls(), and ImportContext().
DiagnosticBuilder ASTImporter::FromDiag | ( | SourceLocation | Loc, |
unsigned | DiagID | ||
) |
Report a diagnostic in the "from" context.
Definition at line 7598 of file ASTImporter.cpp.
References clang::ASTContext::getDiagnostics(), clang::DiagnosticsEngine::notePriorDiagnosticFrom(), and clang::DiagnosticsEngine::Report().
Referenced by getFromFileManager().
Return the copy of the given declaration in the "to" context if it has already been imported from the "from" context.
Otherwise return NULL.
Definition at line 6985 of file ASTImporter.cpp.
References clang::ASTNodeImporter::ImportDefinitionIfNeeded().
Referenced by Import().
|
inline |
Retrieve the context that AST nodes are being imported from.
Definition at line 294 of file ASTImporter.h.
|
inline |
Retrieve the file manager that AST nodes are being imported from.
Definition at line 300 of file ASTImporter.h.
References FromDiag(), and ToDiag().
|
inline |
Return the set of declarations that we know are not equivalent.
Definition at line 309 of file ASTImporter.h.
References CompleteDecl().
Called by StructuralEquivalenceContext.
If a RecordDecl is being compared to another RecordDecl as part of import, completing the other RecordDecl may trigger importation of the first RecordDecl. This happens especially for anonymous structs. If the original of the second RecordDecl can be found, we can complete it without the need for importation, eliminating this loop.
Definition at line 330 of file ASTImporter.h.
References IsStructurallyEquivalent().
|
inline |
Retrieve the context that AST nodes are being imported into.
Definition at line 291 of file ASTImporter.h.
|
inline |
Retrieve the file manager that AST nodes are being imported into.
Definition at line 297 of file ASTImporter.h.
|
virtual |
Cope with a name conflict when importing a declaration into the given context.
This routine is invoked whenever there is a name conflict while importing a declaration. The returned name will become the name of the imported declaration. By default, the returned name is the same as the original name, leaving the conflict unresolve such that name lookup for this name is likely to find an ambiguity later.
Subclasses may override this routine to resolve the conflict, e.g., by renaming the declaration being imported.
Name | the name of the declaration being imported, which conflicts with other declarations. |
DC | the declaration context (in the "to" AST context) in which the name is being imported. |
IDNS | the identifier namespace in which the name will be found. |
Decls | the set of declarations with the same name as the declaration being imported. |
NumDecls | the number of conflicting declarations in Decls . |
Definition at line 7582 of file ASTImporter.cpp.
Referenced by Import().
Import the given type from the "from" context into the "to" context.
Definition at line 6941 of file ASTImporter.cpp.
References clang::QualType::getLocalQualifiers(), clang::ASTContext::getQualifiedType(), clang::QualType::getTypePtr(), clang::QualType::isNull(), and clang::TypeVisitor< ImplClass, RetTy >::Visit().
Referenced by clang::ExternalASTMerger::FindExternalLexicalDecls(), clang::ExternalASTMerger::FindExternalVisibleDeclsByName(), Import(), clang::ASTNodeImporter::ImportArray(), clang::ASTNodeImporter::ImportArrayChecked(), ImportContext(), clang::cross_tu::CrossTranslationUnitContext::importDefinition(), ImportDefinition(), importSpecializations(), isMinimalImport(), IsStructurallyEquivalent(), and setTypedefNameForAnonDecl().
TypeSourceInfo * ASTImporter::Import | ( | TypeSourceInfo * | FromTSI | ) |
Import the given type source information from the "from" context into the "to" context.
Definition at line 6965 of file ASTImporter.cpp.
References clang::TypeLoc::getLocStart(), clang::ASTContext::getTrivialTypeSourceInfo(), clang::TypeSourceInfo::getType(), clang::TypeSourceInfo::getTypeLoc(), Import(), and clang::QualType::isNull().
Import the given attribute from the "from" context into the "to" context.
Definition at line 6979 of file ASTImporter.cpp.
References clang::Attr::clone(), clang::Attr::getRange(), Import(), and clang::Attr::setRange().
Import the given declaration from the "from" context into the "to" context.
Definition at line 6997 of file ASTImporter.cpp.
References GetAlreadyImportedOrNull(), Imported(), clang::updateFlags(), and clang::TypeVisitor< ImplClass, RetTy >::Visit().
Definition at line 151 of file ASTImporter.h.
References GetAlreadyImportedOrNull(), HandleNameConflict(), Import(), ImportContext(), and ImportDefinition().
Import the given expression from the "from" context into the "to" context.
Definition at line 7077 of file ASTImporter.cpp.
References Import().
Import the given statement from the "from" context into the "to" context.
Definition at line 7084 of file ASTImporter.cpp.
NestedNameSpecifier * ASTImporter::Import | ( | NestedNameSpecifier * | FromNNS | ) |
Import the given nested-name-specifier from the "from" context into the "to" context.
Definition at line 7104 of file ASTImporter.cpp.
References clang::NestedNameSpecifier::Create(), clang::NestedNameSpecifier::getAsIdentifier(), clang::NestedNameSpecifier::getAsNamespace(), clang::NestedNameSpecifier::getAsNamespaceAlias(), clang::NestedNameSpecifier::getAsRecordDecl(), clang::NestedNameSpecifier::getAsType(), clang::NestedNameSpecifier::getKind(), clang::NestedNameSpecifier::getPrefix(), clang::QualType::getTypePtr(), clang::NestedNameSpecifier::Global, clang::NestedNameSpecifier::GlobalSpecifier(), clang::NestedNameSpecifier::Identifier, Import(), clang::QualType::isNull(), clang::NestedNameSpecifier::Namespace, clang::NestedNameSpecifier::NamespaceAlias, clang::NestedNameSpecifier::Super, clang::NestedNameSpecifier::SuperSpecifier(), clang::NestedNameSpecifier::TypeSpec, and clang::NestedNameSpecifier::TypeSpecWithTemplate.
NestedNameSpecifierLoc ASTImporter::Import | ( | NestedNameSpecifierLoc | FromNNS | ) |
Import the given nested-name-specifier from the "from" context into the "to" context.
Definition at line 7157 of file ASTImporter.cpp.
References clang::NestedNameSpecifierLoc::getPrefix().
TemplateName ASTImporter::Import | ( | TemplateName | From | ) |
Import the goven template name from the "from" context into the "to" context.
Definition at line 7228 of file ASTImporter.cpp.
References clang::TemplateName::getAsOverloadedTemplate(), clang::TemplateName::getAsTemplateDecl(), clang::TemplateName::getKind(), Import(), clang::TemplateName::OverloadedTemplate, and clang::TemplateName::Template.
SourceLocation ASTImporter::Import | ( | SourceLocation | FromLoc | ) |
Import the given source location from the "from" context into the "to" context.
Definition at line 7316 of file ASTImporter.cpp.
References clang::SourceManager::getComposedLoc(), clang::SourceManager::getDecomposedLoc(), clang::ASTContext::getSourceManager(), Import(), clang::FileID::isInvalid(), and clang::SourceLocation::isInvalid().
SourceRange ASTImporter::Import | ( | SourceRange | FromRange | ) |
Import the given source range from the "from" context into the "to" context.
Definition at line 7330 of file ASTImporter.cpp.
References clang::SourceRange::getBegin(), clang::SourceRange::getEnd(), and Import().
DeclarationName ASTImporter::Import | ( | DeclarationName | FromName | ) |
Import the given declaration name from the "from" context into the "to" context.
Definition at line 7495 of file ASTImporter.cpp.
References clang::DeclarationName::CXXConstructorName, clang::DeclarationName::CXXConversionFunctionName, clang::DeclarationName::CXXDeductionGuideName, clang::DeclarationName::CXXDestructorName, clang::DeclarationName::CXXLiteralOperatorName, clang::DeclarationName::CXXOperatorName, clang::DeclarationName::CXXUsingDirective, clang::ASTContext::DeclarationNames, clang::DeclarationName::getAsIdentifierInfo(), clang::ASTContext::getCanonicalType(), clang::DeclarationNameTable::getCXXConstructorName(), clang::DeclarationNameTable::getCXXConversionFunctionName(), clang::DeclarationNameTable::getCXXDeductionGuideName(), clang::DeclarationName::getCXXDeductionGuideTemplate(), clang::DeclarationNameTable::getCXXDestructorName(), clang::DeclarationName::getCXXLiteralIdentifier(), clang::DeclarationNameTable::getCXXLiteralOperatorName(), clang::DeclarationName::getCXXNameType(), clang::DeclarationNameTable::getCXXOperatorName(), clang::DeclarationName::getCXXOverloadedOperator(), clang::DeclarationName::getNameKind(), clang::DeclarationName::getObjCSelector(), clang::DeclarationName::getUsingDirectiveName(), clang::DeclarationName::Identifier, Import(), clang::QualType::isNull(), clang::DeclarationName::ObjCMultiArgSelector, clang::DeclarationName::ObjCOneArgSelector, and clang::DeclarationName::ObjCZeroArgSelector.
IdentifierInfo * ASTImporter::Import | ( | const IdentifierInfo * | FromId | ) |
Import the given identifier from the "from" context into the "to" context.
Definition at line 7559 of file ASTImporter.cpp.
References clang::IdentifierTable::get(), clang::IdentifierInfo::getBuiltinID(), clang::IdentifierInfo::getName(), clang::ASTContext::Idents, and clang::IdentifierInfo::setBuiltinID().
Import the given Objective-C selector from the "from" context into the "to" context.
Definition at line 7571 of file ASTImporter.cpp.
References clang::Selector::getIdentifierInfoForSlot(), Import(), and clang::Selector::isNull().
Import the given file ID from the "from" context into the "to" context.
Definition at line 7334 of file ASTImporter.cpp.
References clang::SourceManager::createExpansionLoc(), clang::SourceManager::createFileID(), clang::SourceManager::createMacroArgExpansionLoc(), clang::SrcMgr::FileInfo::getContentCache(), clang::ASTContext::getDiagnostics(), clang::SrcMgr::SLocEntry::getExpansion(), clang::SrcMgr::ExpansionInfo::getExpansionLocEnd(), clang::SrcMgr::ExpansionInfo::getExpansionLocStart(), clang::FileManager::getFile(), clang::SrcMgr::SLocEntry::getFile(), clang::SrcMgr::FileInfo::getFileCharacteristic(), clang::SourceManager::getFileID(), clang::SrcMgr::FileInfo::getIncludeLoc(), clang::ASTContext::getSourceManager(), clang::SrcMgr::ExpansionInfo::getSpellingLoc(), Import(), clang::SrcMgr::SLocEntry::isExpansion(), clang::SrcMgr::ExpansionInfo::isExpansionTokenRange(), and clang::SrcMgr::ExpansionInfo::isMacroArgExpansion().
CXXCtorInitializer * ASTImporter::Import | ( | CXXCtorInitializer * | FromInit | ) |
Import the given C++ constructor initializer from the "from" context into the "to" context.
Definition at line 7391 of file ASTImporter.cpp.
References clang::CXXCtorInitializer::getEllipsisLoc(), clang::CXXCtorInitializer::getIndirectMember(), clang::CXXCtorInitializer::getInit(), clang::CXXCtorInitializer::getLParenLoc(), clang::CXXCtorInitializer::getMember(), clang::CXXCtorInitializer::getMemberLocation(), clang::CXXCtorInitializer::getRParenLoc(), clang::CXXCtorInitializer::getTypeSourceInfo(), Import(), clang::CXXCtorInitializer::isBaseInitializer(), clang::CXXCtorInitializer::isBaseVirtual(), clang::CXXCtorInitializer::isDelegatingInitializer(), clang::CXXCtorInitializer::isIndirectMemberInitializer(), clang::CXXCtorInitializer::isMemberInitializer(), and clang::CXXCtorInitializer::isPackExpansion().
CXXBaseSpecifier * ASTImporter::Import | ( | const CXXBaseSpecifier * | FromSpec | ) |
Import the given CXXBaseSpecifier from the "from" context into the "to" context.
Definition at line 7436 of file ASTImporter.cpp.
References clang::CXXBaseSpecifier::getAccessSpecifierAsWritten(), clang::CXXBaseSpecifier::getEllipsisLoc(), clang::CXXBaseSpecifier::getSourceRange(), clang::CXXBaseSpecifier::getTypeSourceInfo(), Import(), Imported(), clang::CXXBaseSpecifier::isBaseOfClass(), and clang::CXXBaseSpecifier::isVirtual().
DeclContext * ASTImporter::ImportContext | ( | DeclContext * | FromDC | ) |
Import the given declaration context from the "from" AST context into the "to" AST context.
Definition at line 7022 of file ASTImporter.cpp.
References CompleteDecl(), clang::ObjCInterfaceDecl::getDefinition(), clang::ObjCProtocolDecl::getDefinition(), clang::ASTNodeImporter::IDK_Basic, Import(), and clang::ASTNodeImporter::ImportDefinition().
Referenced by Import().
void ASTImporter::ImportDefinition | ( | Decl * | From | ) |
Import the definition of the given declaration, including all of the declarations it contains.
This routine is intended to be used
Definition at line 7451 of file ASTImporter.cpp.
References clang::ASTNodeImporter::IDK_Everything, Import(), clang::ASTNodeImporter::ImportDeclContext(), and clang::ASTNodeImporter::ImportDefinition().
Referenced by clang::ExternalASTMerger::CompleteType(), and Import().
Subclasses can override this function to observe all of the From
-> To
declaration mappings as they are imported.
Definition at line 319 of file ASTImporter.h.
References MapImported().
Referenced by Import().
|
inline |
Whether the importer will perform a minimal import, creating to-be-completed forward declarations when possible.
Definition at line 123 of file ASTImporter.h.
References Import().
Referenced by getStructuralEquivalenceKind(), and clang::ASTNodeImporter::shouldForceImportDeclContext().
Determine whether the given types are structurally equivalent.
Definition at line 7636 of file ASTImporter.cpp.
References getStructuralEquivalenceKind(), clang::QualType::getTypePtr(), clang::ASTContext::hasSameType(), Import(), and clang::StructuralEquivalenceContext::IsEquivalent().
Referenced by GetOriginalDecl().
Store and assign the imported declaration to its counterpart.
Definition at line 7626 of file ASTImporter.cpp.
Referenced by clang::ExternalASTMerger::CompleteType(), and Imported().
DiagnosticBuilder ASTImporter::ToDiag | ( | SourceLocation | Loc, |
unsigned | DiagID | ||
) |
Report a diagnostic in the "to" context.
Definition at line 7590 of file ASTImporter.cpp.
References clang::ASTContext::getDiagnostics(), clang::DiagnosticsEngine::notePriorDiagnosticFrom(), and clang::DiagnosticsEngine::Report().
Referenced by getFromFileManager().