center: center windows by default if they are placed in the top right corner, ref. #52

This commit is contained in:
bakkeby 2020-09-29 13:26:05 +02:00
parent b6cf350098
commit fbacf17346

24
dwm.c
View File

@ -798,8 +798,12 @@ applyrules(Client *c)
if (m) if (m)
c->mon = m; c->mon = m;
#if FLOATPOS_PATCH #if FLOATPOS_PATCH
if (c->isfloating && r->floatpos) if (c->isfloating && r->floatpos) {
#if CENTER_PATCH
c->iscentered = 0;
#endif // CENTER_PATCH
setfloatpos(c, r->floatpos); setfloatpos(c, r->floatpos);
}
#endif // FLOATPOS_PATCH #endif // FLOATPOS_PATCH
#if SWITCHTAG_PATCH #if SWITCHTAG_PATCH
@ -2123,34 +2127,35 @@ manage(Window w, XWindowAttributes *wa)
#if CFACTS_PATCH #if CFACTS_PATCH
c->cfact = 1.0; c->cfact = 1.0;
#endif // CFACTS_PATCH #endif // CFACTS_PATCH
updatetitle(c); updatetitle(c);
#if CENTER_PATCH
if (c->x == c->mon->wx && c->y == c->mon->wy)
c->iscentered = 1;
#endif // CENTER_PATCH
if (XGetTransientForHint(dpy, w, &trans) && (t = wintoclient(trans))) { if (XGetTransientForHint(dpy, w, &trans) && (t = wintoclient(trans))) {
c->mon = t->mon; c->mon = t->mon;
c->tags = t->tags; c->tags = t->tags;
#if FLOATPOS_PATCH
#if SETBORDERPX_PATCH #if SETBORDERPX_PATCH
c->bw = c->mon->borderpx; c->bw = c->mon->borderpx;
#else #else
c->bw = borderpx; c->bw = borderpx;
#endif // SETBORDERPX_PATCH #endif // SETBORDERPX_PATCH
#endif // FLOATPOS_PATCH
#if CENTER_TRANSIENT_WINDOWS_BY_PARENT_PATCH #if CENTER_TRANSIENT_WINDOWS_BY_PARENT_PATCH
c->x = t->x + WIDTH(t) / 2 - WIDTH(c) / 2; c->x = t->x + WIDTH(t) / 2 - WIDTH(c) / 2;
c->y = t->y + HEIGHT(t) / 2 - HEIGHT(c) / 2; c->y = t->y + HEIGHT(t) / 2 - HEIGHT(c) / 2;
#elif CENTER_PATCH && CENTER_TRANSIENT_WINDOWS_PATCH
c->iscentered = 1;
#elif CENTER_TRANSIENT_WINDOWS_PATCH #elif CENTER_TRANSIENT_WINDOWS_PATCH
c->x = c->mon->wx + (c->mon->ww - WIDTH(c)) / 2; c->x = c->mon->wx + (c->mon->ww - WIDTH(c)) / 2;
c->y = c->mon->wy + (c->mon->wh - HEIGHT(c)) / 2; c->y = c->mon->wy + (c->mon->wh - HEIGHT(c)) / 2;
#endif // CENTER_TRANSIENT_WINDOWS_PATCH | CENTER_TRANSIENT_WINDOWS_BY_PARENT_PATCH #endif // CENTER_TRANSIENT_WINDOWS_PATCH | CENTER_TRANSIENT_WINDOWS_BY_PARENT_PATCH
} else { } else {
c->mon = selmon; c->mon = selmon;
#if FLOATPOS_PATCH
#if SETBORDERPX_PATCH #if SETBORDERPX_PATCH
c->bw = c->mon->borderpx; c->bw = c->mon->borderpx;
#else #else
c->bw = borderpx; c->bw = borderpx;
#endif // SETBORDERPX_PATCH #endif // SETBORDERPX_PATCH
#endif // FLOATPOS_PATCH
applyrules(c); applyrules(c);
#if SWALLOW_PATCH #if SWALLOW_PATCH
term = termforwin(c); term = termforwin(c);
@ -2167,13 +2172,6 @@ manage(Window w, XWindowAttributes *wa)
/* only fix client y-offset, if the client center might cover the bar */ /* only fix client y-offset, if the client center might cover the bar */
c->y = MAX(c->y, ((c->mon->bar->by == c->mon->my) && (c->x + (c->w / 2) >= c->mon->wx) c->y = MAX(c->y, ((c->mon->bar->by == c->mon->my) && (c->x + (c->w / 2) >= c->mon->wx)
&& (c->x + (c->w / 2) < c->mon->wx + c->mon->ww)) ? bh : c->mon->my); && (c->x + (c->w / 2) < c->mon->wx + c->mon->ww)) ? bh : c->mon->my);
#if !FLOATPOS_PATCH
#if SETBORDERPX_PATCH
c->bw = c->mon->borderpx;
#else
c->bw = borderpx;
#endif // SETBORDERPX_PATCH
#endif // FLOATPOS_PATCH
wc.border_width = c->bw; wc.border_width = c->bw;
XConfigureWindow(dpy, w, CWBorderWidth, &wc); XConfigureWindow(dpy, w, CWBorderWidth, &wc);