Browse Source

- Fixed overflow handling in ETA calculation

adaptive-webui-19844
Christophe Dumez 17 years ago
parent
commit
f75501f781
  1. 12
      src/bittorrent.cpp

12
src/bittorrent.cpp

@ -166,8 +166,16 @@ void bittorrent::updateETAs() { @@ -166,8 +166,16 @@ void bittorrent::updateETAs() {
foreach(val, listEtas) {
moy += (qlonglong)((double)val/(double)nbETAs);
}
Q_ASSERT(moy >= 0);
ETAs[hash] = moy;
if(moy < 0) {
if(ETAstats.contains(hash)) {
ETAstats.remove(hash);
}
if(ETAs.contains(hash)) {
ETAs.remove(hash);
}
} else {
ETAs[hash] = moy;
}
} else {
// Speed is too low, we don't want an overflow.
if(ETAstats.contains(hash)) {

Loading…
Cancel
Save