diff --git a/config.h b/config.h new file mode 100644 index 0000000..c68afe0 --- /dev/null +++ b/config.h @@ -0,0 +1,132 @@ +/* See LICENSE file for copyright and license details. */ + +/* appearance */ +static const unsigned int borderpx = 2; /* border pixel of 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 char *fonts[] = {"JetBrainsMono Nerd Font:size=13"}; +static const char dmenufont[] = "JetBrainsMono Nerd Font:size=13"; +// background color +static const char col_gray1[] = "#222222"; +// inactive window color +static const char col_gray2[] = "#444444"; +// font color +static const char col_gray3[] = "#bbbbbb"; +// current tag and window font color +static const char col_gray4[] = "#eeeeee"; +// top bar second color and active window border +static const char col_cyan[] = "#5c24b5"; +static const char *colors[][3] = { + /* fg bg border */ + [SchemeNorm] = {col_gray3, col_gray1, col_gray2}, + [SchemeSel] = {col_gray4, col_cyan, col_cyan}, +}; + +/* tagging */ +static const char *tags[] = {"", "", "󰙯", "󰎆", ""}; + +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}, + {"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 Layout layouts[] = { + /* symbol arrange function */ + {"[]=", tile}, /* first entry is default */ + {"><>", NULL}, /* no layout function means floating behavior */ + {"[M]", monocle}, +}; + +/* 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 } \ + } + +/* commands */ +static char dmenumon[2] = + "0"; /* component of dmenucmd, manipulated in spawn() */ +static const char *dmenucmd[] = { + "dmenu_run", "-m", dmenumon, "-fn", dmenufont, "-nb", col_gray1, + "-nf", col_gray3, "-sb", col_cyan, "-sf", col_gray4, NULL}; +static const char *termcmd[] = {"alacritty", NULL}; +static const char *browsercmd[] = {"firefox", NULL}; +static const char *filemanagercmd[] = {"thunar", NULL}; +static const char *screenshotcmd[] = {"xfce4-screenshooter", "-r -s ~/Pictures", NULL}; + +#include "shiftview.c" +static Key keys[] = { + /* modifier key function argument */ + {MODKEY, XK_p, spawn, {.v = dmenucmd}}, + {MODKEY, XK_t, spawn, {.v = termcmd}}, + {MODKEY, XK_w, spawn, {.v = browsercmd}}, + {MODKEY, XK_f, spawn, {.v = filemanagercmd}}, + {MODKEY, XK_s, spawn, {.v = screenshotcmd}}, + {MODKEY, XK_b, togglebar, {0}}, + {MODKEY, XK_j, focusstack, {.i = +1}}, + {MODKEY, XK_k, focusstack, {.i = -1}}, + {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_Return, zoom, {0}}, + {MODKEY, XK_twosuperior, view, {0}}, + {MODKEY, XK_q, killclient, {0}}, + {MODKEY | ShiftMask, XK_t, setlayout, {.v = &layouts[0]}}, + {MODKEY | ShiftMask, XK_f, setlayout, {.v = &layouts[1]}}, + {MODKEY | ShiftMask, XK_m, setlayout, {.v = &layouts[2]}}, + {MODKEY | ShiftMask, XK_h, setlayout, {.v = &layouts[3]}}, + {MODKEY, XK_space, setlayout, {0}}, + {MODKEY | ShiftMask, XK_space, togglefloating, {0}}, + {MODKEY, XK_0, view, {.ui = ~0}}, + {MODKEY | ShiftMask, XK_0, tag, {.ui = ~0}}, + {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_Tab, shiftview, {.i = +1}}, + {MODKEY, XK_Control_L, shiftview, {.i = -1}}, + TAGKEYS(XK_ampersand, 0) TAGKEYS(XK_eacute, 1) TAGKEYS(XK_quotedbl, 2) + TAGKEYS(XK_apostrophe, 3) TAGKEYS(XK_parenleft, 4) + TAGKEYS(XK_section, 5) TAGKEYS(XK_egrave, 6) TAGKEYS(XK_exclam, 7) + TAGKEYS(XK_ccedilla, 8){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, Button2, spawn, {.v = termcmd}}, + {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}}, +}; diff --git a/shiftview.c b/shiftview.c new file mode 100644 index 0000000..e82053a --- /dev/null +++ b/shiftview.c @@ -0,0 +1,19 @@ +/** Function to shift the current view to the left/right + * + * @param: "arg->i" stores the number of tags to shift right (positive value) + * or left (negative value) + */ +void +shiftview(const Arg *arg) { + Arg shifted; + + if(arg->i > 0) // left circular shift + shifted.ui = (selmon->tagset[selmon->seltags] << arg->i) + | (selmon->tagset[selmon->seltags] >> (LENGTH(tags) - arg->i)); + + else // right circular shift + shifted.ui = selmon->tagset[selmon->seltags] >> (- arg->i) + | selmon->tagset[selmon->seltags] << (LENGTH(tags) + arg->i); + + view(&shifted); +}