Adapt DynamicMacros plugin to KeyEvent handlers

Signed-off-by: Michael Richters <gedankenexperimenter@gmail.com>
pull/1024/head
Michael Richters 4 years ago
parent f619f1bc78
commit 5db82fd7c8
No known key found for this signature in database
GPG Key ID: 1288FD13E4EEF0C0

@ -25,34 +25,35 @@ namespace plugin {
uint16_t DynamicMacros::storage_base_; uint16_t DynamicMacros::storage_base_;
uint16_t DynamicMacros::storage_size_; uint16_t DynamicMacros::storage_size_;
uint16_t DynamicMacros::map_[]; uint16_t DynamicMacros::map_[];
Key DynamicMacros::active_macro_keys_[];
static void playMacroKeyswitchEvent(Key key, uint8_t keyswitch_state, bool explicit_report) {
handleKeyswitchEvent(key, UnknownKeyswitchLocation, keyswitch_state | INJECTED); // =============================================================================
// It might be possible to use Macros instead of reproducing it
if (explicit_report) void DynamicMacros::press(Key key) {
return; Runtime.handleKeyEvent(KeyEvent(KeyAddr::none(), IS_PRESSED | INJECTED, key));
for (Key &mkey : active_macro_keys_) {
kaleidoscope::Runtime.hid().keyboard().sendReport(); if (mkey == Key_NoKey) {
kaleidoscope::Runtime.hid().mouse().sendReport(); mkey = key;
break;
}
}
} }
static void playKeyCode(Key key, uint8_t keyStates, bool explicit_report) { void DynamicMacros::release(Key key) {
if (keyIsPressed(keyStates)) { for (Key &mkey : active_macro_keys_) {
playMacroKeyswitchEvent(key, IS_PRESSED, explicit_report); if (mkey == key) {
} mkey = Key_NoKey;
if (keyWasPressed(keyStates)) { }
playMacroKeyswitchEvent(key, WAS_PRESSED, explicit_report);
} }
Runtime.handleKeyEvent(KeyEvent(KeyAddr::none(), WAS_PRESSED | INJECTED, key));
} }
static void readKeyCodeAndPlay(uint16_t pos, uint8_t flags, uint8_t keyStates, bool explicit_report) { void DynamicMacros::tap(Key key) {
Key key(Runtime.storage().read(pos++), // key_code Runtime.handleKeyEvent(KeyEvent(KeyAddr::none(), IS_PRESSED | INJECTED, key));
flags); Runtime.handleKeyEvent(KeyEvent(KeyAddr::none(), WAS_PRESSED | INJECTED, key));
playKeyCode(key, keyStates, explicit_report);
} }
void DynamicMacros::updateDynamicMacroCache(void) { void DynamicMacros::updateDynamicMacroCache() {
uint16_t pos = storage_base_; uint16_t pos = storage_base_;
uint8_t current_id = 0; uint8_t current_id = 0;
macro_t macro = MACRO_ACTION_END; macro_t macro = MACRO_ACTION_END;
@ -116,27 +117,22 @@ void DynamicMacros::updateDynamicMacroCache(void) {
} }
} }
// public
void DynamicMacros::play(uint8_t macro_id) { void DynamicMacros::play(uint8_t macro_id) {
macro_t macro = MACRO_ACTION_END; macro_t macro = MACRO_ACTION_END;
uint8_t interval = 0; uint8_t interval = 0;
uint8_t flags;
bool explicit_report = false;
uint16_t pos; uint16_t pos;
Key key;
pos = storage_base_ + map_[macro_id]; pos = storage_base_ + map_[macro_id];
while (true) { while (true) {
switch (macro = Runtime.storage().read(pos++)) { switch (macro = Runtime.storage().read(pos++)) {
case MACRO_ACTION_STEP_EXPLICIT_REPORT: case MACRO_ACTION_STEP_EXPLICIT_REPORT:
explicit_report = true;
break;
case MACRO_ACTION_STEP_IMPLICIT_REPORT: case MACRO_ACTION_STEP_IMPLICIT_REPORT:
explicit_report = false;
break;
case MACRO_ACTION_STEP_SEND_REPORT: case MACRO_ACTION_STEP_SEND_REPORT:
kaleidoscope::Runtime.hid().keyboard().sendReport();
kaleidoscope::Runtime.hid().mouse().sendReport();
break; break;
case MACRO_ACTION_STEP_INTERVAL: case MACRO_ACTION_STEP_INTERVAL:
interval = Runtime.storage().read(pos++); interval = Runtime.storage().read(pos++);
break; break;
@ -145,46 +141,59 @@ void DynamicMacros::play(uint8_t macro_id) {
delay(wait); delay(wait);
break; break;
} }
case MACRO_ACTION_STEP_KEYDOWN: case MACRO_ACTION_STEP_KEYDOWN:
flags = Runtime.storage().read(pos++); key.setFlags(Runtime.storage().read(pos++));
readKeyCodeAndPlay(pos++, flags, IS_PRESSED, explicit_report); key.setKeyCode(Runtime.storage().read(pos++));
press(key);
break; break;
case MACRO_ACTION_STEP_KEYUP: case MACRO_ACTION_STEP_KEYUP:
flags = Runtime.storage().read(pos++); key.setFlags(Runtime.storage().read(pos++));
readKeyCodeAndPlay(pos++, flags, WAS_PRESSED, explicit_report); key.setKeyCode(Runtime.storage().read(pos++));
release(key);
break; break;
case MACRO_ACTION_STEP_TAP: case MACRO_ACTION_STEP_TAP:
flags = Runtime.storage().read(pos++); key.setFlags(Runtime.storage().read(pos++));
readKeyCodeAndPlay(pos++, flags, IS_PRESSED | WAS_PRESSED, false); key.setKeyCode(Runtime.storage().read(pos++));
tap(key);
break; break;
case MACRO_ACTION_STEP_KEYCODEDOWN: case MACRO_ACTION_STEP_KEYCODEDOWN:
readKeyCodeAndPlay(pos++, 0, IS_PRESSED, explicit_report); key.setFlags(0);
key.setKeyCode(Runtime.storage().read(pos++));
press(key);
break; break;
case MACRO_ACTION_STEP_KEYCODEUP: case MACRO_ACTION_STEP_KEYCODEUP:
readKeyCodeAndPlay(pos++, 0, WAS_PRESSED, explicit_report); key.setFlags(0);
key.setKeyCode(Runtime.storage().read(pos++));
release(key);
break; break;
case MACRO_ACTION_STEP_TAPCODE: case MACRO_ACTION_STEP_TAPCODE:
readKeyCodeAndPlay(pos++, 0, IS_PRESSED | WAS_PRESSED, false); key.setFlags(0);
key.setKeyCode(Runtime.storage().read(pos++));
tap(key);
break; break;
case MACRO_ACTION_STEP_TAP_SEQUENCE: { case MACRO_ACTION_STEP_TAP_SEQUENCE: {
uint8_t keyCode; while (true) {
do { key.setFlags(0);
flags = Runtime.storage().read(pos++); key.setKeyCode(pgm_read_byte(pos++));
keyCode = Runtime.storage().read(pos++); if (key == Key_NoKey)
playKeyCode(Key(keyCode, flags), IS_PRESSED | WAS_PRESSED, false); break;
tap(key);
delay(interval); delay(interval);
} while (!(flags == 0 && keyCode == 0)); }
break; break;
} }
case MACRO_ACTION_STEP_TAP_CODE_SEQUENCE: { case MACRO_ACTION_STEP_TAP_CODE_SEQUENCE: {
uint8_t keyCode; while (true) {
do { key.setFlags(0);
keyCode = Runtime.storage().read(pos++); key.setKeyCode(pgm_read_byte(pos++));
playKeyCode(Key(keyCode, 0), IS_PRESSED | WAS_PRESSED, false); if (key.getKeyCode() == 0)
break;
tap(key);
delay(interval); delay(interval);
} while (keyCode != 0); }
break; break;
} }
@ -197,12 +206,23 @@ void DynamicMacros::play(uint8_t macro_id) {
} }
} }
EventHandlerResult DynamicMacros::onKeyswitchEvent(Key &mappedKey, KeyAddr key_addr, uint8_t keyState) { bool isDynamicMacrosKey(Key key) {
if (mappedKey.getRaw() < ranges::DYNAMIC_MACRO_FIRST || mappedKey.getRaw() > ranges::DYNAMIC_MACRO_LAST) return (key.getRaw() >= ranges::DYNAMIC_MACRO_FIRST &&
key.getRaw() <= ranges::DYNAMIC_MACRO_LAST);
}
// -----------------------------------------------------------------------------
EventHandlerResult DynamicMacros::onKeyEvent(KeyEvent &event) {
if (!isDynamicMacrosKey(event.key))
return EventHandlerResult::OK; return EventHandlerResult::OK;
if (keyToggledOn(keyState)) { if (keyToggledOn(event.state)) {
play(mappedKey.getRaw() - ranges::DYNAMIC_MACRO_FIRST); uint8_t macro_id = event.key.getRaw() - ranges::DYNAMIC_MACRO_FIRST;
play(macro_id);
} else {
for (Key key : active_macro_keys_) {
release(key);
}
} }
return EventHandlerResult::EVENT_CONSUMED; return EventHandlerResult::EVENT_CONSUMED;
@ -249,14 +269,14 @@ EventHandlerResult DynamicMacros::onFocusEvent(const char *command) {
return EventHandlerResult::EVENT_CONSUMED; return EventHandlerResult::EVENT_CONSUMED;
} }
// public
void DynamicMacros::reserve_storage(uint16_t size) { void DynamicMacros::reserve_storage(uint16_t size) {
storage_base_ = ::EEPROMSettings.requestSlice(size); storage_base_ = ::EEPROMSettings.requestSlice(size);
storage_size_ = size; storage_size_ = size;
updateDynamicMacroCache(); updateDynamicMacroCache();
} }
} // namespace plugin
} } // namespace kaleidoscope
}
kaleidoscope::plugin::DynamicMacros DynamicMacros; kaleidoscope::plugin::DynamicMacros DynamicMacros;

