forked from kofal.net/zmk
refactor(core): Extra event payloads to own types, refactor API.
* Make it easier to use *just* event payloads by defining the data, and then having event manager macros generate "wrapper structs" * Improve is_*/cast_* APIs to hide details of full event struct. * Create `zmk_event_t` typedef to pass to event handlers. * Bring event names inline w/ consistent `zmk_` prefix.
This commit is contained in:
@@ -75,8 +75,8 @@ int zmk_display_init() {
|
||||
return 0;
|
||||
}
|
||||
|
||||
int display_event_handler(const struct zmk_event_header *eh) {
|
||||
struct activity_state_changed *ev = cast_activity_state_changed(eh);
|
||||
int display_event_handler(const zmk_event_t *eh) {
|
||||
struct zmk_activity_state_changed *ev = cast_zmk_activity_state_changed(eh);
|
||||
switch (ev->state) {
|
||||
case ZMK_ACTIVITY_ACTIVE:
|
||||
start_display_updates();
|
||||
@@ -93,4 +93,4 @@ int display_event_handler(const struct zmk_event_header *eh) {
|
||||
}
|
||||
|
||||
ZMK_LISTENER(display, display_event_handler);
|
||||
ZMK_SUBSCRIPTION(display, activity_state_changed);
|
||||
ZMK_SUBSCRIPTION(display, zmk_activity_state_changed);
|
||||
@@ -75,14 +75,14 @@ lv_obj_t *zmk_widget_battery_status_obj(struct zmk_widget_battery_status *widget
|
||||
return widget->obj;
|
||||
}
|
||||
|
||||
int battery_status_listener(const struct zmk_event_header *eh) {
|
||||
int battery_status_listener(const zmk_event_t *eh) {
|
||||
struct zmk_widget_battery_status *widget;
|
||||
SYS_SLIST_FOR_EACH_CONTAINER(&widgets, widget, node) { set_battery_symbol(widget->obj); }
|
||||
return ZMK_EV_EVENT_BUBBLE;
|
||||
}
|
||||
|
||||
ZMK_LISTENER(widget_battery_status, battery_status_listener)
|
||||
ZMK_SUBSCRIPTION(widget_battery_status, battery_state_changed);
|
||||
ZMK_SUBSCRIPTION(widget_battery_status, zmk_battery_state_changed);
|
||||
#if IS_ENABLED(CONFIG_USB)
|
||||
ZMK_SUBSCRIPTION(widget_battery_status, usb_conn_state_changed);
|
||||
ZMK_SUBSCRIPTION(widget_battery_status, zmk_usb_conn_state_changed);
|
||||
#endif /* IS_ENABLED(CONFIG_USB) */
|
||||
|
||||
@@ -69,11 +69,11 @@ lv_obj_t *zmk_widget_layer_status_obj(struct zmk_widget_layer_status *widget) {
|
||||
return widget->obj;
|
||||
}
|
||||
|
||||
int layer_status_listener(const struct zmk_event_header *eh) {
|
||||
int layer_status_listener(const zmk_event_t *eh) {
|
||||
struct zmk_widget_layer_status *widget;
|
||||
SYS_SLIST_FOR_EACH_CONTAINER(&widgets, widget, node) { set_layer_symbol(widget->obj); }
|
||||
return 0;
|
||||
}
|
||||
|
||||
ZMK_LISTENER(widget_layer_status, layer_status_listener)
|
||||
ZMK_SUBSCRIPTION(widget_layer_status, layer_state_changed);
|
||||
ZMK_SUBSCRIPTION(widget_layer_status, zmk_layer_state_changed);
|
||||
@@ -79,7 +79,7 @@ lv_obj_t *zmk_widget_output_status_obj(struct zmk_widget_output_status *widget)
|
||||
return widget->obj;
|
||||
}
|
||||
|
||||
int output_status_listener(const struct zmk_event_header *eh) {
|
||||
int output_status_listener(const zmk_event_t *eh) {
|
||||
struct zmk_widget_output_status *widget;
|
||||
SYS_SLIST_FOR_EACH_CONTAINER(&widgets, widget, node) { set_status_symbol(widget->obj); }
|
||||
return ZMK_EV_EVENT_BUBBLE;
|
||||
@@ -87,8 +87,8 @@ int output_status_listener(const struct zmk_event_header *eh) {
|
||||
|
||||
ZMK_LISTENER(widget_output_status, output_status_listener)
|
||||
#if defined(CONFIG_USB)
|
||||
ZMK_SUBSCRIPTION(widget_output_status, usb_conn_state_changed);
|
||||
ZMK_SUBSCRIPTION(widget_output_status, zmk_usb_conn_state_changed);
|
||||
#endif
|
||||
#if defined(CONFIG_ZMK_BLE)
|
||||
ZMK_SUBSCRIPTION(widget_output_status, ble_active_profile_changed);
|
||||
ZMK_SUBSCRIPTION(widget_output_status, zmk_ble_active_profile_changed);
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user