Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/sugar
diff options
context:
space:
mode:
authorKonrad Kleine <konrad.kleine@gmx.de>2007-05-29 16:11:57 (GMT)
committer Marco Pesenti Gritti <marco@localhost.localdomain>2007-05-29 19:28:59 (GMT)
commit76d3e783021de39caf1125ffb566b478d0bd091f (patch)
treea08b8cb04022ee93e7aa5b73d3c06317960b43a1 /sugar
parentb1ed24498c94df1182ead21e79c646924fd9d432 (diff)
Bug #590 fixed.
All logfiles will be backed up to ~./sugar/default/logs/old . You can adjust the backup directory and the number of backup versions. You can also adjust the file suffix for the backup files. Konrad Kleine
Diffstat (limited to 'sugar')
-rw-r--r--sugar/logger.py61
1 files changed, 58 insertions, 3 deletions
diff --git a/sugar/logger.py b/sugar/logger.py
index fa2e28f..6bec4c6 100644
--- a/sugar/logger.py
+++ b/sugar/logger.py
@@ -21,6 +21,7 @@ import os
import logging
import traceback
from cStringIO import StringIO
+import time
from sugar import env
@@ -113,6 +114,60 @@ def start(module_id):
sys.excepthook = __exception_handler
def cleanup():
- logs_dir = _get_logs_dir()
- for f in os.listdir(logs_dir):
- os.remove(os.path.join(logs_dir, f))
+ logs_dir = _get_logs_dir()
+
+ #---------------------------------------------------------
+ # Configure logfile backups
+ #---------------------------------------------------------
+ # File extension for backed up logfiles.
+ file_suffix = int( time.time() )
+ # Absolute directory path where to store old logfiles.
+ # It will be created recursivly if it's not present.
+ backup_dirpath = os.path.join(logs_dir, 'old')
+ # How many versions shall be backed up of every logfile?
+ num_backup_versions = 4
+ #---------------------------------------------------------
+
+ # Make sure the backup location for old log files exists
+ if not os.path.exists(backup_dirpath):
+ os.makedirs(backup_dirpath)
+
+ # Iterate over every item in 'logs' directory
+ for filename in os.listdir(logs_dir):
+
+ old_filepath = os.path.join(logs_dir, filename)
+
+ if os.path.isfile(old_filepath):
+ # Backup every file
+ new_filename = filename + '.' + str(file_suffix)
+ new_filepath = os.path.join(backup_dirpath, new_filename)
+ os.rename(old_filepath, new_filepath)
+
+ backup_map = {}
+
+ # Tempoarily map all backup logfiles
+ for filename in os.listdir(backup_dirpath):
+ # Remove the 'file_suffix' from the filename.
+ end = filename.rfind(".")
+ key = filename[0:end].lower()
+ key = key.replace(".", "_")
+
+ if key not in backup_map:
+ backup_map[key] = []
+
+ backup_list = backup_map[key]
+
+ backup_list.append( os.path.join(backup_dirpath, filename) )
+
+ print backup_map
+
+ # Only keep 'num_backup_versions' versions of every logfile.
+ # Remove the others.
+ for key in backup_map:
+ backup_list = backup_map[key]
+ backup_list.sort()
+ backup_list.reverse()
+
+ for i in range(num_backup_versions, len(backup_list)):
+ os.remove(backup_list[i])
+ \ No newline at end of file