[hackers] [dwm] setfullscreen: don't process the property twice || Quentin Rameau
commit dce4fb373757727374d00c857ec0dfd225bbeafd
Author: Quentin Rameau <quinq+hackers_AT_fifth.space>
AuthorDate: Sat Nov 7 14:09:08 2015 +0100
Commit: Hiltjo Posthuma <hiltjo_AT_codemadness.org>
CommitDate: Sat Nov 7 14:31:21 2015 +0100
setfullscreen: don't process the property twice
Some clients try to set _NET_WM_STATE_FULLSCREEN even when the window is
already in fullscreen.
For example, c->oldstate was set two times in a raw and window would
then always be floating.
We must check that it's not the case before processing it.
(original patch modified with suggestion from Markus Teich
<markus.teich_AT_stusta.mhn.de>)
diff --git a/dwm.c b/dwm.c
index 96b43f7..3639165 100644
--- a/dwm.c
+++ b/dwm.c
_AT_@ -1441,7 +1441,7 @@ setfocus(Client *c) {
void
setfullscreen(Client *c, Bool fullscreen) {
- if(fullscreen) {
+ if(fullscreen && !c->isfullscreen) {
XChangeProperty(dpy, c->win, netatom[NetWMState], XA_ATOM, 32,
PropModeReplace, (unsigned char*)&netatom[NetWMFullscreen], 1);
c->isfullscreen = True;
_AT_@ -1452,7 +1452,7 @@ setfullscreen(Client *c, Bool fullscreen) {
resizeclient(c, c->mon->mx, c->mon->my, c->mon->mw, c->mon->mh);
XRaiseWindow(dpy, c->win);
}
- else {
+ else if(!fullscreen && c->isfullscreen){
XChangeProperty(dpy, c->win, netatom[NetWMState], XA_ATOM, 32,
PropModeReplace, (unsigned char*)0, 0);
c->isfullscreen = False;
Received on Sat Nov 07 2015 - 14:32:57 CET
This archive was generated by hypermail 2.3.0
: Sat Nov 07 2015 - 14:36:11 CET