From e92ad9e6fe0dc9088ed440470efef1aedc0ea500 Mon Sep 17 00:00:00 2001 From: Thor77 Date: Mon, 20 Jun 2016 21:31:59 +0200 Subject: [PATCH] update scope of tsstats.log._sort_logs (rename to tsstats.log._bundle_logs) * rename to tsstats.log._bundle_logs * expect list of logpaths as argument and return them sorted * move globbing-stuff to parse_logs in an upcoming commit --- tsstats/log.py | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/tsstats/log.py b/tsstats/log.py index 23a9f3e..2aec053 100644 --- a/tsstats/log.py +++ b/tsstats/log.py @@ -41,27 +41,27 @@ def parse_logs(log_glob): return vserver_clients -def _sort_logfiles(log_glob): +def _bundle_logs(logs): ''' - collect logfiles from `log_glob` and sort them by date - and bundle them by virtualserver-id + bundle `logs` by virtualserver-id + and sort by timestamp from filename (if exists) - :param log_glob: path to log-files (supports globbing) + :param logs: list of paths to logfiles - :type log_glob: str + :type logs: list - :return: log-files sorted by date and bundled virtualserver-id + :return: `logs` bundled by virtualserver-id and sorted by timestamp :rtype: dict{str: [TimedLog]} ''' vserver_logfiles = {} # sid: [/path/to/log1, ..., /path/to/logn] - for log_file in sorted(log_file for log_file in glob(log_glob)): + for log in logs: # try to get date and sid from filename - match = re_log_filename.match(basename(log_file)) + match = re_log_filename.match(basename(log)) if match: match = match.groupdict() timestamp = datetime.strptime('{0} {1}'.format( match['date'], match['time'].replace('_', ':'))) - tl = TimedLog(log_file, timestamp) + tl = TimedLog(log, timestamp) sid = match['sid'] if sid in vserver_logfiles: # if already exists, keep list sorted by timestamp @@ -75,7 +75,7 @@ def _sort_logfiles(log_glob): else: # fallback to plain sorting vserver_logfiles.setdefault('', [])\ - .append(TimedLog(log_file, None)) + .append(TimedLog(log, None)) return vserver_logfiles