Fixing the redrawing patch of k0ga, so it's using xclear() in redraw() too.
This commit is contained in:
		
							
								
								
									
										16
									
								
								st.c
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								st.c
									
									
									
									
									
								
							| @@ -198,6 +198,7 @@ typedef struct { | |||||||
| 	int scr; | 	int scr; | ||||||
| 	Bool isfixed; /* is fixed geometry? */ | 	Bool isfixed; /* is fixed geometry? */ | ||||||
| 	int fx, fy, fw, fh; /* fixed geometry */ | 	int fx, fy, fw, fh; /* fixed geometry */ | ||||||
|  | 	int tw, th; /* tty width and height */ | ||||||
| 	int w;	/* window width */ | 	int w;	/* window width */ | ||||||
| 	int h;	/* window height */ | 	int h;	/* window height */ | ||||||
| 	int ch; /* char height */ | 	int ch; /* char height */ | ||||||
| @@ -894,8 +895,8 @@ ttyresize(int x, int y) { | |||||||
|  |  | ||||||
| 	w.ws_row = term.row; | 	w.ws_row = term.row; | ||||||
| 	w.ws_col = term.col; | 	w.ws_col = term.col; | ||||||
| 	w.ws_xpixel = xw.w; | 	w.ws_xpixel = xw.tw; | ||||||
| 	w.ws_ypixel = xw.h; | 	w.ws_ypixel = xw.th; | ||||||
| 	if(ioctl(cmdfd, TIOCSWINSZ, &w) < 0) | 	if(ioctl(cmdfd, TIOCSWINSZ, &w) < 0) | ||||||
| 		fprintf(stderr, "Couldn't set window size: %s\n", SERRNO); | 		fprintf(stderr, "Couldn't set window size: %s\n", SERRNO); | ||||||
| } | } | ||||||
| @@ -1837,11 +1838,8 @@ tresize(int col, int row) { | |||||||
|  |  | ||||||
| void | void | ||||||
| xresize(int col, int row) { | xresize(int col, int row) { | ||||||
| 	xw.w = MAX(1, 2*BORDER + col * xw.cw); | 	xw.tw = MAX(1, 2*BORDER + col * xw.cw); | ||||||
| 	xw.h = MAX(1, 2*BORDER + row * xw.ch); | 	xw.th = MAX(1, 2*BORDER + row * xw.ch); | ||||||
| 	XFillRectangle(xw.dpy, xw.buf, dc.gc, 0, 0, |  | ||||||
| 		       DisplayWidth(xw.dpy, xw.scr), |  | ||||||
| 		       DisplayHeight(xw.dpy, xw.scr)); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
| @@ -2145,6 +2143,8 @@ xresettitle(void) { | |||||||
| void | void | ||||||
| redraw(void) { | redraw(void) { | ||||||
| 	struct timespec tv = {0, REDRAW_TIMEOUT * 1000}; | 	struct timespec tv = {0, REDRAW_TIMEOUT * 1000}; | ||||||
|  |  | ||||||
|  | 	xclear(0, 0, xw.w, xw.h); | ||||||
| 	tfulldirt(); | 	tfulldirt(); | ||||||
| 	draw(); | 	draw(); | ||||||
| 	XSync(xw.dpy, False); /* necessary for a good tput flash */ | 	XSync(xw.dpy, False); /* necessary for a good tput flash */ | ||||||
| @@ -2334,6 +2334,8 @@ resize(XEvent *e) { | |||||||
| 	row = (xw.h - 2*BORDER) / xw.ch; | 	row = (xw.h - 2*BORDER) / xw.ch; | ||||||
| 	if(col == term.col && row == term.row) | 	if(col == term.col && row == term.row) | ||||||
| 		return; | 		return; | ||||||
|  |  | ||||||
|  | 	xclear(0, 0, xw.w, xw.h); | ||||||
| 	tresize(col, row); | 	tresize(col, row); | ||||||
| 	xresize(col, row); | 	xresize(col, row); | ||||||
| 	ttyresize(col, row); | 	ttyresize(col, row); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user