mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-18 22:26:30 +01:00
51 lines
1.2 KiB
Python
Executable file
51 lines
1.2 KiB
Python
Executable file
#!/usr/bin/python
|
|
|
|
import re;
|
|
|
|
LOGFILE = "./xwrelay.log"
|
|
LINEPAT = r"^<0x.*>"
|
|
|
|
# first get a list of the threads
|
|
|
|
last_seen = {}
|
|
last_ts = ""
|
|
|
|
def do_init():
|
|
return [ {}, "00:00:00" ]
|
|
|
|
def print_last_seen(last_seen):
|
|
print "one run's worth:"
|
|
for key,value in last_seen.iteritems():
|
|
print key, "---", value
|
|
|
|
def main():
|
|
cur_date = "00/00/00"
|
|
last_seen, last_ts = do_init()
|
|
|
|
fil = open( LOGFILE, "r" )
|
|
for line in fil:
|
|
mo = re.match( r".* \*\*\*\*\* forked \d*th new process \*\*\*\*\*", line )
|
|
if mo:
|
|
print_last_seen( last_seen )
|
|
last_seen, last_ts = do_init()
|
|
continue
|
|
mo = re.match( r"<(0x.*)>(\d\d:\d\d:\d\d): (.*)$", line)
|
|
if mo:
|
|
thread = mo.group(1);
|
|
last_ts = mo.group(2)
|
|
last_seen[thread] = cur_date + "--" + last_ts
|
|
continue
|
|
mo = re.match( r"It's a new day: (.*)$", line )
|
|
if mo:
|
|
cur_date = mo.group(1)
|
|
fil.close()
|
|
|
|
print_last_seen( last_seen )
|
|
|
|
#######################################################################
|
|
# main
|
|
#######################################################################
|
|
if __name__ == "__main__":
|
|
main()
|
|
else:
|
|
print "not main"
|