From 7cac1f19acf894aaf4470460732574abc158fd78 Mon Sep 17 00:00:00 2001 From: Marius Nita Date: Thu, 22 Aug 2002 18:19:57 +0000 Subject: toggleGrabs action added --- util/epist/screen.cc | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) (limited to 'util/epist/screen.cc') 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; } -- cgit v1.2.3