]> git.saurik.com Git - apt.git/blobdiff - apt-pkg/depcache.cc
Source record file list parsing
[apt.git] / apt-pkg / depcache.cc
index 19f30b2c172f0c889f7cfd4a5aec05a163170099..727f01462920a3310aa7a10eef7deec2e324dde4 100644 (file)
@@ -1,6 +1,6 @@
 // -*- mode: cpp; mode: fold -*-
 // Description                                                         /*{{{*/
-// $Id: depcache.cc,v 1.13 1998/12/22 07:58:50 jgg Exp $
+// $Id: depcache.cc,v 1.15 1999/03/26 07:38:43 jgg Exp $
 /* ######################################################################
 
    Dependency Cache - Caches Dependency information.
@@ -12,7 +12,6 @@
 #pragma implementation "apt-pkg/depcache.h"
 #endif
 #include <apt-pkg/depcache.h>
-#include <apt-pkg/configuration.h>
 
 #include <apt-pkg/version.h>
 #include <apt-pkg/error.h>
@@ -105,40 +104,18 @@ pkgDepCache::VerIterator pkgDepCache::GetCandidateVer(PkgIterator Pkg)
    // Try to use an explicit target
    if (Pkg->TargetVer == 0)
    {
-      string DistHack = _config->Find("to");
-
-      /* If disthack is set then we look for a dist by that name to install
-         from */
-      if (DistHack.empty() == false)
-      {
-        for (VerIterator I = Pkg.VersionList(); I.end() == false; I++)
-        {
-           for (VerFileIterator J = I.FileList(); J.end() == false; J++)
-              if ((J.File()->Flags & Flag::NotSource) == 0 &&
-                  (J.File()->Flags & Flag::NotAutomatic) == 0 &&
-                  J.File().Archive() == DistHack)
-                 return I;         
-        }
-        
-        // Hmm, target is current if there is no alternative.
-        if (Pkg->CurrentVer != 0)
-           return Pkg.CurrentVer();
-      }
-      else
+      /* Not source/not automatic versions cannot be a candidate version 
+         unless they are already installed */
+      for (VerIterator I = Pkg.VersionList(); I.end() == false; I++)
       {
-        /* Not source/not automatic versions cannot be a candidate version 
-           unless they are already installed */
-        for (VerIterator I = Pkg.VersionList(); I.end() == false; I++)
-        {
-           if (Pkg.CurrentVer() == I)
-              return I;
-           for (VerFileIterator J = I.FileList(); J.end() == false; J++)
-              if ((J.File()->Flags & Flag::NotSource) == 0 &&
-                  (J.File()->Flags & Flag::NotAutomatic) == 0)
-                 return I;
-        }
+        if (Pkg.CurrentVer() == I)
+           return I;
+        for (VerFileIterator J = I.FileList(); J.end() == false; J++)
+           if ((J.File()->Flags & Flag::NotSource) == 0 &&
+               (J.File()->Flags & Flag::NotAutomatic) == 0)
+               return I;
       }
-      
+        
       return VerIterator(*this,0);
    }
    else
@@ -238,7 +215,8 @@ void pkgDepCache::AddSizes(const PkgIterator &Pkg,long Mult)
 {
    StateCache &P = PkgState[Pkg->ID];
    
-   if (Pkg.State() == pkgCache::PkgIterator::NeedsConfigure)
+   if (Pkg.State() == pkgCache::PkgIterator::NeedsConfigure && 
+       P.Keep() == true)
    {
       iUsrSize += Mult*P.InstVerIter(*this)->InstalledSize;
       return;
@@ -311,8 +289,6 @@ void pkgDepCache::AddStates(const PkgIterator &Pkg,int Add)
    {
       if (State.Mode == ModeDelete)
         iDelCount += Add;
-      if (State.Mode == ModeInstall)
-        iInstCount += Add;
       return;
    }