| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282 | /* <!-- copyright *//* * aria2 - The high speed download utility * * Copyright (C) 2006 Tatsuhiro Tsujikawa * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA * * In addition, as a special exception, the copyright holders give * permission to link the code of portions of this program with the * OpenSSL library under certain conditions as described in each * individual source file, and distribute linked combinations * including the two. * You must obey the GNU General Public License in all respects * for all of the code used other than OpenSSL.  If you modify * file(s) with this exception, you may extend this exception to your * version of the file(s), but you are not obligated to do so.  If you * do not wish to do so, delete this exception statement from your * version.  If you delete this exception statement from all source * files in the program, then also delete it here. *//* copyright --> */#include "PeerSessionResource.h"#include <cassert>#include <algorithm>#include "BitfieldManFactory.h"#include "BitfieldMan.h"#include "A2STR.h"#include "BtMessageDispatcher.h"namespace aria2 {PeerSessionResource::PeerSessionResource(size_t pieceLength, uint64_t totalLength):  _amChoking(true),  _amInterested(false),  _peerChoking(true),  _peerInterested(false),  _chokingRequired(true),  _optUnchoking(false),  _snubbing(false),  _bitfieldMan(BitfieldManFactory::getFactoryInstance()->createBitfieldMan(pieceLength, totalLength)),  _fastExtensionEnabled(false),  _extendedMessagingEnabled(false),  _dhtEnabled(false),  _latency(DEFAULT_LATENCY),  _lastDownloadUpdate(0),  _lastAmUnchoking(0){}PeerSessionResource::~PeerSessionResource(){  delete _bitfieldMan;}void PeerSessionResource::amChoking(bool b){  _amChoking = b;  if(!b) {    _lastAmUnchoking.reset();  }}void PeerSessionResource::amInterested(bool b){  _amInterested = b;}void PeerSessionResource::peerChoking(bool b){  _peerChoking = b;}void PeerSessionResource::peerInterested(bool b){  _peerInterested = b;}  void PeerSessionResource::chokingRequired(bool b){  _chokingRequired = b;}void PeerSessionResource::optUnchoking(bool b){  _optUnchoking = b;}bool PeerSessionResource::shouldBeChoking() const{  if(_optUnchoking) {    return false;  }  return _chokingRequired;}void PeerSessionResource::snubbing(bool b){  _snubbing = b;  if(_snubbing) {    chokingRequired(true);    optUnchoking(false);  }}bool PeerSessionResource::hasAllPieces() const{  return _bitfieldMan->isAllBitSet();}void PeerSessionResource::updateBitfield(size_t index, int operation){  if(operation == 1) {    _bitfieldMan->setBit(index);  } else if(operation == 0) {    _bitfieldMan->unsetBit(index);  }}void PeerSessionResource::setBitfield(const unsigned char* bitfield, size_t bitfieldLength){  _bitfieldMan->setBitfield(bitfield, bitfieldLength);}const unsigned char* PeerSessionResource::getBitfield() const{  return _bitfieldMan->getBitfield();}size_t PeerSessionResource::getBitfieldLength() const{  return _bitfieldMan->getBitfieldLength();}bool PeerSessionResource::hasPiece(size_t index) const{  return _bitfieldMan->isBitSet(index);}void PeerSessionResource::markSeeder(){  _bitfieldMan->setAllBit();}void PeerSessionResource::fastExtensionEnabled(bool b){  _fastExtensionEnabled = b;}const std::deque<size_t>& PeerSessionResource::peerAllowedIndexSet() const{  return _peerAllowedIndexSet;}static void updateIndexSet(std::deque<size_t>& c, size_t index){  std::deque<size_t>::iterator i = std::lower_bound(c.begin(), c.end(), index);  if(i == c.end() || (*i) != index) {    c.insert(i, index);  } }void PeerSessionResource::addPeerAllowedIndex(size_t index){  updateIndexSet(_peerAllowedIndexSet, index);}bool PeerSessionResource::peerAllowedIndexSetContains(size_t index) const{  return std::binary_search(_peerAllowedIndexSet.begin(),			    _peerAllowedIndexSet.end(),			    index);}void PeerSessionResource::addAmAllowedIndex(size_t index){  updateIndexSet(_amAllowedIndexSet, index);}bool PeerSessionResource::amAllowedIndexSetContains(size_t index) const{  return std::binary_search(_amAllowedIndexSet.begin(),			    _amAllowedIndexSet.end(),			    index);}void PeerSessionResource::extendedMessagingEnabled(bool b){  _extendedMessagingEnabled = b;}uint8_tPeerSessionResource::getExtensionMessageID(const std::string& name) const{  Extensions::const_iterator itr = _extensions.find(name);  if(itr == _extensions.end()) {    return 0;  } else {    return (*itr).second;  }}std::string PeerSessionResource::getExtensionName(uint8_t id) const{  for(Extensions::const_iterator itr = _extensions.begin();      itr != _extensions.end(); ++itr) {    const Extensions::value_type& p = *itr;    if(p.second == id) {      return p.first;    }  }  return A2STR::NIL;}void PeerSessionResource::addExtension(const std::string& name, uint8_t id){  _extensions[name] = id;}void PeerSessionResource::dhtEnabled(bool b){  _dhtEnabled = b;}void PeerSessionResource::updateLatency(unsigned int latency){  _latency = static_cast<unsigned int>(_latency*0.2+latency*0.8);}uint64_t PeerSessionResource::uploadLength() const{  return _peerStat.getSessionUploadLength();}void PeerSessionResource::updateUploadLength(size_t bytes){  _peerStat.updateUploadLength(bytes);}uint64_t PeerSessionResource::downloadLength() const{  return _peerStat.getSessionDownloadLength();}void PeerSessionResource::updateDownloadLength(size_t bytes){  _peerStat.updateDownloadLength(bytes);  _lastDownloadUpdate.reset();}uint64_t PeerSessionResource::getCompletedLength() const{  return _bitfieldMan->getCompletedLength();}void PeerSessionResource::setBtMessageDispatcher(const WeakHandle<BtMessageDispatcher>& dpt){  _dispatcher = dpt;}size_t PeerSessionResource::countOutstandingUpload() const{  assert(!_dispatcher.isNull());  return _dispatcher->countOutstandingUpload();}} // namespace aria2
 |