* Properly encapsulate the mmap/span stuff. * Finish balancing socketsPerTorrent and half-open, handshakes and worst conns. * Use big.Int, and it's Xor(), and SetBytes() functions for DHT node ID distances. * Add a coarse-responsive download strategy, that prioritizes pieces instead of chunks. * Track upload and download data. * Remove non-deterministic stuff from unit tests, like the tracker UDP and fuse fs stuff. * Expose a public Torrent type bound to a given client or similar to work with common per-torrent operations. * Split scraping and announcing on DHT into separate routines. * Ping nodes that stop being good. * Merge duplicate magnet data.