kekl
@ -11,9 +11,7 @@ in
|
||||
imports = [
|
||||
(import "${home-manager}/nixos")
|
||||
./hardware-configuration.nix
|
||||
./modules/nix/firefox.nix
|
||||
./modules/nix/gaming.nix
|
||||
./modules/nix/X/dwm/default.nix
|
||||
./modules/system/nix/default.nix
|
||||
];
|
||||
|
||||
nixpkgs.config.allowUnfree = true;
|
||||
@ -257,10 +255,10 @@ in
|
||||
|
||||
environment.etc = {
|
||||
"makepkg.conf".source = "${pkgs.pacman}/etc/makepkg.conf";
|
||||
"pacman.conf".source = ./modules/raw/pacman.conf;
|
||||
"pacman.conf".source = ./modules/system/raw/pacman.conf;
|
||||
};
|
||||
|
||||
system.stateVersion = "unstable";
|
||||
home-manager.users.fabian = ./modules/home.nix;
|
||||
home-manager.users.fabian = ./modules/home/home.nix;
|
||||
|
||||
}
|
||||
|
@ -20,7 +20,7 @@
|
||||
colors = {
|
||||
primary = {
|
||||
foreground = "#FFFFFF";
|
||||
background = "#161616";
|
||||
background = "#121212";
|
||||
};
|
||||
};
|
||||
};
|
@ -28,6 +28,8 @@
|
||||
"checkjobs"
|
||||
];
|
||||
initExtra = ''
|
||||
PS1 = "(\u) %"
|
||||
|
||||
eval "$(fzf --bash)"
|
||||
complete -cf doas
|
||||
'';
|
@ -2,6 +2,7 @@
|
||||
{
|
||||
imports = [
|
||||
./nvim/default.nix
|
||||
./alacritty.nix
|
||||
./bash.nix
|
||||
./git.nix
|
||||
./tmux.nix
|
@ -21,6 +21,7 @@ in
|
||||
./dev.nix
|
||||
./nonels.nix
|
||||
./treesitter.nix
|
||||
./lualine.nix
|
||||
];
|
||||
programs.nixvim = {
|
||||
enable = true;
|
Before Width: | Height: | Size: 12 MiB After Width: | Height: | Size: 12 MiB |
Before Width: | Height: | Size: 2.3 MiB After Width: | Height: | Size: 2.3 MiB |
Before Width: | Height: | Size: 1.0 MiB After Width: | Height: | Size: 1.0 MiB |
Before Width: | Height: | Size: 181 KiB After Width: | Height: | Size: 181 KiB |
Before Width: | Height: | Size: 754 KiB After Width: | Height: | Size: 754 KiB |
Before Width: | Height: | Size: 1.8 MiB After Width: | Height: | Size: 1.8 MiB |
Before Width: | Height: | Size: 1.2 MiB After Width: | Height: | Size: 1.2 MiB |
Before Width: | Height: | Size: 964 KiB After Width: | Height: | Size: 964 KiB |
Before Width: | Height: | Size: 6.2 MiB After Width: | Height: | Size: 6.2 MiB |
Before Width: | Height: | Size: 759 KiB After Width: | Height: | Size: 759 KiB |
Before Width: | Height: | Size: 486 KiB After Width: | Height: | Size: 486 KiB |
@ -1,323 +0,0 @@
|
||||
static char *font = "Terminus:pixelsize=18:antialias=true:autohint=true";
|
||||
static int borderpx = 2;
|
||||
|
||||
static char *shell = "/usr/local/bin/bash";
|
||||
char *utmp = NULL;
|
||||
char *scroll = NULL;
|
||||
char *stty_args = "stty raw pass8 nl -echo -iexten -cstopb 38400";
|
||||
char *vtiden = "\033[?6c";
|
||||
|
||||
static float cwscale = 1.0;
|
||||
static float chscale = 1.0;
|
||||
wchar_t *worddelimiters = L" ";
|
||||
static unsigned int doubleclicktimeout = 300;
|
||||
static unsigned int tripleclicktimeout = 600;
|
||||
int allowaltscreen = 1;
|
||||
int allowwindowops = 0;
|
||||
static double minlatency = 2;
|
||||
static double maxlatency = 33;
|
||||
static unsigned int blinktimeout = 800;
|
||||
static unsigned int cursorthickness = 2;
|
||||
static int bellvolume = 0;
|
||||
char *termname = "xterm";
|
||||
unsigned int tabspaces = 2;
|
||||
|
||||
static const char *colorname[] = {
|
||||
/* Normal colors */
|
||||
[0] = "#121212", /* black */
|
||||
[1] = "#ee5396", /* red */
|
||||
[2] = "#42be65", /* green */
|
||||
[3] = "#ffe97b", /* yellow */
|
||||
[4] = "#33b1ff", /* blue */
|
||||
[5] = "#ff7eb6", /* magenta */
|
||||
[6] = "#3ddbd9", /* cyan */
|
||||
[7] = "#dde1e6", /* white */
|
||||
|
||||
/* Bright colors */
|
||||
[8] = "#393939", /* black */
|
||||
[9] = "#ee5396", /* red */
|
||||
[10] = "#42be65", /* green */
|
||||
[11] = "#ffe97b", /* yellow */
|
||||
[12] = "#33b1ff", /* blue */
|
||||
[13] = "#ff7eb6", /* magenta */
|
||||
[14] = "#3ddbd9", /* cyan */
|
||||
[15] = "#ffffff", /* white */
|
||||
|
||||
/* Background and Foreground */
|
||||
[256] = "#121212", /* background */
|
||||
[257] = "#ffffff", /* foreground */
|
||||
};
|
||||
/*
|
||||
* Default colors (colorname index)
|
||||
* foreground, background, cursor, reverse cursor
|
||||
*/
|
||||
unsigned int defaultfg = 15;
|
||||
unsigned int defaultbg = 0;
|
||||
unsigned int defaultcs = 15;
|
||||
static unsigned int defaultrcs = 257;
|
||||
|
||||
/*
|
||||
* Default shape of cursor
|
||||
* 2: Block ("█")
|
||||
* 4: Underline ("_")
|
||||
* 6: Bar ("|")
|
||||
* 7: Snowman ("☃")
|
||||
*/
|
||||
static unsigned int cursorshape = 4;
|
||||
static unsigned int cols = 80;
|
||||
static unsigned int rows = 24;
|
||||
static unsigned int mouseshape = XC_xterm;
|
||||
static unsigned int mousefg = 7;
|
||||
static unsigned int mousebg = 0;
|
||||
static unsigned int defaultattr = 11;
|
||||
static uint forcemousemod = ShiftMask;
|
||||
static MouseShortcut mshortcuts[] = {
|
||||
/* mask button function argument release */
|
||||
{XK_ANY_MOD, Button2, selpaste, {.i = 0}, 1},
|
||||
{ShiftMask, Button4, ttysend, {.s = "\033[5;2~"}},
|
||||
{XK_ANY_MOD, Button4, ttysend, {.s = "\031"}},
|
||||
{ShiftMask, Button5, ttysend, {.s = "\033[6;2~"}},
|
||||
{XK_ANY_MOD, Button5, ttysend, {.s = "\005"}},
|
||||
};
|
||||
|
||||
/* Internal keyboard shortcuts. */
|
||||
#define MODKEY Mod1Mask
|
||||
#define TERMMOD (ControlMask | ShiftMask)
|
||||
|
||||
static Shortcut shortcuts[] = {
|
||||
/* mask keysym function argument */
|
||||
{XK_ANY_MOD, XK_Break, sendbreak, {.i = 0}},
|
||||
{ControlMask, XK_Print, toggleprinter, {.i = 0}},
|
||||
{ShiftMask, XK_Print, printscreen, {.i = 0}},
|
||||
{XK_ANY_MOD, XK_Print, printsel, {.i = 0}},
|
||||
{TERMMOD, XK_Prior, zoom, {.f = +1}},
|
||||
{TERMMOD, XK_Next, zoom, {.f = -1}},
|
||||
{TERMMOD, XK_Home, zoomreset, {.f = 0}},
|
||||
{TERMMOD, XK_C, clipcopy, {.i = 0}},
|
||||
{TERMMOD, XK_V, clippaste, {.i = 0}},
|
||||
{TERMMOD, XK_Y, selpaste, {.i = 0}},
|
||||
{ShiftMask, XK_Insert, selpaste, {.i = 0}},
|
||||
{TERMMOD, XK_Num_Lock, numlock, {.i = 0}},
|
||||
};
|
||||
static KeySym mappedkeys[] = {-1};
|
||||
static uint ignoremod = Mod2Mask | XK_SWITCH_MOD;
|
||||
static Key key[] = {
|
||||
/* keysym mask string appkey appcursor */
|
||||
{XK_KP_Home, ShiftMask, "\033[2J", 0, -1},
|
||||
{XK_KP_Home, ShiftMask, "\033[1;2H", 0, +1},
|
||||
{XK_KP_Home, XK_ANY_MOD, "\033[H", 0, -1},
|
||||
{XK_KP_Home, XK_ANY_MOD, "\033[1~", 0, +1},
|
||||
{XK_KP_Up, XK_ANY_MOD, "\033Ox", +1, 0},
|
||||
{XK_KP_Up, XK_ANY_MOD, "\033[A", 0, -1},
|
||||
{XK_KP_Up, XK_ANY_MOD, "\033OA", 0, +1},
|
||||
{XK_KP_Down, XK_ANY_MOD, "\033Or", +1, 0},
|
||||
{XK_KP_Down, XK_ANY_MOD, "\033[B", 0, -1},
|
||||
{XK_KP_Down, XK_ANY_MOD, "\033OB", 0, +1},
|
||||
{XK_KP_Left, XK_ANY_MOD, "\033Ot", +1, 0},
|
||||
{XK_KP_Left, XK_ANY_MOD, "\033[D", 0, -1},
|
||||
{XK_KP_Left, XK_ANY_MOD, "\033OD", 0, +1},
|
||||
{XK_KP_Right, XK_ANY_MOD, "\033Ov", +1, 0},
|
||||
{XK_KP_Right, XK_ANY_MOD, "\033[C", 0, -1},
|
||||
{XK_KP_Right, XK_ANY_MOD, "\033OC", 0, +1},
|
||||
{XK_KP_Prior, ShiftMask, "\033[5;2~", 0, 0},
|
||||
{XK_KP_Prior, XK_ANY_MOD, "\033[5~", 0, 0},
|
||||
{XK_KP_Begin, XK_ANY_MOD, "\033[E", 0, 0},
|
||||
{XK_KP_End, ControlMask, "\033[J", -1, 0},
|
||||
{XK_KP_End, ControlMask, "\033[1;5F", +1, 0},
|
||||
{XK_KP_End, ShiftMask, "\033[K", -1, 0},
|
||||
{XK_KP_End, ShiftMask, "\033[1;2F", +1, 0},
|
||||
{XK_KP_End, XK_ANY_MOD, "\033[4~", 0, 0},
|
||||
{XK_KP_Next, ShiftMask, "\033[6;2~", 0, 0},
|
||||
{XK_KP_Next, XK_ANY_MOD, "\033[6~", 0, 0},
|
||||
{XK_KP_Insert, ShiftMask, "\033[2;2~", +1, 0},
|
||||
{XK_KP_Insert, ShiftMask, "\033[4l", -1, 0},
|
||||
{XK_KP_Insert, ControlMask, "\033[L", -1, 0},
|
||||
{XK_KP_Insert, ControlMask, "\033[2;5~", +1, 0},
|
||||
{XK_KP_Insert, XK_ANY_MOD, "\033[4h", -1, 0},
|
||||
{XK_KP_Insert, XK_ANY_MOD, "\033[2~", +1, 0},
|
||||
{XK_KP_Delete, ControlMask, "\033[M", -1, 0},
|
||||
{XK_KP_Delete, ControlMask, "\033[3;5~", +1, 0},
|
||||
{XK_KP_Delete, ShiftMask, "\033[2K", -1, 0},
|
||||
{XK_KP_Delete, ShiftMask, "\033[3;2~", +1, 0},
|
||||
{XK_KP_Delete, XK_ANY_MOD, "\033[P", -1, 0},
|
||||
{XK_KP_Delete, XK_ANY_MOD, "\033[3~", +1, 0},
|
||||
{XK_KP_Multiply, XK_ANY_MOD, "\033Oj", +2, 0},
|
||||
{XK_KP_Add, XK_ANY_MOD, "\033Ok", +2, 0},
|
||||
{XK_KP_Enter, XK_ANY_MOD, "\033OM", +2, 0},
|
||||
{XK_KP_Enter, XK_ANY_MOD, "\r", -1, 0},
|
||||
{XK_KP_Subtract, XK_ANY_MOD, "\033Om", +2, 0},
|
||||
{XK_KP_Decimal, XK_ANY_MOD, "\033On", +2, 0},
|
||||
{XK_KP_Divide, XK_ANY_MOD, "\033Oo", +2, 0},
|
||||
{XK_KP_0, XK_ANY_MOD, "\033Op", +2, 0},
|
||||
{XK_KP_1, XK_ANY_MOD, "\033Oq", +2, 0},
|
||||
{XK_KP_2, XK_ANY_MOD, "\033Or", +2, 0},
|
||||
{XK_KP_3, XK_ANY_MOD, "\033Os", +2, 0},
|
||||
{XK_KP_4, XK_ANY_MOD, "\033Ot", +2, 0},
|
||||
{XK_KP_5, XK_ANY_MOD, "\033Ou", +2, 0},
|
||||
{XK_KP_6, XK_ANY_MOD, "\033Ov", +2, 0},
|
||||
{XK_KP_7, XK_ANY_MOD, "\033Ow", +2, 0},
|
||||
{XK_KP_8, XK_ANY_MOD, "\033Ox", +2, 0},
|
||||
{XK_KP_9, XK_ANY_MOD, "\033Oy", +2, 0},
|
||||
{XK_Up, ShiftMask, "\033[1;2A", 0, 0},
|
||||
{XK_Up, Mod1Mask, "\033[1;3A", 0, 0},
|
||||
{XK_Up, ShiftMask | Mod1Mask, "\033[1;4A", 0, 0},
|
||||
{XK_Up, ControlMask, "\033[1;5A", 0, 0},
|
||||
{XK_Up, ShiftMask | ControlMask, "\033[1;6A", 0, 0},
|
||||
{XK_Up, ControlMask | Mod1Mask, "\033[1;7A", 0, 0},
|
||||
{XK_Up, ShiftMask | ControlMask | Mod1Mask, "\033[1;8A", 0, 0},
|
||||
{XK_Up, XK_ANY_MOD, "\033[A", 0, -1},
|
||||
{XK_Up, XK_ANY_MOD, "\033OA", 0, +1},
|
||||
{XK_Down, ShiftMask, "\033[1;2B", 0, 0},
|
||||
{XK_Down, Mod1Mask, "\033[1;3B", 0, 0},
|
||||
{XK_Down, ShiftMask | Mod1Mask, "\033[1;4B", 0, 0},
|
||||
{XK_Down, ControlMask, "\033[1;5B", 0, 0},
|
||||
{XK_Down, ShiftMask | ControlMask, "\033[1;6B", 0, 0},
|
||||
{XK_Down, ControlMask | Mod1Mask, "\033[1;7B", 0, 0},
|
||||
{XK_Down, ShiftMask | ControlMask | Mod1Mask, "\033[1;8B", 0, 0},
|
||||
{XK_Down, XK_ANY_MOD, "\033[B", 0, -1},
|
||||
{XK_Down, XK_ANY_MOD, "\033OB", 0, +1},
|
||||
{XK_Left, ShiftMask, "\033[1;2D", 0, 0},
|
||||
{XK_Left, Mod1Mask, "\033[1;3D", 0, 0},
|
||||
{XK_Left, ShiftMask | Mod1Mask, "\033[1;4D", 0, 0},
|
||||
{XK_Left, ControlMask, "\033[1;5D", 0, 0},
|
||||
{XK_Left, ShiftMask | ControlMask, "\033[1;6D", 0, 0},
|
||||
{XK_Left, ControlMask | Mod1Mask, "\033[1;7D", 0, 0},
|
||||
{XK_Left, ShiftMask | ControlMask | Mod1Mask, "\033[1;8D", 0, 0},
|
||||
{XK_Left, XK_ANY_MOD, "\033[D", 0, -1},
|
||||
{XK_Left, XK_ANY_MOD, "\033OD", 0, +1},
|
||||
{XK_Right, ShiftMask, "\033[1;2C", 0, 0},
|
||||
{XK_Right, Mod1Mask, "\033[1;3C", 0, 0},
|
||||
{XK_Right, ShiftMask | Mod1Mask, "\033[1;4C", 0, 0},
|
||||
{XK_Right, ControlMask, "\033[1;5C", 0, 0},
|
||||
{XK_Right, ShiftMask | ControlMask, "\033[1;6C", 0, 0},
|
||||
{XK_Right, ControlMask | Mod1Mask, "\033[1;7C", 0, 0},
|
||||
{XK_Right, ShiftMask | ControlMask | Mod1Mask, "\033[1;8C", 0, 0},
|
||||
{XK_Right, XK_ANY_MOD, "\033[C", 0, -1},
|
||||
{XK_Right, XK_ANY_MOD, "\033OC", 0, +1},
|
||||
{XK_ISO_Left_Tab, ShiftMask, "\033[Z", 0, 0},
|
||||
{XK_Return, Mod1Mask, "\033\r", 0, 0},
|
||||
{XK_Return, XK_ANY_MOD, "\r", 0, 0},
|
||||
{XK_Insert, ShiftMask, "\033[4l", -1, 0},
|
||||
{XK_Insert, ShiftMask, "\033[2;2~", +1, 0},
|
||||
{XK_Insert, ControlMask, "\033[L", -1, 0},
|
||||
{XK_Insert, ControlMask, "\033[2;5~", +1, 0},
|
||||
{XK_Insert, XK_ANY_MOD, "\033[4h", -1, 0},
|
||||
{XK_Insert, XK_ANY_MOD, "\033[2~", +1, 0},
|
||||
{XK_Delete, ControlMask, "\033[M", -1, 0},
|
||||
{XK_Delete, ControlMask, "\033[3;5~", +1, 0},
|
||||
{XK_Delete, ShiftMask, "\033[2K", -1, 0},
|
||||
{XK_Delete, ShiftMask, "\033[3;2~", +1, 0},
|
||||
{XK_Delete, XK_ANY_MOD, "\033[P", -1, 0},
|
||||
{XK_Delete, XK_ANY_MOD, "\033[3~", +1, 0},
|
||||
{XK_BackSpace, XK_NO_MOD, "\177", 0, 0},
|
||||
{XK_BackSpace, Mod1Mask, "\033\177", 0, 0},
|
||||
{XK_Home, ShiftMask, "\033[2J", 0, -1},
|
||||
{XK_Home, ShiftMask, "\033[1;2H", 0, +1},
|
||||
{XK_Home, XK_ANY_MOD, "\033[H", 0, -1},
|
||||
{XK_Home, XK_ANY_MOD, "\033[1~", 0, +1},
|
||||
{XK_End, ControlMask, "\033[J", -1, 0},
|
||||
{XK_End, ControlMask, "\033[1;5F", +1, 0},
|
||||
{XK_End, ShiftMask, "\033[K", -1, 0},
|
||||
{XK_End, ShiftMask, "\033[1;2F", +1, 0},
|
||||
{XK_End, XK_ANY_MOD, "\033[4~", 0, 0},
|
||||
{XK_Prior, ControlMask, "\033[5;5~", 0, 0},
|
||||
{XK_Prior, ShiftMask, "\033[5;2~", 0, 0},
|
||||
{XK_Prior, XK_ANY_MOD, "\033[5~", 0, 0},
|
||||
{XK_Next, ControlMask, "\033[6;5~", 0, 0},
|
||||
{XK_Next, ShiftMask, "\033[6;2~", 0, 0},
|
||||
{XK_Next, XK_ANY_MOD, "\033[6~", 0, 0},
|
||||
{XK_F1, XK_NO_MOD, "\033OP", 0, 0},
|
||||
{XK_F1, /* F13 */ ShiftMask, "\033[1;2P", 0, 0},
|
||||
{XK_F1, /* F25 */ ControlMask, "\033[1;5P", 0, 0},
|
||||
{XK_F1, /* F37 */ Mod4Mask, "\033[1;6P", 0, 0},
|
||||
{XK_F1, /* F49 */ Mod1Mask, "\033[1;3P", 0, 0},
|
||||
{XK_F1, /* F61 */ Mod3Mask, "\033[1;4P", 0, 0},
|
||||
{XK_F2, XK_NO_MOD, "\033OQ", 0, 0},
|
||||
{XK_F2, /* F14 */ ShiftMask, "\033[1;2Q", 0, 0},
|
||||
{XK_F2, /* F26 */ ControlMask, "\033[1;5Q", 0, 0},
|
||||
{XK_F2, /* F38 */ Mod4Mask, "\033[1;6Q", 0, 0},
|
||||
{XK_F2, /* F50 */ Mod1Mask, "\033[1;3Q", 0, 0},
|
||||
{XK_F2, /* F62 */ Mod3Mask, "\033[1;4Q", 0, 0},
|
||||
{XK_F3, XK_NO_MOD, "\033OR", 0, 0},
|
||||
{XK_F3, /* F15 */ ShiftMask, "\033[1;2R", 0, 0},
|
||||
{XK_F3, /* F27 */ ControlMask, "\033[1;5R", 0, 0},
|
||||
{XK_F3, /* F39 */ Mod4Mask, "\033[1;6R", 0, 0},
|
||||
{XK_F3, /* F51 */ Mod1Mask, "\033[1;3R", 0, 0},
|
||||
{XK_F3, /* F63 */ Mod3Mask, "\033[1;4R", 0, 0},
|
||||
{XK_F4, XK_NO_MOD, "\033OS", 0, 0},
|
||||
{XK_F4, /* F16 */ ShiftMask, "\033[1;2S", 0, 0},
|
||||
{XK_F4, /* F28 */ ControlMask, "\033[1;5S", 0, 0},
|
||||
{XK_F4, /* F40 */ Mod4Mask, "\033[1;6S", 0, 0},
|
||||
{XK_F4, /* F52 */ Mod1Mask, "\033[1;3S", 0, 0},
|
||||
{XK_F5, XK_NO_MOD, "\033[15~", 0, 0},
|
||||
{XK_F5, /* F17 */ ShiftMask, "\033[15;2~", 0, 0},
|
||||
{XK_F5, /* F29 */ ControlMask, "\033[15;5~", 0, 0},
|
||||
{XK_F5, /* F41 */ Mod4Mask, "\033[15;6~", 0, 0},
|
||||
{XK_F5, /* F53 */ Mod1Mask, "\033[15;3~", 0, 0},
|
||||
{XK_F6, XK_NO_MOD, "\033[17~", 0, 0},
|
||||
{XK_F6, /* F18 */ ShiftMask, "\033[17;2~", 0, 0},
|
||||
{XK_F6, /* F30 */ ControlMask, "\033[17;5~", 0, 0},
|
||||
{XK_F6, /* F42 */ Mod4Mask, "\033[17;6~", 0, 0},
|
||||
{XK_F6, /* F54 */ Mod1Mask, "\033[17;3~", 0, 0},
|
||||
{XK_F7, XK_NO_MOD, "\033[18~", 0, 0},
|
||||
{XK_F7, /* F19 */ ShiftMask, "\033[18;2~", 0, 0},
|
||||
{XK_F7, /* F31 */ ControlMask, "\033[18;5~", 0, 0},
|
||||
{XK_F7, /* F43 */ Mod4Mask, "\033[18;6~", 0, 0},
|
||||
{XK_F7, /* F55 */ Mod1Mask, "\033[18;3~", 0, 0},
|
||||
{XK_F8, XK_NO_MOD, "\033[19~", 0, 0},
|
||||
{XK_F8, /* F20 */ ShiftMask, "\033[19;2~", 0, 0},
|
||||
{XK_F8, /* F32 */ ControlMask, "\033[19;5~", 0, 0},
|
||||
{XK_F8, /* F44 */ Mod4Mask, "\033[19;6~", 0, 0},
|
||||
{XK_F8, /* F56 */ Mod1Mask, "\033[19;3~", 0, 0},
|
||||
{XK_F9, XK_NO_MOD, "\033[20~", 0, 0},
|
||||
{XK_F9, /* F21 */ ShiftMask, "\033[20;2~", 0, 0},
|
||||
{XK_F9, /* F33 */ ControlMask, "\033[20;5~", 0, 0},
|
||||
{XK_F9, /* F45 */ Mod4Mask, "\033[20;6~", 0, 0},
|
||||
{XK_F9, /* F57 */ Mod1Mask, "\033[20;3~", 0, 0},
|
||||
{XK_F10, XK_NO_MOD, "\033[21~", 0, 0},
|
||||
{XK_F10, /* F22 */ ShiftMask, "\033[21;2~", 0, 0},
|
||||
{XK_F10, /* F34 */ ControlMask, "\033[21;5~", 0, 0},
|
||||
{XK_F10, /* F46 */ Mod4Mask, "\033[21;6~", 0, 0},
|
||||
{XK_F10, /* F58 */ Mod1Mask, "\033[21;3~", 0, 0},
|
||||
{XK_F11, XK_NO_MOD, "\033[23~", 0, 0},
|
||||
{XK_F11, /* F23 */ ShiftMask, "\033[23;2~", 0, 0},
|
||||
{XK_F11, /* F35 */ ControlMask, "\033[23;5~", 0, 0},
|
||||
{XK_F11, /* F47 */ Mod4Mask, "\033[23;6~", 0, 0},
|
||||
{XK_F11, /* F59 */ Mod1Mask, "\033[23;3~", 0, 0},
|
||||
{XK_F12, XK_NO_MOD, "\033[24~", 0, 0},
|
||||
{XK_F12, /* F24 */ ShiftMask, "\033[24;2~", 0, 0},
|
||||
{XK_F12, /* F36 */ ControlMask, "\033[24;5~", 0, 0},
|
||||
{XK_F12, /* F48 */ Mod4Mask, "\033[24;6~", 0, 0},
|
||||
{XK_F12, /* F60 */ Mod1Mask, "\033[24;3~", 0, 0},
|
||||
{XK_F13, XK_NO_MOD, "\033[1;2P", 0, 0},
|
||||
{XK_F14, XK_NO_MOD, "\033[1;2Q", 0, 0},
|
||||
{XK_F15, XK_NO_MOD, "\033[1;2R", 0, 0},
|
||||
{XK_F16, XK_NO_MOD, "\033[1;2S", 0, 0},
|
||||
{XK_F17, XK_NO_MOD, "\033[15;2~", 0, 0},
|
||||
{XK_F18, XK_NO_MOD, "\033[17;2~", 0, 0},
|
||||
{XK_F19, XK_NO_MOD, "\033[18;2~", 0, 0},
|
||||
{XK_F20, XK_NO_MOD, "\033[19;2~", 0, 0},
|
||||
{XK_F21, XK_NO_MOD, "\033[20;2~", 0, 0},
|
||||
{XK_F22, XK_NO_MOD, "\033[21;2~", 0, 0},
|
||||
{XK_F23, XK_NO_MOD, "\033[23;2~", 0, 0},
|
||||
{XK_F24, XK_NO_MOD, "\033[24;2~", 0, 0},
|
||||
{XK_F25, XK_NO_MOD, "\033[1;5P", 0, 0},
|
||||
{XK_F26, XK_NO_MOD, "\033[1;5Q", 0, 0},
|
||||
{XK_F27, XK_NO_MOD, "\033[1;5R", 0, 0},
|
||||
{XK_F28, XK_NO_MOD, "\033[1;5S", 0, 0},
|
||||
{XK_F29, XK_NO_MOD, "\033[15;5~", 0, 0},
|
||||
{XK_F30, XK_NO_MOD, "\033[17;5~", 0, 0},
|
||||
{XK_F31, XK_NO_MOD, "\033[18;5~", 0, 0},
|
||||
{XK_F32, XK_NO_MOD, "\033[19;5~", 0, 0},
|
||||
{XK_F33, XK_NO_MOD, "\033[20;5~", 0, 0},
|
||||
{XK_F34, XK_NO_MOD, "\033[21;5~", 0, 0},
|
||||
{XK_F35, XK_NO_MOD, "\033[23;5~", 0, 0},
|
||||
};
|
||||
|
||||
static uint selmasks[] = {
|
||||
[SEL_RECTANGULAR] = Mod1Mask,
|
||||
};
|
||||
|
||||
static char ascii_printable[] = " !\"#$%&'()*+,-./0123456789:;<=>?"
|
||||
"@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_"
|
||||
"`abcdefghijklmnopqrstuvwxyz{|}~";
|
@ -1,11 +0,0 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
imports = [
|
||||
./i3.nix
|
||||
./alacritty.nix
|
||||
];
|
||||
|
||||
home.file = {
|
||||
".config/i3/i3status.conf".source = ./raw/i3status.conf;
|
||||
};
|
||||
}
|
@ -1,114 +0,0 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
xsession.windowManager.i3 = {
|
||||
enable = true;
|
||||
package = pkgs.i3-gaps;
|
||||
config = {
|
||||
gaps = {
|
||||
inner = 5;
|
||||
outer = 5;
|
||||
};
|
||||
bars = [
|
||||
{
|
||||
command = "${pkgs.feh}/bin/feh --bg-fill ~/.wp/gruvbox-dark-blue.png; i3status -c ~/.config/i3/i3status.conf";
|
||||
}
|
||||
];
|
||||
keybindings = {
|
||||
|
||||
# IMPORTANT STUFF #
|
||||
"Mod4+Return" = "exec alacritty ";
|
||||
"Mod4+space" = "exec ${pkgs.rofi}/bin/rofi -show run";
|
||||
"Mod4+Q" = "kill";
|
||||
"Mod4+Shift+R" = "restart";
|
||||
"Mod4+Shift+S" = "exec ${pkgs.flameshot}/bin/flameshot gui";
|
||||
|
||||
# WINDOW STUFF #
|
||||
"Mod4+Shift+space" = "floating toggle";
|
||||
"Mod4+Shift+F" = "fullscreen toggle";
|
||||
"Mod4+Left" = "focus left";
|
||||
"Mod4+Down" = "focus down";
|
||||
"Mod4+Up" = "focus up";
|
||||
"Mod4+Right" = "focus right";
|
||||
|
||||
"Mod4+Ctrl+Right" = "resize shrink width 3 px or 3 ppt";
|
||||
"Mod4+Ctrl+Down" = "resize grow height 3 px or 3 ppt";
|
||||
"Mod4+Ctrl+Up" = "resize shrink height 3 px or 3 ppt";
|
||||
"Mod4+Ctrl+Left" = "resize grow width 3 px or 3 ppt";
|
||||
|
||||
"Mod4+Shift+Left" = "move left";
|
||||
"Mod4+Shift+Down" = "move down";
|
||||
"Mod4+Shift+Up" = "move up";
|
||||
"Mod4+Shift+Right" = "move right";
|
||||
|
||||
# WORKSPACES #
|
||||
"Mod4+1" = "workspace number 1";
|
||||
"Mod4+2" = "workspace number 2";
|
||||
"Mod4+3" = "workspace number 3";
|
||||
"Mod4+4" = "workspace number 4";
|
||||
"Mod4+5" = "workspace number 5";
|
||||
"Mod4+6" = "workspace number 6";
|
||||
"Mod4+7" = "workspace number 7";
|
||||
"Mod4+8" = "workspace number 8";
|
||||
"Mod4+9" = "workspace number 9";
|
||||
|
||||
# MOVE WINDOW TO OTHER WS #
|
||||
"Mod4+Shift+1" = "move container to workspace number 1";
|
||||
"Mod4+Shift+2" = "move container to workspace number 2";
|
||||
"Mod4+Shift+3" = "move container to workspace number 3";
|
||||
"Mod4+Shift+4" = "move container to workspace number 4";
|
||||
"Mod4+Shift+5" = "move container to workspace number 5";
|
||||
"Mod4+Shift+6" = "move container to workspace number 6";
|
||||
"Mod4+Shift+7" = "move container to workspace number 7";
|
||||
"Mod4+Shift+8" = "move container to workspace number 8";
|
||||
"Mod4+Shift+9" = "move container to workspace number 9";
|
||||
|
||||
# Audio
|
||||
"XF86AudioRaiseVolume" = "exec wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%+";
|
||||
"XF86AudioLowerVolume" = "exec wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%-";
|
||||
"XF86AudioMute" = "exec set-volume toggle-mute";
|
||||
|
||||
"XF86AudioStop" = "exec ${pkgs.playerctl}/bin/playerctl stop";
|
||||
"XF86AudioPrev" = "exec ${pkgs.playerctl}/bin/playerctl previous";
|
||||
"XF86AudioNext" = "exec ${pkgs.playerctl}/bin/playerctl next";
|
||||
"XF86AudioPlay" = "exec ${pkgs.playerctl}/bin/playerctl play-pause";
|
||||
|
||||
"XF86MonBrightnessDown" = "exec ${pkgs.brightnessctl}/bin/brightnessctl set 5%-";
|
||||
"XF86MonBrightnessUp" = "exec ${pkgs.brightnessctl}/bin/brightnessctl set 5%+";
|
||||
|
||||
};
|
||||
};
|
||||
extraConfig = ''
|
||||
bar {
|
||||
position top
|
||||
status_command i3status -c /home/fabian/.config/i3/i3status.conf
|
||||
colors {
|
||||
background #161616
|
||||
statusline #FFFFFF
|
||||
separator #FFFFFF
|
||||
|
||||
focused_workspace #458588 #458588 #ebdbb2
|
||||
active_workspace #83a598 #83a598 #ebdbb2
|
||||
inactive_workspace #504945 #504945 #ebdbb2
|
||||
urgent_workspace #cc241d #cc241d #504945
|
||||
}
|
||||
}
|
||||
|
||||
set $bg #161616
|
||||
set $red #cc241d
|
||||
set $green #98971a
|
||||
set $yellow #101010
|
||||
set $blue #458588
|
||||
set $purple #b16286
|
||||
set $aqua #689d68
|
||||
set $gray #a89984
|
||||
set $darkgray #161616
|
||||
|
||||
floating_modifier Mod4
|
||||
|
||||
client.focused $green $green $darkgray $yellow $yellow
|
||||
client.focused_inactive $darkgray $darkgray $yellow $purple $darkgray
|
||||
client.unfocused $darkgray $darkgray $yellow $purple $darkgray
|
||||
for_window [class="^.*"] border pixel 1
|
||||
'';
|
||||
};
|
||||
}
|
@ -1,55 +0,0 @@
|
||||
general {
|
||||
colors = true
|
||||
color_good = "#98971a"
|
||||
color_bad = "#cc241d"
|
||||
color_degraded = "#fabd2f"
|
||||
interval = 2
|
||||
}
|
||||
|
||||
#order += "wireless wlp4s0"
|
||||
order += "ethernet enp2s0f0u1"
|
||||
#order += "battery all"
|
||||
order += "memory"
|
||||
order += "cpu_usage"
|
||||
order += "volume master"
|
||||
order += "tztime local"
|
||||
|
||||
volume master {
|
||||
#format = "♪%volume"
|
||||
device = "default"
|
||||
mixer = "Master"
|
||||
mixer_idx = 0
|
||||
# termsyn font
|
||||
format = "🔊 %volume"
|
||||
}
|
||||
|
||||
cpu_usage {
|
||||
format = "%usage CPU"
|
||||
}
|
||||
|
||||
|
||||
wireless wlp4s0 {
|
||||
format_up = " (%quality) %ip "
|
||||
format_down = " ☡ WiFi "
|
||||
}
|
||||
|
||||
ethernet enp4s0 {
|
||||
# termsyn font
|
||||
format_up = "%ip"
|
||||
#format_down = "eth0 "
|
||||
}
|
||||
|
||||
memory {
|
||||
format = "%used"
|
||||
threshold_degraded = "10%"
|
||||
format_degraded = "MEMORY: %free"
|
||||
}
|
||||
|
||||
battery all {
|
||||
format = "%percentage/%remaining"
|
||||
}
|
||||
|
||||
tztime local {
|
||||
# termsyn font
|
||||
format = "%H:%M"
|
||||
}
|
@ -1,28 +0,0 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
programs.alacritty = {
|
||||
enable = true;
|
||||
|
||||
settings = {
|
||||
terminal = {
|
||||
shell = "tmux";
|
||||
};
|
||||
window = {
|
||||
opacity = 0.8;
|
||||
blur = true;
|
||||
};
|
||||
colors = {
|
||||
primary = {
|
||||
background = "#000000";
|
||||
foreground = "#FFFFFF";
|
||||
};
|
||||
};
|
||||
font = {
|
||||
size = 18;
|
||||
normal = {
|
||||
family = "FantasqueSansMNerdFont";
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
@ -1,13 +0,0 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
imports = [
|
||||
./sway.nix
|
||||
./alacritty.nix
|
||||
];
|
||||
|
||||
home = {
|
||||
file = {
|
||||
".config/rofi/config.rasi".source = ./raw/config.rasi;
|
||||
};
|
||||
};
|
||||
}
|
@ -1,77 +0,0 @@
|
||||
configuration {
|
||||
display-drun: "Applications:";
|
||||
drun-display-format: "{icon} {name}";
|
||||
font: "JetBrainsMono Nerd Font Medium 10";
|
||||
show-icons: true;
|
||||
modi: "drun";
|
||||
}
|
||||
|
||||
|
||||
@theme "/dev/null"
|
||||
|
||||
* {
|
||||
|
||||
opacity: 0.5;
|
||||
color0: #39305320;
|
||||
color1: #494d6420;
|
||||
color3: #d8dee9;
|
||||
color4: #7b68ee;
|
||||
color5: #cbe3e7;
|
||||
|
||||
|
||||
background-color: transparent;
|
||||
text-color: @color3;
|
||||
accent-color: @color5;
|
||||
|
||||
margin: 0px;
|
||||
border: 0px;
|
||||
padding: 0px;
|
||||
spacing: 0px;
|
||||
}
|
||||
|
||||
window {
|
||||
background-color: @color0;
|
||||
border-color: @accent-color;
|
||||
|
||||
width: 50%;
|
||||
border: 2px;
|
||||
}
|
||||
|
||||
inputbar {
|
||||
padding: 10px 12px;
|
||||
spacing: 12px;
|
||||
children: [ prompt, entry ];
|
||||
}
|
||||
|
||||
prompt, entry, element-text, element-icon {
|
||||
vertical-align: 0.5;
|
||||
}
|
||||
|
||||
prompt {
|
||||
text-color: @accent-color;
|
||||
enabled: true;
|
||||
text-color: @color4;
|
||||
}
|
||||
|
||||
listview {
|
||||
lines: 8;
|
||||
columns: 2;
|
||||
|
||||
}
|
||||
|
||||
element {
|
||||
padding: 8px;
|
||||
spacing: 8px;
|
||||
}
|
||||
|
||||
element selected {
|
||||
text-color: @color4;
|
||||
}
|
||||
|
||||
element-icon {
|
||||
size: 20;
|
||||
}
|
||||
|
||||
element-text {
|
||||
text-color: inherit;
|
||||
}
|
@ -1,122 +0,0 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
wayland.windowManager.sway = {
|
||||
enable = true;
|
||||
xwayland = true;
|
||||
package = pkgs.swayfx-unwrapped;
|
||||
wrapperFeatures.gtk = true;
|
||||
checkConfig = false;
|
||||
extraSessionCommands = ''
|
||||
export _JAVA_AWT_WM_NONREPARENTING=1
|
||||
export QT_QPA_PLATFORM=wayland
|
||||
export XDG_CURRENT_DESKTOP=sway
|
||||
'';
|
||||
|
||||
config = rec {
|
||||
modifier = "Mod4";
|
||||
terminal = "alacritty";
|
||||
menu = "${pkgs.rofi}/bin/rofi -show run -c ~/.config/rofi/config.rasi";
|
||||
bars = [
|
||||
{
|
||||
command = "wayff";
|
||||
}
|
||||
];
|
||||
startup = [
|
||||
{ command = "${pkgs.swaybg}/bin/swaybg -i $HOME/.wp/ios.png"; }
|
||||
];
|
||||
gaps = {
|
||||
outer = 5;
|
||||
inner = 10;
|
||||
};
|
||||
|
||||
window = {
|
||||
border = 0;
|
||||
};
|
||||
|
||||
keybindings = {
|
||||
# IMPORTANT STUFF #
|
||||
"${modifier}+Return" = "exec ${terminal}";
|
||||
"${modifier}+space" = "exec ${menu}";
|
||||
"${modifier}+Q" = "kill";
|
||||
"${modifier}+Shift+R" = "reload";
|
||||
"${modifier}+Shift+S" = "${pkgs.shotman}/bin/shotman --capture region";
|
||||
# WINDOW STUFF #
|
||||
"${modifier}+Shift+space" = "floating toggle";
|
||||
"${modifier}+Shift+F" = "fullscreen toggle";
|
||||
"${modifier}+Left" = "focus left";
|
||||
"${modifier}+Down" = "focus down";
|
||||
"${modifier}+Up" = "focus up";
|
||||
"${modifier}+Right" = "focus right";
|
||||
|
||||
"${modifier}+Ctrl+Right" = "resize shrink width 3 px or 3 ppt";
|
||||
"${modifier}+Ctrl+Down" = "resize grow height 3 px or 3 ppt";
|
||||
"${modifier}+Ctrl+Up" = "resize shrink height 3 px or 3 ppt";
|
||||
"${modifier}+Ctrl+Left" = "resize grow width 3 px or 3 ppt";
|
||||
|
||||
"${modifier}+Shift+Left" = "move left";
|
||||
"${modifier}+Shift+Down" = "move down";
|
||||
"${modifier}+Shift+Up" = "move up";
|
||||
"${modifier}+Shift+Right" = "move right";
|
||||
|
||||
# WORKSPACES #
|
||||
"${modifier}+1" = "workspace number 1";
|
||||
"${modifier}+2" = "workspace number 2";
|
||||
"${modifier}+3" = "workspace number 3";
|
||||
"${modifier}+4" = "workspace number 4";
|
||||
"${modifier}+5" = "workspace number 5";
|
||||
"${modifier}+6" = "workspace number 6";
|
||||
"${modifier}+7" = "workspace number 7";
|
||||
"${modifier}+8" = "workspace number 8";
|
||||
"${modifier}+9" = "workspace number 9";
|
||||
|
||||
# MOVE WINDOW TO OTHER WS #
|
||||
"${modifier}+Shift+1" = "move container to workspace number 1";
|
||||
"${modifier}+Shift+2" = "move container to workspace number 2";
|
||||
"${modifier}+Shift+3" = "move container to workspace number 3";
|
||||
"${modifier}+Shift+4" = "move container to workspace number 4";
|
||||
"${modifier}+Shift+5" = "move container to workspace number 5";
|
||||
"${modifier}+Shift+6" = "move container to workspace number 6";
|
||||
"${modifier}+Shift+7" = "move container to workspace number 7";
|
||||
"${modifier}+Shift+8" = "move container to workspace number 8";
|
||||
"${modifier}+Shift+9" = "move container to workspace number 9";
|
||||
|
||||
# Audio
|
||||
"XF86AudioRaiseVolume" = "exec wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%+";
|
||||
"XF86AudioLowerVolume" = "exec wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%-";
|
||||
"XF86AudioMute" = "exec set-volume toggle-mute";
|
||||
"XF86AudioStop" = "exec ${pkgs.playerctl}/bin/playerctl stop";
|
||||
"XF86AudioPrev" = "exec ${pkgs.playerctl}/bin/playerctl previous";
|
||||
"XF86AudioNext" = "exec ${pkgs.playerctl}/bin/playerctl next";
|
||||
"XF86AudioPlay" = "exec ${pkgs.playerctl}/bin/playerctl play-pause";
|
||||
|
||||
"XF86MonBrightnessDown" = "exec brightnessctl set 15%-";
|
||||
"XF86MonBrightnessUp" = "exec brightnessctl set +15%";
|
||||
};
|
||||
};
|
||||
|
||||
extraConfig = ''
|
||||
shadows enable
|
||||
corner_radius 12
|
||||
blur_radius 7
|
||||
blur_passes 4
|
||||
default_dim_inactive 0.1
|
||||
|
||||
for_window [app_id="Alacritty"] blur enable
|
||||
for_window [app_id="alacritty"] blur enable
|
||||
|
||||
for_window [app_id="Firefox"] blur enable
|
||||
for_window [app_id="firefox"] blur enable
|
||||
|
||||
for_window [app_id="Discord"] blur enable
|
||||
for_window [app_id="discord"] blur enable
|
||||
|
||||
for_window [app_id="code"] blur enable
|
||||
|
||||
for_window [app_id="rofi"] blur enable
|
||||
|
||||
default_border pixel 0px
|
||||
default_floating_border none
|
||||
titlebar_border_thickness 0
|
||||
'';
|
||||
};
|
||||
}
|
9
modules/system/nix/default.nix
Normal file
@ -0,0 +1,9 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
imports = [
|
||||
./dns.nix
|
||||
./gaming.nix
|
||||
./firefox.nix
|
||||
./x/dwm/default.nix
|
||||
];
|
||||
}
|
12
modules/system/nix/dns.nix
Normal file
@ -0,0 +1,12 @@
|
||||
{ config, pkgs, ... }:
|
||||
{
|
||||
environment.systemPackages = with pkgs; [
|
||||
dhcpcd
|
||||
];
|
||||
networking = {
|
||||
nameservers = [
|
||||
"192.168.0.122"
|
||||
"1.1.1.1"
|
||||
];
|
||||
};
|
||||
}
|
@ -2,9 +2,6 @@
|
||||
{
|
||||
environment.systemPackages = with pkgs; [
|
||||
dmenu
|
||||
(st.overrideAttrs (oldAttrs: rec {
|
||||
configFile = writeText "config.def.h" (builtins.readFile ./source/st/config.def.h);
|
||||
}))
|
||||
];
|
||||
services = {
|
||||
xserver = {
|
44
modules/system/nix/x/dwm/source/dwm/Makefile
Normal file
@ -0,0 +1,44 @@
|
||||
# dwm - dynamic window manager
|
||||
# See LICENSE file for copyright and license details.
|
||||
|
||||
include config.mk
|
||||
|
||||
SRC = drw.c dwm.c util.c
|
||||
OBJ = ${SRC:.c=.o}
|
||||
|
||||
all: dwm
|
||||
|
||||
.c.o:
|
||||
${CC} -c ${CFLAGS} $<
|
||||
|
||||
${OBJ}: config.h config.mk
|
||||
|
||||
config.h:
|
||||
cp config.def.h $@
|
||||
|
||||
dwm: ${OBJ}
|
||||
${CC} -o $@ ${OBJ} ${LDFLAGS}
|
||||
|
||||
clean:
|
||||
rm -f config.h dwm ${OBJ} dwm-${VERSION}.tar.gz
|
||||
|
||||
dist: clean
|
||||
mkdir -p dwm-${VERSION}
|
||||
cp -R LICENSE Makefile README config.def.h config.mk\
|
||||
dwm.1 drw.h util.h ${SRC} dwm.png transient.c dwm-${VERSION}
|
||||
tar -cf dwm-${VERSION}.tar dwm-${VERSION}
|
||||
gzip dwm-${VERSION}.tar
|
||||
rm -rf config.h dwm-${VERSION}
|
||||
install: all
|
||||
mkdir -p ${DESTDIR}${PREFIX}/bin
|
||||
cp -f dwm ${DESTDIR}${PREFIX}/bin
|
||||
chmod 755 ${DESTDIR}${PREFIX}/bin/dwm
|
||||
mkdir -p ${DESTDIR}${MANPREFIX}/man1
|
||||
sed "s/VERSION/${VERSION}/g" < dwm.1 > ${DESTDIR}${MANPREFIX}/man1/dwm.1
|
||||
chmod 644 ${DESTDIR}${MANPREFIX}/man1/dwm.1
|
||||
|
||||
uninstall:
|
||||
rm -f ${DESTDIR}${PREFIX}/bin/dwm\
|
||||
${DESTDIR}${MANPREFIX}/man1/dwm.1
|
||||
|
||||
.PHONY: all clean dist install uninstall
|
161
modules/system/nix/x/dwm/source/dwm/config.def.h
Normal file
@ -0,0 +1,161 @@
|
||||
static const unsigned int borderpx = 1; /* border pixel of windows */
|
||||
static const unsigned int snap = 32; /* snap pixel */
|
||||
static const unsigned int gappih = 10; /* horiz inner gap between windows */
|
||||
static const unsigned int gappiv = 10; /* vert inner gap between windows */
|
||||
static const unsigned int gappoh =
|
||||
10; /* horiz outer gap between windows and screen edge */
|
||||
static const unsigned int gappov =
|
||||
10; /* vert outer gap between windows and screen edge */
|
||||
static int smartgaps =
|
||||
0; /* 1 means no outer gap when there is only one window */
|
||||
static const int showbar = 1; /* 0 means no bar */
|
||||
static const int topbar = 1; /* 0 means bottom bar */
|
||||
static const char *fonts[] = {"Terminus:size=10"};
|
||||
static const char dmenufont[] = "Terminus:size=10";
|
||||
|
||||
/* Farben aus Alacritty übernommen */
|
||||
static const char col_gray1[] = "#161616";
|
||||
static const char col_gray2[] = "#ffffff";
|
||||
static const char col_gray3[] = "#dde1e6";
|
||||
static const char col_gray4[] = "#ffffff";
|
||||
static const char col_cyan[] = "#161616";
|
||||
|
||||
/* Farbschema für die Fenster und die Leiste */
|
||||
static const char *colors[][3] = {
|
||||
/* fg bg border */
|
||||
[SchemeNorm] = {col_gray3, col_gray1, col_gray1}, /* Normale Fenster */
|
||||
[SchemeSel] = {col_gray4, col_cyan, col_gray2}, /* Ausgewähltes Fenster */
|
||||
};
|
||||
|
||||
/* tagging */
|
||||
static const char *tags[] = {"1", "2", "3", "4", "5", "6", "7", "8", "9"};
|
||||
|
||||
static const Rule rules[] = {
|
||||
{"Gimp", NULL, NULL, 0, 1, -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 */
|
||||
|
||||
#define FORCE_VSPLIT \
|
||||
1 /* nrowgrid layout: force two clients to always split vertically */
|
||||
#include "vanitygaps.c"
|
||||
#include <X11/XF86keysym.h>
|
||||
|
||||
static const Layout layouts[] = {
|
||||
{"[\\]", dwindle},
|
||||
{NULL, centeredfloatingmaster},
|
||||
{"|M|", centeredmaster},
|
||||
{"[]=", tile}, /* first entry is default */
|
||||
{"[M]", monocle},
|
||||
{"[@]", spiral},
|
||||
{"H[]", deck},
|
||||
{"TTT", bstack},
|
||||
{"===", bstackhoriz},
|
||||
{"HHH", grid},
|
||||
{"###", nrowgrid},
|
||||
{"---", horizgrid},
|
||||
{":::", gaplessgrid},
|
||||
{"><>", NULL}, /* no layout function means floating behavior */
|
||||
{NULL, NULL},
|
||||
};
|
||||
|
||||
#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}},
|
||||
|
||||
#define SHCMD(cmd) \
|
||||
{ \
|
||||
.v = (const char *[]) { "/bin/sh", "-c", cmd, NULL } \
|
||||
}
|
||||
|
||||
static char dmenumon[2] =
|
||||
"0"; /* component of dmenucmd, manipulated in spawn() */
|
||||
static const char *termcmd[] = {"alacritty", NULL};
|
||||
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 *upvol[] = {"wpctl", "set-sink-volume",
|
||||
"@DEFAULT_AUDIO_SINK@", "5%-", NULL};
|
||||
static const char *downvol[] = {"wpctl", "set-volume", "@DEFAULT_AUDIO_SINK@",
|
||||
"5%-", NULL};
|
||||
static const char *mutevol[] = {"wpctl", "set-mute", "@DEFAULT_AUDIO_SINK@",
|
||||
"toggle", NULL};
|
||||
|
||||
static const Key keys[] = {
|
||||
/* modifier key function argument */
|
||||
{MODKEY, XK_space, spawn, {.v = dmenucmd}},
|
||||
{MODKEY, XK_Return, spawn, {.v = termcmd}},
|
||||
{MODKEY | ShiftMask, XK_m, quit, {0}},
|
||||
{MODKEY, XK_Right, focusstack, {.i = +1}},
|
||||
{MODKEY, XK_Left, focusstack, {.i = -1}},
|
||||
{MODKEY, XK_i, incnmaster, {.i = +1}},
|
||||
{MODKEY, XK_d, incnmaster, {.i = -1}},
|
||||
{MODKEY, XK_r, rotatestack, {.i = -1}},
|
||||
{MODKEY | ShiftMask, XK_Left, setmfact, {.f = -0.05}},
|
||||
{MODKEY | ShiftMask, XK_Right, setmfact, {.f = +0.05}},
|
||||
{MODKEY, XK_Tab, view, {0}},
|
||||
{MODKEY, XK_q, killclient, {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_b, togglebar, {0}},
|
||||
|
||||
// Vanity Gaps shit //
|
||||
{MODKEY | ShiftMask, XK_h, setcfact, {.f = +0.25}},
|
||||
{MODKEY | ShiftMask, XK_l, setcfact, {.f = -0.25}},
|
||||
{MODKEY | ShiftMask, XK_o, setcfact, {.f = 0.00}},
|
||||
{MODKEY | Mod1Mask, XK_u, incrgaps, {.i = +3}},
|
||||
{MODKEY | Mod1Mask | ShiftMask, XK_u, incrgaps, {.i = -3}},
|
||||
{MODKEY | Mod1Mask, XK_i, incrigaps, {.i = +1}},
|
||||
{MODKEY | Mod1Mask | ShiftMask, XK_i, incrigaps, {.i = -1}},
|
||||
{MODKEY | Mod1Mask, XK_o, incrogaps, {.i = +1}},
|
||||
{MODKEY | Mod1Mask | ShiftMask, XK_o, incrogaps, {.i = -1}},
|
||||
{MODKEY | Mod1Mask, XK_6, incrihgaps, {.i = +1}},
|
||||
{MODKEY | Mod1Mask | ShiftMask, XK_6, incrihgaps, {.i = -1}},
|
||||
{MODKEY | Mod1Mask, XK_7, incrivgaps, {.i = +5}},
|
||||
{MODKEY | Mod1Mask | ShiftMask, XK_7, incrivgaps, {.i = -5}},
|
||||
{MODKEY | Mod1Mask, XK_8, incrohgaps, {.i = +1}},
|
||||
{MODKEY | Mod1Mask | ShiftMask, XK_8, incrohgaps, {.i = -1}},
|
||||
{MODKEY | Mod1Mask, XK_9, incrovgaps, {.i = +1}},
|
||||
{MODKEY | Mod1Mask | ShiftMask, XK_9, incrovgaps, {.i = -1}},
|
||||
{MODKEY | Mod1Mask, XK_0, togglegaps, {0}},
|
||||
{MODKEY | Mod1Mask | ShiftMask, XK_0, defaultgaps, {0}},
|
||||
|
||||
// WS
|
||||
TAGKEYS(XK_1, 0) TAGKEYS(XK_2, 1) TAGKEYS(XK_3, 2) TAGKEYS(XK_4, 3)
|
||||
TAGKEYS(XK_5, 4) TAGKEYS(XK_6, 5) TAGKEYS(XK_7, 6) TAGKEYS(XK_8, 7)
|
||||
TAGKEYS(XK_9, 8)
|
||||
|
||||
// Media Keys //
|
||||
{0, XF86XK_AudioLowerVolume, spawn, {.v = downvol}},
|
||||
{0, XF86XK_AudioMute, spawn, {.v = mutevol}},
|
||||
{0, XF86XK_AudioRaiseVolume, spawn, {.v = upvol}},
|
||||
|
||||
};
|
||||
|
||||
static const Button buttons[] = {
|
||||
{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, Button3, resizemouse, {0}},
|
||||
{ClkTagBar, 0, Button1, view, {0}},
|
||||
{ClkTagBar, 0, Button3, toggleview, {0}},
|
||||
{ClkTagBar, MODKEY, Button1, tag, {0}},
|
||||
{ClkTagBar, MODKEY, Button3, toggletag, {0}},
|
||||
};
|
39
modules/system/nix/x/dwm/source/dwm/config.mk
Normal file
@ -0,0 +1,39 @@
|
||||
# dwm version
|
||||
VERSION = 6.5
|
||||
|
||||
# Customize below to fit your system
|
||||
|
||||
# paths
|
||||
PREFIX = /usr/local
|
||||
MANPREFIX = ${PREFIX}/share/man
|
||||
|
||||
X11INC = ${PREFIX}/include
|
||||
X11LIB = ${PREFIX}/lib
|
||||
|
||||
# Xinerama, comment if you don't want it
|
||||
XINERAMALIBS = -lXinerama
|
||||
XINERAMAFLAGS = -DXINERAMA
|
||||
|
||||
# freetype
|
||||
FREETYPELIBS = -lfontconfig -lXft
|
||||
FREETYPEINC = ${PREFIX}/include/freetype2
|
||||
# OpenBSD (uncomment)
|
||||
FREETYPEINC = ${X11INC}/freetype2
|
||||
MANPREFIX = ${PREFIX}/man
|
||||
|
||||
# includes and libs
|
||||
INCS = -I${X11INC} -I${FREETYPEINC}
|
||||
LIBS = -L${X11LIB} -lX11 ${XINERAMALIBS} ${FREETYPELIBS}
|
||||
|
||||
# flags
|
||||
CPPFLAGS = -D_DEFAULT_SOURCE -D_BSD_SOURCE -D_XOPEN_SOURCE=700L -DVERSION=\"${VERSION}\" ${XINERAMAFLAGS}
|
||||
#CFLAGS = -g -std=c99 -pedantic -Wall -O0 ${INCS} ${CPPFLAGS}
|
||||
CFLAGS = -std=c99 -pedantic -Wall -Wno-deprecated-declarations -Os ${INCS} ${CPPFLAGS}
|
||||
LDFLAGS = ${LIBS}
|
||||
|
||||
# Solaris
|
||||
#CFLAGS = -fast ${INCS} -DVERSION=\"${VERSION}\"
|
||||
#LDFLAGS = ${LIBS}
|
||||
|
||||
# compiler and linker
|
||||
CC = cc
|
425
modules/system/nix/x/dwm/source/dwm/drw.c
Normal file
@ -0,0 +1,425 @@
|
||||
/* See LICENSE file for copyright and license details. */
|
||||
#include <X11/Xft/Xft.h>
|
||||
#include <X11/Xlib.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
#include "drw.h"
|
||||
#include "util.h"
|
||||
|
||||
#define UTF_INVALID 0xFFFD
|
||||
#define UTF_SIZ 4
|
||||
|
||||
static const unsigned char utfbyte[UTF_SIZ + 1] = {0x80, 0, 0xC0, 0xE0, 0xF0};
|
||||
static const unsigned char utfmask[UTF_SIZ + 1] = {0xC0, 0x80, 0xE0, 0xF0,
|
||||
0xF8};
|
||||
static const long utfmin[UTF_SIZ + 1] = {0, 0, 0x80, 0x800, 0x10000};
|
||||
static const long utfmax[UTF_SIZ + 1] = {0x10FFFF, 0x7F, 0x7FF, 0xFFFF,
|
||||
0x10FFFF};
|
||||
|
||||
static long utf8decodebyte(const char c, size_t *i) {
|
||||
for (*i = 0; *i < (UTF_SIZ + 1); ++(*i))
|
||||
if (((unsigned char)c & utfmask[*i]) == utfbyte[*i])
|
||||
return (unsigned char)c & ~utfmask[*i];
|
||||
return 0;
|
||||
}
|
||||
|
||||
static size_t utf8validate(long *u, size_t i) {
|
||||
if (!BETWEEN(*u, utfmin[i], utfmax[i]) || BETWEEN(*u, 0xD800, 0xDFFF))
|
||||
*u = UTF_INVALID;
|
||||
for (i = 1; *u > utfmax[i]; ++i)
|
||||
;
|
||||
return i;
|
||||
}
|
||||
|
||||
static size_t utf8decode(const char *c, long *u, size_t clen) {
|
||||
size_t i, j, len, type;
|
||||
long udecoded;
|
||||
|
||||
*u = UTF_INVALID;
|
||||
if (!clen)
|
||||
return 0;
|
||||
udecoded = utf8decodebyte(c[0], &len);
|
||||
if (!BETWEEN(len, 1, UTF_SIZ))
|
||||
return 1;
|
||||
for (i = 1, j = 1; i < clen && j < len; ++i, ++j) {
|
||||
udecoded = (udecoded << 6) | utf8decodebyte(c[i], &type);
|
||||
if (type)
|
||||
return j;
|
||||
}
|
||||
if (j < len)
|
||||
return 0;
|
||||
*u = udecoded;
|
||||
utf8validate(u, len);
|
||||
|
||||
return len;
|
||||
}
|
||||
|
||||
Drw *drw_create(Display *dpy, int screen, Window root, unsigned int w,
|
||||
unsigned int h) {
|
||||
Drw *drw = ecalloc(1, sizeof(Drw));
|
||||
|
||||
drw->dpy = dpy;
|
||||
drw->screen = screen;
|
||||
drw->root = root;
|
||||
drw->w = w;
|
||||
drw->h = h;
|
||||
drw->drawable = XCreatePixmap(dpy, root, w, h, DefaultDepth(dpy, screen));
|
||||
drw->gc = XCreateGC(dpy, root, 0, NULL);
|
||||
XSetLineAttributes(dpy, drw->gc, 1, LineSolid, CapButt, JoinMiter);
|
||||
|
||||
return drw;
|
||||
}
|
||||
|
||||
void drw_resize(Drw *drw, unsigned int w, unsigned int h) {
|
||||
if (!drw)
|
||||
return;
|
||||
|
||||
drw->w = w;
|
||||
drw->h = h;
|
||||
if (drw->drawable)
|
||||
XFreePixmap(drw->dpy, drw->drawable);
|
||||
drw->drawable = XCreatePixmap(drw->dpy, drw->root, w, h,
|
||||
DefaultDepth(drw->dpy, drw->screen));
|
||||
}
|
||||
|
||||
void drw_free(Drw *drw) {
|
||||
XFreePixmap(drw->dpy, drw->drawable);
|
||||
XFreeGC(drw->dpy, drw->gc);
|
||||
drw_fontset_free(drw->fonts);
|
||||
free(drw);
|
||||
}
|
||||
|
||||
/* This function is an implementation detail. Library users should use
|
||||
* drw_fontset_create instead.
|
||||
*/
|
||||
static Fnt *xfont_create(Drw *drw, const char *fontname,
|
||||
FcPattern *fontpattern) {
|
||||
Fnt *font;
|
||||
XftFont *xfont = NULL;
|
||||
FcPattern *pattern = NULL;
|
||||
|
||||
if (fontname) {
|
||||
/* Using the pattern found at font->xfont->pattern does not yield the
|
||||
* same substitution results as using the pattern returned by
|
||||
* FcNameParse; using the latter results in the desired fallback
|
||||
* behaviour whereas the former just results in missing-character
|
||||
* rectangles being drawn, at least with some fonts. */
|
||||
if (!(xfont = XftFontOpenName(drw->dpy, drw->screen, fontname))) {
|
||||
fprintf(stderr, "error, cannot load font from name: '%s'\n", fontname);
|
||||
return NULL;
|
||||
}
|
||||
if (!(pattern = FcNameParse((FcChar8 *)fontname))) {
|
||||
fprintf(stderr, "error, cannot parse font name to pattern: '%s'\n",
|
||||
fontname);
|
||||
XftFontClose(drw->dpy, xfont);
|
||||
return NULL;
|
||||
}
|
||||
} else if (fontpattern) {
|
||||
if (!(xfont = XftFontOpenPattern(drw->dpy, fontpattern))) {
|
||||
fprintf(stderr, "error, cannot load font from pattern.\n");
|
||||
return NULL;
|
||||
}
|
||||
} else {
|
||||
die("no font specified.");
|
||||
}
|
||||
|
||||
font = ecalloc(1, sizeof(Fnt));
|
||||
font->xfont = xfont;
|
||||
font->pattern = pattern;
|
||||
font->h = xfont->ascent + xfont->descent;
|
||||
font->dpy = drw->dpy;
|
||||
|
||||
return font;
|
||||
}
|
||||
|
||||
static void xfont_free(Fnt *font) {
|
||||
if (!font)
|
||||
return;
|
||||
if (font->pattern)
|
||||
FcPatternDestroy(font->pattern);
|
||||
XftFontClose(font->dpy, font->xfont);
|
||||
free(font);
|
||||
}
|
||||
|
||||
Fnt *drw_fontset_create(Drw *drw, const char *fonts[], size_t fontcount) {
|
||||
Fnt *cur, *ret = NULL;
|
||||
size_t i;
|
||||
|
||||
if (!drw || !fonts)
|
||||
return NULL;
|
||||
|
||||
for (i = 1; i <= fontcount; i++) {
|
||||
if ((cur = xfont_create(drw, fonts[fontcount - i], NULL))) {
|
||||
cur->next = ret;
|
||||
ret = cur;
|
||||
}
|
||||
}
|
||||
return (drw->fonts = ret);
|
||||
}
|
||||
|
||||
void drw_fontset_free(Fnt *font) {
|
||||
if (font) {
|
||||
drw_fontset_free(font->next);
|
||||
xfont_free(font);
|
||||
}
|
||||
}
|
||||
|
||||
void drw_clr_create(Drw *drw, Clr *dest, const char *clrname) {
|
||||
if (!drw || !dest || !clrname)
|
||||
return;
|
||||
|
||||
if (!XftColorAllocName(drw->dpy, DefaultVisual(drw->dpy, drw->screen),
|
||||
DefaultColormap(drw->dpy, drw->screen), clrname, dest))
|
||||
die("error, cannot allocate color '%s'", clrname);
|
||||
}
|
||||
|
||||
/* Wrapper to create color schemes. The caller has to call free(3) on the
|
||||
* returned color scheme when done using it. */
|
||||
Clr *drw_scm_create(Drw *drw, const char *clrnames[], size_t clrcount) {
|
||||
size_t i;
|
||||
Clr *ret;
|
||||
|
||||
/* need at least two colors for a scheme */
|
||||
if (!drw || !clrnames || clrcount < 2 ||
|
||||
!(ret = ecalloc(clrcount, sizeof(XftColor))))
|
||||
return NULL;
|
||||
|
||||
for (i = 0; i < clrcount; i++)
|
||||
drw_clr_create(drw, &ret[i], clrnames[i]);
|
||||
return ret;
|
||||
}
|
||||
|
||||
void drw_setfontset(Drw *drw, Fnt *set) {
|
||||
if (drw)
|
||||
drw->fonts = set;
|
||||
}
|
||||
|
||||
void drw_setscheme(Drw *drw, Clr *scm) {
|
||||
if (drw)
|
||||
drw->scheme = scm;
|
||||
}
|
||||
|
||||
void drw_rect(Drw *drw, int x, int y, unsigned int w, unsigned int h,
|
||||
int filled, int invert) {
|
||||
if (!drw || !drw->scheme)
|
||||
return;
|
||||
XSetForeground(drw->dpy, drw->gc,
|
||||
invert ? drw->scheme[ColBg].pixel : drw->scheme[ColFg].pixel);
|
||||
if (filled)
|
||||
XFillRectangle(drw->dpy, drw->drawable, drw->gc, x, y, w, h);
|
||||
else
|
||||
XDrawRectangle(drw->dpy, drw->drawable, drw->gc, x, y, w - 1, h - 1);
|
||||
}
|
||||
|
||||
int drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h,
|
||||
unsigned int lpad, const char *text, int invert) {
|
||||
int i, ty, ellipsis_x = 0;
|
||||
unsigned int tmpw, ew, ellipsis_w = 0, ellipsis_len;
|
||||
XftDraw *d = NULL;
|
||||
Fnt *usedfont, *curfont, *nextfont;
|
||||
int utf8strlen, utf8charlen, render = x || y || w || h;
|
||||
long utf8codepoint = 0;
|
||||
const char *utf8str;
|
||||
FcCharSet *fccharset;
|
||||
FcPattern *fcpattern;
|
||||
FcPattern *match;
|
||||
XftResult result;
|
||||
int charexists = 0, overflow = 0;
|
||||
/* keep track of a couple codepoints for which we have no match. */
|
||||
enum { nomatches_len = 64 };
|
||||
static struct {
|
||||
long codepoint[nomatches_len];
|
||||
unsigned int idx;
|
||||
} nomatches;
|
||||
static unsigned int ellipsis_width = 0;
|
||||
|
||||
if (!drw || (render && (!drw->scheme || !w)) || !text || !drw->fonts)
|
||||
return 0;
|
||||
|
||||
if (!render) {
|
||||
w = invert ? invert : ~invert;
|
||||
} else {
|
||||
XSetForeground(drw->dpy, drw->gc,
|
||||
drw->scheme[invert ? ColFg : ColBg].pixel);
|
||||
XFillRectangle(drw->dpy, drw->drawable, drw->gc, x, y, w, h);
|
||||
d = XftDrawCreate(drw->dpy, drw->drawable,
|
||||
DefaultVisual(drw->dpy, drw->screen),
|
||||
DefaultColormap(drw->dpy, drw->screen));
|
||||
x += lpad;
|
||||
w -= lpad;
|
||||
}
|
||||
|
||||
usedfont = drw->fonts;
|
||||
if (!ellipsis_width && render)
|
||||
ellipsis_width = drw_fontset_getwidth(drw, "...");
|
||||
while (1) {
|
||||
ew = ellipsis_len = utf8strlen = 0;
|
||||
utf8str = text;
|
||||
nextfont = NULL;
|
||||
while (*text) {
|
||||
utf8charlen = utf8decode(text, &utf8codepoint, UTF_SIZ);
|
||||
for (curfont = drw->fonts; curfont; curfont = curfont->next) {
|
||||
charexists = charexists ||
|
||||
XftCharExists(drw->dpy, curfont->xfont, utf8codepoint);
|
||||
if (charexists) {
|
||||
drw_font_getexts(curfont, text, utf8charlen, &tmpw, NULL);
|
||||
if (ew + ellipsis_width <= w) {
|
||||
/* keep track where the ellipsis still fits */
|
||||
ellipsis_x = x + ew;
|
||||
ellipsis_w = w - ew;
|
||||
ellipsis_len = utf8strlen;
|
||||
}
|
||||
|
||||
if (ew + tmpw > w) {
|
||||
overflow = 1;
|
||||
/* called from drw_fontset_getwidth_clamp():
|
||||
* it wants the width AFTER the overflow
|
||||
*/
|
||||
if (!render)
|
||||
x += tmpw;
|
||||
else
|
||||
utf8strlen = ellipsis_len;
|
||||
} else if (curfont == usedfont) {
|
||||
utf8strlen += utf8charlen;
|
||||
text += utf8charlen;
|
||||
ew += tmpw;
|
||||
} else {
|
||||
nextfont = curfont;
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (overflow || !charexists || nextfont)
|
||||
break;
|
||||
else
|
||||
charexists = 0;
|
||||
}
|
||||
|
||||
if (utf8strlen) {
|
||||
if (render) {
|
||||
ty = y + (h - usedfont->h) / 2 + usedfont->xfont->ascent;
|
||||
XftDrawStringUtf8(d, &drw->scheme[invert ? ColBg : ColFg],
|
||||
usedfont->xfont, x, ty, (XftChar8 *)utf8str,
|
||||
utf8strlen);
|
||||
}
|
||||
x += ew;
|
||||
w -= ew;
|
||||
}
|
||||
if (render && overflow)
|
||||
drw_text(drw, ellipsis_x, y, ellipsis_w, h, 0, "...", invert);
|
||||
|
||||
if (!*text || overflow) {
|
||||
break;
|
||||
} else if (nextfont) {
|
||||
charexists = 0;
|
||||
usedfont = nextfont;
|
||||
} else {
|
||||
/* Regardless of whether or not a fallback font is found, the
|
||||
* character must be drawn. */
|
||||
charexists = 1;
|
||||
|
||||
for (i = 0; i < nomatches_len; ++i) {
|
||||
/* avoid calling XftFontMatch if we know we won't find a match */
|
||||
if (utf8codepoint == nomatches.codepoint[i])
|
||||
goto no_match;
|
||||
}
|
||||
|
||||
fccharset = FcCharSetCreate();
|
||||
FcCharSetAddChar(fccharset, utf8codepoint);
|
||||
|
||||
if (!drw->fonts->pattern) {
|
||||
/* Refer to the comment in xfont_create for more information. */
|
||||
die("the first font in the cache must be loaded from a font string.");
|
||||
}
|
||||
|
||||
fcpattern = FcPatternDuplicate(drw->fonts->pattern);
|
||||
FcPatternAddCharSet(fcpattern, FC_CHARSET, fccharset);
|
||||
FcPatternAddBool(fcpattern, FC_SCALABLE, FcTrue);
|
||||
|
||||
FcConfigSubstitute(NULL, fcpattern, FcMatchPattern);
|
||||
FcDefaultSubstitute(fcpattern);
|
||||
match = XftFontMatch(drw->dpy, drw->screen, fcpattern, &result);
|
||||
|
||||
FcCharSetDestroy(fccharset);
|
||||
FcPatternDestroy(fcpattern);
|
||||
|
||||
if (match) {
|
||||
usedfont = xfont_create(drw, NULL, match);
|
||||
if (usedfont &&
|
||||
XftCharExists(drw->dpy, usedfont->xfont, utf8codepoint)) {
|
||||
for (curfont = drw->fonts; curfont->next; curfont = curfont->next)
|
||||
; /* NOP */
|
||||
curfont->next = usedfont;
|
||||
} else {
|
||||
xfont_free(usedfont);
|
||||
nomatches.codepoint[++nomatches.idx % nomatches_len] = utf8codepoint;
|
||||
no_match:
|
||||
usedfont = drw->fonts;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (d)
|
||||
XftDrawDestroy(d);
|
||||
|
||||
return x + (render ? w : 0);
|
||||
}
|
||||
|
||||
void drw_map(Drw *drw, Window win, int x, int y, unsigned int w,
|
||||
unsigned int h) {
|
||||
if (!drw)
|
||||
return;
|
||||
|
||||
XCopyArea(drw->dpy, drw->drawable, win, drw->gc, x, y, w, h, x, y);
|
||||
XSync(drw->dpy, False);
|
||||
}
|
||||
|
||||
unsigned int drw_fontset_getwidth(Drw *drw, const char *text) {
|
||||
if (!drw || !drw->fonts || !text)
|
||||
return 0;
|
||||
return drw_text(drw, 0, 0, 0, 0, 0, text, 0);
|
||||
}
|
||||
|
||||
unsigned int drw_fontset_getwidth_clamp(Drw *drw, const char *text,
|
||||
unsigned int n) {
|
||||
unsigned int tmp = 0;
|
||||
if (drw && drw->fonts && text && n)
|
||||
tmp = drw_text(drw, 0, 0, 0, 0, 0, text, n);
|
||||
return MIN(n, tmp);
|
||||
}
|
||||
|
||||
void drw_font_getexts(Fnt *font, const char *text, unsigned int len,
|
||||
unsigned int *w, unsigned int *h) {
|
||||
XGlyphInfo ext;
|
||||
|
||||
if (!font || !text)
|
||||
return;
|
||||
|
||||
XftTextExtentsUtf8(font->dpy, font->xfont, (XftChar8 *)text, len, &ext);
|
||||
if (w)
|
||||
*w = ext.xOff;
|
||||
if (h)
|
||||
*h = font->h;
|
||||
}
|
||||
|
||||
Cur *drw_cur_create(Drw *drw, int shape) {
|
||||
Cur *cur;
|
||||
|
||||
if (!drw || !(cur = ecalloc(1, sizeof(Cur))))
|
||||
return NULL;
|
||||
|
||||
cur->cursor = XCreateFontCursor(drw->dpy, shape);
|
||||
|
||||
return cur;
|
||||
}
|
||||
|
||||
void drw_cur_free(Drw *drw, Cur *cursor) {
|
||||
if (!cursor)
|
||||
return;
|
||||
|
||||
XFreeCursor(drw->dpy, cursor->cursor);
|
||||
free(cursor);
|
||||
}
|
64
modules/system/nix/x/dwm/source/dwm/drw.h
Normal file
@ -0,0 +1,64 @@
|
||||
/* See LICENSE file for copyright and license details. */
|
||||
|
||||
typedef struct {
|
||||
Cursor cursor;
|
||||
} Cur;
|
||||
|
||||
typedef struct Fnt {
|
||||
Display *dpy;
|
||||
unsigned int h;
|
||||
XftFont *xfont;
|
||||
FcPattern *pattern;
|
||||
struct Fnt *next;
|
||||
} Fnt;
|
||||
|
||||
enum { ColFg, ColBg, ColBorder }; /* Clr scheme index */
|
||||
typedef XftColor Clr;
|
||||
|
||||
typedef struct {
|
||||
unsigned int w, h;
|
||||
Display *dpy;
|
||||
int screen;
|
||||
Window root;
|
||||
Drawable drawable;
|
||||
GC gc;
|
||||
Clr *scheme;
|
||||
Fnt *fonts;
|
||||
} Drw;
|
||||
|
||||
/* Drawable abstraction */
|
||||
Drw *drw_create(Display *dpy, int screen, Window win, unsigned int w,
|
||||
unsigned int h);
|
||||
void drw_resize(Drw *drw, unsigned int w, unsigned int h);
|
||||
void drw_free(Drw *drw);
|
||||
|
||||
/* Fnt abstraction */
|
||||
Fnt *drw_fontset_create(Drw *drw, const char *fonts[], size_t fontcount);
|
||||
void drw_fontset_free(Fnt *set);
|
||||
unsigned int drw_fontset_getwidth(Drw *drw, const char *text);
|
||||
unsigned int drw_fontset_getwidth_clamp(Drw *drw, const char *text,
|
||||
unsigned int n);
|
||||
void drw_font_getexts(Fnt *font, const char *text, unsigned int len,
|
||||
unsigned int *w, unsigned int *h);
|
||||
|
||||
/* Colorscheme abstraction */
|
||||
void drw_clr_create(Drw *drw, Clr *dest, const char *clrname);
|
||||
Clr *drw_scm_create(Drw *drw, const char *clrnames[], size_t clrcount);
|
||||
|
||||
/* Cursor abstraction */
|
||||
Cur *drw_cur_create(Drw *drw, int shape);
|
||||
void drw_cur_free(Drw *drw, Cur *cursor);
|
||||
|
||||
/* Drawing context manipulation */
|
||||
void drw_setfontset(Drw *drw, Fnt *set);
|
||||
void drw_setscheme(Drw *drw, Clr *scm);
|
||||
|
||||
/* Drawing functions */
|
||||
void drw_rect(Drw *drw, int x, int y, unsigned int w, unsigned int h,
|
||||
int filled, int invert);
|
||||
int drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h,
|
||||
unsigned int lpad, const char *text, int invert);
|
||||
|
||||
/* Map functions */
|
||||
void drw_map(Drw *drw, Window win, int x, int y, unsigned int w,
|
||||
unsigned int h);
|
176
modules/system/nix/x/dwm/source/dwm/dwm.1
Normal file
@ -0,0 +1,176 @@
|
||||
.TH DWM 1 dwm\-VERSION
|
||||
.SH NAME
|
||||
dwm \- dynamic window manager
|
||||
.SH SYNOPSIS
|
||||
.B dwm
|
||||
.RB [ \-v ]
|
||||
.SH DESCRIPTION
|
||||
dwm is a dynamic window manager for X. It manages windows in tiled, monocle
|
||||
and floating layouts. Either layout can be applied dynamically, optimising the
|
||||
environment for the application in use and the task performed.
|
||||
.P
|
||||
In tiled layouts windows are managed in a master and stacking area. The master
|
||||
area on the left contains one window by default, and the stacking area on the
|
||||
right contains all other windows. The number of master area windows can be
|
||||
adjusted from zero to an arbitrary number. In monocle layout all windows are
|
||||
maximised to the screen size. In floating layout windows can be resized and
|
||||
moved freely. Dialog windows are always managed floating, regardless of the
|
||||
layout applied.
|
||||
.P
|
||||
Windows are grouped by tags. Each window can be tagged with one or multiple
|
||||
tags. Selecting certain tags displays all windows with these tags.
|
||||
.P
|
||||
Each screen contains a small status bar which displays all available tags, the
|
||||
layout, the title of the focused window, and the text read from the root window
|
||||
name property, if the screen is focused. A floating window is indicated with an
|
||||
empty square and a maximised floating window is indicated with a filled square
|
||||
before the windows title. The selected tags are indicated with a different
|
||||
color. The tags of the focused window are indicated with a filled square in the
|
||||
top left corner. The tags which are applied to one or more windows are
|
||||
indicated with an empty square in the top left corner.
|
||||
.P
|
||||
dwm draws a small border around windows to indicate the focus state.
|
||||
.SH OPTIONS
|
||||
.TP
|
||||
.B \-v
|
||||
prints version information to stderr, then exits.
|
||||
.SH USAGE
|
||||
.SS Status bar
|
||||
.TP
|
||||
.B X root window name
|
||||
is read and displayed in the status text area. It can be set with the
|
||||
.BR xsetroot (1)
|
||||
command.
|
||||
.TP
|
||||
.B Button1
|
||||
click on a tag label to display all windows with that tag, click on the layout
|
||||
label toggles between tiled and floating layout.
|
||||
.TP
|
||||
.B Button3
|
||||
click on a tag label adds/removes all windows with that tag to/from the view.
|
||||
.TP
|
||||
.B Mod1\-Button1
|
||||
click on a tag label applies that tag to the focused window.
|
||||
.TP
|
||||
.B Mod1\-Button3
|
||||
click on a tag label adds/removes that tag to/from the focused window.
|
||||
.SS Keyboard commands
|
||||
.TP
|
||||
.B Mod1\-Shift\-Return
|
||||
Start
|
||||
.BR st(1).
|
||||
.TP
|
||||
.B Mod1\-p
|
||||
Spawn
|
||||
.BR dmenu(1)
|
||||
for launching other programs.
|
||||
.TP
|
||||
.B Mod1\-,
|
||||
Focus previous screen, if any.
|
||||
.TP
|
||||
.B Mod1\-.
|
||||
Focus next screen, if any.
|
||||
.TP
|
||||
.B Mod1\-Shift\-,
|
||||
Send focused window to previous screen, if any.
|
||||
.TP
|
||||
.B Mod1\-Shift\-.
|
||||
Send focused window to next screen, if any.
|
||||
.TP
|
||||
.B Mod1\-b
|
||||
Toggles bar on and off.
|
||||
.TP
|
||||
.B Mod1\-t
|
||||
Sets tiled layout.
|
||||
.TP
|
||||
.B Mod1\-f
|
||||
Sets floating layout.
|
||||
.TP
|
||||
.B Mod1\-m
|
||||
Sets monocle layout.
|
||||
.TP
|
||||
.B Mod1\-space
|
||||
Toggles between current and previous layout.
|
||||
.TP
|
||||
.B Mod1\-j
|
||||
Focus next window.
|
||||
.TP
|
||||
.B Mod1\-k
|
||||
Focus previous window.
|
||||
.TP
|
||||
.B Mod1\-i
|
||||
Increase number of windows in master area.
|
||||
.TP
|
||||
.B Mod1\-d
|
||||
Decrease number of windows in master area.
|
||||
.TP
|
||||
.B Mod1\-l
|
||||
Increase master area size.
|
||||
.TP
|
||||
.B Mod1\-h
|
||||
Decrease master area size.
|
||||
.TP
|
||||
.B Mod1\-Return
|
||||
Zooms/cycles focused window to/from master area (tiled layouts only).
|
||||
.TP
|
||||
.B Mod1\-Shift\-c
|
||||
Close focused window.
|
||||
.TP
|
||||
.B Mod1\-Shift\-space
|
||||
Toggle focused window between tiled and floating state.
|
||||
.TP
|
||||
.B Mod1\-Tab
|
||||
Toggles to the previously selected tags.
|
||||
.TP
|
||||
.B Mod1\-Shift\-[1..n]
|
||||
Apply nth tag to focused window.
|
||||
.TP
|
||||
.B Mod1\-Shift\-0
|
||||
Apply all tags to focused window.
|
||||
.TP
|
||||
.B Mod1\-Control\-Shift\-[1..n]
|
||||
Add/remove nth tag to/from focused window.
|
||||
.TP
|
||||
.B Mod1\-[1..n]
|
||||
View all windows with nth tag.
|
||||
.TP
|
||||
.B Mod1\-0
|
||||
View all windows with any tag.
|
||||
.TP
|
||||
.B Mod1\-Control\-[1..n]
|
||||
Add/remove all windows with nth tag to/from the view.
|
||||
.TP
|
||||
.B Mod1\-Shift\-q
|
||||
Quit dwm.
|
||||
.SS Mouse commands
|
||||
.TP
|
||||
.B Mod1\-Button1
|
||||
Move focused window while dragging. Tiled windows will be toggled to the floating state.
|
||||
.TP
|
||||
.B Mod1\-Button2
|
||||
Toggles focused window between floating and tiled state.
|
||||
.TP
|
||||
.B Mod1\-Button3
|
||||
Resize focused window while dragging. Tiled windows will be toggled to the floating state.
|
||||
.SH CUSTOMIZATION
|
||||
dwm is customized by creating a custom config.h and (re)compiling the source
|
||||
code. This keeps it fast, secure and simple.
|
||||
.SH SEE ALSO
|
||||
.BR dmenu (1),
|
||||
.BR st (1)
|
||||
.SH ISSUES
|
||||
Java applications which use the XToolkit/XAWT backend may draw grey windows
|
||||
only. The XToolkit/XAWT backend breaks ICCCM-compliance in recent JDK 1.5 and early
|
||||
JDK 1.6 versions, because it assumes a reparenting window manager. Possible workarounds
|
||||
are using JDK 1.4 (which doesn't contain the XToolkit/XAWT backend) or setting the
|
||||
environment variable
|
||||
.BR AWT_TOOLKIT=MToolkit
|
||||
(to use the older Motif backend instead) or running
|
||||
.B xprop -root -f _NET_WM_NAME 32a -set _NET_WM_NAME LG3D
|
||||
or
|
||||
.B wmname LG3D
|
||||
(to pretend that a non-reparenting window manager is running that the
|
||||
XToolkit/XAWT backend can recognize) or when using OpenJDK setting the environment variable
|
||||
.BR _JAVA_AWT_WM_NONREPARENTING=1 .
|
||||
.SH BUGS
|
||||
Send all bug reports with a patch to hackers@suckless.org.
|
2209
modules/system/nix/x/dwm/source/dwm/dwm.c
Normal file
42
modules/system/nix/x/dwm/source/dwm/transient.c
Normal file
@ -0,0 +1,42 @@
|
||||
/* cc transient.c -o transient -lX11 */
|
||||
|
||||
#include <X11/Xlib.h>
|
||||
#include <X11/Xutil.h>
|
||||
#include <stdlib.h>
|
||||
#include <unistd.h>
|
||||
|
||||
int main(void) {
|
||||
Display *d;
|
||||
Window r, f, t = None;
|
||||
XSizeHints h;
|
||||
XEvent e;
|
||||
|
||||
d = XOpenDisplay(NULL);
|
||||
if (!d)
|
||||
exit(1);
|
||||
r = DefaultRootWindow(d);
|
||||
|
||||
f = XCreateSimpleWindow(d, r, 100, 100, 400, 400, 0, 0, 0);
|
||||
h.min_width = h.max_width = h.min_height = h.max_height = 400;
|
||||
h.flags = PMinSize | PMaxSize;
|
||||
XSetWMNormalHints(d, f, &h);
|
||||
XStoreName(d, f, "floating");
|
||||
XMapWindow(d, f);
|
||||
|
||||
XSelectInput(d, f, ExposureMask);
|
||||
while (1) {
|
||||
XNextEvent(d, &e);
|
||||
|
||||
if (t == None) {
|
||||
sleep(5);
|
||||
t = XCreateSimpleWindow(d, r, 50, 50, 100, 100, 0, 0, 0);
|
||||
XSetTransientForHint(d, t, f);
|
||||
XStoreName(d, t, "transient");
|
||||
XMapWindow(d, t);
|
||||
XSelectInput(d, t, ExposureMask);
|
||||
}
|
||||
}
|
||||
|
||||
XCloseDisplay(d);
|
||||
exit(0);
|
||||
}
|
32
modules/system/nix/x/dwm/source/dwm/util.c
Normal file
@ -0,0 +1,32 @@
|
||||
/* See LICENSE file for copyright and license details. */
|
||||
#include <stdarg.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
#include "util.h"
|
||||
|
||||
void die(const char *fmt, ...) {
|
||||
va_list ap;
|
||||
|
||||
va_start(ap, fmt);
|
||||
vfprintf(stderr, fmt, ap);
|
||||
va_end(ap);
|
||||
|
||||
if (fmt[0] && fmt[strlen(fmt) - 1] == ':') {
|
||||
fputc(' ', stderr);
|
||||
perror(NULL);
|
||||
} else {
|
||||
fputc('\n', stderr);
|
||||
}
|
||||
|
||||
exit(1);
|
||||
}
|
||||
|
||||
void *ecalloc(size_t nmemb, size_t size) {
|
||||
void *p;
|
||||
|
||||
if (!(p = calloc(nmemb, size)))
|
||||
die("calloc:");
|
||||
return p;
|
||||
}
|
8
modules/system/nix/x/dwm/source/dwm/util.h
Normal file
@ -0,0 +1,8 @@
|
||||
/* See LICENSE file for copyright and license details. */
|
||||
|
||||
#define MAX(A, B) ((A) > (B) ? (A) : (B))
|
||||
#define MIN(A, B) ((A) < (B) ? (A) : (B))
|
||||
#define BETWEEN(X, A, B) ((A) <= (X) && (X) <= (B))
|
||||
|
||||
void die(const char *fmt, ...);
|
||||
void *ecalloc(size_t nmemb, size_t size);
|
778
modules/system/nix/x/dwm/source/dwm/vanitygaps.c
Normal file
@ -0,0 +1,778 @@
|
||||
/* Key binding functions */
|
||||
static void defaultgaps(const Arg *arg);
|
||||
static void incrgaps(const Arg *arg);
|
||||
static void incrigaps(const Arg *arg);
|
||||
static void incrogaps(const Arg *arg);
|
||||
static void incrohgaps(const Arg *arg);
|
||||
static void incrovgaps(const Arg *arg);
|
||||
static void incrihgaps(const Arg *arg);
|
||||
static void incrivgaps(const Arg *arg);
|
||||
static void togglegaps(const Arg *arg);
|
||||
/* Layouts (delete the ones you do not need) */
|
||||
static void bstack(Monitor *m);
|
||||
static void bstackhoriz(Monitor *m);
|
||||
static void centeredmaster(Monitor *m);
|
||||
static void centeredfloatingmaster(Monitor *m);
|
||||
static void deck(Monitor *m);
|
||||
static void dwindle(Monitor *m);
|
||||
static void fibonacci(Monitor *m, int s);
|
||||
static void grid(Monitor *m);
|
||||
static void nrowgrid(Monitor *m);
|
||||
static void spiral(Monitor *m);
|
||||
static void tile(Monitor *m);
|
||||
/* Internals */
|
||||
static void getgaps(Monitor *m, int *oh, int *ov, int *ih, int *iv,
|
||||
unsigned int *nc);
|
||||
static void getfacts(Monitor *m, int msize, int ssize, float *mf, float *sf,
|
||||
int *mr, int *sr);
|
||||
static void setgaps(int oh, int ov, int ih, int iv);
|
||||
|
||||
/* Settings */
|
||||
#if !PERTAG_PATCH
|
||||
static int enablegaps = 1;
|
||||
#endif // PERTAG_PATCH
|
||||
|
||||
void setgaps(int oh, int ov, int ih, int iv) {
|
||||
if (oh < 0)
|
||||
oh = 0;
|
||||
if (ov < 0)
|
||||
ov = 0;
|
||||
if (ih < 0)
|
||||
ih = 0;
|
||||
if (iv < 0)
|
||||
iv = 0;
|
||||
|
||||
selmon->gappoh = oh;
|
||||
selmon->gappov = ov;
|
||||
selmon->gappih = ih;
|
||||
selmon->gappiv = iv;
|
||||
arrange(selmon);
|
||||
}
|
||||
|
||||
void togglegaps(const Arg *arg) {
|
||||
#if PERTAG_PATCH
|
||||
selmon->pertag->enablegaps[selmon->pertag->curtag] =
|
||||
!selmon->pertag->enablegaps[selmon->pertag->curtag];
|
||||
#else
|
||||
enablegaps = !enablegaps;
|
||||
#endif // PERTAG_PATCH
|
||||
arrange(NULL);
|
||||
}
|
||||
|
||||
void defaultgaps(const Arg *arg) { setgaps(gappoh, gappov, gappih, gappiv); }
|
||||
|
||||
void incrgaps(const Arg *arg) {
|
||||
setgaps(selmon->gappoh + arg->i, selmon->gappov + arg->i,
|
||||
selmon->gappih + arg->i, selmon->gappiv + arg->i);
|
||||
}
|
||||
|
||||
void incrigaps(const Arg *arg) {
|
||||
setgaps(selmon->gappoh, selmon->gappov, selmon->gappih + arg->i,
|
||||
selmon->gappiv + arg->i);
|
||||
}
|
||||
|
||||
void incrogaps(const Arg *arg) {
|
||||
setgaps(selmon->gappoh + arg->i, selmon->gappov + arg->i, selmon->gappih,
|
||||
selmon->gappiv);
|
||||
}
|
||||
|
||||
void incrohgaps(const Arg *arg) {
|
||||
setgaps(selmon->gappoh + arg->i, selmon->gappov, selmon->gappih,
|
||||
selmon->gappiv);
|
||||
}
|
||||
|
||||
void incrovgaps(const Arg *arg) {
|
||||
setgaps(selmon->gappoh, selmon->gappov + arg->i, selmon->gappih,
|
||||
selmon->gappiv);
|
||||
}
|
||||
|
||||
void incrihgaps(const Arg *arg) {
|
||||
setgaps(selmon->gappoh, selmon->gappov, selmon->gappih + arg->i,
|
||||
selmon->gappiv);
|
||||
}
|
||||
|
||||
void incrivgaps(const Arg *arg) {
|
||||
setgaps(selmon->gappoh, selmon->gappov, selmon->gappih,
|
||||
selmon->gappiv + arg->i);
|
||||
}
|
||||
|
||||
void getgaps(Monitor *m, int *oh, int *ov, int *ih, int *iv, unsigned int *nc) {
|
||||
unsigned int n, oe, ie;
|
||||
#if PERTAG_PATCH
|
||||
oe = ie = selmon->pertag->enablegaps[selmon->pertag->curtag];
|
||||
#else
|
||||
oe = ie = enablegaps;
|
||||
#endif // PERTAG_PATCH
|
||||
Client *c;
|
||||
|
||||
for (n = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), n++)
|
||||
;
|
||||
if (smartgaps && n == 1) {
|
||||
oe = 0; // outer gaps disabled when only one client
|
||||
}
|
||||
|
||||
*oh = m->gappoh * oe; // outer horizontal gap
|
||||
*ov = m->gappov * oe; // outer vertical gap
|
||||
*ih = m->gappih * ie; // inner horizontal gap
|
||||
*iv = m->gappiv * ie; // inner vertical gap
|
||||
*nc = n; // number of clients
|
||||
}
|
||||
|
||||
void getfacts(Monitor *m, int msize, int ssize, float *mf, float *sf, int *mr,
|
||||
int *sr) {
|
||||
unsigned int n;
|
||||
float mfacts = 0, sfacts = 0;
|
||||
int mtotal = 0, stotal = 0;
|
||||
Client *c;
|
||||
|
||||
for (n = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), n++)
|
||||
if (n < m->nmaster)
|
||||
mfacts += c->cfact;
|
||||
else
|
||||
sfacts += c->cfact;
|
||||
|
||||
for (n = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), n++)
|
||||
if (n < m->nmaster)
|
||||
mtotal += msize * (c->cfact / mfacts);
|
||||
else
|
||||
stotal += ssize * (c->cfact / sfacts);
|
||||
|
||||
*mf = mfacts; // total factor of master area
|
||||
*sf = sfacts; // total factor of stack area
|
||||
*mr = msize -
|
||||
mtotal; // the remainder (rest) of pixels after a cfacts master split
|
||||
*sr = ssize -
|
||||
stotal; // the remainder (rest) of pixels after a cfacts stack split
|
||||
}
|
||||
|
||||
/***
|
||||
* Layouts
|
||||
*/
|
||||
|
||||
/*
|
||||
* Bottomstack layout + gaps
|
||||
* https://dwm.suckless.org/patches/bottomstack/
|
||||
*/
|
||||
static void bstack(Monitor *m) {
|
||||
unsigned int i, n;
|
||||
int oh, ov, ih, iv;
|
||||
int mx = 0, my = 0, mh = 0, mw = 0;
|
||||
int sx = 0, sy = 0, sh = 0, sw = 0;
|
||||
float mfacts, sfacts;
|
||||
int mrest, srest;
|
||||
Client *c;
|
||||
|
||||
getgaps(m, &oh, &ov, &ih, &iv, &n);
|
||||
if (n == 0)
|
||||
return;
|
||||
|
||||
sx = mx = m->wx + ov;
|
||||
sy = my = m->wy + oh;
|
||||
sh = mh = m->wh - 2 * oh;
|
||||
mw = m->ww - 2 * ov - iv * (MIN(n, m->nmaster) - 1);
|
||||
sw = m->ww - 2 * ov - iv * (n - m->nmaster - 1);
|
||||
|
||||
if (m->nmaster && n > m->nmaster) {
|
||||
sh = (mh - ih) * (1 - m->mfact);
|
||||
mh = mh - ih - sh;
|
||||
sx = mx;
|
||||
sy = my + mh + ih;
|
||||
}
|
||||
|
||||
getfacts(m, mw, sw, &mfacts, &sfacts, &mrest, &srest);
|
||||
|
||||
for (i = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), i++) {
|
||||
if (i < m->nmaster) {
|
||||
resize(c, mx, my,
|
||||
mw * (c->cfact / mfacts) + (i < mrest ? 1 : 0) - (2 * c->bw),
|
||||
mh - (2 * c->bw), 0);
|
||||
mx += WIDTH(c) + iv;
|
||||
} else {
|
||||
resize(c, sx, sy,
|
||||
sw * (c->cfact / sfacts) + ((i - m->nmaster) < srest ? 1 : 0) -
|
||||
(2 * c->bw),
|
||||
sh - (2 * c->bw), 0);
|
||||
sx += WIDTH(c) + iv;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static void bstackhoriz(Monitor *m) {
|
||||
unsigned int i, n;
|
||||
int oh, ov, ih, iv;
|
||||
int mx = 0, my = 0, mh = 0, mw = 0;
|
||||
int sx = 0, sy = 0, sh = 0, sw = 0;
|
||||
float mfacts, sfacts;
|
||||
int mrest, srest;
|
||||
Client *c;
|
||||
|
||||
getgaps(m, &oh, &ov, &ih, &iv, &n);
|
||||
if (n == 0)
|
||||
return;
|
||||
|
||||
sx = mx = m->wx + ov;
|
||||
sy = my = m->wy + oh;
|
||||
mh = m->wh - 2 * oh;
|
||||
sh = m->wh - 2 * oh - ih * (n - m->nmaster - 1);
|
||||
mw = m->ww - 2 * ov - iv * (MIN(n, m->nmaster) - 1);
|
||||
sw = m->ww - 2 * ov;
|
||||
|
||||
if (m->nmaster && n > m->nmaster) {
|
||||
sh = (mh - ih) * (1 - m->mfact);
|
||||
mh = mh - ih - sh;
|
||||
sy = my + mh + ih;
|
||||
sh = m->wh - mh - 2 * oh - ih * (n - m->nmaster);
|
||||
}
|
||||
|
||||
getfacts(m, mw, sh, &mfacts, &sfacts, &mrest, &srest);
|
||||
|
||||
for (i = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), i++) {
|
||||
if (i < m->nmaster) {
|
||||
resize(c, mx, my,
|
||||
mw * (c->cfact / mfacts) + (i < mrest ? 1 : 0) - (2 * c->bw),
|
||||
mh - (2 * c->bw), 0);
|
||||
mx += WIDTH(c) + iv;
|
||||
} else {
|
||||
resize(c, sx, sy, sw - (2 * c->bw),
|
||||
sh * (c->cfact / sfacts) + ((i - m->nmaster) < srest ? 1 : 0) -
|
||||
(2 * c->bw),
|
||||
0);
|
||||
sy += HEIGHT(c) + ih;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Centred master layout + gaps
|
||||
* https://dwm.suckless.org/patches/centeredmaster/
|
||||
*/
|
||||
void centeredmaster(Monitor *m) {
|
||||
unsigned int i, n;
|
||||
int oh, ov, ih, iv;
|
||||
int mx = 0, my = 0, mh = 0, mw = 0;
|
||||
int lx = 0, ly = 0, lw = 0, lh = 0;
|
||||
int rx = 0, ry = 0, rw = 0, rh = 0;
|
||||
float mfacts = 0, lfacts = 0, rfacts = 0;
|
||||
int mtotal = 0, ltotal = 0, rtotal = 0;
|
||||
int mrest = 0, lrest = 0, rrest = 0;
|
||||
Client *c;
|
||||
|
||||
getgaps(m, &oh, &ov, &ih, &iv, &n);
|
||||
if (n == 0)
|
||||
return;
|
||||
|
||||
/* initialize areas */
|
||||
mx = m->wx + ov;
|
||||
my = m->wy + oh;
|
||||
mh = m->wh - 2 * oh - ih * ((!m->nmaster ? n : MIN(n, m->nmaster)) - 1);
|
||||
mw = m->ww - 2 * ov;
|
||||
lh = m->wh - 2 * oh - ih * (((n - m->nmaster) / 2) - 1);
|
||||
rh = m->wh - 2 * oh -
|
||||
ih * (((n - m->nmaster) / 2) - ((n - m->nmaster) % 2 ? 0 : 1));
|
||||
|
||||
if (m->nmaster && n > m->nmaster) {
|
||||
/* go mfact box in the center if more than nmaster clients */
|
||||
if (n - m->nmaster > 1) {
|
||||
/* ||<-S->|<---M--->|<-S->|| */
|
||||
mw = (m->ww - 2 * ov - 2 * iv) * m->mfact;
|
||||
lw = (m->ww - mw - 2 * ov - 2 * iv) / 2;
|
||||
rw = (m->ww - mw - 2 * ov - 2 * iv) - lw;
|
||||
mx += lw + iv;
|
||||
} else {
|
||||
/* ||<---M--->|<-S->|| */
|
||||
mw = (mw - iv) * m->mfact;
|
||||
lw = 0;
|
||||
rw = m->ww - mw - iv - 2 * ov;
|
||||
}
|
||||
lx = m->wx + ov;
|
||||
ly = m->wy + oh;
|
||||
rx = mx + mw + iv;
|
||||
ry = m->wy + oh;
|
||||
}
|
||||
|
||||
/* calculate facts */
|
||||
for (n = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), n++) {
|
||||
if (!m->nmaster || n < m->nmaster)
|
||||
mfacts += c->cfact;
|
||||
else if ((n - m->nmaster) % 2)
|
||||
lfacts += c->cfact; // total factor of left hand stack area
|
||||
else
|
||||
rfacts += c->cfact; // total factor of right hand stack area
|
||||
}
|
||||
|
||||
for (n = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), n++)
|
||||
if (!m->nmaster || n < m->nmaster)
|
||||
mtotal += mh * (c->cfact / mfacts);
|
||||
else if ((n - m->nmaster) % 2)
|
||||
ltotal += lh * (c->cfact / lfacts);
|
||||
else
|
||||
rtotal += rh * (c->cfact / rfacts);
|
||||
|
||||
mrest = mh - mtotal;
|
||||
lrest = lh - ltotal;
|
||||
rrest = rh - rtotal;
|
||||
|
||||
for (i = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), i++) {
|
||||
if (!m->nmaster || i < m->nmaster) {
|
||||
/* nmaster clients are stacked vertically, in the center of the screen */
|
||||
resize(c, mx, my, mw - (2 * c->bw),
|
||||
mh * (c->cfact / mfacts) + (i < mrest ? 1 : 0) - (2 * c->bw), 0);
|
||||
my += HEIGHT(c) + ih;
|
||||
} else {
|
||||
/* stack clients are stacked vertically */
|
||||
if ((i - m->nmaster) % 2) {
|
||||
resize(c, lx, ly, lw - (2 * c->bw),
|
||||
lh * (c->cfact / lfacts) +
|
||||
((i - 2 * m->nmaster) < 2 * lrest ? 1 : 0) - (2 * c->bw),
|
||||
0);
|
||||
ly += HEIGHT(c) + ih;
|
||||
} else {
|
||||
resize(c, rx, ry, rw - (2 * c->bw),
|
||||
rh * (c->cfact / rfacts) +
|
||||
((i - 2 * m->nmaster) < 2 * rrest ? 1 : 0) - (2 * c->bw),
|
||||
0);
|
||||
ry += HEIGHT(c) + ih;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void centeredfloatingmaster(Monitor *m) {
|
||||
unsigned int i, n;
|
||||
float mfacts, sfacts;
|
||||
float mivf = 1.0; // master inner vertical gap factor
|
||||
int oh, ov, ih, iv, mrest, srest;
|
||||
int mx = 0, my = 0, mh = 0, mw = 0;
|
||||
int sx = 0, sy = 0, sh = 0, sw = 0;
|
||||
Client *c;
|
||||
|
||||
getgaps(m, &oh, &ov, &ih, &iv, &n);
|
||||
if (n == 0)
|
||||
return;
|
||||
|
||||
sx = mx = m->wx + ov;
|
||||
sy = my = m->wy + oh;
|
||||
sh = mh = m->wh - 2 * oh;
|
||||
mw = m->ww - 2 * ov - iv * (n - 1);
|
||||
sw = m->ww - 2 * ov - iv * (n - m->nmaster - 1);
|
||||
|
||||
if (m->nmaster && n > m->nmaster) {
|
||||
mivf = 0.8;
|
||||
/* go mfact box in the center if more than nmaster clients */
|
||||
if (m->ww > m->wh) {
|
||||
mw = m->ww * m->mfact - iv * mivf * (MIN(n, m->nmaster) - 1);
|
||||
mh = m->wh * 0.9;
|
||||
} else {
|
||||
mw = m->ww * 0.9 - iv * mivf * (MIN(n, m->nmaster) - 1);
|
||||
mh = m->wh * m->mfact;
|
||||
}
|
||||
mx = m->wx + (m->ww - mw) / 2;
|
||||
my = m->wy + (m->wh - mh - 2 * oh) / 2;
|
||||
|
||||
sx = m->wx + ov;
|
||||
sy = m->wy + oh;
|
||||
sh = m->wh - 2 * oh;
|
||||
}
|
||||
|
||||
getfacts(m, mw, sw, &mfacts, &sfacts, &mrest, &srest);
|
||||
|
||||
for (i = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), i++)
|
||||
if (i < m->nmaster) {
|
||||
/* nmaster clients are stacked horizontally, in the center of the screen
|
||||
*/
|
||||
resize(c, mx, my,
|
||||
mw * (c->cfact / mfacts) + (i < mrest ? 1 : 0) - (2 * c->bw),
|
||||
mh - (2 * c->bw), 0);
|
||||
mx += WIDTH(c) + iv * mivf;
|
||||
} else {
|
||||
/* stack clients are stacked horizontally */
|
||||
resize(c, sx, sy,
|
||||
sw * (c->cfact / sfacts) + ((i - m->nmaster) < srest ? 1 : 0) -
|
||||
(2 * c->bw),
|
||||
sh - (2 * c->bw), 0);
|
||||
sx += WIDTH(c) + iv;
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Deck layout + gaps
|
||||
* https://dwm.suckless.org/patches/deck/
|
||||
*/
|
||||
void deck(Monitor *m) {
|
||||
unsigned int i, n;
|
||||
int oh, ov, ih, iv;
|
||||
int mx = 0, my = 0, mh = 0, mw = 0;
|
||||
int sx = 0, sy = 0, sh = 0, sw = 0;
|
||||
float mfacts, sfacts;
|
||||
int mrest, srest;
|
||||
Client *c;
|
||||
|
||||
getgaps(m, &oh, &ov, &ih, &iv, &n);
|
||||
if (n == 0)
|
||||
return;
|
||||
|
||||
sx = mx = m->wx + ov;
|
||||
sy = my = m->wy + oh;
|
||||
sh = mh = m->wh - 2 * oh - ih * (MIN(n, m->nmaster) - 1);
|
||||
sw = mw = m->ww - 2 * ov;
|
||||
|
||||
if (m->nmaster && n > m->nmaster) {
|
||||
sw = (mw - iv) * (1 - m->mfact);
|
||||
mw = mw - iv - sw;
|
||||
sx = mx + mw + iv;
|
||||
sh = m->wh - 2 * oh;
|
||||
}
|
||||
|
||||
getfacts(m, mh, sh, &mfacts, &sfacts, &mrest, &srest);
|
||||
|
||||
if (n - m->nmaster > 0) /* override layout symbol */
|
||||
snprintf(m->ltsymbol, sizeof m->ltsymbol, "D %d", n - m->nmaster);
|
||||
|
||||
for (i = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), i++)
|
||||
if (i < m->nmaster) {
|
||||
resize(c, mx, my, mw - (2 * c->bw),
|
||||
mh * (c->cfact / mfacts) + (i < mrest ? 1 : 0) - (2 * c->bw), 0);
|
||||
my += HEIGHT(c) + ih;
|
||||
} else {
|
||||
resize(c, sx, sy, sw - (2 * c->bw), sh - (2 * c->bw), 0);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Fibonacci layout + gaps
|
||||
* https://dwm.suckless.org/patches/fibonacci/
|
||||
*/
|
||||
void fibonacci(Monitor *m, int s) {
|
||||
unsigned int i, n;
|
||||
int nx, ny, nw, nh;
|
||||
int oh, ov, ih, iv;
|
||||
int nv, hrest = 0, wrest = 0, r = 1;
|
||||
Client *c;
|
||||
|
||||
getgaps(m, &oh, &ov, &ih, &iv, &n);
|
||||
if (n == 0)
|
||||
return;
|
||||
|
||||
nx = m->wx + ov;
|
||||
ny = m->wy + oh;
|
||||
nw = m->ww - 2 * ov;
|
||||
nh = m->wh - 2 * oh;
|
||||
|
||||
for (i = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next)) {
|
||||
if (r) {
|
||||
if ((i % 2 && (nh - ih) / 2 <= (bh + 2 * c->bw)) ||
|
||||
(!(i % 2) && (nw - iv) / 2 <= (bh + 2 * c->bw))) {
|
||||
r = 0;
|
||||
}
|
||||
if (r && i < n - 1) {
|
||||
if (i % 2) {
|
||||
nv = (nh - ih) / 2;
|
||||
hrest = nh - 2 * nv - ih;
|
||||
nh = nv;
|
||||
} else {
|
||||
nv = (nw - iv) / 2;
|
||||
wrest = nw - 2 * nv - iv;
|
||||
nw = nv;
|
||||
}
|
||||
|
||||
if ((i % 4) == 2 && !s)
|
||||
nx += nw + iv;
|
||||
else if ((i % 4) == 3 && !s)
|
||||
ny += nh + ih;
|
||||
}
|
||||
|
||||
if ((i % 4) == 0) {
|
||||
if (s) {
|
||||
ny += nh + ih;
|
||||
nh += hrest;
|
||||
} else {
|
||||
nh -= hrest;
|
||||
ny -= nh + ih;
|
||||
}
|
||||
} else if ((i % 4) == 1) {
|
||||
nx += nw + iv;
|
||||
nw += wrest;
|
||||
} else if ((i % 4) == 2) {
|
||||
ny += nh + ih;
|
||||
nh += hrest;
|
||||
if (i < n - 1)
|
||||
nw += wrest;
|
||||
} else if ((i % 4) == 3) {
|
||||
if (s) {
|
||||
nx += nw + iv;
|
||||
nw -= wrest;
|
||||
} else {
|
||||
nw -= wrest;
|
||||
nx -= nw + iv;
|
||||
nh += hrest;
|
||||
}
|
||||
}
|
||||
if (i == 0) {
|
||||
if (n != 1) {
|
||||
nw = (m->ww - iv - 2 * ov) - (m->ww - iv - 2 * ov) * (1 - m->mfact);
|
||||
wrest = 0;
|
||||
}
|
||||
ny = m->wy + oh;
|
||||
} else if (i == 1)
|
||||
nw = m->ww - nw - iv - 2 * ov;
|
||||
i++;
|
||||
}
|
||||
|
||||
resize(c, nx, ny, nw - (2 * c->bw), nh - (2 * c->bw), False);
|
||||
}
|
||||
}
|
||||
|
||||
void dwindle(Monitor *m) { fibonacci(m, 1); }
|
||||
|
||||
void spiral(Monitor *m) { fibonacci(m, 0); }
|
||||
|
||||
/*
|
||||
* Gappless grid layout + gaps (ironically)
|
||||
* https://dwm.suckless.org/patches/gaplessgrid/
|
||||
*/
|
||||
void gaplessgrid(Monitor *m) {
|
||||
unsigned int i, n;
|
||||
int x, y, cols, rows, ch, cw, cn, rn, rrest, crest; // counters
|
||||
int oh, ov, ih, iv;
|
||||
Client *c;
|
||||
|
||||
getgaps(m, &oh, &ov, &ih, &iv, &n);
|
||||
if (n == 0)
|
||||
return;
|
||||
|
||||
/* grid dimensions */
|
||||
for (cols = 0; cols <= n / 2; cols++)
|
||||
if (cols * cols >= n)
|
||||
break;
|
||||
if (n ==
|
||||
5) /* set layout against the general calculation: not 1:2:2, but 2:3 */
|
||||
cols = 2;
|
||||
rows = n / cols;
|
||||
cn = rn = 0; // reset column no, row no, client count
|
||||
|
||||
ch = (m->wh - 2 * oh - ih * (rows - 1)) / rows;
|
||||
cw = (m->ww - 2 * ov - iv * (cols - 1)) / cols;
|
||||
rrest = (m->wh - 2 * oh - ih * (rows - 1)) - ch * rows;
|
||||
crest = (m->ww - 2 * ov - iv * (cols - 1)) - cw * cols;
|
||||
x = m->wx + ov;
|
||||
y = m->wy + oh;
|
||||
|
||||
for (i = 0, c = nexttiled(m->clients); c; i++, c = nexttiled(c->next)) {
|
||||
if (i / rows + 1 > cols - n % cols) {
|
||||
rows = n / cols + 1;
|
||||
ch = (m->wh - 2 * oh - ih * (rows - 1)) / rows;
|
||||
rrest = (m->wh - 2 * oh - ih * (rows - 1)) - ch * rows;
|
||||
}
|
||||
resize(c, x, y + rn * (ch + ih) + MIN(rn, rrest),
|
||||
cw + (cn < crest ? 1 : 0) - 2 * c->bw,
|
||||
ch + (rn < rrest ? 1 : 0) - 2 * c->bw, 0);
|
||||
rn++;
|
||||
if (rn >= rows) {
|
||||
rn = 0;
|
||||
x += cw + ih + (cn < crest ? 1 : 0);
|
||||
cn++;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Gridmode layout + gaps
|
||||
* https://dwm.suckless.org/patches/gridmode/
|
||||
*/
|
||||
void grid(Monitor *m) {
|
||||
unsigned int i, n;
|
||||
int cx, cy, cw, ch, cc, cr, chrest, cwrest, cols, rows;
|
||||
int oh, ov, ih, iv;
|
||||
Client *c;
|
||||
|
||||
getgaps(m, &oh, &ov, &ih, &iv, &n);
|
||||
|
||||
/* grid dimensions */
|
||||
for (rows = 0; rows <= n / 2; rows++)
|
||||
if (rows * rows >= n)
|
||||
break;
|
||||
cols = (rows && (rows - 1) * rows >= n) ? rows - 1 : rows;
|
||||
|
||||
/* window geoms (cell height/width) */
|
||||
ch = (m->wh - 2 * oh - ih * (rows - 1)) / (rows ? rows : 1);
|
||||
cw = (m->ww - 2 * ov - iv * (cols - 1)) / (cols ? cols : 1);
|
||||
chrest = (m->wh - 2 * oh - ih * (rows - 1)) - ch * rows;
|
||||
cwrest = (m->ww - 2 * ov - iv * (cols - 1)) - cw * cols;
|
||||
for (i = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), i++) {
|
||||
cc = i / rows;
|
||||
cr = i % rows;
|
||||
cx = m->wx + ov + cc * (cw + iv) + MIN(cc, cwrest);
|
||||
cy = m->wy + oh + cr * (ch + ih) + MIN(cr, chrest);
|
||||
resize(c, cx, cy, cw + (cc < cwrest ? 1 : 0) - 2 * c->bw,
|
||||
ch + (cr < chrest ? 1 : 0) - 2 * c->bw, False);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Horizontal grid layout + gaps
|
||||
* https://dwm.suckless.org/patches/horizgrid/
|
||||
*/
|
||||
void horizgrid(Monitor *m) {
|
||||
Client *c;
|
||||
unsigned int n, i;
|
||||
int oh, ov, ih, iv;
|
||||
int mx = 0, my = 0, mh = 0, mw = 0;
|
||||
int sx = 0, sy = 0, sh = 0, sw = 0;
|
||||
int ntop, nbottom = 1;
|
||||
float mfacts = 0, sfacts = 0;
|
||||
int mrest, srest, mtotal = 0, stotal = 0;
|
||||
|
||||
/* Count windows */
|
||||
getgaps(m, &oh, &ov, &ih, &iv, &n);
|
||||
if (n == 0)
|
||||
return;
|
||||
|
||||
if (n <= 2)
|
||||
ntop = n;
|
||||
else {
|
||||
ntop = n / 2;
|
||||
nbottom = n - ntop;
|
||||
}
|
||||
sx = mx = m->wx + ov;
|
||||
sy = my = m->wy + oh;
|
||||
sh = mh = m->wh - 2 * oh;
|
||||
sw = mw = m->ww - 2 * ov;
|
||||
|
||||
if (n > ntop) {
|
||||
sh = (mh - ih) / 2;
|
||||
mh = mh - ih - sh;
|
||||
sy = my + mh + ih;
|
||||
mw = m->ww - 2 * ov - iv * (ntop - 1);
|
||||
sw = m->ww - 2 * ov - iv * (nbottom - 1);
|
||||
}
|
||||
|
||||
/* calculate facts */
|
||||
for (i = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), i++)
|
||||
if (i < ntop)
|
||||
mfacts += c->cfact;
|
||||
else
|
||||
sfacts += c->cfact;
|
||||
|
||||
for (i = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), i++)
|
||||
if (i < ntop)
|
||||
mtotal += mh * (c->cfact / mfacts);
|
||||
else
|
||||
stotal += sw * (c->cfact / sfacts);
|
||||
|
||||
mrest = mh - mtotal;
|
||||
srest = sw - stotal;
|
||||
|
||||
for (i = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), i++)
|
||||
if (i < ntop) {
|
||||
resize(c, mx, my,
|
||||
mw * (c->cfact / mfacts) + (i < mrest ? 1 : 0) - (2 * c->bw),
|
||||
mh - (2 * c->bw), 0);
|
||||
mx += WIDTH(c) + iv;
|
||||
} else {
|
||||
resize(c, sx, sy,
|
||||
sw * (c->cfact / sfacts) + ((i - ntop) < srest ? 1 : 0) -
|
||||
(2 * c->bw),
|
||||
sh - (2 * c->bw), 0);
|
||||
sx += WIDTH(c) + iv;
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* nrowgrid layout + gaps
|
||||
* https://dwm.suckless.org/patches/nrowgrid/
|
||||
*/
|
||||
void nrowgrid(Monitor *m) {
|
||||
unsigned int n;
|
||||
int ri = 0, ci = 0; /* counters */
|
||||
int oh, ov, ih, iv; /* vanitygap settings */
|
||||
unsigned int cx, cy, cw, ch; /* client geometry */
|
||||
unsigned int uw = 0, uh = 0, uc = 0; /* utilization trackers */
|
||||
unsigned int cols, rows = m->nmaster + 1;
|
||||
Client *c;
|
||||
|
||||
/* count clients */
|
||||
getgaps(m, &oh, &ov, &ih, &iv, &n);
|
||||
|
||||
/* nothing to do here */
|
||||
if (n == 0)
|
||||
return;
|
||||
|
||||
/* force 2 clients to always split vertically */
|
||||
if (FORCE_VSPLIT && n == 2)
|
||||
rows = 1;
|
||||
|
||||
/* never allow empty rows */
|
||||
if (n < rows)
|
||||
rows = n;
|
||||
|
||||
/* define first row */
|
||||
cols = n / rows;
|
||||
uc = cols;
|
||||
cy = m->wy + oh;
|
||||
ch = (m->wh - 2 * oh - ih * (rows - 1)) / rows;
|
||||
uh = ch;
|
||||
|
||||
for (c = nexttiled(m->clients); c; c = nexttiled(c->next), ci++) {
|
||||
if (ci == cols) {
|
||||
uw = 0;
|
||||
ci = 0;
|
||||
ri++;
|
||||
|
||||
/* next row */
|
||||
cols = (n - uc) / (rows - ri);
|
||||
uc += cols;
|
||||
cy = m->wy + oh + uh + ih;
|
||||
uh += ch + ih;
|
||||
}
|
||||
|
||||
cx = m->wx + ov + uw;
|
||||
cw = (m->ww - 2 * ov - uw) / (cols - ci);
|
||||
uw += cw + iv;
|
||||
|
||||
resize(c, cx, cy, cw - (2 * c->bw), ch - (2 * c->bw), 0);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Default tile layout + gaps
|
||||
*/
|
||||
static void tile(Monitor *m) {
|
||||
unsigned int i, n;
|
||||
int oh, ov, ih, iv;
|
||||
int mx = 0, my = 0, mh = 0, mw = 0;
|
||||
int sx = 0, sy = 0, sh = 0, sw = 0;
|
||||
float mfacts, sfacts;
|
||||
int mrest, srest;
|
||||
Client *c;
|
||||
|
||||
getgaps(m, &oh, &ov, &ih, &iv, &n);
|
||||
if (n == 0)
|
||||
return;
|
||||
|
||||
sx = mx = m->wx + ov;
|
||||
sy = my = m->wy + oh;
|
||||
mh = m->wh - 2 * oh - ih * (MIN(n, m->nmaster) - 1);
|
||||
sh = m->wh - 2 * oh - ih * (n - m->nmaster - 1);
|
||||
sw = mw = m->ww - 2 * ov;
|
||||
|
||||
if (m->nmaster && n > m->nmaster) {
|
||||
sw = (mw - iv) * (1 - m->mfact);
|
||||
mw = mw - iv - sw;
|
||||
sx = mx + mw + iv;
|
||||
}
|
||||
|
||||
getfacts(m, mh, sh, &mfacts, &sfacts, &mrest, &srest);
|
||||
|
||||
for (i = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), i++)
|
||||
if (i < m->nmaster) {
|
||||
resize(c, mx, my, mw - (2 * c->bw),
|
||||
mh * (c->cfact / mfacts) + (i < mrest ? 1 : 0) - (2 * c->bw), 0);
|
||||
my += HEIGHT(c) + ih;
|
||||
} else {
|
||||
resize(c, sx, sy, sw - (2 * c->bw),
|
||||
sh * (c->cfact / sfacts) + ((i - m->nmaster) < srest ? 1 : 0) -
|
||||
(2 * c->bw),
|
||||
0);
|
||||
sy += HEIGHT(c) + ih;
|
||||
}
|
||||
}
|