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;
}