diff options
| author | Pablo Recio | 2013-05-18 12:51:40 +0200 |
|---|---|---|
| committer | Pablo Recio | 2013-05-18 12:51:40 +0200 |
| commit | 53a80044016c2ea0f4551735b0f974d1571d52ee (patch) | |
| tree | b79711fc0854ea614f8a51c850fda870e4d07630 /rest_framework/fields.py | |
| parent | ab8bd566f9db327a4c463317011818d421bbf89c (diff) | |
| parent | 2a3056d03844a31373f1e30aec58e70616115838 (diff) | |
| download | django-rest-framework-53a80044016c2ea0f4551735b0f974d1571d52ee.tar.bz2 | |
Merge branch 'master' into 725-blank-choice-dash
Conflicts:
rest_framework/tests/fields.py
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 7fd4c638..9bbe6633 100644 --- a/rest_framework/fields.py +++ b/rest_framework/fields.py @@ -20,6 +20,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 @@ -171,7 +172,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): |
