From: andrei kulakov Date: Thu, 15 Jul 2021 10:53:26 +0000 (-0400) Subject: bpo-42799: fnmatch module: bump up size of lru_cache for patterns (GH-27084) X-Git-Tag: v3.11.0a1~672 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=b39eea06d148887dd91a3612febafbddda760593;p=thirdparty%2FPython%2Fcpython.git bpo-42799: fnmatch module: bump up size of lru_cache for patterns (GH-27084) --- diff --git a/Doc/library/fnmatch.rst b/Doc/library/fnmatch.rst index 925f08e91468..9163da57c7b9 100644 --- a/Doc/library/fnmatch.rst +++ b/Doc/library/fnmatch.rst @@ -46,6 +46,9 @@ module. See module :mod:`glob` for pathname expansion (:mod:`glob` uses a period are not special for this module, and are matched by the ``*`` and ``?`` patterns. +Also note that :func:`functools.lru_cache` with the *maxsize* of 32768 is used to +cache the compiled regex patterns in the following functions: :func:`fnmatch`, +:func:`fnmatchcase`, :func:`filter`. .. function:: fnmatch(filename, pattern) diff --git a/Lib/fnmatch.py b/Lib/fnmatch.py index 7c52c23067d4..239c7490d49e 100644 --- a/Lib/fnmatch.py +++ b/Lib/fnmatch.py @@ -41,7 +41,7 @@ def fnmatch(name, pat): pat = os.path.normcase(pat) return fnmatchcase(name, pat) -@functools.lru_cache(maxsize=256, typed=True) +@functools.lru_cache(maxsize=32768, typed=True) def _compile_pattern(pat): if isinstance(pat, bytes): pat_str = str(pat, 'ISO-8859-1') diff --git a/Misc/NEWS.d/next/Library/2021-07-10-19-55-13.bpo-42799.ad4tq8.rst b/Misc/NEWS.d/next/Library/2021-07-10-19-55-13.bpo-42799.ad4tq8.rst new file mode 100644 index 000000000000..8a25800611a5 --- /dev/null +++ b/Misc/NEWS.d/next/Library/2021-07-10-19-55-13.bpo-42799.ad4tq8.rst @@ -0,0 +1,4 @@ +In :mod:`fnmatch`, the cache size for compiled regex patterns +(:func:`functools.lru_cache`) was bumped up from 256 to 32768, affecting +functions: :func:`fnmatch.fnmatch`, :func:`fnmatch.fnmatchcase`, +:func:`fnmatch.filter`.