/* See LICENSE file for copyright and license details. */ /* appearance */ static const unsigned int borderpx = 0; /* border pixel of windows */ static const unsigned int gappx = 5; /* gaps between windows */ static const unsigned int snap = 32; /* snap pixel */ static const int showbar = 1; /* 0 means no bar */ static const int topbar = 1; /* 0 means bottom bar */ static const int user_bh = 0; /* 0 means that dwm will calculate bar height, >= 1 means dwm will user_bh as bar height */ static const char *fonts[] = { "monospace:size=22" }; static const char norm_fg[] = "#447a6c"; static const char norm_bg[] = "#1b1d1b"; static const char sel_fg[] = "#1b1d1b"; static const char sel_bg[] = "#7d4b23"; static const char norm_border[] = "#c0ffee"; static const char sel_border[] = "#bada55"; static const unsigned int baralpha = 0xd0; static const unsigned int borderalpha = OPAQUE; static const char *colors[][3] = { /* fg bg border */ [SchemeNorm] = { norm_fg, norm_bg, norm_border }, [SchemeSel] = { sel_fg, sel_bg, sel_border }, }; static const unsigned int alphas[][3] = { /* fg bg border */ [SchemeNorm] = { OPAQUE, baralpha, borderalpha }, [SchemeSel] = { OPAQUE, baralpha, borderalpha }, }; /* tagging */ static const char *tags[] = { "1", "2", "3", "4", "5", "6", "7", "8", "9" }; static const Rule rules[] = { /* xprop(1): * WM_CLASS(STRING) = instance, class * WM_NAME(STRING) = title */ /* class instance title tags mask isfloating monitor */ { "Gimp", NULL, NULL, 0, 1, -1 }, { "dropdown", NULL, NULL, 0, 1, -1 }, /* { "Firefox", NULL, NULL, 1 << 8, 0, -1 }, */ }; /* layout(s) */ static const float mfact = 0.55; /* factor of master area size [0.05..0.95] */ static const int nmaster = 1; /* number of clients in master area */ static const int resizehints = 1; /* 1 means respect size hints in tiled resizals */ static const int lockfullscreen = 1; /* 1 will force focus on the fullscreen window */ static const int mainmon = 0; /* xsetroot will only change the bar on this monitor */ static const int lpm[] = { /* Index of preferred layout], if LENGTH(lpm)<#monitors -> default layout */ 0, 4 }; static const Layout layouts[] = { /* symbol arrange function */ { " []= ", tile }, /* first entry is default */ { " ", NULL }, /* no layout function means floating behavior */ { " ", monocle }, { " |H| ", bstack }, { " |v| ", bstackhoriz }, { " |_| ", centeredmaster }, { " |=| ", centeredfloatingmaster }, { " [+] ", gaplessgrid }, }; /* key definitions */ #define MODKEY Mod4Mask #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 } } #define STATUSBAR "dwmblocks" static Key keys[] = { /* modifier key function argument */ { MODKEY|ShiftMask, XK_q, quit, {0} }, }; /* button definitions */ /* click can be ClkTagBar, ClkLtSymbol, ClkStatusText, ClkWinTitle, ClkClientWin, or ClkRootWin */ static Button buttons[] = { /* click event mask button function argument */ { ClkLtSymbol, 0, Button1, setlayout, {0} }, { ClkLtSymbol, 0, Button3, setlayout, {.v = &layouts[2]} }, { ClkWinTitle, 0, Button2, zoom, {0} }, { ClkStatusText, 0, Button1, sigstatusbar, {.i = 1} }, { ClkStatusText, 0, Button2, sigstatusbar, {.i = 2} }, { ClkStatusText, 0, Button3, sigstatusbar, {.i = 3} }, { ClkClientWin, MODKEY, Button1, movemouse, {0} }, { ClkClientWin, MODKEY, Button2, togglefloating, {0} }, { ClkClientWin, MODKEY, Button3, resizemouse, {0} }, { ClkTagBar, 0, Button1, view, {0} }, { ClkTagBar, 0, Button3, toggleview, {0} }, { ClkTagBar, MODKEY, Button1, tag, {0} }, { ClkTagBar, MODKEY, Button3, toggletag, {0} }, }; void setlayoutex(const Arg *arg) { setlayout(&((Arg) { .v = &layouts[arg->i] })); } void viewex(const Arg *arg) { view(&((Arg) { .ui = 1 << arg->ui })); } void viewall(const Arg *arg) { view(&((Arg){.ui = ~0})); } void toggleviewex(const Arg *arg) { toggleview(&((Arg) { .ui = 1 << arg->ui })); } void tagex(const Arg *arg) { tag(&((Arg) { .ui = 1 << arg->ui })); } void toggletagex(const Arg *arg) { toggletag(&((Arg) { .ui = 1 << arg->ui })); } void tagall(const Arg *arg) { tag(&((Arg){.ui = ~0})); } /* signal definitions */ /* signum must be greater than 0 */ /* trigger signals using `xsetroot -name "fsignal: [ ]"` */ static Signal signals[] = { /* signum function */ { "focusmaster", focusmaster }, { "focusmon", focusmon }, { "focusstack", focusstack }, { "fullscreen", fullscreen }, { "incnmaster", incnmaster }, { "killclient", killclient }, { "movestack", movestack }, { "rotatestack", rotatestack }, { "setlayout", setlayout }, { "setlayoutex", setlayoutex }, { "setgaps", setgaps }, { "setmfact", setmfact }, { "quit", quit }, { "tag", tag }, { "tagall", tagall }, { "tagex", tagex }, { "tagmon", tagmon }, { "togglebar", togglebar }, { "togglefloating", togglefloating }, { "toggletag", tag }, { "toggletagex", toggletagex }, { "toggleview", view }, { "toggleviewex", toggleviewex }, { "view", view }, { "viewall", viewall }, { "viewex", viewex }, { "zoom", zoom }, };