Implement Xdbe-based double-buffering
This commit is contained in:
		
							
								
								
									
										50
									
								
								st.c
									
									
									
									
									
								
							
							
						
						
									
										50
									
								
								st.c
									
									
									
									
									
								
							| @@ -24,6 +24,7 @@ | ||||
| #include <X11/Xutil.h> | ||||
| #include <X11/cursorfont.h> | ||||
| #include <X11/keysym.h> | ||||
| #include <X11/extensions/Xdbe.h> | ||||
|  | ||||
| #if   defined(__linux) | ||||
|  #include <pty.h> | ||||
| @@ -178,7 +179,7 @@ typedef struct { | ||||
| 	Display* dpy; | ||||
| 	Colormap cmap; | ||||
| 	Window win; | ||||
| 	Pixmap buf; | ||||
| 	XdbeBackBuffer buf; | ||||
| 	Atom xembed; | ||||
| 	XIM xim; | ||||
| 	XIC xic; | ||||
| @@ -270,7 +271,7 @@ static void ttywrite(const char *, size_t); | ||||
| static void xdraws(char *, Glyph, int, int, int, int); | ||||
| static void xhints(void); | ||||
| static void xclear(int, int, int, int); | ||||
| static void xcopy(int, int, int, int); | ||||
| static void xcopy(); | ||||
| static void xdrawcursor(void); | ||||
| static void xinit(void); | ||||
| static void xloadcols(void); | ||||
| @@ -1620,32 +1621,8 @@ tresize(int col, int row) { | ||||
|  | ||||
| void | ||||
| xresize(int col, int row) { | ||||
| 	Pixmap newbuf; | ||||
| 	int oldw, oldh; | ||||
|  | ||||
| 	oldw = xw.bufw; | ||||
| 	oldh = xw.bufh; | ||||
| 	xw.bufw = MAX(1, col * xw.cw); | ||||
| 	xw.bufh = MAX(1, row * xw.ch); | ||||
| 	newbuf = XCreatePixmap(xw.dpy, xw.win, xw.bufw, xw.bufh, XDefaultDepth(xw.dpy, xw.scr)); | ||||
| 	XCopyArea(xw.dpy, xw.buf, newbuf, dc.gc, 0, 0, xw.bufw, xw.bufh, 0, 0); | ||||
| 	XFreePixmap(xw.dpy, xw.buf); | ||||
| 	XSetForeground(xw.dpy, dc.gc, dc.col[DefaultBG]); | ||||
| 	if(xw.bufw > oldw) | ||||
| 		XFillRectangle(xw.dpy, newbuf, dc.gc, oldw, 0, | ||||
| 				xw.bufw-oldw, MIN(xw.bufh, oldh)); | ||||
| 	else if(xw.bufw < oldw && (BORDER > 0 || xw.w > xw.bufw)) | ||||
| 		XClearArea(xw.dpy, xw.win, BORDER+xw.bufw, BORDER, | ||||
| 				xw.w-xw.bufh-BORDER, BORDER+MIN(xw.bufh, oldh), | ||||
| 				False); | ||||
| 	if(xw.bufh > oldh) | ||||
| 		XFillRectangle(xw.dpy, newbuf, dc.gc, 0, oldh, | ||||
| 				xw.bufw, xw.bufh-oldh); | ||||
| 	else if(xw.bufh < oldh && (BORDER > 0 || xw.h > xw.bufh)) | ||||
| 		XClearArea(xw.dpy, xw.win, BORDER, BORDER+xw.bufh, | ||||
| 				xw.w-2*BORDER, xw.h-xw.bufh-BORDER, | ||||
| 				False); | ||||
| 	xw.buf = newbuf; | ||||
| } | ||||
|  | ||||
| void | ||||
| @@ -1801,7 +1778,7 @@ xinit(void) { | ||||
| 			CWBackPixel | CWBorderPixel | CWBitGravity | CWEventMask | ||||
| 			| CWColormap, | ||||
| 			&attrs); | ||||
| 	xw.buf = XCreatePixmap(xw.dpy, xw.win, xw.bufw, xw.bufh, XDefaultDepth(xw.dpy, xw.scr)); | ||||
| 	xw.buf = XdbeAllocateBackBufferName(xw.dpy, xw.win, XdbeCopied); | ||||
|  | ||||
|  | ||||
| 	/* input methods */ | ||||
| @@ -1871,10 +1848,10 @@ xdraws(char *s, Glyph base, int x, int y, int charlen, int bytelen) { | ||||
|  | ||||
| /* copy buffer pixmap to screen pixmap */ | ||||
| void | ||||
| xcopy(int x, int y, int cols, int rows) { | ||||
| 	int src_x = x*xw.cw, src_y = y*xw.ch, src_w = cols*xw.cw, src_h = rows*xw.ch; | ||||
| 	int dst_x = BORDER+src_x, dst_y = BORDER+src_y; | ||||
| 	XCopyArea(xw.dpy, xw.buf, xw.win, dc.gc, src_x, src_y, src_w, src_h, dst_x, dst_y); | ||||
| xcopy() { | ||||
|         XdbeSwapInfo swpinfo[1] = {{xw.win, XdbeCopied}}; | ||||
|         XdbeSwapBuffers(xw.dpy, swpinfo, 1); | ||||
|  | ||||
| } | ||||
|  | ||||
| void | ||||
| @@ -1918,6 +1895,7 @@ xdrawcursor(void) { | ||||
| void | ||||
| draw() { | ||||
| 	drawregion(0, 0, term.col, term.row); | ||||
| 	xcopy(); | ||||
| 	gettimeofday(&xw.lastdraw, NULL); | ||||
| } | ||||
|  | ||||
| @@ -1959,7 +1937,6 @@ drawregion(int x1, int y1, int x2, int y2) { | ||||
| 		} | ||||
| 		if(ib > 0) | ||||
| 			xdraws(buf, base, ox, y, ic, ib); | ||||
| 		xcopy(0, y, term.col, 1); | ||||
| 	} | ||||
| 	xdrawcursor(); | ||||
| } | ||||
| @@ -1968,13 +1945,10 @@ void | ||||
| expose(XEvent *ev) { | ||||
| 	XExposeEvent *e = &ev->xexpose; | ||||
| 	if(xw.state & WIN_REDRAW) { | ||||
| 		if(!e->count) { | ||||
| 		if(!e->count) | ||||
| 			xw.state &= ~WIN_REDRAW; | ||||
| 			xcopy(0, 0, term.col, term.row); | ||||
| 		} | ||||
| 	} else | ||||
| 		XCopyArea(xw.dpy, xw.buf, xw.win, dc.gc, e->x-BORDER, e->y-BORDER, | ||||
| 				e->width, e->height, e->x, e->y); | ||||
|         } | ||||
|         xcopy(); | ||||
| } | ||||
|  | ||||
| void | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Brandon Invergo
					Brandon Invergo