forked from openvswitch/ovs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathovsdb-monitor-sort.py
executable file
·85 lines (61 loc) · 1.93 KB
/
ovsdb-monitor-sort.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
#! /usr/bin/env python
# Breaks lines read from stdin into groups using blank lines as
# group separators, then sorts lines within the groups for
# reproducibility.
import re
import sys
# This is copied out of the Python Sorting HOWTO at
# https://docs.python.org/3/howto/sorting.html#sortinghowto
def cmp_to_key(mycmp):
'Convert a cmp= function into a key= function'
class K(object):
def __init__(self, obj, *args):
self.obj = obj
def __lt__(self, other):
return mycmp(self.obj, other.obj) < 0
def __gt__(self, other):
return mycmp(self.obj, other.obj) > 0
def __eq__(self, other):
return mycmp(self.obj, other.obj) == 0
def __le__(self, other):
return mycmp(self.obj, other.obj) <= 0
def __ge__(self, other):
return mycmp(self.obj, other.obj) >= 0
def __ne__(self, other):
return mycmp(self.obj, other.obj) != 0
return K
u = '[0-9a-fA-F]'
uuid_re = re.compile(r'%s{8}-%s{4}-%s{4}-%s{4}-%s{12}' % ((u,) * 5))
def cmp(a, b):
return (a > b) - (a < b)
def compare_lines(a, b):
if uuid_re.match(a):
if uuid_re.match(b):
return cmp(a[36:], b[36:])
else:
return 1
elif uuid_re.match(b):
return -1
else:
return cmp(a, b)
def output_group(group, dst):
for x in sorted(group, key=cmp_to_key(compare_lines)):
dst.write(x)
def ovsdb_monitor_sort(src, dst):
group = []
while True:
line = src.readline()
if not line:
break
if line.rstrip() == '':
output_group(group, dst)
group = []
dst.write(line)
elif line.startswith(',') and group:
group[len(group) - 1] += line
else:
group.append(line)
if group:
output_group(group, dst)
if __name__ == '__main__':
ovsdb_monitor_sort(sys.stdin, sys.stdout)