focus fallback works when nothing is focused

This commit is contained in:
Dana Jansens 2003-03-18 09:10:05 +00:00
parent 77bd016628
commit 20a5dd4745

View file

@ -1,6 +1,7 @@
#include "../kernel/dispatch.h" #include "../kernel/dispatch.h"
#include "../kernel/screen.h" #include "../kernel/screen.h"
#include "../kernel/client.h" #include "../kernel/client.h"
#include "../kernel/focus.h"
#include "../kernel/stacking.h" #include "../kernel/stacking.h"
static GSList **focus_order = NULL; static GSList **focus_order = NULL;
@ -18,6 +19,11 @@ static void events(ObEvent *e, void *foo)
client_focus(e->data.c.client); client_focus(e->data.c.client);
break; break;
case Event_Client_Destroy:
i = e->data.c.client->desktop;
focus_order[i] = g_slist_remove(focus_order[i], e->data.c.client);
break;
case Event_Ob_NumDesktops: case Event_Ob_NumDesktops:
new = e->data.o.num[0]; new = e->data.o.num[0];
old = e->data.o.num[1]; old = e->data.o.num[1];
@ -43,11 +49,22 @@ static void events(ObEvent *e, void *foo)
break; break;
case Event_Ob_Desktop: case Event_Ob_Desktop:
for (it = focus_order[e->data.o.num[0]]; it != NULL; it = it->next) /* focus the next available target */
new = e->data.o.num[0];
for (it = focus_order[new]; it != NULL; it = it->next)
if (client_focus(it->data)) if (client_focus(it->data))
break; break;
break; break;
case Event_Client_Unfocus:
if (focus_client == NULL) { /* nothing is left with focus! */
/* focus the next available target */
for (it = focus_order[screen_desktop]; it != NULL; it = it->next)
if (client_focus(it->data))
break;
}
break;
case Event_Client_Focus: case Event_Client_Focus:
/* move to the top of the list */ /* move to the top of the list */
focus_order[e->data.c.num[1]] = focus_order[e->data.c.num[1]] =
@ -65,9 +82,11 @@ void plugin_startup()
{ {
guint i; guint i;
dispatch_register(Event_Client_Mapped | Event_Ob_Desktop | dispatch_register(Event_Client_Mapped | Event_Client_Destroy |
Event_Ob_NumDesktops | Event_Client_Focus | Event_Ob_Desktop | Event_Ob_NumDesktops |
Event_Client_Desktop, (EventHandler)events, NULL); Event_Client_Focus | Event_Client_Unfocus |
Event_Client_Desktop,
(EventHandler)events, NULL);
focus_order = g_new(GSList*, screen_num_desktops); focus_order = g_new(GSList*, screen_num_desktops);
for (i = 0; i < screen_num_desktops; ++i) for (i = 0; i < screen_num_desktops; ++i)