aboutsummaryrefslogtreecommitdiffstats
path: root/main.c
diff options
context:
space:
mode:
authorBert Münnich <ber.t@posteo.de>2014-01-02 13:36:00 +0100
committerBert Münnich <ber.t@posteo.de>2014-01-02 14:13:08 +0100
commitb2eae528ed54c3ee1509e410686fabc1c7ecc0b4 (patch)
treebd00ae76f4cbe12d5c4e9aaac7a65f432b9d6312 /main.c
parentab28c9a8b9240d032fa84d50b1858cf553b134d7 (diff)
downloadnsxiv-b2eae528ed54c3ee1509e410686fabc1c7ecc0b4.tar.zst
Proper support for Ctrl/Shift/Alt modifiers in key & mouse mappings
Diffstat (limited to 'main.c')
-rw-r--r--main.c30
1 files changed, 15 insertions, 15 deletions
diff --git a/main.c b/main.c
index 6fbed6d..f89a064 100644
--- a/main.c
+++ b/main.c
@@ -418,30 +418,28 @@ void clear_resize(void)
resized = false;
}
-bool keymask(const keymap_t *k, unsigned int state)
-{
- return (k->ctrl ? ControlMask : 0) == (state & ControlMask);
-}
-
-bool buttonmask(const button_t *b, unsigned int state)
-{
- return ((b->ctrl ? ControlMask : 0) | (b->shift ? ShiftMask : 0)) ==
- (state & (ControlMask | ShiftMask));
-}
+#define MODMASK(mask) ((mask) & (ShiftMask|ControlMask|Mod1Mask))
void on_keypress(XKeyEvent *kev)
{
int i;
- KeySym ksym;
+ unsigned int sh;
+ KeySym ksym, shksym;
char key;
if (kev == NULL)
return;
+ if (kev->state & ShiftMask) {
+ kev->state &= ~ShiftMask;
+ XLookupString(kev, &key, 1, &shksym, NULL);
+ kev->state |= ShiftMask;
+ }
XLookupString(kev, &key, 1, &ksym, NULL);
+ sh = (kev->state & ShiftMask) && ksym != shksym ? ShiftMask : 0;
- if ((ksym == XK_Escape || (key >= '0' && key <= '9')) &&
- (kev->state & ControlMask) == 0)
+ if ((ksym == XK_Escape && MODMASK(kev->state) == 0) ||
+ (key >= '0' && key <= '9'))
{
/* number prefix for commands */
prefix = ksym == XK_Escape ? 0 : prefix * 10 + (int) (key - '0');
@@ -449,7 +447,9 @@ void on_keypress(XKeyEvent *kev)
}
for (i = 0; i < ARRLEN(keys); i++) {
- if (keys[i].ksym == ksym && keymask(&keys[i], kev->state)) {
+ if (keys[i].ksym == ksym &&
+ MODMASK(keys[i].mask | sh) == MODMASK(kev->state))
+ {
if (keys[i].cmd != NULL && keys[i].cmd(keys[i].arg))
redraw();
prefix = 0;
@@ -471,7 +471,7 @@ void on_buttonpress(XButtonEvent *bev)
for (i = 0; i < ARRLEN(buttons); i++) {
if (buttons[i].button == bev->button &&
- buttonmask(&buttons[i], bev->state))
+ MODMASK(buttons[i].mask) == MODMASK(bev->state))
{
if (buttons[i].cmd != NULL && buttons[i].cmd(buttons[i].arg))
redraw();