Implement data driven joysticks (#22947)
This commit is contained in:
parent
938badc3b0
commit
53a0cdc446
10 changed files with 97 additions and 31 deletions
|
@ -6,7 +6,7 @@ from qmk.info import info_json
|
|||
from qmk.commands import dump_lines
|
||||
from qmk.keyboard import keyboard_completer, keyboard_folder
|
||||
from qmk.path import normpath
|
||||
from qmk.constants import GPL2_HEADER_C_LIKE, GENERATED_HEADER_C_LIKE
|
||||
from qmk.constants import GPL2_HEADER_C_LIKE, GENERATED_HEADER_C_LIKE, JOYSTICK_AXES
|
||||
|
||||
|
||||
def _gen_led_configs(info_data):
|
||||
|
@ -91,6 +91,41 @@ def _gen_matrix_mask(info_data):
|
|||
return lines
|
||||
|
||||
|
||||
def _gen_joystick_axes(info_data):
|
||||
"""Convert info.json content to joystick_axes
|
||||
"""
|
||||
if 'axes' not in info_data.get('joystick', {}):
|
||||
return []
|
||||
|
||||
axes = info_data['joystick']['axes']
|
||||
axes_keys = list(axes.keys())
|
||||
|
||||
lines = []
|
||||
lines.append('#ifdef JOYSTICK_ENABLE')
|
||||
lines.append('joystick_config_t joystick_axes[JOYSTICK_AXIS_COUNT] = {')
|
||||
|
||||
# loop over all available axes - injecting virtual axis for those not specified
|
||||
for index, cur in enumerate(JOYSTICK_AXES):
|
||||
# bail out if we have generated all requested axis
|
||||
if len(axes_keys) == 0:
|
||||
break
|
||||
|
||||
axis = 'virtual'
|
||||
if cur in axes:
|
||||
axis = axes[cur]
|
||||
axes_keys.remove(cur)
|
||||
|
||||
if axis == 'virtual':
|
||||
lines.append(f" [{index}] = JOYSTICK_AXIS_VIRTUAL,")
|
||||
else:
|
||||
lines.append(f" [{index}] = JOYSTICK_AXIS_IN({axis['input_pin']}, {axis['low']}, {axis['rest']}, {axis['high']}),")
|
||||
|
||||
lines.append('};')
|
||||
lines.append('#endif')
|
||||
|
||||
return lines
|
||||
|
||||
|
||||
@cli.argument('-o', '--output', arg_only=True, type=normpath, help='File to write to')
|
||||
@cli.argument('-q', '--quiet', arg_only=True, action='store_true', help="Quiet mode, only output error messages")
|
||||
@cli.argument('-kb', '--keyboard', arg_only=True, type=keyboard_folder, completer=keyboard_completer, required=True, help='Keyboard to generate keyboard.c for.')
|
||||
|
@ -105,6 +140,7 @@ def generate_keyboard_c(cli):
|
|||
|
||||
keyboard_h_lines.extend(_gen_led_configs(kb_info_json))
|
||||
keyboard_h_lines.extend(_gen_matrix_mask(kb_info_json))
|
||||
keyboard_h_lines.extend(_gen_joystick_axes(kb_info_json))
|
||||
|
||||
# Show the results
|
||||
dump_lines(cli.args.output, keyboard_h_lines, cli.args.quiet)
|
||||
|
|
|
@ -320,3 +320,5 @@ LICENSE_TEXTS = [
|
|||
you may not use this file except in compliance with the License.
|
||||
"""]),
|
||||
]
|
||||
|
||||
JOYSTICK_AXES = ['x', 'y', 'z', 'rx', 'ry', 'rz']
|
||||
|
|
|
@ -7,7 +7,7 @@ from dotty_dict import dotty
|
|||
|
||||
from milc import cli
|
||||
|
||||
from qmk.constants import COL_LETTERS, ROW_LETTERS, CHIBIOS_PROCESSORS, LUFA_PROCESSORS, VUSB_PROCESSORS
|
||||
from qmk.constants import COL_LETTERS, ROW_LETTERS, CHIBIOS_PROCESSORS, LUFA_PROCESSORS, VUSB_PROCESSORS, JOYSTICK_AXES
|
||||
from qmk.c_parse import find_layouts, parse_config_h_file, find_led_config
|
||||
from qmk.json_schema import deep_update, json_load, validate
|
||||
from qmk.keyboard import config_h, rules_mk
|
||||
|
@ -249,8 +249,9 @@ def info_json(keyboard):
|
|||
info_data = _extract_rules_mk(info_data, rules_mk(str(keyboard)))
|
||||
info_data = _extract_config_h(info_data, config_h(str(keyboard)))
|
||||
|
||||
# Ensure that we have matrix row and column counts
|
||||
# Ensure that we have various calculated values
|
||||
info_data = _matrix_size(info_data)
|
||||
info_data = _joystick_axis_count(info_data)
|
||||
|
||||
# Merge in data from <keyboard.c>
|
||||
info_data = _extract_led_config(info_data, str(keyboard))
|
||||
|
@ -800,6 +801,16 @@ def _matrix_size(info_data):
|
|||
return info_data
|
||||
|
||||
|
||||
def _joystick_axis_count(info_data):
|
||||
"""Add info_data['joystick.axis_count'] if required
|
||||
"""
|
||||
if 'axes' in info_data.get('joystick', {}):
|
||||
axes_keys = info_data['joystick']['axes'].keys()
|
||||
info_data['joystick']['axis_count'] = max(JOYSTICK_AXES.index(a) for a in axes_keys) + 1 if axes_keys else 0
|
||||
|
||||
return info_data
|
||||
|
||||
|
||||
def _check_matrix(info_data):
|
||||
"""Check the matrix to ensure that row/column count is consistent.
|
||||
"""
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue