diff options
Diffstat (limited to 'lib/python/qmk/cli/generate/config_h.py')
-rwxr-xr-x | lib/python/qmk/cli/generate/config_h.py | 29 |
1 files changed, 13 insertions, 16 deletions
diff --git a/lib/python/qmk/cli/generate/config_h.py b/lib/python/qmk/cli/generate/config_h.py index c0c148f1c..ca7e14fe6 100755 --- a/lib/python/qmk/cli/generate/config_h.py +++ b/lib/python/qmk/cli/generate/config_h.py | |||
@@ -5,11 +5,11 @@ from pathlib import Path | |||
5 | from dotty_dict import dotty | 5 | from dotty_dict import dotty |
6 | from milc import cli | 6 | from milc import cli |
7 | 7 | ||
8 | from qmk.decorators import automagic_keyboard, automagic_keymap | ||
9 | from qmk.info import info_json | 8 | from qmk.info import info_json |
10 | from qmk.json_schema import json_load | 9 | from qmk.json_schema import json_load, validate |
11 | from qmk.keyboard import keyboard_completer, keyboard_folder | 10 | from qmk.keyboard import keyboard_completer, keyboard_folder |
12 | from qmk.path import is_keyboard, normpath | 11 | from qmk.keymap import locate_keymap |
12 | from qmk.path import normpath | ||
13 | 13 | ||
14 | 14 | ||
15 | def direct_pins(direct_pins, postfix): | 15 | def direct_pins(direct_pins, postfix): |
@@ -157,25 +157,22 @@ def generate_split_config(kb_info_json, config_h_lines): | |||
157 | 157 | ||
158 | @cli.argument('-o', '--output', arg_only=True, type=normpath, help='File to write to') | 158 | @cli.argument('-o', '--output', arg_only=True, type=normpath, help='File to write to') |
159 | @cli.argument('-q', '--quiet', arg_only=True, action='store_true', help="Quiet mode, only output error messages") | 159 | @cli.argument('-q', '--quiet', arg_only=True, action='store_true', help="Quiet mode, only output error messages") |
160 | @cli.argument('-kb', '--keyboard', type=keyboard_folder, completer=keyboard_completer, help='Keyboard to generate config.h for.') | 160 | @cli.argument('-kb', '--keyboard', arg_only=True, type=keyboard_folder, completer=keyboard_completer, required=True, help='Keyboard to generate config.h for.') |
161 | @cli.argument('-km', '--keymap', arg_only=True, help='Keymap to generate config.h for.') | ||
161 | @cli.subcommand('Used by the make system to generate info_config.h from info.json', hidden=True) | 162 | @cli.subcommand('Used by the make system to generate info_config.h from info.json', hidden=True) |
162 | @automagic_keyboard | ||
163 | @automagic_keymap | ||
164 | def generate_config_h(cli): | 163 | def generate_config_h(cli): |
165 | """Generates the info_config.h file. | 164 | """Generates the info_config.h file. |
166 | """ | 165 | """ |
167 | # Determine our keyboard(s) | 166 | # Determine our keyboard/keymap |
168 | if not cli.config.generate_config_h.keyboard: | 167 | if cli.args.keymap: |
169 | cli.log.error('Missing parameter: --keyboard') | 168 | km = locate_keymap(cli.args.keyboard, cli.args.keymap) |
170 | cli.subcommands['info'].print_help() | 169 | km_json = json_load(km) |
171 | return False | 170 | validate(km_json, 'qmk.keymap.v1') |
172 | 171 | kb_info_json = dotty(km_json.get('config', {})) | |
173 | if not is_keyboard(cli.config.generate_config_h.keyboard): | 172 | else: |
174 | cli.log.error('Invalid keyboard: "%s"', cli.config.generate_config_h.keyboard) | 173 | kb_info_json = dotty(info_json(cli.args.keyboard)) |
175 | return False | ||
176 | 174 | ||
177 | # Build the info_config.h file. | 175 | # Build the info_config.h file. |
178 | kb_info_json = dotty(info_json(cli.config.generate_config_h.keyboard)) | ||
179 | config_h_lines = ['/* This file was generated by `qmk generate-config-h`. Do not edit or copy.' ' */', '', '#pragma once'] | 176 | config_h_lines = ['/* This file was generated by `qmk generate-config-h`. Do not edit or copy.' ' */', '', '#pragma once'] |
180 | 177 | ||
181 | generate_config_items(kb_info_json, config_h_lines) | 178 | generate_config_items(kb_info_json, config_h_lines) |