mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #12746 -- Updated sorting calls to use 'key' instead of 'cmp'. This will be slightly faster in certain circumstances, but more importantly, is a required step for migration to Python 3. Thanks to Martin van Loewis for the patch.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@13509 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -35,7 +35,7 @@ def get_declared_fields(bases, attrs, with_base_fields=True): | ||||
|     Also integrates any additional media definitions | ||||
|     """ | ||||
|     fields = [(field_name, attrs.pop(field_name)) for field_name, obj in attrs.items() if isinstance(obj, Field)] | ||||
|     fields.sort(lambda x, y: cmp(x[1].creation_counter, y[1].creation_counter)) | ||||
|     fields.sort(key=lambda x: x[1].creation_counter) | ||||
|  | ||||
|     # If this class is subclassing another Form, add that Form's fields. | ||||
|     # Note that we loop over the bases in *reverse*. This is necessary in | ||||
|   | ||||
| @@ -199,14 +199,12 @@ class BaseFormSet(StrAndUnicode): | ||||
|             # A sort function to order things numerically ascending, but | ||||
|             # None should be sorted below anything else. Allowing None as | ||||
|             # a comparison value makes it so we can leave ordering fields | ||||
|             # blamk. | ||||
|             def compare_ordering_values(x, y): | ||||
|                 if x[1] is None: | ||||
|                     return 1 | ||||
|                 if y[1] is None: | ||||
|                     return -1 | ||||
|                 return x[1] - y[1] | ||||
|             self._ordering.sort(compare_ordering_values) | ||||
|             # blank. | ||||
|             def compare_ordering_key(k): | ||||
|                 if k[1] is None: | ||||
|                     return (1, 0) # +infinity, larger than any number | ||||
|                 return (0, k[1]) | ||||
|             self._ordering.sort(key=compare_ordering_key) | ||||
|         # Return a list of form.cleaned_data dicts in the order spcified by | ||||
|         # the form data. | ||||
|         return [self.forms[i[0]] for i in self._ordering] | ||||
|   | ||||
		Reference in New Issue
	
	Block a user