aboutsummaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
authorLoek Le Blansch <loek@pipeframe.xyz>2024-09-16 16:40:46 +0200
committerLoek Le Blansch <loek@pipeframe.xyz>2024-09-16 16:40:46 +0200
commitdd2db2b7f62106e6c6c2abdaed73c5f608c690c6 (patch)
tree559570acfcb18214abf092f086ec68efdad5b201 /scripts
parentf6cb1e9d141d881ae6205027626d6643776e833c (diff)
update reqs2tex and add comments to reqs.toml
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/reqs2tex.py42
-rw-r--r--scripts/tex.py3
2 files changed, 38 insertions, 7 deletions
diff --git a/scripts/reqs2tex.py b/scripts/reqs2tex.py
index 9e71a48..c5ab3dd 100755
--- a/scripts/reqs2tex.py
+++ b/scripts/reqs2tex.py
@@ -9,7 +9,7 @@ def flatten(data):
items = flatten(value)
for item in items:
if 'label' in item:
- item['label'] = f"{key}:{item['label']}"
+ item['label'] = f"{key}.{item['label']}"
else:
item['label'] = f"{key}"
out += items
@@ -24,16 +24,44 @@ def make_id(item):
counter = id_counter,
)
+def sanitize(item, ids):
+ def die(msg):
+ print(f"[{item['label']}]: {msg}")
+ exit(1)
+
+ # ensure properties
+ item['description'] = item.get('description')
+ item['done'] = item.get('done')
+ item['priority'] = item.get('priority')
+ item['type'] = item.get('type')
+
+ # type checks
+ if item['type'] not in ['system', 'user']:
+ die(f"unknown or missing requirement type {repr(item['type'])}")
+ if item['priority'] not in ['must', 'should', 'could', 'will not']:
+ die(f"unknown or missing requirement priority {repr(item['type'])}")
+
+ # logic checks
+ if item['type'] != 'user' and item['done'] is not None:
+ die("has definition of done but is not a user requirement")
+
+ # conversions
+ if isinstance(item['done'], list):
+ # safety check
+ if not set(item['done']).issubset(ids):
+ die("definition of done includes unknown requirement(s)")
+ item['done'] = tex.cmd('Cref', tex.label2ref(*item['done']))
+
def convert(data):
reqs = flatten(data)
- for index, item in enumerate(reqs):
+ index = 0
+ for item in reqs:
item['id'] = tex.esc(make_id(item))
- item['index'] = index
- item['description'] = item.get('description', '???')
- item['done'] = item.get('done', None)
- item['priority'] = item.get('priority', 'must')
- item['type'] = item.get('type', 'system')
item['deleted'] = item.get('deleted', False)
+ if item['deleted']: continue
+ item['index'] = index
+ index += 1
+ sanitize(item, [req['label'] for req in reqs])
# skip deleted requirements (but process for make_id)
reqs = [item for item in reqs if item['deleted'] == False]
diff --git a/scripts/tex.py b/scripts/tex.py
index b044857..2fd51d8 100644
--- a/scripts/tex.py
+++ b/scripts/tex.py
@@ -41,3 +41,6 @@ def esc(plain):
def tabrule(*cells):
return "&".join(cells) + "\\\\"
+def label2ref(*labels):
+ return ",".join(["req:" + label.replace('.', ':') for label in labels])
+