dwm-cfacts_bottomstack-6.2.diff - sites - public wiki contents of suckless.org | |
git clone git://git.suckless.org/sites | |
Log | |
Files | |
Refs | |
--- | |
dwm-cfacts_bottomstack-6.2.diff (3863B) | |
--- | |
1 diff -up a/config.def.h b/config.def.h | |
2 --- a/config.def.h 2019-06-06 21:23:27.006661784 +0200 | |
3 +++ b/config.def.h 2019-06-06 21:31:38.133319129 +0200 | |
4 @@ -41,6 +41,8 @@ static const Layout layouts[] = { | |
5 { "[]=", tile }, /* first entry is default */ | |
6 { "><>", NULL }, /* no layout function means floating b… | |
7 { "[M]", monocle }, | |
8 + { "TTT", bstack }, | |
9 + { "===", bstackhoriz }, | |
10 }; | |
11 | |
12 /* key definitions */ | |
13 @@ -79,6 +81,8 @@ static Key keys[] = { | |
14 { MODKEY, XK_t, setlayout, {.v … | |
15 { MODKEY, XK_f, setlayout, {.v … | |
16 { MODKEY, XK_m, setlayout, {.v … | |
17 + { MODKEY, XK_u, setlayout, {.v … | |
18 + { MODKEY, XK_o, setlayout, {.v … | |
19 { MODKEY, XK_space, setlayout, {0} … | |
20 { MODKEY|ShiftMask, XK_space, togglefloating, {0} … | |
21 { MODKEY, XK_0, view, {.ui… | |
22 Only in a: config.def.h.orig | |
23 Only in b: config.def.h.orig.orig | |
24 Only in b: dwm-bottomstack-20160719-56a31dc.diff | |
25 diff -up a/dwm.c b/dwm.c | |
26 --- a/dwm.c 2019-06-06 21:23:27.023328450 +0200 | |
27 +++ b/dwm.c 2019-06-06 21:31:38.133319129 +0200 | |
28 @@ -235,6 +235,8 @@ static int xerror(Display *dpy, XErrorEv | |
29 static int xerrordummy(Display *dpy, XErrorEvent *ee); | |
30 static int xerrorstart(Display *dpy, XErrorEvent *ee); | |
31 static void zoom(const Arg *arg); | |
32 +static void bstack(Monitor *m); | |
33 +static void bstackhoriz(Monitor *m); | |
34 | |
35 /* variables */ | |
36 static const char broken[] = "broken"; | |
37 @@ -2175,3 +2177,87 @@ main(int argc, char *argv[]) | |
38 XCloseDisplay(dpy); | |
39 return EXIT_SUCCESS; | |
40 } | |
41 + | |
42 +void | |
43 +bstack(Monitor *m) | |
44 +{ | |
45 + unsigned int i, n, w, mh, mx, tx; | |
46 + float mfacts = 0, sfacts = 0; | |
47 + Client *c; | |
48 + | |
49 + for (n = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next… | |
50 + if (n < m->nmaster) | |
51 + mfacts += c->cfact; | |
52 + else | |
53 + sfacts += c->cfact; | |
54 + } | |
55 + if (n == 0) | |
56 + return; | |
57 + if(n == 1){ | |
58 + c = nexttiled(m->clients); | |
59 + resize(c, m->wx, m->wy, m->ww - 2 * c->bw, m->wh - 2 * … | |
60 + return; | |
61 + } | |
62 + | |
63 + if (n > m->nmaster) | |
64 + mh = m->nmaster ? m->wh * m->mfact : 0; | |
65 + else | |
66 + mh = m->wh; | |
67 + for (i = 0, mx = tx = 0, c = nexttiled(m->clients); c; c = next… | |
68 + if (i < m->nmaster) { | |
69 + w = (m->ww - mx) * (c->cfact / mfacts); | |
70 + resize(c, m->wx + mx, m->wy, w - (2*c->bw), mh … | |
71 + if(mx + WIDTH(c) < m->mw) | |
72 + mx += WIDTH(c); | |
73 + mfacts -= c->cfact; | |
74 + } else { | |
75 + w = (m->ww - tx) * (c->cfact / sfacts); | |
76 + resize(c, m->wx + tx, m->wy + mh, w - (2*c->bw)… | |
77 + if(tx + WIDTH(c) < m->mw) | |
78 + tx += WIDTH(c); | |
79 + sfacts -= c->cfact; | |
80 + } | |
81 +} | |
82 + | |
83 +void | |
84 +bstackhoriz(Monitor *m) | |
85 +{ | |
86 + unsigned int i, n, h, mw, mh, my, ty; | |
87 + float mfacts = 0, sfacts = 0; | |
88 + Client *c; | |
89 + | |
90 + for (n = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next… | |
91 + if (n < m->nmaster) | |
92 + mfacts += c->cfact; | |
93 + else | |
94 + sfacts += c->cfact; | |
95 + } | |
96 + if (n == 0) | |
97 + return; | |
98 + if(n == 1){ | |
99 + c = nexttiled(m->clients); | |
100 + resize(c, m->wx, m->wy, m->ww - 2 * c->bw, m->wh - 2 * … | |
101 + return; | |
102 + } | |
103 + | |
104 + if (n > m->nmaster) | |
105 + mh = m->nmaster ? m->wh * m->mfact : 0; | |
106 + else | |
107 + mh = m->wh; | |
108 + mw = m->ww; | |
109 + | |
110 + for (i = ty = 0, my = 0, c = nexttiled(m->clients); c; c = next… | |
111 + if (i < m->nmaster) { | |
112 + h = (mh - my) * (c->cfact / mfacts); | |
113 + resize(c, m->wx, m->wy + my, mw - 2*c->bw, h - … | |
114 + if(my + HEIGHT(c) < m->mh) | |
115 + my += HEIGHT(c); | |
116 + mfacts -= c->cfact; | |
117 + } else { | |
118 + h = (m->wh - mh - ty) * (c->cfact / sfacts); | |
119 + resize(c, m->wx, m->wy + mh + ty, mw - 2*c->bw,… | |
120 + if(ty + HEIGHT(c) < m->mh) | |
121 + ty += HEIGHT(c); | |
122 + sfacts -= c->cfact; | |
123 + } | |
124 +} |