diff options
| author | Raymond Hettinger <python@rcn.com> | 2011-10-15 23:50:42 -0700 |
|---|---|---|
| committer | Raymond Hettinger <python@rcn.com> | 2011-10-15 23:50:42 -0700 |
| commit | 4b779b3785c0014224eef95c8805f166d0ef2a86 (patch) | |
| tree | 30b3372cbf7db8e7c46ece24f2811991bb44967d /Lib/functools.py | |
| parent | 9be57231dd6a3b69bda09e53e5f751aafaf89b51 (diff) | |
| download | cpython-git-4b779b3785c0014224eef95c8805f166d0ef2a86.tar.gz | |
Issue 13177: Make tracebacks more readable by avoiding chained exceptions in the lru_cache.
Diffstat (limited to 'Lib/functools.py')
| -rw-r--r-- | Lib/functools.py | 34 |
1 files changed, 19 insertions, 15 deletions
diff --git a/Lib/functools.py b/Lib/functools.py index 03bcb1e69f..85ea257abd 100644 --- a/Lib/functools.py +++ b/Lib/functools.py @@ -141,7 +141,7 @@ def lru_cache(maxsize=100): hits = misses = 0 kwd_mark = (object(),) # separates positional and keyword args - lock = Lock() # needed because ordereddicts aren't threadsafe + lock = Lock() # needed because OrderedDict isn't threadsafe if maxsize is None: cache = dict() # simple cache without ordering or size limit @@ -155,13 +155,15 @@ def lru_cache(maxsize=100): try: result = cache[key] hits += 1 + return result except KeyError: - result = user_function(*args, **kwds) - cache[key] = result - misses += 1 + pass + result = user_function(*args, **kwds) + cache[key] = result + misses += 1 return result else: - cache = OrderedDict() # ordered least recent to most recent + cache = OrderedDict() # ordered least recent to most recent cache_popitem = cache.popitem cache_renew = cache.move_to_end @@ -171,18 +173,20 @@ def lru_cache(maxsize=100): key = args if kwds: key += kwd_mark + tuple(sorted(kwds.items())) - try: - with lock: + with lock: + try: result = cache[key] - cache_renew(key) # record recent use of this key + cache_renew(key) # record recent use of this key hits += 1 - except KeyError: - result = user_function(*args, **kwds) - with lock: - cache[key] = result # record recent use of this key - misses += 1 - if len(cache) > maxsize: - cache_popitem(0) # purge least recently used cache entry + return result + except KeyError: + pass + result = user_function(*args, **kwds) + with lock: + cache[key] = result # record recent use of this key + misses += 1 + if len(cache) > maxsize: + cache_popitem(0) # purge least recently used cache entry return result def cache_info(): |
