소스 검색

Promote 'layouts require matrix data' to api error (#17349)

Joel Challis 3 년 전
부모
커밋
92665aef33
2개의 변경된 파일5개의 추가작업 그리고 9개의 파일을 삭제
  1. 0 7
      lib/python/qmk/cli/lint.py
  2. 5 2
      lib/python/qmk/info.py

+ 0 - 7
lib/python/qmk/cli/lint.py

@@ -116,13 +116,6 @@ def lint(cli):
             if not keymap_check(kb, cli.config.lint.keymap):
                 ok = False
 
-        # Check if all non-data driven macros exist in <keyboard.h>
-        for layout, data in keyboard_info['layouts'].items():
-            # Matrix data should be a list with exactly two integers: [0, 1]
-            if not data['c_macro'] and not all('matrix' in key_data.keys() or len(key_data) == 2 or all(isinstance(n, int) for n in key_data) for key_data in data['layout']):
-                cli.log.error(f'{kb}: "{layout}" has no "matrix" definition in either "info.json" or "<keyboard>.h"!')
-                ok = False
-
         # Report status
         if not ok:
             failed.append(kb)

+ 5 - 2
lib/python/qmk/info.py

@@ -797,8 +797,11 @@ def merge_info_jsons(keyboard, info_data):
                     for new_key, existing_key in zip(layout['layout'], info_data['layouts'][layout_name]['layout']):
                         existing_key.update(new_key)
             else:
-                layout['c_macro'] = False
-                info_data['layouts'][layout_name] = layout
+                if not all('matrix' in key_data.keys() for key_data in layout['layout']):
+                    _log_error(info_data, f'Layout "{layout_name}" has no "matrix" definition in either "info.json" or "<keyboard>.h"!')
+                else:
+                    layout['c_macro'] = False
+                    info_data['layouts'][layout_name] = layout
 
         # Update info_data with the new data
         if 'layouts' in new_info_data: