dwl

My patch set and modifications to dwl
git clone git://git.ethandl.dev/dwl
Log | Files | Refs | README | LICENSE

commit 66dce64145ed7e08be3e949bb635d2deaa0105dc
parent 53798dfbff8c8352e42be2f9c400cb4b66ca28fe
Author: Devin J. Pohly <djpohly@gmail.com>
Date:   Fri, 24 Jul 2020 17:07:52 -0400

Merge pull request #18 from guidocella/zoom

Add zoom
Diffstat:
Mconfig.def.h | 1+
Mdwl.c | 30++++++++++++++++++++++++++++++
2 files changed, 31 insertions(+), 0 deletions(-)

diff --git a/config.def.h b/config.def.h @@ -59,6 +59,7 @@ static const Key keys[] = { { MODKEY, XKB_KEY_d, incnmaster, {.i = -1} }, { MODKEY, XKB_KEY_h, setmfact, {.f = -0.05} }, { MODKEY, XKB_KEY_l, setmfact, {.f = +0.05} }, + { MODKEY, XKB_KEY_Return, zoom, {0} }, { MODKEY, XKB_KEY_Tab, view, {0} }, { MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_c, killclient, {0} }, { MODKEY, XKB_KEY_t, setlayout, {.v = &layouts[0]} }, diff --git a/dwl.c b/dwl.c @@ -211,6 +211,7 @@ static void unmapnotify(struct wl_listener *listener, void *data); static void view(const Arg *arg); static Client *xytoclient(double x, double y); static Monitor *xytomon(double x, double y); +static void zoom(const Arg *arg); /* variables */ static const char broken[] = "broken"; @@ -1636,6 +1637,35 @@ xytomon(double x, double y) return o ? o->data : NULL; } +void +zoom(const Arg *arg) +{ + unsigned int n = 0; + Client *c, *sel = selclient(); + + if (!sel || !selmon->lt[selmon->sellt]->arrange || sel->isfloating) + return; + + wl_list_for_each(c, &clients, link) + if (VISIBLEON(c, selmon) && !c->isfloating) { + if (++n == 1 && c == sel) + sel = NULL; + else if (n == 2) { + if (!sel) + sel = c; + break; + } + } + + if (n == 1) + return; + + wl_list_remove(&sel->link); + wl_list_insert(&clients, &sel->link); + focusclient(sel, NULL, 1); + arrange(selmon); +} + int main(int argc, char *argv[]) {