diff options
Diffstat (limited to 'lib/python/qmk/cli/generate/rules_mk.py')
| -rwxr-xr-x | lib/python/qmk/cli/generate/rules_mk.py | 41 |
1 files changed, 25 insertions, 16 deletions
diff --git a/lib/python/qmk/cli/generate/rules_mk.py b/lib/python/qmk/cli/generate/rules_mk.py index 41c94e16b..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 | ||
| @@ -76,6 +74,17 @@ def generate_rules_mk(cli): | |||
| 76 | enabled = 'yes' if enabled else 'no' | 74 | enabled = 'yes' if enabled else 'no' |
| 77 | rules_mk_lines.append(f'{feature}_ENABLE ?= {enabled}') | 75 | rules_mk_lines.append(f'{feature}_ENABLE ?= {enabled}') |
| 78 | 76 | ||
| 77 | # Set SPLIT_TRANSPORT, if needed | ||
| 78 | if kb_info_json.get('split', {}).get('transport', {}).get('protocol') == 'custom': | ||
| 79 | rules_mk_lines.append('SPLIT_TRANSPORT ?= custom') | ||
| 80 | |||
| 81 | # Set CUSTOM_MATRIX, if needed | ||
| 82 | if kb_info_json.get('matrix_pins', {}).get('custom'): | ||
| 83 | if kb_info_json.get('matrix_pins', {}).get('custom_lite'): | ||
| 84 | rules_mk_lines.append('CUSTOM_MATRIX ?= lite') | ||
| 85 | else: | ||
| 86 | rules_mk_lines.append('CUSTOM_MATRIX ?= yes') | ||
| 87 | |||
| 79 | # Show the results | 88 | # Show the results |
| 80 | rules_mk = '\n'.join(rules_mk_lines) + '\n' | 89 | rules_mk = '\n'.join(rules_mk_lines) + '\n' |
| 81 | 90 | ||
