add swallow patch
This commit is contained in:
		
							parent
							
								
									d5fb9c9217
								
							
						
					
					
						commit
						96065f0f1f
					
				| @ -5,6 +5,7 @@ static const unsigned int borderpx  = 1;        /* border pixel of windows */ | ||||
| static const int startwithgaps	     = 0;	 /* 1 means gaps are used by default */ | ||||
| static const unsigned int gappx     = 10;       /* default gap between windows in pixels */ | ||||
| static const unsigned int snap      = 32;       /* snap pixel */ | ||||
| static const int swallowfloating    = 0;        /* 1 means swallow floating windows by default */ | ||||
| static const int showbar            = 1;        /* 0 means no bar */ | ||||
| static const int topbar             = 1;        /* 0 means bottom bar */ | ||||
| static const char *fonts[]          = { "Fairfax Hax HD:size=22" }; | ||||
| @ -28,9 +29,11 @@ static const Rule rules[] = { | ||||
| 	 *	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 }, | ||||
| 	/* class     instance  title           tags mask  isfloating  isterminal  noswallow  monitor */ | ||||
| 	{ "Gimp",    NULL,     NULL,           0,         1,          0,           0,        -1 }, | ||||
| 	{ "Firefox", NULL,     NULL,           1 << 8,    0,          0,          -1,        -1 }, | ||||
| 	{ "St",      NULL,     NULL,           0,         0,          1,           0,        -1 }, | ||||
| 	{ NULL,      NULL,     "Event Tester", 0,         0,          0,           1,        -1 }, /* xev */ | ||||
| }; | ||||
| 
 | ||||
| /* layout(s) */ | ||||
|  | ||||
| @ -2,6 +2,8 @@ | ||||
| 
 | ||||
| /* appearance */ | ||||
| static const unsigned int borderpx  = 1;        /* border pixel of windows */ | ||||
| static const int startwithgaps	     = 0;	 /* 1 means gaps are used by default */ | ||||
| static const unsigned int gappx     = 10;       /* default gap between windows in pixels */ | ||||
| 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 */ | ||||
| @ -85,6 +87,10 @@ static const Key keys[] = { | ||||
| 	{ MODKEY,                       XK_period, focusmon,       {.i = +1 } }, | ||||
| 	{ MODKEY|ShiftMask,             XK_comma,  tagmon,         {.i = -1 } }, | ||||
| 	{ MODKEY|ShiftMask,             XK_period, tagmon,         {.i = +1 } }, | ||||
| 	{ MODKEY,                       XK_minus,  setgaps,        {.i = -5 } }, | ||||
| 	{ MODKEY,                       XK_equal,  setgaps,        {.i = +5 } }, | ||||
| 	{ MODKEY|ShiftMask,             XK_minus,  setgaps,        {.i = GAP_RESET } }, | ||||
| 	{ MODKEY|ShiftMask,             XK_equal,  setgaps,        {.i = GAP_TOGGLE} }, | ||||
| 	TAGKEYS(                        XK_1,                      0) | ||||
| 	TAGKEYS(                        XK_2,                      1) | ||||
| 	TAGKEYS(                        XK_3,                      2) | ||||
|  | ||||
							
								
								
									
										9
									
								
								config.h
									
									
									
									
									
								
							
							
						
						
									
										9
									
								
								config.h
									
									
									
									
									
								
							| @ -10,6 +10,7 @@ static void shutdown(const Arg *arg); | ||||
| /* appearance */ | ||||
| static unsigned int borderpx  = 2;        /* border pixel of windows */ | ||||
| static const int startwithgaps	 = 0;	 /* 1 means gaps are used by default */ | ||||
| static const int swallowfloating    = 0;        /* 1 means swallow floating windows by default */ | ||||
| static const unsigned int gappx  = 10;       /* default gap between windows in pixels */ | ||||
| static unsigned int snap      = 32;       /* snap pixel */ | ||||
| static int showbar            = 1;        /* 0 means no bar */ | ||||
| @ -45,9 +46,11 @@ static const Rule rules[] = { | ||||
| 	 *	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 }, | ||||
| 	/* class     instance  title           tags mask  isfloating  isterminal  noswallow  monitor */ | ||||
| 	{ "Gimp",    NULL,     NULL,           0,         1,          0,           0,        -1 }, | ||||
| 	{ "Firefox", NULL,     NULL,           1 << 8,    0,          0,          -1,        -1 }, | ||||
| 	{ "St",      NULL,     NULL,           0,         0,          1,           0,        -1 }, | ||||
| 	{ NULL,      NULL,     "Event Tester", 0,         0,          0,           1,        -1 }, /* xev */ | ||||
| }; | ||||
| 
 | ||||
