+["package_"+x for x in ["mask", "unmask", "use", "keywords"]]
class PackageSet(object):
- # That this to operations that are supported by this set class. While
+ # Set this to operations that are supported by your subclass. While
# technically there is no difference between "merge" and "unmerge" regarding
# package sets, the latter doesn't make sense for some sets like "system"
# or "security" and therefore isn't supported by them.
def __init__(self, name):
self._name = name
- self._atoms = []
- self._loaded = False
+ self._atoms = set()
+ self._mtime = None
def supportsOperation(self, op):
if not op in OPERATIONS:
return op in self._operations
def getAtoms(self):
- if not self._loaded:
+ if not self._mtime or self.supportsOperation("edit"):
self.load()
- self._loaded = True
return self._atoms
def _setAtoms(self, atoms):
elif not isvalidatom(a):
raise InvalidAtom(a)
self._atoms = atoms
+ if not self.supportsOperation("edit"):
+ self._mtime = True
def getName(self):
return self._name
- def addAtom(self, atom):
+ def updateAtoms(self, atoms):
if self.supportsOperation("edit"):
self.load()
- self._atoms.append(atom)
+ self._atoms.update(atoms)
self.write()
else:
raise NotImplementedError()
+
+ def addAtom(self, atom):
+ self.updateAtoms([atom])
def removeAtom(self, atom):
if self.supportsOperation("edit"):
self.load()
- self._atoms.remove(atom)
+ self._atoms.discard(atom)
self.write()
else:
raise NotImplementedError()
def load(self):
# This method must be overwritten by subclasses
+ # Editable sets should use the value of self._mtime to determine if they
+ # need to reload themselves
raise NotImplementedError()
def containsCPV(self, cpv):
def load(self):
pass
+ def write(self):
+ pass
def make_default_sets(configroot, root, profile_paths, settings=None,
vdbapi=None, portdbapi=None):
# $Id$
from portage.util import grabfile_package, grabdict_package, write_atomic
+import os
from portage.sets import PackageSet
write_atomic(self._filename, "\n".join(self._atoms)+"\n")
def load(self):
+ mtime = os.stat(self._filename).st_mtime
+ if not self._mtime or self._mtime != mtime:
+ self._load()
+ self._mtime = mtime
+
+ def _load(self):
self._setAtoms(grabfile_package(self._filename, recursive=True))
class ConfigFileSet(StaticFileSet):
def write(self):
raise NotImplementedError()
- def load(self):
+ def _load(self):
self._setAtoms(grabdict_package(self._filename, recursive=True).keys())