summaryrefslogtreecommitdiff
path: root/app/src
diff options
context:
space:
mode:
authorOkke Formsma <okke@formsma.nl>2020-12-12 21:35:52 +0100
committerPete Johanson <peter@peterjohanson.com>2021-01-28 17:10:04 -0500
commitc925cf02dd1999c0e968ead7652956e5e1925875 (patch)
tree0040ab144a3c7d1ca176539116b37ebbca308a7c /app/src
parenta89d8a6ea425e28856e762bd4db50a6a40ef58e8 (diff)
feature(sticky_keys): add quick-release
when quick-release is enabled, the sticky key is released immediately after another key is pressed
Diffstat (limited to 'app/src')
-rw-r--r--app/src/behaviors/behavior_sticky_key.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/app/src/behaviors/behavior_sticky_key.c b/app/src/behaviors/behavior_sticky_key.c
index fe05e06..aa9fe9a 100644
--- a/app/src/behaviors/behavior_sticky_key.c
+++ b/app/src/behaviors/behavior_sticky_key.c
@@ -29,6 +29,7 @@ LOG_MODULE_DECLARE(zmk, CONFIG_ZMK_LOG_LEVEL);
struct behavior_sticky_key_config {
uint32_t release_after_ms;
+ bool quick_release;
struct zmk_behavior_binding behavior;
};
@@ -209,10 +210,12 @@ static int sticky_key_keycode_state_changed_listener(const zmk_event_t *eh) {
}
if (sticky_key->timer_started) {
stop_timer(sticky_key);
+ if (sticky_key->config->quick_release) {
+ release_sticky_key_behavior(sticky_key, ev->timestamp);
+ }
}
sticky_key->modified_key_usage_page = ev->usage_page;
sticky_key->modified_key_keycode = ev->keycode;
-
} else { // key up
if (sticky_key->timer_started &&
sticky_key->modified_key_usage_page == ev->usage_page &&
@@ -269,6 +272,7 @@ static struct behavior_sticky_key_data behavior_sticky_key_data;
#define KP_INST(n) \
static struct behavior_sticky_key_config behavior_sticky_key_config_##n = { \
.behavior = _TRANSFORM_ENTRY(0, n).release_after_ms = DT_INST_PROP(n, release_after_ms), \
+ .quick_release = DT_INST_PROP(n, quick_release), \
}; \
DEVICE_AND_API_INIT(behavior_sticky_key_##n, DT_INST_LABEL(n), behavior_sticky_key_init, \
&behavior_sticky_key_data, &behavior_sticky_key_config_##n, APPLICATION, \