only re-position floating clients mapped to (0, 0), add pixels for decoration

This commit is contained in:
Michael Stapelberg 2010-11-12 20:55:43 +01:00
parent 57e602a97c
commit 0723876429
1 changed files with 15 additions and 2 deletions

View File

@ -34,6 +34,11 @@ void floating_enable(Con *con, bool automatic) {
Con *nc = con_new(NULL); Con *nc = con_new(NULL);
nc->parent = con_get_workspace(con); nc->parent = con_get_workspace(con);
nc->rect = con->rect; nc->rect = con->rect;
/* add pixels for the decoration */
/* TODO: dont add them when the user automatically puts new windows into
* 1pixel/borderless mode */
nc->rect.height += 17 + 2;
nc->rect.width += 4;
nc->orientation = NO_ORIENTATION; nc->orientation = NO_ORIENTATION;
nc->type = CT_FLOATING_CON; nc->type = CT_FLOATING_CON;
TAILQ_INSERT_TAIL(&(nc->parent->floating_head), nc, floating_windows); TAILQ_INSERT_TAIL(&(nc->parent->floating_head), nc, floating_windows);
@ -43,8 +48,16 @@ void floating_enable(Con *con, bool automatic) {
con->old_parent = con->parent; con->old_parent = con->parent;
con->parent = nc; con->parent = nc;
con->floating = FLOATING_USER_ON; con->floating = FLOATING_USER_ON;
nc->rect.x = 400;
nc->rect.y = 400; /* Some clients (like GIMPs color picker window) get mapped
* to (0, 0), so we push them to a reasonable position
* (centered over their leader) */
if (nc->rect.x == 0 && nc->rect.y == 0) {
/* TODO: client_leader support */
nc->rect.x = 400;
nc->rect.y = 400;
}
TAILQ_INSERT_TAIL(&(nc->nodes_head), con, nodes); TAILQ_INSERT_TAIL(&(nc->nodes_head), con, nodes);
TAILQ_INSERT_TAIL(&(nc->focus_head), con, focused); TAILQ_INSERT_TAIL(&(nc->focus_head), con, focused);
} }