]> git.saurik.com Git - apt.git/commitdiff
More inproved comments about loops.
authorChristopher Baines <cbaines8@gmail.com>
Tue, 9 Aug 2011 16:10:09 +0000 (17:10 +0100)
committerChristopher Baines <cbaines8@gmail.com>
Tue, 9 Aug 2011 16:10:09 +0000 (17:10 +0100)
apt-pkg/orderlist.cc
apt-pkg/orderlist.h

index eaa5ea20a6b2968c31416bf3dd1ec09141c7820e..1e412ead52bbb4a0beb1884974346ba8f91b6a37 100644 (file)
@@ -1023,6 +1023,8 @@ bool pkgOrderList::AddLoop(DepIterator D)
    // Mark the packages as being part of a loop.
    //Flag(D.TargetPkg(),Loop);
    //Flag(D.ParentPkg(),Loop);
+   /* This is currently disabled because the Loop flag is being used for
+      loop management in the package manager. Check the orderlist.h file for more info */
    return true;
 }
                                                                        /*}}}*/
index bbceb3879a6bac2685c8769dcab683aef283d96e..2f5c6d0d1bcd04d289fd074713db21a61abab4c7 100644 (file)
@@ -74,7 +74,12 @@ class pkgOrderList : protected pkgCache::Namespace
 
    typedef Package **iterator;
    
-   // State flags
+   /* State flags
+      The Loop flag can be set on a package that is currently being processed by either SmartConfigure or
+      SmartUnPack. This allows the package manager to tell when a loop has been formed as it will try to 
+      SmartUnPack or SmartConfigure a package with the Loop flag set. It will then either stop (as it knows
+      that the operation is unnecessary as its already in process), or in the case of the conflicts resolution
+      in SmartUnPack, use EarlyRemove to resolve the situation.  */
    enum Flags {Added = (1 << 0), AddPending = (1 << 1),
                Immediate = (1 << 2), Loop = (1 << 3),
                UnPacked = (1 << 4), Configured = (1 << 5),
@@ -89,6 +94,7 @@ class pkgOrderList : protected pkgCache::Namespace
    void Flag(PkgIterator Pkg,unsigned long State, unsigned long F) {Flags[Pkg->ID] = (Flags[Pkg->ID] & (~F)) | State;};
    inline void Flag(PkgIterator Pkg,unsigned long F) {Flags[Pkg->ID] |= F;};
    inline void Flag(Package *Pkg,unsigned long F) {Flags[Pkg->ID] |= F;};
+   // IsNow will return true if the Pkg has been not been either configured or unpacked
    inline bool IsNow(PkgIterator Pkg) {return (Flags[Pkg->ID] & (States & (~Removed))) == 0;};
    bool IsMissing(PkgIterator Pkg);
    void WipeFlags(unsigned long F);