diff options
| author | Benjamin Woodruff <github@benjam.info> | 2019-05-06 16:53:40 -0400 |
|---|---|---|
| committer | Mariusz Felisiak <felisiak.mariusz@gmail.com> | 2019-07-03 11:37:28 +0200 |
| commit | 54dcfbc36780054d39299bfd1078938e5dd4e839 (patch) | |
| tree | 6e5f7744dc1d8cf5b41f71d5374a1206b4ceacc2 /django/urls | |
| parent | 55b68de643b5c2d5f0a8ea7587ab3b2966021ccc (diff) | |
Fixed #29744 -- Fixed caching of URLResolver for a default URLconf.
get_resolver() for a default URLconf (passing no argument) and for
settings.ROOT_URLCONF should return the same cached object.
Diffstat (limited to 'django/urls')
| -rw-r--r-- | django/urls/base.py | 4 | ||||
| -rw-r--r-- | django/urls/resolvers.py | 6 |
2 files changed, 7 insertions, 3 deletions
diff --git a/django/urls/base.py b/django/urls/base.py index 0e1c3d909c..dd9b2e4c22 100644 --- a/django/urls/base.py +++ b/django/urls/base.py @@ -7,7 +7,7 @@ from django.utils.functional import lazy from django.utils.translation import override from .exceptions import NoReverseMatch, Resolver404 -from .resolvers import get_ns_resolver, get_resolver +from .resolvers import _get_cached_resolver, get_ns_resolver, get_resolver from .utils import get_callable # SCRIPT_NAME prefixes for each thread are stored here. If there's no entry for @@ -92,7 +92,7 @@ reverse_lazy = lazy(reverse, str) def clear_url_caches(): get_callable.cache_clear() - get_resolver.cache_clear() + _get_cached_resolver.cache_clear() get_ns_resolver.cache_clear() diff --git a/django/urls/resolvers.py b/django/urls/resolvers.py index 247e3680c0..2154a46320 100644 --- a/django/urls/resolvers.py +++ b/django/urls/resolvers.py @@ -63,10 +63,14 @@ class ResolverMatch: ) -@functools.lru_cache(maxsize=None) def get_resolver(urlconf=None): if urlconf is None: urlconf = settings.ROOT_URLCONF + return _get_cached_resolver(urlconf) + + +@functools.lru_cache(maxsize=None) +def _get_cached_resolver(urlconf=None): return URLResolver(RegexPattern(r'^/'), urlconf) |
