summaryrefslogtreecommitdiff
path: root/app/src
diff options
context:
space:
mode:
authorinnovaker <66737976+innovaker@users.noreply.github.com>2020-10-27 22:35:44 +0000
committerinnovaker <66737976+innovaker@users.noreply.github.com>2020-10-27 22:36:26 +0000
commitf4596fc784d11aa2d03ff0b7fa0a921600fc2db2 (patch)
tree1a063ac59d31d6fd52be9f49ba15312543f7b528 /app/src
parentdfb69d8727e01cb9ee855ac2d1cb7a6da1d6aa85 (diff)
refactor(hid): Refactor keypad report to use a configurable integer array
Replace NKRO bit array with configurable integer (DV) array.
Diffstat (limited to 'app/src')
-rw-r--r--app/src/hid.c45
1 files changed, 11 insertions, 34 deletions
diff --git a/app/src/hid.c b/app/src/hid.c
index f80906c..5e46832 100644
--- a/app/src/hid.c
+++ b/app/src/hid.c
@@ -9,8 +9,8 @@ LOG_MODULE_DECLARE(zmk, CONFIG_ZMK_LOG_LEVEL);
#include <zmk/hid.h>
-static struct zmk_hid_keypad_report kp_report = {
- .report_id = 1, .body = {.modifiers = 0, .keys = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}}};
+static struct zmk_hid_keypad_report kp_report = {.report_id = 1,
+ .body = {.modifiers = 0, .keys = {0}}};
static struct zmk_hid_consumer_report consumer_report = {.report_id = 2,
.body = {.keys = {0, 0, 0, 0, 0, 0}}};
@@ -35,23 +35,16 @@ int zmk_hid_unregister_mods(zmk_mod_flags modifiers) {
return 0;
}
-#define KEY_OFFSET 0x02
#define MAX_KEYS 6
-/*
-#define TOGGLE_BOOT_KEY(match, val) \
- for (int idx = 0; idx < MAX_KEYS; idx++) \
- { \
- if (kp_report.boot.keys[idx + KEY_OFFSET] != match) \
- { \
- continue; \
- } \
- kp_report.boot.keys[idx + KEY_OFFSET] = val; \
- break; \
+#define TOGGLE_KEYPAD(match, val) \
+ for (int idx = 0; idx < ZMK_HID_KEYPAD_NKRO_SIZE; idx++) { \
+ if (kp_report.body.keys[idx] != match) { \
+ continue; \
+ } \
+ kp_report.body.keys[idx] = val; \
+ break; \
}
-*/
-
-#define TOGGLE_KEY(code, val) WRITE_BIT(kp_report.body.keys[code / 8], code % 8, val)
#define TOGGLE_CONSUMER(match, val) \
for (int idx = 0; idx < MAX_KEYS; idx++) { \
@@ -66,15 +59,7 @@ int zmk_hid_keypad_press(zmk_key code) {
if (code >= LCTL && code <= RGUI) {
return zmk_hid_register_mod(code - LCTL);
}
-
- if (code > ZMK_HID_MAX_KEYCODE) {
- return -EINVAL;
- }
-
- // TOGGLE_BOOT_KEY(0U, code);
-
- TOGGLE_KEY(code, true);
-
+ TOGGLE_KEYPAD(0U, code);
return 0;
};
@@ -82,15 +67,7 @@ int zmk_hid_keypad_release(zmk_key code) {
if (code >= LCTL && code <= RGUI) {
return zmk_hid_unregister_mod(code - LCTL);
}
-
- if (code > ZMK_HID_MAX_KEYCODE) {
- return -EINVAL;
- }
-
- // TOGGLE_BOOT_KEY(0U, code);
-
- TOGGLE_KEY(code, false);
-
+ TOGGLE_KEYPAD(code, 0U);
return 0;
};