diff options
author | Vinay Sajip <vinay_sajip@yahoo.co.uk> | 2006-01-16 09:27:10 +0000 |
---|---|---|
committer | Vinay Sajip <vinay_sajip@yahoo.co.uk> | 2006-01-16 09:27:10 +0000 |
commit | b0c7fede00dbe73936773278ff22cf6392fbe372 (patch) | |
tree | 282f9bd7eb6ae09655f6b39c5378e1f5390aea42 /Lib/logging | |
parent | 4badbf4ab76c225e12c5d03fe84d464db80a1742 (diff) | |
download | cpython-b0c7fede00dbe73936773278ff22cf6392fbe372.tar.gz |
Exceptions raised during renaming in rotating file handlers are now passed to handleError (except for SystemExit and KeyboardInterrupt, which are re-raised).
Diffstat (limited to 'Lib/logging')
-rw-r--r-- | Lib/logging/handlers.py | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/Lib/logging/handlers.py b/Lib/logging/handlers.py index c6b526a9c6..9e1bec1c62 100644 --- a/Lib/logging/handlers.py +++ b/Lib/logging/handlers.py @@ -126,7 +126,12 @@ class RotatingFileHandler(BaseRotatingHandler): dfn = self.baseFilename + ".1" if os.path.exists(dfn): os.remove(dfn) - os.rename(self.baseFilename, dfn) + try: + os.rename(self.baseFilename, dfn) + except (KeyboardInterrupt, SystemExit): + raise + except: + pass #print "%s -> %s" % (self.baseFilename, dfn) if self.encoding: self.stream = codecs.open(self.baseFilename, 'w', self.encoding) @@ -270,7 +275,12 @@ class TimedRotatingFileHandler(BaseRotatingHandler): dfn = self.baseFilename + "." + time.strftime(self.suffix, timeTuple) if os.path.exists(dfn): os.remove(dfn) - os.rename(self.baseFilename, dfn) + try: + os.rename(self.baseFilename, dfn) + except (KeyboardInterrupt, SystemExit): + raise + except: + pass if self.backupCount > 0: # find the oldest log file and delete it s = glob.glob(self.baseFilename + ".20*") |