summaryrefslogtreecommitdiff
path: root/openbox
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2003-03-19 18:55:10 +0000
committerDana Jansens <danakj@orodu.net>2003-03-19 18:55:10 +0000
commitfd9dc6f9d5762d9829d9e56b434965512b6b5ac6 (patch)
tree19ba555aca86b7b75ba9875bc4f3f4099eaece3d /openbox
parent32a17b31b0e3ec9302de7d8dbc3994d47a6a842c (diff)
grab all lock keys
Diffstat (limited to 'openbox')
-rw-r--r--openbox/grab.c51
1 files changed, 51 insertions, 0 deletions
diff --git a/openbox/grab.c b/openbox/grab.c
index 63127117..719d3301 100644
--- a/openbox/grab.c
+++ b/openbox/grab.c
@@ -1,9 +1,16 @@
#include "openbox.h"
+#include "event.h"
+
#include <glib.h>
#include <X11/Xlib.h>
static guint kgrabs, pgrabs, sgrabs;
+#define MASK_LIST_SIZE 8
+
+/*! A list of all possible combinations of keyboard lock masks */
+static unsigned int mask_list[MASK_LIST_SIZE];
+
void grab_keyboard(gboolean grab)
{
if (grab) {
@@ -45,7 +52,19 @@ void grab_server(gboolean grab)
void grab_startup()
{
+ guint i = 0;
+
kgrabs = pgrabs = sgrabs = 0;
+
+ mask_list[i++] = 0;
+ mask_list[i++] = LockMask;
+ mask_list[i++] = NumLockMask;
+ mask_list[i++] = LockMask | NumLockMask;
+ mask_list[i++] = ScrollLockMask;
+ mask_list[i++] = ScrollLockMask | LockMask;
+ mask_list[i++] = ScrollLockMask | NumLockMask;
+ mask_list[i++] = ScrollLockMask | LockMask | NumLockMask;
+ g_assert(i == MASK_LIST_SIZE);
}
void grab_shutdown()
@@ -54,3 +73,35 @@ void grab_shutdown()
while (pgrabs) grab_pointer(FALSE, None);
while (sgrabs) grab_server(FALSE);
}
+
+void grab_button(guint button, guint state, Window win, guint mask,
+ int pointer_mode)
+{
+ guint i;
+
+ for (i = 0; i < MASK_LIST_SIZE; ++i)
+ XGrabButton(ob_display, button, state | mask_list[i], win, FALSE, mask,
+ pointer_mode, GrabModeAsync, None, None);
+}
+
+void ungrab_button(guint button, guint state, Window win)
+{
+ guint i;
+
+ for (i = 0; i < MASK_LIST_SIZE; ++i)
+ XUngrabButton(ob_display, button, state | mask_list[i], win);
+}
+
+void grab_key(guint keycode, guint state, int keyboard_mode)
+{
+ guint i;
+
+ for (i = 0; i < MASK_LIST_SIZE; ++i)
+ XGrabKey(ob_display, keycode, state | mask_list[i], ob_root, FALSE,
+ GrabModeAsync, keyboard_mode);
+}
+
+void ungrab_all_keys()
+{
+ XUngrabKey(ob_display, AnyKey, AnyModifier, ob_root);
+}