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);
 | 
								fcpattern = FcPatternDuplicate(drw->fonts->pattern);
 | 
				
			||||||
			FcPatternAddCharSet(fcpattern, FC_CHARSET, fccharset);
 | 
								FcPatternAddCharSet(fcpattern, FC_CHARSET, fccharset);
 | 
				
			||||||
			FcPatternAddBool(fcpattern, FC_SCALABLE, FcTrue);
 | 
								FcPatternAddBool(fcpattern, FC_SCALABLE, FcTrue);
 | 
				
			||||||
			FcPatternAddBool(fcpattern, FC_COLOR, FcFalse);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
			FcConfigSubstitute(NULL, fcpattern, FcMatchPattern);
 | 
								FcConfigSubstitute(NULL, fcpattern, FcMatchPattern);
 | 
				
			||||||
			FcDefaultSubstitute(fcpattern);
 | 
								FcDefaultSubstitute(fcpattern);
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -209,7 +209,7 @@ static void monocle(Monitor *m);
 | 
				
			||||||
static void motionnotify(XEvent *e);
 | 
					static void motionnotify(XEvent *e);
 | 
				
			||||||
static void movemouse(const Arg *arg);
 | 
					static void movemouse(const Arg *arg);
 | 
				
			||||||
static Client *nexttiled(Client *c);
 | 
					static Client *nexttiled(Client *c);
 | 
				
			||||||
static void pop(Client *);
 | 
					static void pop(Client *c);
 | 
				
			||||||
static void propertynotify(XEvent *e);
 | 
					static void propertynotify(XEvent *e);
 | 
				
			||||||
static void quit(const Arg *arg);
 | 
					static void quit(const Arg *arg);
 | 
				
			||||||
static Monitor *recttomon(int x, int y, int w, int h);
 | 
					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 restack(Monitor *m);
 | 
				
			||||||
static void run(void);
 | 
					static void run(void);
 | 
				
			||||||
