diff options
author | Zac Medico <zmedico@gentoo.org> | 2010-11-30 16:46:52 -0800 |
---|---|---|
committer | Zac Medico <zmedico@gentoo.org> | 2010-12-03 22:27:39 -0800 |
commit | d634d736e6cdafefa39bedf53f64113bea650ef9 (patch) | |
tree | 69a5cf0483424ba47d7aeb3a64cea07ae7c87957 | |
parent | b5aa445c81192171423179385231583782d1523f (diff) | |
download | portage-d634d736e6cdafefa39bedf53f64113bea650ef9.tar.gz portage-d634d736e6cdafefa39bedf53f64113bea650ef9.tar.bz2 portage-d634d736e6cdafefa39bedf53f64113bea650ef9.zip |
fix AttributeError in recent use dep changes
-rw-r--r-- | pym/portage/dbapi/__init__.py | 4 | ||||
-rw-r--r-- | pym/portage/dep/__init__.py | 36 |
2 files changed, 22 insertions, 18 deletions
diff --git a/pym/portage/dbapi/__init__.py b/pym/portage/dbapi/__init__.py index 7d137b0bb..555125ac5 100644 --- a/pym/portage/dbapi/__init__.py +++ b/pym/portage/dbapi/__init__.py @@ -160,7 +160,9 @@ class dbapi(object): break if missing_iuse: continue - if not self._use_mutable: + if not atom.use: + pass + elif not self._use_mutable: missing_enabled = atom.use.missing_enabled.difference(iuse) missing_disabled = atom.use.missing_disabled.difference(iuse) diff --git a/pym/portage/dep/__init__.py b/pym/portage/dep/__init__.py index baf0fc3fc..1f956e39b 100644 --- a/pym/portage/dep/__init__.py +++ b/pym/portage/dep/__init__.py @@ -1936,26 +1936,28 @@ def match_from_list(mydep, candidate_list): mydep.unevaluated_atom.use.required): continue - missing_enabled = mydep.use.missing_enabled.difference(x.iuse.all) - missing_disabled = mydep.use.missing_disabled.difference(x.iuse.all) - - if mydep.use.enabled: - if mydep.use.enabled.intersection(missing_disabled): - continue - need_enabled = mydep.use.enabled.difference(use.enabled) - if need_enabled: - need_enabled = need_enabled.difference(missing_enabled) - if need_enabled: + if mydep.use: + + missing_enabled = mydep.use.missing_enabled.difference(x.iuse.all) + missing_disabled = mydep.use.missing_disabled.difference(x.iuse.all) + + if mydep.use.enabled: + if mydep.use.enabled.intersection(missing_disabled): continue + need_enabled = mydep.use.enabled.difference(use.enabled) + if need_enabled: + need_enabled = need_enabled.difference(missing_enabled) + if need_enabled: + continue - if mydep.use.disabled: - if mydep.use.disabled.intersection(missing_enabled): - continue - need_disabled = mydep.use.disabled.intersection(use.enabled) - if need_disabled: - need_disabled = need_disabled.difference(missing_disabled) - if need_disabled: + if mydep.use.disabled: + if mydep.use.disabled.intersection(missing_enabled): continue + need_disabled = mydep.use.disabled.intersection(use.enabled) + if need_disabled: + need_disabled = need_disabled.difference(missing_disabled) + if need_disabled: + continue mylist.append(x) |