Support passing a data pointer to annotation factory methods
authorChris Lattner <sabre@nondot.org>
Mon, 27 Aug 2001 05:19:10 +0000 (05:19 +0000)
committerChris Lattner <sabre@nondot.org>
Mon, 27 Aug 2001 05:19:10 +0000 (05:19 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@376 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Support/Annotation.cpp
support/lib/Support/Annotation.cpp

index 735d01b7824a2d3e8ca2c514707f3ae9d872a687..e98662078945590e59f7b337ad84b51af83b6b9e 100644 (file)
@@ -14,8 +14,8 @@ static unsigned IDCounter = 0;  // Unique ID counter
 static IDMapType &getIDMap() { static IDMapType TheMap; return TheMap; }
 
 // On demand annotation creation support...
-typedef Annotation *(*AnnFactory)(AnnotationID, Annotable *);
-typedef map<unsigned, AnnFactory> FactMapType;
+typedef Annotation *(*AnnFactory)(AnnotationID, Annotable *, void *);
+typedef map<unsigned, pair<AnnFactory,void*> > FactMapType;
 static FactMapType &getFactMap() { static FactMapType FactMap; return FactMap; }
 
 
@@ -45,9 +45,10 @@ const string &AnnotationManager::getName(AnnotationID ID) {        // ID -> Name
 // Annotable::findOrCreateAnnotation method.
 //
 void AnnotationManager::registerAnnotationFactory(AnnotationID ID, 
-                                                 AnnFactory F) {
+                                                 AnnFactory F,
+                                                 void *ExtraData) {
   if (F)
-    getFactMap()[ID.ID] = F;
+    getFactMap()[ID.ID] = make_pair(F, ExtraData);
   else
     getFactMap().erase(ID.ID);
 }
@@ -59,5 +60,5 @@ Annotation *AnnotationManager::createAnnotation(AnnotationID ID,
                                                Annotable *Obj) {
   FactMapType::iterator I = getFactMap().find(ID.ID);
   if (I == getFactMap().end()) return 0;
-  return I->second(ID, Obj);
+  return I->second.first(ID, Obj, I->second.second);
 }
index 735d01b7824a2d3e8ca2c514707f3ae9d872a687..e98662078945590e59f7b337ad84b51af83b6b9e 100644 (file)
@@ -14,8 +14,8 @@ static unsigned IDCounter = 0;  // Unique ID counter
 static IDMapType &getIDMap() { static IDMapType TheMap; return TheMap; }
 
 // On demand annotation creation support...
-typedef Annotation *(*AnnFactory)(AnnotationID, Annotable *);
-typedef map<unsigned, AnnFactory> FactMapType;
+typedef Annotation *(*AnnFactory)(AnnotationID, Annotable *, void *);
+typedef map<unsigned, pair<AnnFactory,void*> > FactMapType;
 static FactMapType &getFactMap() { static FactMapType FactMap; return FactMap; }
 
 
@@ -45,9 +45,10 @@ const string &AnnotationManager::getName(AnnotationID ID) {        // ID -> Name
 // Annotable::findOrCreateAnnotation method.
 //
 void AnnotationManager::registerAnnotationFactory(AnnotationID ID, 
-                                                 AnnFactory F) {
+                                                 AnnFactory F,
+                                                 void *ExtraData) {
   if (F)
-    getFactMap()[ID.ID] = F;
+    getFactMap()[ID.ID] = make_pair(F, ExtraData);
   else
     getFactMap().erase(ID.ID);
 }
@@ -59,5 +60,5 @@ Annotation *AnnotationManager::createAnnotation(AnnotationID ID,
                                                Annotable *Obj) {
   FactMapType::iterator I = getFactMap().find(ID.ID);
   if (I == getFactMap().end()) return 0;
-  return I->second(ID, Obj);
+  return I->second.first(ID, Obj, I->second.second);
 }