summaryrefslogtreecommitdiff
path: root/tmk_core/common/action.c
diff options
context:
space:
mode:
authorErez Zukerman <bulk@ezuk.org>2016-03-27 21:09:15 +0300
committerErez Zukerman <bulk@ezuk.org>2016-03-27 21:09:15 +0300
commit80eefb09ac5de95a6977702b4014d4b4d79a5d7d (patch)
tree3c5176ee8dfdadd4429b709e8c2cabcaff84f063 /tmk_core/common/action.c
parent16da54cfa037aad7575bae2fd12527ae7a0149b1 (diff)
parentb7a81f041906c3c978a314987e486536be0a58cd (diff)
Merge pull request #188 from DidierLoiseau/issue-156
Fix #156: clear weak mods on every key press
Diffstat (limited to 'tmk_core/common/action.c')
-rw-r--r--tmk_core/common/action.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/tmk_core/common/action.c b/tmk_core/common/action.c
index 77ea39e942..4197c53ed2 100644
--- a/tmk_core/common/action.c
+++ b/tmk_core/common/action.c
@@ -70,6 +70,10 @@ void process_action(keyrecord_t *record)
#endif
dprintln();
+ if (event.pressed) {
+ // clear the potential weak mods left by previously pressed keys
+ clear_weak_mods();
+ }
switch (action.kind.id) {
/* Key and Mods */
case ACT_LMODS:
@@ -500,6 +504,7 @@ void clear_keyboard(void)
void clear_keyboard_but_mods(void)
{
clear_weak_mods();
+ clear_macro_mods();
clear_keys();
send_keyboard_report();
#ifdef MOUSEKEY_ENABLE