X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;f=src%2Fscreen.cc;h=01abd83c0c341a7f7deadf026bd7db5cda8d7d4b;hb=9860b76c50e5ecacc85921539058eab4c655c38d;hp=e3217cca3e64a8f6cc64401ec97528b84749ab2f;hpb=0da967a8313bad4a9dbcca9b5c760bda32b7981f;p=chaz%2Fopenbox diff --git a/src/screen.cc b/src/screen.cc index e3217cca..01abd83c 100644 --- a/src/screen.cc +++ b/src/screen.cc @@ -37,7 +37,8 @@ namespace ob { OBScreen::OBScreen(int screen, const otk::Configuration &config) - : _number(screen) + : _number(screen), + _root(screen) { assert(screen >= 0); assert(screen < ScreenCount(otk::OBDisplay::display)); _info = otk::OBDisplay::screenInfo(screen); @@ -349,6 +350,8 @@ void OBScreen::manageWindow(Window window) // create the OBClient class, which gets all of the hints on the window Openbox::instance->addClient(window, client = new OBClient(_number, window)); + // register for events + Openbox::instance->registerHandler(window, client); // we dont want a border on the client XSetWindowBorderWidth(otk::OBDisplay::display, window, 0); @@ -365,25 +368,12 @@ void OBScreen::manageWindow(Window window) client->frame = new OBFrame(client, &_style); // XXX: if on the current desktop.. - XMapWindow(otk::OBDisplay::display, client->frame->window()); + client->frame->show(); // XXX: handle any requested states such as shaded/maximized otk::OBDisplay::ungrab(); - // add all the client's windows as event handlers for the client - Openbox::instance->addClient(window, client); - Openbox::instance->addClient(client->frame->window(), client); - Openbox::instance->addClient(client->frame->titlebar(), client); - Openbox::instance->addClient(client->frame->buttonIconify(), client); - Openbox::instance->addClient(client->frame->buttonMax(), client); - Openbox::instance->addClient(client->frame->buttonStick(), client); - Openbox::instance->addClient(client->frame->buttonClose(), client); - Openbox::instance->addClient(client->frame->label(), client); - Openbox::instance->addClient(client->frame->handle(), client); - Openbox::instance->addClient(client->frame->gripLeft(), client); - Openbox::instance->addClient(client->frame->gripRight(), client); - // add to the screen's list _clients.push_back(client); // update the root properties @@ -396,6 +386,9 @@ void OBScreen::unmanageWindow(OBClient *client) OBFrame *frame = client->frame; // XXX: pass around focus if this window was focused + + // unregister for handling events + Openbox::instance->clearHandler(client->window()); // remove the window from our save set XChangeSaveSet(otk::OBDisplay::display, client->window(), SetModeDelete); @@ -403,26 +396,12 @@ void OBScreen::unmanageWindow(OBClient *client) // we dont want events no more XSelectInput(otk::OBDisplay::display, client->window(), NoEventMask); - XUnmapWindow(otk::OBDisplay::display, frame->window()); + frame->hide(); // we dont want a border on the client XSetWindowBorderWidth(otk::OBDisplay::display, client->window(), client->borderWidth()); - // remove the client class from the search list - Openbox::instance->removeClient(client->window()); - // remove the frame's decor elements as event handlers for the client - Openbox::instance->removeClient(frame->window()); - Openbox::instance->removeClient(frame->titlebar()); - Openbox::instance->removeClient(frame->buttonIconify()); - Openbox::instance->removeClient(frame->buttonMax()); - Openbox::instance->removeClient(frame->buttonStick()); - Openbox::instance->removeClient(frame->buttonClose()); - Openbox::instance->removeClient(frame->label()); - Openbox::instance->removeClient(frame->handle()); - Openbox::instance->removeClient(frame->gripLeft()); - Openbox::instance->removeClient(frame->gripRight()); - delete client->frame; client->frame = 0;