From 7d4aecffc20478ea6807b9649b25b71e22ebbcb6 Mon Sep 17 00:00:00 2001 From: Adrien Schildknecht Date: Thu, 25 Apr 2013 20:27:50 +0200 Subject: [PATCH] properly handle gtk windows --- TODO | 1 - xcwd.c | 47 +++++++++++++++++++++++++++++++++++++---------- 2 files changed, 37 insertions(+), 11 deletions(-) diff --git a/TODO b/TODO index 3097fad..5ba2c5f 100644 --- a/TODO +++ b/TODO @@ -8,5 +8,4 @@ multi-monitor ? Bugs ---- -xcwd is unable to get the properties of a gtk window. diff --git a/xcwd.c b/xcwd.c index e5cb4fb..521f732 100644 --- a/xcwd.c +++ b/xcwd.c @@ -12,7 +12,9 @@ #include #include -#define XA_STRING (XInternAtom(dpy, "STRING", 0)) +#define XA_STRING (XInternAtom(dpy, "STRING", 0)) +#define XA_CARDINAL (XInternAtom(dpy, "CARDINAL", 0)) +#define XA_WM_STATE (XInternAtom(dpy, "WM_STATE", 0)) Display *dpy; @@ -39,31 +41,52 @@ int ppidCmp(const void *p1, const void *p2) static Window focusedWindow() { - Window focuswin; + Window focuswin, root; int focusrevert; + int format, status; + unsigned long nitems, after; + unsigned char *data; + Atom type; + Window* children; + unsigned int nchildren; dpy = XOpenDisplay (NULL); if (!dpy) exit (1); XGetInputFocus (dpy, &focuswin, &focusrevert); + root = XDefaultRootWindow(dpy); + + do { + status = XGetWindowProperty(dpy, focuswin, XA_WM_STATE, 0, 65536, 0, + XA_WM_STATE, &type, &format, &nitems, &after, &data); + if(status == Success && data) { + XFree(data); #ifdef DEBUG - fprintf(stderr, "Window ID = %lu\n", focuswin); + fprintf(stderr, "Window ID = %lu\n", focuswin); #endif - return focuswin; + return focuswin; + } + XQueryTree(dpy, focuswin, &root, &focuswin, &children, &nchildren); +#ifdef DEBUG + fprintf(stderr, "Current window do not have WM_STATE, getting parent\n"); +#endif + } while(focuswin != root); + + return 0; } static long windowPid(Window focuswin) { Atom nameAtom = XInternAtom(dpy, "_NET_WM_PID", 1); - Atom cardinalAtom = XInternAtom(dpy, "CARDINAL", 0); Atom type; - int format; + int format, status; long pid = -1; unsigned long nitems, after; - unsigned char *data = 0; + unsigned char *data; - if (XGetWindowProperty(dpy, focuswin, nameAtom, 0, 1024, 0, cardinalAtom, - &type, &format, &nitems, &after, &data) == Success) { + status = XGetWindowProperty(dpy, focuswin, nameAtom, 0, 65536, 0, + XA_CARDINAL, &type, &format, &nitems, &after, &data); + if(status == Success) { if (data) { pid = *((long*)data); XFree(data); @@ -187,8 +210,12 @@ static void readPath(long pid) int main(int argc, const char *argv[]) { processes_t p; - Window w = focusedWindow(); long pid; + Window w = focusedWindow(); + if(w == 0) { + fprintf(stdout, "%s\n", getenv("HOME")); + return EXIT_FAILURE; + } pid = windowPid(w); p = getProcesses();