summaryrefslogtreecommitdiffstats
path: root/dwm.c
diff options
context:
space:
mode:
authorMalfurious <m@lfurio.us>2024-03-02 15:12:21 -0500
committerMalfurious <m@lfurio.us>2024-03-05 21:04:47 -0500
commitdde75954fa94186d192b9a8c78dba7bbd040eb47 (patch)
tree93d68876b1f1d0a08af24c4ea5d18cc8851e3e43 /dwm.c
parent74eb25562964b4d42979b82805f01427147f717a (diff)
downloaddwm-dde75954fa94186d192b9a8c78dba7bbd040eb47.tar.gz
dwm-dde75954fa94186d192b9a8c78dba7bbd040eb47.zip
patch: philcollins (full columns)
Layout adapted from centerfloatingmaster to simply tile all clients horizontally across the screen, without respect to mfact or nmaster.
Diffstat (limited to 'dwm.c')
-rw-r--r--dwm.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/dwm.c b/dwm.c
index ddef5a6..bf0e19d 100644
--- a/dwm.c
+++ b/dwm.c
@@ -192,6 +192,7 @@ static void monocle(Monitor *m);
static void motionnotify(XEvent *e);
static void movemouse(const Arg *arg);
static Client *nexttiled(Client *c);
+static void philcollins(Monitor *m);
static void pop(Client *c);
static void propertynotify(XEvent *e);
static void quit(const Arg *arg);
@@ -1323,6 +1324,25 @@ nexttiled(Client *c)
}
void
+philcollins(Monitor *m)
+{
+ unsigned int i, n, w, tx;
+ Client *c;
+
+ /* count number of clients in the selected monitor */
+ for (n = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), n++);
+ if (n == 0)
+ return;
+
+ /* there are no masters, clients are stacked in columns horizontally */
+ for (i = tx = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), i++) {
+ w = (m->ww - tx) / (n - i);
+ resize(c, m->wx + tx, m->wy, w - (2*c->bw), m->wh - (2*c->bw), 0);
+ tx += WIDTH(c);
+ }
+}
+
+void
pop(Client *c)
{
detach(c);