aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJulian Schuler2025-11-23 12:25:59 +0100
committerGitHub2025-11-23 12:25:59 +0100
commitb321789d7b3e0207f9f5e103a8481a0d90ba2814 (patch)
tree42ebfe5efd5625306bb0ccf485b8ca0d42d19bc0
parent4015c40ba4fd9a671c2e919582bbabab7320544b (diff)
Fix single key combos activating only once (#25198)
Co-authored-by: Julian Schuler <julianschuler@users.noreply.github.com>
-rw-r--r--quantum/process_keycode/process_combo.c4
-rw-r--r--tests/combo/test_combo.cpp15
-rw-r--r--tests/combo/test_combos.c6
3 files changed, 23 insertions, 2 deletions
diff --git a/quantum/process_keycode/process_combo.c b/quantum/process_keycode/process_combo.c
index c99a66a74b..b02b7f5433 100644
--- a/quantum/process_keycode/process_combo.c
+++ b/quantum/process_keycode/process_combo.c
@@ -347,6 +347,10 @@ void apply_combo(uint16_t combo_index, combo_t *combo) {
qrecord->combo_index = combo_index;
ACTIVATE_COMBO(combo);
+ if (key_count == 1) {
+ release_combo(combo_index, combo);
+ }
+
break;
} else {
// key was part of the combo but not the last one, "disable" it
diff --git a/tests/combo/test_combo.cpp b/tests/combo/test_combo.cpp
index d78ec55990..cc6425a94c 100644
--- a/tests/combo/test_combo.cpp
+++ b/tests/combo/test_combo.cpp
@@ -54,3 +54,18 @@ TEST_F(Combo, combo_osmshift_tapped) {
tap_key(key_i);
VERIFY_AND_CLEAR(driver);
}
+
+TEST_F(Combo, combo_single_key_twice) {
+ TestDriver driver;
+ KeymapKey key_a(0, 0, 1, KC_A);
+ set_keymap({key_a});
+
+ EXPECT_REPORT(driver, (KC_B));
+ tap_combo({key_a});
+ VERIFY_AND_CLEAR(driver);
+
+ EXPECT_REPORT(driver, (KC_B));
+ EXPECT_EMPTY_REPORT(driver);
+ tap_combo({key_a});
+ VERIFY_AND_CLEAR(driver);
+}
diff --git a/tests/combo/test_combos.c b/tests/combo/test_combos.c
index 8dcb364c6e..9a0465a9b4 100644
--- a/tests/combo/test_combos.c
+++ b/tests/combo/test_combos.c
@@ -4,14 +4,16 @@
// SPDX-License-Identifier: GPL-2.0-or-later
#include "quantum.h"
-enum combos { modtest, osmshift };
+enum combos { modtest, osmshift, single_key };
uint16_t const modtest_combo[] = {KC_Y, KC_U, COMBO_END};
uint16_t const osmshift_combo[] = {KC_Z, KC_X, COMBO_END};
+uint16_t const single_key_combo[] = {KC_A, COMBO_END};
// clang-format off
combo_t key_combos[] = {
[modtest] = COMBO(modtest_combo, RSFT_T(KC_SPACE)),
- [osmshift] = COMBO(osmshift_combo, OSM(MOD_LSFT))
+ [osmshift] = COMBO(osmshift_combo, OSM(MOD_LSFT)),
+ [single_key] = COMBO(single_key_combo, KC_B),
};
// clang-format on