From ccd816ceb50096fff849221a78d16b78c5dc33c6 Mon Sep 17 00:00:00 2001 From: Mario Frasca Date: Mon, 27 May 2019 12:35:28 -0500 Subject: [PATCH] attempt partial sorting at least see issue #606. if one object has anything that doesn't compare to `int`, bring it to the top, and correctly sort the rest. --- babel/messages/pofile.py | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/babel/messages/pofile.py b/babel/messages/pofile.py index bbcf7f76c..93b0697c6 100644 --- a/babel/messages/pofile.py +++ b/babel/messages/pofile.py @@ -582,11 +582,13 @@ def _write_message(message, prefix=''): if not no_location: locs = [] - # Attempt to sort the locations. If we can't do that, for instance - # because there are mixed integers and Nones or whatnot (see issue #606) - # then give up, but also don't just crash. + # sort locations by filename and lineno. + # if there's no as lineno, use `-1`. + # if no sorting possible, leave unsorted. + # (see issue #606) try: - locations = sorted(message.locations) + locations = sorted(message.locations, + key=lambda x: (x[0], isinstance(x[1], int) and x[1] or -1)) except TypeError: # e.g. "TypeError: unorderable types: NoneType() < int()" locations = message.locations