diff --git a/app/include/zmk/keymap.h b/app/include/zmk/keymap.h index 6cb39311..2642849d 100644 --- a/app/include/zmk/keymap.h +++ b/app/include/zmk/keymap.h @@ -6,8 +6,10 @@ #pragma once -u8_t zmk_layer_default(); -u32_t zmk_layer_state(); +typedef u32_t zmk_keymap_layers_state; + +u8_t zmk_keymap_layer_default(); +zmk_keymap_layers_state zmk_keymap_layer_state(); bool zmk_keymap_layer_active(u8_t layer); u8_t zmk_highest_layer_active(); int zmk_keymap_layer_activate(u8_t layer); diff --git a/app/src/keymap.c b/app/src/keymap.c index cd6dd6f4..a1bfcbd5 100644 --- a/app/src/keymap.c +++ b/app/src/keymap.c @@ -19,9 +19,8 @@ LOG_MODULE_DECLARE(zmk, CONFIG_ZMK_LOG_LEVEL); #include #include -typedef u32_t zmk_layers_state; -static zmk_layers_state zmk_keymap_layer_state = 0; -static u8_t zmk_keymap_layer_default = 0; +static zmk_keymap_layers_state _zmk_keymap_layer_state = 0; +static u8_t _zmk_keymap_layer_default = 0; #define DT_DRV_COMPAT zmk_keymap @@ -82,17 +81,17 @@ static inline int set_layer_state(u8_t layer, bool state) { if (layer >= 32) { return -EINVAL; } - WRITE_BIT(zmk_keymap_layer_state, layer, state); + WRITE_BIT(_zmk_keymap_layer_state, layer, state); ZMK_EVENT_RAISE(create_layer_state_changed(layer, state)); return 0; } -u8_t zmk_layer_default() { return zmk_keymap_layer_default; } +u8_t zmk_keymap_layer_default() { return _zmk_keymap_layer_default; } -zmk_layers_state zmk_layer_state() { return zmk_keymap_layer_state; } +zmk_keymap_layers_state zmk_keymap_layer_state() { return _zmk_keymap_layer_state; } bool zmk_keymap_layer_active(u8_t layer) { - return (zmk_keymap_layer_state & (BIT(layer))) == (BIT(layer)); + return (_zmk_keymap_layer_state & (BIT(layer))) == (BIT(layer)); }; u8_t zmk_highest_layer_active() { @@ -101,7 +100,7 @@ u8_t zmk_highest_layer_active() { return layer; } } - return zmk_layer_default(); + return zmk_keymap_layer_default(); } int zmk_keymap_layer_activate(u8_t layer) { return set_layer_state(layer, true); }; @@ -116,8 +115,8 @@ int zmk_keymap_layer_toggle(u8_t layer) { return zmk_keymap_layer_activate(layer); }; -bool is_active_layer(u8_t layer, zmk_layers_state layer_state) { - return (layer_state & BIT(layer)) == BIT(layer) || layer == zmk_keymap_layer_default; +bool is_active_layer(u8_t layer, zmk_keymap_layers_state layer_state) { + return (layer_state & BIT(layer)) == BIT(layer) || layer == _zmk_keymap_layer_default; } int zmk_keymap_apply_position_state(int layer, u32_t position, bool pressed, s64_t timestamp) { @@ -148,9 +147,9 @@ int zmk_keymap_apply_position_state(int layer, u32_t position, bool pressed, s64 int zmk_keymap_position_state_changed(u32_t position, bool pressed, s64_t timestamp) { if (pressed) { - zmk_keymap_active_behavior_layer[position] = zmk_keymap_layer_state; + zmk_keymap_active_behavior_layer[position] = _zmk_keymap_layer_state; } - for (int layer = ZMK_KEYMAP_LAYERS_LEN - 1; layer >= zmk_keymap_layer_default; layer--) { + for (int layer = ZMK_KEYMAP_LAYERS_LEN - 1; layer >= _zmk_keymap_layer_default; layer--) { if (is_active_layer(layer, zmk_keymap_active_behavior_layer[position])) { int ret = zmk_keymap_apply_position_state(layer, position, pressed, timestamp); if (ret > 0) { @@ -170,9 +169,9 @@ int zmk_keymap_position_state_changed(u32_t position, bool pressed, s64_t timest #if ZMK_KEYMAP_HAS_SENSORS int zmk_keymap_sensor_triggered(u8_t sensor_number, struct device *sensor, s64_t timestamp) { - for (int layer = ZMK_KEYMAP_LAYERS_LEN - 1; layer >= zmk_keymap_layer_default; layer--) { - if (((zmk_keymap_layer_state & BIT(layer)) == BIT(layer) || - layer == zmk_keymap_layer_default) && + for (int layer = ZMK_KEYMAP_LAYERS_LEN - 1; layer >= _zmk_keymap_layer_default; layer--) { + if (((_zmk_keymap_layer_state & BIT(layer)) == BIT(layer) || + layer == _zmk_keymap_layer_default) && zmk_sensor_keymap[layer] != NULL) { struct zmk_behavior_binding *binding = &zmk_sensor_keymap[layer][sensor_number]; struct device *behavior;