From ed589e570b592a8aad5665f8763e947164abd1ce Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Sat, 30 Aug 2008 06:10:22 +0000 Subject: [PATCH] =?utf8?q?In=20dep=5Fzapdeps(),=20add=20a=20new=20choice?= =?utf8?q?=20category=20for=20choices=20that=20have=20packages=20that=20ar?= =?utf8?q?en't=20yet=20installed=20but=20have=20been=20added=20to=20the=20?= =?utf8?q?graph.=20This=20category=20is=20given=20lower=20priority=20that?= =?utf8?q?=20the=20category=20for=20packages=20that=20are=20already=20inst?= =?utf8?q?alled.=20This=20helps=20dep=5Fzapdeps()=20avoid=20making=20choic?= =?utf8?q?es=20in=20some=20cases=20that=20would=20result=20in=20an=20unsol?= =?utf8?q?vable=20circular=20dependency.=20Thanks=20to=20Diego=20"Flameeye?= =?utf8?q?s"=20Petten=C3=B2=20for=20reporting=20a=20circular=20dependency?= =?utf8?q?=20issue=20involving=20that=20java=20overlay=20which=20is=20solv?= =?utf8?q?ed=20by=20this=20patch.=20The=20particular=20issue=20was=20trigg?= =?utf8?q?ered=20when=20attempting=20to=20install=20dev-java/icedtea6=20fo?= =?utf8?q?r=20the=20first=20time.=20A=20circular=20dependency=20between=20?= =?utf8?q?dev-java/eclipse-ecj-3.2.2-r1=20and=20dev-java/icedtea6-1.2=20oc?= =?utf8?q?cured=20since=20icedtea6=20was=20chosen=20to=20satisfy=20the=20j?= =?utf8?q?dk=20dependency=20of=20eclipse-ecj,=20even=20though=20sun-jdk-1.?= =?utf8?q?6.0.07=20was=20already=20installed=20and=20capable=20of=20satisf?= =?utf8?q?ying=20the=20dependency.=20This=20patch=20solves=20the=20issue?= =?utf8?q?=20by=20causing=20sun-jdk=20to=20be=20properly=20selected=20to?= =?utf8?q?=20satisfy=20the=20jdk=20dependency=20of=20eclipse-ecj.?= MIME-Version: 1.0 Content-Type: text/plain; charset=utf8 Content-Transfer-Encoding: 8bit svn path=/main/trunk/; revision=11478 --- pym/portage/__init__.py | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/pym/portage/__init__.py b/pym/portage/__init__.py index a97f1eec7..3bcb0b06c 100644 --- a/pym/portage/__init__.py +++ b/pym/portage/__init__.py @@ -6218,6 +6218,7 @@ def dep_zapdeps(unreduced, reduced, myroot, use_binaries=0, trees=None): # d) is the first item preferred = [] + preferred_not_installed = [] preferred_any_slot = [] possible_upgrades = [] other = [] @@ -6298,7 +6299,7 @@ def dep_zapdeps(unreduced, reduced, myroot, use_binaries=0, trees=None): break if all_in_graph: if parent is None: - preferred.append(this_choice) + preferred_not_installed.append(this_choice) else: # Check if the atom would result in a direct circular # dependency and try to avoid that if it seems likely @@ -6318,7 +6319,7 @@ def dep_zapdeps(unreduced, reduced, myroot, use_binaries=0, trees=None): circular_atom = atom break if circular_atom is None: - preferred.append(this_choice) + preferred_not_installed.append(this_choice) else: other.append(this_choice) else: @@ -6332,6 +6333,7 @@ def dep_zapdeps(unreduced, reduced, myroot, use_binaries=0, trees=None): # into || ( highest version ... lowest version ). We want to prefer the # highest all_available version of the new-style virtual when there is a # lower all_installed version. + preferred.extend(preferred_not_installed) preferred.extend(preferred_any_slot) preferred.extend(possible_upgrades) possible_upgrades = preferred[1:] -- 2.26.2