亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? piecepicker.py

?? 一個多點下載且源碼公開的P2P軟件
?? PY
字號:
# Written by Bram Cohen# see LICENSE.txt for license informationfrom random import randrange, shufflefrom BitTornado.clock import clocktry:    Trueexcept:    True = 1    False = 0class PiecePicker:    def __init__(self, numpieces,                 rarest_first_cutoff = 1, rarest_first_priority_cutoff = 3,                 priority_step = 20):        self.rarest_first_cutoff = rarest_first_cutoff        self.rarest_first_priority_cutoff = rarest_first_priority_cutoff + priority_step        self.priority_step = priority_step        self.cutoff = rarest_first_priority_cutoff        self.numpieces = numpieces        self.started = []        self.totalcount = 0        self.numhaves = [0] * numpieces        self.priority = [1] * numpieces        self.removed_partials = {}        self.crosscount = [numpieces]        self.crosscount2 = [numpieces]        self.has = [0] * numpieces        self.numgot = 0        self.done = False        self.seed_connections = {}        self.past_ips = {}        self.seed_time = None        self.superseed = False        self.seeds_connected = 0        self._init_interests()    def _init_interests(self):        self.interests = [[] for x in xrange(self.priority_step)]        self.level_in_interests = [self.priority_step] * self.numpieces        interests = range(self.numpieces)        shuffle(interests)        self.pos_in_interests = [0] * self.numpieces        for i in xrange(self.numpieces):            self.pos_in_interests[interests[i]] = i        self.interests.append(interests)    def got_have(self, piece):        self.totalcount+=1        numint = self.numhaves[piece]        self.numhaves[piece] += 1        self.crosscount[numint] -= 1        if numint+1==len(self.crosscount):            self.crosscount.append(0)        self.crosscount[numint+1] += 1        if not self.done:            numintplus = numint+self.has[piece]            self.crosscount2[numintplus] -= 1            if numintplus+1 == len(self.crosscount2):                self.crosscount2.append(0)            self.crosscount2[numintplus+1] += 1            numint = self.level_in_interests[piece]            self.level_in_interests[piece] += 1        if self.superseed:            self.seed_got_haves[piece] += 1            numint = self.level_in_interests[piece]            self.level_in_interests[piece] += 1        elif self.has[piece] or self.priority[piece] == -1:            return        if numint == len(self.interests) - 1:            self.interests.append([])        self._shift_over(piece, self.interests[numint], self.interests[numint + 1])    def lost_have(self, piece):        self.totalcount-=1        numint = self.numhaves[piece]        self.numhaves[piece] -= 1        self.crosscount[numint] -= 1        self.crosscount[numint-1] += 1        if not self.done:            numintplus = numint+self.has[piece]            self.crosscount2[numintplus] -= 1            self.crosscount2[numintplus-1] += 1            numint = self.level_in_interests[piece]            self.level_in_interests[piece] -= 1        if self.superseed:            numint = self.level_in_interests[piece]            self.level_in_interests[piece] -= 1        elif self.has[piece] or self.priority[piece] == -1:            return        self._shift_over(piece, self.interests[numint], self.interests[numint - 1])    def _shift_over(self, piece, l1, l2):        assert self.superseed or (not self.has[piece] and self.priority[piece] >= 0)        parray = self.pos_in_interests        p = parray[piece]        assert l1[p] == piece        q = l1[-1]        l1[p] = q        parray[q] = p        del l1[-1]        newp = randrange(len(l2)+1)        if newp == len(l2):            parray[piece] = len(l2)            l2.append(piece)        else:            old = l2[newp]            parray[old] = len(l2)            l2.append(old)            l2[newp] = piece            parray[piece] = newp    def got_seed(self):        self.seeds_connected += 1        self.cutoff = max(self.rarest_first_priority_cutoff-self.seeds_connected,0)    def became_seed(self):        self.got_seed()        self.totalcount -= self.numpieces        self.numhaves = [i-1 for i in self.numhaves]        if self.superseed or not self.done:            self.level_in_interests = [i-1 for i in self.level_in_interests]            if self.interests:                del self.interests[0]        del self.crosscount[0]        if not self.done:            del self.crosscount2[0]    def lost_seed(self):        self.seeds_connected -= 1        self.cutoff = max(self.rarest_first_priority_cutoff-self.seeds_connected,0)    def requested(self, piece):        if piece not in self.started:            self.started.append(piece)    def _remove_from_interests(self, piece, keep_partial = False):        l = self.interests[self.level_in_interests[piece]]        p = self.pos_in_interests[piece]        assert l[p] == piece        q = l[-1]        l[p] = q        self.pos_in_interests[q] = p        del l[-1]        try:            self.started.remove(piece)            if keep_partial:                self.removed_partials[piece] = 1        except ValueError:            pass    def complete(self, piece):        assert not self.has[piece]        self.has[piece] = 1        self.numgot += 1        if self.numgot == self.numpieces:            self.done = True            self.crosscount2 = self.crosscount        else:            numhaves = self.numhaves[piece]            self.crosscount2[numhaves] -= 1            if numhaves+1 == len(self.crosscount2):                self.crosscount2.append(0)            self.crosscount2[numhaves+1] += 1        self._remove_from_interests(piece)    def next(self, haves, wantfunc, complete_first = False):        cutoff = self.numgot < self.rarest_first_cutoff        complete_first = (complete_first or cutoff) and not haves.complete()        best = None        bestnum = 2 ** 30        for i in self.started:            if haves[i] and wantfunc(i):                if self.level_in_interests[i] < bestnum:                    best = i                    bestnum = self.level_in_interests[i]        if best is not None:            if complete_first or (cutoff and len(self.interests) > self.cutoff):                return best        if haves.complete():            r = [ (0, min(bestnum,len(self.interests))) ]        elif cutoff and len(self.interests) > self.cutoff:            r = [ (self.cutoff, min(bestnum,len(self.interests))),                      (0, self.cutoff) ]        else:            r = [ (0, min(bestnum,len(self.interests))) ]        for lo,hi in r:            for i in xrange(lo,hi):                for j in self.interests[i]:                    if haves[j] and wantfunc(j):                        return j        if best is not None:            return best        return None    def am_I_complete(self):        return self.done        def bump(self, piece):        l = self.interests[self.level_in_interests[piece]]        pos = self.pos_in_interests[piece]        del l[pos]        l.append(piece)        for i in range(pos,len(l)):            self.pos_in_interests[l[i]] = i        try:            self.started.remove(piece)        except:            pass    def set_priority(self, piece, p):        if self.superseed:            return False    # don't muck with this if you're a superseed        oldp = self.priority[piece]        if oldp == p:            return False        self.priority[piece] = p        if p == -1:            # when setting priority -1,            # make sure to cancel any downloads for this piece            if not self.has[piece]:                self._remove_from_interests(piece, True)            return True        if oldp == -1:            level = self.numhaves[piece] + (self.priority_step * p)            self.level_in_interests[piece] = level            if self.has[piece]:                return True            while len(self.interests) < level+1:                self.interests.append([])            l2 = self.interests[level]            parray = self.pos_in_interests            newp = randrange(len(l2)+1)            if newp == len(l2):                parray[piece] = len(l2)                l2.append(piece)            else:                old = l2[newp]                parray[old] = len(l2)                l2.append(old)                l2[newp] = piece                parray[piece] = newp            if self.removed_partials.has_key(piece):                del self.removed_partials[piece]                self.started.append(piece)            # now go to downloader and try requesting more            return True        numint = self.level_in_interests[piece]        newint = numint + ((p - oldp) * self.priority_step)        self.level_in_interests[piece] = newint        if self.has[piece]:            return False        while len(self.interests) < newint+1:            self.interests.append([])        self._shift_over(piece, self.interests[numint], self.interests[newint])        return False    def is_blocked(self, piece):        return self.priority[piece] < 0    def set_superseed(self):        assert self.done        self.superseed = True        self.seed_got_haves = [0] * self.numpieces        self._init_interests()  # assume everyone is disconnected    def next_have(self, connection, looser_upload):        if self.seed_time is None:            self.seed_time = clock()            return None        if clock() < self.seed_time+10:  # wait 10 seconds after seeing the first peers            return None                 # to give time to grab have lists        if not connection.upload.super_seeding:            return None        olddl = self.seed_connections.get(connection)        if olddl is None:            ip = connection.get_ip()            olddl = self.past_ips.get(ip)            if olddl is not None:                           # peer reconnected                self.seed_connections[connection] = olddl                if not looser_upload:                    self.seed_got_haves[olddl] -= 1         # penalize        if olddl is not None:            if looser_upload:                num = 1     # send a new have even if it hasn't spread that piece elsewhere            else:                num = 2            if self.seed_got_haves[olddl] < num:                return None            if not connection.upload.was_ever_interested:   # it never downloaded it?                connection.upload.skipped_count += 1                if connection.upload.skipped_count >= 3:    # probably another stealthed seed                    return -1                               # signal to close it        for tier in self.interests:            for piece in tier:                if not connection.download.have[piece]:                    seedint = self.level_in_interests[piece]                    self.level_in_interests[piece] += 1  # tweak it up one, so you don't duplicate effort                    if seedint == len(self.interests) - 1:                        self.interests.append([])                    self._shift_over(piece,                                self.interests[seedint], self.interests[seedint + 1])                    self.seed_got_haves[piece] = 0       # reset this                    self.seed_connections[connection] = piece                    connection.upload.seed_have_list.append(piece)                    return piece        return -1       # something screwy; terminate connection    def lost_peer(self, connection):        olddl = self.seed_connections.get(connection)        if olddl is None:            return        del self.seed_connections[connection]        self.past_ips[connection.get_ip()] = olddl        if self.seed_got_haves[olddl] == 1:            self.seed_got_haves[olddl] = 0

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线精品视频一区二区三四 | 99精品久久99久久久久| 久久福利视频一区二区| 日本不卡123| 蜜桃免费网站一区二区三区| 日日欢夜夜爽一区| 日本欧美一区二区| 精品综合免费视频观看| 国产美女精品一区二区三区| 成人一区二区视频| 91亚洲国产成人精品一区二三| 成人app下载| 在线欧美日韩精品| 在线播放中文字幕一区| 日韩免费视频线观看| 久久久美女艺术照精彩视频福利播放 | 男人的天堂久久精品| 蓝色福利精品导航| 国产精品亚洲а∨天堂免在线| 国产成人精品影视| 色婷婷国产精品| 欧美二区三区91| 精品国产免费人成电影在线观看四季 | 国产亚洲美州欧州综合国| 亚洲国产高清aⅴ视频| 一区二区三区四区五区视频在线观看| 一区二区三区欧美久久| 蜜臀av性久久久久蜜臀av麻豆| 国产一区二区三区蝌蚪| 91在线视频在线| 日韩精品一区二区三区四区| 国产精品久久午夜| 日韩电影一二三区| 99精品视频在线播放观看| 欧美少妇bbb| 国产清纯在线一区二区www| 一区二区三区中文在线| 免费人成在线不卡| 一本到高清视频免费精品| 欧美大黄免费观看| 一区二区三区小说| 成人三级伦理片| 欧美一区二区三区视频在线观看| 欧美激情一区二区在线| 日本三级韩国三级欧美三级| 99久久婷婷国产| 精品美女被调教视频大全网站| 亚洲人成亚洲人成在线观看图片| 久久99国产精品久久99果冻传媒| 99国产精品视频免费观看| 久久综合久色欧美综合狠狠| 亚洲国产成人tv| 不卡一卡二卡三乱码免费网站| 欧美成人三级在线| 婷婷开心激情综合| 色香蕉久久蜜桃| 一区在线观看免费| 成人午夜免费av| 久久品道一品道久久精品| 日韩av一二三| 欧美精品日韩精品| 亚洲精品中文字幕乱码三区| 成人高清视频在线| 国产欧美日韩另类视频免费观看 | 国产91在线|亚洲| 日韩网站在线看片你懂的| 亚洲国产成人tv| 欧美亚洲精品一区| 亚洲一区二区三区四区五区黄| 91免费视频网址| 日韩一区欧美小说| 99久久综合99久久综合网站| 国产精品久久久久久久久久久免费看| 国产美女一区二区三区| 久久夜色精品国产噜噜av| 久久99精品久久久久久| 日韩精品一区二区三区中文不卡 | 国产精品国产成人国产三级| 国产乱一区二区| 久久精品人人做人人爽人人| 国产伦精品一区二区三区免费| 精品国产乱码久久久久久浪潮| 捆绑紧缚一区二区三区视频| 久久综合久色欧美综合狠狠| 国产成人综合网| 国产精品久久久爽爽爽麻豆色哟哟 | 国产在线播精品第三| 久久久国产精华| 99精品一区二区三区| 一区二区三区视频在线观看| 欧美军同video69gay| 美腿丝袜在线亚洲一区| 久久久久久久久久久99999| 成人高清在线视频| 亚洲制服丝袜av| 日韩欧美你懂的| 成人三级伦理片| 午夜欧美在线一二页| 欧美成人女星排名| 成人小视频免费在线观看| 一二三区精品视频| 日韩三级视频在线看| 国产馆精品极品| 亚洲国产视频在线| 国产视频一区不卡| 欧美在线短视频| 国产麻豆欧美日韩一区| 18成人在线观看| 日韩一区二区三区免费观看| 国产69精品一区二区亚洲孕妇| 亚洲精品美国一| 精品乱人伦小说| 91蜜桃传媒精品久久久一区二区| 婷婷丁香久久五月婷婷| 国产亚洲一本大道中文在线| 日本高清免费不卡视频| 黑人巨大精品欧美一区| 亚洲黄色片在线观看| 国产亚洲婷婷免费| 日韩一区二区三区免费观看| 不卡在线观看av| 国产精品一卡二卡| 午夜精品久久久久| 国产精品久久久久久久裸模| 日韩欧美国产一区在线观看| 91日韩在线专区| 丰满亚洲少妇av| 久久国产精品色| 天天综合色天天综合色h| 国产精品亲子伦对白| 欧美变态凌虐bdsm| 欧美日韩久久久一区| 色婷婷久久99综合精品jk白丝| 国产一区91精品张津瑜| 日韩黄色片在线观看| 伊人一区二区三区| 中文字幕一区二区在线播放| 精品国产乱码久久久久久老虎| 777精品伊人久久久久大香线蕉| 色偷偷一区二区三区| 99久久国产综合精品麻豆| 国产**成人网毛片九色 | 中文字幕第一页久久| 久久视频一区二区| 久久综合成人精品亚洲另类欧美 | 国产精品国产三级国产三级人妇| 欧美mv日韩mv亚洲| 欧美一区二区三区在线看| 欧美日韩亚洲高清一区二区| 欧美亚洲一区二区三区四区| 91黄色免费网站| 在线观看欧美黄色| 欧美吻胸吃奶大尺度电影| 欧美视频在线一区二区三区| 在线观看三级视频欧美| 91成人国产精品| 欧美综合久久久| 欧美日韩一区二区三区在线 | 成人免费视频视频| 99在线视频精品| 色哟哟精品一区| 欧美久久一区二区| 欧美一区在线视频| 久久久夜色精品亚洲| 欧美国产精品劲爆| 亚洲男人都懂的| 午夜视频久久久久久| 麻豆高清免费国产一区| 国产精品自拍三区| av成人动漫在线观看| 日本二三区不卡| 777午夜精品免费视频| 精品理论电影在线| 国产精品五月天| 亚洲午夜精品在线| 狠狠色丁香婷婷综合久久片| 99久免费精品视频在线观看| 精品视频一区三区九区| 精品免费日韩av| 亚洲人午夜精品天堂一二香蕉| 亚洲成a人片综合在线| 国精产品一区一区三区mba视频 | 日韩成人午夜精品| 国产精品影视天天线| 色网综合在线观看| 日韩精品一区二区三区蜜臀| 欧美经典一区二区三区| 亚洲一区二区精品3399| 经典三级一区二区| 色综合久久久久综合| 欧美第一区第二区| 国产精品入口麻豆原神| 日韩高清不卡一区二区| 99在线精品免费| 日韩美女视频在线| 一区二区三区日韩欧美| 国产在线精品一区二区不卡了| 欧美最新大片在线看| 久久免费的精品国产v∧| 日精品一区二区三区|