]> Dogcows Code - chaz/tint2/commitdiff
desktop name : last step
authorThierry Lorthiois <lorthiois@bbsoft.fr>
Tue, 16 Nov 2010 20:00:22 +0000 (20:00 +0000)
committerThierry Lorthiois <lorthiois@bbsoft.fr>
Tue, 16 Nov 2010 20:00:22 +0000 (20:00 +0000)
src/taskbar/taskbarname.c
src/tint.c
src/util/window.c
src/util/window.h

index 2cde28b1e7b92b7af04d7d2fc21b3defafa9770d..12866c7aabb46e1c75b6b553bb03d9e49da588a6 100644 (file)
@@ -49,25 +49,11 @@ void init_taskbarname_panel(void *p)
 {
        Panel *panel =(Panel*)p;
        Taskbar *tskbar;
-       int j, count;
+       int j;
        
        if (!taskbarname_enabled) return;
        
-       GList *list = NULL;
-       gchar *data_ptr, *ptr;
-       data_ptr = server_get_property (server.root_win, server.atom._NET_DESKTOP_NAMES, server.atom.UTF8_STRING, &count);
-       if (data_ptr) {
-               list = g_list_append(list, g_strdup(data_ptr));
-               for (j = 0; j < count-1; j++) {
-                       if (*(data_ptr + j)     == '\0') {
-                               ptr = (gchar*)data_ptr + j + 1;
-                               list = g_list_append(list, g_strdup(ptr));
-                       }
-               }
-               XFree(data_ptr);
-       }
-
-       GList *l;
+       GSList *l, *list = server_get_name_of_desktop();
        for (j=0, l=list ; j < panel->nb_desktop ; j++) {
                tskbar = &panel->taskbar[j];
                memcpy(&tskbar->bar_name.area, &panel->g_taskbar.area_name, sizeof(Area));
@@ -77,18 +63,21 @@ void init_taskbarname_panel(void *p)
                else
                        tskbar->bar_name.area.bg = panel->g_taskbar.background_name[TASKBAR_NORMAL];
 
+               // use desktop number if name is missing
                if (l) {
                        tskbar->bar_name.name = g_strdup(l->data);
                        l = l->next;
                }
-               else {
-                       // use desktop number if name is missing
+               else
                        tskbar->bar_name.name = g_strdup_printf("%d", j+1);
-               }
                
                // append the name at the beginning of taskbar
                tskbar->area.list = g_slist_append(tskbar->area.list, &tskbar->bar_name);
        }
+
+       for (l=list ; l ; l = l->next)
+               g_free(l->data);
+       g_slist_free(list);
 }
 
 
index 536cbc38e03c6c5e4191efd4efdb4d53df2ca633..5d5720c996ad591ff9631e6e6045a87dc5bd7b70 100644 (file)
@@ -492,7 +492,32 @@ void event_property_notify (XEvent *e)
 
                // Change name of desktops
                else if (at == server.atom._NET_DESKTOP_NAMES) {
-                       printf("_NET_DESKTOP_NAMES\n");
+                       if (!taskbarname_enabled) return;
+                       GSList *l, *list = server_get_name_of_desktop();
+                       int j;
+                       gchar *name;
+                       Taskbar *tskbar;
+                       for (i=0 ; i < nb_panel ; i++) {
+                               for (j=0, l=list ; j < panel1[i].nb_desktop ; j++) {
+                                       if (l) {
+                                               name = g_strdup(l->data);
+                                               l = l->next;
+                                       }
+                                       else
+                                               name = g_strdup_printf("%d", j+1);
+                                       tskbar = &panel1[i].taskbar[j];
+                                       if (strcmp(name, tskbar->bar_name.name) != 0) {
+                                               g_free(tskbar->bar_name.name);
+                                               tskbar->bar_name.name = name;
+                                               tskbar->bar_name.area.resize = 1;
+                                       }
+                                       else
+                                               g_free(name);
+                               }
+                       }
+                       for (l=list ; l ; l = l->next)
+                               g_free(l->data);
+                       g_slist_free(list);
                        panel_refresh = 1;
                }
                // Change number of desktops
index ef38071a8589dba7c87a5f20ea0939ad5dc7f73d..ac2b40016e9d9f581a250f69aee16e17e7e65ef8 100644 (file)
@@ -203,6 +203,26 @@ int server_get_number_of_desktop ()
 }
 
 
+GSList *server_get_name_of_desktop ()
+{
+       int count, j;
+       GSList *list = NULL;
+       gchar *data_ptr, *ptr;
+       data_ptr = server_get_property (server.root_win, server.atom._NET_DESKTOP_NAMES, server.atom.UTF8_STRING, &count);
+       if (data_ptr) {
+               list = g_slist_append(list, g_strdup(data_ptr));
+               for (j = 0; j < count-1; j++) {
+                       if (*(data_ptr + j)     == '\0') {
+                               ptr = (gchar*)data_ptr + j + 1;
+                               list = g_slist_append(list, g_strdup(ptr));
+                       }
+               }
+               XFree(data_ptr);
+       }
+       return list;
+}
+
+
 int server_get_current_desktop ()
 {
        return get_property32(server.root_win, server.atom._NET_CURRENT_DESKTOP, XA_CARDINAL);
index db6d3a99a7ab281f85e827c22195e3d730f07e15..fcf666fd2c9599d86cbc6857b714348cf62d944b 100644 (file)
@@ -9,6 +9,7 @@
 #ifndef WINDOW_H
 #define WINDOW_H
 
+#include <glib.h>
 #include <pango/pangocairo.h>
 
 
@@ -17,6 +18,7 @@ void set_desktop (int desktop);
 void set_close (Window win);
 int server_get_current_desktop ();
 int server_get_number_of_desktop ();
+GSList *server_get_name_of_desktop ();
 int window_is_iconified (Window win);
 int window_is_urgent (Window win);
 int window_is_hidden (Window win);
This page took 0.029324 seconds and 4 git commands to generate.