applied Andreas Amanns' netwm_client_list patch, but with some indentation fixes
This commit is contained in:
		
							
								
								
									
										21
									
								
								dwm.c
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								dwm.c
									
									
									
									
									
								
							@@ -60,7 +60,7 @@ enum { CurNormal, CurResize, CurMove, CurLast };        /* cursor */
 | 
				
			|||||||
enum { ColBorder, ColFG, ColBG, ColLast };              /* color */
 | 
					enum { ColBorder, ColFG, ColBG, ColLast };              /* color */
 | 
				
			||||||
enum { NetSupported, NetWMName, NetWMState,
 | 
					enum { NetSupported, NetWMName, NetWMState,
 | 
				
			||||||
       NetWMFullscreen, NetActiveWindow, NetWMWindowType,
 | 
					       NetWMFullscreen, NetActiveWindow, NetWMWindowType,
 | 
				
			||||||
       NetWMWindowTypeDialog, NetLast };     /* EWMH atoms */
 | 
					       NetWMWindowTypeDialog, NetClientList, NetLast };     /* EWMH atoms */
 | 
				
			||||||
enum { WMProtocols, WMDelete, WMState, WMTakeFocus, WMLast }; /* default atoms */
 | 
					enum { WMProtocols, WMDelete, WMState, WMTakeFocus, WMLast }; /* default atoms */
 | 
				
			||||||
enum { ClkTagBar, ClkLtSymbol, ClkStatusText, ClkWinTitle,
 | 
					enum { ClkTagBar, ClkLtSymbol, ClkStatusText, ClkWinTitle,
 | 
				
			||||||
       ClkClientWin, ClkRootWin, ClkLast };             /* clicks */
 | 
					       ClkClientWin, ClkRootWin, ClkLast };             /* clicks */
 | 
				
			||||||
@@ -238,6 +238,7 @@ static void unmapnotify(XEvent *e);
 | 
				
			|||||||
static Bool updategeom(void);
 | 
					static Bool updategeom(void);
 | 
				
			||||||
static void updatebarpos(Monitor *m);
 | 
					static void updatebarpos(Monitor *m);
 | 
				
			||||||
static void updatebars(void);
 | 
					static void updatebars(void);
 | 
				
			||||||
 | 
					static void updateclientlist(void);
 | 
				
			||||||
static void updatenumlockmask(void);
 | 
					static void updatenumlockmask(void);
 | 
				
			||||||
static void updatesizehints(Client *c);
 | 
					static void updatesizehints(Client *c);
 | 
				
			||||||
static void updatestatus(void);
 | 
					static void updatestatus(void);
 | 
				
			||||||
