diff options
| author | markotibold | 2011-06-26 01:34:52 +0200 |
|---|---|---|
| committer | markotibold | 2011-06-26 01:34:52 +0200 |
| commit | 7f536c1db3950bff2486fd243748f833565c9155 (patch) | |
| tree | b92dda970166130d1009a6fe8d77dbf34b171fce /djangorestframework/renderers.py | |
| parent | 0b18b58c170aae0c2a93a608997e557fdcefe826 (diff) | |
| download | django-rest-framework-7f536c1db3950bff2486fd243748f833565c9155.tar.bz2 | |
Very basic YAML support. Probably needs some tweaking, and definitely needs tests.
Diffstat (limited to 'djangorestframework/renderers.py')
| -rw-r--r-- | djangorestframework/renderers.py | 25 |
1 files changed, 20 insertions, 5 deletions
diff --git a/djangorestframework/renderers.py b/djangorestframework/renderers.py index 13cd52f5..18ffbf66 100644 --- a/djangorestframework/renderers.py +++ b/djangorestframework/renderers.py @@ -11,7 +11,7 @@ from django.core.serializers.json import DateTimeAwareJSONEncoder from django.template import RequestContext, loader from django.utils import simplejson as json -from djangorestframework import status + from djangorestframework.compat import apply_markdown from djangorestframework.utils import dict2xml, url_resolves from djangorestframework.utils.breadcrumbs import get_breadcrumbs @@ -19,10 +19,9 @@ from djangorestframework.utils.description import get_name, get_description from djangorestframework.utils.mediatypes import get_media_type_params, add_media_type_param, media_type_matches from djangorestframework import VERSION -from decimal import Decimal -import re import string from urllib import quote_plus +import yaml __all__ = ( 'BaseRenderer', @@ -31,7 +30,8 @@ __all__ = ( 'DocumentingHTMLRenderer', 'DocumentingXHTMLRenderer', 'DocumentingPlainTextRenderer', - 'XMLRenderer' + 'XMLRenderer', + 'YAMLRenderer' ) @@ -120,6 +120,20 @@ class XMLRenderer(BaseRenderer): return '' return dict2xml(obj) +class YAMLRenderer(BaseRenderer): + """ + Renderer which serializes to YAML. + """ + + media_type = 'application/yaml' + + def render(self, obj=None, media_type=None): + """ + Renders *obj* into serialized YAML. + """ + if obj is None: + return '' + return yaml.dump(obj) class TemplateRenderer(BaseRenderer): """ @@ -346,6 +360,7 @@ DEFAULT_RENDERERS = ( JSONRenderer, DocumentingHTMLRenderer, DocumentingXHTMLRenderer, DocumentingPlainTextRenderer, - XMLRenderer ) + XMLRenderer, + YAMLRenderer ) |
