forked from github/lukesmith-dwm
		
	make it easier for the user, if Xinerama support is given, always use the screen 0 as window area/bar area, everything else can be used for floating clients
This commit is contained in:
		
							parent
							
								
									4a5c8d84db
								
							
						
					
					
						commit
						f22d047d41
					
				
							
								
								
									
										11
									
								
								config.mk
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								config.mk
									
									
									
									
									
								
							| @ -10,14 +10,19 @@ MANPREFIX = ${PREFIX}/share/man | |||||||
| X11INC = /usr/X11R6/include | X11INC = /usr/X11R6/include | ||||||
| X11LIB = /usr/X11R6/lib | X11LIB = /usr/X11R6/lib | ||||||
| 
 | 
 | ||||||
|  | # Xinerama, uncomment if you don't want it
 | ||||||
|  | XINERAMALIBS = -L${X11LIB} -lXinerama | ||||||
|  | XINERAMAFLAGS = -DXINERAMA | ||||||
|  | 
 | ||||||
| # includes and libs
 | # includes and libs
 | ||||||
| INCS = -I. -I/usr/include -I${X11INC} | INCS = -I. -I/usr/include -I${X11INC} | ||||||
| LIBS = -L/usr/lib -lc -L${X11LIB} -lX11 | LIBS = -L/usr/lib -lc -L${X11LIB} -lX11 ${XINERAMALIBS} | ||||||
| 
 | 
 | ||||||
| # flags
 | # flags
 | ||||||
| CFLAGS = -Os ${INCS} -DVERSION=\"${VERSION}\" | CPPFLAGS = -DVERSION=\"${VERSION}\" ${XINERAMAFLAGS} | ||||||
|  | CFLAGS = -Os ${INCS} ${CPPFLAGS} | ||||||
| LDFLAGS = -s ${LIBS} | LDFLAGS = -s ${LIBS} | ||||||
| #CFLAGS = -g -std=c99 -pedantic -Wall -O2 ${INCS} -DVERSION=\"${VERSION}\"
 | #CFLAGS = -g -std=c99 -pedantic -Wall -O2 ${INCS} ${CPPFLAGS}
 | ||||||
| #LDFLAGS = -g ${LIBS}
 | #LDFLAGS = -g ${LIBS}
 | ||||||
| 
 | 
 | ||||||
| # Solaris
 | # Solaris
 | ||||||
|  | |||||||
							
								
								
									
										3
									
								
								dwm.1
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								dwm.1
									
									
									
									
									
								
							| @ -57,6 +57,9 @@ click on a tag label adds/removes that tag to/from the focused window. | |||||||
| Start | Start | ||||||
| .BR xterm. | .BR xterm. | ||||||
| .TP | .TP | ||||||
|  | .B Mod1\-b | ||||||
|  | Toggles bar on and off. | ||||||
|  | .TP | ||||||
| .B Mod1\-space | .B Mod1\-space | ||||||
| Toggles between layouts. | Toggles between layouts. | ||||||
| .TP | .TP | ||||||
|  | |||||||
							
								
								
									
										39
									
								
								dwm.c
									
									
									
									
									
								
							
							
						
						
									
										39
									
								
								dwm.c
									
									
									
									
									
								
							| @ -39,6 +39,9 @@ | |||||||
| #include <X11/Xlib.h> | #include <X11/Xlib.h> | ||||||
| #include <X11/Xproto.h> | #include <X11/Xproto.h> | ||||||
| #include <X11/Xutil.h> | #include <X11/Xutil.h> | ||||||
|  | #ifdef XINERAMA | ||||||
|  | #include <X11/extensions/Xinerama.h> | ||||||
|  | #endif | ||||||
| 
 | 
 | ||||||
| /* macros */ | /* macros */ | ||||||
| #define MAX(a, b)       ((a) > (b) ? (a) : (b)) | #define MAX(a, b)       ((a) > (b) ? (a) : (b)) | ||||||
| @ -1579,22 +1582,32 @@ updatebar(void) { | |||||||
| 
 | 
 | ||||||
| void | void | ||||||
| updategeom(void) { | updategeom(void) { | ||||||
| 	unsigned int i; | 	int i; | ||||||
| 
 | #ifdef XINERAMA | ||||||
| #ifdef CUSTOMGEOM /* define your own if you are Xinerama user */ | 	XineramaScreenInfo *info = NULL; | ||||||
| 	CUSTOMGEOM |  | ||||||
| #else |  | ||||||
| 	/* bar geometry*/ |  | ||||||
| 	bx = 0; |  | ||||||
| 	by = showbar ? (topbar ? 0 : sh - bh) : -bh; |  | ||||||
| 	bw = sw; |  | ||||||
| 
 | 
 | ||||||
| 	/* window area geometry */ | 	/* window area geometry */ | ||||||
| 	wx = sx; | 	if(XineramaIsActive(dpy)) { | ||||||
| 	wy = showbar && topbar ? sy + bh : sy; | 		info = XineramaQueryScreens(dpy, &i); | ||||||
| 	ww = sw; | 		wx = info[0].x_org; | ||||||
| 	wh = showbar ? sh - bh : sh; | 		wy = showbar && topbar ? info[0].y_org + info[0].height + bh : info[0].y_org; | ||||||
|  | 		ww = info[0].width; | ||||||
|  | 		wh = showbar ? info[0].height - bh : info[0].height; | ||||||
|  | 		XFree(info); | ||||||
|  | 	} | ||||||
|  | 	else | ||||||
| #endif | #endif | ||||||
|  | 	{ | ||||||
|  | 		wx = sx; | ||||||
|  | 		wy = showbar && topbar ? sy + bh : sy; | ||||||
|  | 		ww = sw; | ||||||
|  | 		wh = showbar ? sh - bh : sh; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	/* bar geometry*/ | ||||||
|  | 	bx = wx; | ||||||
|  | 	by = showbar ? (topbar ? 0 : wy + wh) : -bh; | ||||||
|  | 	bw = ww; | ||||||
| 
 | 
 | ||||||
| 	/* update layout geometries */ | 	/* update layout geometries */ | ||||||
| 	for(i = 0; i < LENGTH(layouts); i++) | 	for(i = 0; i < LENGTH(layouts); i++) | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user