diff options
author | CrossR <r.cross@lancaster.ac.uk> | 2020-08-19 20:53:40 +0100 |
---|---|---|
committer | CrossR <r.cross@lancaster.ac.uk> | 2020-08-19 20:53:40 +0100 |
commit | f8a635aaa0b379d499c0b4c4cd5d7831e1fda7fd (patch) | |
tree | b2adb5a989b2a67360aea46abe0d13ffa02734a9 /app/src/keymap.c | |
parent | dcd36f12e049ee2c423204ebaaa3c16062d9fd5e (diff) | |
parent | ebd6fbb2254cfcdd8af6309dd9a5c3251ac19935 (diff) |
Merge remote-tracking branch 'upstream/main' into CrossR/Sofle
Diffstat (limited to 'app/src/keymap.c')
-rw-r--r-- | app/src/keymap.c | 15 |
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) |