forked from nasa/astrobee
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathluaTable.py
More file actions
80 lines (64 loc) · 1.82 KB
/
Copy pathluaTable.py
File metadata and controls
80 lines (64 loc) · 1.82 KB
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
"""
Output Python data structure as a Lua table constructor.
PLEASE NOTE: This script currently only works with python 2.
The python script that imports this script and generates the
astrobee fsw files uses a repo that is only compatible with
python 2. Until that repo is updated to work with python 3,
this script will only be compatible with python 2 since there
is no easy way to guarantee the python 3 compatibility changes
continue to generate the fsw files correctly.
"""
import sys
if (sys.version_info > (3, 0)):
# exit if python 3
print("The lua table script is only compatible with python 2")
sys.exit(1)
from cStringIO import StringIO # fmt: skip
def q(s):
return '"%s"' % s
def ind(lvl):
return ' ' * (lvl * 2)
def dumpStream(out, d, lvl=0):
def w(s):
out.write(s)
if isinstance(d, basestring): # fmt: skip
w(q(d))
elif isinstance(d, (list, tuple)):
if d:
w('{\n')
n = len(d)
for i, elt in enumerate(d):
w(ind(lvl + 1))
dumpStream(out, elt, lvl + 1)
if i < n - 1:
w(',')
w('\n')
w(ind(lvl))
w('}')
else:
w('{}')
elif isinstance(d, dict):
if d:
w('{\n')
n = len(d)
keys = list(d.keys())
keys.sort()
for i, k in enumerate(keys):
v = d[k]
w(ind(lvl + 1))
w(k)
w('=')
dumpStream(out, v, lvl + 1)
if i < n - 1:
w(',')
w('\n')
w(ind(lvl))
w('}')
else:
w('{}')
else:
w(str(d))
def dumps(d):
out = StringIO()
dumpStream(out, d, 0)
return out.getvalue()