kill placeholder windows when the actual window appears

This commit is contained in:
Michael Stapelberg 2013-12-15 15:00:26 +01:00
parent 28a993e656
commit 42e359ec60
3 changed files with 40 additions and 0 deletions

View File

@ -29,4 +29,13 @@ void restore_connect(void);
*/ */
void restore_open_placeholder_windows(Con *con); void restore_open_placeholder_windows(Con *con);
/**
* Kill the placeholder window, if placeholder refers to a placeholder window.
* This function is called when manage.c puts a window into an existing
* container. In order not to leak resources, we need to destroy the window and
* all associated X11 objects (pixmap/gc).
*
*/
bool restore_kill_placeholder(xcb_window_t placeholder);
#endif #endif

View File

@ -327,6 +327,11 @@ void manage_window(xcb_window_t window, xcb_get_window_attributes_cookie_t cooki
} }
DLOG("new container = %p\n", nc); DLOG("new container = %p\n", nc);
if (nc->window != NULL) {
if (!restore_kill_placeholder(nc->window->id)) {
DLOG("Uh?! Container without a placeholder, but with a window, has swallowed this to-be-managed window?!\n");
}
}
nc->window = cwindow; nc->window = cwindow;
x_reinit(nc); x_reinit(nc);

View File

@ -226,6 +226,32 @@ void restore_open_placeholder_windows(Con *parent) {
xcb_flush(restore_conn); xcb_flush(restore_conn);
} }
/*
* Kill the placeholder window, if placeholder refers to a placeholder window.
* This function is called when manage.c puts a window into an existing
* container. In order not to leak resources, we need to destroy the window and
* all associated X11 objects (pixmap/gc).
*
*/
bool restore_kill_placeholder(xcb_window_t placeholder) {
placeholder_state *state;
TAILQ_FOREACH(state, &state_head, state) {
if (state->window != placeholder)
continue;
xcb_destroy_window(restore_conn, state->window);
xcb_free_pixmap(restore_conn, state->pixmap);
xcb_free_gc(restore_conn, state->gc);
TAILQ_REMOVE(&state_head, state, state);
free(state);
DLOG("placeholder window 0x%08x destroyed.\n", placeholder);
return true;
}
DLOG("0x%08x is not a placeholder window, ignoring.\n", placeholder);
return false;
}
static void expose_event(xcb_expose_event_t *event) { static void expose_event(xcb_expose_event_t *event) {
placeholder_state *state; placeholder_state *state;
TAILQ_FOREACH(state, &state_head, state) { TAILQ_FOREACH(state, &state_head, state) {