all repos — tint2 @ d44628b16ce22ef3d91b80b3b602a0f582b86a9f

fork of the tint2 desktop panel for my custom setup - only minimized windows across all desktops for the taskbar

panel_items : fixed change number of desktop

git-svn-id: http://tint2.googlecode.com/svn/trunk@554 121b4492-b84c-0410-8b4c-0d4edfb3f3cc
thilor77 thilor77@121b4492-b84c-0410-8b4c-0d4edfb3f3cc
commit

d44628b16ce22ef3d91b80b3b602a0f582b86a9f

parent

1bd5fd99378fc3f031d951306c7e7239fc9ae260

3 files changed, 28 insertions(+), 17 deletions(-)

jump to
M src/panel.csrc/panel.c

@@ -126,7 +126,7 @@ }

void init_panel() { - int i; + int i, k; Panel *p; if (panel_config.monitor > (server.nb_monitor-1)) {

@@ -174,7 +174,24 @@ p->g_taskbar.area.panel = p;

p->g_task.area.panel = p; init_panel_size_and_position(p); // add childs according to panel_items - set_panel_items(p); + for (k=0 ; k < strlen(panel_items_order) ; k++) { + if (panel_items_order[k] == 'L') + init_launcher_panel(p); + if (panel_items_order[k] == 'T') + init_taskbar_panel(p); +#ifdef ENABLE_BATTERY + if (panel_items_order[k] == 'B') + init_battery_panel(p); +#endif + if (panel_items_order[k] == 'S') { + // TODO : check systray is only on 1 panel + init_systray_panel(p); + refresh_systray = 1; + } + if (panel_items_order[k] == 'C') + init_clock_panel(p); + } + set_panel_items_order(p); // catch some events XSetWindowAttributes att = { .colormap=server.colormap, .background_pixel=0, .border_pixel=0 };

@@ -453,7 +470,7 @@ XChangeProperty (server.dsp, p->main_win, server.atom._NET_WM_STRUT_PARTIAL, XA_CARDINAL, 32, PropModeReplace, (unsigned char *) &struts, 12);

} -void set_panel_items(Panel *p) +void set_panel_items_order(Panel *p) { int k, j;

@@ -463,31 +480,22 @@ p->area.list = 0;

} for (k=0 ; k < strlen(panel_items_order) ; k++) { - if (panel_items_order[k] == 'L') { - init_launcher_panel(p); + if (panel_items_order[k] == 'L') p->area.list = g_slist_append(p->area.list, &p->launcher); - } if (panel_items_order[k] == 'T') { - init_taskbar_panel(p); for (j=0 ; j < p->nb_desktop ; j++) p->area.list = g_slist_append(p->area.list, &p->taskbar[j]); } #ifdef ENABLE_BATTERY - if (panel_items_order[k] == 'B') { - init_battery_panel(p); + if (panel_items_order[k] == 'B') p->area.list = g_slist_append(p->area.list, &p->battery); - } #endif if (panel_items_order[k] == 'S') { // TODO : check systray is only on 1 panel - init_systray_panel(p); - refresh_systray = 1; p->area.list = g_slist_append(p->area.list, &systray); } - if (panel_items_order[k] == 'C') { - init_clock_panel(p); + if (panel_items_order[k] == 'C') p->area.list = g_slist_append(p->area.list, &p->clock); - } } }
M src/panel.hsrc/panel.h

@@ -137,7 +137,7 @@

void init_panel_size_and_position(Panel *panel); int resize_panel(void *obj); -void set_panel_items(Panel *p); +void set_panel_items_order(Panel *p); void set_panel_properties(Panel *p); void visible_object();
M src/tint.csrc/tint.c

@@ -487,11 +487,13 @@ }

// Change number of desktops else if (at == server.atom._NET_NUMBER_OF_DESKTOPS) { + if (!taskbar_enabled) return; server.nb_desktop = server_get_number_of_desktop (); cleanup_taskbar(); init_taskbar(); for (i=0 ; i < nb_panel ; i++) { - set_panel_items(&panel1[i]); + init_taskbar_panel(&panel1[i]); + set_panel_items_order(&panel1[i]); panel1[i].area.resize = 1; } visible_object();

@@ -501,6 +503,7 @@ panel_refresh = 1;

} // Change desktop else if (at == server.atom._NET_CURRENT_DESKTOP) { + if (!taskbar_enabled) return; int old_desktop = server.desktop; server.desktop = server_get_current_desktop (); for (i=0 ; i < nb_panel ; i++) {