expose event handler: use x_deco_recurse
This commit is contained in:
parent
7d9ba707b3
commit
78d25c4cd9
|
@ -60,6 +60,14 @@ void x_window_kill(xcb_window_t window, kill_window_t kill_window);
|
|||
*/
|
||||
void x_draw_decoration(Con *con);
|
||||
|
||||
/**
|
||||
* Recursively calls x_draw_decoration. This cannot be done in x_push_node
|
||||
* because x_push_node uses focus order to recurse (see the comment above)
|
||||
* while drawing the decoration needs to happen in the actual order.
|
||||
*
|
||||
*/
|
||||
void x_deco_recurse(Con *con);
|
||||
|
||||
/**
|
||||
* This function pushes the properties of each node of the layout tree to
|
||||
* X11 if they have changed (like the map state, position of the window, …).
|
||||
|
|
|
@ -586,7 +586,7 @@ static int handle_windowclass_change(void *data, xcb_connection_t *conn, uint8_t
|
|||
*
|
||||
*/
|
||||
static int handle_expose_event(xcb_expose_event_t *event) {
|
||||
Con *parent, *con;
|
||||
Con *parent;
|
||||
|
||||
/* event->count is the number of minimum remaining expose events for this
|
||||
* window, so we skip all events but the last one */
|
||||
|
@ -600,22 +600,8 @@ static int handle_expose_event(xcb_expose_event_t *event) {
|
|||
return 1;
|
||||
}
|
||||
|
||||
if (parent->window)
|
||||
x_draw_decoration(parent);
|
||||
|
||||
TAILQ_FOREACH(con, &(parent->nodes_head), nodes) {
|
||||
DLOG("expose for con %p / %s\n", con, con->name);
|
||||
if (con->window)
|
||||
x_draw_decoration(con);
|
||||
}
|
||||
|
||||
/* We also need to render the decorations of other Cons nearby the Con
|
||||
* itself to not get overlapping decorations */
|
||||
TAILQ_FOREACH(con, &(parent->parent->nodes_head), nodes) {
|
||||
DLOG("expose for con %p / %s\n", con, con->name);
|
||||
if (con->window)
|
||||
x_draw_decoration(con);
|
||||
}
|
||||
/* re-render the parent (recursively, if it’s a split con) */
|
||||
x_deco_recurse(parent);
|
||||
xcb_flush(conn);
|
||||
|
||||
return 1;
|
||||
|
|
Loading…
Reference in New Issue