summaryrefslogtreecommitdiff
path: root/src/openbox.cc
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2002-12-02 23:03:41 +0000
committerDana Jansens <danakj@orodu.net>2002-12-02 23:03:41 +0000
commita77f0fb344978bb4dafd2ad4639f3de3e090bf7b (patch)
tree0ef049d0310e504bde3cd97b441198c5f92ceec2 /src/openbox.cc
parent958df7716291a1af680bf9d5432aa99f0b7cf644 (diff)
handle map requests with the root window class
Diffstat (limited to 'src/openbox.cc')
-rw-r--r--src/openbox.cc56
1 files changed, 0 insertions, 56 deletions
diff --git a/src/openbox.cc b/src/openbox.cc
index d2213ec4..80622c1c 100644
--- a/src/openbox.cc
+++ b/src/openbox.cc
@@ -121,9 +121,6 @@ Openbox::Openbox(int argc, char **argv)
_property = new otk::OBProperty();
- // set this class as the fallback event handler (for map events)
- setFallbackHandler(this);
-
// create the mouse cursors we'll use
_cursors.session = XCreateFontCursor(otk::OBDisplay::display, XC_left_ptr);
_cursors.move = XCreateFontCursor(otk::OBDisplay::display, XC_fleur);
@@ -284,58 +281,5 @@ OBClient *Openbox::findClient(Window window)
}
-void Openbox::mapRequestHandler(const XMapRequestEvent &e)
-{
-#ifdef DEBUG
- printf("MapRequest for 0x%lx\n", e.window);
-#endif // DEBUG
-
- otk::OtkEventHandler::mapRequestHandler(e);
-
- OBClient *client = findClient(e.window);
-
- if (client) {
- // XXX: uniconify and/or unshade the window
- } else {
- int screen = INT_MAX;
-
- for (int i = 0; i < ScreenCount(otk::OBDisplay::display); ++i)
- if (otk::OBDisplay::screenInfo(i)->getRootWindow() == e.parent) {
- screen = i;
- break;
- }
-
- if (screen >= ScreenCount(otk::OBDisplay::display)) {
- /*
- we got a map request for a window who's parent isn't root. this
- can happen in only one circumstance:
-
- a client window unmapped a managed window, and then remapped it
- somewhere between unmapping the client window and reparenting it
- to root.
-
- regardless of how it happens, we need to find the screen that
- the window is on
- */
- XWindowAttributes wattrib;
- if (! XGetWindowAttributes(otk::OBDisplay::display, e.window,
- &wattrib)) {
- // failed to get the window attributes, perhaps the window has
- // now been destroyed?
- return;
- }
-
- for (int i = 0; i < ScreenCount(otk::OBDisplay::display); ++i)
- if (otk::OBDisplay::screenInfo(i)->getRootWindow() == wattrib.root) {
- screen = i;
- break;
- }
- }
-
- assert(screen < static_cast<int>(_screens.size()));
- _screens[screen]->manageWindow(e.window);
- }
-}
-
}