mirror of
https://github.com/qmk/qmk_firmware.git
synced 2024-11-21 19:09:25 +00:00
Merge 04914fec8b
into 36b5559b99
This commit is contained in:
commit
42e71f565f
@ -664,6 +664,8 @@ void process_action(keyrecord_t *record, action_t action) {
|
||||
if (tap_count >= ONESHOT_TAP_TOGGLE) {
|
||||
reset_oneshot_layer();
|
||||
set_oneshot_layer(action.layer_tap.val, ONESHOT_TOGGLED);
|
||||
} else if (get_oneshot_layer() != action.layer_tap.val) {
|
||||
layer_off(action.layer_tap.val);
|
||||
} else {
|
||||
clear_oneshot_layer_state(ONESHOT_PRESSED);
|
||||
}
|
||||
@ -671,6 +673,8 @@ void process_action(keyrecord_t *record, action_t action) {
|
||||
# else
|
||||
if (event.pressed) {
|
||||
set_oneshot_layer(action.layer_tap.val, ONESHOT_START);
|
||||
} else if (get_oneshot_layer() != action.layer_tap.val) {
|
||||
layer_off(action.layer_tap.val);
|
||||
} else {
|
||||
clear_oneshot_layer_state(ONESHOT_PRESSED);
|
||||
if (tap_count > 1) {
|
||||
|
@ -353,3 +353,77 @@ TEST_F(OneShot, OSLWithOsmAndAdditionalKeypress) {
|
||||
run_one_scan_loop();
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
}
|
||||
|
||||
TEST_F(OneShot, OSLWithNestedOSL) {
|
||||
TestDriver driver;
|
||||
KeymapKey layer0_osl_key = KeymapKey{0, 0, 0, OSL(1)};
|
||||
KeymapKey layer1_osl_key = KeymapKey{1, 1, 0, OSL(2)};
|
||||
KeymapKey layer2_regular_key = KeymapKey{2, 1, 1, KC_A};
|
||||
|
||||
set_keymap({layer0_osl_key, layer1_osl_key, layer2_regular_key});
|
||||
|
||||
EXPECT_NO_REPORT(driver);
|
||||
|
||||
/* Activate OSL for layer 1 */
|
||||
tap_key(layer0_osl_key);
|
||||
EXPECT_TRUE(layer_state_is(1));
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
|
||||
/* Activate OSL for layer 2 from layer 1 */
|
||||
EXPECT_NO_REPORT(driver);
|
||||
tap_key(layer1_osl_key);
|
||||
EXPECT_TRUE(layer_state_is(2));
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
|
||||
/* Tap key on layer 2 */
|
||||
EXPECT_REPORT(driver, (layer2_regular_key.report_code)).Times(1);
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(layer2_regular_key);
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
|
||||
/* Ensure both layers are deactivated. */
|
||||
EXPECT_FALSE(layer_state_is(1));
|
||||
EXPECT_FALSE(layer_state_is(2));
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
}
|
||||
|
||||
TEST_F(OneShot, HeldOSLWithNestedOSL) {
|
||||
TestDriver driver;
|
||||
KeymapKey layer0_osl_key = KeymapKey{0, 0, 0, OSL(1)};
|
||||
KeymapKey layer1_osl_key = KeymapKey{1, 1, 0, OSL(2)};
|
||||
KeymapKey layer2_regular_key = KeymapKey{2, 1, 1, KC_A};
|
||||
|
||||
set_keymap({layer0_osl_key, layer1_osl_key, layer2_regular_key});
|
||||
|
||||
/* Hold OSL for layer 1 key */
|
||||
EXPECT_NO_REPORT(driver);
|
||||
layer0_osl_key.press();
|
||||
idle_for(TAPPING_TERM);
|
||||
run_one_scan_loop(); // The layer isn't activated until one loop more than
|
||||
expect_layer_state(1);
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
|
||||
/* Tap OSL for layer 2 */
|
||||
EXPECT_NO_REPORT(driver);
|
||||
tap_key(layer1_osl_key);
|
||||
expect_layer_state(2);
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
|
||||
/* Ensure layer 2 key can be pressed */
|
||||
EXPECT_REPORT(driver, (layer2_regular_key.report_code)).Times(1);
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(layer2_regular_key);
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
|
||||
EXPECT_FALSE(layer_state_is(2));
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
|
||||
/* Release OSL key for layer 1 */
|
||||
EXPECT_NO_REPORT(driver);
|
||||
layer0_osl_key.release();
|
||||
run_one_scan_loop();
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
|
||||
EXPECT_FALSE(layer_state_is(1));
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user