fix(hid): Clear all matching usages, not just first.
* If various events get dropped, we can end up with duplicate codes in our report, so tweak to ensure we look for all matches and clear them when we have a keycode released.
This commit is contained in:
parent
a0c32bb47e
commit
c11759bc79
1 changed files with 6 additions and 2 deletions
|
@ -55,7 +55,9 @@ int zmk_hid_unregister_mod(zmk_mod_t modifier) {
|
||||||
continue; \
|
continue; \
|
||||||
} \
|
} \
|
||||||
keyboard_report.body.keys[idx] = val; \
|
keyboard_report.body.keys[idx] = val; \
|
||||||
|
if (val) { \
|
||||||
break; \
|
break; \
|
||||||
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define TOGGLE_CONSUMER(match, val) \
|
#define TOGGLE_CONSUMER(match, val) \
|
||||||
|
@ -64,7 +66,9 @@ int zmk_hid_unregister_mod(zmk_mod_t modifier) {
|
||||||
continue; \
|
continue; \
|
||||||
} \
|
} \
|
||||||
consumer_report.body.keys[idx] = val; \
|
consumer_report.body.keys[idx] = val; \
|
||||||
|
if (val) { \
|
||||||
break; \
|
break; \
|
||||||
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
int zmk_hid_implicit_modifiers_press(zmk_mod_flags_t implicit_modifiers) {
|
int zmk_hid_implicit_modifiers_press(zmk_mod_flags_t implicit_modifiers) {
|
||||||
|
|
Loading…
Add table
Reference in a new issue