X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;f=src%2Fclient.cc;h=c69d576a47f1c5c3b4e1d58359d3ae4ce0ae9be3;hb=8f8acc24933830d4f5784616b9b0c5896bde0b93;hp=07bf6f0b7c4bef5b89cc2e1309efb7ac0ca9ad8c;hpb=b1739374a61d0c33270bafe84da9d787e79c0686;p=chaz%2Fopenbox diff --git a/src/client.cc b/src/client.cc index 07bf6f0b..c69d576a 100644 --- a/src/client.cc +++ b/src/client.cc @@ -43,6 +43,8 @@ OBClient::OBClient(int screen, Window window) _focused = false; // not a transient by default of course _transient_for = 0; + // pick a layer to start from + _layer = Layer_Normal; getArea(); getDesktop(); @@ -1003,8 +1005,26 @@ void OBClient::move(int x, int y) _area.setPos(x, y); // move the frame to be in the requested position - if (frame) // this can be called while mapping, before frame exists + if (frame) { // this can be called while mapping, before frame exists frame->adjustPosition(); + + // send synthetic configure notify (we don't need to if we aren't mapped + // yet) + XEvent event; + event.type = ConfigureNotify; + event.xconfigure.display = otk::OBDisplay::display; + event.xconfigure.event = _window; + event.xconfigure.window = _window; + event.xconfigure.x = x; + event.xconfigure.y = y; + event.xconfigure.width = _area.width(); + event.xconfigure.height = _area.height(); + event.xconfigure.border_width = _border_width; + event.xconfigure.above = frame->window(); + event.xconfigure.override_redirect = False; + XSendEvent(event.xconfigure.display, event.xconfigure.window, False, + StructureNotifyMask, &event); + } }