don't compute position if program or user specified ones
This commit is contained in:
parent
8d3c24e03e
commit
4ad1f8a54a
13
client.c
13
client.c
|
@ -294,6 +294,7 @@ client_manage(Window w, XWindowAttributes *wa, int screen)
|
|||
Rule *rule;
|
||||
Area screen_geom;
|
||||
int phys_screen = get_phys_screen(screen);
|
||||
long flags;
|
||||
|
||||
c = p_new(Client, 1);
|
||||
|
||||
|
@ -324,7 +325,7 @@ client_manage(Window w, XWindowAttributes *wa, int screen)
|
|||
client_updatetitle(c);
|
||||
|
||||
/* update hints */
|
||||
client_updatesizehints(c);
|
||||
flags = client_updatesizehints(c);
|
||||
client_updatewmhints(c);
|
||||
|
||||
/* First check clients hints */
|
||||
|
@ -373,6 +374,7 @@ client_manage(Window w, XWindowAttributes *wa, int screen)
|
|||
client_setfloating(c, rettrans || c->isfixed);
|
||||
}
|
||||
|
||||
if(!(flags & (USSize | PSize)))
|
||||
c->f_geometry = client_get_smart_geometry(c->f_geometry, c->border, c->screen);
|
||||
|
||||
XSelectInput(globalconf.display, w, StructureNotifyMask | PropertyChangeMask | EnterWindowMask);
|
||||
|
@ -604,14 +606,15 @@ client_updatewmhints(Client *c)
|
|||
}
|
||||
}
|
||||
|
||||
void
|
||||
long
|
||||
client_updatesizehints(Client *c)
|
||||
{
|
||||
long msize;
|
||||
XSizeHints size;
|
||||
|
||||
if(!XGetWMNormalHints(globalconf.display, c->win, &size, &msize) || !size.flags)
|
||||
size.flags = PSize;
|
||||
if(!XGetWMNormalHints(globalconf.display, c->win, &size, &msize))
|
||||
return 0L;
|
||||
|
||||
if(size.flags & PBaseSize)
|
||||
{
|
||||
c->basew = size.base_width;
|
||||
|
@ -666,6 +669,8 @@ client_updatesizehints(Client *c)
|
|||
if(c->maxw && c->minw && c->maxh && c->minh
|
||||
&& c->maxw == c->minw && c->maxh == c->minh)
|
||||
c->isfixed = True;
|
||||
|
||||
return size.flags;
|
||||
}
|
||||
|
||||
/** Returns True if a client is tagged
|
||||
|
|
2
client.h
2
client.h
|
@ -34,7 +34,7 @@ void client_manage(Window, XWindowAttributes *, int);
|
|||
Bool client_resize(Client *, Area, Bool);
|
||||
void client_unmanage(Client *);
|
||||
void client_updatewmhints(Client *);
|
||||
void client_updatesizehints(Client *);
|
||||
long client_updatesizehints(Client *);
|
||||
void client_updatetitle(Client *);
|
||||
void client_saveprops(Client *);
|
||||
void client_kill(Client *);
|
||||
|
|
Loading…
Reference in New Issue