summaryrefslogtreecommitdiff
path: root/src/screen.cc
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2002-12-01 11:45:55 +0000
committerDana Jansens <danakj@orodu.net>2002-12-01 11:45:55 +0000
commitfb3848450e649a05c0bed84a02bc9ab4e563b5d9 (patch)
tree97db6c6ba662c354c46c46f440364bb9e43d076e /src/screen.cc
parentfac1a6581b65b91eba3024d813a393e04007e197 (diff)
window decorations use "unmanaged" widgets now.
Diffstat (limited to 'src/screen.cc')
-rw-r--r--src/screen.cc31
1 files changed, 2 insertions, 29 deletions
diff --git a/src/screen.cc b/src/screen.cc
index e3217cca..4457096b 100644
--- a/src/screen.cc
+++ b/src/screen.cc
@@ -365,25 +365,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
@@ -403,26 +390,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;