all repos — openbox @ eb2a0feb0154e86a1c6c117fd0f6d1a18959b694

openbox fork - make it a bit more like ryudo

watch for reverttoparent reverting to the root window, which will create a DetailInferior focusin event on root.

adding some debug messages also which I am using..
Dana Jansens danakj@orodu.net
commit

eb2a0feb0154e86a1c6c117fd0f6d1a18959b694

parent

4aa8d64f76b48f8c43eb39eeca1f61fcc8c7b61e

4 files changed, 24 insertions(+), 22 deletions(-)

jump to
M openbox/client.copenbox/client.c

@@ -220,13 +220,14 @@ gint newx, newy;

grab_server(TRUE); - /* check if it has already been unmapped by the time we started mapping + /* check if it has already been unmapped by the time we started mapping. the grab does a sync so we don't have to here */ if (XCheckTypedWindowEvent(ob_display, window, DestroyNotify, &e) || XCheckTypedWindowEvent(ob_display, window, UnmapNotify, &e)) { XPutBackEvent(ob_display, &e); + ob_debug("Trying to manage unmapped window. Aborting that.\n"); grab_server(FALSE); return; /* don't manage it */ }

@@ -393,6 +394,8 @@ /* do this after the window is placed, so the premax/prefullscreen numbers

won't be all wacko!! also, this moves the window to the position where it has been placed */ + ob_debug("placing window 0x%x at %d, %d with size %d x %d\n", + self->window, newx, newy, self->area.width, self->area.height); client_apply_startup_state(self, newx, newy); keyboard_grab_for_client(self, TRUE);
M openbox/event.copenbox/event.c

@@ -329,7 +329,8 @@ /* These are the ones we want.. */

if (win == RootWindow(ob_display, ob_screen)) { /* This means focus reverted off of a client */ - if (detail == NotifyPointerRoot || detail == NotifyDetailNone) + if (detail == NotifyPointerRoot || detail == NotifyDetailNone || + detail == NotifyInferior) return TRUE; else return FALSE;

@@ -688,7 +689,8 @@ focus_fallback(FALSE);

} else if (ce.xfocus.detail == NotifyInferior) { ob_debug("Focus went to parent\n"); /* Focus has been reverted to parent, which is our frame window, - so fall back to something other than the window which had it. */ + or the root window, so fall back to something other than the + window which had it. */ focus_fallback(FALSE); } else { /* Focus did move, so process the FocusIn event */

@@ -906,7 +908,10 @@ }

} break; case UnmapNotify: - ob_debug("UnmapNotify for window 0x%x\n", client->window); + ob_debug("UnmapNotify for window 0x%x eventwin 0x%x sendevent %d " + "ignores left %d\n", + client->window, e->xunmap.event, e->xunmap.from_configure, + client->ignore_unmaps); if (client->ignore_unmaps) { client->ignore_unmaps--; break;

@@ -932,6 +937,7 @@ /* we don't want the reparent event, put it back on the stack for the

X server to deal with after we unmanage the window */ XPutBackEvent(ob_display, e); + ob_debug("ReparentNotify for window 0x%x\n", client->window); client_unmanage(client); break; case MapRequest:
M openbox/frame.copenbox/frame.c

@@ -234,32 +234,26 @@ }

void frame_show(ObFrame *self) { + ob_debug("frame_show for window 0x%x : %d\n", self->client->window, + self->visible); if (!self->visible) { self->visible = TRUE; XMapWindow(ob_display, self->client->window); XMapWindow(ob_display, self->window); - self->firstmap = TRUE; } } void frame_hide(ObFrame *self) { - if (self->visible || self->firstmap == FALSE) { - if (self->visible) { - self->visible = FALSE; - self->client->ignore_unmaps += 1; - /* we unmap the client itself so that we can get MapRequest - events, and because the ICCCM tells us to! */ - XUnmapWindow(ob_display, self->window); - XUnmapWindow(ob_display, self->client->window); - } else { - /* the frame wasn't visible, but the frame is being hidden now. - so we don't need to unmap the frame, but we do need to unmap - the client. */ - self->client->ignore_unmaps += 1; - XUnmapWindow(ob_display, self->client->window); - } - self->firstmap = TRUE; + ob_debug("frame_hide for window 0x%x : %d\n", self->client->window, + self->visible); + if (self->visible) { + self->visible = FALSE; + self->client->ignore_unmaps += 1; + /* we unmap the client itself so that we can get MapRequest + events, and because the ICCCM tells us to! */ + XUnmapWindow(ob_display, self->window); + XUnmapWindow(ob_display, self->client->window); } }
M openbox/frame.hopenbox/frame.h

@@ -76,7 +76,6 @@

Strut size; Rect area; gboolean visible; - gboolean firstmap; /*! Whether the window is obscured at all or fully visible. */ gboolean obscured;