mirror of
https://github.com/zsa/qmk_firmware.git
synced 2026-01-10 23:53:25 +00:00
Add more hooks to Community Modules
This commit is contained in:
@@ -27,11 +27,20 @@ __attribute__((weak)) layer_state_t default_layer_state_set_kb(layer_state_t sta
|
||||
return default_layer_state_set_user(state);
|
||||
}
|
||||
|
||||
/** \brief Default Layer State Set At Module Level
|
||||
*
|
||||
* Run module code on default layer state change
|
||||
*/
|
||||
__attribute__((weak)) layer_state_t default_layer_state_set_modules(layer_state_t state) {
|
||||
return state;
|
||||
}
|
||||
|
||||
/** \brief Default Layer State Set
|
||||
*
|
||||
* Static function to set the default layer state, prints debug info and clears keys
|
||||
*/
|
||||
static void default_layer_state_set(layer_state_t state) {
|
||||
state = default_layer_state_set_modules(state);
|
||||
state = default_layer_state_set_kb(state);
|
||||
ac_dprintf("default_layer_state: ");
|
||||
default_layer_debug();
|
||||
@@ -107,11 +116,21 @@ __attribute__((weak)) layer_state_t layer_state_set_kb(layer_state_t state) {
|
||||
return layer_state_set_user(state);
|
||||
}
|
||||
|
||||
/** \brief Layer state set modules
|
||||
*
|
||||
* Runs module code on layer state change
|
||||
*/
|
||||
|
||||
__attribute__((weak)) layer_state_t layer_state_set_modules(layer_state_t state) {
|
||||
return state;
|
||||
}
|
||||
|
||||
/** \brief Layer state set
|
||||
*
|
||||
* Sets the layer to match the specified state (a bitmask)
|
||||
*/
|
||||
void layer_state_set(layer_state_t state) {
|
||||
state = layer_state_set_modules(state);
|
||||
state = layer_state_set_kb(state);
|
||||
ac_dprintf("layer_state: ");
|
||||
layer_debug();
|
||||
|
||||
@@ -78,6 +78,7 @@ extern layer_state_t default_layer_state;
|
||||
void default_layer_debug(void);
|
||||
void default_layer_set(layer_state_t state);
|
||||
|
||||
__attribute__((weak)) layer_state_t default_layer_state_set_modules(layer_state_t state);
|
||||
__attribute__((weak)) layer_state_t default_layer_state_set_kb(layer_state_t state);
|
||||
__attribute__((weak)) layer_state_t default_layer_state_set_user(layer_state_t state);
|
||||
|
||||
@@ -114,6 +115,7 @@ void layer_and(layer_state_t state);
|
||||
void layer_xor(layer_state_t state);
|
||||
layer_state_t layer_state_set_user(layer_state_t state);
|
||||
layer_state_t layer_state_set_kb(layer_state_t state);
|
||||
layer_state_t layer_state_set_modules(layer_state_t state);
|
||||
|
||||
/**
|
||||
* @brief Applies the tri layer to global layer state. Not be used in layer_state_set_(kb|user) functions.
|
||||
@@ -149,6 +151,7 @@ layer_state_t update_tri_layer_state(layer_state_t state, uint8_t layer1, uint8_
|
||||
# define layer_or(state) (void)state
|
||||
# define layer_and(state) (void)state
|
||||
# define layer_xor(state) (void)state
|
||||
# define layer_state_set_modules(state) (void)state
|
||||
# define layer_state_set_kb(state) (void)state
|
||||
# define layer_state_set_user(state) (void)state
|
||||
# define update_tri_layer(layer1, layer2, layer3)
|
||||
|
||||
@@ -102,6 +102,11 @@ const pointing_device_driver_t custom_pointing_device_driver = {
|
||||
|
||||
const pointing_device_driver_t *pointing_device_driver = &POINTING_DEVICE_DRIVER(POINTING_DEVICE_DRIVER_NAME);
|
||||
|
||||
__attribute__((weak)) void pointing_device_init_modules(void) {}
|
||||
__attribute__((weak)) report_mouse_t pointing_device_task_modules(report_mouse_t mouse_report) {
|
||||
return mouse_report;
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief Keyboard level code pointing device initialisation
|
||||
*
|
||||
@@ -177,6 +182,7 @@ __attribute__((weak)) void pointing_device_init(void) {
|
||||
#endif
|
||||
}
|
||||
|
||||
pointing_device_init_modules();
|
||||
pointing_device_init_kb();
|
||||
pointing_device_init_user();
|
||||
}
|
||||
@@ -303,9 +309,10 @@ __attribute__((weak)) bool pointing_device_task(void) {
|
||||
local_mouse_report = pointing_device_adjust_by_defines_right(local_mouse_report);
|
||||
shared_mouse_report = pointing_device_adjust_by_defines(shared_mouse_report);
|
||||
}
|
||||
local_mouse_report = is_keyboard_left() ? pointing_device_task_combined_kb(local_mouse_report, shared_mouse_report) : pointing_device_task_combined_kb(shared_mouse_report, local_mouse_report);
|
||||
local_mouse_report = is_keyboard_left() ? pointing_device_task_combined(local_mouse_report, shared_mouse_report) : pointing_device_task_combined(shared_mouse_report, local_mouse_report);
|
||||
#else
|
||||
local_mouse_report = pointing_device_adjust_by_defines(local_mouse_report);
|
||||
local_mouse_report = pointing_device_task_modules(local_mouse_report);
|
||||
local_mouse_report = pointing_device_task_kb(local_mouse_report);
|
||||
#endif
|
||||
// automatic mouse layer function
|
||||
@@ -486,6 +493,21 @@ report_mouse_t pointing_device_adjust_by_defines_right(report_mouse_t mouse_repo
|
||||
return mouse_report;
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief Weak function allowing for keyboard level mouse report modification
|
||||
*
|
||||
* Takes 2 report_mouse_t structs allowing individual modification of sides at keyboard level then returns pointing_device_task_combined_user.
|
||||
*
|
||||
* NOTE: Only available when using SPLIT_POINTING_ENABLE and POINTING_DEVICE_COMBINED
|
||||
*
|
||||
* @param[in] left_report report_mouse_t
|
||||
* @param[in] right_report report_mouse_t
|
||||
* @return pointing_device_task_combined_user(left_report, right_report) by default
|
||||
*/
|
||||
report_mouse_t pointing_device_task_combined(report_mouse_t left_report, report_mouse_t right_report) {
|
||||
return pointing_device_task_modules(pointing_device_task_combined_kb(left_report, right_report));
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief Weak function allowing for keyboard level mouse report modification
|
||||
*
|
||||
|
||||
@@ -17,6 +17,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <stdbool.h>
|
||||
#include <stdint.h>
|
||||
#include "host.h"
|
||||
#include "report.h"
|
||||
@@ -139,6 +140,7 @@ uint16_t pointing_device_get_shared_cpi(void);
|
||||
# if defined(POINTING_DEVICE_COMBINED)
|
||||
void pointing_device_set_cpi_on_side(bool left, uint16_t cpi);
|
||||
report_mouse_t pointing_device_combine_reports(report_mouse_t left_report, report_mouse_t right_report);
|
||||
report_mouse_t pointing_device_task_combined(report_mouse_t left_report, report_mouse_t right_report);
|
||||
report_mouse_t pointing_device_task_combined_kb(report_mouse_t left_report, report_mouse_t right_report);
|
||||
report_mouse_t pointing_device_task_combined_user(report_mouse_t left_report, report_mouse_t right_report);
|
||||
report_mouse_t pointing_device_adjust_by_defines_right(report_mouse_t mouse_report);
|
||||
|
||||
@@ -394,7 +394,12 @@ void rgb_matrix_task(void) {
|
||||
}
|
||||
}
|
||||
|
||||
__attribute__((weak)) bool rgb_matrix_indicators_modules(void) {
|
||||
return true;
|
||||
}
|
||||
|
||||
void rgb_matrix_indicators(void) {
|
||||
rgb_matrix_indicators_modules();
|
||||
rgb_matrix_indicators_kb();
|
||||
}
|
||||
|
||||
@@ -434,6 +439,10 @@ struct rgb_matrix_limits_t rgb_matrix_get_limits(uint8_t iter) {
|
||||
return limits;
|
||||
}
|
||||
|
||||
__attribute__((weak)) bool rgb_matrix_indicators_advanced_modules(uint8_t led_min, uint8_t led_max) {
|
||||
return true;
|
||||
}
|
||||
|
||||
void rgb_matrix_indicators_advanced(effect_params_t *params) {
|
||||
/* special handling is needed for "params->iter", since it's already been incremented.
|
||||
* Could move the invocations to rgb_task_render, but then it's missing a few checks
|
||||
@@ -441,6 +450,7 @@ void rgb_matrix_indicators_advanced(effect_params_t *params) {
|
||||
* rgb_task_render, right before the iter++ line.
|
||||
*/
|
||||
RGB_MATRIX_USE_LIMITS_ITER(min, max, params->iter - 1);
|
||||
rgb_matrix_indicators_advanced_modules(min, max);
|
||||
rgb_matrix_indicators_advanced_kb(min, max);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user