X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=util%2Fepist%2Fscreen.cc;h=ee19abb1cd1548d0ed209e0ccff99900b9cf78cc;hb=fc792813a24d22330b49eda8b3ef7054eadf20d3;hp=1ccf9833d0be96b75d3bb7b01718e6d32ca88489;hpb=6595476d81f01cee9001bbc90dda5b37915e5821;p=chaz%2Fopenbox diff --git a/util/epist/screen.cc b/util/epist/screen.cc index 1ccf9833..ee19abb1 100644 --- a/util/epist/screen.cc +++ b/util/epist/screen.cc @@ -120,12 +120,6 @@ void screen::processEvent(const XEvent &e) { assert(_managed); assert(e.xany.window == _root); - XWindow *window = 0; - if (e.xany.window != _root) { - window = findWindow(e); // find the window - assert(window); // we caught an event for a window we don't know about!? - } - switch (e.type) { case PropertyNotify: // root window @@ -155,11 +149,18 @@ void screen::processEvent(const XEvent &e) { } void screen::handleKeypress(const XEvent &e) { + int scrolllockMask, numlockMask; + ActionList::const_iterator it = _epist->actions().begin(); ActionList::const_iterator end = _epist->actions().end(); + + _epist->getLockModifiers(numlockMask, scrolllockMask); + for (; it != end; ++it) { + unsigned int state = e.xkey.state & ~(LockMask|scrolllockMask|numlockMask); + if (e.xkey.keycode == it->keycode() && - e.xkey.state == it->modifierMask()) { + state == it->modifierMask()) { switch (it->type()) { case Action::nextWorkspace: cycleWorkspace(true); @@ -360,7 +361,7 @@ void screen::updateClientList() { break; if (it == end) { // didn't already exist if (doAddWindow(rootclients[i])) { - cout << "Added window: 0x" << hex << rootclients[i] << dec << endl; + //cout << "Added window: 0x" << hex << rootclients[i] << dec << endl; _clients.insert(insert_point, new XWindow(_epist, this, rootclients[i])); } @@ -374,7 +375,7 @@ void screen::updateClientList() { if (**it2 == rootclients[i]) break; if (i == num) { // no longer exists - cout << "Removed window: 0x" << hex << (*it2)->window() << dec << endl; + //cout << "Removed window: 0x" << hex << (*it2)->window() << dec << endl; delete *it2; _clients.erase(it2); } @@ -397,9 +398,9 @@ void screen::updateActiveWindow() { } _active = it; - cout << "Active window is now: "; - if (_active == _clients.end()) cout << "None\n"; - else cout << "0x" << hex << (*_active)->window() << dec << endl; + //cout << "Active window is now: "; + //if (_active == _clients.end()) cout << "None\n"; + //else cout << "0x" << hex << (*_active)->window() << dec << endl; } @@ -491,3 +492,37 @@ void screen::changeWorkspace(const int num) const { _xatom->sendClientMessage(_root, XAtom::net_current_desktop, _root, num); } + +void screen::grabKey(const KeyCode keyCode, const int modifierMask) const { + + Display *display = _epist->getXDisplay(); + int numlockMask, scrolllockMask; + + _epist->getLockModifiers(numlockMask, scrolllockMask); + + XGrabKey(display, keyCode, modifierMask, + _root, True, GrabModeAsync, GrabModeAsync); + XGrabKey(display, keyCode, + modifierMask|LockMask, + _root, True, GrabModeAsync, GrabModeAsync); + XGrabKey(display, keyCode, + modifierMask|scrolllockMask, + _root, True, GrabModeAsync, GrabModeAsync); + XGrabKey(display, keyCode, + modifierMask|numlockMask, + _root, True, GrabModeAsync, GrabModeAsync); + + XGrabKey(display, keyCode, + modifierMask|LockMask|scrolllockMask, + _root, True, GrabModeAsync, GrabModeAsync); + XGrabKey(display, keyCode, + modifierMask|scrolllockMask|numlockMask, + _root, True, GrabModeAsync, GrabModeAsync); + XGrabKey(display, keyCode, + modifierMask|numlockMask|LockMask, + _root, True, GrabModeAsync, GrabModeAsync); + + XGrabKey(display, keyCode, + modifierMask|numlockMask|LockMask|scrolllockMask, + _root, True, GrabModeAsync, GrabModeAsync); +}