Skip to content

Commit

Permalink
[CI] detect clang-formatted VIAL_KEYBOARD_UID (vial-kb#428)
Browse files Browse the repository at this point in the history
* fix: detect clang-formatted VIAL_KEYBOARD_UIDs

* style: match UID output to "About..." in Vial GUI
  • Loading branch information
lesshonor committed Mar 29, 2023
1 parent b6b360b commit 209c682
Showing 1 changed file with 14 additions and 13 deletions.
27 changes: 14 additions & 13 deletions util/ci_vial_verify_uid.py
Original file line number Diff line number Diff line change
@@ -1,41 +1,42 @@
#!/usr/bin/env python3
from glob import glob
import os
from pathlib import Path
import re
import sys
import struct
from collections import defaultdict


def main():

VIAL_UID_REGEX = re.compile(r"#\s*define\s+VIAL_KEYBOARD_UID\s+(?:\\(?:\n|\r)\s*)*{\s*((?:0(?:x|X)(?:[0-9a-fA-F]){2}\s*,\s*){7}(?:0(?:x|X)(?:[0-9a-fA-F]){2}))\s*}")

error = 0
uid_to_keyboards = defaultdict(set)

for filename in glob("keyboards/**/vial.json", recursive=True):
keyboard = filename[10:-10].split("/keymaps/")[0]

path = os.path.dirname(filename)
dirname = Path(filename).parents[0]
uid = None

while True:
config_h = os.path.join(path, "config.h")
if os.path.exists(config_h):
with open(config_h, "r") as inf:
for line in inf:
uid = re.findall(r"#define.*VIAL_KEYBOARD_UID.*{(.*)}", line)
if uid:
break
config_h = dirname.joinpath("config.h")
if config_h.exists() and config_h.stat().st_size < 100000:
content = config_h.read_text()
uid = VIAL_UID_REGEX.search(content)
if uid:
break
path = os.path.dirname(path)
if path.endswith("keyboards"):
dirname = dirname.parents[0]
if dirname.match("keyboards"):
break

if not uid:
print("Keyboard {} does not define a VIAL_KEYBOARD_UID".format(keyboard))
error = 1
continue

uid = uid[0].split(",")
uid = uid[1].split(",")
uid.reverse()
uid = [int(x, 16) for x in uid]
uid = struct.pack("BBBBBBBB", *uid).hex()
uid_to_keyboards[uid].add(keyboard)
Expand Down

0 comments on commit 209c682

Please sign in to comment.