| /* layout(s) */ | ||||
|  | ||||
| @ -20,10 +20,11 @@ FREETYPEINC = /usr/include/freetype2 | ||||
| # OpenBSD (uncomment)
 | ||||
| #FREETYPEINC = ${X11INC}/freetype2
 | ||||
| #MANPREFIX = ${PREFIX}/man
 | ||||
| #KVMLIB = -lkvm
 | ||||
| 
 | ||||
| # includes and libs
 | ||||
| INCS = -I${X11INC} -I${FREETYPEINC} | ||||
| LIBS = -L${X11LIB} -lX11 ${XINERAMALIBS} ${FREETYPELIBS} | ||||
| LIBS = -L${X11LIB} -lX11 ${XINERAMALIBS} ${FREETYPELIBS} -lX11-xcb -lxcb -lxcb-res ${KVMLIB} | ||||
| 
 | ||||
| # flags
 | ||||
| CPPFLAGS = -D_DEFAULT_SOURCE -D_BSD_SOURCE -D_XOPEN_SOURCE=700L -DVERSION=\"${VERSION}\" ${XINERAMAFLAGS} | ||||
|  | ||||
							
								
								
									
										231
									
								
								dwm.c
									
									
									
									
									
								
							
							
						
						
									
										231
									
								
								dwm.c
									
									
									
									
									
								
							| @ -41,6 +41,12 @@ | ||||
| #include <X11/extensions/Xinerama.h> | ||||
| #endif /* XINERAMA */ | ||||
| #include <X11/Xft/Xft.h> | ||||
| #include <X11/Xlib-xcb.h> | ||||
| #include <xcb/res.h> | ||||
| #ifdef __OpenBSD__ | ||||
| #include <sys/sysctl.h> | ||||
| #include <kvm.h> | ||||
| #endif /* __OpenBSD */ | ||||
| 
 | ||||
| #include "drw.h" | ||||
| #include "util.h" | ||||
| @ -96,9 +102,11 @@ struct Client { | ||||
| 	int basew, baseh, incw, inch, maxw, maxh, minw, minh, hintsvalid; | ||||
| 	int bw, oldbw; | ||||
| 	unsigned int tags; | ||||
| 	int isfixed, isfloating, isurgent, neverfocus, oldstate, isfullscreen; | ||||
| 	int isfixed, isfloating, isurgent, neverfocus, oldstate, isfullscreen, isterminal, noswallow; | ||||
| 	pid_t pid; | ||||
| 	Client *next; | ||||
| 	Client *snext; | ||||
| 	Client *swallowing; | ||||
| 	Monitor *mon; | ||||
| 	Window win; | ||||
| }; | ||||
| @ -144,6 +152,8 @@ typedef struct { | ||||
| 	const char *title; | ||||
| 	unsigned int tags; | ||||
| 	int isfloating; | ||||
| 	int isterminal; | ||||
| 	int noswallow; | ||||
| 	int monitor; | ||||
| } Rule; | ||||
| 
 | ||||
| @ -256,6 +266,12 @@ static void zoom(const Arg *arg); | ||||
| static void load_xresources(void); | ||||
| static void resource_load(XrmDatabase db, char *name, enum resource_type rtype, void *dst); | ||||
| 
 | ||||
| static pid_t getparentprocess(pid_t p); | ||||
| static int isdescprocess(pid_t p, pid_t c); | ||||
| static Client *swallowingclient(Window w); | ||||
| static Client *termforwin(const Client *c); | ||||
| static pid_t winpid(Window w); | ||||
| 
 | ||||
| /* variables */ | ||||
| static const char broken[] = "broken"; | ||||
| static char stext[256]; | ||||
| @ -290,6 +306,8 @@ static Drw *drw; | ||||
| static Monitor *mons, *selmon; | ||||
| static Window root, wmcheckwin; | ||||
| 
 | ||||
| static xcb_connection_t *xcon; | ||||
| 
 | ||||
| /* configuration, allows nested code to access above variables */ | ||||
| #include "config.h" | ||||
| 
 | ||||
