tabbed

tab interface for application supporting Xembed
git clone git://git.suckless.org/tabbed
Log | Files | Refs | README | LICENSE

commit bcf3d90ce7d93bf2a34c2bec3b2fdd2a7c5e0af0
parent ef13e0d92e2bf38610f7d3540ee6282f84495b88
Author: Christoph Lohmann <20h@r-36.net>
Date:   Sat, 13 Oct 2012 06:57:32 +0200

Fix the atom handling and fix the title setting. Thanks to Carlos Pita!
Diffstat:
tabbed.c | 14++++++++------
1 file changed, 8 insertions(+), 6 deletions(-)

diff --git a/tabbed.c b/tabbed.c @@ -47,7 +47,7 @@ #define TEXTW(x) (textnw(x, strlen(x)) + dc.font.height) enum { ColFG, ColBG, ColLast }; /* color */ -enum { WMProtocols, WMDelete, WMLast }; /* default atoms */ +enum { WMProtocols, WMDelete, WMName, XEmbed, WMLast }; /* default atoms */ typedef union { int i; @@ -147,7 +147,7 @@ static unsigned int numlockmask = 0; static Bool running = True, nextfocus, doinitspawn = True; static Display *dpy; static DC dc; -static Atom wmatom[WMLast], xembedatom; +static Atom wmatom[WMLast]; static Window root, win; static Client *clients = NULL, *sel = NULL, *lastsel = NULL; static int (*xerrorxlib)(Display *, XErrorEvent *); @@ -601,7 +601,7 @@ manage(Window w) { XMapRaised(dpy, w); e.xclient.window = w; e.xclient.type = ClientMessage; - e.xclient.message_type = xembedatom; + e.xclient.message_type = wmatom[XEmbed]; e.xclient.format = 32; e.xclient.data.l[0] = CurrentTime; e.xclient.data.l[1] = XEMBED_EMBEDDED_NOTIFY; @@ -708,7 +708,7 @@ sendxembed(Client *c, long msg, long detail, long d1, long d2) { e.xclient.window = c->win; e.xclient.type = ClientMessage; - e.xclient.message_type = xembedatom; + e.xclient.message_type = wmatom[XEmbed]; e.xclient.format = 32; e.xclient.data.l[0] = CurrentTime; e.xclient.data.l[1] = msg; @@ -743,7 +743,8 @@ setup(void) { /* init atoms */ wmatom[WMProtocols] = XInternAtom(dpy, "WM_PROTOCOLS", False); wmatom[WMDelete] = XInternAtom(dpy, "WM_DELETE_WINDOW", False); - xembedatom = XInternAtom(dpy, "_XEMBED", False); + wmatom[XEmbed] = XInternAtom(dpy, "_XEMBED", False); + wmatom[WMName] = XInternAtom(dpy, "_NET_WM_NAME", False); /* init appearance */ wx = 0; @@ -855,7 +856,8 @@ updatenumlockmask(void) { void updatetitle(Client *c) { - gettextprop(c->win, XA_WM_NAME, c->name, sizeof c->name); + if(!gettextprop(c->win, wmatom[WMName], c->name, sizeof c->name)) + gettextprop(c->win, XA_WM_NAME, c->name, sizeof c->name); if(sel == c) XStoreName(dpy, win, c->name); drawbar();