@@ -1160,6 +1161,8 @@ manage(Window w, XWindowAttributes *wa) {
 | 
				
			|||||||
		XRaiseWindow(dpy, c->win);
 | 
							XRaiseWindow(dpy, c->win);
 | 
				
			||||||
	attach(c);
 | 
						attach(c);
 | 
				
			||||||
	attachstack(c);
 | 
						attachstack(c);
 | 
				
			||||||
 | 
						XChangeProperty(dpy, root, netatom[NetClientList], XA_WINDOW, 32, PropModeAppend,
 | 
				
			||||||
 | 
						                (unsigned char *) &(c->win), 1);
 | 
				
			||||||
	XMoveResizeWindow(dpy, c->win, c->x + 2 * sw, c->y, c->w, c->h); /* some windows require this */
 | 
						XMoveResizeWindow(dpy, c->win, c->x + 2 * sw, c->y, c->w, c->h); /* some windows require this */
 | 
				
			||||||
	setclientstate(c, NormalState);
 | 
						setclientstate(c, NormalState);
 | 
				
			||||||
	if (c->mon == selmon)
 | 
						if (c->mon == selmon)
 | 
				
			||||||
@@ -1621,6 +1624,7 @@ setup(void) {
 | 
				
			|||||||
	netatom[NetWMFullscreen] = XInternAtom(dpy, "_NET_WM_STATE_FULLSCREEN", False);
 | 
						netatom[NetWMFullscreen] = XInternAtom(dpy, "_NET_WM_STATE_FULLSCREEN", False);
 | 
				
			||||||
	netatom[NetWMWindowType] = XInternAtom(dpy, "_NET_WM_WINDOW_TYPE", False);
 | 
						netatom[NetWMWindowType] = XInternAtom(dpy, "_NET_WM_WINDOW_TYPE", False);
 | 
				
			||||||
	netatom[NetWMWindowTypeDialog] = XInternAtom(dpy, "_NET_WM_WINDOW_TYPE_DIALOG", False);
 | 
						netatom[NetWMWindowTypeDialog] = XInternAtom(dpy, "_NET_WM_WINDOW_TYPE_DIALOG", False);
 | 
				
			||||||
 | 
						netatom[NetClientList] = XInternAtom(dpy, "_NET_CLIENT_LIST", False);
 | 
				
			||||||
	/* init cursors */
 | 
						/* init cursors */
 | 
				
			||||||
	cursor[CurNormal] = XCreateFontCursor(dpy, XC_left_ptr);
 | 
						cursor[CurNormal] = XCreateFontCursor(dpy, XC_left_ptr);
 | 
				
			||||||
	cursor[CurResize] = XCreateFontCursor(dpy, XC_sizing);
 | 
						cursor[CurResize] = XCreateFontCursor(dpy, XC_sizing);
 | 
				
			||||||
@@ -1643,6 +1647,7 @@ setup(void) {
 | 
				
			|||||||
	/* EWMH support per view */
 | 
						/* EWMH support per view */
 | 
				
			||||||
	XChangeProperty(dpy, root, netatom[NetSupported], XA_ATOM, 32,
 | 
						XChangeProperty(dpy, root, netatom[NetSupported], XA_ATOM, 32,
 | 
				
			||||||
			PropModeReplace, (unsigned char *) netatom, NetLast);
 | 
								PropModeReplace, (unsigned char *) netatom, NetLast);
 | 
				
			||||||
 | 
						XDeleteProperty(dpy, root, netatom[NetClientList]);
 | 
				
			||||||
	/* select for events */
 | 
						/* select for events */
 | 
				
			||||||
	wa.cursor = cursor[CurNormal];
 | 
						wa.cursor = cursor[CurNormal];
 | 
				
			||||||
	wa.event_mask = SubstructureRedirectMask|SubstructureNotifyMask|ButtonPressMask|PointerMotionMask
 | 
						wa.event_mask = SubstructureRedirectMask|SubstructureNotifyMask|ButtonPressMask|PointerMotionMask
 | 
				
			||||||
@@ -1820,6 +1825,7 @@ unmanage(Client *c, Bool destroyed) {
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
	free(c);
 | 
						free(c);
 | 
				
			||||||
	focus(NULL);
 | 
						focus(NULL);
 | 
				
			||||||
 | 
						updateclientlist();
 | 
				
			||||||
	arrange(m);
 | 
						arrange(m);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1868,6 +1874,19 @@ updatebarpos(Monitor *m) {
 | 
				
			|||||||
		m->by = -bh;
 | 
							m->by = -bh;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void
 | 
				
			||||||
 | 
					updateclientlist() {
 | 
				
			||||||
 | 
						Client *c;
 | 
				
			||||||
 | 
						Monitor *m;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						XDeleteProperty(dpy, root, netatom[NetClientList]);
 | 
				
			||||||
 | 
						for(m = mons; m; m = m->next)
 | 
				
			||||||
 | 
							for(c = m->clients; c; c = c->next)
 | 
				
			||||||
 | 
								XChangeProperty(dpy, root, netatom[NetClientList],
 | 
				
			||||||
 | 
								                XA_WINDOW, 32, PropModeAppend,
 | 
				
			||||||
 | 
								                (unsigned char *) &(c->win), 1);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Bool
 | 
					Bool
 | 
				
			||||||
updategeom(void) {
 | 
					updategeom(void) {
 | 
				
			||||||
	Bool dirty = False;
 | 
						Bool dirty = False;
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user