summaryrefslogtreecommitdiff
path: root/Lib/logging/handlers.py
diff options
context:
space:
mode:
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>2021-10-29 08:25:31 -0700
committerGitHub <noreply@github.com>2021-10-29 16:25:31 +0100
commit191a93905a84f272b2232701dc5dcc69987330f5 (patch)
tree5d517ce51fffee5e9edd0b6cf1dfe1ce0cdc3c85 /Lib/logging/handlers.py
parent6742b0dfb61ebdb92a1ff633ec071734b5d39981 (diff)
downloadcpython-git-191a93905a84f272b2232701dc5dcc69987330f5.tar.gz
[3.10] bpo-45628: Check all parts of the suffix for an extension match. (GH-29310) (GH-29314)
Diffstat (limited to 'Lib/logging/handlers.py')
-rw-r--r--Lib/logging/handlers.py9
1 files changed, 7 insertions, 2 deletions
diff --git a/Lib/logging/handlers.py b/Lib/logging/handlers.py
index 4dcbe4530f..4e8f0a8cc2 100644
--- a/Lib/logging/handlers.py
+++ b/Lib/logging/handlers.py
@@ -371,8 +371,13 @@ class TimedRotatingFileHandler(BaseRotatingHandler):
for fileName in fileNames:
if fileName[:plen] == prefix:
suffix = fileName[plen:]
- if self.extMatch.match(suffix):
- result.append(os.path.join(dirName, fileName))
+ # See bpo-45628: The date/time suffix could be anywhere in the
+ # filename
+ parts = suffix.split('.')
+ for part in parts:
+ if self.extMatch.match(part):
+ result.append(os.path.join(dirName, fileName))
+ break
if len(result) < self.backupCount:
result = []
else: