From 07723b9a69217e822f63e0bb10b767f15b9847df Mon Sep 17 00:00:00 2001 From: Benedikt Peetz Date: Mon, 30 Dec 2024 23:04:51 +0100 Subject: feat(soispha/keymap): Actually send a keycode to start the application --- src/keymaps/soispha/keymap.c | 34 ++++++++++++++++++++++++++++++++-- 1 file changed, 32 insertions(+), 2 deletions(-) diff --git a/src/keymaps/soispha/keymap.c b/src/keymaps/soispha/keymap.c index 2b6c16f..7b8c14d 100644 --- a/src/keymaps/soispha/keymap.c +++ b/src/keymaps/soispha/keymap.c @@ -10,12 +10,12 @@ * If not, see . */ +#include "hid/hid.h" #include "layout/layout.h" #include "macros.h" #include "version.h" #include #include -#include "hid/hid.h" bool process_record_user(uint16_t keycode, keyrecord_t *record) { switch (keycode) { @@ -82,8 +82,38 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { return false; } - if (keycode >= UK_UNICODE && keycode <= UK_UNICODE_MAX) { + uint8_t unicode_saved_mods; + // led_t unicode_saved_led_state; + if (keycode >= UK_UNICODE && keycode <= UK_UNICODE_MAX && + record->event.pressed) { + + // unicode_saved_led_state = host_keyboard_led_state(); + // + // // Note the order matters here! + // // Need to do this before we mess around with the mods, or else + // // UNICODE_KEY_LNX (which is usually Ctrl-Shift-U) might not work + // // correctly in the shifted case. + // if (unicode_saved_led_state.caps_lock) { + // tap_code(KC_CAPS_LOCK); + // } + + unicode_saved_mods = get_mods(); // Save current mods + clear_mods(); // Unregister mods to start from a clean state + clear_weak_mods(); + + tap_code16(HYPR(KC_Z)); + + // Give the pc time to start our application + wait_ms(10); + hid_send(QK_UNICODE_GET_CODE_POINT(keycode)); + + // if (unicode_saved_led_state.caps_lock) { + // tap_code(KC_CAPS_LOCK); + // } + set_mods(unicode_saved_mods); // Reregister previously set mods + + return false; } return true; -- cgit 1.4.1