diff options
| author | Brandon Cazander | 2015-01-28 17:08:34 -0800 |
|---|---|---|
| committer | Brandon Cazander | 2015-02-02 20:37:33 -0800 |
| commit | 77d061d234e03004f34058028707ecddfc730fae (patch) | |
| tree | b67e2414ba475a2122cb46dcd737b1a39b92911e /rest_framework/reverse.py | |
| parent | e63f49bd1d55501f766ca2e3f9c0c9fa3cfa19ab (diff) | |
| download | django-rest-framework-77d061d234e03004f34058028707ecddfc730fae.tar.bz2 | |
Provide rest_framework.resolve. Fixes #2489
Diffstat (limited to 'rest_framework/reverse.py')
| -rw-r--r-- | rest_framework/reverse.py | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/rest_framework/reverse.py b/rest_framework/reverse.py index 8fcca55b..0d1d94a7 100644 --- a/rest_framework/reverse.py +++ b/rest_framework/reverse.py @@ -1,12 +1,25 @@ """ -Provide reverse functions that return fully qualified URLs +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 resolve as django_resolve from django.utils import six from django.utils.functional import lazy +def resolve(path, urlconf=None, request=None): + """ + If versioning is being used then we pass any `resolve` calls through + to the versioning scheme instance, so that the resulting view name + can be modified if needed. + """ + scheme = getattr(request, 'versioning_scheme', None) + if scheme is not None: + return scheme.resolve(path, urlconf, request) + return django_resolve(path, urlconf) + + def reverse(viewname, args=None, kwargs=None, request=None, format=None, **extra): """ If versioning is being used then we pass any `reverse` calls through |
