diff options
| author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2009-07-29 23:41:18 +0000 |
|---|---|---|
| committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2009-07-29 23:41:18 +0000 |
| commit | d70a92139fe447444f977740486799291378ddac (patch) | |
| tree | fe232e5d561b4cff54743ad28f0fe6b9f99cda64 /clang | |
| parent | f7f56741e074bc96f167d339a377fe01d1c5e0f5 (diff) | |
| download | bcm5719-llvm-d70a92139fe447444f977740486799291378ddac.tar.gz bcm5719-llvm-d70a92139fe447444f977740486799291378ddac.zip | |
Index the selectors and provide the translation units that contain them
through the IndexProvider.
llvm-svn: 77543
Diffstat (limited to 'clang')
| -rw-r--r-- | clang/include/clang/Index/IndexProvider.h | 3 | ||||
| -rw-r--r-- | clang/include/clang/Index/Indexer.h | 6 | ||||
| -rw-r--r-- | clang/lib/Index/Indexer.cpp | 43 |
3 files changed, 49 insertions, 3 deletions
diff --git a/clang/include/clang/Index/IndexProvider.h b/clang/include/clang/Index/IndexProvider.h index f69945eb2b4..187dd9393cb 100644 --- a/clang/include/clang/Index/IndexProvider.h +++ b/clang/include/clang/Index/IndexProvider.h @@ -19,6 +19,7 @@ namespace clang { namespace idx { class Entity; class TranslationUnitHandler; + class GlobalSelector; /// \brief Maps information to TranslationUnits. class IndexProvider { @@ -26,6 +27,8 @@ public: virtual ~IndexProvider(); virtual void GetTranslationUnitsFor(Entity Ent, TranslationUnitHandler &Handler) = 0; + virtual void GetTranslationUnitsFor(GlobalSelector Sel, + TranslationUnitHandler &Handler) = 0; }; } // namespace idx diff --git a/clang/include/clang/Index/Indexer.h b/clang/include/clang/Index/Indexer.h index 4fa36160649..98cce9e44ba 100644 --- a/clang/include/clang/Index/Indexer.h +++ b/clang/include/clang/Index/Indexer.h @@ -15,6 +15,8 @@ #define LLVM_CLANG_INDEX_INDEXER_H #include "clang/Index/IndexProvider.h" +#include "clang/Index/Entity.h" +#include "clang/Index/GlobalSelector.h" #include "llvm/ADT/SmallPtrSet.h" #include "llvm/ADT/DenseMap.h" #include <map> @@ -32,6 +34,7 @@ public: typedef llvm::SmallPtrSet<TranslationUnit *, 4> TUSetTy; typedef llvm::DenseMap<ASTContext *, TranslationUnit *> CtxTUMapTy; typedef std::map<Entity, TUSetTy> MapTy; + typedef std::map<GlobalSelector, TUSetTy> SelMapTy; explicit Indexer(Program &prog) : Prog(prog) { } @@ -42,11 +45,14 @@ public: virtual void GetTranslationUnitsFor(Entity Ent, TranslationUnitHandler &Handler); + virtual void GetTranslationUnitsFor(GlobalSelector Sel, + TranslationUnitHandler &Handler); private: Program &Prog; MapTy Map; CtxTUMapTy CtxTUMap; + SelMapTy SelMap; }; } // namespace idx diff --git a/clang/lib/Index/Indexer.cpp b/clang/lib/Index/Indexer.cpp index ddc22f7fbc0..75dfbd584cc 100644 --- a/clang/lib/Index/Indexer.cpp +++ b/clang/lib/Index/Indexer.cpp @@ -13,9 +13,9 @@ #include "clang/Index/Indexer.h" #include "clang/Index/Program.h" -#include "clang/Index/Entity.h" #include "clang/Index/Handlers.h" #include "clang/Index/TranslationUnit.h" +#include "ASTVisitor.h" #include "clang/AST/DeclBase.h" using namespace clang; using namespace idx; @@ -36,13 +36,37 @@ public: } }; +class SelectorIndexer : public ASTVisitor<SelectorIndexer> { + Program &Prog; + TranslationUnit *TU; + Indexer::SelMapTy ⤅ + +public: + SelectorIndexer(Program &prog, TranslationUnit *tu, Indexer::SelMapTy &map) + : Prog(prog), TU(tu), Map(map) { } + + void VisitObjCMethodDecl(ObjCMethodDecl *D) { + Map[GlobalSelector::get(D->getSelector(), Prog)].insert(TU); + Base::VisitObjCMethodDecl(D); + } + + void VisitObjCMessageExpr(ObjCMessageExpr *Node) { + Map[GlobalSelector::get(Node->getSelector(), Prog)].insert(TU); + Base::VisitObjCMessageExpr(Node); + } +}; + } // anonymous namespace void Indexer::IndexAST(TranslationUnit *TU) { assert(TU && "Passed null TranslationUnit"); - CtxTUMap[&TU->getASTContext()] = TU; + ASTContext &Ctx = TU->getASTContext(); + CtxTUMap[&Ctx] = TU; EntityIndexer Idx(TU, Map); - Prog.FindEntities(TU->getASTContext(), Idx); + Prog.FindEntities(Ctx, Idx); + + SelectorIndexer SelIdx(Prog, TU, SelMap); + SelIdx.Visit(Ctx.getTranslationUnitDecl()); } void Indexer::GetTranslationUnitsFor(Entity Ent, @@ -65,3 +89,16 @@ void Indexer::GetTranslationUnitsFor(Entity Ent, for (TUSetTy::iterator I = Set.begin(), E = Set.end(); I != E; ++I) Handler.Handle(*I); } + +void Indexer::GetTranslationUnitsFor(GlobalSelector Sel, + TranslationUnitHandler &Handler) { + assert(Sel.isValid() && "Expected valid GlobalSelector"); + + SelMapTy::iterator I = SelMap.find(Sel); + if (I == SelMap.end()) + return; + + TUSetTy &Set = I->second; + for (TUSetTy::iterator I = Set.begin(), E = Set.end(); I != E; ++I) + Handler.Handle(*I); +} |

