From 157e2065c3327e5cab22af9c74e9a46b47d18f29 Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Mon, 4 Jan 2010 21:30:22 +0000 Subject: Revert r15161 so 12.2.5 is greater than 12.2b once again. Depending on how you look at, it may seem counter-intuitive. However, if you really think about it, it seems like it's probably safe to assume that 12.2.5 > 12.2b is the behavior that is intended by anyone who would use versions such as these. svn path=/main/trunk/; revision=15166 --- pym/portage/versions.py | 27 +++++++++++---------------- 1 file changed, 11 insertions(+), 16 deletions(-) (limited to 'pym/portage/versions.py') diff --git a/pym/portage/versions.py b/pym/portage/versions.py index 208378172..5ab3aaeb5 100644 --- a/pym/portage/versions.py +++ b/pym/portage/versions.py @@ -103,22 +103,6 @@ def vercmp(ver1, ver2, silent=1): if match1.group(3) or match2.group(3): vlist1 = match1.group(3)[1:].split(".") vlist2 = match2.group(3)[1:].split(".") - else: - vlist1 = [] - vlist2 = [] - - if match1.group(5) or match2.group(5): - # and now the final letter - if match1.group(5): - vlist1.append(str(ord(match1.group(5)))) - else: - vlist1.append('0') - if match2.group(5): - vlist2.append(str(ord(match2.group(5)))) - else: - vlist2.append('0') - - if vlist1 or vlist2: for i in range(0, max(len(vlist1), len(vlist2))): # Implcit .0 is given a value of -1, so that 1.0.0 > 1.0, since it @@ -148,6 +132,17 @@ def vercmp(ver1, ver2, silent=1): list1.append(int(vlist1[i].ljust(max_len, "0"))) list2.append(int(vlist2[i].ljust(max_len, "0"))) + # and now the final letter + # NOTE: Behavior changed in r2309 (between portage-2.0.x and portage-2.1). + # The new behavior is 12.2.5 > 12.2b which, depending on how you look at, + # may seem counter-intuitive. However, if you really think about it, it + # seems like it's probably safe to assume that this is the behavior that + # is intended by anyone who would use versions such as these. + if len(match1.group(5)): + list1.append(ord(match1.group(5))) + if len(match2.group(5)): + list2.append(ord(match2.group(5))) + for i in range(0, max(len(list1), len(list2))): if len(list1) <= i: vercmp_cache[mykey] = -1 -- cgit v1.2.3-1-g7c22