From eff1b8223b5010d526914530c5d1d469eff356df Mon Sep 17 00:00:00 2001 From: Pete Johanson Date: Mon, 26 Oct 2020 00:30:24 -0400 Subject: refactor(keys): Unify usage page. * Remove need for separate `&cp` behavior, but keep it for now for backward compat. * Refactor sensor inc/dec as well. --- app/include/zmk/events/keycode-state-changed.h | 22 ++++++++++++++++------ 1 file changed, 16 insertions(+), 6 deletions(-) (limited to 'app/include/zmk') diff --git a/app/include/zmk/events/keycode-state-changed.h b/app/include/zmk/events/keycode-state-changed.h index 26d07ec..fe47a0f 100644 --- a/app/include/zmk/events/keycode-state-changed.h +++ b/app/include/zmk/events/keycode-state-changed.h @@ -8,7 +8,9 @@ #include #include +#include #include +#include struct keycode_state_changed { struct zmk_event_header header; @@ -20,12 +22,20 @@ struct keycode_state_changed { ZMK_EVENT_DECLARE(keycode_state_changed); -static inline struct keycode_state_changed * -create_keycode_state_changed(u8_t usage_page, u32_t keycode, bool state) { +static inline struct keycode_state_changed *keycode_state_changed_from_encoded(u32_t encoded, + bool pressed) { + u16_t page = HID_EXT_USAGE_PAGE(encoded) & 0xFF; + u16_t id = HID_EXT_USAGE_ID(encoded); + zmk_mod_flags implicit_mods = SELECT_MODS(encoded); + + if (!page) { + page = HID_USAGE_KEY; + } + struct keycode_state_changed *ev = new_keycode_state_changed(); - ev->usage_page = usage_page; - ev->keycode = STRIP_MODS(keycode); - ev->implicit_modifiers = SELECT_MODS(keycode); - ev->state = state; + ev->usage_page = page; + ev->keycode = id; + ev->implicit_modifiers = implicit_mods; + ev->state = pressed; return ev; } -- cgit v1.2.3