aboutsummaryrefslogtreecommitdiffstats
path: root/rest_framework/serializers.py
diff options
context:
space:
mode:
authorTom Christie2015-02-06 00:05:59 +0000
committerTom Christie2015-02-06 00:05:59 +0000
commit1fdfea275844acbbb81c3af7db88375af70d252b (patch)
tree34abccf42f2ff40138e62c2d55b331c48f81a313 /rest_framework/serializers.py
parentb11a98f1e765b0b3c11cd353405bde8379057194 (diff)
parentf1e7ce54a1c841bb4cc009e110bebd4435bb5c7e (diff)
downloaddjango-rest-framework-1fdfea275844acbbb81c3af7db88375af70d252b.tar.bz2
Merge branch 'version-3.1' of https://github.com/tomchristie/django-rest-framework into version-3.1
Diffstat (limited to 'rest_framework/serializers.py')
-rw-r--r--rest_framework/serializers.py11
1 files changed, 11 insertions, 0 deletions
diff --git a/rest_framework/serializers.py b/rest_framework/serializers.py
index a91fe23e..18821958 100644
--- a/rest_framework/serializers.py
+++ b/rest_framework/serializers.py
@@ -986,15 +986,25 @@ class ModelSerializer(Serializer):
# Fields with choices get coerced into `ChoiceField`
# instead of using their regular typed field.
field_class = ChoiceField
+
if not issubclass(field_class, ModelField):
# `model_field` is only valid for the fallback case of
# `ModelField`, which is used when no other typed field
# matched to the model field.
field_kwargs.pop('model_field', None)
+
if not issubclass(field_class, CharField) and not issubclass(field_class, ChoiceField):
# `allow_blank` is only valid for textual fields.
field_kwargs.pop('allow_blank', None)
+ if postgres_fields and isinstance(model_field, postgres_fields.ArrayField):
+ child_model_field = model_field.base_field
+ child_field_class, child_field_kwargs = self.build_standard_field(
+ 'child', child_model_field
+ )
+
+ field_kwargs['child'] = child_field_class(**child_field_kwargs)
+
return field_class, field_kwargs
def build_relational_field(self, field_name, relation_info):
@@ -1337,6 +1347,7 @@ if postgres_fields:
child = CharField()
ModelSerializer.serializer_field_mapping[postgres_fields.HStoreField] = CharMappingField
+ ModelSerializer.serializer_field_mapping[postgres_fields.ArrayField] = ListField
class HyperlinkedModelSerializer(ModelSerializer):