diff options
author | Marvin Borner | 2021-01-09 23:19:53 +0100 |
---|---|---|
committer | Marvin Borner | 2021-01-09 23:19:53 +0100 |
commit | 836294b9232c7d63d26db4f87c32cf1420cd856d (patch) | |
tree | 54f1b28951c53b38dcde5866a74c082c8ef83b0f /libgui/gui.c | |
parent | f27a5f8af9fc5a16b80a7d6646e44d718b0efd7d (diff) |
To be continued
Diffstat (limited to 'libgui/gui.c')
-rw-r--r-- | libgui/gui.c | 14 |
1 files changed, 6 insertions, 8 deletions
diff --git a/libgui/gui.c b/libgui/gui.c index b675586..8ab6260 100644 --- a/libgui/gui.c +++ b/libgui/gui.c @@ -531,28 +531,28 @@ void gui_event_loop(struct element *container) if (!container) return; - struct message *msg; + struct message msg = { 0 }; struct element *focused = NULL; while (1) { - if (!(msg = msg_receive())) { + if (!msg_receive(&msg)) { yield(); continue; } - switch (msg->type) { + switch (msg.type) { case GUI_KILL: { remove_all(); exit(0); } case GUI_MOUSE: { - struct gui_event_mouse *event = msg->data; + struct gui_event_mouse *event = msg.data; focused = element_at(container, event->x, event->y); if (focused && focused->event.on_click && event->but1) focused->event.on_click(event, focused); break; } case GUI_KEYBOARD: { - struct gui_event_keyboard *event = msg->data; + struct gui_event_keyboard *event = msg.data; if (focused && focused->type == GUI_TYPE_TEXT_INPUT && event->press) { char *s = ((struct element_text_input *)focused->data)->text; @@ -584,15 +584,13 @@ void gui_event_loop(struct element *container) break; } case GUI_RESIZE: { - struct gui_event_resize *event = msg->data; + struct gui_event_resize *event = msg.data; struct element *root = get_root(container->window_id); root->ctx = event->new_ctx; gui_sync_window(container->window_id); break; } } - - free(msg); } exit(1); |