X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Fopenbox.cc;h=50146e270dad245e0a025535aab917cba032c75c;hb=1da8531a7b4eea22592b6d0760352d2a34e9b6b0;hp=727b403ebbe8c543bf55ef36f1c0b8b9c171e6f3;hpb=05a8e51f177b1d0215bcd8c4b6f7b65e7ba7d3ed;p=chaz%2Fopenbox diff --git a/src/openbox.cc b/src/openbox.cc index 727b403e..50146e27 100644 --- a/src/openbox.cc +++ b/src/openbox.cc @@ -360,13 +360,27 @@ Client *Openbox::findClient(Window window) void Openbox::setFocusedClient(Client *c) { + if (c == _focused_client) return; + assert(_focused_screen); + + // uninstall the old colormap + if (_focused_client) + _focused_client->installColormap(false); + else + _focused_screen->installColormap(false); + _focused_client = c; if (c) { _focused_screen = _screens[c->screen()]; + + // install the client's colormap + c->installColormap(true); } else { - assert(_focused_screen); XSetInputFocus(**otk::display, _focused_screen->focuswindow(), RevertToNone, CurrentTime); + + // install the root window colormap + _focused_screen->installColormap(true); } // set the NET_ACTIVE_WINDOW hint for all screens ScreenList::iterator it, end = _screens.end();