diff options
author | Zac Medico <zmedico@gentoo.org> | 2010-02-10 21:02:42 +0000 |
---|---|---|
committer | Zac Medico <zmedico@gentoo.org> | 2010-02-10 21:02:42 +0000 |
commit | c9891910a8f7df878686a8be7e6d73adb66dd9c6 (patch) | |
tree | 1194e2067c24c5aa75e4a9b52e52328bf2bbbb8f | |
parent | 33a9d38b3e4e73d4ba5c08d1f151e0b6156712c7 (diff) | |
download | portage-c9891910a8f7df878686a8be7e6d73adb66dd9c6.tar.gz portage-c9891910a8f7df878686a8be7e6d73adb66dd9c6.tar.bz2 portage-c9891910a8f7df878686a8be7e6d73adb66dd9c6.zip |
Ignore blockers in DEPEND of built packages when --with-bdeps is enabled.
svn path=/main/trunk/; revision=15336
-rw-r--r-- | pym/_emerge/depgraph.py | 22 |
1 files changed, 16 insertions, 6 deletions
diff --git a/pym/_emerge/depgraph.py b/pym/_emerge/depgraph.py index abd60ed03..fd9fe12bd 100644 --- a/pym/_emerge/depgraph.py +++ b/pym/_emerge/depgraph.py @@ -1140,9 +1140,14 @@ class depgraph(object): deps = ( (bdeps_root, edepend["DEPEND"], self._priority(buildtime=(not bdeps_optional), - optional=bdeps_optional)), - (myroot, edepend["RDEPEND"], self._priority(runtime=True)), - (myroot, edepend["PDEPEND"], self._priority(runtime_post=True)) + optional=bdeps_optional), + pkg.built), + (myroot, edepend["RDEPEND"], + self._priority(runtime=True), + False), + (myroot, edepend["PDEPEND"], + self._priority(runtime_post=True), + False) ) debug = "--debug" in self._frozen_config.myopts @@ -1151,7 +1156,7 @@ class depgraph(object): if not strict: portage.dep._dep_check_strict = False - for dep_root, dep_string, dep_priority in deps: + for dep_root, dep_string, dep_priority, ignore_blockers in deps: if not dep_string: continue if debug: @@ -1186,7 +1191,7 @@ class depgraph(object): if not self._add_pkg_dep_string( pkg, dep_root, dep_priority, dep_string, - allow_unsatisfied): + allow_unsatisfied, ignore_blockers=ignore_blockers): return 0 except portage.exception.AmbiguousPackageName as e: @@ -1213,7 +1218,7 @@ class depgraph(object): return 1 def _add_pkg_dep_string(self, pkg, dep_root, dep_priority, dep_string, - allow_unsatisfied): + allow_unsatisfied, ignore_blockers=False): depth = pkg.depth + 1 debug = "--debug" in self._frozen_config.myopts strict = pkg.type_name != "installed" @@ -1248,6 +1253,11 @@ class depgraph(object): for atom, child in self._minimize_children( pkg, dep_priority, root_config, selected_atoms[pkg]): + if ignore_blockers and atom.blocker: + # For --with-bdeps, ignore build-time only blockers + # that originate from built packages. + continue + mypriority = dep_priority.copy() if not atom.blocker and vardb.match(atom): mypriority.satisfied = True |