From e23cbba35eac0ece8a84df1184d2e32976cbbd1b Mon Sep 17 00:00:00 2001 From: "Jason R. Coombs" Date: Fri, 13 Sep 2024 10:04:31 -0400 Subject: [PATCH] Rely on cached_property to cache values on the instance. --- newsfragments/+f9a115e5.feature.rst | 1 + zipp/__init__.py | 20 +++++++++++--------- 2 files changed, 12 insertions(+), 9 deletions(-) create mode 100644 newsfragments/+f9a115e5.feature.rst diff --git a/newsfragments/+f9a115e5.feature.rst b/newsfragments/+f9a115e5.feature.rst new file mode 100644 index 0000000..8e692a2 --- /dev/null +++ b/newsfragments/+f9a115e5.feature.rst @@ -0,0 +1 @@ +Rely on cached_property to cache values on the instance. \ No newline at end of file diff --git a/zipp/__init__.py b/zipp/__init__.py index 20b6d04..d5b96b8 100644 --- a/zipp/__init__.py +++ b/zipp/__init__.py @@ -7,7 +7,7 @@ for more detail. """ -import contextlib +import functools import io import itertools import pathlib @@ -181,16 +181,18 @@ class FastLookup(CompleteDirs): """ def namelist(self): - with contextlib.suppress(AttributeError): - return self.__names - self.__names = super().namelist() - return self.__names + return self._namelist + + @functools.cached_property + def _namelist(self): + return super().namelist() def _name_set(self): - with contextlib.suppress(AttributeError): - return self.__lookup - self.__lookup = super()._name_set() - return self.__lookup + return self._name_set_prop + + @functools.cached_property + def _name_set_prop(self): + return super()._name_set() def _extract_text_encoding(encoding=None, *args, **kwargs):