|
|
@ -18,93 +18,89 @@
|
|
|
|
|
|
|
|
|
|
|
|
#include <Kaleidoscope-EEPROM-Keymap-Programmer.h>
|
|
|
|
#include <Kaleidoscope-EEPROM-Keymap-Programmer.h>
|
|
|
|
|
|
|
|
|
|
|
|
namespace KaleidoscopePlugins {
|
|
|
|
namespace kaleidoscope {
|
|
|
|
uint16_t EEPROMKeymapProgrammer::updatePosition;
|
|
|
|
uint16_t EEPROMKeymapProgrammer::update_position_;
|
|
|
|
EEPROMKeymapProgrammer::state_t EEPROMKeymapProgrammer::state;
|
|
|
|
EEPROMKeymapProgrammer::state_t EEPROMKeymapProgrammer::state_;
|
|
|
|
EEPROMKeymapProgrammer::mode_t EEPROMKeymapProgrammer::mode;
|
|
|
|
EEPROMKeymapProgrammer::mode_t EEPROMKeymapProgrammer::mode;
|
|
|
|
Key EEPROMKeymapProgrammer::newKey;
|
|
|
|
Key EEPROMKeymapProgrammer::new_key_;
|
|
|
|
|
|
|
|
|
|
|
|
EEPROMKeymapProgrammer::EEPROMKeymapProgrammer (void) {
|
|
|
|
EEPROMKeymapProgrammer::EEPROMKeymapProgrammer(void) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
void EEPROMKeymapProgrammer::begin(void) {
|
|
|
|
EEPROMKeymapProgrammer::begin (void) {
|
|
|
|
event_handler_hook_use(eventHandlerHook);
|
|
|
|
event_handler_hook_use (eventHandlerHook);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
void EEPROMKeymapProgrammer::nextState(void) {
|
|
|
|
EEPROMKeymapProgrammer::nextState (void) {
|
|
|
|
switch (state_) {
|
|
|
|
switch (state) {
|
|
|
|
|
|
|
|
case INACTIVE:
|
|
|
|
case INACTIVE:
|
|
|
|
state = WAIT_FOR_KEY;
|
|
|
|
state_ = WAIT_FOR_KEY;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case WAIT_FOR_KEY:
|
|
|
|
case WAIT_FOR_KEY:
|
|
|
|
if (mode == CODE)
|
|
|
|
if (mode == CODE)
|
|
|
|
state = WAIT_FOR_CODE;
|
|
|
|
state_ = WAIT_FOR_CODE;
|
|
|
|
else
|
|
|
|
else
|
|
|
|
state = WAIT_FOR_SOURCE_KEY;
|
|
|
|
state_ = WAIT_FOR_SOURCE_KEY;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case WAIT_FOR_CODE:
|
|
|
|
case WAIT_FOR_CODE:
|
|
|
|
case WAIT_FOR_SOURCE_KEY:
|
|
|
|
case WAIT_FOR_SOURCE_KEY:
|
|
|
|
::EEPROMKeymap.updateKey (updatePosition, newKey);
|
|
|
|
::EEPROMKeymap.updateKey(update_position_, new_key_);
|
|
|
|
cancel ();
|
|
|
|
cancel();
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
void EEPROMKeymapProgrammer::cancel(void) {
|
|
|
|
EEPROMKeymapProgrammer::cancel (void) {
|
|
|
|
update_position_ = 0;
|
|
|
|
updatePosition = 0;
|
|
|
|
new_key_ = Key_NoKey;
|
|
|
|
newKey = Key_NoKey;
|
|
|
|
state_ = INACTIVE;
|
|
|
|
state = INACTIVE;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Key
|
|
|
|
Key EEPROMKeymapProgrammer::eventHandlerHook(Key mapped_key, byte row, byte col, uint8_t key_state) {
|
|
|
|
EEPROMKeymapProgrammer::eventHandlerHook (Key mappedKey, byte row, byte col, uint8_t keyState) {
|
|
|
|
if (state_ == INACTIVE)
|
|
|
|
if (state == INACTIVE)
|
|
|
|
return mapped_key;
|
|
|
|
return mappedKey;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (state == WAIT_FOR_KEY) {
|
|
|
|
if (state_ == WAIT_FOR_KEY) {
|
|
|
|
if (key_toggled_on (keyState)) {
|
|
|
|
if (key_toggled_on(key_state)) {
|
|
|
|
updatePosition = Layer.top () * ROWS * COLS + row * COLS + col;
|
|
|
|
update_position_ = Layer.top() * ROWS * COLS + row * COLS + col;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (key_toggled_off (keyState)) {
|
|
|
|
if (key_toggled_off(key_state)) {
|
|
|
|
if ((uint16_t)(Layer.top () * ROWS * COLS + row * COLS + col) == updatePosition)
|
|
|
|
if ((uint16_t)(Layer.top() * ROWS * COLS + row * COLS + col) == update_position_)
|
|
|
|
nextState ();
|
|
|
|
nextState();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return Key_NoKey;
|
|
|
|
return Key_NoKey;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (state == WAIT_FOR_SOURCE_KEY) {
|
|
|
|
if (state_ == WAIT_FOR_SOURCE_KEY) {
|
|
|
|
if (key_toggled_on (keyState)) {
|
|
|
|
if (key_toggled_on(key_state)) {
|
|
|
|
newKey = Layer.getKeyFromPROGMEM (Layer.top (), row, col);
|
|
|
|
new_key_ = Layer.getKeyFromPROGMEM(Layer.top(), row, col);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (key_toggled_off (keyState)) {
|
|
|
|
if (key_toggled_off(key_state)) {
|
|
|
|
if (newKey == Layer.getKeyFromPROGMEM (Layer.top (), row, col))
|
|
|
|
if (new_key_ == Layer.getKeyFromPROGMEM(Layer.top(), row, col))
|
|
|
|
nextState ();
|
|
|
|
nextState();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return Key_NoKey;
|
|
|
|
return Key_NoKey;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// WAIT_FOR_CODE state
|
|
|
|
// WAIT_FOR_CODE state
|
|
|
|
|
|
|
|
|
|
|
|
if (mappedKey < Key_1 || mappedKey > Key_0)
|
|
|
|
if (mapped_key < Key_1 || mapped_key > Key_0)
|
|
|
|
return mappedKey;
|
|
|
|
return mapped_key;
|
|
|
|
|
|
|
|
|
|
|
|
if (!key_toggled_on (keyState))
|
|
|
|
if (!key_toggled_on(key_state))
|
|
|
|
return Key_NoKey;
|
|
|
|
return Key_NoKey;
|
|
|
|
|
|
|
|
|
|
|
|
uint8_t n;
|
|
|
|
uint8_t n;
|
|
|
|
if (mappedKey.keyCode == Key_0.keyCode)
|
|
|
|
if (mapped_key.keyCode == Key_0.keyCode)
|
|
|
|
n = 0;
|
|
|
|
n = 0;
|
|
|
|
else
|
|
|
|
else
|
|
|
|
n = mappedKey.keyCode - Key_1.keyCode + 1;
|
|
|
|
n = mapped_key.keyCode - Key_1.keyCode + 1;
|
|
|
|
|
|
|
|
|
|
|
|
newKey.raw = newKey.raw * 10 + n;
|
|
|
|
new_key_.raw = new_key_.raw * 10 + n;
|
|
|
|
|
|
|
|
|
|
|
|
return Key_NoKey;
|
|
|
|
return Key_NoKey;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
KaleidoscopePlugins::EEPROMKeymapProgrammer EEPROMKeymapProgrammer;
|
|
|
|
kaleidoscope::EEPROMKeymapProgrammer EEPROMKeymapProgrammer;
|
|
|
|