2015-04-09 17:32:04 +01:00
/*
Copyright 2011 , 2012 , 2013 Jun Wako < wakojun @ gmail . com >
This program is free software : you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation , either version 2 of the License , or
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
along with this program . If not , see < http : //www.gnu.org/licenses/>.
*/
2020-12-26 04:56:11 +00:00
# pragma once
2015-04-09 17:32:04 +01:00
# include <stdbool.h>
# include <stdint.h>
2023-07-16 14:42:56 +01:00
# include "timer.h"
2015-04-09 17:32:04 +01:00
# ifdef __cplusplus
extern " C " {
# endif
/* key matrix position */
typedef struct {
uint8_t col ;
uint8_t row ;
} keypos_t ;
2023-12-11 23:06:18 +00:00
typedef enum keyevent_type_t { TICK_EVENT = 0 , KEY_EVENT = 1 , ENCODER_CW_EVENT = 2 , ENCODER_CCW_EVENT = 3 , COMBO_EVENT = 4 , DIP_SWITCH_ON_EVENT = 5 , DIP_SWITCH_OFF_EVENT = 6 } keyevent_type_t ;
2023-04-03 09:33:45 +01:00
2015-04-09 17:32:04 +01:00
/* key event */
typedef struct {
2023-04-03 09:33:45 +01:00
keypos_t key ;
uint16_t time ;
keyevent_type_t type ;
bool pressed ;
2015-04-09 17:32:04 +01:00
} keyevent_t ;
/* equivalent test of keypos_t */
2019-08-30 19:19:03 +01:00
# define KEYEQ(keya, keyb) ((keya).row == (keyb).row && (keya).col == (keyb).col)
2015-04-09 17:32:04 +01:00
2022-03-09 08:29:00 +00:00
/* special keypos_t entries */
# define KEYLOC_ENCODER_CW 253
# define KEYLOC_ENCODER_CCW 252
2023-12-11 23:06:18 +00:00
# define KEYLOC_DIP_SWITCH_ON 251
# define KEYLOC_DIP_SWITCH_OFF 250
2022-03-09 08:29:00 +00:00
2023-04-03 09:33:45 +01:00
static inline bool IS_NOEVENT ( const keyevent_t event ) {
return event . type = = TICK_EVENT ;
2022-03-09 08:29:00 +00:00
}
2023-04-03 09:33:45 +01:00
static inline bool IS_EVENT ( const keyevent_t event ) {
return event . type ! = TICK_EVENT ;
2022-03-09 08:29:00 +00:00
}
2023-04-03 09:33:45 +01:00
static inline bool IS_KEYEVENT ( const keyevent_t event ) {
return event . type = = KEY_EVENT ;
2022-02-12 18:29:31 +00:00
}
2023-04-03 09:33:45 +01:00
static inline bool IS_COMBOEVENT ( const keyevent_t event ) {
return event . type = = COMBO_EVENT ;
2022-02-12 18:29:31 +00:00
}
2023-04-03 09:33:45 +01:00
static inline bool IS_ENCODEREVENT ( const keyevent_t event ) {
return event . type = = ENCODER_CW_EVENT | | event . type = = ENCODER_CCW_EVENT ;
2022-02-12 18:29:31 +00:00
}
2023-12-11 23:06:18 +00:00
static inline bool IS_DIPSWITCHEVENT ( const keyevent_t event ) {
return event . type = = DIP_SWITCH_ON_EVENT | | event . type = = DIP_SWITCH_OFF_EVENT ;
}
2015-04-09 17:32:04 +01:00
2023-04-03 09:33:45 +01:00
/* Common keypos_t object factory */
2022-03-09 08:29:00 +00:00
# define MAKE_KEYPOS(row_num, col_num) ((keypos_t){.row = (row_num), .col = (col_num)})
2022-08-06 11:51:13 +01:00
2023-04-03 09:33:45 +01:00
/* Common keyevent_t object factory */
# define MAKE_EVENT(row_num, col_num, press, event_type) ((keyevent_t){.key = MAKE_KEYPOS((row_num), (col_num)), .pressed = (press), .time = timer_read(), .type = (event_type)})
2022-08-06 11:51:13 +01:00
/**
* @ brief Constructs a key event for a pressed or released key .
*/
2023-04-03 09:33:45 +01:00
# define MAKE_KEYEVENT(row_num, col_num, press) MAKE_EVENT((row_num), (col_num), (press), KEY_EVENT)
/**
* @ brief Constructs a combo event .
*/
# define MAKE_COMBOEVENT(press) MAKE_EVENT(0, 0, (press), COMBO_EVENT)
2022-03-09 08:29:00 +00:00
2022-08-06 11:51:13 +01:00
/**
* @ brief Constructs a internal tick event that is used to drive the internal QMK state machine .
*/
2023-04-03 09:33:45 +01:00
# define MAKE_TICK_EVENT MAKE_EVENT(0, 0, false, TICK_EVENT)
2022-03-09 08:29:00 +00:00
# ifdef ENCODER_MAP_ENABLE
/* Encoder events */
2023-04-03 09:33:45 +01:00
# define MAKE_ENCODER_CW_EVENT(enc_id, press) MAKE_EVENT(KEYLOC_ENCODER_CW, (enc_id), (press), ENCODER_CW_EVENT)
# define MAKE_ENCODER_CCW_EVENT(enc_id, press) MAKE_EVENT(KEYLOC_ENCODER_CCW, (enc_id), (press), ENCODER_CCW_EVENT)
2022-03-09 08:29:00 +00:00
# endif // ENCODER_MAP_ENABLE
2015-04-09 17:32:04 +01:00
2023-12-11 23:06:18 +00:00
# ifdef DIP_SWITCH_MAP_ENABLE
/* Dip Switch events */
# define MAKE_DIPSWITCH_ON_EVENT(switch_id, press) MAKE_EVENT(KEYLOC_DIP_SWITCH_ON, (switch_id), (press), DIP_SWITCH_ON_EVENT)
# define MAKE_DIPSWITCH_OFF_EVENT(switch_id, press) MAKE_EVENT(KEYLOC_DIP_SWITCH_OFF, (switch_id), (press), DIP_SWITCH_OFF_EVENT)
# endif // DIP_SWITCH_MAP_ENABLE
2015-05-17 11:34:34 +01:00
/* it runs once at early stage of startup before keyboard_init. */
void keyboard_setup ( void ) ;
/* it runs once after initializing host side protocol, debug and MCU peripherals. */
2015-04-09 17:32:04 +01:00
void keyboard_init ( void ) ;
2015-05-17 11:34:34 +01:00
/* it runs repeatedly in main loop */
2015-04-09 17:32:04 +01:00
void keyboard_task ( void ) ;
2019-01-17 18:08:14 +00:00
/* it runs whenever code has to behave differently on a slave */
bool is_keyboard_master ( void ) ;
2020-11-19 00:50:32 +00:00
/* it runs whenever code has to behave differently on left vs right split */
bool is_keyboard_left ( void ) ;
2015-04-09 17:32:04 +01:00
2019-02-15 04:18:54 +00:00
void keyboard_pre_init_kb ( void ) ;
void keyboard_pre_init_user ( void ) ;
void keyboard_post_init_kb ( void ) ;
void keyboard_post_init_user ( void ) ;
2022-02-12 18:29:31 +00:00
void housekeeping_task ( void ) ; // To be executed by the main loop in each backend TMK protocol
void housekeeping_task_kb ( void ) ; // To be overridden by keyboard-level code
void housekeeping_task_user ( void ) ; // To be overridden by user/keymap-level code
2020-11-28 20:02:18 +00:00
2023-03-31 02:27:39 +01:00
uint32_t last_input_activity_time ( void ) ; // Timestamp of the last matrix or encoder or pointing device activity
uint32_t last_input_activity_elapsed ( void ) ; // Number of milliseconds since the last matrix or encoder or pointing device activity
2021-01-21 11:24:07 +00:00
2022-02-12 18:29:31 +00:00
uint32_t last_matrix_activity_time ( void ) ; // Timestamp of the last matrix activity
uint32_t last_matrix_activity_elapsed ( void ) ; // Number of milliseconds since the last matrix activity
2021-01-17 18:01:38 +00:00
2022-02-12 18:29:31 +00:00
uint32_t last_encoder_activity_time ( void ) ; // Timestamp of the last encoder activity
uint32_t last_encoder_activity_elapsed ( void ) ; // Number of milliseconds since the last encoder activity
2021-01-21 11:24:07 +00:00
2023-03-31 02:27:39 +01:00
uint32_t last_pointing_device_activity_time ( void ) ; // Timestamp of the last pointing device activity
uint32_t last_pointing_device_activity_elapsed ( void ) ; // Number of milliseconds since the last pointing device activity
void set_activity_timestamps ( uint32_t matrix_timestamp , uint32_t encoder_timestamp , uint32_t pointing_device_timestamp ) ; // Set the timestamps of the last matrix and encoder activity
2023-03-21 09:16:11 +00:00
2021-01-27 17:34:50 +00:00
uint32_t get_matrix_scan_rate ( void ) ;
2015-04-09 17:32:04 +01:00
# ifdef __cplusplus
}
# endif