Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add a lot more data to info.json #13366

Merged
merged 37 commits into from
Aug 16, 2021
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
c15431b
add some split data to info.json
skullydazed Jun 25, 2021
06bbd07
add tags
skullydazed Jun 25, 2021
e6ae983
add half of config_options.md to info.json
skullydazed Jun 25, 2021
021fa69
add support for designating master split
skullydazed Jun 25, 2021
d6e152b
sort out split transport and primary
skullydazed Jun 26, 2021
cd1c3fc
fix bad data in UNUSED_PINS
skullydazed Jun 26, 2021
c09216e
fixup custom transport
skullydazed Jun 26, 2021
aa29277
wip
skullydazed Jun 26, 2021
dad8f59
allow for setting split right half keyboard matrix
skullydazed Jun 28, 2021
8d4494c
add SPLIT_USB_DETECT
skullydazed Jun 28, 2021
191f78f
minor cleanup
skullydazed Jun 28, 2021
c0f3ceb
fix an erroneous message
skullydazed Jun 28, 2021
5356204
rework split.usb_detect
skullydazed Jun 28, 2021
0fe118e
adding missing rgblight vars to info.json
skullydazed Jun 28, 2021
605e23a
add mouse_key to info.json
skullydazed Jun 28, 2021
a969a80
add all remaining options from docs/config_options.md
skullydazed Jun 28, 2021
e7a5922
fix audio voices
skullydazed Jun 28, 2021
3f6e62b
qmk info: Change text output to use dotted notation
skullydazed Jun 26, 2021
9cca69d
tweak layout output
skullydazed Jun 28, 2021
0845e3f
resolve alias names
skullydazed Jun 28, 2021
089c94f
break out some functions to make flake8 happy
skullydazed Jul 11, 2021
173117d
add a field for bootloader instructions
skullydazed Jul 11, 2021
6eb427e
qmk generate-info-json: add a write-to-file argument
noroadsleft Jun 28, 2021
1241228
-arg_only, +action
noroadsleft Jun 28, 2021
40dfded
Bring qmk generate-info-json inline with other generate commands
skullydazed Jul 23, 2021
c00b002
pytest fixup
skullydazed Jul 23, 2021
87a4fde
fix esca/getawayvan
skullydazed Aug 9, 2021
6b4293f
fix data driven errors for bpiphany converters
skullydazed Aug 9, 2021
9f13125
features.force_nkro -> usb.force_nkro
skullydazed Aug 9, 2021
26c3ab3
split.primary->split.main
skullydazed Aug 9, 2021
3389e50
fix esca/getawayvan_f042
skullydazed Aug 9, 2021
3be4330
fix the bpiphany converters for real
skullydazed Aug 9, 2021
967a21d
fix bpiphany/tiger_lily
skullydazed Aug 10, 2021
ae29ea4
Apply suggestions from code review
skullydazed Aug 16, 2021
b885c63
fix generate-api errors
skullydazed Aug 16, 2021
0ca7238
fix matrix pin extraction for split boards
skullydazed Aug 16, 2021
7a5f286
fix ploopyco/trackball_nano/rev1_001
skullydazed Aug 16, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
add half of config_options.md to info.json
  • Loading branch information
