event_lasttime = e->xproperty.time;
break;
case FocusIn:
+ if (e->xfocus.mode == NotifyGrab) return;
+/* if (e->type == FocusIn && window == focus_backup && focus_client != NULL) {
+*/
+ /* Something's focused but we got a focus event for the backup
+ window. this means that something unfocused before we received
+ the new FocusIn. Just ignore it, and refocus what should be
+ focused! */
+/* client_focus(focus_client);
+ return;
+ }
+*/
+ break;
case FocusOut:
- if (e->xfocus.mode == NotifyGrab)
+ if (e->xfocus.mode == NotifyGrab) return;
/*|| e.xfocus.mode == NotifyUngrab ||*/
-
/* From Metacity, from WindowMaker, ignore all funky pointer
root events. Its commented out cuz I don't think we need this
at all. If problems arise we can look into it */
/*e.xfocus.detail > NotifyNonlinearVirtual) */
- return; /* skip me! */
- if (e->type == FocusOut) {
- /* FocusOut events just make us look for FocusIn events. They
- are mostly ignored otherwise. */
- XEvent fi;
- if (XCheckTypedEvent(ob_display, FocusIn, &fi)) {
+
+ /* FocusOut events just make us look for FocusIn events. They
+ are mostly ignored otherwise. */
+ {
+ XEvent fi;
+ if (XCheckTypedEvent(ob_display, FocusIn, &fi)) {
event_process(&fi);
/* dont unfocus the window we just focused! */
if (fi.xfocus.window == e->xfocus.window)
return;
}
- }
+ }
break;
case EnterNotify:
case LeaveNotify:
}
client = g_hash_table_lookup(client_map, (gpointer)window);
- g_message("EVENT: 0x%lx -> 0x%lx", window, client);
/* deal with it in the kernel */
if (client)
switch (e->type) {
case FocusIn:
- client_set_focused(client, TRUE);
+ if (focus_client != client)
+ focus_set_client(client);
+
+ /* focus state can affect the stacking layer */
+ client_calc_layer(client);
+
+ engine_frame_adjust_focus(client->frame);
break;
case FocusOut:
- client_set_focused(client, FALSE);
+ if (focus_client == client)
+ focus_set_client(NULL);
+
+ /* focus state can affect the stacking layer */
+ client_calc_layer(client);
+
+ engine_frame_adjust_focus(client->frame);
break;
case ConfigureRequest:
g_message("ConfigureRequest for window %lx", client->window);