Merge branch 'macro-delay' into vial
This commit is contained in:
commit
cc5961fe3f
@ -376,16 +376,30 @@ void dynamic_keymap_macro_send(uint8_t id) {
|
|||||||
if (data[0] == 0) {
|
if (data[0] == 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// If the char is magic (tap, down, up),
|
if (data[0] == SS_QMK_PREFIX) {
|
||||||
// add the next char (key to use) and send a 3 char string.
|
// If the char is magic, process it as indicated by the next character
|
||||||
if (data[0] == SS_TAP_CODE || data[0] == SS_DOWN_CODE || data[0] == SS_UP_CODE) {
|
// (tap, down, up, delay)
|
||||||
data[1] = data[0];
|
data[1] = eeprom_read_byte(p++);
|
||||||
data[0] = SS_QMK_PREFIX;
|
if (data[1] == 0)
|
||||||
data[2] = eeprom_read_byte(p++);
|
|
||||||
if (data[2] == 0) {
|
|
||||||
break;
|
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);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
|
||||||
#define VIAL_PROTOCOL_VERSION ((uint32_t)0x00000001)
|
#define VIAL_PROTOCOL_VERSION ((uint32_t)0x00000002)
|
||||||
|
|
||||||
void vial_handle_cmd(uint8_t *data, uint8_t length);
|
void vial_handle_cmd(uint8_t *data, uint8_t length);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user