Răsfoiți Sursa

configurenotify remembers max geom now, and restores this if necessary, however it accepts to touch the max size on configurerequest, this shouldn't break fillscreen apps (tested with mplayer)

Anselm R. Garbe 20 ani în urmă
părinte
comite
aa1bda8164
2 a modificat fișierele cu 14 adăugiri și 4 ștergeri
  1. 11 1
      event.c
  2. 3 3
      tag.c

+ 11 - 1
event.c

@@ -150,6 +150,7 @@ buttonpress(XEvent *e)
 static void
 static void
 configurerequest(XEvent *e)
 configurerequest(XEvent *e)
 {
 {
+	int ox, oy, ow, oh;
 	unsigned long newmask;
 	unsigned long newmask;
 	Client *c;
 	Client *c;
 	XConfigureRequestEvent *ev = &e->xconfigurerequest;
 	XConfigureRequestEvent *ev = &e->xconfigurerequest;
@@ -157,6 +158,10 @@ configurerequest(XEvent *e)
 	XWindowChanges wc;
 	XWindowChanges wc;
 
 
 	if((c = getclient(ev->window))) {
 	if((c = getclient(ev->window))) {
+		ox = c->x;
+		oy = c->y;
+		ow = c->w;
+		oh = c->h;
 		gravitate(c, True);
 		gravitate(c, True);
 		if(ev->value_mask & CWX)
 		if(ev->value_mask & CWX)
 			c->x = ev->x;
 			c->x = ev->x;
@@ -191,8 +196,13 @@ configurerequest(XEvent *e)
 			XSendEvent(dpy, c->win, True, NoEventMask, &synev);
 			XSendEvent(dpy, c->win, True, NoEventMask, &synev);
 		}
 		}
 		XSync(dpy, False);
 		XSync(dpy, False);
-		if(c->isfloat)
+		if(c->isfloat || c->ismax) {
 			resize(c, False, TopLeft);
 			resize(c, False, TopLeft);
+			c->x = ox;
+			c->y = oy;
+			c->w = ow;
+			c->h = oh;
+		}
 		else
 		else
 			arrange(NULL);
 			arrange(NULL);
 	}
 	}

+ 3 - 3
tag.c

@@ -31,7 +31,7 @@ static RReg *rreg = NULL;
 static unsigned int len = 0;
 static unsigned int len = 0;
 
 
 static void
 static void
-applytag()
+commit()
 {
 {
 	/* asserts sel != NULL */
 	/* asserts sel != NULL */
 	settitle(sel);
 	settitle(sel);
@@ -132,7 +132,7 @@ tag(Arg *arg)
 	for(i = 0; i < ntags; i++)
 	for(i = 0; i < ntags; i++)
 		sel->tags[i] = False;
 		sel->tags[i] = False;
 	sel->tags[arg->i] = True;
 	sel->tags[arg->i] = True;
-	applytag();
+	commit();
 }
 }
 
 
 void
 void
@@ -147,5 +147,5 @@ toggletag(Arg *arg)
 	for(i = 0; i < ntags && !sel->tags[i]; i++);
 	for(i = 0; i < ntags && !sel->tags[i]; i++);
 	if(i == ntags)
 	if(i == ntags)
 		sel->tags[arg->i] = True;
 		sel->tags[arg->i] = True;
-	applytag();
+	commit();
 }
 }