diff options
| author | Tom Christie | 2015-03-23 11:35:21 +0000 |
|---|---|---|
| committer | Tom Christie | 2015-03-23 11:35:21 +0000 |
| commit | a90dbe3bd9ce88a6837d7d20f3e904f43d68c996 (patch) | |
| tree | 4c4b2ef3b22e24645d3ce9314855368c239d64c1 /rest_framework/reverse.py | |
| parent | f7cd7a1c1fca4c7f0e38c5ed1762f5f498bf37a3 (diff) | |
| parent | fac27853418699116304ad8d77270fe9a20873dc (diff) | |
| download | django-rest-framework-a90dbe3bd9ce88a6837d7d20f3e904f43d68c996.tar.bz2 | |
Merge pull request #2724 from delinhabit/namespaced-versioning-non-api-reversal
Handle reversal of non-API view_name in HyperLinkedRelatedField
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) |
