logo

qmk_firmware

custom branch of QMK firmware git clone https://anongit.hacktivis.me/git/qmk_firmware.git

leader.c (2695B)


  1. // Copyright 2023 QMK
  2. // SPDX-License-Identifier: GPL-2.0-or-later
  3. #include "leader.h"
  4. #include "timer.h"
  5. #include "util.h"
  6. #include <string.h>
  7. #ifndef LEADER_TIMEOUT
  8. # define LEADER_TIMEOUT 300
  9. #endif
  10. // Leader key stuff
  11. bool leading = false;
  12. uint16_t leader_time = 0;
  13. uint16_t leader_sequence[5] = {0, 0, 0, 0, 0};
  14. uint8_t leader_sequence_size = 0;
  15. __attribute__((weak)) void leader_start_user(void) {}
  16. __attribute__((weak)) void leader_end_user(void) {}
  17. __attribute__((weak)) bool leader_add_user(uint16_t keycode) {
  18. return false;
  19. }
  20. void leader_start(void) {
  21. if (leading) {
  22. return;
  23. }
  24. leader_start_user();
  25. leading = true;
  26. leader_time = timer_read();
  27. leader_sequence_size = 0;
  28. memset(leader_sequence, 0, sizeof(leader_sequence));
  29. }
  30. void leader_end(void) {
  31. leading = false;
  32. leader_end_user();
  33. }
  34. void leader_task(void) {
  35. if (leader_sequence_active() && leader_sequence_timed_out()) {
  36. leader_end();
  37. }
  38. }
  39. bool leader_sequence_active(void) {
  40. return leading;
  41. }
  42. bool leader_sequence_add(uint16_t keycode) {
  43. if (leader_sequence_size >= ARRAY_SIZE(leader_sequence)) {
  44. return false;
  45. }
  46. #if defined(LEADER_NO_TIMEOUT)
  47. if (leader_sequence_size == 0) {
  48. leader_reset_timer();
  49. }
  50. #endif
  51. leader_sequence[leader_sequence_size] = keycode;
  52. leader_sequence_size++;
  53. if (leader_add_user(keycode)) {
  54. leader_end();
  55. }
  56. return true;
  57. }
  58. bool leader_sequence_timed_out(void) {
  59. #if defined(LEADER_NO_TIMEOUT)
  60. return leader_sequence_size > 0 && timer_elapsed(leader_time) > LEADER_TIMEOUT;
  61. #else
  62. return timer_elapsed(leader_time) > LEADER_TIMEOUT;
  63. #endif
  64. }
  65. void leader_reset_timer(void) {
  66. leader_time = timer_read();
  67. }
  68. bool leader_sequence_is(uint16_t kc1, uint16_t kc2, uint16_t kc3, uint16_t kc4, uint16_t kc5) {
  69. return leader_sequence[0] == kc1 && leader_sequence[1] == kc2 && leader_sequence[2] == kc3 && leader_sequence[3] == kc4 && leader_sequence[4] == kc5;
  70. }
  71. bool leader_sequence_one_key(uint16_t kc) {
  72. return leader_sequence_is(kc, 0, 0, 0, 0);
  73. }
  74. bool leader_sequence_two_keys(uint16_t kc1, uint16_t kc2) {
  75. return leader_sequence_is(kc1, kc2, 0, 0, 0);
  76. }
  77. bool leader_sequence_three_keys(uint16_t kc1, uint16_t kc2, uint16_t kc3) {
  78. return leader_sequence_is(kc1, kc2, kc3, 0, 0);
  79. }
  80. bool leader_sequence_four_keys(uint16_t kc1, uint16_t kc2, uint16_t kc3, uint16_t kc4) {
  81. return leader_sequence_is(kc1, kc2, kc3, kc4, 0);
  82. }
  83. bool leader_sequence_five_keys(uint16_t kc1, uint16_t kc2, uint16_t kc3, uint16_t kc4, uint16_t kc5) {
  84. return leader_sequence_is(kc1, kc2, kc3, kc4, kc5);
  85. }