From d463781a50c93f833b6c310f51a36136f3334e84 Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Sun, 5 Dec 2010 14:36:16 -0800 Subject: dbapi.match: Use IUSE to validate built USE --- pym/portage/dbapi/__init__.py | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) (limited to 'pym/portage/dbapi/__init__.py') diff --git a/pym/portage/dbapi/__init__.py b/pym/portage/dbapi/__init__.py index 94fbc47b0..0708d6840 100644 --- a/pym/portage/dbapi/__init__.py +++ b/pym/portage/dbapi/__init__.py @@ -162,7 +162,6 @@ class dbapi(object): iuse, slot, use = self.aux_get(cpv, ["IUSE", "SLOT", "USE"], myrepo=myrepo) except KeyError: continue - use = use.split() iuse = frozenset(x.lstrip('+-') for x in iuse.split()) missing_iuse = False for x in atom.unevaluated_atom.use.required: @@ -174,6 +173,12 @@ class dbapi(object): if not atom.use: pass elif not self._use_mutable: + # Use IUSE to validate USE settings for built packages, + # in case the package manager that built this package + # failed to do that for some reason (or in case of + # data corruption). + use = frozenset(x for x in use.split() if x in iuse or \ + iuse_implicit_match(x)) missing_enabled = atom.use.missing_enabled.difference(iuse) missing_disabled = atom.use.missing_disabled.difference(iuse) -- cgit v1.2.3-1-g7c22