summaryrefslogtreecommitdiffstats
path: root/keyboards/yosino58/lib/keylogger.c
diff options
context:
space:
mode:
authorさくらんぼ <47372812+sakurachari@users.noreply.github.com>2019-04-11 18:07:39 +0200
committerMechMerlin <30334081+mechmerlin@users.noreply.github.com>2019-04-11 18:07:39 +0200
commitdc570b0b389d23b8ea8b46311294a7040b5e1e44 (patch)
tree8e47ebf2f6c291e960664e5d20afc308afa92e24 /keyboards/yosino58/lib/keylogger.c
parentfa514e63aaed358dbe4d098e7dc31561f148aec0 (diff)
downloadqmk_firmware-dc570b0b389d23b8ea8b46311294a7040b5e1e44.tar.gz
qmk_firmware-dc570b0b389d23b8ea8b46311294a7040b5e1e44.tar.xz
Keyboard: Add yosino58 Keyboard (#5465)
* Keyboard: Add yosino58 Keyboard * Keyboard: Add yosino58 Keyboard
Diffstat (limited to 'keyboards/yosino58/lib/keylogger.c')
-rw-r--r--keyboards/yosino58/lib/keylogger.c45
1 files changed, 45 insertions, 0 deletions
diff --git a/keyboards/yosino58/lib/keylogger.c b/keyboards/yosino58/lib/keylogger.c
new file mode 100644
index 000000000..c50de94c2
--- /dev/null
+++ b/keyboards/yosino58/lib/keylogger.c
@@ -0,0 +1,45 @@
+#include <stdio.h>
+#include "yosino58.h"
+
+char keylog_str[24] = {};
+char keylogs_str[21] = {};
+int keylogs_str_idx = 0;
+
+const char code_to_name[60] = {
+ ' ', ' ', ' ', ' ', 'a', 'b', 'c', 'd', 'e', 'f',
+ 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p',
+ 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z',
+ '1', '2', '3', '4', '5', '6', '7', '8', '9', '0',
+ 'R', 'E', 'B', 'T', ' ', ' ', ' ', ' ', ' ', ' ',
+ ' ', ';', '\'', ' ', ',', '.', '/', ' ', ' ', ' '};
+
+void set_keylog(uint16_t keycode, keyrecord_t *record) {
+ char name = ' ';
+ if (keycode < 60) {
+ name = code_to_name[keycode];
+ }
+
+ // update keylog
+ snprintf(keylog_str, sizeof(keylog_str), "%dx%d, k%2d : %c",
+ record->event.key.row, record->event.key.col,
+ keycode, name);
+
+ // update keylogs
+ if (keylogs_str_idx == sizeof(keylogs_str) - 1) {
+ keylogs_str_idx = 0;
+ for (int i = 0; i < sizeof(keylogs_str) - 1; i++) {
+ keylogs_str[i] = ' ';
+ }
+ }
+
+ keylogs_str[keylogs_str_idx] = name;
+ keylogs_str_idx++;
+}
+
+const char *read_keylog(void) {
+ return keylog_str;
+}
+
+const char *read_keylogs(void) {
+ return keylogs_str;
+}