shithub: riscv

Download patch

ref: 37cbd6b632c56f09c0c561cddc1c4e5645dd4269
parent: f8f677b48ebaf490c6d870e8728285bc409789c0
author: cinap_lenrek <[email protected]>
date: Mon Aug 20 22:02:50 EDT 2018

vncv: adjust window size on desktop resize, fix canresize checks

--- a/sys/src/cmd/vnc/draw.c
+++ b/sys/src/cmd/vnc/draw.c
@@ -29,6 +29,9 @@
 	pixbuf = realloc(pixbuf, v->dim.max.x * pixb * v->dim.max.y);
 	if(linebuf == nil || pixbuf == nil)
 		sysfatal("can't allocate pix decompression storage");
+	lockdisplay(display);
+	adjustwin(v, 0);
+	unlockdisplay(display);
 }
 
 static void
@@ -79,7 +82,7 @@
 	r = rectsubpt(screen->r, screen->r.min);
 	unlockdisplay(display);
 	vnclock(v);
-	if(incremental == 0 && v->canresize && !eqrect(r, v->dim)){
+	if(incremental == 0 && (v->canresize&2)!=0 && !eqrect(r, v->dim)){
 		vncwrchar(v, MSetDesktopSize);
 		vncwrchar(v, 0);
 		vncwrpoint(v, r.max);
--- a/sys/src/cmd/vnc/vncv.h
+++ b/sys/src/cmd/vnc/vncv.h
@@ -18,6 +18,7 @@
 extern	int		mousefd;
 
 /* wsys.c */
+extern	void		adjustwin(Vnc*, int);
 extern	void		readkbd(Vnc*);
 extern	void		initmouse(void);
 extern	void		mousewarp(Point);
--- a/sys/src/cmd/vnc/wsys.c
+++ b/sys/src/cmd/vnc/wsys.c
@@ -10,35 +10,46 @@
 	Point xy;
 };
 
-static void
-resize(Vnc *v, int first)
+void
+adjustwin(Vnc *v, int force)
 {
 	int fd;
 	Point d;
 
-	lockdisplay(display);
-	if(getwindow(display, Refnone) < 0)
-		sysfatal("internal error: can't get the window image");
-	if(!v->canresize){
+	if(force)
+		d = v->dim.max;
+	else {
 		/*
 		 * limit the window to at most the vnc server's size
 		 */
-		d = addpt(v->dim.max, Pt(2*Borderwidth, 2*Borderwidth));
-		if(first || d.x < Dx(screen->r) || d.y < Dy(screen->r)){
-			fd = open("/dev/wctl", OWRITE);
-			if(fd >= 0){
-				fprint(fd, "resize -dx %d -dy %d", d.x, d.y);
-				close(fd);
-			}
+		d = subpt(screen->r.max, screen->r.min);
+		if(d.x > v->dim.max.x){
+			d.x = v->dim.max.x;
+			force = 1;
 		}
+		if(d.y > v->dim.max.y){
+			d.y = v->dim.max.y;
+			force = 1;
+		}
 	}
-	unlockdisplay(display);
+	if(force) {
+		fd = open("/dev/wctl", OWRITE);
+		if(fd >= 0){
+			fprint(fd, "resize -dx %d -dy %d", d.x+2*Borderwidth, d.y+2*Borderwidth);
+			close(fd);
+		}
+	}
 }
 
 static void
-eresized(void)
+resized(int first)
 {
-	resize(vnc, 0);
+	lockdisplay(display);
+	if(getwindow(display, Refnone) < 0)
+		sysfatal("internal error: can't get the window image");
+	if((vnc->canresize&2) == 0)
+		adjustwin(vnc, first);
+	unlockdisplay(display);
 	requestupdate(vnc, 0);
 }
 
@@ -130,8 +141,7 @@
 	memmove(curs+2*4, cs->clr, 2*2*16);
 	write(cursorfd, curs, sizeof curs);
 
-	resize(v, 1);
-	requestupdate(vnc, 0);
+	resized(1);
 	start = end = buf;
 	len = 0;
 	for(;;){
@@ -155,8 +165,7 @@
 					}
 				}
 			} else
-				eresized();
-
+				resized(0);
 			start += EventSize;
 			len -= EventSize;
 		}