diff options
| -rw-r--r-- | ot_stats.c | 25 | 
1 files changed, 19 insertions, 6 deletions
| @@ -320,7 +320,7 @@ typedef struct { | |||
| 320 | /* Fetches stats from tracker */ | 320 | /* Fetches stats from tracker */ | 
| 321 | size_t stats_top_txt(char *reply, int amount) { | 321 | size_t stats_top_txt(char *reply, int amount) { | 
| 322 | size_t j; | 322 | size_t j; | 
| 323 | ot_record top100s[100], top100c[100]; | 323 | ot_record top100s[100], top100c[100], top100l[100]; | 
| 324 | char *r = reply, hex_out[42]; | 324 | char *r = reply, hex_out[42]; | 
| 325 | int idx, bucket; | 325 | int idx, bucket; | 
| 326 | 326 | ||
| @@ -331,12 +331,13 @@ size_t stats_top_txt(char *reply, int amount) { | |||
| 331 | byte_zero(top100c, sizeof(top100c)); | 331 | byte_zero(top100c, sizeof(top100c)); | 
| 332 | 332 | ||
| 333 | for (bucket = 0; bucket < OT_BUCKET_COUNT; ++bucket) { | 333 | for (bucket = 0; bucket < OT_BUCKET_COUNT; ++bucket) { | 
| 334 | ot_vector *torrents_list = mutex_bucket_lock(bucket); | 334 | ot_vector *torrents_list = mutex_bucket_lock(bucket); | 
| 335 | for (j = 0; j < torrents_list->size; ++j) { | 335 | for (j = 0; j < torrents_list->size; ++j) { | 
| 336 | ot_torrent *torrent = (ot_torrent *)(torrents_list->data) + j; | 336 | ot_torrent *torrent = (ot_torrent *)(torrents_list->data) + j; | 
| 337 | size_t peer_count = torrent->peer_list6->peer_count + torrent->peer_list4->peer_count; | 337 | size_t peer_count = torrent->peer_list6->peer_count + torrent->peer_list4->peer_count; | 
| 338 | size_t seed_count = torrent->peer_list6->seed_count + torrent->peer_list4->seed_count; | 338 | size_t seed_count = torrent->peer_list6->seed_count + torrent->peer_list4->seed_count; | 
| 339 | idx = amount - 1; | 339 | size_t leech_count = peer_count - seed_count; | 
| 340 | idx = amount - 1; | ||
| 340 | while ((idx >= 0) && (peer_count > top100c[idx].val)) | 341 | while ((idx >= 0) && (peer_count > top100c[idx].val)) | 
| 341 | --idx; | 342 | --idx; | 
| 342 | if (idx++ != amount - 1) { | 343 | if (idx++ != amount - 1) { | 
| @@ -352,6 +353,14 @@ size_t stats_top_txt(char *reply, int amount) { | |||
| 352 | memcpy(&top100s[idx].hash, &torrent->hash, sizeof(ot_hash)); | 353 | memcpy(&top100s[idx].hash, &torrent->hash, sizeof(ot_hash)); | 
| 353 | top100s[idx].val = seed_count; | 354 | top100s[idx].val = seed_count; | 
| 354 | } | 355 | } | 
| 356 | idx = amount - 1; | ||
| 357 | while ((idx >= 0) && (leech_count > top100l[idx].val)) | ||
| 358 | --idx; | ||
| 359 | if (idx++ != amount - 1) { | ||
| 360 | memmove(top100l + idx + 1, top100l + idx, (amount - 1 - idx) * sizeof(ot_record)); | ||
| 361 | memcpy(&top100l[idx].hash, &torrent->hash, sizeof(ot_hash)); | ||
| 362 | top100l[idx].val = leech_count; | ||
| 363 | } | ||
| 355 | } | 364 | } | 
| 356 | mutex_bucket_unlock(bucket, 0); | 365 | mutex_bucket_unlock(bucket, 0); | 
| 357 | if (!g_opentracker_running) | 366 | if (!g_opentracker_running) | 
| @@ -366,6 +375,10 @@ size_t stats_top_txt(char *reply, int amount) { | |||
| 366 | for (idx = 0; idx < amount; ++idx) | 375 | for (idx = 0; idx < amount; ++idx) | 
| 367 | if (top100s[idx].val) | 376 | if (top100s[idx].val) | 
| 368 | r += sprintf(r, "\t%zd\t%s\n", top100s[idx].val, to_hex(hex_out, top100s[idx].hash)); | 377 | r += sprintf(r, "\t%zd\t%s\n", top100s[idx].val, to_hex(hex_out, top100s[idx].hash)); | 
| 378 | r += sprintf(r, "Top %d torrents by leechers:\n", amount); | ||
| 379 | for (idx = 0; idx < amount; ++idx) | ||
| 380 | if (top100l[idx].val) | ||
| 381 | r += sprintf(r, "\t%zd\t%s\n", top100l[idx].val, to_hex(hex_out, top100l[idx].hash)); | ||
| 369 | 382 | ||
| 370 | return r - reply; | 383 | return r - reply; | 
| 371 | } | 384 | } | 
