From: Alex Waygood Date: Mon, 7 Aug 2023 12:46:36 +0000 (+0100) Subject: gh-85160: Reduce memory usage of `singledispatchmethod` (#107706) X-Git-Tag: v3.13.0a1~1053 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=2ac103c346ffe9d0e4c146402ce215c5ce6c1ef2;p=thirdparty%2FPython%2Fcpython.git gh-85160: Reduce memory usage of `singledispatchmethod` (#107706) A small followup to #107148 Co-authored-by: Serhiy Storchaka --- diff --git a/Lib/functools.py b/Lib/functools.py index 2a8a69b3c527..be44ccdae6b6 100644 --- a/Lib/functools.py +++ b/Lib/functools.py @@ -928,14 +928,14 @@ class singledispatchmethod: """ def __init__(self, func): - import weakref # see comment in singledispatch function if not callable(func) and not hasattr(func, "__get__"): raise TypeError(f"{func!r} is not callable or a descriptor") self.dispatcher = singledispatch(func) self.func = func + + import weakref # see comment in singledispatch function self._method_cache = weakref.WeakKeyDictionary() - self._all_weakrefable_instances = True def register(self, cls, method=None): """generic_method.register(cls, func) -> func @@ -945,11 +945,11 @@ class singledispatchmethod: return self.dispatcher.register(cls, func=method) def __get__(self, obj, cls=None): - if self._all_weakrefable_instances: + if self._method_cache is not None: try: _method = self._method_cache[obj] except TypeError: - self._all_weakrefable_instances = False + self._method_cache = None except KeyError: pass else: @@ -963,7 +963,7 @@ class singledispatchmethod: _method.register = self.register update_wrapper(_method, self.func) - if self._all_weakrefable_instances: + if self._method_cache is not None: self._method_cache[obj] = _method return _method