scripts: logextract.py Python 3 compatibility

- Open log files in text mode,
- Normalize the encoding of tmcuart messages,
- Fix a bug where StatsStream.get_lines() would return None timestamps for lines
before the first Stats line. Timestamps are now back-propagated.

Signed-off-by: Maël Kerbiriou <m431kerbiriou@gmail.com>
This commit is contained in:
Maël Kerbiriou 2023-07-02 14:57:32 +02:00 committed by KevinOConnor
parent 73d017aa89
commit fbc5589097
1 changed files with 16 additions and 10 deletions

View File

@ -1,4 +1,4 @@
#!/usr/bin/env python2
#!/usr/bin/env python3
# Script to extract config and shutdown information file a klippy.log file
#
# Copyright (C) 2017 Kevin O'Connor <kevin@koconnor.net>
@ -40,7 +40,7 @@ class GatherConfig:
if comment is not None:
self.comments.append(comment)
def write_file(self):
f = open(self.filename, 'wb')
f = open(self.filename, 'wt')
f.write('\n'.join(self.comments + self.config_lines).strip() + '\n')
f.close()
@ -93,7 +93,7 @@ class TMCUartHelper:
return
# Convert data into a long integer for easy manipulation
mval = pos = 0
for d in bytearray(data):
for d in data:
mval |= d << pos
pos += 8
# Extract register value
@ -110,7 +110,7 @@ class TMCUartHelper:
return
# Convert data into a long integer for easy manipulation
mval = pos = 0
for d in bytearray(data):
for d in data:
mval |= d << pos
pos += 8
# Extract register value
@ -218,7 +218,7 @@ repl_seq_r = re.compile(r": seq: 1" + shortseq_s)
clock_s = r"(?P<clock>[0-9]+)"
repl_clock_r = re.compile(r"clock=" + clock_s)
repl_uart_r = re.compile(r"tmcuart_(?:response|send) oid=[0-9]+"
+ r" (?:read|write)=(?P<msg>(?:'[^']*'"
+ r" (?:read|write)=b?(?P<msg>(?:'[^']*'"
+ r'|"[^"]*"))')
# MCU shutdown message parsing
@ -244,7 +244,8 @@ class MCUStream:
self.trans_clock(int(m.group('clock')), ts),)
line = repl_clock_r.sub(clock_update, line)
def uart_update(m):
msg = TMCUartHelper().parse_msg(ast.literal_eval(m.group('msg')))
msg = ast.literal_eval('b' + m.group('msg'))
msg = TMCUartHelper().parse_msg(msg)
return m.group(0).rstrip() + msg
line = repl_uart_r.sub(uart_update, line)
if self.name != 'mcu':
@ -383,7 +384,7 @@ class GCodeStream:
# Produce output gcode stream
if self.gcode_stream:
data = [ast.literal_eval(gc) for gc in self.gcode_commands]
f = open(self.gcode_filename, 'wb')
f = open(self.gcode_filename, 'wt')
f.write(self.gcode_state + ''.join(data))
f.close()
return self.gcode_stream
@ -500,8 +501,13 @@ class StatsStream:
if info[0] is not None and info[0] >= min_stream_ts - 5.:
del self.stats_stream[:i]
break
# Find the first stats timestamp
last_ts = min_stream_ts
for ts, line_num, line in self.stats_stream:
if ts is not None:
last_ts = ts
break
# Improve accuracy of stats timestamps
last_ts = self.stats_stream[0][0]
for i, (ts, line_num, line) in enumerate(self.stats_stream):
if ts is not None:
last_ts = self.check_stats_seq(ts, line)
@ -561,7 +567,7 @@ class GatherShutdown:
out = [i for s in streams for i in s]
out.sort()
out = [i[2] for i in out]
f = open(self.filename, 'wb')
f = open(self.filename, 'wt')
f.write('\n'.join(self.comments + out))
f.close()
@ -577,7 +583,7 @@ def main():
handler = None
recent_lines = collections.deque([], 200)
# Parse log file
f = open(logname, 'rb')
f = open(logname, 'rt')
for line_num, line in enumerate(f):
line = line.rstrip()
line_num += 1