]> Dogcows Code - chaz/tint2/blobdiff - src/server.c
fixed issue 48
[chaz/tint2] / src / server.c
index 8e90d24b8da179751adc2ec29aa701a1e4fcb242..db069930a6bfdf3e9da783febad492fb823c5ca8 100644 (file)
 
 #include <stdio.h>
 #include <stdlib.h>
+#include <unistd.h>
 
 #include "server.h"
-#include "panel.h"
 #include "task.h"
 #include "window.h"
 
 void server_catch_error (Display *d, XErrorEvent *ev){}
 
+static char *name_trayer = 0;
+
 
 void server_init_atoms ()
 {
@@ -41,6 +43,7 @@ void server_init_atoms ()
    server.atom._NET_WM_STATE_SKIP_PAGER = XInternAtom (server.dsp, "_NET_WM_STATE_SKIP_PAGER", False);
    server.atom._NET_WM_STATE_SKIP_TASKBAR = XInternAtom (server.dsp, "_NET_WM_STATE_SKIP_TASKBAR", False);
    server.atom._NET_WM_STATE_STICKY = XInternAtom (server.dsp, "_NET_WM_STATE_STICKY", False);
+   server.atom._NET_WM_STATE_DEMANDS_ATTENTION = XInternAtom (server.dsp, "_NET_WM_STATE_DEMANDS_ATTENTION", False);
    server.atom._NET_WM_WINDOW_TYPE_DOCK = XInternAtom (server.dsp, "_NET_WM_WINDOW_TYPE_DOCK", False);
    server.atom._NET_WM_WINDOW_TYPE_DESKTOP = XInternAtom (server.dsp, "_NET_WM_WINDOW_TYPE_DESKTOP", False);
    server.atom._NET_WM_WINDOW_TYPE_TOOLBAR = XInternAtom (server.dsp, "_NET_WM_WINDOW_TYPE_TOOLBAR", False);
@@ -68,6 +71,20 @@ void server_init_atoms ()
    server.atom.WM_NAME = XInternAtom(server.dsp, "WM_NAME", False);
    server.atom.__SWM_VROOT = XInternAtom(server.dsp, "__SWM_VROOT", False);
    server.atom._MOTIF_WM_HINTS = XInternAtom(server.dsp, "_MOTIF_WM_HINTS", False);
+
+       // systray protocol
+       name_trayer = g_strdup_printf("_NET_SYSTEM_TRAY_S%d", DefaultScreen(server.dsp));
+       server.atom._NET_SYSTEM_TRAY_SCREEN = XInternAtom(server.dsp, name_trayer, False);
+       server.atom._NET_SYSTEM_TRAY_OPCODE = XInternAtom(server.dsp, "_NET_SYSTEM_TRAY_OPCODE", False);
+       server.atom.MANAGER = XInternAtom(server.dsp, "MANAGER", False);
+       server.atom._NET_SYSTEM_TRAY_MESSAGE_DATA = XInternAtom(server.dsp, "_NET_SYSTEM_TRAY_MESSAGE_DATA", False);
+       server.atom._NET_SYSTEM_TRAY_ORIENTATION = XInternAtom(server.dsp, "_NET_SYSTEM_TRAY_ORIENTATION", False);
+}
+
+
+void cleanup_server()
+{
+       if (name_trayer) free(name_trayer);
 }
 
 
@@ -135,6 +152,38 @@ void *server_get_property (Window win, Atom at, Atom type, int *num_results)
 }
 
 
+void get_root_pixmap()
+{
+       Pixmap ret = None;
+
+   unsigned long *res;
+       int  c = 2;
+
+       do {
+               res = server_get_property (server.root_win, server.atom._XROOTPMAP_ID, XA_PIXMAP, 0);
+               if (res) {
+                       ret = *((Pixmap*)res);
+                       XFree(res);
+         break;
+               }
+       } while (--c > 0);
+       server.root_pmap = ret;
+
+       if (server.root_pmap == None)
+               fprintf(stderr, "tint2 : pixmap background detection failed\n");
+       else {
+               XGCValues  gcv;
+               gcv.ts_x_origin = 0;
+               gcv.ts_y_origin = 0;
+               gcv.fill_style = FillTiled;
+               uint mask = GCTileStipXOrigin | GCTileStipYOrigin | GCFillStyle | GCTile;
+
+               gcv.tile = server.root_pmap;
+               XChangeGC(server.dsp, server.gc, mask, &gcv);
+       }
+}
+
+
 int compareMonitor(const void *monitor1, const void *monitor2)
 {
    Monitor *m1 = (Monitor*)monitor1;
@@ -161,8 +210,10 @@ int compareMonitor(const void *monitor1, const void *monitor2)
 }
 
 
-void get_monitors()
+void get_monitors_and_desktops()
 {
+   int i;
+
    if (server.monitor) free(server.monitor);
    server.nb_monitor = 0;
    server.monitor = 0;
@@ -172,8 +223,9 @@ void get_monitors()
       XineramaScreenInfo *info = XineramaQueryScreens(server.dsp, &nb_monitor);
 
       if (info) {
-         int i = 0, nb=0, j;
+                       int nb=0, j;
 
+         i = 0;
          server.monitor = calloc(nb_monitor, sizeof(Monitor));
          while (i < nb_monitor) {
                 for (j = 0; j < i; j++) {
@@ -190,7 +242,6 @@ void get_monitors()
                                        }
                                }
 
-               //fprintf(stderr, "monitor %d added\n", i);
             server.monitor[nb].x = info[i].x_org;
             server.monitor[nb].y = info[i].y_org;
             server.monitor[nb].width = info[i].width;
@@ -214,6 +265,18 @@ next:
       server.monitor[0].width = DisplayWidth (server.dsp, server.screen);
       server.monitor[0].height = DisplayHeight (server.dsp, server.screen);
    }
+
+       // detect number of desktops
+   for (i=0 ; i < 15 ; i++) {
+      server.nb_desktop = server_get_number_of_desktop ();
+      if (server.nb_desktop > 0) break;
+      sleep(1);
+   }
+   if (server.nb_desktop == 0) {
+      server.nb_desktop = 1;
+      fprintf(stderr, "tint2 : cannot found number of desktop.\n");
+   }
+       fprintf(stderr, "tint2 : nb monitor %d, nb desktop %d\n", server.nb_monitor, server.nb_desktop);
 }
 
 
This page took 0.027956 seconds and 4 git commands to generate.