rename setclientstate to window_setstate and change args for isprotodel()
This commit is contained in:
parent
f957a0e0b5
commit
25d12961a8
27
client.c
27
client.c
|
@ -143,16 +143,16 @@ grabbuttons(Client * c, Bool focused, Bool raised, KeySym modkey, unsigned int n
|
||||||
* \return True if client has WM_DELETE_WINDOW
|
* \return True if client has WM_DELETE_WINDOW
|
||||||
*/
|
*/
|
||||||
static Bool
|
static Bool
|
||||||
isprotodel(Client * c)
|
isprotodel(Display *disp, Window win)
|
||||||
{
|
{
|
||||||
int i, n;
|
int i, n;
|
||||||
Atom *protocols;
|
Atom *protocols;
|
||||||
Bool ret = False;
|
Bool ret = False;
|
||||||
|
|
||||||
if(XGetWMProtocols(c->display, c->win, &protocols, &n))
|
if(XGetWMProtocols(disp, win, &protocols, &n))
|
||||||
{
|
{
|
||||||
for(i = 0; !ret && i < n; i++)
|
for(i = 0; !ret && i < n; i++)
|
||||||
if(protocols[i] == XInternAtom(c->display, "WM_DELETE_WINDOW", False))
|
if(protocols[i] == XInternAtom(disp, "WM_DELETE_WINDOW", False))
|
||||||
ret = True;
|
ret = True;
|
||||||
XFree(protocols);
|
XFree(protocols);
|
||||||
}
|
}
|
||||||
|
@ -164,12 +164,12 @@ isprotodel(Client * c)
|
||||||
* \param state no idea
|
* \param state no idea
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
setclientstate(Client * c, long state)
|
window_setstate(Display *disp, Window win, long state)
|
||||||
{
|
{
|
||||||
long data[] = { state, None };
|
long data[] = { state, None };
|
||||||
|
|
||||||
XChangeProperty(c->display, c->win, XInternAtom(c->display, "WM_STATE", False),
|
XChangeProperty(disp, win, XInternAtom(disp, "WM_STATE", False),
|
||||||
XInternAtom(c->display, "WM_STATE", False), 32,
|
XInternAtom(disp, "WM_STATE", False), 32,
|
||||||
PropModeReplace, (unsigned char *) data, 2);
|
PropModeReplace, (unsigned char *) data, 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -242,7 +242,7 @@ void
|
||||||
ban(Client * c)
|
ban(Client * c)
|
||||||
{
|
{
|
||||||
XUnmapWindow(c->display, c->win);
|
XUnmapWindow(c->display, c->win);
|
||||||
setclientstate(c, IconicState);
|
window_setstate(c->display, c->win, IconicState);
|
||||||
c->isbanned = True;
|
c->isbanned = True;
|
||||||
c->unmapped = True;
|
c->unmapped = True;
|
||||||
}
|
}
|
||||||
|
@ -579,7 +579,7 @@ void
|
||||||
unban(Client *c)
|
unban(Client *c)
|
||||||
{
|
{
|
||||||
XMapWindow(c->display, c->win);
|
XMapWindow(c->display, c->win);
|
||||||
setclientstate(c, NormalState);
|
window_setstate(c->display, c->win, NormalState);
|
||||||
c->isbanned = False;
|
c->isbanned = False;
|
||||||
c->unmapped = False;
|
c->unmapped = False;
|
||||||
}
|
}
|
||||||
|
@ -599,7 +599,7 @@ unmanage(Client * c, long state, awesome_config *awesomeconf)
|
||||||
if(*awesomeconf->client_sel == c)
|
if(*awesomeconf->client_sel == c)
|
||||||
focus(NULL, True, awesomeconf);
|
focus(NULL, True, awesomeconf);
|
||||||
XUngrabButton(c->display, AnyButton, AnyModifier, c->win);
|
XUngrabButton(c->display, AnyButton, AnyModifier, c->win);
|
||||||
setclientstate(c, state);
|
window_setstate(c->display, c->win, state);
|
||||||
XSync(c->display, False);
|
XSync(c->display, False);
|
||||||
XSetErrorHandler(xerror);
|
XSetErrorHandler(xerror);
|
||||||
XUngrabServer(c->display);
|
XUngrabServer(c->display);
|
||||||
|
@ -833,20 +833,21 @@ uicb_killclient(awesome_config *awesomeconf,
|
||||||
const char *arg __attribute__ ((unused)))
|
const char *arg __attribute__ ((unused)))
|
||||||
{
|
{
|
||||||
XEvent ev;
|
XEvent ev;
|
||||||
|
Client *sel = *awesomeconf->client_sel;
|
||||||
|
|
||||||
if(!*awesomeconf->client_sel)
|
if(!*awesomeconf->client_sel)
|
||||||
return;
|
return;
|
||||||
if(isprotodel(*awesomeconf->client_sel))
|
if(isprotodel(sel->display, sel->win))
|
||||||
{
|
{
|
||||||
ev.type = ClientMessage;
|
ev.type = ClientMessage;
|
||||||
ev.xclient.window = (*awesomeconf->client_sel)->win;
|
ev.xclient.window = sel->win;
|
||||||
ev.xclient.message_type = XInternAtom(awesomeconf->display, "WM_PROTOCOLS", False);
|
ev.xclient.message_type = XInternAtom(awesomeconf->display, "WM_PROTOCOLS", False);
|
||||||
ev.xclient.format = 32;
|
ev.xclient.format = 32;
|
||||||
ev.xclient.data.l[0] = XInternAtom(awesomeconf->display, "WM_DELETE_WINDOW", False);
|
ev.xclient.data.l[0] = XInternAtom(awesomeconf->display, "WM_DELETE_WINDOW", False);
|
||||||
ev.xclient.data.l[1] = CurrentTime;
|
ev.xclient.data.l[1] = CurrentTime;
|
||||||
XSendEvent(awesomeconf->display, (*awesomeconf->client_sel)->win, False, NoEventMask, &ev);
|
XSendEvent(awesomeconf->display, sel->win, False, NoEventMask, &ev);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
XKillClient(awesomeconf->display, (*awesomeconf->client_sel)->win);
|
XKillClient(awesomeconf->display, sel->win);
|
||||||
}
|
}
|
||||||
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=99
|
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=99
|
||||||
|
|
Loading…
Reference in New Issue