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 | |
| 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')
| -rw-r--r-- | djangorestframework/parsers.py | 23 | ||||
| -rw-r--r-- | djangorestframework/renderers.py | 25 | 
2 files changed, 43 insertions, 5 deletions
diff --git a/djangorestframework/parsers.py b/djangorestframework/parsers.py index 3346a26e..a25ca89e 100644 --- a/djangorestframework/parsers.py +++ b/djangorestframework/parsers.py @@ -18,12 +18,15 @@ from djangorestframework import status  from djangorestframework.response import ErrorResponse  from djangorestframework.utils.mediatypes import media_type_matches +import yaml +  __all__ = (      'BaseParser',      'JSONParser',      'PlainTextParser',      'FormParser',      'MultiPartParser', +    'YAMLParser',  ) @@ -84,6 +87,26 @@ class JSONParser(BaseParser):                                  {'detail': 'JSON parse error - %s' % unicode(exc)}) +class YAMLParser(BaseParser): +    """ +    Parses YAML-serialized data. +    """ + +    media_type = 'application/yaml' + +    def parse(self, stream): +        """ +        Returns a 2-tuple of `(data, files)`. + +        `data` will be an object which is the parsed content of the response. +        `files` will always be `None`. +        """ +        try: +            return (yaml.safe_load(stream), None) +        except ValueError, exc: +            raise ErrorResponse(status.HTTP_400_BAD_REQUEST, +                                {'detail': 'YAML parse error - %s' % unicode(exc)}) +  class PlainTextParser(BaseParser):      """ 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 )  | 
