Fixed transfer stall detecion in dsh.
[doldaconnect.git] / clients / gui-shell / dsh.c
index e5310cd..652e45e 100644 (file)
@@ -48,6 +48,7 @@ struct trinfo {
     int ostate;
     int opos, spos, speed;
     time_t lastprog;
+    int warned;
     double sprog;
 };
 
@@ -229,11 +230,11 @@ void updatetooltip(void)
     }
     buf = NULL;
     bufsize = bufdata = 0;
-    bprintf(buf, "Transfers: %i", t);
+    bprintf(buf, "%s: %i", _("Transfers"), t);
     if(t > 0)
        bprintf(buf, " (%i/%i)", i, a);
     if(bt > 0)
-       bprintf(buf, ", %.1f%%", (double)bc / (double)bt);
+       bprintf(buf, ", %.1f%%", ((double)bc / (double)bt) * 100.0);
     if(st != -1)
        bprintf(buf, ", %s/s", bytes2si(st));
     addtobuf(buf, 0);
@@ -287,11 +288,14 @@ void updatetrinfo(void)
            if(tri->opos != tr->curpos) {
                tri->opos = tr->curpos;
                tri->lastprog = now;
+               tri->warned = 0;
            }
-#ifdef NOTIFY
-           if((tr->state = DC_TRNS_MAIN) && (now - tri->lastprog > 600)) {
-               if(dcpid == 0)
+#ifdef HAVE_NOTIFY
+           if((tr->state = DC_TRNS_MAIN) && (now - tri->lastprog > 600) && !tri->warned) {
+               if(dcpid == 0) {
                    notify(&trnote, "transfer.error", _("Transfer stalled"), _("The transfer of %ls from %ls has not made progress for 10 minutes"), getfilename(tr->path), tr->peernick);
+                   tri->warned = 1;
+               }
            }
 #endif
            if((tr->state == DC_TRNS_MAIN) && (dnow - tri->sprog > 10)) {