summaryrefslogtreecommitdiff
path: root/utils/gen-controls.py
diff options
context:
space:
mode:
authorKieran Bingham <kieran.bingham@ideasonboard.com>2020-10-07 19:57:18 +0100
committerJacopo Mondi <jacopo@jmondi.org>2020-10-26 17:51:54 +0100
commit89916a486cbdf352ba55bbe595942f2a3f9a1349 (patch)
tree7c3db889b06530048d034ad9c5c38f75bd4b2328 /utils/gen-controls.py
parent581bb274956fcf7e781384342e88cd8fa35b1336 (diff)
libcamera: Support draft controls and properties
Extend the control and property framework to support exposing draft controls and properties in a scoped namespace. The controls/properties themselves will retain the same ordering in the relevant enum/id maps - but the access to any draft control will require explicitly referencing through its' draft:: namespace prefix. Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com> Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Signed-off-by: Kieran Bingham <kieran.bingham@ideasonboard.com> [Added missing hunk in control_ids.cpp.in and changed subject] Signed-off-by: Jacopo Mondi <jacopo@jmondi.org>
Diffstat (limited to 'utils/gen-controls.py')
-rwxr-xr-xutils/gen-controls.py39
1 files changed, 31 insertions, 8 deletions
diff --git a/utils/gen-controls.py b/utils/gen-controls.py
index 87c3d52a..93cb3885 100755
--- a/utils/gen-controls.py
+++ b/utils/gen-controls.py
@@ -36,6 +36,8 @@ ${description}
ctrls_doc = []
ctrls_def = []
+ draft_ctrls_doc = []
+ draft_ctrls_def = []
ctrls_map = []
for ctrl in controls:
@@ -55,6 +57,12 @@ ${description}
'id_name': id_name,
}
+ target_doc = ctrls_doc
+ target_def = ctrls_def
+ if ctrl.get('draft'):
+ target_doc = draft_ctrls_doc
+ target_def = draft_ctrls_def
+
enum = ctrl.get('enum')
if enum:
enum_doc = []
@@ -70,15 +78,21 @@ ${description}
enum_doc = '\n *\n'.join(enum_doc)
enum_doc += '\n */'
- ctrls_doc.append(enum_doc)
+ target_doc.append(enum_doc)
+
+ target_doc.append(doc_template.substitute(info))
+ target_def.append(def_template.substitute(info))
+
+ if ctrl.get('draft'):
+ name = 'draft::' + name
- ctrls_doc.append(doc_template.substitute(info))
- ctrls_def.append(def_template.substitute(info))
ctrls_map.append('\t{ ' + id_name + ', &' + name + ' },')
return {
'controls_doc': '\n\n'.join(ctrls_doc),
'controls_def': '\n'.join(ctrls_def),
+ 'draft_controls_doc': '\n\n'.join(draft_ctrls_doc),
+ 'draft_controls_def': '\n\n'.join(draft_ctrls_def),
'controls_map': '\n'.join(ctrls_map),
}
@@ -89,6 +103,7 @@ def generate_h(controls):
template = string.Template('''extern const Control<${type}> ${name};''')
ctrls = []
+ draft_ctrls = []
ids = []
id_value = 1
@@ -109,22 +124,30 @@ def generate_h(controls):
'type': ctrl_type,
}
+ target_ctrls = ctrls
+ if ctrl.get('draft'):
+ target_ctrls = draft_ctrls
+
enum = ctrl.get('enum')
if enum:
- ctrls.append(enum_template_start.substitute(info))
+ target_ctrls.append(enum_template_start.substitute(info))
for entry in enum:
value_info = {
'name': entry['name'],
'value': entry['value'],
}
- ctrls.append(enum_value_template.substitute(value_info))
- ctrls.append("};")
+ target_ctrls.append(enum_value_template.substitute(value_info))
+ target_ctrls.append("};")
- ctrls.append(template.substitute(info))
+ target_ctrls.append(template.substitute(info))
id_value += 1
- return {'ids': '\n'.join(ids), 'controls': '\n'.join(ctrls)}
+ return {
+ 'ids': '\n'.join(ids),
+ 'controls': '\n'.join(ctrls),
+ 'draft_controls': '\n'.join(draft_ctrls)
+ }
def fill_template(template, data):