From: Zac Medico Date: Wed, 17 Jan 2007 02:31:56 +0000 (-0000) Subject: Fix elimination of duplicate virtuals between the binpkg repo and installed packages. X-Git-Tag: v2.1.2-r3~41 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=88d7916055d59b40ad95027937e9d70b6c1880c4;p=portage.git Fix elimination of duplicate virtuals between the binpkg repo and installed packages. svn path=/main/trunk/; revision=5684 --- diff --git a/pym/portage.py b/pym/portage.py index 31be26307..9c5277feb 100644 --- a/pym/portage.py +++ b/pym/portage.py @@ -3913,11 +3913,11 @@ def _expand_new_virtuals(mysplit, edebug, mydbapi, mysettings, myroot="/", match_atom = x if isblocker: match_atom = x[1:] - pkgs = [] + pkgs = {} for cpv in portdb.match(match_atom): # only use new-style matches if cpv.startswith("virtual/"): - pkgs.append((cpv, pkgsplit(cpv), portdb)) + pkgs[cpv] = (cpv, pkgsplit(cpv), portdb) if kwargs["use_binaries"] and "vartree" in trees[myroot]: vardb = trees[myroot]["vartree"].dbapi for cpv in vardb.match(match_atom): @@ -3925,7 +3925,7 @@ def _expand_new_virtuals(mysplit, edebug, mydbapi, mysettings, myroot="/", if cpv.startswith("virtual/"): if cpv in pkgs: continue - pkgs.append((cpv, pkgsplit(cpv), vardb)) + pkgs[cpv] = (cpv, pkgsplit(cpv), vardb) if not (pkgs or mychoices): # This one couldn't be expanded as a new-style virtual. Old-style # virtuals have already been expanded by dep_virtual, so this one @@ -3937,6 +3937,7 @@ def _expand_new_virtuals(mysplit, edebug, mydbapi, mysettings, myroot="/", if not pkgs and len(mychoices) == 1: newsplit.append(x.replace(mykey, mychoices[0])) continue + pkgs = pkgs.values() pkgs.sort(compare_pkgs) # Prefer higher versions. if isblocker: a = []