diff options
author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2009-07-29 23:39:52 +0000 |
---|---|---|
committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2009-07-29 23:39:52 +0000 |
commit | 52f1d4793588af6c5c09ab096818ff942bae3af6 (patch) | |
tree | 6b96038d9e89db1e8c40afb752aea9f16a4b430c /lib/Index/Indexer.cpp | |
parent | e380c51d6f56a2cc32fa0f5723584224214c5b9f (diff) |
Modify the Indexer class so that it can return the TranslationUnit that internal
decls originated from.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@77534 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Index/Indexer.cpp')
-rw-r--r-- | lib/Index/Indexer.cpp | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/lib/Index/Indexer.cpp b/lib/Index/Indexer.cpp index 08e367a279..ddc22f7fbc 100644 --- a/lib/Index/Indexer.cpp +++ b/lib/Index/Indexer.cpp @@ -16,6 +16,7 @@ #include "clang/Index/Entity.h" #include "clang/Index/Handlers.h" #include "clang/Index/TranslationUnit.h" +#include "clang/AST/DeclBase.h" using namespace clang; using namespace idx; @@ -39,6 +40,7 @@ public: void Indexer::IndexAST(TranslationUnit *TU) { assert(TU && "Passed null TranslationUnit"); + CtxTUMap[&TU->getASTContext()] = TU; EntityIndexer Idx(TU, Map); Prog.FindEntities(TU->getASTContext(), Idx); } @@ -46,8 +48,14 @@ void Indexer::IndexAST(TranslationUnit *TU) { void Indexer::GetTranslationUnitsFor(Entity Ent, TranslationUnitHandler &Handler) { assert(Ent.isValid() && "Expected valid Entity"); - assert(!Ent.isInternalToTU() && - "Expected an Entity visible outside of its translation unit"); + + if (Ent.isInternalToTU()) { + Decl *D = Ent.getInternalDecl(); + CtxTUMapTy::iterator I = CtxTUMap.find(&D->getASTContext()); + if (I != CtxTUMap.end()) + Handler.Handle(I->second); + return; + } MapTy::iterator I = Map.find(Ent); if (I == Map.end()) |