diff options
author | garbeam@gmail.com <unknown> | 2011-07-29 20:01:22 +0200 |
---|---|---|
committer | garbeam@gmail.com <unknown> | 2011-07-29 20:01:22 +0200 |
commit | 0de4197cc5e8e81d94d0faffbaf46abab4d44d1a (patch) | |
tree | e28bf0daec67f4fbd455c9af15a0b1738c916c1a /transient.c | |
parent | a372248b803e92e6e781d26703a7fee96550ef3a (diff) | |
download | dwm-0de4197cc5e8e81d94d0faffbaf46abab4d44d1a.tar.gz dwm-0de4197cc5e8e81d94d0faffbaf46abab4d44d1a.tar.bz2 dwm-0de4197cc5e8e81d94d0faffbaf46abab4d44d1a.zip |
applied Peter Hartlichs nice interim Xinerama and map fix patches, for debugging purposes I also added his transient test driver
Diffstat (limited to 'transient.c')
-rw-r--r-- | transient.c | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/transient.c b/transient.c new file mode 100644 index 0000000..040adb5 --- /dev/null +++ b/transient.c @@ -0,0 +1,42 @@ +/* cc transient.c -o transient -lX11 */ + +#include <stdlib.h> +#include <unistd.h> +#include <X11/Xlib.h> +#include <X11/Xutil.h> + +int main(void) { + Display *d; + Window r, f, t = None; + XSizeHints h; + XEvent e; + + d = XOpenDisplay(NULL); + if (!d) + exit(1); + r = DefaultRootWindow(d); + + f = XCreateSimpleWindow(d, r, 100, 100, 400, 400, 0, 0, 0); + h.min_width = h.max_width = h.min_height = h.max_height = 400; + h.flags = PMinSize | PMaxSize; + XSetWMNormalHints(d, f, &h); + XStoreName(d, f, "floating"); + XMapWindow(d, f); + + XSelectInput(d, f, ExposureMask); + while (1) { + XNextEvent(d, &e); + + if (t == None) { + sleep(5); + t = XCreateSimpleWindow(d, r, 50, 50, 100, 100, 0, 0, 0); + XSetTransientForHint(d, t, f); + XStoreName(d, t, "transient"); + XMapWindow(d, t); + XSelectInput(d, t, ExposureMask); + } + } + + XCloseDisplay(d); + exit(0); +} |