X-Git-Url: https://jasonwoof.com/gitweb/?p=dwm.git;a=blobdiff_plain;f=dev.c;h=c77ef587074f263b623d8ef719c8db16f6a2dd61;hp=aaab99a4ea765c817eff5a09b4b9655a5e621262;hb=3aad92202d58208c4197857d3f17c535ba0bd56a;hpb=c47da143bdf5b4e3924a411f42648d4b3e86ff00 diff --git a/dev.c b/dev.c index aaab99a..c77ef58 100644 --- a/dev.c +++ b/dev.c @@ -25,14 +25,20 @@ static Key key[] = { { Mod1Mask, XK_l, spawn, { .argv = xlock } }, { Mod1Mask, XK_k, prevc, { 0 } }, { Mod1Mask, XK_j, nextc, { 0 } }, - { Mod1Mask, XK_t, tiling, { 0 } }, - { Mod1Mask, XK_f, floating, { 0 } }, { Mod1Mask, XK_m, max, { 0 } }, - { Mod1Mask, XK_0, tag, { .i = Tscratch } }, - { Mod1Mask, XK_1, tag, { .i = Tdev } }, - { Mod1Mask, XK_2, tag, { .i = Tirc } }, - { Mod1Mask, XK_3, tag, { .i = Twww } }, - { Mod1Mask, XK_4, tag, { .i = Twork } }, + { Mod1Mask, XK_0, view, { .i = Tscratch } }, + { Mod1Mask, XK_1, view, { .i = Tdev } }, + { Mod1Mask, XK_2, view, { .i = Tirc } }, + { Mod1Mask, XK_3, view, { .i = Twww } }, + { Mod1Mask, XK_4, view, { .i = Twork } }, + { Mod1Mask, XK_space, tiling, { 0 } }, + { Mod1Mask | ShiftMask, XK_Return, zoom, { 0 } }, + { Mod1Mask | ShiftMask, XK_space, floating, { 0 } }, + { Mod1Mask | ShiftMask, XK_0, tag, { .i = Tscratch } }, + { Mod1Mask | ShiftMask, XK_1, tag, { .i = Tdev } }, + { Mod1Mask | ShiftMask, XK_2, tag, { .i = Tirc } }, + { Mod1Mask | ShiftMask, XK_3, tag, { .i = Twww } }, + { Mod1Mask | ShiftMask, XK_4, tag, { .i = Twork } }, { Mod1Mask | ShiftMask, XK_c, ckill, { 0 } }, { Mod1Mask | ShiftMask, XK_q, quit, { 0 } }, }; @@ -42,10 +48,10 @@ static Key key[] = { void update_keys(void) { - unsigned int i, len; + static unsigned int len = key ? sizeof(key) / sizeof(key[0]) : 0; + unsigned int i; KeyCode code; - len = sizeof(key) / sizeof(key[0]); for(i = 0; i < len; i++) { code = XKeysymToKeycode(dpy, key[i].keysym); XUngrabKey(dpy, code, key[i].mod, root); @@ -57,11 +63,11 @@ void keypress(XEvent *e) { XKeyEvent *ev = &e->xkey; - unsigned int i, len; + static unsigned int len = key ? sizeof(key) / sizeof(key[0]) : 0; + unsigned int i; KeySym keysym; keysym = XKeycodeToKeysym(dpy, (KeyCode)ev->keycode, 0); - len = sizeof(key) / sizeof(key[0]); for(i = 0; i < len; i++) if((keysym == key[i].keysym) && (key[i].mod == ev->state)) { if(key[i].func)