summaryrefslogtreecommitdiff
path: root/app/scripts/west_commands
diff options
context:
space:
mode:
authorPeter Johanson <peter@peterjohanson.com>2021-03-27 20:51:04 -0400
committerPete Johanson <peter@peterjohanson.com>2021-09-11 00:50:36 -0400
commit1d69bdda602e5de1339a3b4713cf594e4852fb24 (patch)
treeab4b3904e05c647c32f7510347c2d1ca292db1e4 /app/scripts/west_commands
parent4a5454b0f9f2cbf755f507ab2a233a2f8c4a2fd3 (diff)
feat: Add hardware metadata schema.
* Initial hardware metadata JSON schema. * GH Action to validate all schemas for boards/shields.
Diffstat (limited to 'app/scripts/west_commands')
-rw-r--r--app/scripts/west_commands/metadata.py59
1 files changed, 59 insertions, 0 deletions
diff --git a/app/scripts/west_commands/metadata.py b/app/scripts/west_commands/metadata.py
new file mode 100644
index 0000000..a06024c
--- /dev/null
+++ b/app/scripts/west_commands/metadata.py
@@ -0,0 +1,59 @@
+# Copyright (c) 2021 The ZMK Contributors
+# SPDX-License-Identifier: MIT
+'''Metadata command for ZMK.'''
+
+from functools import cached_property
+import glob
+import json
+from jsonschema import validate, ValidationError
+import os
+import sys
+import yaml
+from textwrap import dedent # just for nicer code indentation
+
+from west.commands import WestCommand
+from west import log # use this for user output
+
+
+class Metadata(WestCommand):
+ def __init__(self):
+ super().__init__(
+ 'metadata', # gets stored as self.name
+ 'ZMK hardware metadata commands', # self.help
+ # self.description:
+ dedent('''Operate on the board/shield metadata.'''))
+
+ def do_add_parser(self, parser_adder):
+ parser = parser_adder.add_parser(self.name,
+ help=self.help,
+ description=self.description)
+
+ parser.add_argument('subcommand', default="check",
+ help='The subcommand to run. Defaults to "check".', nargs="?")
+ return parser # gets stored as self.parser
+
+ @cached_property
+ def schema(self):
+ return json.load(
+ open("../schema/hardware-metadata.schema.json", 'r'))
+
+ def validate_file(self, file):
+ print("Validating: " + file)
+ with open(file, 'r') as stream:
+ try:
+ validate(yaml.safe_load(stream), self.schema)
+ except yaml.YAMLError as exc:
+ print("Failed loading metadata yaml: " + file)
+ print(exc)
+ return False
+ except ValidationError as vexc:
+ print("Failed validation of: " + file)
+ print(vexc)
+ return False
+ return True
+
+ def do_run(self, args, unknown_args):
+ status = all([self.validate_file(f) for f in glob.glob(
+ "boards/**/*.zmk.yml", recursive=True)])
+
+ sys.exit(0 if status else 1)