[hackers] [dwm] fixed the border issue for mplayer, ff is definately broken when using F11 (fullscreen mode)

From: Anselm R. Garbe <arg_AT_suckless.org>
Date: Thu Apr 19 09:27:45 2007

changeset: 865:018c38468422
tag: 4.0
user: Anselm R. Garbe <arg_AT_suckless.org>
date: Thu Apr 19 09:24:25 2007 +0200
summary: fixed the border issue for mplayer, ff is definately broken when using F11 (fullscreen mode)

diff -r 8e23c227b097 -r 018c38468422 client.c
--- a/client.c Thu Apr 19 08:53:40 2007 +0200
+++ b/client.c Thu Apr 19 09:24:25 2007 +0200
@@ -185,9 +185,11 @@ manage(Window w, XWindowAttributes *wa)
         c->y = wa->y;
         c->w = wa->width;
         c->h = wa->height;
+ c->oldborder = wa->border_width;
         if(c->w == sw && c->h == sh) {
                 c->x = sx;
                 c->y = sy;
+ c->border = wa->border_width;
         }
         else {
                 if(c->x + c->w + 2 * c->border > wax + waw)
@@ -198,15 +200,16 @@ manage(Window w, XWindowAttributes *wa)
                         c->x = wax;
                 if(c->y < way)
                         c->y = way;
- }
+ c->border = BORDERPX;
+ }
+ wc.border_width = c->border;
+ XConfigureWindow(dpy, w, CWBorderWidth, &wc);
+ XSetWindowBorder(dpy, w, dc.norm[ColBorder]);
+ configure(c); /* propagates border_width, if size doesn't change */
         updatesizehints(c);
         XSelectInput(dpy, w,
                 StructureNotifyMask | PropertyChangeMask | EnterWindowMask);
         grabbuttons(c, False);
- c->border = wc.border_width = (c->w == sw && c->h == sh) ? wa->border_width : BORDERPX;
- XConfigureWindow(dpy, w, CWBorderWidth, &wc);
- XSetWindowBorder(dpy, w, dc.norm[ColBorder]);
- configure(c); /* propagates border_width, if size doesn't change */
         updatetitle(c);
         if((rettrans = XGetTransientForHint(dpy, w, &trans) == Success))
                 for(t = clients; t && t->win != trans; t = t->next);
@@ -378,10 +381,13 @@ void
 void
 unmanage(Client *c) {
         Client *nc;
-
+ XWindowChanges wc;
+
+ wc.border_width = c->oldborder;
         /* The server grab construct avoids race conditions. */
         XGrabServer(dpy);
         XSetErrorHandler(xerrordummy);
+ XConfigureWindow(dpy, c->win, CWBorderWidth, &wc); /* restore border */
         detach(c);
         detachstack(c);
         if(sel == c) {
diff -r 8e23c227b097 -r 018c38468422 dwm.h
--- a/dwm.h Thu Apr 19 08:53:40 2007 +0200
+++ b/dwm.h Thu Apr 19 09:24:25 2007 +0200
@@ -50,7 +50,7 @@ struct Client {
         int basew, baseh, incw, inch, maxw, maxh, minw, minh;
         int minax, maxax, minay, maxay;
         long flags;
- unsigned int border;
+ unsigned int border, oldborder;
         Bool isbanned, isfixed, ismax, isfloating;
         Bool *tags;
         Client *next;
diff -r 8e23c227b097 -r 018c38468422 main.c
--- a/main.c Thu Apr 19 08:53:40 2007 +0200
+++ b/main.c Thu Apr 19 09:24:25 2007 +0200
@@ -81,7 +81,7 @@ initfont(const char *fontstr) {
         dc.font.set = XCreateFontSet(dpy, fontstr, &missing, &n, &def);
         if(missing) {
                 while(n--)
- fprintf(stderr, "missing fontset: %s\n", missing[n]);
+ fprintf(stderr, "dwm: missing fontset: %s\n", missing[n]);
                 XFreeStringList(missing);
         }
         if(dc.font.set) {
Received on Thu Apr 19 2007 - 09:27:45 UTC

This archive was generated by hypermail 2.2.0 : Sun Jul 13 2008 - 15:56:40 UTC