summaryrefslogtreecommitdiff
path: root/util/epist/screen.cc
diff options
context:
space:
mode:
authorMarius Nita <marius@cs.pdx.edu>2002-08-22 18:19:57 +0000
committerMarius Nita <marius@cs.pdx.edu>2002-08-22 18:19:57 +0000
commit7cac1f19acf894aaf4470460732574abc158fd78 (patch)
tree8c735f4a346c29073e2e5751a96016e0ad7b4e03 /util/epist/screen.cc
parent22e8615f6125cc117af9e01124b9bcc2b19c59ab (diff)
toggleGrabs action added
Diffstat (limited to 'util/epist/screen.cc')
-rw-r--r--util/epist/screen.cc17
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;
}