Tools: param_metadata: do not emit Legacy fields to rst/Wiki

This commit is contained in:
Peter Barker 2024-09-04 21:02:52 +10:00 committed by Peter Barker
parent 792941d4de
commit bbdbf33c21
8 changed files with 22 additions and 1 deletions

View File

@ -49,6 +49,9 @@ class EDNEmit(Emit):
# remove any keys we don't really care to share # remove any keys we don't really care to share
for key in self.remove_keys: for key in self.remove_keys:
output_dict.pop(key, None) output_dict.pop(key, None)
for key in list(output_dict.keys()):
if not self.should_emit_field(param, key):
output_dict.pop(key, None)
# rearrange bitmasks to be a vector with nil's if the bit doesn't have meaning # rearrange bitmasks to be a vector with nil's if the bit doesn't have meaning
if "bitmask" in output_dict: if "bitmask" in output_dict:

View File

@ -19,3 +19,6 @@ class Emit:
def emit(self, g): def emit(self, g):
pass pass
def should_emit_field(self, param, field):
return field not in ['Legacy']

View File

@ -65,6 +65,8 @@ DO NOT EDIT
t += "<ul>\n" t += "<ul>\n"
for field in param.__dict__.keys(): for field in param.__dict__.keys():
if not self.should_emit_field(param, field):
continue
if field not in ['name', 'DisplayName', 'Description', 'User', 'SortValues'] and field in known_param_fields: if field not in ['name', 'DisplayName', 'Description', 'User', 'SortValues'] and field in known_param_fields:
if field == 'Values' and Emit.prog_values_field.match(param.__dict__[field]): if field == 'Values' and Emit.prog_values_field.match(param.__dict__[field]):
values = (param.__dict__[field]).split(',') values = (param.__dict__[field]).split(',')

View File

@ -56,6 +56,9 @@ class JSONEmit(Emit):
name = name.split(':')[1] name = name.split(':')[1]
# Remove various unwanted keys # Remove various unwanted keys
for key in list(param.__dict__.keys()):
if not self.should_emit_field(param, key):
param.__dict__.pop(key)
for key in 'real_path', 'SortValues', '__field_text': for key in 'real_path', 'SortValues', '__field_text':
try: try:
param.__dict__.pop(key) param.__dict__.pop(key)

View File

@ -90,6 +90,8 @@ class MDEmit(Emit):
t += "\n\n%s" % param.Description t += "\n\n%s" % param.Description
for field in param.__dict__.keys(): for field in param.__dict__.keys():
if not self.should_emit_field(param, field):
continue
if field not in ['name', 'DisplayName', 'Description', 'User', 'SortValues'] and field in known_param_fields: if field not in ['name', 'DisplayName', 'Description', 'User', 'SortValues'] and field in known_param_fields:
if field == 'Values' and Emit.prog_values_field.match(param.__dict__[field]): if field == 'Values' and Emit.prog_values_field.match(param.__dict__[field]):
values = (param.__dict__[field]).split(',') values = (param.__dict__[field]).split(',')

View File

@ -51,7 +51,8 @@ known_param_fields = [
'ReadOnly', 'ReadOnly',
'Calibration', 'Calibration',
'Vector3Parameter', 'Vector3Parameter',
'SortValues' 'SortValues',
'Legacy',
] ]
# Follow SI units conventions from: # Follow SI units conventions from:

View File

@ -225,6 +225,9 @@ This list is automatically generated from the latest ardupilot source code, and
reference=reference) reference=reference)
for param in g.params: for param in g.params:
if getattr(param, "Legacy", False):
# do not emit legacy parameters to the Wiki
continue
if not hasattr(param, 'DisplayName') or not hasattr(param, 'Description'): if not hasattr(param, 'DisplayName') or not hasattr(param, 'Description'):
continue continue
d = param.__dict__ d = param.__dict__
@ -263,6 +266,8 @@ This list is automatically generated from the latest ardupilot source code, and
headings = [] headings = []
row = [] row = []
for field in sorted(param.__dict__.keys()): for field in sorted(param.__dict__.keys()):
if not self.should_emit_field(param, field):
continue
if (field not in ['name', 'DisplayName', 'Description', 'User', 'SortValues', 'RebootRequired'] and if (field not in ['name', 'DisplayName', 'Description', 'User', 'SortValues', 'RebootRequired'] and
field in known_param_fields): field in known_param_fields):
headings.append(field) headings.append(field)

View File

@ -63,6 +63,8 @@ class XmlEmit(Emit):
# Add values as chidren of this node # Add values as chidren of this node
for field in param.__dict__.keys(): for field in param.__dict__.keys():
if not self.should_emit_field(param, field):
continue
if field not in ['name', 'DisplayName', 'Description', 'User', 'SortValues'] and field in known_param_fields: if field not in ['name', 'DisplayName', 'Description', 'User', 'SortValues'] and field in known_param_fields:
if field == 'Values' and Emit.prog_values_field.match(param.__dict__[field]): if field == 'Values' and Emit.prog_values_field.match(param.__dict__[field]):
xml_values = etree.SubElement(xml_param, 'values') xml_values = etree.SubElement(xml_param, 'values')