commit c40d34337e95617842ea6ebf398582be2ad8056a
parent a2f8df64808a25cbef517559048699820e71d8e9
Author: Jake Koroman <jake@jakekoroman.com>
Date: Thu, 2 Oct 2025 12:00:38 -0400
patch: applied cyclelayouts.
Diffstat:
4 files changed, 30 insertions(+), 3 deletions(-)
diff --git a/README b/README
@@ -5,9 +5,10 @@ dwm is an extremely fast, small, and dynamic window manager for X.
Patches Applied
---------------
-pertag - https://dwm.suckless.org/patches/pertag/dwm-pertag-20200914-61bb8b2.diff
-vanitygaps - https://dwm.suckless.org/patches/vanitygaps/dwm-cfacts-vanitygaps-6.4_combo.diff
-movestack - https://dwm.suckless.org/patches/movestack/dwm-movestack-20211115-a786211.diff
+pertag - https://dwm.suckless.org/patches/pertag/dwm-pertag-20200914-61bb8b2.diff
+vanitygaps - https://dwm.suckless.org/patches/vanitygaps/dwm-cfacts-vanitygaps-6.4_combo.diff
+movestack - https://dwm.suckless.org/patches/movestack/dwm-movestack-20211115-a786211.diff
+cyclelayouts - https://dwm.suckless.org/patches/cyclelayouts/dwm-cyclelayouts-20180524-6.2.diff
Requirements
------------
diff --git a/config.def.h b/config.def.h
@@ -119,6 +119,8 @@ static const Key keys[] = {
{ MODKEY, XK_t, setlayout, {.v = &layouts[0]} },
{ MODKEY, XK_f, setlayout, {.v = &layouts[1]} },
{ MODKEY, XK_m, setlayout, {.v = &layouts[2]} },
+ { MODKEY|ControlMask, XK_comma, cyclelayout, {.i = -1 } },
+ { MODKEY|ControlMask, XK_period, cyclelayout, {.i = +1 } },
{ MODKEY, XK_space, setlayout, {0} },
{ MODKEY|ShiftMask, XK_space, togglefloating, {0} },
{ MODKEY, XK_0, view, {.ui = ~0 } },
diff --git a/dwm.1 b/dwm.1
@@ -92,6 +92,12 @@ Sets monocle layout.
.B Mod1\-space
Toggles between current and previous layout.
.TP
+.B Mod1\-Control\-,
+Cycles backwards in layout list.
+.TP
+.B Mod1\-Control\-.
+Cycles forwards in layout list.
+.TP
.B Mod1\-j
Focus next window.
.TP
diff --git a/dwm.c b/dwm.c
@@ -163,6 +163,7 @@ static void configure(Client *c);
static void configurenotify(XEvent *e);
static void configurerequest(XEvent *e);
static Monitor *createmon(void);
+static void cyclelayout(const Arg *arg);
static void destroynotify(XEvent *e);
static void detach(Client *c);
static void detachstack(Client *c);
@@ -683,6 +684,23 @@ createmon(void)
}
void
+cyclelayout(const Arg *arg) {
+ Layout *l;
+ for(l = (Layout *)layouts; l != selmon->lt[selmon->sellt]; l++);
+ if(arg->i > 0) {
+ if(l->symbol && (l + 1)->symbol)
+ setlayout(&((Arg) { .v = (l + 1) }));
+ else
+ setlayout(&((Arg) { .v = layouts }));
+ } else {
+ if(l != layouts && (l - 1)->symbol)
+ setlayout(&((Arg) { .v = (l - 1) }));
+ else
+ setlayout(&((Arg) { .v = &layouts[LENGTH(layouts) - 2] }));
+ }
+}
+
+void
destroynotify(XEvent *e)
{
Client *c;