From 72bf921d62086fbba7ca96dbdfabda2cb44a876f Mon Sep 17 00:00:00 2001 From: Ilya Zhuravlev Date: Sat, 6 Mar 2021 14:05:32 -0500 Subject: [PATCH] dynamic_keymap: support delays in VIA macros --- quantum/dynamic_keymap.c | 30 ++++++++++++++++++++++-------- quantum/vial.h | 2 +- 2 files changed, 23 insertions(+), 9 deletions(-) diff --git a/quantum/dynamic_keymap.c b/quantum/dynamic_keymap.c index 8087c59513..97881646a3 100644 --- a/quantum/dynamic_keymap.c +++ b/quantum/dynamic_keymap.c @@ -376,16 +376,30 @@ void dynamic_keymap_macro_send(uint8_t id) { if (data[0] == 0) { break; } - // If the char is magic (tap, down, up), - // add the next char (key to use) and send a 3 char string. - if (data[0] == SS_TAP_CODE || data[0] == SS_DOWN_CODE || data[0] == SS_UP_CODE) { - data[1] = data[0]; - data[0] = SS_QMK_PREFIX; - data[2] = eeprom_read_byte(p++); - if (data[2] == 0) { + if (data[0] == SS_QMK_PREFIX) { + // If the char is magic, process it as indicated by the next character + // (tap, down, up, delay) + data[1] = eeprom_read_byte(p++); + if (data[1] == 0) break; + if (data[1] == SS_TAP_CODE || data[1] == SS_DOWN_CODE || data[1] == SS_UP_CODE) { + // For tap, down, up, just stuff it into the array and send_string it + data[2] = eeprom_read_byte(p++); + if (data[2] != 0) + send_string(data); + } else if (data[1] == SS_DELAY_CODE) { + // For delay, decode the delay and wait_ms for that amount + uint8_t d0 = eeprom_read_byte(p++); + uint8_t d1 = eeprom_read_byte(p++); + if (d0 == 0 || d1 == 0) + break; + // we cannot use 0 for these, need to subtract 1 and use 255 instead of 256 for delay calculation + int ms = (d0 - 1) + (d1 - 1) * 255; + while (ms--) wait_ms(1); } + } else { + // If the char wasn't magic, just send it + send_string(data); } - send_string(data); } } diff --git a/quantum/vial.h b/quantum/vial.h index b75eb2415a..3015448ebf 100644 --- a/quantum/vial.h +++ b/quantum/vial.h @@ -19,7 +19,7 @@ #include #include -#define VIAL_PROTOCOL_VERSION ((uint32_t)0x00000001) +#define VIAL_PROTOCOL_VERSION ((uint32_t)0x00000002) void vial_handle_cmd(uint8_t *data, uint8_t length);