aboutsummaryrefslogtreecommitdiffhomepage
path: root/app/src/behaviors/behavior_key_toggle.c
diff options
context:
space:
mode:
authorNicolas Munnich <[email protected]>2024-12-13 00:13:56 +0000
committerGitHub <[email protected]>2024-12-12 19:13:56 -0500
commit4ef231f4bba87151acfbd1cf3babd83b69813e45 (patch)
tree4f8ed2da58aa8284d6fdc010983279140819f73a /app/src/behaviors/behavior_key_toggle.c
parent7013158a6715d94b34e8c471ce25bb5005f3bb49 (diff)
downloadzmk-4ef231f4bba87151acfbd1cf3babd83b69813e45.tar.gz
zmk-4ef231f4bba87151acfbd1cf3babd83b69813e45.zip
feat: Added `toggle-mode`, allowing toggle-on and toggle-off (#2555)
feat: added toggle mode to key and layer toggles docs: documented toggle mode changes
Diffstat (limited to 'app/src/behaviors/behavior_key_toggle.c')
-rw-r--r--app/src/behaviors/behavior_key_toggle.c35
1 files changed, 31 insertions, 4 deletions
diff --git a/app/src/behaviors/behavior_key_toggle.c b/app/src/behaviors/behavior_key_toggle.c
index 72f2570b4d..355f4e465d 100644
--- a/app/src/behaviors/behavior_key_toggle.c
+++ b/app/src/behaviors/behavior_key_toggle.c
@@ -17,18 +17,41 @@
LOG_MODULE_DECLARE(zmk, CONFIG_ZMK_LOG_LEVEL);
+enum toggle_mode {
+ ON,
+ OFF,
+ FLIP,
+};
+
+struct behavior_key_toggle_config {
+ enum toggle_mode toggle_mode;
+};
+
static int behavior_key_toggle_init(const struct device *dev) { return 0; }
static int on_keymap_binding_pressed(struct zmk_behavior_binding *binding,
struct zmk_behavior_binding_event event) {
LOG_DBG("position %d keycode 0x%02X", event.position, binding->param1);
- bool pressed = zmk_hid_is_pressed(binding->param1);
- return raise_zmk_keycode_state_changed_from_encoded(binding->param1, !pressed, event.timestamp);
+ const struct behavior_key_toggle_config *cfg =
+ zmk_behavior_get_binding(binding->behavior_dev)->config;
+ switch (cfg->toggle_mode) {
+ case ON:
+ return raise_zmk_keycode_state_changed_from_encoded(binding->param1, true, event.timestamp);
+ case OFF:
+ return raise_zmk_keycode_state_changed_from_encoded(binding->param1, false,
+ event.timestamp);
+ case FLIP:
+ bool pressed = zmk_hid_is_pressed(binding->param1);
+ return raise_zmk_keycode_state_changed_from_encoded(binding->param1, !pressed,
+ event.timestamp);
+ default:
+ return -ENOTSUP;
+ };
}
static int on_keymap_binding_released(struct zmk_behavior_binding *binding,
struct zmk_behavior_binding_event event) {
- return 0;
+ return ZMK_BEHAVIOR_OPAQUE;
}
#if IS_ENABLED(CONFIG_ZMK_BEHAVIOR_METADATA)
@@ -61,7 +84,11 @@ static const struct behavior_driver_api behavior_key_toggle_driver_api = {
};
#define KT_INST(n) \
- BEHAVIOR_DT_INST_DEFINE(n, behavior_key_toggle_init, NULL, NULL, NULL, POST_KERNEL, \
+ static const struct behavior_key_toggle_config behavior_key_toggle_config_##n = { \
+ .toggle_mode = DT_ENUM_IDX(DT_DRV_INST(n), toggle_mode), \
+ }; \
+ BEHAVIOR_DT_INST_DEFINE(n, behavior_key_toggle_init, NULL, NULL, \
+ &behavior_key_toggle_config_##n, POST_KERNEL, \
CONFIG_KERNEL_INIT_PRIORITY_DEFAULT, &behavior_key_toggle_driver_api);
DT_INST_FOREACH_STATUS_OKAY(KT_INST)