diff options
| author | Tom Christie | 2013-05-18 11:27:48 +0100 |
|---|---|---|
| committer | Tom Christie | 2013-05-18 11:27:48 +0100 |
| commit | a73c16b85f79aeb9139734a64623b49bc169fce9 (patch) | |
| tree | 9abfe20aa5b49073a591c4ccf934db8bac946223 /rest_framework/fields.py | |
| parent | b950b025bc66e3018d5f74e1494ff17f7742be75 (diff) | |
| download | django-rest-framework-a73c16b85f79aeb9139734a64623b49bc169fce9.tar.bz2 | |
serializers.Field respects ordering on dicts if it exists. Closes #832
Diffstat (limited to 'rest_framework/fields.py')
| -rw-r--r-- | rest_framework/fields.py | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/rest_framework/fields.py b/rest_framework/fields.py index c83ee5ec..49d2a6d5 100644 --- a/rest_framework/fields.py +++ b/rest_framework/fields.py @@ -19,6 +19,7 @@ from django import forms from django.forms import widgets from django.utils.encoding import is_protected_type from django.utils.translation import ugettext_lazy as _ +from django.utils.datastructures import SortedDict from rest_framework import ISO_8601 from rest_framework.compat import timezone, parse_date, parse_datetime, parse_time @@ -170,7 +171,11 @@ class Field(object): elif hasattr(value, '__iter__') and not isinstance(value, (dict, six.string_types)): return [self.to_native(item) for item in value] elif isinstance(value, dict): - return dict(map(self.to_native, (k, v)) for k, v in value.items()) + # Make sure we preserve field ordering, if it exists + ret = SortedDict() + for key, val in value.items(): + ret[key] = self.to_native(val) + return ret return smart_text(value) def attributes(self): |
