setup basic keybindings
Layout loosely inspired by https://github.com/xahlee/xah-fly-keys. More so the concept of rebinding based on ergonomics not using letters to remember.config
parent
38fc20ad66
commit
c558fb6989
74
config.h
74
config.h
|
|
@ -1,5 +1,7 @@
|
|||
/* See LICENSE file for copyright and license details. */
|
||||
|
||||
#include <X11/XF86keysym.h>
|
||||
|
||||
/*
|
||||
* Appearance
|
||||
*/
|
||||
|
|
@ -64,18 +66,6 @@ static const Layout layouts[] = {
|
|||
{ "[M]", monocle },
|
||||
};
|
||||
|
||||
/*
|
||||
* Key definitions
|
||||
*/
|
||||
#define MODKEY Mod1Mask
|
||||
#define TAGKEYS(KEY,TAG) \
|
||||
{ MODKEY, KEY, view, {.ui = 1 << TAG} }, \
|
||||
{ MODKEY|ControlMask, KEY, toggleview, {.ui = 1 << TAG} }, \
|
||||
{ MODKEY|ShiftMask, KEY, tag, {.ui = 1 << TAG} }, \
|
||||
{ MODKEY|ControlMask|ShiftMask, KEY, toggletag, {.ui = 1 << TAG} },
|
||||
|
||||
/* helper for spawning shell commands in the pre dwm-5.0 fashion */
|
||||
#define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } }
|
||||
/*
|
||||
* Xresources preferences to load at startup
|
||||
*/
|
||||
|
|
@ -91,48 +81,70 @@ ResourcePref resources[] = {
|
|||
};
|
||||
|
||||
/*
|
||||
* Commands
|
||||
* Key definitions
|
||||
*/
|
||||
#define MODKEY Mod1Mask
|
||||
#define TAGKEYS(KEY,TAG) \
|
||||
{ MODKEY, KEY, view, {.ui = 1 << TAG} }, \
|
||||
{ MODKEY|ControlMask, KEY, toggleview, {.ui = 1 << TAG} }, \
|
||||
{ MODKEY|ShiftMask, KEY, tag, {.ui = 1 << TAG} }, \
|
||||
{ MODKEY|ControlMask|ShiftMask, KEY, toggletag, {.ui = 1 << TAG} },
|
||||
|
||||
/* helper for spawning shell commands in the pre dwm-5.0 fashion */
|
||||
#define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } }
|
||||
|
||||
/* Commands */
|
||||
static char dmenumon[2] = "0"; /* component of dmenucmd, manipulated in spawn() */
|
||||
static const char *dmenucmd[] = { "dmenu_run", "-m", dmenumon, NULL };
|
||||
static const char *termcmd[] = { "st", NULL };
|
||||
|
||||
|
||||
static Key keys[] = {
|
||||
/* modifier key function argument */
|
||||
|
||||
/* spawn programs */
|
||||
{ MODKEY, XK_p, spawn, {.v = dmenucmd } },
|
||||
{ MODKEY|ShiftMask, XK_Return, spawn, {.v = termcmd } },
|
||||
{ MODKEY, XK_t, spawn, {.v = dmenucmd } },
|
||||
{ MODKEY, XK_a, spawn, {.v = termcmd } },
|
||||
{ MODKEY, XK_g, spawn, SHCMD("emacsclient -c") },
|
||||
{ MODKEY, XK_q, spawn, SHCMD("dmenu-sys") },
|
||||
{ MODKEY, XK_s, spawn, SHCMD("pass-dmenu type") },
|
||||
{ MODKEY|ShiftMask, XK_S, spawn, SHCMD("pass-dmenu clip") },
|
||||
|
||||
/* window manager controls */
|
||||
{ MODKEY, XK_b, togglebar, {0} },
|
||||
{ MODKEY|ShiftMask, XK_space, togglefloating, {0} },
|
||||
{ MODKEY, XK_i, incnmaster, {.i = +1 } },
|
||||
{ MODKEY, XK_d, incnmaster, {.i = -1 } },
|
||||
{ MODKEY, XK_h, setmfact, {.f = -0.05} },
|
||||
{ MODKEY, XK_l, setmfact, {.f = +0.05} },
|
||||
{ MODKEY, XK_t, setlayout, {.v = &layouts[0]} },
|
||||
{ MODKEY|ControlMask, XK_j, togglebar, {0} },
|
||||
{ MODKEY|ControlMask, XK_u, incnmaster, {.i = +1 } },
|
||||
{ MODKEY|ControlMask, XK_d, incnmaster, {.i = -1 } },
|
||||
{ MODKEY|ControlMask, XK_h, setmfact, {.f = -0.05} },
|
||||
{ MODKEY|ControlMask, XK_l, setmfact, {.f = +0.05} },
|
||||
{ MODKEY, XK_w, setlayout, {.v = &layouts[0]} },
|
||||
{ MODKEY, XK_f, setlayout, {.v = &layouts[1]} },
|
||||
{ MODKEY, XK_m, setlayout, {.v = &layouts[2]} },
|
||||
{ MODKEY, XK_p, setlayout, {.v = &layouts[2]} },
|
||||
{ MODKEY, XK_space, setlayout, {0} },
|
||||
{ MODKEY|ShiftMask, XK_q, quit, {0} },
|
||||
{ MODKEY|ControlMask|ShiftMask, XK_q, quit, {1} },
|
||||
|
||||
/* window management */
|
||||
{ MODKEY, XK_j, focusstack, {.i = +1 } },
|
||||
{ MODKEY, XK_k, focusstack, {.i = -1 } },
|
||||
{ MODKEY, XK_n, focusstack, {.i = +1 } },
|
||||
{ MODKEY, XK_e, focusstack, {.i = -1 } },
|
||||
{ MODKEY, XK_Return, zoom, {0} },
|
||||
{ MODKEY, XK_Tab, view, {0} },
|
||||
{ MODKEY, XK_0, view, {.ui = ~0 } },
|
||||
{ MODKEY|ShiftMask, XK_0, tag, {.ui = ~0 } },
|
||||
{ MODKEY|ShiftMask, XK_c, killclient, {0} },
|
||||
{ MODKEY, XK_x, togglefloating, {0} },
|
||||
{ MODKEY, XK_q, killclient, {0} },
|
||||
|
||||
/* monitor navigation */
|
||||
{ MODKEY, XK_comma, focusmon, {.i = -1 } },
|
||||
{ MODKEY, XK_period, focusmon, {.i = +1 } },
|
||||
{ MODKEY|ShiftMask, XK_comma, tagmon, {.i = -1 } },
|
||||
{ MODKEY|ShiftMask, XK_period, tagmon, {.i = +1 } },
|
||||
{ MODKEY, XK_i, focusmon, {.i = +1 } },
|
||||
{ MODKEY|ShiftMask, XK_i, tagmon, {.i = +1 } },
|
||||
|
||||
/* system managemment */
|
||||
{ 0, XF86XK_AudioMute, spawn, SHCMD("pamixer --toggle-mute") },
|
||||
{ 0, XF86XK_AudioLowerVolume, spawn, SHCMD("pamixer -i 5") },
|
||||
{ ShiftMask, XF86XK_AudioLowerVolume, spawn, SHCMD("pamixer -i 10") },
|
||||
{ 0, XF86XK_AudioRaiseVolume, spawn, SHCMD("pamixer -d 5") },
|
||||
{ ShiftMask, XF86XK_AudioRaiseVolume, spawn, SHCMD("pamixer -d 10") },
|
||||
{ 0, XF86XK_AudioPlay, spawn, SHCMD("playerctl play-pause") },
|
||||
{ 0, XF86XK_AudioNext, spawn, SHCMD("playerctl next") },
|
||||
{ 0, XF86XK_AudioPrev, spawn, SHCMD("playerctl previous") },
|
||||
|
||||
/* tags */
|
||||
TAGKEYS( XK_1, 0)
|
||||
|
|
|
|||
Loading…
Reference in New Issue