Merge branch 'master' of git://git.suckless.org/dwm
This commit is contained in:
		
						commit
						9cf8ec6fa8
					
				
					 4 changed files with 170 additions and 49 deletions
				
			
		
							
								
								
									
										115
									
								
								config.def.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										115
									
								
								config.def.h
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,115 @@
 | 
			
		|||
/* See LICENSE file for copyright and license details. */
 | 
			
		||||
 | 
			
		||||
/* appearance */
 | 
			
		||||
static const unsigned int borderpx  = 1;        /* border pixel of windows */
 | 
			
		||||
static const unsigned int snap      = 32;       /* snap pixel */
 | 
			
		||||
static const int showbar            = 1;        /* 0 means no bar */
 | 
			
		||||
static const int topbar             = 1;        /* 0 means bottom bar */
 | 
			
		||||
static const char *fonts[]          = { "monospace:size=10" };
 | 
			
		||||
static const char dmenufont[]       = "monospace:size=10";
 | 
			
		||||
static const char col_gray1[]       = "#222222";
 | 
			
		||||
static const char col_gray2[]       = "#444444";
 | 
			
		||||
static const char col_gray3[]       = "#bbbbbb";
 | 
			
		||||
static const char col_gray4[]       = "#eeeeee";
 | 
			
		||||
static const char col_cyan[]        = "#005577";
 | 
			
		||||
