aboutsummaryrefslogtreecommitdiffstats
path: root/rest_framework
diff options
context:
space:
mode:
authorTom Christie2012-10-05 14:22:02 +0100
committerTom Christie2012-10-05 14:22:02 +0100
commit3e862c77379b2f84356e2e8f0be20b7aca5b9e89 (patch)
tree73b42ff68ddf94ead735b808eaa9bf567f86b04a /rest_framework
parent6a15556384c48984868493b6b38a7afa61d77a3a (diff)
downloaddjango-rest-framework-3e862c77379b2f84356e2e8f0be20b7aca5b9e89.tar.bz2
Tweak view slightly
Diffstat (limited to 'rest_framework')
-rw-r--r--rest_framework/generics.py2
-rw-r--r--rest_framework/views.py12
2 files changed, 10 insertions, 4 deletions
diff --git a/rest_framework/generics.py b/rest_framework/generics.py
index 901d23d1..44f677cc 100644
--- a/rest_framework/generics.py
+++ b/rest_framework/generics.py
@@ -23,7 +23,7 @@ class BaseView(views.APIView):
"""
return {
'request': self.request,
- 'format': self.format,
+ 'format': self.format_kwarg,
'view': self
}
diff --git a/rest_framework/views.py b/rest_framework/views.py
index 0359c225..166bf0b1 100644
--- a/rest_framework/views.py
+++ b/rest_framework/views.py
@@ -162,13 +162,19 @@ class APIView(View):
"""
return [throttle(self) for throttle in self.throttle_classes]
+ def get_content_negotiator(self):
+ """
+ Instantiate and return the content negotiation class to use.
+ """
+ return self.content_negotiation_class()
+
def perform_content_negotiation(self, request, force=False):
"""
Determine which renderer and media type to use render the response.
"""
renderers = self.get_renderers()
- conneg = self.content_negotiation_class()
- return conneg.negotiate(request, renderers, self.format, force)
+ conneg = self.get_content_negotiator()
+ return conneg.negotiate(request, renderers, self.format_kwarg, force)
def has_permission(self, request, obj=None):
"""
@@ -198,7 +204,7 @@ class APIView(View):
"""
Runs anything that needs to occur prior to calling the method handlers.
"""
- self.format = self.get_format_suffix(**kwargs)
+ self.format_kwarg = self.get_format_suffix(**kwargs)
if not self.has_permission(request):
self.permission_denied(request)