all repos — openbox @ 6e2593cadc9a755d0e08facb7df0459a786e692b

openbox fork - make it a bit more like ryudo

handle events on all of the client's decor as for the client
Dana Jansens danakj@orodu.net
commit

6e2593cadc9a755d0e08facb7df0459a786e692b

parent

0b17bd83c7d09ee364913f5e5f6b214f996b3a83

2 files changed, 30 insertions(+), 0 deletions(-)

jump to
M src/frame.hhsrc/frame.hh

@@ -104,6 +104,16 @@

//! 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; } }; }
M src/xeventhandler.ccsrc/xeventhandler.cc

@@ -156,6 +156,16 @@ CWEventMask|CWDontPropagate, &attrib_set);

// 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 @@ 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->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;