summaryrefslogtreecommitdiff
path: root/portato/backend/portage
diff options
context:
space:
mode:
authorNecoro <>2008-01-24 23:49:51 +0000
committerNecoro <>2008-01-24 23:49:51 +0000
commit4d4d5a6fd0348ecc628251dbca5ac9e22acfb555 (patch)
tree4b9e0de2dc57b8f4794812349c04466c5877c946 /portato/backend/portage
parentbf75aae3c9f6ac2130b65a0499e501ee697688b1 (diff)
downloadportato-4d4d5a6fd0348ecc628251dbca5ac9e22acfb555.tar.gz
portato-4d4d5a6fd0348ecc628251dbca5ac9e22acfb555.tar.bz2
portato-4d4d5a6fd0348ecc628251dbca5ac9e22acfb555.zip
r716@Devoty: necoro | 2008-01-25 00:35:00 +0100
Improved useflag handling r717@Devoty: necoro | 2008-01-25 00:47:45 +0100 improved update_world
Diffstat (limited to 'portato/backend/portage')
-rw-r--r--portato/backend/portage/package.py22
-rw-r--r--portato/backend/portage/system.py18
2 files changed, 22 insertions, 18 deletions
diff --git a/portato/backend/portage/package.py b/portato/backend/portage/package.py
index 42badbe..4760acb 100644
--- a/portato/backend/portage/package.py
+++ b/portato/backend/portage/package.py
@@ -146,21 +146,21 @@ class PortagePackage (Package):
else:
return reason
- def get_iuse_flags (self, installed = False, keep = False):
+ def get_iuse_flags (self, installed = False, removeForced = True):
if installed or not self.is_in_system():
tree = self._settings.vartree
else:
tree = self._settings.porttree
- flags = self.get_package_settings("IUSE", tree = tree).split()
+ iuse = flags.filter_defaults(self.get_package_settings("IUSE", tree = tree).split())
- if not keep: # remove "+"/"-"
- for ctr, f in enumerate(flags):
- if f.startswith(("+","-")):
- flags[ctr] = f[1:]
-
- return list(set(flags).difference(self.forced_flags))
+ iuse = set(iuse)
+ if removeForced:
+ return list(iuse.difference(self.forced_flags))
+ else:
+ return list(iuse)
+
def get_matched_dep_packages (self, depvar):
# change the useflags, because we have internally changed some, but not made them visible for portage
actual = self.get_actual_use_flags()
@@ -281,10 +281,10 @@ class PortagePackage (Package):
return r[0]
- def get_use_flags(self):
+ def get_installed_use_flags(self):
if self.is_installed():
- return self.get_package_settings("USE", tree = self._settings.vartree)
- else: return ""
+ return self.get_package_settings("USE", tree = self._settings.vartree).split()
+ else: return []
def compare_version(self,other):
v1 = self._scpv
diff --git a/portato/backend/portage/system.py b/portato/backend/portage/system.py
index a1ac90c..e2a00cb 100644
--- a/portato/backend/portage/system.py
+++ b/portato/backend/portage/system.py
@@ -370,9 +370,9 @@ class PortageSystem (SystemInterface):
# append system packages
packages.extend(unique_array([p.get_cp() for p in self.find_all_system_packages()]))
- states = [(["RDEPEND","PDEPEND"],True)]#, (["DEPEND"], False)]
+ states = [(["RDEPEND"], True)]
if self.with_bdeps():
- states[1] = (["DEPEND"], True)
+ states.append((["DEPEND"], True))
checked = []
updating = []
@@ -413,15 +413,19 @@ class PortageSystem (SystemInterface):
new_iuse = set(p.get_iuse_flags(installed = False)) # IUSE in the ebuild
old_iuse = set(p.get_iuse_flags(installed = True)) # IUSE in the vardb
+
+ # add forced flags, as they might trigger a rebuild
+ new_iuse_f = set(p.get_iuse_flags(installed = False, removeForced = False))
+ old_iuse_f = set(p.get_iuse_flags(installed = True, removeForced = False))
- if new_iuse.symmetric_difference(old_iuse): # difference between new_iuse and old_iuse
+ if new_iuse.symmetric_difference(old_iuse): # difference between IUSE (w/o forced)
tempDeep = True
if not appended:
updating.append((p,p))
appended = True
- else:
- if new_iuse.intersection(p.get_actual_use_flags()).symmetric_difference(p.get_installed_use_flags()):
+ else: # check for difference between the _set_ useflags (w/ forced)
+ if new_iuse_f.intersection(p.get_actual_use_flags()).symmetric_difference(old_iuse_f.intersection(p.get_installed_use_flags())):
tempDeep = True
if not appended:
updating.append((p,p))
@@ -429,7 +433,7 @@ class PortageSystem (SystemInterface):
if deep or tempDeep:
if (appended or prev_appended) and len(states) < 2:
- real_states = states + [("DEPEND", False)]
+ real_states = states + [("PDEPEND", True), ("DEPEND", False)]
else:
real_states = states
for state in real_states:
@@ -442,7 +446,7 @@ class PortageSystem (SystemInterface):
else:
for pkg in bm:
if not pkg: continue
- check(pkg, state[1], appended)
+ check(pkg, state[1], appended) # XXX: should be 'or'ed with prev_appended?
for p in self.get_new_packages(packages):
if not p: continue # if a masked package is installed we have "None" here