Add support for key override introspection. (#24120)
This commit is contained in:
parent
fef8e7195b
commit
8abaa3bc2d
6 changed files with 90 additions and 25 deletions
19
docs/ChangeLog/PR24120.md
Normal file
19
docs/ChangeLog/PR24120.md
Normal file
|
@ -0,0 +1,19 @@
|
|||
## Changes requiring user action
|
||||
|
||||
### Key Override Introspection
|
||||
|
||||
Changes were made to key overrides in order to hook them into the keymap introspection system.
|
||||
|
||||
Key override signature changed from:
|
||||
|
||||
```c
|
||||
const key_override_t **key_overrides = (const key_override_t *[]){
|
||||
```
|
||||
|
||||
to:
|
||||
|
||||
```c
|
||||
const key_override_t *key_overrides[] = {
|
||||
```
|
||||
|
||||
The list of key overrides now does not need to be `NULL`-terminated.
|
|
@ -14,7 +14,7 @@ You can use key overrides in a similar way to momentary layer/fn keys to activat
|
|||
|
||||
To enable this feature, you need to add `KEY_OVERRIDE_ENABLE = yes` to your `rules.mk`.
|
||||
|
||||
Then, in your `keymap.c` file, you'll need to define the array `key_overrides`, which defines all key overrides to be used. Each override is a value of type `key_override_t`. The array `key_overrides` is `NULL`-terminated and contains pointers to `key_override_t` values (`const key_override_t **`).
|
||||
Then, in your `keymap.c` file, you'll need to define the array `key_overrides`, which defines all key overrides to be used. Each override is a value of type `key_override_t`. The array `key_overrides`contains pointers to `key_override_t` values (`const key_override_t **`).
|
||||
|
||||
## Creating Key Overrides {#creating-key-overrides}
|
||||
|
||||
|
@ -42,9 +42,8 @@ This shows how the mentioned example of sending `delete` when `shift` + `backspa
|
|||
const key_override_t delete_key_override = ko_make_basic(MOD_MASK_SHIFT, KC_BSPC, KC_DEL);
|
||||
|
||||
// This globally defines all key overrides to be used
|
||||
const key_override_t **key_overrides = (const key_override_t *[]){
|
||||
&delete_key_override,
|
||||
NULL // Null terminate the array of overrides!
|
||||
const key_override_t *key_overrides[] = {
|
||||
&delete_key_override
|
||||
};
|
||||
```
|
||||
|
||||
|
@ -91,14 +90,13 @@ const key_override_t brightness_up_override = ko_make_with_layers_negmods_and_op
|
|||
const key_override_t brightness_down_override = ko_make_basic(MOD_MASK_CSA, KC_MPLY, KC_BRID);
|
||||
|
||||
// This globally defines all key overrides to be used
|
||||
const key_override_t **key_overrides = (const key_override_t *[]){
|
||||
const key_override_t *key_overrides[] = {
|
||||
&next_track_override,
|
||||
&prev_track_override,
|
||||
&vol_up_override,
|
||||
&vol_down_override,
|
||||
&brightness_up_override,
|
||||
&brightness_down_override,
|
||||
NULL
|
||||
&brightness_down_override
|
||||
};
|
||||
```
|
||||
|
||||
|
@ -112,10 +110,9 @@ const key_override_t tilde_esc_override = ko_make_basic(MOD_MASK_SHIFT, KC_ESC,
|
|||
// GUI + esc = `
|
||||
const key_override_t grave_esc_override = ko_make_basic(MOD_MASK_GUI, KC_ESC, KC_GRV);
|
||||
|
||||
const key_override_t **key_overrides = (const key_override_t *[]){
|
||||
const key_override_t *key_overrides[] = {
|
||||
&tilde_esc_override,
|
||||
&grave_esc_override,
|
||||
NULL
|
||||
&grave_esc_override
|
||||
};
|
||||
```
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue