summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'net-p2p')
-rw-r--r--net-p2p/bittorrent-stats/ChangeLog8
-rw-r--r--net-p2p/bittorrent-stats/Manifest26
-rw-r--r--net-p2p/bittorrent-stats/bittorrent-stats-3.2.1b-r4.ebuild9
-rw-r--r--net-p2p/bittorrent-stats/files/bittorrent-stats-3.2.1b.patch537
-rw-r--r--net-p2p/bittorrent-stats/files/digest-bittorrent-stats-3.2.1b-r45
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