diff options
| author | Ion Scerbatiuc | 2015-03-19 16:12:28 -0700 | 
|---|---|---|
| committer | Ion Scerbatiuc | 2015-03-19 16:12:28 -0700 | 
| commit | fac27853418699116304ad8d77270fe9a20873dc (patch) | |
| tree | 6db53170c36e093ea308ab4d81cd6e20030c1a13 /rest_framework/reverse.py | |
| parent | 90280a343746f662ac2e7da4844828a61253c77d (diff) | |
| download | django-rest-framework-fac27853418699116304ad8d77270fe9a20873dc.tar.bz2 | |
Handling the fallback in `reverse`
Diffstat (limited to 'rest_framework/reverse.py')
| -rw-r--r-- | rest_framework/reverse.py | 9 | 
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) | 