skullydazed committed Aug 16, 2021
commit e6ae9834797e8aa545a54705dec9e09a88ea08d2
33 changes: 32 additions & 1 deletion data/mappings/info_config.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,16 +7,36 @@
# to_json: Default `true`. Set to `false` to exclude this mapping from info.json
# to_c: Default `true`. Set to `false` to exclude this mapping from config.h
# warn_duplicate: Default `true`. Set to `false` to turn off warning when a value exists in both places
"AUDIO_VOICES": {"info_key": "matrix_pins.ghost", "value_type": "bool"},
"BACKLIGHT_BREATHING": {"info_key": "backlight.breathing", "value_type": "bool"},
"BREATHING_PERIOD": {"info_key": "backlight.breathing_period", "value_type": "int"},
"BACKLIGHT_PIN": {"info_key": "backlight.pin"},
"COMBO_COUNT": {"info_key": "combo.count", "value_type": "int"},
"COMBO_TERM": {"info_key": "combo.term", "value_type": "int"},
"DEBOUNCE": {"info_key": "debounce", "value_type": "int"},
"DEVICE_VER": {"info_key": "usb.device_ver", "value_type": "hex"},
"DESCRIPTION": {"info_key": "keyboard_folder", "to_json": false},
"DIODE_DIRECTION": {"info_key": "diode_direction"},
"EE_HANDS": {"info_key": "split.ee_hands"},
"FORCE_NKRO": {"info_key": "features.force_nkro", "value_type": "bool"},
"IGNORE_MOD_TAP_INTERRUPT": {"info_key": "tapping.ignore_mod_tap_interrupt", "value_type": "bool"},
"IGNORE_MOD_TAP_INTERRUPT_PER_KEY": {"info_key": "tapping.ignore_mod_tap_interrupt_per_key", "value_type": "bool"},
"LAYOUTS": {"info_key": "layout_aliases", "value_type": "mapping"},
"LEADER_PER_KEY_TIMING": {"info_key": "leader_key.timing", "value_type": "bool"},
"LEADER_KEY_STRICT_KEY_PROCESSING": {"info_key": "leader_key.strict_processing", "value_type": "bool"},
"LEADER_TIMEOUT": {"info_key": "leader_key.timeout", "value_type": "int"},
"LED_CAPS_LOCK_PIN": {"info_key": "indicators.caps_lock"},
"LED_NUM_LOCK_PIN": {"info_key": "indicators.num_lock"},
"LED_SCROLL_LOCK_PIN": {"info_key": "indicators.scroll_lock"},
"MANUFACTURER": {"info_key": "manufacturer"},
"MATRIX_HAS_GHOST": {"info_key": "matrix_pins.ghost", "value_type": "bool"},
"MATRIX_IO_DELAY": {"info_key": "matrix_pins.io_delay", "value_type": "int"},
"ONESHOT_TIMEOUT": {"info_key": "oneshot.timeout", "value_type": "int"},
"ONESHOT_TAP_TOGGLE": {"info_key": "oneshot.tap_toggle", "value_type": "int"},
"PERMISSIVE_HOLD": {"info_key": "tapping.permissive_hold", "value_type": "bool"},
"PERMISSIVE_HOLD_PER_KEY": {"info_key": "tapping.permissive_hold_per_key", "value_type": "bool"},
"RETRO_TAPPING": {"info_key": "tapping.retro", "value_type": "bool"},
"RETRO_TAPPING_PER_KEY": {"info_key": "tapping.retro_per_key", "value_type": "bool"},
"RGB_DI_PIN": {"info_key": "rgblight.pin"},
"RGBLED_NUM": {"info_key": "rgblight.led_count", "value_type": "int"},
"RGBLED_SPLIT": {"info_key": "rgblight.split_count", "value_type": "array.int"},
Expand All @@ -42,11 +62,22 @@
"VENDOR_ID": {"info_key": "usb.vid", "value_type": "hex"},
"QMK_ESC_OUTPUT": {"info_key": "qmk_lufa_bootloader.esc_output"},
"QMK_ESC_INPUT": {"info_key": "qmk_lufa_bootloader.esc_input"},
"QMK_KEYS_PER_SCAN": {"info_key": "qmk.keys_per_scan", "value_type": "int"},
"QMK_LED": {"info_key": "qmk_lufa_bootloader.led"},
"QMK_SPEAKER": {"info_key": "qmk_lufa_bootloader.speaker"},
"SPLIT_HAND_PIN": {"info_key": "split.hand_pin"},
"SPLIT_HAND_MATRIX_GRID": {"info_key": "split.hand_matrix_grid", "value_type": "array"},
"SPLIT_TRANSPORT_MIRROR": {"info_key": "split.mirror", "value_type": "bool"},
"SOFT_SERIAL_PIN": {"info_key": "split.soft_serial_pin"},
"SOFT_SERIAL_SPEED": {"info_key": "split.soft_serial_speed"}
"SOFT_SERIAL_SPEED": {"info_key": "split.soft_serial_speed"},
"TAP_CODE_DELAY": {"info_key": "qmk.tap_keycode_delay", "value_type": "int"},
"TAP_HOLD_CAPS_DELAY": {"info_key": "qmk.tap_capslock_delay", "value_type": "int"},
"TAPPING_FORCE_HOLD": {"info_key": "tapping.force_hold", "value_type": "bool"},
"TAPPING_FORCE_HOLD_PER_KEY": {"info_key": "tapping.force_hold_per_key", "value_type": "bool"},
"TAPPING_TERM": {"info_key": "tapping.term", "value_type": "int"},
"TAPPING_TERM_PER_KEY": {"info_key": "tapping.term_per_key", "value_type": "bool"},
"TAPPING_TOGGLE": {"info_key": "tapping.toggle", "value_type": "int"},
"USB_MAX_POWER_CONSUMPTION": {"info_key": "usb.max_power", "value_type": "int"},
"USB_POLLING_INTERVAL_MS": {"info_key": "usb.polling_interval", "value_type": "int"},
"USB_SUSPEND_WAKEUP_DELAY": {"info_key": "usb.suspend_wakeup_delay", "value_type": "int"},
}
82 changes: 79 additions & 3 deletions data/schemas/keyboard.jsonschema
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,29 @@
"type": "string",
"enum": ["cortex-m0", "cortex-m0plus", "cortex-m3", "cortex-m4", "MKL26Z64", "MK20DX128", "MK20DX256", "MK66F18", "STM32F042", "STM32F072", "STM32F103", "STM32F303", "STM32F401", "STM32F407", "STM32F411", "STM32F446", "STM32G431", "STM32G474", "STM32L412", "STM32L422", "STM32L433", "STM32L443", "atmega16u2", "atmega32u2", "atmega16u4", "atmega32u4", "at90usb162", "at90usb646", "at90usb647", "at90usb1286", "at90usb1287", "atmega32a", "atmega328p", "atmega328", "attiny85", "unknown"]
},
"audio": {
"type": "object",
"additionalProperties": false,
"properties": {
"pins": {"$ref": "qmk.definitions.v1#/mcu_pin_array"},
"voices": {"type": "boolean"}
}
},
"backlight": {
"type": "object",
"additionalProperties": false,
"properties": {
"breathing": {"type": "boolean"},
"breathing_period": {"$ref": "qmk.definitions.v1#/unsigned_int_8"},
"levels": {
"type": "number",
"min": 1,
"max": 31,
"multipleOf": 1
},
"pin": {"$ref": "qmk.definitions.v1#/mcu_pin"}
}
},
"board": {
"type": "string",
"minLength": 2,
Expand All @@ -29,6 +52,13 @@
"enum": ["COL2ROW", "ROW2COL"]
},
"debounce": {"$ref": "qmk.definitions.v1#/unsigned_int"},
"combo": {
"type": "object",
"properties": {
"count": {"$ref": "qmk.definitions.v1#/unsigned_int"},
"term": {"$ref": "qmk.definitions.v1#/unsigned_int"}
}
},
"community_layouts": {
"type": "array",
"items": {"$ref": "qmk.definitions.v1#/filename"}
Expand Down Expand Up @@ -90,16 +120,34 @@
}
}
},
"leader_key": {
"type": "object",
"properties": {
"timing": {"type": "boolean"},
"strict_processing": {"type": "boolean"},
"timeout": {"$ref": "qmk.definitions.v1#/unsigned_int"}
}
},
"matrix_pins": {
"type": "object",
"additionalProperties": false,
"properties": {
"ghost": {"type": "boolean"},
"io_delay": {"$ref": "qmk.definitions.v1#/unsigned_int"},
"direct": {
"type": "array",
"items": {$ref": "qmk.definitions.v1#/mcu_pin_array"}
"items": {"$ref": "qmk.definitions.v1#/mcu_pin_array"}
},
"cols": {"$ref": "qmk.definitions.v1#/mcu_pin_array"},
"rows": {"$ref": "qmk.definitions.v1#/mcu_pin_array"}
"rows": {"$ref": "qmk.definitions.v1#/mcu_pin_array"},
"unused": {"$ref": "qmk.definitions.v1#/mcu_pin_array"}
}
},
"oneshot": {
"type": "object",
"properties": {
"tap_toggle": {"$ref": "qmk.definitions.v1#/unsigned_int"},
"timeout": {"$ref": "qmk.definitions.v1#/unsigned_int"}
}
},
"rgblight": {
Expand Down Expand Up @@ -154,13 +202,41 @@
"type": "array",
"items": {"type": "string"}
},
"tapping": {
"type": "object",
"properties": {
"force_hold": {"type": "boolean"},
"force_hold_per_key": {"type": "boolean"},
"ignore_mod_tap_interrupt": {"type": "boolean"},
"ignore_mod_tap_interrupt_per_key": {"type": "boolean"},
"permissive_hold": {"type": "boolean"},
"permissive_hold_per_key": {"type": "boolean"},
"retro": {"type": "boolean"},
"retro_per_key": {"type": "boolean"},
"term": {"$ref": "qmk.definitions.v1#/unsigned_int"},
"term_per_key": {"type": "boolean"},
"toggle": {"$ref": "qmk.definitions.v1#/unsigned_int"},
}
},
"usb": {
"type": "object",
"additionalProperties": false,
"properties": {
"device_ver": {"$ref": "qmk.definitions.v1#/hex_number_4d"},
"pid": {"$ref": "qmk.definitions.v1#/hex_number_4d"},
"vid": {"$ref": "qmk.definitions.v1#/hex_number_4d"}
"vid": {"$ref": "qmk.definitions.v1#/hex_number_4d"},
"max_power": {"$ref": "qmk.definitions.v1#/unsigned_int_8"},
"polling_interval": {"$ref": "qmk.definitions.v1#/unsigned_int_8"},
"suspend_wakeup_delay": {"$ref": "qmk.definitions.v1#/unsigned_int_8"}
}
},
"qmk": {
"type": "object",
"additionalProperties": false,
"properties": {
"keys_per_scan": {"$ref": "qmk.definitions.v1#/unsigned_int_8"},
"tap_keycode_delay": {"$ref": "qmk.definitions.v1#/unsigned_int_8"},
"tap_capslock_delay": {"$ref": "qmk.definitions.v1#/unsigned_int_8"},
}
},
"qmk_lufa_bootloader": {
Expand Down
2 changes: 1 addition & 1 deletion lib/python/qmk/cli/generate/info_json.py
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ def strip_info_json(kb_info_json):
"""Remove the API-only properties from the info.json.
"""
pruning_draft_7_validator = pruning_validator(Draft7Validator)
schema = load_jsonschema('keyboard')
schema = load_jsonschema('qmk.keyboard.v1')
validator = pruning_draft_7_validator(schema).validate

return validator(kb_info_json)
Expand Down
19 changes: 19 additions & 0 deletions lib/python/qmk/info.py
Original file line number Diff line number Diff line change
Expand Up @@ -188,11 +188,26 @@ def _extract_direct_matrix(info_data, direct_pins):
return direct_pin_array


def _extract_audio(info_data, config_c):
"""Populate the matrix information.
"""
audio_pins = []

for pin in 'B5', 'B6', 'B7', 'C4', 'C5', 'C6':
if config_c.get(f'{pin}_AUDIO'):
audio_pins.append(pin)

if audio_pins:
info_data['audio'] = {'pins': audio_pins}


def _extract_matrix_info(info_data, config_c):
"""Populate the matrix information.
"""
row_pins = config_c.get('MATRIX_ROW_PINS', '').replace('{', '').replace('}', '').strip()
col_pins = config_c.get('MATRIX_COL_PINS', '').replace('{', '').replace('}', '').strip()
unused_pin_text = config_c.get('UNUSED_PINS')
unused_pins = unused_pin_text.replace('{', '').replace('}', '').strip() if isinstance(unused_pin_text, str) else None
direct_pins = config_c.get('DIRECT_PINS', '').replace(' ', '')[1:-1]

if 'MATRIX_ROWS' in config_c and 'MATRIX_COLS' in config_c:
Expand All @@ -219,6 +234,9 @@ def _extract_matrix_info(info_data, config_c):

info_data['matrix_pins']['direct'] = _extract_direct_matrix(info_data, direct_pins)

if unused_pins and 'matirx_pins' in info_data:
info_data['matrix_pins']['unused'] = _extract_pins(unused_pins)

return info_data


Expand Down Expand Up @@ -275,6 +293,7 @@ def _extract_config_h(info_data):

# Pull data that easily can't be mapped in json
_extract_matrix_info(info_data, config_c)
_extract_audio(info_data, config_c)

return info_data

Expand Down
3 changes: 3 additions & 0 deletions lib/python/qmk/json_schema.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
"""
import json
from collections.abc import Mapping
from functools import lru_cache
from pathlib import Path

import hjson
Expand All @@ -25,6 +26,7 @@ def json_load(json_file):
exit(1)


@lru_cache(maxsize=0)
def load_jsonschema(schema_name):
"""Read a jsonschema file from disk.
"""
Expand All @@ -39,6 +41,7 @@ def load_jsonschema(schema_name):
return json_load(schema_path)


@lru_cache(maxsize=0)
def create_validator(schema):
"""Creates a validator for the given schema id.
"""
Expand Down