X-Git-Url: https://git.friedersdorff.com/?a=blobdiff_plain;ds=sidebyside;f=common%2Fhost.h;h=7c4f06601d9a0e682b77a38b56bd46cf0abfc4e4;hb=8c80deb775ac151001dc1592a2e94e8677b49964;hp=11b9aacd7cc50f89537ea3c614952dee72ac32f0;hpb=62d1ebb91c7b381ce3d88aad9ee0b03bea9fce26;p=max%2Ftmk_keyboard.git diff --git a/common/host.h b/common/host.h index 11b9aacd..7c4f0660 100644 --- a/common/host.h +++ b/common/host.h @@ -19,39 +19,59 @@ along with this program. If not, see . #define HOST_H #include +#include #include "report.h" #include "host_driver.h" +#ifdef __cplusplus +extern "C" { +#endif + #ifdef NKRO_ENABLE extern bool keyboard_nkro; #endif +/* report */ extern report_keyboard_t *keyboard_report; -extern report_keyboard_t *keyboard_report_prev; +extern report_mouse_t mouse_report; +/* host driver */ void host_set_driver(host_driver_t *driver); host_driver_t *host_get_driver(void); + +/* host driver interface */ uint8_t host_keyboard_leds(void); +void host_keyboard_send(report_keyboard_t *report); +void host_mouse_send(report_mouse_t *report); +void host_system_send(uint16_t data); +void host_consumer_send(uint16_t data); -/* keyboard report operations */ +/* keyboard report utils */ void host_add_key(uint8_t key); void host_del_key(uint8_t key); -void host_add_mod_bit(uint8_t mod); -void host_del_mod_bit(uint8_t mod); +void host_clear_keys(void); + +uint8_t host_get_mods(void); +void host_add_mods(uint8_t mods); +void host_del_mods(uint8_t mods); void host_set_mods(uint8_t mods); -void host_add_code(uint8_t code); -void host_del_code(uint8_t code); -void host_swap_keyboard_report(void); -void host_clear_keyboard_report(void); +void host_clear_mods(void); + uint8_t host_has_anykey(void); +uint8_t host_has_anymod(void); uint8_t host_get_first_key(void); +void host_send_keyboard_report(void); +/* mouse report utils */ +uint8_t host_mouse_in_use(void); -void host_send_keyboard_report(void); -void host_mouse_send(report_mouse_t *report); -void host_system_send(uint16_t data); -void host_consumer_send(uint16_t data); +uint16_t host_last_sysytem_report(void); +uint16_t host_last_consumer_report(void); + +#ifdef __cplusplus +} +#endif #endif