summaryrefslogtreecommitdiff
path: root/portato
diff options
context:
space:
mode:
Diffstat (limited to 'portato')
-rw-r--r--portato/backend/catapult/system.py70
1 files changed, 41 insertions, 29 deletions
diff --git a/portato/backend/catapult/system.py b/portato/backend/catapult/system.py
index 8c84b56..3d913e4 100644
--- a/portato/backend/catapult/system.py
+++ b/portato/backend/catapult/system.py
@@ -79,11 +79,30 @@ class CatapultSystem (SystemInterface):
return str(p)
return None
+ def _wrap_find(self, key, masked, set, withVersion, only_cpv):
+
+ l = []
+ try:
+ l = self.proxy.find_packages(key, set, masked, withVersion)
+ except dbus.DBusException, e:
+ name, data = str(e).split("\n")[-2].split(": ")[1:]
+ debug((name, data))
+
+ if name == "org.gentoo.catapult.AmbigousPackageError":
+ debug("Ambigous packages: %s.", data)
+ l = []
+ for cp in data.split(","):
+ l += self.proxy.find_packages(cp, set, masked, withVersion)
+ else:
+ raise
+
+ return self.geneticize_list(l, not(withVersion) or only_cpv)
+
def find_packages (self, search_key, masked = False, only_cpv = False):
- return self.geneticize_list(self.proxy.find_packages(search_key, "all", masked, True), only_cpv)
+ return self._wrap_find(search_key, masked, "all", True, only_cpv)
def find_installed_packages (self, search_key, masked = False, only_cpv = False):
- return self.geneticize_list(self.proxy.find_packages(search_key, "installed", masked, True), only_cpv)
+ return self._wrap_find(search_key, masked, "installed", True, only_cpv)
def find_system_packages (self, only_cpv = False):
# result = self.proxy.find_system_packages()
@@ -91,7 +110,7 @@ class CatapultSystem (SystemInterface):
# return result
# else:
# return tuple(map(self.geneticize_list, result))
- return (self.geneticize_list(self.proxy.find_packages(search_key, "system", False, True), only_cpv), [])
+ return (self._wrap_find(search_key, False, "system", True, only_cpv), [])
def find_world_packages (self, only_cpv = False):
# result = self.proxy.find_world_packages()
@@ -99,42 +118,35 @@ class CatapultSystem (SystemInterface):
# return result
# else:
# return tuple(map(self.geneticize_list, result))
- return (self.geneticize_list(self.proxy.find_packages(search_key, "world", False, True), only_cpv), [])
+ return (self._wrap_find(search_key, False, "world", True, only_cpv), [])
- def find_all_installed_packages (self, name = None, withVersion = True, only_cpv = False):
- if not name:
- name = ".*"
+ def _wrap_find_all (self, key, masked, set, withVersion, only_cpv):
+ if not key:
+ key = ""
else:
- name = ".*%s.*" % name
- return self.geneticize_list(self.proxy.find_packages(name, "installed", True, withVersion), (not withVersion) or only_cpv)
+ key = "*%s*" % key
+
+ l = self.proxy.find_packages("", set, masked, withVersion)
+
+ if key:
+ l = catapult.filter_list(key, l)
+
+ return self.geneticize_list(l, not(withVersion) or only_cpv)
+
+ def find_all_installed_packages (self, name = None, withVersion = True, only_cpv = False):
+ return self._wrap_find_all(name, True, "installed", withVersion, only_cpv)
def find_all_uninstalled_packages (self, name = None, only_cpv = False):
- if not name:
- name = ".*"
- else:
- name = ".*%s.*" % name
- return self.geneticize_list(self.proxy.find_packages(name, "uninstalled", True, withVersion), (not withVersion) or only_cpv)
+ return self._wrap_find_all(name, True, "uninstalled", True, only_cpv)
def find_all_packages (self, name = None, withVersion = True, only_cpv = False):
- if not name:
- name = ".*"
- else:
- name = ".*%s.*" % name
- return self.geneticize_list(self.proxy.find_packages(name, "all", True, withVersion), (not withVersion) or only_cpv)
+ return self._wrap_find_all(name, True, "all", withVersion, only_cpv)
def find_all_world_packages (self, name = None, only_cpv = False):
- if not name:
- name = ".*"
- else:
- name = ".*%s.*" % name
- return self.geneticize_list(self.proxy.find_packages(name, "world", True, True), (not withVersion) or only_cpv)
+ return self._wrap_find_all(name, True, "world", withVersion, only_cpv)
def find_all_system_packages (self, name = None, only_cpv = False):
- if not name:
- name = ".*"
- else:
- name = ".*%s.*" % name
- return self.geneticize_list(self.proxy.find_packages(name, "system", True, True), (not withVersion) or only_cpv)
+ return self._wrap_find_all(name, True, "system", withVersion, only_cpv)
def list_categories (self, name = None):
if not name:
ndows.py?h=0.13&id=40eaa80dce320c6e64e66d96ec28c9fc532c061c&follow=1'>First implementation of "emerge --update world"necoro4-17/+100 2006-10-14Wah - I'm tired ...necoro1-3/+3 2006-10-14and now another bug -.-necoro1-2/+2 2006-10-14forgot one returnnecoro1-0/+2 2006-10-14Set min height to 600 if maxHeight is smaller then 800necoro2-4/+7 2006-10-13Some more documentationnecoro2-82/+298 2006-10-13Documentation worknecoro2-154/+160 2006-10-12Enabled oneshotnecoro3-32/+103 2006-10-12Layout updatenecoro1-16/+38 2006-10-12Fixed bugsnecoro2-15/+16 2006-10-12Migrated to UIManagernecoro1-33/+64 2006-10-10Fixed bug not showing the use-flag-list in some casesnecoro1-3/+5 2006-10-09bla - prepared 0.4.0 ; added dialogs.py; extended some commentsnecoro9-125/+293 2006-10-08Made the testing stuff working too ... I hope ^^ ... removed obsolete-dirnecoro7-145/+113 2006-10-05Added first support for the masking stuff ... and hoping that it is going to ↵necoro5-79/+135 work properly ;) 2006-10-05Changed changelog / added config-filenecoro2-0/+10 2006-10-05Added preference windownecoro4-49/+155 2006-10-02Corrected comments, structure, bad algorithms etcnecoro4-176/+209 2006-10-02Corrected indention in commentnecoro1-8/+6 2006-10-010.3.3necoro1-0/+6 2006-10-01Implemented an internal db; removed unmerge-bugnecoro2-26/+43 2006-09-30Implemented some new backend functions which speed up the ↵necoro2-12/+37 package-list-creation. (Thanks an porthole for the inspiration ;P) 2006-09-300.3.2 release; changed font in terminal; added new "masking"-dialognecoro3-11/+36 2006-09-29fixed bugsnecoro4-13/+23 2006-09-29Corrected setup.pynecoro1-1/+1