static const char *colors[][3]      = {
 | 
			
		||||
	/*               fg         bg         border   */
 | 
			
		||||
	[SchemeNorm] = { col_gray3, col_gray1, col_gray2 },
 | 
			
		||||
	[SchemeSel]  = { col_gray4, col_cyan,  col_cyan  },
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/* tagging */
 | 
			
		||||
static const char *tags[] = { "1", "2", "3", "4", "5", "6", "7", "8", "9" };
 | 
			
		||||
 | 
			
		||||
static const Rule rules[] = {
 | 
			
		||||
	/* xprop(1):
 | 
			
		||||
	 *	WM_CLASS(STRING) = instance, class
 | 
			
		||||
	 *	WM_NAME(STRING) = title
 | 
			
		||||
	 */
 | 
			
		||||
	/* class      instance    title       tags mask     isfloating   monitor */
 | 
			
		||||
	{ "Gimp",     NULL,       NULL,       0,            1,           -1 },
 | 
			
		||||
	{ "Firefox",  NULL,       NULL,       1 << 8,       0,           -1 },
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/* layout(s) */
 | 
			
		||||
static const float mfact     = 0.55; /* factor of master area size [0.05..0.95] */
 | 
			
		||||
static const int nmaster     = 1;    /* number of clients in master area */
 | 
			
		||||
static const int resizehints = 1;    /* 1 means respect size hints in tiled resizals */
 | 
			
		||||
static const int lockfullscreen = 1; /* 1 will force focus on the fullscreen window */
 | 
			
		||||
 | 
			
		||||
static const Layout layouts[] = {
 | 
			
		||||
	/* symbol     arrange function */
 | 
			
		||||
	{ "[]=",      tile },    /* first entry is default */
 | 
			
		||||
	{ "><>",      NULL },    /* no layout function means floating behavior */
 | 
			
		||||
	{ "[M]",      monocle },
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/* key definitions */
 | 
			
		||||
#define MODKEY Mod1Mask
 | 
			
		||||
#define TAGKEYS(KEY,TAG) \
 | 
			
		||||
	{ MODKEY,                       KEY,      view,           {.ui = 1 << TAG} }, \
 | 
			
		||||
	{ MODKEY|ControlMask,           KEY,      toggleview,     {.ui = 1 << TAG} }, \
 | 
			
		||||
	{ MODKEY|ShiftMask,             KEY,      tag,            {.ui = 1 << TAG} }, \
 | 
			
		||||
	{ MODKEY|ControlMask|ShiftMask, KEY,      toggletag,      {.ui = 1 << TAG} },
 | 
			
		||||
 | 
			
		||||
/* helper for spawning shell commands in the pre dwm-5.0 fashion */
 | 
			
		||||
#define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } }
 | 
			
		||||
 | 
			
		||||
/* commands */
 | 
			
		||||
static const char *dmenucmd[] = { "dmenu_run", "-fn", dmenufont, "-nb", col_gray1, "-nf", col_gray3, "-sb", col_cyan, "-sf", col_gray4, NULL };
 | 
			
		||||
static const char *termcmd[]  = { "st", NULL };
 | 
			
		||||
 | 
			
		||||
static const Key keys[] = {
 | 
			
		||||
	/* modifier                     key        function        argument */
 | 
			
		||||
	{ MODKEY,                       XK_p,      spawn,          {.v = dmenucmd } },
 | 
			
		||||
	{ MODKEY|ShiftMask,             XK_Return, spawn,          {.v = termcmd } },
 | 
			
		||||
	{ MODKEY,                       XK_b,      togglebar,      {0} },
 | 
			
		||||
	{ MODKEY,                       XK_j,      focusstack,     {.i = +1 } },
 | 
			
		||||
	{ MODKEY,                       XK_k,      focusstack,     {.i = -1 } },
 | 
			
		||||
	{ MODKEY,                       XK_i,      incnmaster,     {.i = +1 } },
 | 
			
		||||
	{ MODKEY,                       XK_d,      incnmaster,     {.i = -1 } },
 | 
			
		||||
	{ MODKEY,                       XK_h,      setmfact,       {.f = -0.05} },
 | 
			
		||||
	{ MODKEY,                       XK_l,      setmfact,       {.f = +0.05} },
 | 
			
		||||
	{ MODKEY,                       XK_Return, zoom,           {0} },
 | 
			
		||||
	{ MODKEY,                       XK_Tab,    view,           {0} },
 | 
			
		||||
	{ MODKEY|ShiftMask,             XK_c,      killclient,     {0} },
 | 
			
		||||
	{ MODKEY,                       XK_t,      setlayout,      {.v = &layouts[0]} },
 | 
			
		||||
	{ MODKEY,                       XK_f,      setlayout,      {.v = &layouts[1]} },
 | 
			
		||||
	{ MODKEY,                       XK_m,      setlayout,      {.v = &layouts[2]} },
 | 
			
		||||
	{ MODKEY,                       XK_space,  setlayout,      {0} },
 | 
			
		||||
	{ MODKEY|ShiftMask,             XK_space,  togglefloating, {0} },
 | 
			
		||||
	{ MODKEY,                       XK_0,      view,           {.ui = ~0 } },
 | 
			
		||||
	{ MODKEY|ShiftMask,             XK_0,      tag,            {.ui = ~0 } },
 | 
			
		||||
	{ MODKEY,                       XK_comma,  focusmon,       {.i = -1 } },
 | 
			
		||||
	{ MODKEY,                       XK_period, focusmon,       {.i = +1 } },
 | 
			
		||||
	{ MODKEY|ShiftMask,             XK_comma,  tagmon,         {.i = -1 } },
 | 
			
		||||
	{ MODKEY|ShiftMask,             XK_period, tagmon,         {.i = +1 } },
 | 
			
		||||
	TAGKEYS(                        XK_1,                      0)
 | 
			
		||||
	TAGKEYS(                        XK_2,                      1)
 | 
			
		||||
	TAGKEYS(                        XK_3,                      2)
 | 
			
		||||
	TAGKEYS(                        XK_4,                      3)
 | 
			
		||||
	TAGKEYS(                        XK_5,                      4)
 | 
			
		||||
	TAGKEYS(                        XK_6,                      5)
 | 
			
		||||
	TAGKEYS(                        XK_7,                      6)
 | 
			
		||||
	TAGKEYS(                        XK_8,                      7)
 | 
			
		||||
	TAGKEYS(                        XK_9,                      8)
 | 
			
		||||
	{ MODKEY|ShiftMask,             XK_q,      quit,           {0} },
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/* button definitions */
 | 
			
		||||
/* click can be ClkTagBar, ClkLtSymbol, ClkStatusText, ClkWinTitle, ClkClientWin, or ClkRootWin */
 | 
			
		||||
static const Button buttons[] = {
 | 
			
		||||
	/* click                event mask      button          function        argument */
 | 
			
		||||
	{ ClkLtSymbol,          0,              Button1,        setlayout,      {0} },
 | 
			
		||||
	{ ClkLtSymbol,          0,              Button3,        setlayout,      {.v = &layouts[2]} },
 | 
			
		||||
	{ ClkWinTitle,          0,              Button2,        zoom,           {0} },
 | 
			
		||||
	{ ClkStatusText,        0,              Button2,        spawn,          {.v = termcmd } },
 | 
			
		||||
	{ ClkClientWin,         MODKEY,         Button1,        movemouse,      {0} },
 | 
			
		||||
	{ ClkClientWin,         MODKEY,         Button2,        togglefloating, {0} },
 | 
			
		||||
	{ ClkClientWin,         MODKEY,         Button3,        resizemouse,    {0} },
 | 
			
		||||
	{ ClkTagBar,            0,              Button1,        view,           {0} },
 | 
			
		||||
	{ ClkTagBar,            0,              Button3,        toggleview,     {0} },
 | 
			
		||||
	{ ClkTagBar,            MODKEY,         Button1,        tag,            {0} },
 | 
			
		||||
	{ ClkTagBar,            MODKEY,         Button3,        toggletag,      {0} },
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -355,7 +355,6 @@ drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, unsigned int lp
 | 
			
		|||
			fcpattern = FcPatternDuplicate(drw->fonts->pattern);
 | 
			
		||||
			FcPatternAddCharSet(fcpattern, FC_CHARSET, fccharset);
 | 
			
		||||
			FcPatternAddBool(fcpattern, FC_SCALABLE, FcTrue);
 | 
			
		||||
			FcPatternAddBool(fcpattern, FC_COLOR, FcFalse);
 | 
			
		||||
 | 
			
		||||
			FcConfigSubstitute(NULL, fcpattern, FcMatchPattern);
 | 
			
		||||
			FcDefaultSubstitute(fcpattern);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -209,7 +209,7 @@ static void monocle(Monitor *m);
 | 
			
		|||
static void motionnotify(XEvent *e);
 | 
			
		||||
static void movemouse(const Arg *arg);
 | 
			
		||||
static Client *nexttiled(Client *c);
 | 
			
		||||
static void pop(Client *);
 | 
			
		||||
static void pop(Client *c);
 | 
			
		||||
static void propertynotify(XEvent *e);
 | 
			
		||||
static void quit(const Arg *arg);
 | 
			
		||||
static Monitor *recttomon(int x, int y, int w, int h);
 | 
			
		||||
| 
						 | 
				
			
			@ -222,7 +222,7 @@ static void resizerequest(XEvent *e);
 | 
			
		|||
static void restack(Monitor *m);
 | 
			
		||||
static void run(void);
 | 
			
		||||
static void scan(void);
 | 
			
		||||
static int sendevent(Window w, Atom proto, int m, long d0, long d1, long d2, long d3, long d4);
 | 
			
		||||
static int sendevent(Client *c, Atom proto, int m, long d0, long d1, long d2, long d3, long d4);
 | 
			
		||||
static void sendmon(Client *c, Monitor *m);
 | 
			
		||||
static void setclientstate(Client *c, long state);
 | 
			
		||||
static void setfocus(Client *c);
 | 
			
		||||
| 
						 | 
				
			
			@ -238,7 +238,7 @@ static void spawn(const Arg *arg);
 | 
			
		|||
static Monitor *systraytomon(Monitor *m);
 | 
			
		||||
static void tag(const Arg *arg);
 | 
			
		||||
static void tagmon(const Arg *arg);
 | 
			
		||||
static void tile(Monitor *);
 | 
			
		||||
static void tile(Monitor *m);
 | 
			
		||||
static void togglebar(const Arg *arg);
 | 
			
		||||
static void togglefloating(const Arg *arg);
 | 
			
		||||
static void togglesticky(const Arg *arg);
 | 
			
		||||
| 
						 | 
				
			
			@ -276,7 +276,7 @@ static const char broken[] = "broken";
 | 
			
		|||
static char stext[256];
 | 
			
		||||
static int screen;
 | 
			
		||||
static int sw, sh;           /* X display screen geometry width, height */
 | 
			
		||||
static int bh, blw = 0;      /* bar geometry */
 | 
			
		||||
static int bh;               /* bar height */
 | 
			
		||||
static int lrpad;            /* sum of left and right padding for text */
 | 
			
		||||
static int (*xerrorxlib)(Display *, XErrorEvent *);
 | 
			
		||||
static unsigned int numlockmask = 0;
 | 
			
		||||
| 
						 | 
				
			
			@ -514,7 +514,7 @@ buttonpress(XEvent *e)
 | 
			
		|||
		if (i < LENGTH(tags)) {
 | 
			
		||||
			click = ClkTagBar;
 | 
			
		||||
			arg.ui = 1 << i;
 | 
			
		||||
		} else if (ev->x < x + blw)
 | 
			
		||||
		} else if (ev->x < x + TEXTW(selmon->ltsymbol))
 | 
			
		||||
			click = ClkLtSymbol;
 | 
			
		||||
		else if (ev->x > selmon->ww - (int)TEXTW(stext) - getsystraywidth())
 | 
			
		||||
			click = ClkStatusText;
 | 
			
		||||
| 
						 | 
				
			
			@ -885,7 +885,7 @@ drawbar(Monitor *m)
 | 
			
		|||
				urg & 1 << i);
 | 
			
		||||
		x += w;
 | 
			
		||||
	}
 | 
			
		||||
	w = blw = TEXTW(m->ltsymbol);
 | 
			
		||||
	w = TEXTW(m->ltsymbol);
 | 
			
		||||
	drw_setscheme(drw, scheme[SchemeNorm]);
 | 
			
		||||
	x = drw_text(drw, x, 0, w, bh, lrpad / 2, m->ltsymbol, 0);
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -1093,13 +1093,11 @@ gettextprop(Window w, Atom atom, char *text, unsigned int size)
 | 
			
		|||
	text[0] = '\0';
 | 
			
		||||
	if (!XGetTextProperty(dpy, w, &name, atom) || !name.nitems)
 | 
			
		||||
		return 0;
 | 
			
		||||
	if (name.encoding == XA_STRING)
 | 
			
		||||
	if (name.encoding == XA_STRING) {
 | 
			
		||||
		strncpy(text, (char *)name.value, size - 1);
 | 
			
		||||
	else {
 | 
			
		||||
		if (XmbTextPropertyToTextList(dpy, &name, &list, &n) >= Success && n > 0 && *list) {
 | 
			
		||||
			strncpy(text, *list, size - 1);
 | 
			
		||||
			XFreeStringList(list);
 | 
			
		||||
		}
 | 
			
		||||
	} else if (XmbTextPropertyToTextList(dpy, &name, &list, &n) >= Success && n > 0 && *list) {
 | 
			
		||||
		strncpy(text, *list, size - 1);
 | 
			
		||||
		XFreeStringList(list);
 | 
			
		||||
	}
 | 
			
		||||
	text[size - 1] = '\0';
 | 
			
		||||
	XFree(name.value);
 | 
			
		||||
| 
						 | 
				
			
			@ -1222,14 +1220,12 @@ manage(Window w, XWindowAttributes *wa)
 | 
			
		|||
		applyrules(c);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if (c->x + WIDTH(c) > c->mon->mx + c->mon->mw)
 | 
			
		||||
		c->x = c->mon->mx + c->mon->mw - WIDTH(c);
 | 
			
		||||
	if (c->y + HEIGHT(c) > c->mon->my + c->mon->mh)
 | 
			
		||||
		c->y = c->mon->my + c->mon->mh - HEIGHT(c);
 | 
			
		||||
	c->x = MAX(c->x, c->mon->mx);
 | 
			
		||||
	/* only fix client y-offset, if the client center might cover the bar */
 | 
			
		||||
	c->y = MAX(c->y, ((c->mon->by == c->mon->my) && (c->x + (c->w / 2) >= c->mon->wx)
 | 
			
		||||
		&& (c->x + (c->w / 2) < c->mon->wx + c->mon->ww)) ? bh : c->mon->my);
 | 
			
		||||
	if (c->x + WIDTH(c) > c->mon->wx + c->mon->ww)
 | 
			
		||||
		c->x = c->mon->wx + c->mon->ww - WIDTH(c);
 | 
			
		||||
	if (c->y + HEIGHT(c) > c->mon->wy + c->mon->wh)
 | 
			
		||||
		c->y = c->mon->wy + c->mon->wh - HEIGHT(c);
 | 
			
		||||
	c->x = MAX(c->x, c->mon->wx);
 | 
			
		||||
	c->y = MAX(c->y, c->mon->wy);
 | 
			
		||||
	c->bw = borderpx;
 | 
			
		||||
 | 
			
		||||
	wc.border_width = c->bw;
 | 
			
		||||
| 
						 | 
				
			
			@ -1277,6 +1273,7 @@ maprequest(XEvent *e)
 | 
			
		|||
	static XWindowAttributes wa;
 | 
			
		||||
	XMapRequestEvent *ev = &e->xmaprequest;
 | 
			
		||||
 | 
			
		||||
<<<<<<< HEAD:src/dwm.c.orig
 | 
			
		||||
	Client *i;
 | 
			
		||||
	if ((i = wintosystrayicon(ev->window))) {
 | 
			
		||||
		sendevent(i->win, netatom[Xembed], StructureNotifyMask, CurrentTime, XEMBED_WINDOW_ACTIVATE, 0, systray->win, XEMBED_EMBEDDED_VERSION);
 | 
			
		||||
| 
						 | 
				
			
			@ -1287,6 +1284,13 @@ maprequest(XEvent *e)
 | 
			
		|||
	if (!XGetWindowAttributes(dpy, ev->window, &wa))
 | 
			
		||||
		return;
 | 
			
		||||
	if (wa.override_redirect)
 | 
			
		||||
||||||| 6613d9f:dwm.c
 | 
			
		||||
	if (!XGetWindowAttributes(dpy, ev->window, &wa))
 | 
			
		||||
		return;
 | 
			
		||||
	if (wa.override_redirect)
 | 
			
		||||
=======
 | 
			
		||||
	if (!XGetWindowAttributes(dpy, ev->window, &wa) || wa.override_redirect)
 | 
			
		||||
>>>>>>> 970f37697358574e127019eb0ee2f5725ec05ce0:dwm.c
 | 
			
		||||
		return;
 | 
			
		||||
	if (!wintoclient(ev->window))
 | 
			
		||||
		manage(ev->window, &wa);
 | 
			
		||||
| 
						 | 
				
			
			@ -1673,7 +1677,7 @@ setclientstate(Client *c, long state)
 | 
			
		|||
}
 | 
			
		||||
 | 
			
		||||
int
 | 
			
		||||
sendevent(Window w, Atom proto, int mask, long d0, long d1, long d2, long d3, long d4)
 | 
			
		||||
sendevent(Client *c, Atom proto, int mask, long d0, long d1, long d2, long d3, long d4)
 | 
			
		||||
{
 | 
			
		||||
	int n;
 | 
			
		||||
	Atom *protocols, mt;
 | 
			
		||||
| 
						 | 
				
			
			@ -1695,15 +1699,15 @@ sendevent(Window w, Atom proto, int mask, long d0, long d1, long d2, long d3, lo
 | 
			
		|||
 | 
			
		||||
	if (exists) {
 | 
			
		||||
		ev.type = ClientMessage;
 | 
			
		||||
		ev.xclient.window = w;
 | 
			
		||||
		ev.xclient.message_type = mt;
 | 
			
		||||
		ev.xclient.window = c->win;
 | 
			
		||||
		ev.xclient.message_type = wmatom[WMProtocols];
 | 
			
		||||
		ev.xclient.format = 32;
 | 
			
		||||
		ev.xclient.data.l[0] = d0;
 | 
			
		||||
		ev.xclient.data.l[1] = d1;
 | 
			
		||||
		ev.xclient.data.l[0] = proto;
 | 
			
		||||
		ev.xclient.data.l[1] = CurrentTime;
 | 
			
		||||
		ev.xclient.data.l[2] = d2;
 | 
			
		||||
		ev.xclient.data.l[3] = d3;
 | 
			
		||||
		ev.xclient.data.l[4] = d4;
 | 
			
		||||
		XSendEvent(dpy, w, False, mask, &ev);
 | 
			
		||||
		XSendEvent(dpy, c->w, False, mask, &ev);
 | 
			
		||||
	}
 | 
			
		||||
	return exists;
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -1869,7 +1873,6 @@ setup(void)
 | 
			
		|||
	focus(NULL);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
seturgent(Client *c, int urg)
 | 
			
		||||
{
 | 
			
		||||
| 
						 | 
				
			
			@ -1904,6 +1907,7 @@ showhide(Client *c)
 | 
			
		|||
void
 | 
			
		||||
sigchld(int unused)
 | 
			
		||||
{
 | 
			
		||||
<<<<<<< HEAD:src/dwm.c.orig
 | 
			
		||||
	pid_t pid;
 | 
			
		||||
 | 
			
		||||
	if (signal(SIGCHLD, sigchld) == SIG_ERR)
 | 
			
		||||
| 
						 | 
				
			
			@ -1923,21 +1927,24 @@ sigchld(int unused)
 | 
			
		|||
		}
 | 
			
		||||
 | 
			
		||||
	}
 | 
			
		||||
||||||| 6613d9f:dwm.c
 | 
			
		||||
	while (0 < waitpid(-1, NULL, WNOHANG));
 | 
			
		||||
=======
 | 
			
		||||
	if (signal(SIGCHLD, sigchld) == SIG_ERR)
 | 
			
		||||
		die("can't install SIGCHLD handler:");
 | 
			
		||||
	while (0 < waitpid(-1, NULL, WNOHANG));
 | 
			
		||||
>>>>>>> 970f37697358574e127019eb0ee2f5725ec05ce0:dwm.c
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
spawn(const Arg *arg)
 | 
			
		||||
{
 | 
			
		||||
	if (arg->v == dmenucmd)
 | 
			
		||||
		dmenumon[0] = '0' + selmon->num;
 | 
			
		||||
	if (fork() == 0) {
 | 
			
		||||
		if (dpy)
 | 
			
		||||
			close(ConnectionNumber(dpy));
 | 
			
		||||
		setsid();
 | 
			
		||||
		execvp(((char **)arg->v)[0], (char **)arg->v);
 | 
			
		||||
		fprintf(stderr, "dwm: execvp %s", ((char **)arg->v)[0]);
 | 
			
		||||
		perror(" failed");
 | 
			
		||||
		exit(EXIT_SUCCESS);
 | 
			
		||||
		die("dwm: execvp '%s' failed:", ((char **)arg->v)[0]);
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -2078,6 +2085,7 @@ unmanage(Client *c, int destroyed)
 | 
			
		|||
		wc.border_width = c->oldbw;
 | 
			
		||||
		XGrabServer(dpy); /* avoid race conditions */
 | 
			
		||||
		XSetErrorHandler(xerrordummy);
 | 
			
		||||
		XSelectInput(dpy, c->win, NoEventMask);
 | 
			
		||||
		XConfigureWindow(dpy, c->win, CWBorderWidth, &wc); /* restore border */
 | 
			
		||||
		XUngrabButton(dpy, AnyButton, AnyModifier, c->win);
 | 
			
		||||
		setclientstate(c, WithdrawnState);
 | 
			
		||||
| 
						 | 
				
			
			@ -2606,12 +2614,10 @@ zoom(const Arg *arg)
 | 
			
		|||
{
 | 
			
		||||
	Client *c = selmon->sel;
 | 
			
		||||
 | 
			
		||||
	if (!selmon->lt[selmon->sellt]->arrange
 | 
			
		||||
	|| (selmon->sel && selmon->sel->isfloating))
 | 
			
		||||
	if (!selmon->lt[selmon->sellt]->arrange || !c || c->isfloating)
 | 
			
		||||
		return;
 | 
			
		||||
	if (c == nexttiled(selmon->clients) && !(c = nexttiled(c->next)))
 | 
			
		||||
		return;
 | 
			
		||||
	if (c == nexttiled(selmon->clients))
 | 
			
		||||
		if (!c || !(c = nexttiled(c->next)))
 | 
			
		||||
			return;
 | 
			
		||||
	pop(c);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										23
									
								
								src/util.c
									
										
									
									
									
								
							
							
						
						
									
										23
									
								
								src/util.c
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -6,18 +6,9 @@
 | 
			
		|||
 | 
			
		||||
#include "util.h"
 | 
			
		||||
 | 
			
		||||
void *
 | 
			
		||||
ecalloc(size_t nmemb, size_t size)
 | 
			
		||||
{
 | 
			
		||||
	void *p;
 | 
			
		||||
 | 
			
		||||
	if (!(p = calloc(nmemb, size)))
 | 
			
		||||
		die("calloc:");
 | 
			
		||||
	return p;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
die(const char *fmt, ...) {
 | 
			
		||||
die(const char *fmt, ...)
 | 
			
		||||
{
 | 
			
		||||
	va_list ap;
 | 
			
		||||
 | 
			
		||||
	va_start(ap, fmt);
 | 
			
		||||
| 
						 | 
				
			
			@ -33,3 +24,13 @@ die(const char *fmt, ...) {
 | 
			
		|||
 | 
			
		||||
	exit(1);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void *
 | 
			
		||||
ecalloc(size_t nmemb, size_t size)
 | 
			
		||||
{
 | 
			
		||||
	void *p;
 | 
			
		||||
 | 
			
		||||
	if (!(p = calloc(nmemb, size)))
 | 
			
		||||
		die("calloc:");
 | 
			
		||||
	return p;
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue