diff options
| author | Marius Nita <marius@cs.pdx.edu> | 2002-08-22 18:19:57 +0000 |
|---|---|---|
| committer | Marius Nita <marius@cs.pdx.edu> | 2002-08-22 18:19:57 +0000 |
| commit | 7cac1f19acf894aaf4470460732574abc158fd78 (patch) | |
| tree | 8c735f4a346c29073e2e5751a96016e0ad7b4e03 /util/epist/screen.cc | |
| parent | 22e8615f6125cc117af9e01124b9bcc2b19c59ab (diff) | |
toggleGrabs action added
Diffstat (limited to 'util/epist/screen.cc')
| -rw-r--r-- | util/epist/screen.cc | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/util/epist/screen.cc b/util/epist/screen.cc index 2862b870..0f8dfa56 100644 --- a/util/epist/screen.cc +++ b/util/epist/screen.cc @@ -59,6 +59,7 @@ screen::screen(epist *epist, int number) _number = number; _info = _epist->getScreenInfo(_number); _root = _info->getRootWindow(); + _grabbed = true; // find a window manager supporting NETWM, waiting for it to load if we must int count = 20; // try for 20 seconds @@ -151,8 +152,9 @@ void screen::handleKeypress(const XEvent &e) { // Mask out the lock modifiers. We want our keys to always work // This should be made an option unsigned int state = e.xkey.state & ~(LockMask|scrolllockMask|numlockMask); - const Action *it = _epist->getKeyTree().getAction(e, state, this); - + keytree &ktree = _epist->getKeyTree(); + const Action *it = ktree.getAction(e, state, this); + if (!it) return; @@ -252,6 +254,17 @@ void screen::handleKeypress(const XEvent &e) { None); return; + case Action::toggleGrabs: { + if (_grabbed) { + ktree.ungrabDefaults(this); + _grabbed = false; + } else { + ktree.grabDefaults(this); + _grabbed = true; + } + return; + } + default: break; } |
