aboutsummaryrefslogtreecommitdiffstats
path: root/rest_framework
diff options
context:
space:
mode:
authorTom Christie2015-03-23 11:37:28 +0000
committerTom Christie2015-03-23 11:37:28 +0000
commit54eea7f14a656d14142492f336e42ee9c8e2c0eb (patch)
tree3ef87988ab8207aa8caca225000bbbb5fe9b194b /rest_framework
parent35a0cbb911c641027e9123cbbb67a186e8a80072 (diff)
parenta90dbe3bd9ce88a6837d7d20f3e904f43d68c996 (diff)
downloaddjango-rest-framework-54eea7f14a656d14142492f336e42ee9c8e2c0eb.tar.bz2
Merge branch 'master' of https://github.com/tomchristie/django-rest-framework
Diffstat (limited to 'rest_framework')
-rw-r--r--rest_framework/reverse.py9
1 files changed, 8 insertions, 1 deletions
diff --git a/rest_framework/reverse.py b/rest_framework/reverse.py
index a251d99d..e6d3f563 100644
--- a/rest_framework/reverse.py
+++ b/rest_framework/reverse.py
@@ -3,6 +3,7 @@ Provide urlresolver functions that return fully qualified URLs or view names
"""
from __future__ import unicode_literals
from django.core.urlresolvers import reverse as django_reverse
+from django.core.urlresolvers import NoReverseMatch
from django.utils import six
from django.utils.functional import lazy
@@ -15,7 +16,13 @@ def reverse(viewname, args=None, kwargs=None, request=None, format=None, **extra
"""
scheme = getattr(request, 'versioning_scheme', None)
if scheme is not None:
- return scheme.reverse(viewname, args, kwargs, request, format, **extra)
+ try:
+ return scheme.reverse(viewname, args, kwargs, request, format, **extra)
+ except NoReverseMatch:
+ # In case the versioning scheme reversal fails, fallback to the
+ # default implementation
+ pass
+
return _reverse(viewname, args, kwargs, request, format, **extra)