From 62551a66cc82cfdc426fd533883674035622b4d6 Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Thu, 5 Apr 2007 20:46:31 +0000 Subject: Punt the sorted_versions() function in favor of list.sort(vercmp). svn path=/main/trunk/; revision=6339 --- pym/emerge/__init__.py | 39 +++++++-------------------------------- 1 file changed, 7 insertions(+), 32 deletions(-) (limited to 'pym/emerge/__init__.py') diff --git a/pym/emerge/__init__.py b/pym/emerge/__init__.py index e872f5443..980eff386 100644 --- a/pym/emerge/__init__.py +++ b/pym/emerge/__init__.py @@ -151,32 +151,6 @@ def userquery(prompt, responses=None, colours=None): print "Interrupted." sys.exit(1) -def sorted_versions(verlist): - ret = [] - for ver in verlist: - verparts = ver.split("-") - if len(verparts) == 2: - verrev = int(verparts[1][1:]) - else: - verrev = 0 - x = 0 - while x < len(ret): - retparts = ret[x].split("-") - verdiff = portage.vercmp(retparts[0], verparts[0]) - if verdiff > 0: - break - elif verdiff == 0: - if len(retparts) == 2: - retrev = int(retparts[1][1:]) - else: - retrev = 0 - if retrev >= verrev: - break - x += 1 - ret.insert(x, ver) - return ret - - actions=[ "clean", "config", "depclean", "info", "metadata", @@ -4533,15 +4507,16 @@ def action_info(settings, trees, myopts, myfiles): for x in myvars: if portage.isvalidatom(x): pkg_matches = trees["/"]["vartree"].dbapi.match(x) + pkg_matches = [portage.catpkgsplit(cpv)[1:] for cpv in pkg_matches] + pkg_matches.sort(portage.pkgcmp) pkgs = [] - for y in pkg_matches: - mycpv = portage.catpkgsplit(y) - if(mycpv[3] != "r0"): - pkgs += [mycpv[2] + "-" + mycpv[3]] + for pn, ver, rev in pkg_matches: + if rev != "r0": + pkgs.append(ver + "-" + rev) else: - pkgs += [mycpv[2]] + pkgs.append(ver) if pkgs: - pkgs = ", ".join(sorted_versions(pkgs)) + pkgs = ", ".join(pkgs) print "%-20s %s" % (x+":", pkgs) else: print "%-20s %s" % (x+":", "[NOT VALID]") -- cgit v1.2.3-1-g7c22