From c9891910a8f7df878686a8be7e6d73adb66dd9c6 Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Wed, 10 Feb 2010 21:02:42 +0000 Subject: Ignore blockers in DEPEND of built packages when --with-bdeps is enabled. svn path=/main/trunk/; revision=15336 --- pym/_emerge/depgraph.py | 22 ++++++++++++++++------ 1 file changed, 16 insertions(+), 6 deletions(-) (limited to 'pym') 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 -- cgit v1.2.3-1-g7c22