+void server_init_visual()
+{
+ // inspired by freedesktops fdclock ;)
+ XVisualInfo *xvi;
+ XVisualInfo templ = { .screen=server.screen, .depth=32, .class=TrueColor };
+ int nvi;
+ xvi = XGetVisualInfo(server.dsp, VisualScreenMask|VisualDepthMask|VisualClassMask, &templ, &nvi);
+
+ Visual *visual = 0;
+ if (xvi) {
+ int i;
+ XRenderPictFormat *format;
+ for (i = 0; i < nvi; i++) {
+ format = XRenderFindVisualFormat(server.dsp, xvi[i].visual);
+ if (format->type == PictTypeDirect && format->direct.alphaMask) {
+ visual = xvi[i].visual;
+ break;
+ }
+ }
+ }
+ XFree (xvi);
+
+ if (visual && real_transparency) {
+ server.depth = 32;
+ printf("real transparency on... depth: %d\n", server.depth);
+ server.colormap = XCreateColormap(server.dsp, server.root_win, visual, AllocNone);
+ server.visual = visual;
+ }
+ else {
+ server.depth = DefaultDepth(server.dsp, server.screen);
+ printf("real transparency off.... depth: %d\n", server.depth);
+ server.colormap = DefaultColormap(server.dsp, server.screen);
+ server.visual = DefaultVisual(server.dsp, server.screen);
+ }
+}