Fix issues with Oneshot disabling (#14934)
This commit is contained in:
		| @@ -27,6 +27,7 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>. | |||||||
| #include "action_util.h" | #include "action_util.h" | ||||||
| #include "action.h" | #include "action.h" | ||||||
| #include "wait.h" | #include "wait.h" | ||||||
|  | #include "keycode_config.h" | ||||||
|  |  | ||||||
| #ifdef BACKLIGHT_ENABLE | #ifdef BACKLIGHT_ENABLE | ||||||
| #    include "backlight.h" | #    include "backlight.h" | ||||||
| @@ -87,6 +88,7 @@ void action_exec(keyevent_t event) { | |||||||
|     keyrecord_t record = {.event = event}; |     keyrecord_t record = {.event = event}; | ||||||
|  |  | ||||||
| #ifndef NO_ACTION_ONESHOT | #ifndef NO_ACTION_ONESHOT | ||||||
|  |     if (!keymap_config.oneshot_disable) { | ||||||
| #    if (defined(ONESHOT_TIMEOUT) && (ONESHOT_TIMEOUT > 0)) | #    if (defined(ONESHOT_TIMEOUT) && (ONESHOT_TIMEOUT > 0)) | ||||||
|         if (has_oneshot_layer_timed_out()) { |         if (has_oneshot_layer_timed_out()) { | ||||||
|             clear_oneshot_layer_state(ONESHOT_OTHER_KEY_PRESSED); |             clear_oneshot_layer_state(ONESHOT_OTHER_KEY_PRESSED); | ||||||
| @@ -100,6 +102,7 @@ void action_exec(keyevent_t event) { | |||||||
|         } |         } | ||||||
| #        endif | #        endif | ||||||
| #    endif | #    endif | ||||||
|  |     } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifndef NO_ACTION_TAPPING | #ifndef NO_ACTION_TAPPING | ||||||
| @@ -195,7 +198,7 @@ void process_record(keyrecord_t *record) { | |||||||
|  |  | ||||||
|     if (!process_record_quantum(record)) { |     if (!process_record_quantum(record)) { | ||||||
| #ifndef NO_ACTION_ONESHOT | #ifndef NO_ACTION_ONESHOT | ||||||
|         if (is_oneshot_layer_active() && record->event.pressed) { |         if (is_oneshot_layer_active() && record->event.pressed && !keymap_config.oneshot_disable) { | ||||||
|             clear_oneshot_layer_state(ONESHOT_OTHER_KEY_PRESSED); |             clear_oneshot_layer_state(ONESHOT_OTHER_KEY_PRESSED); | ||||||
|         } |         } | ||||||
| #endif | #endif | ||||||
| @@ -260,7 +263,7 @@ void process_action(keyrecord_t *record, action_t action) { | |||||||
| #    ifdef SWAP_HANDS_ENABLE | #    ifdef SWAP_HANDS_ENABLE | ||||||
|         && !(action.kind.id == ACT_SWAP_HANDS && action.swap.code == OP_SH_ONESHOT) |         && !(action.kind.id == ACT_SWAP_HANDS && action.swap.code == OP_SH_ONESHOT) | ||||||
| #    endif | #    endif | ||||||
|     ) { |         && !keymap_config.oneshot_disable) { | ||||||
|         clear_oneshot_layer_state(ONESHOT_OTHER_KEY_PRESSED); |         clear_oneshot_layer_state(ONESHOT_OTHER_KEY_PRESSED); | ||||||
|         do_release_oneshot = !is_oneshot_layer_active(); |         do_release_oneshot = !is_oneshot_layer_active(); | ||||||
|     } |     } | ||||||
| @@ -304,6 +307,32 @@ void process_action(keyrecord_t *record, action_t action) { | |||||||
| #    ifndef NO_ACTION_ONESHOT | #    ifndef NO_ACTION_ONESHOT | ||||||
|                 case MODS_ONESHOT: |                 case MODS_ONESHOT: | ||||||
|                     // Oneshot modifier |                     // Oneshot modifier | ||||||
|  |                     if (keymap_config.oneshot_disable) { | ||||||
|  |                         if (event.pressed) { | ||||||
|  |                             if (mods) { | ||||||
|  |                                 if (IS_MOD(action.key.code) || action.key.code == KC_NO) { | ||||||
|  |                                     // e.g. LSFT(KC_LGUI): we don't want the LSFT to be weak as it would make it useless. | ||||||
|  |                                     // This also makes LSFT(KC_LGUI) behave exactly the same as LGUI(KC_LSFT). | ||||||
|  |                                     // Same applies for some keys like KC_MEH which are declared as MEH(KC_NO). | ||||||
|  |                                     add_mods(mods); | ||||||
|  |                                 } else { | ||||||
|  |                                     add_weak_mods(mods); | ||||||
|  |                                 } | ||||||
|  |                                 send_keyboard_report(); | ||||||
|  |                             } | ||||||
|  |                             register_code(action.key.code); | ||||||
|  |                         } else { | ||||||
|  |                             unregister_code(action.key.code); | ||||||
|  |                             if (mods) { | ||||||
|  |                                 if (IS_MOD(action.key.code) || action.key.code == KC_NO) { | ||||||
|  |                                     del_mods(mods); | ||||||
|  |                                 } else { | ||||||
|  |                                     del_weak_mods(mods); | ||||||
|  |                                 } | ||||||
|  |                                 send_keyboard_report(); | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|  |                     } else { | ||||||
|                         if (event.pressed) { |                         if (event.pressed) { | ||||||
|                             if (tap_count == 0) { |                             if (tap_count == 0) { | ||||||
|                                 dprint("MODS_TAP: Oneshot: 0\n"); |                                 dprint("MODS_TAP: Oneshot: 0\n"); | ||||||
| @@ -341,6 +370,7 @@ void process_action(keyrecord_t *record, action_t action) { | |||||||
|                                 unregister_mods(mods); |                                 unregister_mods(mods); | ||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|  |                     } | ||||||
|                     break; |                     break; | ||||||
| #    endif | #    endif | ||||||
|                 case MODS_TAP_TOGGLE: |                 case MODS_TAP_TOGGLE: | ||||||
| @@ -523,6 +553,13 @@ void process_action(keyrecord_t *record, action_t action) { | |||||||
| #        ifndef NO_ACTION_ONESHOT | #        ifndef NO_ACTION_ONESHOT | ||||||
|                 case OP_ONESHOT: |                 case OP_ONESHOT: | ||||||
|                     // Oneshot modifier |                     // Oneshot modifier | ||||||
|  |                     if (keymap_config.oneshot_disable) { | ||||||
|  |                         if (event.pressed) { | ||||||
|  |                             layer_on(action.layer_tap.val); | ||||||
|  |                         } else { | ||||||
|  |                             layer_off(action.layer_tap.val); | ||||||
|  |                         } | ||||||
|  |                     } else { | ||||||
| #            if defined(ONESHOT_TAP_TOGGLE) && ONESHOT_TAP_TOGGLE > 1 | #            if defined(ONESHOT_TAP_TOGGLE) && ONESHOT_TAP_TOGGLE > 1 | ||||||
|                         do_release_oneshot = false; |                         do_release_oneshot = false; | ||||||
|                         if (event.pressed) { |                         if (event.pressed) { | ||||||
| @@ -556,6 +593,7 @@ void process_action(keyrecord_t *record, action_t action) { | |||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
| #            endif | #            endif | ||||||
|  |                     } | ||||||
|                     break; |                     break; | ||||||
| #        endif | #        endif | ||||||
|                 default: |                 default: | ||||||
|   | |||||||
| @@ -170,7 +170,7 @@ void reset_oneshot_layer(void) { | |||||||
| void clear_oneshot_layer_state(oneshot_fullfillment_t state) { | void clear_oneshot_layer_state(oneshot_fullfillment_t state) { | ||||||
|     uint8_t start_state = oneshot_layer_data; |     uint8_t start_state = oneshot_layer_data; | ||||||
|     oneshot_layer_data &= ~state; |     oneshot_layer_data &= ~state; | ||||||
|     if ((!get_oneshot_layer_state() && start_state != oneshot_layer_data) || keymap_config.oneshot_disable) { |     if ((!get_oneshot_layer_state() && start_state != oneshot_layer_data) && !keymap_config.oneshot_disable) { | ||||||
|         layer_off(get_oneshot_layer()); |         layer_off(get_oneshot_layer()); | ||||||
|         reset_oneshot_layer(); |         reset_oneshot_layer(); | ||||||
|     } |     } | ||||||
| @@ -189,6 +189,7 @@ void oneshot_set(bool active) { | |||||||
|     if (keymap_config.oneshot_disable != active) { |     if (keymap_config.oneshot_disable != active) { | ||||||
|         keymap_config.oneshot_disable = active; |         keymap_config.oneshot_disable = active; | ||||||
|         eeconfig_update_keymap(keymap_config.raw); |         eeconfig_update_keymap(keymap_config.raw); | ||||||
|  |         clear_oneshot_layer_state(ONESHOT_OTHER_KEY_PRESSED); | ||||||
|         dprintf("Oneshot: active: %d\n", active); |         dprintf("Oneshot: active: %d\n", active); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user