all repos — openbox @ 8d4fe416e5d940670df7b974a004ac041e21196f

openbox fork - make it a bit more like ryudo

maprequests do not come here once the window is managed any more. they go to the plate. make events on the plate go to the client for handling, and dont bother looking for clients in the maprequesthandler anymore
Dana Jansens danakj@orodu.net
commit

8d4fe416e5d940670df7b974a004ac041e21196f

parent

4c5671eecae90077dd930bf36af3be9e13305985

1 files changed, 8 insertions(+), 25 deletions(-)

jump to
M src/screen.ccsrc/screen.cc

@@ -471,6 +471,12 @@ XChangeSaveSet(**otk::display, window, SetModeInsert);

// create the decoration frame for the client window client->frame = new Frame(client, &_style); + // register the plate for events (map req's) + // this involves removing itself from the handler list first, since it is + // auto added to the list, being a widget. we won't get any events on the + // plate except for events for the client (SubstructureRedirectMask) + openbox->clearHandler(client->frame->plate()); + openbox->registerHandler(client->frame->plate(), client); // add to the wm's map openbox->addClient(client->frame->window(), client);

@@ -765,30 +771,7 @@ #ifdef DEBUG

printf("MapRequest for 0x%lx\n", e.window); #endif // DEBUG - /* - MapRequest events come here even after the window exists instead of going - right to the client window, because of how they are sent and their struct - layout. - */ - Client *c = openbox->findClient(e.window); + manageWindow(e.window); +} - if (c) { - // send a net_active_window message - XEvent ce; - ce.xclient.type = ClientMessage; - ce.xclient.message_type = otk::Property::atoms.net_active_window; - ce.xclient.display = **otk::display; - ce.xclient.window = c->window(); - ce.xclient.format = 32; - ce.xclient.data.l[0] = 0l; - ce.xclient.data.l[1] = 0l; - ce.xclient.data.l[2] = 0l; - ce.xclient.data.l[3] = 0l; - ce.xclient.data.l[4] = 0l; - XSendEvent(**otk::display, _info->rootWindow(), false, - SubstructureRedirectMask | SubstructureNotifyMask, - &ce); - } else - manageWindow(e.window); -} }