~ruther/dwl

dcaaccb969b2412d5bcae01f5db585118a5f446d — Rutherther 11 months ago 577d8da patch/focusnthclient
Focus nth client
2 files changed, 22 insertions(+), 0 deletions(-)

M config.def.h
M dwl.c
M config.def.h => config.def.h +1 -0
@@ 143,6 143,7 @@ static const Key keys[] = {
	{ MODKEY,                    XKB_KEY_period,     focusmon,       {.i = WLR_DIRECTION_RIGHT} },
	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_less,       tagmon,         {.i = WLR_DIRECTION_LEFT} },
	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_greater,    tagmon,         {.i = WLR_DIRECTION_RIGHT} },
	{ MODKEY,                    XKB_KEY_m,          focusnthclient, {0} },
	TAGKEYS(          XKB_KEY_1, XKB_KEY_exclam,                     0),
	TAGKEYS(          XKB_KEY_2, XKB_KEY_at,                         1),
	TAGKEYS(          XKB_KEY_3, XKB_KEY_numbersign,                 2),

M dwl.c => dwl.c +21 -0
@@ 281,6 281,7 @@ static Monitor *dirtomon(enum wlr_direction dir);
static void focusclient(Client *c, int lift);
static void focusmon(const Arg *arg);
static void focusstack(const Arg *arg);
static void focusnthclient(const Arg *arg);
static Client *focustop(Monitor *m);
static void fullscreennotify(struct wl_listener *listener, void *data);
static void handlesig(int signo);


@@ 2570,6 2571,26 @@ tagmon(const Arg *arg)
}

void
focusnthclient(const Arg *arg)
{
	Client *c;
	unsigned int i = arg->ui;

	wl_list_for_each(c, &clients, link) {
		if (!VISIBLEON(c, selmon) || c->isfloating) {
			continue;
		}

		if (i == 0) {
			focusclient(c, 1);
			return;
		}

		i--;
	}
}

void
tile(Monitor *m)
{
	unsigned int mw, my, ty;

Do not follow this link