break another recursion cycle, add special subclass for "world" to handle locking
authorMarius Mauch <genone@gentoo.org>
Mon, 16 Jul 2007 13:51:11 +0000 (13:51 -0000)
committerMarius Mauch <genone@gentoo.org>
Mon, 16 Jul 2007 13:51:11 +0000 (13:51 -0000)
svn path=/main/trunk/; revision=7282

pym/portage/sets/__init__.py
pym/portage/sets/files.py

index cab64279b31bdebd3347c4adbfc1727a9be3db34..91ddc357383d83358129af032d381900002b244d 100644 (file)
@@ -42,7 +42,7 @@ class PackageSet(object):
                return op in self._operations
        
        def getAtoms(self):
-               if not self._loaded and not self._loading:
+               if not (self._loaded or self._loading):
                        self._loading = True
                        self.load()
                        self._loaded = True
@@ -78,7 +78,7 @@ class PackageSet(object):
                        return ""
        
        def _updateAtomMap(self):
-               for a in self.getAtoms():
+               for a in self._atoms:
                        cp = dep_getkey(a)
                        self._atommap.setdefault(cp, set())
                        self._atommap[cp].add(a)
index 9558cc7a30a0ab3999fc686e0e4bc150d5b92520..7fa5fb24d6d79db3c470f11811e11de2d16e3919 100644 (file)
@@ -2,7 +2,10 @@
 # Distributed under the terms of the GNU General Public License v2
 # $Id$
 
-from portage.util import grabfile, grabfile_package, grabdict_package, write_atomic
+from portage.util import grabfile, grabfile_package, grabdict_package, write_atomic, ensure_dirs
+from portage.const import PRIVATE_PATH
+from portage.locks import lockfile, unlockfile
+from portage import portage_gid
 import os
 
 from portage.sets import PackageSet, EditablePackageSet
@@ -41,7 +44,7 @@ class StaticFileSet(EditablePackageSet):
                        mtime = os.stat(self._filename).st_mtime
                except (OSError, IOError):
                        mtime = None
-               if not self._loaded or self._mtime != mtime:
+               if (not self._loaded or self._mtime != mtime):
                        self._setAtoms(grabfile_package(self._filename, recursive=True))
                        self._mtime = mtime
        
@@ -54,3 +57,20 @@ class ConfigFileSet(PackageSet):
        def load(self):
                self._setAtoms(grabdict_package(self._filename, recursive=True).keys())
 
+class WorldSet(StaticFileSet):
+       description = "Set of packages that were directly installed by the user"
+       
+       def __init__(self, name, root):
+               super(WorldSet, self).__init__(name, os.path.join(os.sep, root, PRIVATE_PATH, "world"))
+               self._lock = None
+
+       def _ensure_dirs(self):
+               ensure_dirs(os.path.dirname(self._filename), gid=portage_gid, mode=02750, mask=02)
+
+       def lock(self):
+               self._ensure_dirs()
+               self._lock = lockfile(self._filename, wantnewlockfile=1)
+
+       def unlock(self):
+               unlockfile(self._lock)
+               self._lock = None