@ -24,15 +24,15 @@
#define DM(n) Key(kaleidoscope::ranges::DYNAMIC_MACRO_FIRST + n) #define DM(n) Key(kaleidoscope::ranges::DYNAMIC_MACRO_FIRST + n)
#define MAX_CONCURRENT_DYNAMIC_MACRO_KEYS 8
namespace kaleidoscope { namespace kaleidoscope {
namespace plugin { namespace plugin {
class DynamicMacros : public kaleidoscope::Plugin { class DynamicMacros : public kaleidoscope::Plugin {
public: public:
DynamicMacros(void) {}
EventHandlerResult onKeyswitchEvent(Key &mappedKey, KeyAddr key_addr, uint8_t keyState);
EventHandlerResult onNameQuery(); EventHandlerResult onNameQuery();
EventHandlerResult onKeyEvent(KeyEvent &event);
EventHandlerResult onFocusEvent(const char *command); EventHandlerResult onFocusEvent(const char *command);
static void reserve_storage(uint16_t size); static void reserve_storage(uint16_t size);
@ -43,10 +43,14 @@ class DynamicMacros : public kaleidoscope::Plugin {
static uint16_t storage_base_; static uint16_t storage_base_;
static uint16_t storage_size_; static uint16_t storage_size_;
static uint16_t map_[31]; static uint16_t map_[31];
static void updateDynamicMacroCache(void); static void updateDynamicMacroCache();
static Key active_macro_keys_[MAX_CONCURRENT_DYNAMIC_MACRO_KEYS];
static void press(Key key);
static void release(Key key);
static void tap(Key key);
}; };
} } // namespace plugin
} } // namespace kaleidoscope
extern kaleidoscope::plugin::DynamicMacros DynamicMacros; extern kaleidoscope::plugin::DynamicMacros DynamicMacros;

Loading…
Cancel
Save