Download:
child 26:05579dfd3e35
parent 24:58825476075c
25:a98e0e20561c
Anton Shestakov <engored@ya.ru>, 2015-05-27
viewer: batch queries together, ignore unknown marks

1 файлов изменено, 15 вставок(+), 13 удалений(-) [+]
viewer.py file | annotate | diff | comparison | revisions
--- a/viewer.py Sat May 23 17:34:12 2015 +0800
+++ b/viewer.py Wed May 27 18:34:06 2015 +0800
@@ -68,19 +68,21 @@
for mark in MARKS
}
- for cset in changesets:
- node = cset['node']
- resultsq = self.conn.execute(
- 'SELECT mark, time, cache FROM results WHERE node = ?',
- (node,))
- for mark, time, cache in resultsq:
- results.setdefault(node, {}).setdefault(mark, [None, None, None, None])
- if not cache:
- color = green_to_red(limits[mark][0:2], time) if time is not None else None
- results[node][mark][0:2] = [time, color]
- else:
- color = green_to_red(limits[mark][2:4], time) if time is not None else None
- results[node][mark][2:4] = [time, color]
+ resultsq = self.conn.execute(
+ 'SELECT node, mark, time, cache FROM results'
+ ' WHERE node IN (' + ','.join('?' * len(changesets)) + ')',
+ [cset['node'] for cset in changesets])
+
+ for node, mark, time, cache in resultsq:
+ if mark not in MARKS:
+ continue
+ results.setdefault(node, {}).setdefault(mark, [None, None, None, None])
+ if not cache:
+ color = green_to_red(limits[mark][0:2], time) if time is not None else None
+ results[node][mark][0:2] = [time, color]
+ else:
+ color = green_to_red(limits[mark][2:4], time) if time is not None else None
+ results[node][mark][2:4] = [time, color]
return results