mirror of
				https://github.com/python/cpython.git
				synced 2025-10-26 19:24:34 +00:00 
			
		
		
		
	Consistently move the misses update to just before the user function call (GH-11715)
This commit is contained in:
		
							parent
							
								
									dcfcd146f8
								
							
						
					
					
						commit
						ffdf1c30ab
					
				
					 2 changed files with 8 additions and 6 deletions
				
			
		|  | @ -541,10 +541,10 @@ def _lru_cache_wrapper(user_function, maxsize, typed, _CacheInfo): | |||
|     if maxsize == 0: | ||||
| 
 | ||||
|         def wrapper(*args, **kwds): | ||||
|             # No caching -- just a statistics update after a successful call | ||||
|             # No caching -- just a statistics update | ||||
|             nonlocal misses | ||||
|             result = user_function(*args, **kwds) | ||||
|             misses += 1 | ||||
|             result = user_function(*args, **kwds) | ||||
|             return result | ||||
| 
 | ||||
|     elif maxsize is None: | ||||
|  | @ -557,9 +557,9 @@ def wrapper(*args, **kwds): | |||
|             if result is not sentinel: | ||||
|                 hits += 1 | ||||
|                 return result | ||||
|             misses += 1 | ||||
|             result = user_function(*args, **kwds) | ||||
|             cache[key] = result | ||||
|             misses += 1 | ||||
|             return result | ||||
| 
 | ||||
|     else: | ||||
|  |  | |||
|  | @ -796,10 +796,12 @@ lru_cache_make_key(PyObject *args, PyObject *kwds, int typed) | |||
| static PyObject * | ||||
| uncached_lru_cache_wrapper(lru_cache_object *self, PyObject *args, PyObject *kwds) | ||||
| { | ||||
|     PyObject *result = PyObject_Call(self->func, args, kwds); | ||||
|     PyObject *result; | ||||
| 
 | ||||
|     self->misses++; | ||||
|     result = PyObject_Call(self->func, args, kwds); | ||||
|     if (!result) | ||||
|         return NULL; | ||||
|     self->misses++; | ||||
|     return result; | ||||
| } | ||||
| 
 | ||||
|  | @ -827,6 +829,7 @@ infinite_lru_cache_wrapper(lru_cache_object *self, PyObject *args, PyObject *kwd | |||
|         Py_DECREF(key); | ||||
|         return NULL; | ||||
|     } | ||||
|     self->misses++; | ||||
|     result = PyObject_Call(self->func, args, kwds); | ||||
|     if (!result) { | ||||
|         Py_DECREF(key); | ||||
|  | @ -838,7 +841,6 @@ infinite_lru_cache_wrapper(lru_cache_object *self, PyObject *args, PyObject *kwd | |||
|         return NULL; | ||||
|     } | ||||
|     Py_DECREF(key); | ||||
|     self->misses++; | ||||
|     return result; | ||||
| } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Raymond Hettinger
						Raymond Hettinger