summaryrefslogtreecommitdiff
path: root/app/src/keymap.c
diff options
context:
space:
mode:
authorPete Johanson <peter@peterjohanson.com>2020-08-18 14:25:03 -0400
committerGitHub <noreply@github.com>2020-08-18 14:25:03 -0400
commitc667be1404259851daca8719f08e1436b408fea9 (patch)
treefb191880ae293324da190b7aaf89b1c3917b92ff /app/src/keymap.c
parent2ffe09b617419a25e45c387e001ea59d3cbb5652 (diff)
parent50643b2c561ef58d4c96e7dba6c55c0ef291146a (diff)
Merge pull request #98 from BrainWart/layer-toggle
Feature: Layer toggle
Diffstat (limited to 'app/src/keymap.c')
-rw-r--r--app/src/keymap.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/app/src/keymap.c b/app/src/keymap.c
index ff494f7..ee6e370 100644
--- a/app/src/keymap.c
+++ b/app/src/keymap.c
@@ -76,6 +76,11 @@ static struct zmk_behavior_binding zmk_sensor_keymap[ZMK_KEYMAP_LAYERS_LEN][ZMK_
WRITE_BIT(zmk_keymap_layer_state, layer, state); \
return 0;
+bool zmk_keymap_layer_active(u8_t layer)
+{
+ return (zmk_keymap_layer_state & (BIT(layer))) == (BIT(layer));
+};
+
int zmk_keymap_layer_activate(u8_t layer)
{
SET_LAYER_STATE(layer, true);
@@ -86,6 +91,16 @@ int zmk_keymap_layer_deactivate(u8_t layer)
SET_LAYER_STATE(layer, false);
};
+int zmk_keymap_layer_toggle(u8_t layer)
+{
+ if (zmk_keymap_layer_active(layer))
+ {
+ return zmk_keymap_layer_deactivate(layer);
+ }
+
+ return zmk_keymap_layer_activate(layer);
+};
+
bool is_active_position(u32_t position, u8_t layer)
{
return (zmk_keymap_layer_state & BIT(layer)) == BIT(layer)