applied Andreas Amanns' netwm_client_list patch, but with some indentation fixes
This commit is contained in:
		
							parent
							
								
									c1128417a9
								
							
						
					
					
						commit
						3bfc43c3d0
					
				
							
								
								
									
										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; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user