diff options
Diffstat (limited to 'lib/python/qmk/cli/generate/rules_mk.py')
-rwxr-xr-x | lib/python/qmk/cli/generate/rules_mk.py | 30 |
1 files changed, 14 insertions, 16 deletions
diff --git a/lib/python/qmk/cli/generate/rules_mk.py b/lib/python/qmk/cli/generate/rules_mk.py index 2712b81cb..cdf17dfbc 100755 --- a/lib/python/qmk/cli/generate/rules_mk.py +++ b/lib/python/qmk/cli/generate/rules_mk.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 process_mapping_rule(kb_info_json, rules_key, info_dict): | 15 | def process_mapping_rule(kb_info_json, rules_key, info_dict): |
@@ -39,23 +39,21 @@ def process_mapping_rule(kb_info_json, rules_key, info_dict): | |||
39 | @cli.argument('-o', '--output', arg_only=True, type=normpath, help='File to write to') | 39 | @cli.argument('-o', '--output', arg_only=True, type=normpath, help='File to write to') |
40 | @cli.argument('-q', '--quiet', arg_only=True, action='store_true', help="Quiet mode, only output error messages") | 40 | @cli.argument('-q', '--quiet', arg_only=True, action='store_true', help="Quiet mode, only output error messages") |
41 | @cli.argument('-e', '--escape', arg_only=True, action='store_true', help="Escape spaces in quiet mode") | 41 | @cli.argument('-e', '--escape', arg_only=True, action='store_true', help="Escape spaces in quiet mode") |
42 | @cli.argument('-kb', '--keyboard', type=keyboard_folder, completer=keyboard_completer, help='Keyboard to generate config.h for.') | 42 | @cli.argument('-kb', '--keyboard', arg_only=True, type=keyboard_folder, completer=keyboard_completer, required=True, help='Keyboard to generate rules.mk for.') |
43 | @cli.subcommand('Used by the make system to generate info_config.h from info.json', hidden=True) | 43 | @cli.argument('-km', '--keymap', arg_only=True, help='Keymap to generate rules.mk for.') |
44 | @automagic_keyboard | 44 | @cli.subcommand('Used by the make system to generate rules.mk from info.json', hidden=True) |
45 | @automagic_keymap | ||
46 | def generate_rules_mk(cli): | 45 | def generate_rules_mk(cli): |
47 | """Generates a rules.mk file from info.json. | 46 | """Generates a rules.mk file from info.json. |
48 | """ | 47 | """ |
49 | if not cli.config.generate_rules_mk.keyboard: | 48 | # Determine our keyboard/keymap |
50 | cli.log.error('Missing parameter: --keyboard') | 49 | if cli.args.keymap: |
51 | cli.subcommands['info'].print_help() | 50 | km = locate_keymap(cli.args.keyboard, cli.args.keymap) |
52 | return False | 51 | km_json = json_load(km) |
53 | 52 | validate(km_json, 'qmk.keymap.v1') | |
54 | if not is_keyboard(cli.config.generate_rules_mk.keyboard): | 53 | kb_info_json = dotty(km_json.get('config', {})) |
55 | cli.log.error('Invalid keyboard: "%s"', cli.config.generate_rules_mk.keyboard) | 54 | else: |
56 | return False | 55 | kb_info_json = dotty(info_json(cli.args.keyboard)) |
57 | 56 | ||
58 | kb_info_json = dotty(info_json(cli.config.generate_rules_mk.keyboard)) | ||
59 | info_rules_map = json_load(Path('data/mappings/info_rules.json')) | 57 | info_rules_map = json_load(Path('data/mappings/info_rules.json')) |
60 | rules_mk_lines = ['# This file was generated by `qmk generate-rules-mk`. Do not edit or copy.', ''] | 58 | rules_mk_lines = ['# This file was generated by `qmk generate-rules-mk`. Do not edit or copy.', ''] |
61 | 59 | ||