static void scan(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 sendmon(Client *c, Monitor *m);
 | 
				
			||||||
static void setclientstate(Client *c, long state);
 | 
					static void setclientstate(Client *c, long state);
 | 
				
			||||||
static void setfocus(Client *c);
 | 
					static void setfocus(Client *c);
 | 
				
			||||||
| 
						 | 
					@ -238,7 +238,7 @@ static void spawn(const Arg *arg);
 | 
				
			||||||
static Monitor *systraytomon(Monitor *m);
 | 
					static Monitor *systraytomon(Monitor *m);
 | 
				
			||||||
static void tag(const Arg *arg);
 | 
					static void tag(const Arg *arg);
 | 
				
			||||||
static void tagmon(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 togglebar(const Arg *arg);
 | 
				
			||||||
static void togglefloating(const Arg *arg);
 | 
					static void togglefloating(const Arg *arg);
 | 
				
			||||||
static void togglesticky(const Arg *arg);
 | 
					static void togglesticky(const Arg *arg);
 | 
				
			||||||
| 
						 | 
					@ -276,7 +276,7 @@ static const char broken[] = "broken";
 | 
				
			||||||
static char stext[256];
 | 
					static char stext[256];
 | 
				
			||||||
static int screen;
 | 
					static int screen;
 | 
				
			||||||
static int sw, sh;           /* X display screen geometry width, height */
 | 
					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 lrpad;            /* sum of left and right padding for text */
 | 
				
			||||||
static int (*xerrorxlib)(Display *, XErrorEvent *);
 | 
					static int (*xerrorxlib)(Display *, XErrorEvent *);
 | 
				
			||||||
static unsigned int numlockmask = 0;
 | 
					static unsigned int numlockmask = 0;
 | 
				
			||||||
| 
						 | 
					@ -514,7 +514,7 @@ buttonpress(XEvent *e)
 | 
				
			||||||
		if (i < LENGTH(tags)) {
 | 
							if (i < LENGTH(tags)) {
 | 
				
			||||||
			click = ClkTagBar;
 | 
								click = ClkTagBar;
 | 
				
			||||||
			arg.ui = 1 << i;
 | 
								arg.ui = 1 << i;
 | 
				
			||||||
		} else if (ev->x < x + blw)
 | 
							} else if (ev->x < x + TEXTW(selmon->ltsymbol))
 | 
				
			||||||
			click = ClkLtSymbol;
 | 
								click = ClkLtSymbol;
 | 
				
			||||||
		else if (ev->x > selmon->ww - (int)TEXTW(stext) - getsystraywidth())
 | 
							else if (ev->x > selmon->ww - (int)TEXTW(stext) - getsystraywidth())
 | 
				
			||||||
			click = ClkStatusText;
 | 
								click = ClkStatusText;
 | 
				
			||||||
| 
						 | 
					@ -885,7 +885,7 @@ drawbar(Monitor *m)
 | 
				
			||||||
				urg & 1 << i);
 | 
									urg & 1 << i);
 | 
				
			||||||
		x += w;
 | 
							x += w;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	w = blw = TEXTW(m->ltsymbol);
 | 
						w = TEXTW(m->ltsymbol);
 | 
				
			||||||
	drw_setscheme(drw, scheme[SchemeNorm]);
 | 
						drw_setscheme(drw, scheme[SchemeNorm]);
 | 
				
			||||||
	x = drw_text(drw, x, 0, w, bh, lrpad / 2, m->ltsymbol, 0);
 | 
						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';
 | 
						text[0] = '\0';
 | 
				
			||||||
	if (!XGetTextProperty(dpy, w, &name, atom) || !name.nitems)
 | 
						if (!XGetTextProperty(dpy, w, &name, atom) || !name.nitems)
 | 
				
			||||||
		return 0;
 | 
							return 0;
 | 
				
			||||||
	if (name.encoding == XA_STRING)
 | 
						if (name.encoding == XA_STRING) {
 | 
				
			||||||
		strncpy(text, (char *)name.value, size - 1);
 | 
							strncpy(text, (char *)name.value, size - 1);
 | 
				
			||||||
	else {
 | 
						} else if (XmbTextPropertyToTextList(dpy, &name, &list, &n) >= Success && n > 0 && *list) {
 | 
				
			||||||
		if (XmbTextPropertyToTextList(dpy, &name, &list, &n) >= Success && n > 0 && *list) {
 | 
							strncpy(text, *list, size - 1);
 | 
				
			||||||
			strncpy(text, *list, size - 1);
 | 
							XFreeStringList(list);
 | 
				
			||||||
			XFreeStringList(list);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	text[size - 1] = '\0';
 | 
						text[size - 1] = '\0';
 | 
				
			||||||
	XFree(name.value);
 | 
						XFree(name.value);
 | 
				
			||||||
| 
						 | 
					@ -1222,14 +1220,12 @@ manage(Window w, XWindowAttributes *wa)
 | 
				
			||||||
		applyrules(c);
 | 
							applyrules(c);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (c->x + WIDTH(c) > c->mon->mx + c->mon->mw)
 | 
						if (c->x + WIDTH(c) > c->mon->wx + c->mon->ww)
 | 
				
			||||||
		c->x = c->mon->mx + c->mon->mw - WIDTH(c);
 | 
							c->x = c->mon->wx + c->mon->ww - WIDTH(c);
 | 
				
			||||||
	if (c->y + HEIGHT(c) > c->mon->my + c->mon->mh)
 | 
						if (c->y + HEIGHT(c) > c->mon->wy + c->mon->wh)
 | 
				
			||||||
		c->y = c->mon->my + c->mon->mh - HEIGHT(c);
 | 
							c->y = c->mon->wy + c->mon->wh - HEIGHT(c);
 | 
				
			||||||
	c->x = MAX(c->x, c->mon->mx);
 | 
						c->x = MAX(c->x, c->mon->wx);
 | 
				
			||||||
	/* only fix client y-offset, if the client center might cover the bar */
 | 
						c->y = MAX(c->y, c->mon->wy);
 | 
				
			||||||
	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);
 | 
					 | 
				
			||||||
	c->bw = borderpx;
 | 
						c->bw = borderpx;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	wc.border_width = c->bw;
 | 
						wc.border_width = c->bw;
 | 
				
			||||||
| 
						 | 
					@ -1277,6 +1273,7 @@ maprequest(XEvent *e)
 | 
				
			||||||
	static XWindowAttributes wa;
 | 
						static XWindowAttributes wa;
 | 
				
			||||||
	XMapRequestEvent *ev = &e->xmaprequest;
 | 
						XMapRequestEvent *ev = &e->xmaprequest;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<<<<<<< HEAD:src/dwm.c.orig
 | 
				
			||||||
	Client *i;
 | 
						Client *i;
 | 
				
			||||||
	if ((i = wintosystrayicon(ev->window))) {
 | 
						if ((i = wintosystrayicon(ev->window))) {
 | 
				
			||||||
		sendevent(i->win, netatom[Xembed], StructureNotifyMask, CurrentTime, XEMBED_WINDOW_ACTIVATE, 0, systray->win, XEMBED_EMBEDDED_VERSION);
 | 
							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))
 | 
						if (!XGetWindowAttributes(dpy, ev->window, &wa))
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
	if (wa.override_redirect)
 | 
						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;
 | 
							return;
 | 
				
			||||||
	if (!wintoclient(ev->window))
 | 
						if (!wintoclient(ev->window))
 | 
				
			||||||
		manage(ev->window, &wa);
 | 
							manage(ev->window, &wa);
 | 
				
			||||||
| 
						 | 
					@ -1673,7 +1677,7 @@ setclientstate(Client *c, long state)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int
 | 
					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;
 | 
						int n;
 | 
				
			||||||
	Atom *protocols, mt;
 | 
						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) {
 | 
						if (exists) {
 | 
				
			||||||
		ev.type = ClientMessage;
 | 
							ev.type = ClientMessage;
 | 
				
			||||||
		ev.xclient.window = w;
 | 
							ev.xclient.window = c->win;
 | 
				
			||||||
		ev.xclient.message_type = mt;
 | 
							ev.xclient.message_type = wmatom[WMProtocols];
 | 
				
			||||||
		ev.xclient.format = 32;
 | 
							ev.xclient.format = 32;
 | 
				
			||||||
		ev.xclient.data.l[0] = d0;
 | 
							ev.xclient.data.l[0] = proto;
 | 
				
			||||||
		ev.xclient.data.l[1] = d1;
 | 
							ev.xclient.data.l[1] = CurrentTime;
 | 
				
			||||||
		ev.xclient.data.l[2] = d2;
 | 
							ev.xclient.data.l[2] = d2;
 | 
				
			||||||
		ev.xclient.data.l[3] = d3;
 | 
							ev.xclient.data.l[3] = d3;
 | 
				
			||||||
		ev.xclient.data.l[4] = d4;
 | 
							ev.xclient.data.l[4] = d4;
 | 
				
			||||||
		XSendEvent(dpy, w, False, mask, &ev);
 | 
							XSendEvent(dpy, c->w, False, mask, &ev);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	return exists;
 | 
						return exists;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -1869,7 +1873,6 @@ setup(void)
 | 
				
			||||||
	focus(NULL);
 | 
						focus(NULL);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
seturgent(Client *c, int urg)
 | 
					seturgent(Client *c, int urg)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
| 
						 | 
					@ -1904,6 +1907,7 @@ showhide(Client *c)
 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
sigchld(int unused)
 | 
					sigchld(int unused)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 | 
					<<<<<<< HEAD:src/dwm.c.orig
 | 
				
			||||||
	pid_t pid;
 | 
						pid_t pid;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (signal(SIGCHLD, sigchld) == SIG_ERR)
 | 
						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
 | 
					void
 | 
				
			||||||
spawn(const Arg *arg)
 | 
					spawn(const Arg *arg)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	if (arg->v == dmenucmd)
 | 
					 | 
				
			||||||
		dmenumon[0] = '0' + selmon->num;
 | 
					 | 
				
			||||||
	if (fork() == 0) {
 | 
						if (fork() == 0) {
 | 
				
			||||||
		if (dpy)
 | 
							if (dpy)
 | 
				
			||||||
			close(ConnectionNumber(dpy));
 | 
								close(ConnectionNumber(dpy));
 | 
				
			||||||
		setsid();
 | 
							setsid();
 | 
				
			||||||
		execvp(((char **)arg->v)[0], (char **)arg->v);
 | 
							execvp(((char **)arg->v)[0], (char **)arg->v);
 | 
				
			||||||
		fprintf(stderr, "dwm: execvp %s", ((char **)arg->v)[0]);
 | 
							die("dwm: execvp '%s' failed:", ((char **)arg->v)[0]);
 | 
				
			||||||
		perror(" failed");
 | 
					 | 
				
			||||||
		exit(EXIT_SUCCESS);
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -2078,6 +2085,7 @@ unmanage(Client *c, int destroyed)
 | 
				
			||||||
		wc.border_width = c->oldbw;
 | 
							wc.border_width = c->oldbw;
 | 
				
			||||||
		XGrabServer(dpy); /* avoid race conditions */
 | 
							XGrabServer(dpy); /* avoid race conditions */
 | 
				
			||||||
		XSetErrorHandler(xerrordummy);
 | 
							XSetErrorHandler(xerrordummy);
 | 
				
			||||||
 | 
							XSelectInput(dpy, c->win, NoEventMask);
 | 
				
			||||||
		XConfigureWindow(dpy, c->win, CWBorderWidth, &wc); /* restore border */
 | 
							XConfigureWindow(dpy, c->win, CWBorderWidth, &wc); /* restore border */
 | 
				
			||||||
		XUngrabButton(dpy, AnyButton, AnyModifier, c->win);
 | 
							XUngrabButton(dpy, AnyButton, AnyModifier, c->win);
 | 
				
			||||||
		setclientstate(c, WithdrawnState);
 | 
							setclientstate(c, WithdrawnState);
 | 
				
			||||||
| 
						 | 
					@ -2606,12 +2614,10 @@ zoom(const Arg *arg)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	Client *c = selmon->sel;
 | 
						Client *c = selmon->sel;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!selmon->lt[selmon->sellt]->arrange
 | 
						if (!selmon->lt[selmon->sellt]->arrange || !c || c->isfloating)
 | 
				
			||||||
	|| (selmon->sel && selmon->sel->isfloating))
 | 
							return;
 | 
				
			||||||
 | 
						if (c == nexttiled(selmon->clients) && !(c = nexttiled(c->next)))
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
	if (c == nexttiled(selmon->clients))
 | 
					 | 
				
			||||||
		if (!c || !(c = nexttiled(c->next)))
 | 
					 | 
				
			||||||
			return;
 | 
					 | 
				
			||||||
	pop(c);
 | 
						pop(c);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										23
									
								
								src/util.c
									
										
									
									
									
								
							
							
						
						
									
										23
									
								
								src/util.c
									
										
									
									
									
								
							| 
						 | 
					@ -6,18 +6,9 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include "util.h"
 | 
					#include "util.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void *
 | 
					 | 
				
			||||||
ecalloc(size_t nmemb, size_t size)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
	void *p;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if (!(p = calloc(nmemb, size)))
 | 
					 | 
				
			||||||
		die("calloc:");
 | 
					 | 
				
			||||||
	return p;
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
die(const char *fmt, ...) {
 | 
					die(const char *fmt, ...)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
	va_list ap;
 | 
						va_list ap;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	va_start(ap, fmt);
 | 
						va_start(ap, fmt);
 | 
				
			||||||
| 
						 | 
					@ -33,3 +24,13 @@ die(const char *fmt, ...) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	exit(1);
 | 
						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