Skip to content

Commit aa8e0a3

Browse files
authored
Build correctly when out of tree (#18775)
1 parent 18dc851 commit aa8e0a3

File tree

3 files changed

+32
-20
lines changed

3 files changed

+32
-20
lines changed

builddefs/build_keyboard.mk

+2-2
Original file line numberDiff line numberDiff line change
@@ -162,7 +162,7 @@ ifneq ("$(wildcard $(KEYMAP_JSON))", "")
162162
-include $(KEYMAP_PATH)/rules.mk
163163

164164
# Load any rules.mk content from keymap.json
165-
INFO_RULES_MK = $(shell $(QMK_BIN) generate-rules-mk --quiet --escape --keyboard $(KEYBOARD) --keymap $(KEYMAP) --output $(KEYMAP_OUTPUT)/src/rules.mk)
165+
INFO_RULES_MK = $(shell $(QMK_BIN) generate-rules-mk --quiet --escape --output $(KEYMAP_OUTPUT)/src/rules.mk $(KEYMAP_JSON))
166166
include $(INFO_RULES_MK)
167167

168168
# Add rules to generate the keymap files - indentation here is important
@@ -173,7 +173,7 @@ $(KEYMAP_OUTPUT)/src/keymap.c: $(KEYMAP_JSON)
173173

174174
$(KEYMAP_OUTPUT)/src/config.h: $(KEYMAP_JSON)
175175
@$(SILENT) || printf "$(MSG_GENERATING) $@" | $(AWK_CMD)
176-
$(eval CMD=$(QMK_BIN) generate-config-h --quiet --keyboard $(KEYBOARD) --keymap $(KEYMAP) --output $(KEYMAP_H))
176+
$(eval CMD=$(QMK_BIN) generate-config-h --quiet --output $(KEYMAP_H) $(KEYMAP_JSON))
177177
@$(BUILD_CMD)
178178

179179
generated-files: $(KEYMAP_OUTPUT)/src/config.h $(KEYMAP_OUTPUT)/src/keymap.c

lib/python/qmk/cli/generate/config_h.py

+15-9
Original file line numberDiff line numberDiff line change
@@ -1,15 +1,16 @@
11
"""Used by the make system to generate info_config.h from info.json.
22
"""
33
from pathlib import Path
4-
54
from dotty_dict import dotty
5+
6+
from argcomplete.completers import FilesCompleter
67
from milc import cli
78

8-
from qmk.info import info_json, keymap_json_config
9+
from qmk.info import info_json
910
from qmk.json_schema import json_load
1011
from qmk.keyboard import keyboard_completer, keyboard_folder
11-
from qmk.commands import dump_lines
12-
from qmk.path import normpath
12+
from qmk.commands import dump_lines, parse_configurator_json
13+
from qmk.path import normpath, FileType
1314
from qmk.constants import GPL2_HEADER_C_LIKE, GENERATED_HEADER_C_LIKE
1415

1516

@@ -162,19 +163,24 @@ def generate_led_animations_config(led_feature_json, config_h_lines, prefix):
162163
config_h_lines.append(generate_define(f'{prefix}{animation.upper()}'))
163164

164165

166+
@cli.argument('filename', nargs='?', arg_only=True, type=FileType('r'), completer=FilesCompleter('.json'), help='A configurator export JSON to be compiled and flashed or a pre-compiled binary firmware file (bin/hex) to be flashed.')
165167
@cli.argument('-o', '--output', arg_only=True, type=normpath, help='File to write to')
166168
@cli.argument('-q', '--quiet', arg_only=True, action='store_true', help="Quiet mode, only output error messages")
167-
@cli.argument('-kb', '--keyboard', arg_only=True, type=keyboard_folder, completer=keyboard_completer, required=True, help='Keyboard to generate config.h for.')
168-
@cli.argument('-km', '--keymap', arg_only=True, help='Keymap to generate config.h for.')
169+
@cli.argument('-kb', '--keyboard', arg_only=True, type=keyboard_folder, completer=keyboard_completer, help='Keyboard to generate config.h for.')
169170
@cli.subcommand('Used by the make system to generate info_config.h from info.json', hidden=True)
170171
def generate_config_h(cli):
171172
"""Generates the info_config.h file.
172173
"""
173174
# Determine our keyboard/keymap
174-
if cli.args.keymap:
175-
kb_info_json = dotty(keymap_json_config(cli.args.keyboard, cli.args.keymap))
176-
else:
175+
if cli.args.filename:
176+
user_keymap = parse_configurator_json(cli.args.filename)
177+
kb_info_json = user_keymap.get('config', {})
178+
elif cli.args.keyboard:
177179
kb_info_json = dotty(info_json(cli.args.keyboard))
180+
else:
181+
cli.log.error('You must supply a configurator export or `--keyboard`.')
182+
cli.subcommands['generate-config-h'].print_help()
183+
return False
178184

179185
# Build the info_config.h file.
180186
config_h_lines = [GPL2_HEADER_C_LIKE, GENERATED_HEADER_C_LIKE, '#pragma once']

lib/python/qmk/cli/generate/rules_mk.py

+15-9
Original file line numberDiff line numberDiff line change
@@ -1,15 +1,16 @@
11
"""Used by the make system to generate a rules.mk
22
"""
33
from pathlib import Path
4-
54
from dotty_dict import dotty
5+
6+
from argcomplete.completers import FilesCompleter
67
from milc import cli
78

8-
from qmk.info import info_json, keymap_json_config
9+
from qmk.info import info_json
910
from qmk.json_schema import json_load
1011
from qmk.keyboard import keyboard_completer, keyboard_folder
11-
from qmk.commands import dump_lines
12-
from qmk.path import normpath
12+
from qmk.commands import dump_lines, parse_configurator_json
13+
from qmk.path import normpath, FileType
1314
from qmk.constants import GPL2_HEADER_SH_LIKE, GENERATED_HEADER_SH_LIKE
1415

1516

@@ -39,20 +40,25 @@ def process_mapping_rule(kb_info_json, rules_key, info_dict):
3940
return f'{rules_key} ?= {rules_value}'
4041

4142

43+
@cli.argument('filename', nargs='?', arg_only=True, type=FileType('r'), completer=FilesCompleter('.json'), help='A configurator export JSON to be compiled and flashed or a pre-compiled binary firmware file (bin/hex) to be flashed.')
4244
@cli.argument('-o', '--output', arg_only=True, type=normpath, help='File to write to')
4345
@cli.argument('-q', '--quiet', arg_only=True, action='store_true', help="Quiet mode, only output error messages")
4446
@cli.argument('-e', '--escape', arg_only=True, action='store_true', help="Escape spaces in quiet mode")
45-
@cli.argument('-kb', '--keyboard', arg_only=True, type=keyboard_folder, completer=keyboard_completer, required=True, help='Keyboard to generate rules.mk for.')
46-
@cli.argument('-km', '--keymap', arg_only=True, help='Keymap to generate rules.mk for.')
47+
@cli.argument('-kb', '--keyboard', arg_only=True, type=keyboard_folder, completer=keyboard_completer, help='Keyboard to generate rules.mk for.')
4748
@cli.subcommand('Used by the make system to generate rules.mk from info.json', hidden=True)
4849
def generate_rules_mk(cli):
4950
"""Generates a rules.mk file from info.json.
5051
"""
5152
# Determine our keyboard/keymap
52-
if cli.args.keymap:
53-
kb_info_json = dotty(keymap_json_config(cli.args.keyboard, cli.args.keymap))
54-
else:
53+
if cli.args.filename:
54+
user_keymap = parse_configurator_json(cli.args.filename)
55+
kb_info_json = user_keymap.get('config', {})
56+
elif cli.args.keyboard:
5557
kb_info_json = dotty(info_json(cli.args.keyboard))
58+
else:
59+
cli.log.error('You must supply a configurator export or `--keyboard`.')
60+
cli.subcommands['generate-rules-mk'].print_help()
61+
return False
5662

5763
info_rules_map = json_load(Path('data/mappings/info_rules.json'))
5864
rules_mk_lines = [GPL2_HEADER_SH_LIKE, GENERATED_HEADER_SH_LIKE]

0 commit comments

Comments
 (0)