CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutSign UpSign In
Ardupilot

Real-time collaboration for Jupyter Notebooks, Linux Terminals, LaTeX, VS Code, R IDE, and more,
all in one place. Commercial Alternative to JupyterHub.

GitHub Repository: Ardupilot/ardupilot
Path: blob/master/Tools/autotest/param_metadata/htmlemit.py
Views: 1799
1
"""
2
Emit docs in a form acceptable to the old Ardupilot wordpress docs site
3
"""
4
5
from param import known_param_fields, known_units
6
from emit import Emit
7
try:
8
from cgi import escape as cescape
9
except Exception:
10
from html import escape as cescape
11
12
13
class HtmlEmit(Emit):
14
15
def __init__(self, *args, **kwargs):
16
Emit.__init__(self, *args, **kwargs)
17
html_fname = 'Parameters.html'
18
self.f = open(html_fname, mode='w')
19
self.preamble = """<!-- Dynamically generated list of documented parameters
20
This page was generated using Tools/autotest/param_metadata/param_parse.py
21
22
DO NOT EDIT
23
-->
24
25
26
<h3 style="text-align: center">Complete Parameter List</h3>
27
<hr />
28
29
<p>This is a complete list of the parameters which can be set via the MAVLink protocol in the EEPROM of your autopilot to control vehicle behaviour. This list is automatically generated from the latest ardupilot source code, and so may contain parameters which are not yet in the stable released versions of the code.</p>
30
31
<!-- add auto-generated table of contents with "Table of Contents Plus" plugin -->
32
[toc exclude="Complete Parameter List"]
33
34
"""
35
self.t = ''
36
37
def escape(self, s):
38
s = s.replace(' ', '-')
39
s = s.replace(':', '-')
40
s = s.replace('(', '')
41
s = s.replace(')', '')
42
return s
43
44
def close(self):
45
self.f.write(self.preamble)
46
self.f.write(self.t)
47
self.f.close()
48
49
def start_libraries(self):
50
pass
51
52
def emit(self, g):
53
tag = '%s Parameters' % g.reference
54
t = '\n\n<h1>%s</h1>\n' % tag
55
56
for param in g.params:
57
if not hasattr(param, 'DisplayName') or not hasattr(param, 'Description'):
58
continue
59
d = param.__dict__
60
tag = '%s (%s)' % (param.DisplayName, param.name)
61
t += '\n\n<h2>%s</h2>' % tag
62
if d.get('User', None) == 'Advanced':
63
t += '<em>Note: This parameter is for advanced users</em><br>'
64
t += "\n\n<p>%s</p>\n" % cescape(param.Description)
65
t += "<ul>\n"
66
67
for field in param.__dict__.keys():
68
if not self.should_emit_field(param, field):
69
continue
70
if field not in ['name', 'DisplayName', 'Description', 'User', 'SortValues'] and field in known_param_fields:
71
if field == 'Values' and Emit.prog_values_field.match(param.__dict__[field]):
72
values = (param.__dict__[field]).split(',')
73
t += "<table><th>Value</th><th>Meaning</th>\n"
74
for value in values:
75
v = value.split(':')
76
if len(v) != 2:
77
raise ValueError("Bad value (%s)" % v)
78
t += "<tr><td>%s</td><td>%s</td></tr>\n" % (v[0], v[1])
79
t += "</table>\n"
80
elif field == 'Units':
81
abreviated_units = param.__dict__[field]
82
if abreviated_units != '':
83
units = known_units[abreviated_units] # use the known_units dictionary to convert the abreviated unit into a full textual one
84
t += "<li>%s: %s</li>\n" % (field, cescape(units))
85
else:
86
t += "<li>%s: %s</li>\n" % (field, cescape(param.__dict__[field]))
87
t += "</ul>\n"
88
self.t += t
89
90