From 15a6152d2f7ca70565c3a2eacacad632b6f7b66b Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Tue, 27 Apr 2010 14:51:12 -0700 Subject: Check USE deps all in one place (and fix some bugs). --- pym/_emerge/depgraph.py | 35 ++++++++++++++++++----------------- 1 file changed, 18 insertions(+), 17 deletions(-) (limited to 'pym') diff --git a/pym/_emerge/depgraph.py b/pym/_emerge/depgraph.py index 566cd2463..05558a3c3 100644 --- a/pym/_emerge/depgraph.py +++ b/pym/_emerge/depgraph.py @@ -2462,17 +2462,6 @@ class depgraph(object): if higher_version_rejected: continue - if atom.use: - for x in atom.use.required: - if x not in pkg.iuse.all and \ - pkg.root_config.settings._iuse_implicit_re.match(x) is None: - missing_iuse = True - break - if missing_iuse: - if not pkg.installed: - packages_with_invalid_use_config.append(pkg) - continue - cpv = pkg.cpv # Make --noreplace take precedence over --newuse. if not pkg.installed and noreplace and \ @@ -2546,14 +2535,26 @@ class depgraph(object): if not installed and myarg: found_available_arg = True - if atom.use and not pkg.built: - use = pkg.use.enabled - if atom.use.enabled.difference(use): - packages_with_invalid_use_config.append(pkg) + if atom.use: + for x in atom.use.required: + if x not in pkg.iuse.all and \ + pkg.root_config.settings._iuse_implicit_re.match(x) is None: + missing_iuse = True + break + if missing_iuse: + if not pkg.installed: + packages_with_invalid_use_config.append(pkg) continue - if atom.use.disabled.intersection(use): - packages_with_invalid_use_config.append(pkg) + + if atom.use.enabled.difference(pkg.use.enabled): + if not pkg.installed: + packages_with_invalid_use_config.append(pkg) + continue + if atom.use.disabled.intersection(pkg.use.enabled): + if not pkg.installed: + packages_with_invalid_use_config.append(pkg) continue + if pkg.cp == atom_cp: if highest_version is None: highest_version = pkg -- cgit v1.2.3-1-g7c22