Bugfix: Correctly revert floating focus when killing the last floating window (+test)

This commit is contained in:
Michael Stapelberg
2011-07-01 01:10:43 +02:00
parent 9611e46eb6
commit 23d4917e43
2 changed files with 47 additions and 4 deletions

View File

@ -646,7 +646,12 @@ Con *con_next_focused(Con *con) {
if (con->type == CT_FLOATING_CON) {
DLOG("selecting next for CT_FLOATING_CON\n");
next = TAILQ_NEXT(con, floating_windows);
if (next == TAILQ_END(&(parent->floating_head))) {
DLOG("next = %p\n", next);
if (!next) {
next = TAILQ_PREV(con, floating_head, floating_windows);
DLOG("using prev, next = %p\n", next);
}
if (!next) {
Con *ws = con_get_workspace(con);
next = ws;
DLOG("no more floating containers for next = %p, restoring workspace focus\n", next);