mirror of
https://github.com/openstenoproject/qmk
synced 2024-11-11 11:09:10 +00:00
Add out of bound check for Leader Key sequence array (#5840)
* Add out of bound check for Leader Key sequence array * A shot at advanced C stuff for Leader Key optimization * Revert most changes * Change default back * Include string.h if compiling for ARM * Use sizeof instead of a number
This commit is contained in:
parent
ed6a872911
commit
09f5767072
1 changed files with 11 additions and 7 deletions
|
@ -17,6 +17,9 @@
|
||||||
#ifdef LEADER_ENABLE
|
#ifdef LEADER_ENABLE
|
||||||
|
|
||||||
#include "process_leader.h"
|
#include "process_leader.h"
|
||||||
|
#ifdef __arm__
|
||||||
|
# include <string.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef LEADER_TIMEOUT
|
#ifndef LEADER_TIMEOUT
|
||||||
#define LEADER_TIMEOUT 300
|
#define LEADER_TIMEOUT 300
|
||||||
|
@ -41,11 +44,7 @@ void qk_leader_start(void) {
|
||||||
leading = true;
|
leading = true;
|
||||||
leader_time = timer_read();
|
leader_time = timer_read();
|
||||||
leader_sequence_size = 0;
|
leader_sequence_size = 0;
|
||||||
leader_sequence[0] = 0;
|
memset(leader_sequence, 0, sizeof(leader_sequence));
|
||||||
leader_sequence[1] = 0;
|
|
||||||
leader_sequence[2] = 0;
|
|
||||||
leader_sequence[3] = 0;
|
|
||||||
leader_sequence[4] = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool process_leader(uint16_t keycode, keyrecord_t *record) {
|
bool process_leader(uint16_t keycode, keyrecord_t *record) {
|
||||||
|
@ -58,8 +57,13 @@ bool process_leader(uint16_t keycode, keyrecord_t *record) {
|
||||||
keycode = keycode & 0xFF;
|
keycode = keycode & 0xFF;
|
||||||
}
|
}
|
||||||
#endif // LEADER_KEY_STRICT_KEY_PROCESSING
|
#endif // LEADER_KEY_STRICT_KEY_PROCESSING
|
||||||
|
if ( leader_sequence_size < ( sizeof(leader_sequence) / sizeof(leader_sequence[0]) ) ) {
|
||||||
leader_sequence[leader_sequence_size] = keycode;
|
leader_sequence[leader_sequence_size] = keycode;
|
||||||
leader_sequence_size++;
|
leader_sequence_size++;
|
||||||
|
} else {
|
||||||
|
leading = false;
|
||||||
|
leader_end();
|
||||||
|
}
|
||||||
#ifdef LEADER_PER_KEY_TIMING
|
#ifdef LEADER_PER_KEY_TIMING
|
||||||
leader_time = timer_read();
|
leader_time = timer_read();
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue