summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2002-11-10 08:42:34 +0000
committerDana Jansens <danakj@orodu.net>2002-11-10 08:42:34 +0000
commit6e2593cadc9a755d0e08facb7df0459a786e692b (patch)
treea9e837b78d12fcecdf373d73efa68f542a04f244
parent0b17bd83c7d09ee364913f5e5f6b214f996b3a83 (diff)
handle events on all of the client's decor as for the client
-rw-r--r--src/frame.hh10
-rw-r--r--src/xeventhandler.cc20
2 files changed, 30 insertions, 0 deletions
diff --git a/src/frame.hh b/src/frame.hh
index 7814ed35..5e7ba927 100644
--- a/src/frame.hh
+++ b/src/frame.hh
@@ -104,6 +104,16 @@ public:
//! Returns the frame's most-parent window, which is a child of the root
//! window
inline Window window() const { return _window; }
+
+ inline Window titlebar() const { return _titlebar; }
+ inline Window label() const { return _label; }
+ inline Window buttonIconify() const { return _button_iconify; }
+ inline Window buttonMax() const { return _button_max; }
+ inline Window buttonStick() const { return _button_stick; }
+ inline Window buttonClose() const { return _button_close; }
+ inline Window handle() const { return _handle; }
+ inline Window gripLeft() const { return _grip_left; }
+ inline Window gripRight() const { return _grip_right; }
};
}
diff --git a/src/xeventhandler.cc b/src/xeventhandler.cc
index 6cdc87a5..3225fb46 100644
--- a/src/xeventhandler.cc
+++ b/src/xeventhandler.cc
@@ -156,6 +156,16 @@ void OBXEventHandler::manageWindow(int screen, Window window)
// create the OBClient class, which gets all of the hints on the window
Openbox::instance->addClient(window, client = new OBClient(screen, window));
+ // add all the client's decoration windows as event handlers for the 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);
// we dont want a border on the client
XSetWindowBorderWidth(otk::OBDisplay::display, window, 0);
@@ -201,6 +211,16 @@ void OBXEventHandler::unmanageWindow(OBClient *client)
// 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->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;