#include "tooltip.h"
#include "timer.h"
-static int urgent_timer = 0;
+static const struct timeout* urgent_timeout = 0;
const char* task_get_tooltip(void* obj)
{
//printf("add_task panel %d, desktop %d, task %s\n", i, j, new_tsk2->title);
}
}
+ if (window_is_urgent(win))
+ add_urgent(new_tsk2);
return new_tsk2;
}
task_active = 0;
if (tsk2 == task_drag)
task_drag = 0;
+ if (is_urgent(tsk2))
+ del_urgent(tsk2);
XFreePixmap (server.dsp, tsk2->area.pix.pmap);
XFreePixmap (server.dsp, tsk2->area.pix_active.pmap);
}
+Task *next_task(Task *tsk)
+{
+ GSList *l0;
+ int i, j;
+ Task *tsk1;
+
+ for (i=0 ; i < nb_panel ; i++) {
+ for (j=0 ; j < panel1[i].nb_desktop ; j++) {
+ for (l0 = panel1[i].taskbar[j].area.list; l0 ; l0 = l0->next) {
+ tsk1 = l0->data;
+ if (tsk1 == tsk) {
+ if (l0->next == NULL) l0 = panel1[i].taskbar[j].area.list;
+ else l0 = l0->next;
+ return l0->data;
+ }
+ }
+ }
+ }
+
+ return NULL;
+}
+
+Task *prev_task(Task *tsk)
+{
+ GSList *l0;
+ int i, j;
+ Task *tsk1, *tsk2;
+
+ for (i=0 ; i < nb_panel ; i++) {
+ for (j=0 ; j < panel1[i].nb_desktop ; j++) {
+ tsk2 = NULL;
+ for (l0 = panel1[i].taskbar[j].area.list; l0 ; l0 = l0->next) {
+ tsk1 = l0->data;
+ if (tsk1 == tsk) {
+ if (l0 == panel1[i].taskbar[j].area.list) {
+ l0 = g_slist_last ( l0 );
+ tsk2 = l0->data;
+ }
+ return tsk2;
+ }
+ tsk2 = tsk1;
+ }
+ }
+ }
+
+ return NULL;
+}
+
+
void active_task()
{
GSList *l0;
void add_urgent(Task *tsk)
{
+ if (!tsk)
+ return;
+
+ // some programs set urgency hint although they are active
+ if ( task_active && task_active->win == tsk->win )
+ return;
+
// first check if task is already in the list and reset the counter
GSList* urgent_task = urgent_list;
while (urgent_task) {
t->tick = 0;
urgent_list = g_slist_prepend(urgent_list, t);
- if (urgent_timer == 0)
- urgent_timer = install_timer(0, 1000000, 1, 0, blink_urgent);
- else
- reset_timer(urgent_timer, 0, 1000000, 1, 0);
+ if (urgent_timeout == 0)
+ urgent_timeout = add_timeout(10, 1000, blink_urgent);
}
if (t->tsk == tsk) {
urgent_list = g_slist_remove(urgent_list, t);
free(t);
- if (!urgent_list)
- reset_timer(urgent_timer, 0, 0, 0, 0);
+ if (!urgent_list) {
+ stop_timeout(urgent_timeout);
+ urgent_timeout = 0;
+ }
return;
}
urgent_task = urgent_task->next;
int is_urgent(Task *tsk)
{
+ if (!tsk)
+ return;
GSList* urgent_task = urgent_list;
while (urgent_task) {
Task_urgent* t = urgent_task->data;