| @ -319,6 +337,8 @@ applyrules(Client *c) | ||||
| 		&& (!r->class || strstr(class, r->class)) | ||||
| 		&& (!r->instance || strstr(instance, r->instance))) | ||||
| 		{ | ||||
| 			c->isterminal = r->isterminal; | ||||
| 			c->noswallow  = r->noswallow; | ||||
| 			c->isfloating = r->isfloating; | ||||
| 			c->tags |= r->tags; | ||||
| 			for (m = mons; m && m->num != r->monitor; m = m->next); | ||||
| @ -437,6 +457,53 @@ attachstack(Client *c) | ||||
| 	c->mon->stack = c; | ||||
| } | ||||
| 
 | ||||
| void | ||||
| swallow(Client *p, Client *c) | ||||
| { | ||||
| 
 | ||||
| 	if (c->noswallow || c->isterminal) | ||||
| 		return; | ||||
| 	if (c->noswallow && !swallowfloating && c->isfloating) | ||||
| 		return; | ||||
| 
 | ||||
| 	detach(c); | ||||
| 	detachstack(c); | ||||
| 
 | ||||
| 	setclientstate(c, WithdrawnState); | ||||
| 	XUnmapWindow(dpy, p->win); | ||||
| 
 | ||||
| 	p->swallowing = c; | ||||
| 	c->mon = p->mon; | ||||
| 
 | ||||
| 	Window w = p->win; | ||||
| 	p->win = c->win; | ||||
| 	c->win = w; | ||||
| 	updatetitle(p); | ||||
| 	XMoveResizeWindow(dpy, p->win, p->x, p->y, p->w, p->h); | ||||
| 	arrange(p->mon); | ||||
| 	configure(p); | ||||
| 	updateclientlist(); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| unswallow(Client *c) | ||||
| { | ||||
| 	c->win = c->swallowing->win; | ||||
| 
 | ||||
| 	free(c->swallowing); | ||||
| 	c->swallowing = NULL; | ||||
| 
 | ||||
| 	/* unfullscreen the client */ | ||||
| 	setfullscreen(c, 0); | ||||
| 	updatetitle(c); | ||||
| 	arrange(c->mon); | ||||
| 	XMapWindow(dpy, c->win); | ||||
| 	XMoveResizeWindow(dpy, c->win, c->x, c->y, c->w, c->h); | ||||
| 	setclientstate(c, NormalState); | ||||
| 	focus(NULL); | ||||
| 	arrange(c->mon); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| buttonpress(XEvent *e) | ||||
| { | ||||
| @ -679,6 +746,9 @@ destroynotify(XEvent *e) | ||||
| 
 | ||||
| 	if ((c = wintoclient(ev->window))) | ||||
| 		unmanage(c, 1); | ||||
| 
 | ||||
| 	else if ((c = swallowingclient(ev->window))) | ||||
| 		unmanage(c->swallowing, 1); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| @ -1061,12 +1131,13 @@ killclient(const Arg *arg) | ||||
| void | ||||
| manage(Window w, XWindowAttributes *wa) | ||||
| { | ||||
| 	Client *c, *t = NULL; | ||||
| 	Client *c, *t = NULL, *term = NULL; | ||||
| 	Window trans = None; | ||||
| 	XWindowChanges wc; | ||||
| 
 | ||||
| 	c = ecalloc(1, sizeof(Client)); | ||||
| 	c->win = w; | ||||
| 	c->pid = winpid(w); | ||||
| 	/* geometry */ | ||||
| 	c->x = c->oldx = wa->x; | ||||
| 	c->y = c->oldy = wa->y; | ||||
| @ -1081,6 +1152,7 @@ manage(Window w, XWindowAttributes *wa) | ||||
| 	} else { | ||||
| 		c->mon = selmon; | ||||
| 		applyrules(c); | ||||
| 		term = termforwin(c); | ||||
| 	} | ||||
| 
 | ||||
| 	if (c->x + WIDTH(c) > c->mon->wx + c->mon->ww) | ||||
| @ -1115,6 +1187,8 @@ manage(Window w, XWindowAttributes *wa) | ||||
| 	c->mon->sel = c; | ||||
| 	arrange(c->mon); | ||||
| 	XMapWindow(dpy, c->win); | ||||
| 	if (term) | ||||
| 		swallow(term, c); | ||||
| 	focus(NULL); | ||||
| } | ||||
| 
 | ||||
| @ -1862,6 +1936,20 @@ unmanage(Client *c, int destroyed) | ||||
| 	Monitor *m = c->mon; | ||||
| 	XWindowChanges wc; | ||||
| 
 | ||||
| 	if (c->swallowing) { | ||||
| 		unswallow(c); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	Client *s = swallowingclient(c->win); | ||||
| 	if (s) { | ||||
| 		free(s->swallowing); | ||||
| 		s->swallowing = NULL; | ||||
| 		arrange(m); | ||||
| 		focus(NULL); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	detach(c); | ||||
| 	detachstack(c); | ||||
| 	if (!destroyed) { | ||||
| @ -1877,9 +1965,12 @@ unmanage(Client *c, int destroyed) | ||||
| 		XUngrabServer(dpy); | ||||
| 	} | ||||
| 	free(c); | ||||
| 
 | ||||
| 	if (!s) { | ||||
| 		arrange(m); | ||||
| 		focus(NULL); | ||||
| 		updateclientlist(); | ||||
| 	arrange(m); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| void | ||||
| @ -2143,6 +2234,136 @@ view(const Arg *arg) | ||||
| 	arrange(selmon); | ||||
| } | ||||
| 
 | ||||
| pid_t | ||||
| winpid(Window w) | ||||
| { | ||||
| 
 | ||||
| 	pid_t result = 0; | ||||
| 
 | ||||
| #ifdef __linux__ | ||||
| 	xcb_res_client_id_spec_t spec = {0}; | ||||
| 	spec.client = w; | ||||
| 	spec.mask = XCB_RES_CLIENT_ID_MASK_LOCAL_CLIENT_PID; | ||||
| 
 | ||||
| 	xcb_generic_error_t *e = NULL; | ||||
| 	xcb_res_query_client_ids_cookie_t c = xcb_res_query_client_ids(xcon, 1, &spec); | ||||
| 	xcb_res_query_client_ids_reply_t *r = xcb_res_query_client_ids_reply(xcon, c, &e); | ||||
| 
 | ||||
| 	if (!r) | ||||
| 		return (pid_t)0; | ||||
| 
 | ||||
| 	xcb_res_client_id_value_iterator_t i = xcb_res_query_client_ids_ids_iterator(r); | ||||
| 	for (; i.rem; xcb_res_client_id_value_next(&i)) { | ||||
| 		spec = i.data->spec; | ||||
| 		if (spec.mask & XCB_RES_CLIENT_ID_MASK_LOCAL_CLIENT_PID) { | ||||
| 			uint32_t *t = xcb_res_client_id_value_value(i.data); | ||||
| 			result = *t; | ||||
| 			break; | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	free(r); | ||||
| 
 | ||||
| 	if (result == (pid_t)-1) | ||||
| 		result = 0; | ||||
| 
 | ||||
| #endif /* __linux__ */ | ||||
| 
 | ||||
| #ifdef __OpenBSD__ | ||||
|         Atom type; | ||||
|         int format; | ||||
|         unsigned long len, bytes; | ||||
|         unsigned char *prop; | ||||
|         pid_t ret; | ||||
| 
 | ||||
|         if (XGetWindowProperty(dpy, w, XInternAtom(dpy, "_NET_WM_PID", 0), 0, 1, False, AnyPropertyType, &type, &format, &len, &bytes, &prop) != Success || !prop) | ||||
|                return 0; | ||||
| 
 | ||||
|         ret = *(pid_t*)prop; | ||||
|         XFree(prop); | ||||
|         result = ret; | ||||
| 
 | ||||
| #endif /* __OpenBSD__ */ | ||||
| 	return result; | ||||
| } | ||||
| 
 | ||||
| pid_t | ||||
| getparentprocess(pid_t p) | ||||
| { | ||||
| 	unsigned int v = 0; | ||||
| 
 | ||||
| #ifdef __linux__ | ||||
| 	FILE *f; | ||||
| 	char buf[256]; | ||||
| 	snprintf(buf, sizeof(buf) - 1, "/proc/%u/stat", (unsigned)p); | ||||
| 
 | ||||
| 	if (!(f = fopen(buf, "r"))) | ||||
| 		return 0; | ||||
| 
 | ||||
| 	fscanf(f, "%*u %*s %*c %u", &v); | ||||
| 	fclose(f); | ||||
| #endif /* __linux__*/ | ||||
| 
 | ||||
| #ifdef __OpenBSD__ | ||||
| 	int n; | ||||
| 	kvm_t *kd; | ||||
| 	struct kinfo_proc *kp; | ||||
| 
 | ||||
| 	kd = kvm_openfiles(NULL, NULL, NULL, KVM_NO_FILES, NULL); | ||||
| 	if (!kd) | ||||
| 		return 0; | ||||
| 
 | ||||
| 	kp = kvm_getprocs(kd, KERN_PROC_PID, p, sizeof(*kp), &n); | ||||
| 	v = kp->p_ppid; | ||||
| #endif /* __OpenBSD__ */ | ||||
| 
 | ||||
| 	return (pid_t)v; | ||||
| } | ||||
| 
 | ||||
| int | ||||
| isdescprocess(pid_t p, pid_t c) | ||||
| { | ||||
| 	while (p != c && c != 0) | ||||
| 		c = getparentprocess(c); | ||||
| 
 | ||||
| 	return (int)c; | ||||
| } | ||||
| 
 | ||||
| Client * | ||||
| termforwin(const Client *w) | ||||
| { | ||||
| 	Client *c; | ||||
| 	Monitor *m; | ||||
| 
 | ||||
| 	if (!w->pid || w->isterminal) | ||||
| 		return NULL; | ||||
| 
 | ||||
| 	for (m = mons; m; m = m->next) { | ||||
| 		for (c = m->clients; c; c = c->next) { | ||||
| 			if (c->isterminal && !c->swallowing && c->pid && isdescprocess(c->pid, w->pid)) | ||||
| 				return c; | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return NULL; | ||||
| } | ||||
| 
 | ||||
| Client * | ||||
| swallowingclient(Window w) | ||||
| { | ||||
| 	Client *c; | ||||
| 	Monitor *m; | ||||
| 
 | ||||
| 	for (m = mons; m; m = m->next) { | ||||
| 		for (c = m->clients; c; c = c->next) { | ||||
| 			if (c->swallowing && c->swallowing->win == w) | ||||
| 				return c; | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return NULL; | ||||
| } | ||||
| 
 | ||||
| Client * | ||||
| wintoclient(Window w) | ||||
| { | ||||
| @ -2286,12 +2507,14 @@ main(int argc, char *argv[]) | ||||
| 		fputs("warning: no locale support\n", stderr); | ||||
| 	if (!(dpy = XOpenDisplay(NULL))) | ||||
| 		die("dwm: cannot open display"); | ||||
| 	if (!(xcon = XGetXCBConnection(dpy))) | ||||
| 		die("dwm: cannot get xcb connection\n"); | ||||
| 	checkotherwm(); | ||||
| 	XrmInitialize(); | ||||
| 	load_xresources(); | ||||
| 	setup(); | ||||
| #ifdef __OpenBSD__ | ||||
| 	if (pledge("stdio rpath proc exec", NULL) == -1) | ||||
| 	if (pledge("stdio rpath proc exec ps", NULL) == -1) | ||||
| 		die("pledge"); | ||||
| #endif /* __OpenBSD__ */ | ||||
| 	scan(); | ||||
|  | ||||
							
								
								
									
										81
									
								
								dwm.c.orig
									
									
									
									
									
								
							
							
						
						
									
										81
									
								
								dwm.c.orig
									
									
									
									
									
								
							| @ -58,6 +58,9 @@ | ||||
| #define TAGMASK                 ((1 << LENGTH(tags)) - 1) | ||||
| #define TEXTW(X)                (drw_fontset_getwidth(drw, (X)) + lrpad) | ||||
| 
 | ||||
| #define GAP_TOGGLE 100 | ||||
| #define GAP_RESET  0 | ||||
| 
 | ||||
| /* enums */ | ||||
| enum { CurNormal, CurResize, CurMove, CurLast }; /* cursor */ | ||||
| enum { SchemeNorm, SchemeSel }; /* color schemes */ | ||||
| @ -120,6 +123,8 @@ struct Monitor { | ||||
| 	int by;               /* bar geometry */ | ||||
| 	int mx, my, mw, mh;   /* screen size */ | ||||
| 	int wx, wy, ww, wh;   /* window area  */ | ||||
| 	int gappx;	      /* gaps between windows */ | ||||
| 	int drawwithgaps;     /* toggle gaps */ | ||||
| 	unsigned int seltags; | ||||
| 	unsigned int sellt; | ||||
| 	unsigned int tagset[2]; | ||||
| @ -214,6 +219,7 @@ static void sendmon(Client *c, Monitor *m); | ||||
| static void setclientstate(Client *c, long state); | ||||
| static void setfocus(Client *c); | ||||
| static void setfullscreen(Client *c, int fullscreen); | ||||
| static void setgaps(const Arg *arg); | ||||
| static void setlayout(const Arg *arg); | ||||
| static void setmfact(const Arg *arg); | ||||
| static void setup(void); | ||||
| @ -657,6 +663,8 @@ createmon(void) | ||||
| 	m->nmaster = nmaster; | ||||
| 	m->showbar = showbar; | ||||
| 	m->topbar = topbar; | ||||
| 	m->gappx = gappx; | ||||
| 	m->drawwithgaps = startwithgaps; | ||||
| 	m->lt[0] = &layouts[0]; | ||||
| 	m->lt[1] = &layouts[1 % LENGTH(layouts)]; | ||||
| 	strncpy(m->ltsymbol, layouts[0].symbol, sizeof m->ltsymbol); | ||||
| @ -818,6 +826,12 @@ focus(Client *c) | ||||
| 		attachstack(c); | ||||
| 		grabbuttons(c, 1); | ||||
| 		XSetWindowBorder(dpy, c->win, scheme[SchemeSel][ColBorder].pixel); | ||||
|                 if (!selmon->drawwithgaps && !c->isfloating) { | ||||
| 			XWindowChanges wc; | ||||
|                         wc.sibling = selmon->barwin; | ||||
|                         wc.stack_mode = Below; | ||||
|                         XConfigureWindow(dpy, c->win, CWSibling | CWStackMode, &wc); | ||||
|                 } | ||||
| 		setfocus(c); | ||||
| 	} else { | ||||
| 		XSetInputFocus(dpy, root, RevertToPointerRoot, CurrentTime); | ||||
| @ -1138,7 +1152,10 @@ monocle(Monitor *m) | ||||
| 	if (n > 0) /* override layout symbol */ | ||||
| 		snprintf(m->ltsymbol, sizeof m->ltsymbol, "[%d]", n); | ||||
| 	for (c = nexttiled(m->clients); c; c = nexttiled(c->next)) | ||||
| 		if (selmon->drawwithgaps) | ||||
| 			resize(c, m->wx, m->wy, m->ww - 2 * c->bw, m->wh - 2 * c->bw, 0); | ||||
| 		else | ||||
| 			resize(c, m->wx - c->bw, m->wy, m->ww, m->wh, False); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| @ -1308,6 +1325,15 @@ resizeclient(Client *c, int x, int y, int w, int h) | ||||
| 	c->oldw = c->w; c->w = wc.width = w; | ||||
| 	c->oldh = c->h; c->h = wc.height = h; | ||||
| 	wc.border_width = c->bw; | ||||
| 	if (!selmon->drawwithgaps && /* this is the noborderfloatingfix patch, slightly modified so that it will work if, and only if, gaps are disabled. */ | ||||
| 	    (((nexttiled(c->mon->clients) == c && !nexttiled(c->next)) /* these two first lines are the only ones changed. if you are manually patching and have noborder installed already, just change these lines; or conversely, just remove this section if the noborder patch is not desired ;) */ | ||||
| 	    || &monocle == c->mon->lt[c->mon->sellt]->arrange)) | ||||
| 	    && !c->isfullscreen && !c->isfloating | ||||
| 	    && NULL != c->mon->lt[c->mon->sellt]->arrange) { | ||||
| 	        c->w = wc.width += c->bw * 2; | ||||
| 	        c->h = wc.height += c->bw * 2; | ||||
| 	        wc.border_width = 0; | ||||
| 	} | ||||
| 	XConfigureWindow(dpy, c->win, CWX|CWY|CWWidth|CWHeight|CWBorderWidth, &wc); | ||||
| 	configure(c); | ||||
| 	XSync(dpy, False); | ||||
| @ -1523,6 +1549,26 @@ setfullscreen(Client *c, int fullscreen) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| void | ||||
| setgaps(const Arg *arg) | ||||
| { | ||||
| 	switch(arg->i) | ||||
| 	{ | ||||
| 		case GAP_TOGGLE: | ||||
| 			selmon->drawwithgaps = !selmon->drawwithgaps; | ||||
| 			break; | ||||
| 		case GAP_RESET: | ||||
| 			selmon->gappx = gappx; | ||||
| 			break; | ||||
| 		default: | ||||
| 			if (selmon->gappx + arg->i < 0) | ||||
| 				selmon->gappx = 0; | ||||
| 			else | ||||
| 				selmon->gappx += arg->i; | ||||
| 	} | ||||
| 	arrange(selmon); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| setlayout(const Arg *arg) | ||||
| { | ||||
| @ -1709,7 +1755,24 @@ tile(Monitor *m) | ||||
| 	for (n = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), n++); | ||||
| 	if (n == 0) | ||||
| 		return; | ||||
| 
 | ||||
|         if (m->drawwithgaps) { /* draw with fullgaps logic */ | ||||
|                 if (n > m->nmaster) | ||||
|                         mw = m->nmaster ? m->ww * m->mfact : 0; | ||||
|                 else | ||||
|                         mw = m->ww - m->gappx; | ||||
|                 for (i = 0, my = ty = m->gappx, c = nexttiled(m->clients); c; c = nexttiled(c->next), i++) | ||||
|                         if (i < m->nmaster) { | ||||
|                                 h = (m->wh - my) / (MIN(n, m->nmaster) - i) - m->gappx; | ||||
|                                 resize(c, m->wx + m->gappx, m->wy + my, mw - (2*c->bw) - m->gappx, h - (2*c->bw), 0); | ||||
|                                 if (my + HEIGHT(c) + m->gappx < m->wh) | ||||
|                                         my += HEIGHT(c) + m->gappx; | ||||
|                         } else { | ||||
|                                 h = (m->wh - ty) / (n - i) - m->gappx; | ||||
|                                 resize(c, m->wx + mw + m->gappx, m->wy + ty, m->ww - mw - (2*c->bw) - 2*m->gappx, h - (2*c->bw), 0); | ||||
|                                 if (ty + HEIGHT(c) + m->gappx < m->wh) | ||||
|                                         ty += HEIGHT(c) + m->gappx; | ||||
|                         } | ||||
|         } else { /* draw with singularborders logic */ | ||||
|                 if (n > m->nmaster) | ||||
|                         mw = m->nmaster ? m->ww * m->mfact : 0; | ||||
|                 else | ||||
| @ -1717,14 +1780,16 @@ tile(Monitor *m) | ||||
|                 for (i = my = ty = 0, c = nexttiled(m->clients); c; c = nexttiled(c->next), i++) | ||||
|                         if (i < m->nmaster) { | ||||
|                                 h = (m->wh - my) / (MIN(n, m->nmaster) - i); | ||||
| 			resize(c, m->wx, m->wy + my, mw - (2*c->bw), h - (2*c->bw), 0); | ||||
| 			if (my + HEIGHT(c) < m->wh) | ||||
| 				my += HEIGHT(c); | ||||
|                                 if (n == 1) | ||||
|                                         resize(c, m->wx - c->bw, m->wy, m->ww, m->wh, False); | ||||
|                                 else | ||||
|                                         resize(c, m->wx - c->bw, m->wy + my, mw - c->bw, h - c->bw, False); | ||||
|                                 my += HEIGHT(c) - c->bw; | ||||
|                         } else { | ||||
|                                 h = (m->wh - ty) / (n - i); | ||||
| 			resize(c, m->wx + mw, m->wy + ty, m->ww - mw - (2*c->bw), h - (2*c->bw), 0); | ||||
| 			if (ty + HEIGHT(c) < m->wh) | ||||
| 				ty += HEIGHT(c); | ||||
|                                 resize(c, m->wx + mw - c->bw, m->wy + ty, m->ww - mw, h - c->bw, False); | ||||
|                                 ty += HEIGHT(c) - c->bw; | ||||
|                         } | ||||
|         } | ||||
| } | ||||
| 
 | ||||
| @ -1867,7 +1932,7 @@ updatebarpos(Monitor *m) | ||||
| } | ||||
| 
 | ||||
| void | ||||
| updateclientlist() | ||||
| updateclientlist(void) | ||||
| { | ||||
| 	Client *c; | ||||
| 	Monitor *m; | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Michael Chalupiak
						Michael Chalupiak