diff options
Diffstat (limited to 'net-p2p')
5 files changed, 29 insertions, 556 deletions
diff --git a/net-p2p/bittorrent-stats/ChangeLog b/net-p2p/bittorrent-stats/ChangeLog index 9d69997c19b8..33c282f29711 100644 --- a/net-p2p/bittorrent-stats/ChangeLog +++ b/net-p2p/bittorrent-stats/ChangeLog @@ -1,6 +1,10 @@ # ChangeLog for net-p2p/bittorrent-stats -# Copyright 2002-2005 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/net-p2p/bittorrent-stats/ChangeLog,v 1.8 2005/08/24 14:46:52 sekretarz Exp $ +# Copyright 2002-2006 Gentoo Foundation; Distributed under the GPL v2 +# $Header: /var/cvsroot/gentoo-x86/net-p2p/bittorrent-stats/ChangeLog,v 1.9 2006/02/22 10:58:09 lucass Exp $ + + 22 Feb 2006; Lukasz Strzygowski <lucass@gentoo.org> + -files/bittorrent-stats-3.2.1b.patch, bittorrent-stats-3.2.1b-r4.ebuild: + Moved patch to distfiles (bug #123634). 24 Aug 2005; <sekretarz@gentoo.org> bittorrent-stats-3.2.1b-r4.ebuild: Using -pPR instead -a option in cp, bug #103487 diff --git a/net-p2p/bittorrent-stats/Manifest b/net-p2p/bittorrent-stats/Manifest index 37bc4fd6b28c..187f5ffeea2f 100644 --- a/net-p2p/bittorrent-stats/Manifest +++ b/net-p2p/bittorrent-stats/Manifest @@ -1,15 +1,15 @@ ------BEGIN PGP SIGNED MESSAGE----- -Hash: SHA1 - MD5 374f08b6c7d82aed06c15d27063226f9 ChangeLog 3423 -MD5 71c4638c9c88af75b58e5f5cb54fe008 metadata.xml 159 -MD5 2d69d13949c52ce79bd18d9a55c8def7 bittorrent-stats-3.2.1b-r4.ebuild 1663 +RMD160 72f1636a0a6bbd697b4b59b4d992c23fcafe04a9 ChangeLog 3423 +SHA256 bc1db12a09cf0da12af0ee480559a0af5b5e777f0a3466173d7039c10544df26 ChangeLog 3423 +MD5 075d0650909e89a17be128dcf8c7741d bittorrent-stats-3.2.1b-r4.ebuild 1672 +RMD160 eb891010cf6f57e7c3c5fa2574646de1dcc4b8a7 bittorrent-stats-3.2.1b-r4.ebuild 1672 +SHA256 d233b9ef1e918129060803d8913abd5e4a417a8b19e3c32d0fc7333fe3459eda bittorrent-stats-3.2.1b-r4.ebuild 1672 MD5 dfb7c0c50cc6abc6efd5cf380f4615a0 files/bittorrent-stats-3.2.1b.patch 26140 -MD5 18e4d423bad1434f67f294f131f2e181 files/digest-bittorrent-stats-3.2.1b-r4 69 ------BEGIN PGP SIGNATURE----- -Version: GnuPG v1.4.1 (GNU/Linux) - -iD8DBQFDDKWoZ/iYVBmujdURAoPfAJ9om5VZzzKB0p82vg7mRxsCa2i0egCfcdTz -encdIjOfXD3cxBmH3lA5IA8= -=2f35 ------END PGP SIGNATURE----- +RMD160 94bef53377cb9da9e2a642f5db57d601374f8f15 files/bittorrent-stats-3.2.1b.patch 26140 +SHA256 b865ecfbf755b8db581e9defc5a7eb178f64a932b98dab2b17ac7b0f1492a6f8 files/bittorrent-stats-3.2.1b.patch 26140 +MD5 6317852f97105913505b4c14e0bd095f files/digest-bittorrent-stats-3.2.1b-r4 518 +RMD160 17a6c05871a5cb8bda3534e0fe882927c52bdd06 files/digest-bittorrent-stats-3.2.1b-r4 518 +SHA256 01c49bf5e4279477148fbff8f32e59978907b38568494b94699d97448ce31b20 files/digest-bittorrent-stats-3.2.1b-r4 518 +MD5 71c4638c9c88af75b58e5f5cb54fe008 metadata.xml 159 +RMD160 900a8c55d7a7d2f6312594769aaf941bf9e99c7f metadata.xml 159 +SHA256 9f01104d3484792496faff4805eed0ecea2352a897151f3397d49a13800037b4 metadata.xml 159 diff --git a/net-p2p/bittorrent-stats/bittorrent-stats-3.2.1b-r4.ebuild b/net-p2p/bittorrent-stats/bittorrent-stats-3.2.1b-r4.ebuild index d880b1cba054..947a1cd680d9 100644 --- a/net-p2p/bittorrent-stats/bittorrent-stats-3.2.1b-r4.ebuild +++ b/net-p2p/bittorrent-stats/bittorrent-stats-3.2.1b-r4.ebuild @@ -1,13 +1,14 @@ -# Copyright 1999-2005 Gentoo Foundation +# Copyright 1999-2006 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/net-p2p/bittorrent-stats/bittorrent-stats-3.2.1b-r4.ebuild,v 1.7 2005/08/24 14:46:52 sekretarz Exp $ +# $Header: /var/cvsroot/gentoo-x86/net-p2p/bittorrent-stats/bittorrent-stats-3.2.1b-r4.ebuild,v 1.8 2006/02/22 10:58:09 lucass Exp $ inherit distutils eutils MY_P="${P/bittorrent-stats/BitTorrent}" S=${WORKDIR}/${MY_P} DESCRIPTION="BitTorrent is a tool for distributing files via a distributed network of nodes" -SRC_URI="http://bitconjurer.org/BitTorrent/${MY_P}.tar.gz" +SRC_URI="http://bitconjurer.org/BitTorrent/${MY_P}.tar.gz + mirror://gentoo/${P}.patch" HOMEPAGE="http://bitconjurer.org/BitTorrent" SLOT="0" LICENSE="MIT" @@ -29,7 +30,7 @@ mydoc="FAQ.txt README.txt LICENSE.txt" src_unpack() { unpack ${A} cd ${S} - epatch ${FILESDIR}/bittorrent-stats-${PV}.patch || die "patch failed" + epatch ${DISTDIR}/${P}.patch || die "patch failed" } src_install() { diff --git a/net-p2p/bittorrent-stats/files/bittorrent-stats-3.2.1b.patch b/net-p2p/bittorrent-stats/files/bittorrent-stats-3.2.1b.patch deleted file mode 100644 index 70e28de10ecd..000000000000 --- a/net-p2p/bittorrent-stats/files/bittorrent-stats-3.2.1b.patch +++ /dev/null @@ -1,537 +0,0 @@ -diff -uNr BitTorrent-3.2.1b/BitTorrent/Downloader.py BitTorrent-3.2.1b-stats2/BitTorrent/Downloader.py ---- BitTorrent-3.2.1b/BitTorrent/Downloader.py 2002-12-24 05:39:23.000000000 -0500 -+++ BitTorrent-3.2.1b-stats2/BitTorrent/Downloader.py 2003-04-07 16:15:34.000000000 -0400 -@@ -9,6 +9,7 @@ - class SingleDownload: - def __init__(self, downloader, connection): - self.downloader = downloader -+ self.unhave = downloader.numpieces - self.connection = connection - self.choked = true - self.interested = false -@@ -119,9 +120,14 @@ - return - - def got_have(self, index): -+ if index == self.downloader.numpieces-1: -+ self.downloader.totalmeasure.update_rate(self.downloader.storage.total_length-(self.downloader.numpieces-1)*self.downloader.storage.piece_length) -+ else: -+ self.downloader.totalmeasure.update_rate(self.downloader.storage.piece_length) - if self.have[index]: - return - self.have[index] = true -+ self.unhave -= 1 - self.downloader.picker.got_have(index) - self._check_interest([index]) - self.download_more([index]) -@@ -130,6 +136,7 @@ - self.have = have - for i in xrange(len(have)): - if have[i]: -+ self.unhave -= 1 - self.downloader.picker.got_have(i) - self._check_interest([i for i in xrange(len(have)) if have[i]]) - self.download_more() -@@ -148,9 +155,11 @@ - self.backlog = backlog - self.max_rate_period = max_rate_period - self.downmeasure = downmeasure -+ self.totalmeasure = Measure(max_rate_period*storage.piece_length/storage.request_size) - self.numpieces = numpieces - self.snub_time = snub_time - self.measurefunc = measurefunc -+ self.disconnectedseeds = {} - self.downloads = [] - - def make_download(self, connection): -diff -uNr BitTorrent-3.2.1b/BitTorrent/DownloaderFeedback.py BitTorrent-3.2.1b-stats2/BitTorrent/DownloaderFeedback.py ---- BitTorrent-3.2.1b/BitTorrent/DownloaderFeedback.py 2003-03-25 03:32:18.000000000 -0500 -+++ BitTorrent-3.2.1b-stats2/BitTorrent/DownloaderFeedback.py 2003-03-31 18:11:15.000000000 -0500 -@@ -6,7 +6,8 @@ - - class DownloaderFeedback: - def __init__(self, choker, add_task, statusfunc, upfunc, downfunc, -- remainingfunc, leftfunc, file_length, finflag, interval, sp): -+ remainingfunc, leftfunc, file_length, finflag, interval, sp, -+ statistics): - self.choker = choker - self.add_task = add_task - self.statusfunc = statusfunc -@@ -18,6 +19,7 @@ - self.finflag = finflag - self.interval = interval - self.sp = sp -+ self.statistics = statistics - self.lastids = [] - self.display() - -@@ -73,10 +75,12 @@ - - def display(self): - self.add_task(self.display, self.interval) -+ self.statistics.update() - if self.sp: - self.spew() - if self.finflag.isSet(): -- self.statusfunc(upRate = self.upfunc()) -+ self.statusfunc(upRate = self.upfunc(), -+ statistics = self.statistics) - return - timeEst = self.remainingfunc() - -@@ -84,7 +88,9 @@ - - if timeEst is not None: - self.statusfunc(timeEst = timeEst, fractionDone = fractionDone, -- downRate = self.downfunc(), upRate = self.upfunc()) -+ downRate = self.downfunc(), upRate = self.upfunc(), -+ statistics = self.statistics) - else: - self.statusfunc(fractionDone = fractionDone, -- downRate = self.downfunc(), upRate = self.upfunc()) -+ downRate = self.downfunc(), upRate = self.upfunc(), -+ statistics = self.statistics) -diff -uNr BitTorrent-3.2.1b/BitTorrent/EndgameDownloader.py BitTorrent-3.2.1b-stats2/BitTorrent/EndgameDownloader.py ---- BitTorrent-3.2.1b/BitTorrent/EndgameDownloader.py 2002-12-27 05:06:55.000000000 -0500 -+++ BitTorrent-3.2.1b-stats2/BitTorrent/EndgameDownloader.py 2003-04-07 16:02:24.000000000 -0400 -@@ -40,6 +40,9 @@ - - def disconnected(self): - self.downloader.downloads.remove(self) -+ for i in xrange(len(self.have)): -+ if self.have[i]: -+ self.downloader.picker.lost_have(i) - - def got_choke(self): - self.choked = true -@@ -111,14 +114,20 @@ - if self.downloader.requests == []: - for d in copy(self.downloader.downloads): - if d.unhave == 0: -+ self.downloader.disconnectedseeds[d.connection.connection.id]=time() - d.connection.close() - return true - - def got_have(self, index): -+ if index == self.downloader.numpieces-1: -+ self.downloader.totalmeasure.update_rate(self.downloader.storage.total_length-(self.downloader.numpieces-1)*self.downloader.storage.piece_length) -+ else: -+ self.downloader.totalmeasure.update_rate(self.downloader.storage.piece_length) - if self.have[index]: - return - self.have[index] = true - self.unhave -= 1 -+ self.downloader.picker.got_have(index) - if self.downloader.storage.do_I_have(index): - return - shuffle(self.downloader.requests) -@@ -126,18 +135,23 @@ - if i == index: - self.send_request(i, begin, length) - if self.downloader.requests == [] and self.unhave == 0: -+ self.downloader.disconnectedseeds[self.connection.connection.id]=time() - self.connection.close() - - def got_have_bitfield(self, have): - self.have = have -+ i=0 - for h in self.have: - if h: - self.unhave -= 1 -+ self.downloader.picker.got_have(i) -+ i+=1 - shuffle(self.downloader.requests) - for i, begin, length in self.downloader.requests: - if self.have[i]: - self.send_request(i, begin, length) - if self.downloader.requests == [] and self.unhave == 0: -+ self.downloader.disconnectedseeds[self.connection.connection.id]=time() - self.connection.close() - - class EndgameDownloader: -@@ -147,9 +161,12 @@ - self.max_rate_period = old.max_rate_period - self.numpieces = old.numpieces - self.downmeasure = old.downmeasure -+ self.totalmeasure = old.totalmeasure - self.measurefunc = old.measurefunc -+ self.picker = old.picker - self.snub_time = old.snub_time - self.requests = [] -+ self.disconnectedseeds = old.disconnectedseeds - for d in old.downloads: - self.requests.extend(d.active_requests) - self.downloads = [] -diff -uNr BitTorrent-3.2.1b/BitTorrent/PiecePicker.py BitTorrent-3.2.1b-stats2/BitTorrent/PiecePicker.py ---- BitTorrent-3.2.1b/BitTorrent/PiecePicker.py 2003-02-02 00:47:20.000000000 -0500 -+++ BitTorrent-3.2.1b-stats2/BitTorrent/PiecePicker.py 2003-03-31 21:51:13.000000000 -0500 -@@ -61,6 +61,9 @@ - self.numinterests = [0] * numpieces - self.interestpos = range(numpieces) - self.fixed = [] -+ self.totalcount = 0 -+ self.numhaves = [0] * numpieces -+ self.crosscount = [numpieces] - self.got_any = false - - # this is a total hack to support python2.1 but supports for ... in -@@ -73,6 +76,12 @@ - raise IndexError - - def got_have(self, i): -+ self.totalcount+=1 -+ self.crosscount[self.numhaves[i]]-=1 -+ self.numhaves[i]+=1 -+ if self.numhaves[i]==len(self.crosscount): -+ self.crosscount.append(0) -+ self.crosscount[self.numhaves[i]]+=1 - if self.numinterests[i] is None: - return - interests = self.interests[self.numinterests[i]] -@@ -89,6 +98,10 @@ - interests.append(i) - - def lost_have(self, i): -+ self.totalcount-=1 -+ self.crosscount[self.numhaves[i]]-=1 -+ self.numhaves[i]-=1 -+ self.crosscount[self.numhaves[i]]+=1 - if self.numinterests[i] is None: - return - interests = self.interests[self.numinterests[i]] -diff -uNr BitTorrent-3.2.1b/BitTorrent/Statistics.py BitTorrent-3.2.1b-stats2/BitTorrent/Statistics.py ---- BitTorrent-3.2.1b/BitTorrent/Statistics.py 1969-12-31 19:00:00.000000000 -0500 -+++ BitTorrent-3.2.1b-stats2/BitTorrent/Statistics.py 2003-04-07 20:50:53.000000000 -0400 -@@ -0,0 +1,59 @@ -+# Written by Edward Keyes -+# see LICENSE.txt for license information -+ -+from time import time -+from copy import copy -+ -+class Statistics: -+ def __init__(self, upmeasure, downmeasure, connecter): -+ self.upmeasure = upmeasure -+ self.downmeasure = downmeasure -+ self.connecter = connecter -+ self.downloader = connecter.downloader -+ self.picker = connecter.downloader.picker -+ self.torrentmeasure = connecter.downloader.totalmeasure -+ self.upTotal = 0.0 -+ self.downTotal = 0.0 -+ self.shareRating = 0.0 -+ self.numSeeds = 0 -+ self.numOldSeeds = 0 -+ self.numPeers = 0 -+ -+ def update(self): -+ self.upTotal = self.upmeasure.get_total() -+ self.downTotal = self.downmeasure.get_total() -+ if self.downTotal > 0: -+ self.shareRating = float(self.upTotal)/self.downTotal -+ else: -+ if self.upTotal == 0: -+ self.shareRating = 0.0 -+ else: -+ self.shareRating = -1.0 -+ self.downloader = self.connecter.downloader -+ self.picker = self.downloader.picker -+ self.torrentmeasure = self.downloader.totalmeasure -+ self.torrentRate = self.torrentmeasure.get_rate() -+ self.torrentTotal = self.torrentmeasure.get_total() -+ self.numSeeds = 0 -+ for download in self.downloader.downloads: -+ if download.unhave == 0: -+ self.numSeeds+=1 -+ for id in copy(self.downloader.disconnectedseeds.keys()): -+ if time()-self.downloader.disconnectedseeds[id]>3600: -+ #Expire old seeds after 1 hour from last connection -+ del self.downloader.disconnectedseeds[id] -+ self.numOldSeeds = len(self.downloader.disconnectedseeds) -+ self.numPeers = len(self.downloader.downloads)-self.numSeeds -+ self.numCopies = -self.numSeeds -+ for i in range(len(self.picker.crosscount)): -+ if self.picker.crosscount[i]==0: -+ self.numCopies+=1 -+ else: -+ self.numCopies+=1-float(self.picker.crosscount[i])/self.picker.numpieces -+ break -+ if self.numPeers==0: -+ self.percentDone = 0.0 -+ else: -+ self.percentDone = 100.0*(float(self.picker.totalcount)/self.picker.numpieces-self.numSeeds)/self.numPeers -+ -+ -diff -uNr BitTorrent-3.2.1b/BitTorrent/download.py BitTorrent-3.2.1b-stats2/BitTorrent/download.py ---- BitTorrent-3.2.1b/BitTorrent/download.py 2003-03-29 16:01:40.000000000 -0500 -+++ BitTorrent-3.2.1b-stats2/BitTorrent/download.py 2003-03-31 18:40:39.000000000 -0500 -@@ -18,6 +18,7 @@ - from CurrentRateMeasure import Measure - from EndgameDownloader import EndgameDownloader - from PiecePicker import PiecePicker -+from Statistics import Statistics - from bencode import bencode, bdecode - from sha import sha - from os import getpid, path, makedirs -@@ -253,10 +254,11 @@ - upmeasure.get_total, downmeasure.get_total, listen_port, - config['ip'], myid, infohash, config['http_timeout'], errorfunc, - config['max_initiate'], doneflag) -+ statistics = Statistics(upmeasure,downmeasure,connecter) - DownloaderFeedback(choker, rawserver.add_task, statusfunc, - upmeasure.get_rate, downmeasure.get_rate, ratemeasure.get_time_left, - ratemeasure.get_size_left, file_length, finflag, -- config['display_interval'], config['spew']) -+ config['display_interval'], config['spew'], statistics) - - statusfunc(activity = 'connecting to peers') - ann[0] = rerequest.announce -diff -uNr BitTorrent-3.2.1b/BitTorrent/track.py BitTorrent-3.2.1b-stats2/BitTorrent/track.py ---- BitTorrent-3.2.1b/BitTorrent/track.py 2003-03-27 21:10:45.000000000 -0500 -+++ BitTorrent-3.2.1b-stats2/BitTorrent/track.py 2003-04-07 16:18:05.000000000 -0400 -@@ -142,22 +142,24 @@ - names.sort() - if self.allowed != None and self.show_names: - s.write('<table summary="files" border=1>\n' \ -- '<tr><th>info hash</th><th>torrent name</th><th align="right">complete</th><th align="right">downloading</th></tr>\n') -+ '<tr><th>info hash</th><th>torrent name</th><th align="right">complete<BR>(real / NAT)</th><th align="right">downloading<BR>(real / NAT)</th></tr>\n') - else: - s.write('<table summary="files">\n' \ -- '<tr><th>info hash</th><th align="right">complete</th><th align="right">downloading</th></tr>\n') -+ '<tr><th>info hash</th><th align="right">complete<BR>(real / NAT)</th><th align="right">downloading<BR>(real / NAT)</th></tr>\n') - for name in names: - l = self.downloads[name] -- c = len([1 for i in l.values() if i['left'] == 0]) -- d = len(l) - c -+ creal = len([1 for i in l.values() if (i['left'] == 0 and not i.get('nat'))]) -+ cnat = len([1 for i in l.values() if (i['left'] == 0 and i.get('nat'))] ) -+ dreal = len([1 for i in l.values() if (i['left'] > 0 and not i.get('nat'))]) -+ dnat = len([1 for i in l.values() if (i['left'] > 0 and i.get('nat'))] ) - if self.allowed != None and self.show_names: - if self.allowed.has_key(name): -- s.write('<tr><td><code>%s</code></td><td><code>%s</code></td><td align="right"><code>%i</code></td><td align="right"><code>%i</code></td></tr>\n' \ -- % (b2a_hex(name), self.allowed[name], c, d)) -+ s.write('<tr><td><code>%s</code></td><td><code>%s</code></td><td align="right"><code>%i / %i</code></td><td align="right"><code>%i / %i</code></td></tr>\n' \ -+ % (b2a_hex(name), self.allowed[name], creal, cnat, dreal, dnat)) - - else: -- s.write('<tr><td><code>%s</code></td><td align="right"><code>%i</code></td><td align="right"><code>%i</code></td></tr>\n' \ -- % (b2a_hex(name), c, d)) -+ s.write('<tr><td><code>%s</code></td><td align="right"><code>%i / %i</code></td><td align="right"><code>%i / %i</code></td></tr>\n' \ -+ % (b2a_hex(name), creal, cnat, dreal, dnat)) - s.write('</table>\n' \ - '<ul>\n' \ - '<li><em>info hash:</em> SHA1 hash of the "info" section of the metainfo (*.torrent)</li>\n' \ -diff -uNr BitTorrent-3.2.1b/btdownloadcurses.py BitTorrent-3.2.1b-stats2/btdownloadcurses.py ---- BitTorrent-3.2.1b/btdownloadcurses.py 2003-03-28 00:14:08.000000000 -0500 -+++ BitTorrent-3.2.1b-stats2/btdownloadcurses.py 2003-04-07 15:57:37.000000000 -0400 -@@ -68,6 +68,9 @@ - self.downloadTo = '' - self.downRate = '---' - self.upRate = '---' -+ self.shareRating = '' -+ self.seedStatus = '' -+ self.peerStatus = '' - self.errors = [] - self.globalerrlist = mainerrlist - -@@ -89,7 +92,8 @@ - self.display() - - def display(self, fractionDone = None, timeEst = None, -- downRate = None, upRate = None, activity = None): -+ downRate = None, upRate = None, activity = None, -+ statistics = None): - if activity is not None and not self.done: - self.activity = activity - elif timeEst is not None: -@@ -104,6 +108,16 @@ - self.downRate = '%.1f KB/s' % (float(downRate) / (1 << 10)) - if upRate is not None: - self.upRate = '%.1f KB/s' % (float(upRate) / (1 << 10)) -+ if statistics is not None: -+ if (statistics.shareRating < 0) or (statistics.shareRating > 100): -+ self.shareRating = 'oo (%.1f MB up / %.1f MB down)' % (float(statistics.upTotal) / (1<<20), float(statistics.downTotal) / (1<<20)) -+ else: -+ self.shareRating = '%.3f (%.1f MB up / %.1f MB down)' % (statistics.shareRating, float(statistics.upTotal) / (1<<20), float(statistics.downTotal) / (1<<20)) -+ if not self.done: -+ self.seedStatus = '%d seen now, plus %.3f distributed copies' % (statistics.numSeeds,0.001*int(1000*statistics.numCopies)) -+ else: -+ self.seedStatus = '%d seen recently, plus %.3f distributed copies' % (statistics.numOldSeeds,0.001*int(1000*statistics.numCopies)) -+ self.peerStatus = '%d seen now, %.1f%% done at %.1f kB/s' % (statistics.numPeers,statistics.percentDone,float(statistics.torrentRate) / (1 << 10)) - - fieldwin.erase() - fieldwin.addnstr(0, 0, self.file, fieldw, curses.A_BOLD) -@@ -114,12 +128,15 @@ - fieldwin.addnstr(4, 0, self.status, fieldw) - fieldwin.addnstr(5, 0, self.downRate, fieldw) - fieldwin.addnstr(6, 0, self.upRate, fieldw) -+ fieldwin.addnstr(7, 0, self.shareRating, fieldw) -+ fieldwin.addnstr(8, 0, self.seedStatus, fieldw) -+ fieldwin.addnstr(9, 0, self.peerStatus, fieldw) - - if self.errors: - for i in range(len(self.errors)): -- fieldwin.addnstr(7 + i, 0, self.errors[i], fieldw, curses.A_BOLD) -+ fieldwin.addnstr(10 + i, 0, self.errors[i], fieldw, curses.A_BOLD) - else: -- fieldwin.move(7, 0) -+ fieldwin.move(10, 0) - - curses.panel.update_panels() - curses.doupdate() -@@ -151,7 +168,10 @@ - labelwin.addstr(4, 0, 'status:') - labelwin.addstr(5, 0, 'dl speed:') - labelwin.addstr(6, 0, 'ul speed:') -- labelwin.addstr(7, 0, 'error(s):') -+ labelwin.addstr(7, 0, 'sharing:') -+ labelwin.addstr(8, 0, 'seeds:') -+ labelwin.addstr(9, 0, 'peers:') -+ labelwin.addstr(10, 0, 'error(s):') - curses.panel.update_panels() - curses.doupdate() - -@@ -197,4 +217,3 @@ - print "These errors occurred during execution:" - for error in mainerrlist: - print error -- -diff -uNr BitTorrent-3.2.1b/btdownloadgui.py BitTorrent-3.2.1b-stats2/btdownloadgui.py ---- BitTorrent-3.2.1b/btdownloadgui.py 2003-03-27 23:35:58.000000000 -0500 -+++ BitTorrent-3.2.1b-stats2/btdownloadgui.py 2003-04-07 17:11:34.000000000 -0400 -@@ -83,6 +83,19 @@ - gridSizer.Add(wxStaticText(panel, -1, 'Upload rate:')) - self.upRateText = wxStaticText(panel, -1, '') - gridSizer.Add(self.upRateText, 0, wxEXPAND) -+ -+ gridSizer.Add(wxStaticText(panel, -1, 'Share rating:')) -+ self.shareRatingText = wxStaticText(panel, -1, '') -+ gridSizer.Add(self.shareRatingText, 0, wxEXPAND) -+ -+ gridSizer.Add(wxStaticText(panel, -1, 'Seed status:')) -+ self.seedStatusText = wxStaticText(panel, -1, '') -+ gridSizer.Add(self.seedStatusText, 0, wxEXPAND) -+ -+ gridSizer.Add(wxStaticText(panel, -1, 'Peer status:')) -+ self.peerStatusText = wxStaticText(panel, -1, '') -+ gridSizer.Add(self.peerStatusText, 0, wxEXPAND) -+ - gridSizer.AddGrowableCol(1) - - colSizer.Add(gridSizer, 0, wxEXPAND) -@@ -122,10 +135,10 @@ - - def updateStatus(self, fractionDone = None, - timeEst = None, downRate = None, upRate = None, -- activity=None): -- self.invokeLater(self.onUpdateStatus, [fractionDone, timeEst, downRate, upRate, activity]) -+ activity = None, statistics = None): -+ self.invokeLater(self.onUpdateStatus, [fractionDone, timeEst, downRate, upRate, activity, statistics]) - -- def onUpdateStatus(self, fractionDone, timeEst, downRate, upRate, activity): -+ def onUpdateStatus(self, fractionDone, timeEst, downRate, upRate, activity, statistics): - if fractionDone is not None and not self.fin: - self.gauge.SetValue(int(fractionDone * 1000)) - self.frame.SetTitle('%d%% %s - BitTorrent %s' % (int(fractionDone*100), self.filename, version)) -@@ -134,9 +147,19 @@ - if activity is not None and not self.fin: - self.timeEstText.SetLabel(activity) - if downRate is not None: -- self.downRateText.SetLabel('%.0f kB/s' % (float(downRate) / (1 << 10))) -+ self.downRateText.SetLabel('%.1f kB/s' % (float(downRate) / (1 << 10))) - if upRate is not None: -- self.upRateText.SetLabel('%.0f kB/s' % (float(upRate) / (1 << 10))) -+ self.upRateText.SetLabel('%.1f kB/s' % (float(upRate) / (1 << 10))) -+ if statistics is not None: -+ if (statistics.shareRating < 0) or (statistics.shareRating > 100): -+ self.shareRatingText.SetLabel('oo (%.1f MB up / %.1f MB down)' % (float(statistics.upTotal) / (1<<20), float(statistics.downTotal) / (1<<20))) -+ else: -+ self.shareRatingText.SetLabel('%.3f (%.1f MB up / %.1f MB down)' % (statistics.shareRating, float(statistics.upTotal) / (1<<20), float(statistics.downTotal) / (1<<20))) -+ if not self.fin: -+ self.seedStatusText.SetLabel('%d seen now, plus %.3f distributed copies' % (statistics.numSeeds,0.001*int(1000*statistics.numCopies))) -+ else: -+ self.seedStatusText.SetLabel('%d seen recently, plus %.3f distributed copies' % (statistics.numOldSeeds,0.001*int(1000*statistics.numCopies))) -+ self.peerStatusText.SetLabel('%d seen now, %.1f%% done at %.1f kB/s' % (statistics.numPeers,statistics.percentDone,float(statistics.torrentRate) / (1 << 10))) - - def finished(self): - self.fin = true -diff -uNr BitTorrent-3.2.1b/btdownloadheadless.py BitTorrent-3.2.1b-stats2/btdownloadheadless.py ---- BitTorrent-3.2.1b/btdownloadheadless.py 2003-03-17 14:26:39.000000000 -0500 -+++ BitTorrent-3.2.1b-stats2/btdownloadheadless.py 2003-04-07 15:55:35.000000000 -0400 -@@ -35,6 +35,9 @@ - self.downloadTo = '' - self.downRate = '' - self.upRate = '' -+ self.shareRating = '' -+ self.seedStatus = '' -+ self.peerStatus = '' - self.errors = [] - - def finished(self): -@@ -56,7 +59,8 @@ - self.display() - - def display(self, fractionDone = None, timeEst = None, -- downRate = None, upRate = None, activity = None): -+ downRate = None, upRate = None, activity = None, -+ statistics = None): - if fractionDone is not None: - self.percentDone = str(float(int(fractionDone * 1000)) / 10) - if timeEst is not None: -@@ -64,9 +68,19 @@ - if activity is not None and not self.done: - self.timeEst = activity - if downRate is not None: -- self.downRate = '%.0f kB/s' % (float(downRate) / (1 << 10)) -+ self.downRate = '%.1f kB/s' % (float(downRate) / (1 << 10)) - if upRate is not None: -- self.upRate = '%.0f kB/s' % (float(upRate) / (1 << 10)) -+ self.upRate = '%.1f kB/s' % (float(upRate) / (1 << 10)) -+ if statistics is not None: -+ if (statistics.shareRating < 0) or (statistics.shareRating > 100): -+ self.shareRating = 'oo (%.1f MB up / %.1f MB down)' % (float(statistics.upTotal) / (1<<20), float(statistics.downTotal) / (1<<20)) -+ else: -+ self.shareRating = '%.3f (%.1f MB up / %.1f MB down)' % (statistics.shareRating, float(statistics.upTotal) / (1<<20), float(statistics.downTotal) / (1<<20)) -+ if not self.done: -+ self.seedStatus = '%d seen now, plus %.3f distributed copies' % (statistics.numSeeds,0.001*int(1000*statistics.numCopies)) -+ else: -+ self.seedStatus = '%d seen recently, plus %.3f distributed copies' % (statistics.numOldSeeds,0.001*int(1000*statistics.numCopies)) -+ self.peerStatus = '%d seen now, %.1f%% done at %.1f kB/s' % (statistics.numPeers,statistics.percentDone,float(statistics.torrentRate) / (1 << 10)) - print '\n\n\n\n' - for err in self.errors: - print 'ERROR:\n' + err + '\n' -@@ -76,6 +90,9 @@ - print 'download to: ', self.downloadTo - print 'download rate: ', self.downRate - print 'upload rate: ', self.upRate -+ print 'share rating: ', self.shareRating -+ print 'seed status: ', self.seedStatus -+ print 'peer status: ', self.peerStatus - stdout.flush() - - def chooseFile(self, default, size, saveas, dir): -diff -uNr BitTorrent-3.2.1b/btlaunchmany.py BitTorrent-3.2.1b-stats2/btlaunchmany.py ---- BitTorrent-3.2.1b/btlaunchmany.py 2003-03-27 20:05:57.000000000 -0500 -+++ BitTorrent-3.2.1b-stats2/btlaunchmany.py 2003-04-01 10:33:35.000000000 -0500 -@@ -92,7 +92,7 @@ - - def status(self, fractionDone = None, - timeEst = None, downRate = None, upRate = None, -- activity = None): -+ activity = None, statistics = None): - if fractionDone is not None: - newpercent = int(fractionDone*100) - if newpercent != self.percentDone: -diff -uNr BitTorrent-3.2.1b/btlaunchmanycurses.py BitTorrent-3.2.1b-stats2/btlaunchmanycurses.py ---- BitTorrent-3.2.1b/btlaunchmanycurses.py 2003-03-28 00:14:08.000000000 -0500 -+++ BitTorrent-3.2.1b-stats2/btlaunchmanycurses.py 2003-04-01 10:33:58.000000000 -0500 -@@ -213,7 +213,7 @@ - self.localfile = abspath(saveas) - return saveas - -- def display(self, fractionDone = None, timeEst = None, downRate = None, upRate = None, activity = None): -+ def display(self, fractionDone = None, timeEst = None, downRate = None, upRate = None, activity = None, statistics = None): - if self.basex != wininfo[self.myname]['basex']: - # leave nothing but blank space - mainwin.addnstr(self.basex, 0, ' ' * 1000, mainwinw) diff --git a/net-p2p/bittorrent-stats/files/digest-bittorrent-stats-3.2.1b-r4 b/net-p2p/bittorrent-stats/files/digest-bittorrent-stats-3.2.1b-r4 index cfa354976ae9..155c4399c735 100644 --- a/net-p2p/bittorrent-stats/files/digest-bittorrent-stats-3.2.1b-r4 +++ b/net-p2p/bittorrent-stats/files/digest-bittorrent-stats-3.2.1b-r4 @@ -1 +1,6 @@ MD5 9e0cc346a4bfa3904380ed119d8bac90 BitTorrent-3.2.1b.tar.gz 144420 +RMD160 ca17ef25ae96d44867c4e6edccca661826299ae5 BitTorrent-3.2.1b.tar.gz 144420 +SHA256 25aa9f35743ce8895fc66c762bac21a56b0ccb7efe1934e0a698096346c6f870 BitTorrent-3.2.1b.tar.gz 144420 +MD5 dfb7c0c50cc6abc6efd5cf380f4615a0 bittorrent-stats-3.2.1b.patch 26140 +RMD160 94bef53377cb9da9e2a642f5db57d601374f8f15 bittorrent-stats-3.2.1b.patch 26140 +SHA256 b865ecfbf755b8db581e9defc5a7eb178f64a932b98dab2b17ac7b0f1492a6f8 bittorrent-stats-3.2.1b.patch 26140 |