|
|
|
@ -584,7 +584,7 @@ clientmessage(XEvent *e) |
|
|
|
|
if (cme->data.l[1] == netatom[NetWMFullscreen] |
|
|
|
|
|| cme->data.l[2] == netatom[NetWMFullscreen]) |
|
|
|
|
setfullscreen(c, (cme->data.l[0] == 1 /* _NET_WM_STATE_ADD */ |
|
|
|
|
|| cme->data.l[0] == 2 /* _NET_WM_STATE_TOGGLE */)); |
|
|
|
|
|| (cme->data.l[0] == 2 /* _NET_WM_STATE_TOGGLE */ && !c->isfullscreen))); |
|
|
|
|
} else if (cme->message_type == netatom[NetActiveWindow]) { |
|
|
|
|
if (c != selmon->sel && !c->isurgent) |
|
|
|
|
seturgent(c, 1); |
|
|
|
@ -614,6 +614,7 @@ void |
|
|
|
|
configurenotify(XEvent *e) |
|
|
|
|
{ |
|
|
|
|
Monitor *m; |
|
|
|
|
Client *c; |
|
|
|
|
XConfigureEvent *ev = &e->xconfigure; |
|
|
|
|
int dirty; |
|
|
|
|
|
|
|
|
@ -626,11 +627,9 @@ configurenotify(XEvent *e) |
|
|
|
|
drw_resize(drw, sw, bh); |
|
|
|
|
updatebars(); |
|
|
|
|
for (m = mons; m; m = m->next) { |
|
|
|
|
/*
|
|
|
|
|
for (c = m->clients; c; c = c->next) |
|
|
|
|
if (c->isfullscreen) |
|
|
|
|
resizeclient(c, m->mx, m->my, m->mw, m->mh); |
|
|
|
|
*/ |
|
|
|
|
XMoveResizeWindow(dpy, m->barwin, m->wx, m->by, m->ww, m->bh); |
|
|
|
|
} |
|
|
|
|
focus(NULL); |
|
|
|
@ -1282,6 +1281,8 @@ movemouse(const Arg *arg) |
|
|
|
|
|
|
|
|
|
if (!(c = selmon->sel)) |
|
|
|
|
return; |
|
|
|
|
if (c->isfullscreen) /* no support moving fullscreen windows by mouse */ |
|
|
|
|
return; |
|
|
|
|
restack(selmon); |
|
|
|
|
ocx = c->x; |
|
|
|
|
ocy = c->y; |
|
|
|
@ -1583,6 +1584,8 @@ resizemouse(const Arg *arg) |
|
|
|
|
|
|
|
|
|
if (!(c = selmon->sel)) |
|
|
|
|
return; |
|
|
|
|
if (c->isfullscreen) /* no support resizing fullscreen windows by mouse */ |
|
|
|
|
return; |
|
|
|
|
restack(selmon); |
|
|
|
|
ocx = c->x; |
|
|
|
|
ocy = c->y; |
|
|
|
@ -1889,10 +1892,24 @@ setfullscreen(Client *c, int fullscreen) |
|
|
|
|
XChangeProperty(dpy, c->win, netatom[NetWMState], XA_ATOM, 32, |
|
|
|
|
PropModeReplace, (unsigned char*)&netatom[NetWMFullscreen], 1); |
|
|
|
|
c->isfullscreen = 1; |
|
|
|
|
c->oldstate = c->isfloating; |
|
|
|
|
c->oldbw = c->bw; |
|
|
|
|
c->bw = 0; |
|
|
|
|
c->isfloating = 1; |
|
|
|
|
resizeclient(c, c->mon->mx, c->mon->my, c->mon->mw, c->mon->mh); |
|
|
|
|
XRaiseWindow(dpy, c->win); |
|
|
|
|
} else if (!fullscreen && c->isfullscreen){ |
|
|
|
|
XChangeProperty(dpy, c->win, netatom[NetWMState], XA_ATOM, 32, |
|
|
|
|
PropModeReplace, (unsigned char*)0, 0); |
|
|
|
|
c->isfullscreen = 0; |
|
|
|
|
c->isfloating = c->oldstate; |
|
|
|
|
c->bw = c->oldbw; |
|
|
|
|
c->x = c->oldx; |
|
|
|
|
c->y = c->oldy; |
|
|
|
|
c->w = c->oldw; |
|
|
|
|
c->h = c->oldh; |
|
|
|
|
resizeclient(c, c->x, c->y, c->w, c->h); |
|
|
|
|
arrange(c->mon); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
@ -2078,7 +2095,7 @@ showhide(Client *c) |
|
|
|
|
if (ISVISIBLE(c)) { |
|
|
|
|
/* show clients top down */ |
|
|
|
|
XMoveWindow(dpy, c->win, c->x, c->y); |
|
|
|
|
if (!c->mon->lt[c->mon->sellt]->arrange || c->isfloating) |
|
|
|
|
if ((!c->mon->lt[c->mon->sellt]->arrange || c->isfloating) && !c->isfullscreen) |
|
|
|
|
resize(c, c->x, c->y, c->w, c->h, 0); |
|
|
|
|
showhide(c->snext); |
|
|
|
|
} else { |
|
|
|
@ -2188,6 +2205,8 @@ togglefloating(const Arg *arg) |
|
|
|
|
{ |
|
|
|
|
if (!selmon->sel) |
|
|
|
|
return; |
|
|
|
|
if (selmon->sel->isfullscreen) /* no support for fullscreen windows */ |
|
|
|
|
return; |
|
|
|
|
selmon->sel->isfloating = !selmon->sel->isfloating || selmon->sel->isfixed; |
|
|
|
|
if (selmon->sel->isfloating) |
|
|
|
|
resize(selmon->sel, selmon->sel->x, selmon->sel->y, |
|
|
|
|