Various fixes for keyboards not implementing callbacks correctly (#24116)

This commit is contained in:
Joel Challis
2024-07-14 06:38:04 +01:00
committed by GitHub
parent e76069ea4e
commit c0aca9f45c
8 changed files with 30 additions and 33 deletions

View File

@ -86,6 +86,10 @@ void keyboard_post_init_kb(void) {
* Num | Caps | Scroll | * Num | Caps | Scroll |
*/ */
bool rgb_matrix_indicators_kb(void) { bool rgb_matrix_indicators_kb(void) {
if (!rgb_matrix_indicators_user()) {
return false;
}
if (eeprom_ec_config.num.enabled) { if (eeprom_ec_config.num.enabled) {
// The rgb_matrix_set_color function needs an RGB code to work, so first the indicator color is cast to an HSV value and then translated to RGB // The rgb_matrix_set_color function needs an RGB code to work, so first the indicator color is cast to an HSV value and then translated to RGB
HSV hsv_num_indicator_color = {eeprom_ec_config.num.h, eeprom_ec_config.num.s, eeprom_ec_config.num.v}; HSV hsv_num_indicator_color = {eeprom_ec_config.num.h, eeprom_ec_config.num.s, eeprom_ec_config.num.v};

View File

@ -82,12 +82,14 @@ void keyboard_post_init_kb(void) {
// This function gets called when caps, num, scroll change // This function gets called when caps, num, scroll change
bool led_update_kb(led_t led_state) { bool led_update_kb(led_t led_state) {
indicators_callback(); if(led_update_user(led_state)) {
indicators_callback();
}
return true; return true;
} }
// This function is called when layers change // This function is called when layers change
layer_state_t layer_state_set_user(layer_state_t state) { __attribute__((weak)) layer_state_t layer_state_set_user(layer_state_t state) {
indicators_callback(); indicators_callback();
return state; return state;
} }

View File

@ -130,11 +130,8 @@ bool process_record_kb(uint16_t keycode, keyrecord_t *record) {
return process_record_user(keycode, record); return process_record_user(keycode, record);
} }
__attribute__((weak)) bool encoder_update_keymap(uint8_t index, bool clockwise) { return true; }
__attribute__((weak)) bool encoder_update_user(uint8_t index, bool clockwise) { return encoder_update_keymap(index, clockwise); }
bool encoder_update_kb(uint8_t index, bool clockwise) { bool encoder_update_kb(uint8_t index, bool clockwise) {
if (!encoder_update_user(index, clockwise)) { if (encoder_update_user(index, clockwise)) {
// Encoder 1, outside left // Encoder 1, outside left
if (index == 0 && clockwise) { if (index == 0 && clockwise) {
tap_code(KC_MS_U); // turned right tap_code(KC_MS_U); // turned right

View File

@ -24,8 +24,5 @@ enum TWOx1800_keycodes {
ENC_BTN4, ENC_BTN4,
}; };
// Encoder update function that returns true/false
bool encoder_update_keymap(uint8_t index, bool clockwise);
// Encoder button combo check // Encoder button combo check
void check_encoder_buttons(void); void check_encoder_buttons(void);

View File

@ -96,16 +96,11 @@ void matrix_init_kb(void) {
matrix_init_user(); matrix_init_user();
} }
__attribute__ ((weak))
bool encoder_update_keymap(int8_t index, bool clockwise) {
return false;
}
#define NUM_COLUMNS 8*MAX7219_CONTROLLERS #define NUM_COLUMNS 8*MAX7219_CONTROLLERS
uint8_t led_position[2] = {0,0}; // The location of the cursor in the matrix uint8_t led_position[2] = {0,0}; // The location of the cursor in the matrix
bool encoder_update_kb(uint8_t index, bool clockwise) { bool encoder_update_kb(uint8_t index, bool clockwise) {
if (!encoder_update_keymap(index, clockwise)) { if (encoder_update_user(index, clockwise)) {
#if defined(DRAWING_TOY_MODE) #if defined(DRAWING_TOY_MODE)
// Encoder 1, left // Encoder 1, left
if (index == 0 && clockwise) { if (index == 0 && clockwise) {

View File

@ -19,16 +19,16 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
#include "ps2.h" #include "ps2.h"
#include "led.h" #include "led.h"
bool led_update_kb(led_t led_state) {
bool led_update_kb(led_t led_state) if(led_update_user(led_state)) {
{ uint8_t ps2_led = 0;
uint8_t ps2_led = 0; if (led_state.scroll_lock)
if (led_state.scroll_lock) ps2_led |= (1<<PS2_LED_SCROLL_LOCK);
ps2_led |= (1<<PS2_LED_SCROLL_LOCK); if (led_state.num_lock)
if (led_state.num_lock) ps2_led |= (1<<PS2_LED_NUM_LOCK);
ps2_led |= (1<<PS2_LED_NUM_LOCK); if (led_state.caps_lock)
if (led_state.caps_lock) ps2_led |= (1<<PS2_LED_CAPS_LOCK);
ps2_led |= (1<<PS2_LED_CAPS_LOCK); ps2_host_set_led(ps2_led);
ps2_host_set_led(ps2_led); }
return false; return false;
} }

View File

@ -155,7 +155,8 @@ void housekeeping_task_kb(void) {
gpio_write_pin(C15, keymap_config.no_gui); gpio_write_pin(C15, keymap_config.no_gui);
}; };
bool process_record_user(uint16_t keycode, keyrecord_t *record) { bool process_record_kb(uint16_t keycode, keyrecord_t *record) {
if (!process_record_user(keycode, record)) { return false; }
switch (keycode) { switch (keycode) {
@ -166,8 +167,7 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
host_consumer_send(0); host_consumer_send(0);
} }
return false; /* Skip all further processing of this key */ return false; /* Skip all further processing of this key */
default:
return true; /* Process all other keycodes normally */
} }
return true; /* Process all other keycodes normally */
}; };

View File

@ -36,8 +36,10 @@ void keyboard_post_init_kb(void) {
// Activate rgb layer for caps when capslock is enabled // Activate rgb layer for caps when capslock is enabled
bool led_update_kb(led_t led_state) { bool led_update_kb(led_t led_state) {
rgblight_set_layer_state(0, led_state.caps_lock); if(led_update_user(led_state)) {
rgblight_set_layer_state(1, led_state.num_lock); rgblight_set_layer_state(0, led_state.caps_lock);
rgblight_set_layer_state(2, led_state.scroll_lock); rgblight_set_layer_state(1, led_state.num_lock);
rgblight_set_layer_state(2, led_state.scroll_lock);
}
return true; return true;
} }