summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--portato/backend/package.py17
-rw-r--r--portato/backend/portage_helper.py27
2 files changed, 22 insertions, 22 deletions
diff --git a/portato/backend/package.py b/portato/backend/package.py
index fc0bd02..225c06a 100644
--- a/portato/backend/package.py
+++ b/portato/backend/package.py
@@ -38,6 +38,10 @@ class Package:
self._settings = settings
self._settingslock = settingslock
+
+ self.forced_flags = set()
+ self.forced_flags.update(self._settings.usemask)
+ self.forced_flags.update(self._settings.useforce)
try:
self._status = portage.getmaskingstatus(self.get_cpv(), settings = self._settings)
@@ -151,7 +155,7 @@ class Package:
else:
tree = porttree
- return unique_array(self.get_env_var("IUSE", tree = tree).split())
+ return list(set(self.get_env_var("IUSE", tree = tree).split()).difference(self.forced_flags))
def get_installed_use_flags (self):
"""Returns a list of the useflags enabled at installation time. If package is not installed, it returns an empty list.
@@ -160,13 +164,10 @@ class Package:
@rtype: string[]"""
if self.is_installed():
- uses = self.get_use_flags().split() # all set at installation time
- iuses = self.get_all_use_flags() # all you can set for the package
- set = []
- for u in iuses:
- if u in uses:
- set.append(u)
- return set
+ uses = set(self.get_use_flags().split()) # all set at installation time
+ iuses = set(self.get_all_use_flags(installed=True)) # all you can set for the package
+
+ return list(uses.intersection(iuses))
else:
return []
diff --git a/portato/backend/portage_helper.py b/portato/backend/portage_helper.py
index 9c171b4..10ab9fa 100644
--- a/portato/backend/portage_helper.py
+++ b/portato/backend/portage_helper.py
@@ -378,27 +378,26 @@ def update_world (newuse = False, deep = False):
if newuse:
- new = set(p.get_all_use_flags(False)) # IUSE in the ebuild
- old = set(p.get_all_use_flags(True)) # IUSE in the vardb
- if old != new:
- debug(p.get_cpv(),"old:",old)
- debug(p.get_cpv(),"new:",new)
+ new_iuse = set(p.get_all_use_flags(installed = False)) # IUSE in the ebuild
+ old_iuse = set(p.get_all_use_flags(installed = True)) # IUSE in the vardb
+
+ if new_iuse.symmetric_difference(old_iuse): # difference between new_iuse and old_iuse
+ debug(p.get_cpv(),"old:",old_iuse)
+ debug(p.get_cpv(),"new:",new_iuse)
tempDeep = True
if not appended:
updating.append((p,p))
appended = True
else:
- old = p.get_installed_use_flags()
- new = p.get_settings("USE").split()
+ old = set(p.get_installed_use_flags())
+ new = set(p.get_settings("USE").split())
- for u in p.get_all_use_flags():
- if (u in new) != (u in old):
- tempDeep = True
- if not appended:
- updating.append((p,p))
- appended = True
- break
+ if new_iuse.intersection(new) != old_iuse.intersection(old):
+ tempDeep = True
+ if not appended:
+ updating.append((p,p))
+ appended = True
if deep or tempDeep:
for i in p.get_matched_dep_packages():