]> git.saurik.com Git - apt.git/commitdiff
* added a InRootSetFunc class for clients to add own packages to the mark'n'sweep...
authorMichael Vogt <michael.vogt@ubuntu.com>
Fri, 19 Aug 2005 08:50:57 +0000 (08:50 +0000)
committerMichael Vogt <michael.vogt@ubuntu.com>
Fri, 19 Aug 2005 08:50:57 +0000 (08:50 +0000)
apt-pkg/algorithms.cc
apt-pkg/algorithms.h

index 3978e7561a12a0e441ee6d62c9b3d8c126b75787..82ea19c935345f34843cb52136ea3154c76a05a9 100644 (file)
@@ -1342,8 +1342,14 @@ pkgMarkAlwaysInclude(pkgCache::PkgIterator p, vector<regex_t*> alwaysMark)
    return false;
 }
 
+bool pkgMarkUsed(pkgDepCache &Cache)
+{
+   InRootSetFunc f;
+   return pkgMarkUsed(Cache, f);
+}
+
 // the main mark algorithm
-bool pkgMarkUsed(pkgDepCache &Cache, InRootSetFunc func)
+bool pkgMarkUsed(pkgDepCache &Cache, InRootSetFunc &userFunc)
 {
    bool follow_recommends;
    bool follow_suggests;
@@ -1394,7 +1400,7 @@ bool pkgMarkUsed(pkgDepCache &Cache, InRootSetFunc func)
    // do the mark part, this is the core bit of the algorithm
    for(pkgCache::PkgIterator p=Cache.PkgBegin(); !p.end(); ++p)
    {
-      if( (func != NULL ? (*func)(p) : false) ||
+      if( userFunc.InRootSet(p) ||
           pkgMarkAlwaysInclude(p, neverAutoRemoveRegexp) ||
         !(Cache[p].Flags & pkgCache::Flag::Auto) ||
          (p->Flags & pkgCache::Flag::Essential))
index 02b40e15f0fa221a82deae30f678d6dbd904808c..e539a410e32100f8837af46182da07795223203f 100644 (file)
@@ -134,10 +134,16 @@ bool pkgMinimizeUpgrade(pkgDepCache &Cache);
 void pkgPrioSortList(pkgCache &Cache,pkgCache::Version **List);
 
 
-// callback function that can be used by the client to bring in
+// class that can be subclassed by the client to bring in
 // certain own packages into the root set (if the client returns
 // True the package will be considered as part of the root set)
-typedef bool (*InRootSetFunc)(pkgCache::PkgIterator);
+class InRootSetFunc
+{
+ public:
+   virtual bool InRootSet(const pkgCache::PkgIterator &pkg) {return false;};
+   virtual ~InRootSetFunc() {};
+};
+
 
 // Mark all reachable packages with "pkgDepCache::StateCache.Marked=1"
 // the root-set are all essential packages+everything that was not 
@@ -147,7 +153,7 @@ typedef bool (*InRootSetFunc)(pkgCache::PkgIterator);
 // is usefull for clients that have there own idea about the root-set
 // 
 // Everything that is not reach can be removed
-bool pkgMarkUsed(pkgDepCache &Cache, InRootSetFunc f=NULL);
-                
+bool pkgMarkUsed(pkgDepCache &Cache);
+bool pkgMarkUsed(pkgDepCache &Cache, InRootSetFunc &f);
                     
 #endif