123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259 |
- /* <!-- 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 --> */
- #ifndef _D_DEFAULT_PIECE_STORAGE_H_
- #define _D_DEFAULT_PIECE_STORAGE_H_
- #include "PieceStorage.h"
- #include <deque>
- namespace aria2 {
- class DownloadContext;
- class BitfieldMan;
- class Logger;
- class Option;
- class DiskWriterFactory;
- class FileEntry;
- class PieceStatMan;
- class PieceSelector;
- #define END_GAME_PIECE_NUM 20
- class HaveEntry {
- private:
- cuid_t _cuid;
- size_t _index;
- Timer _registeredTime;
- public:
- HaveEntry(cuid_t cuid, size_t index, const Timer& registeredTime):
- _cuid(cuid),
- _index(index),
- _registeredTime(registeredTime) {}
- cuid_t getCuid() const { return _cuid; }
- size_t getIndex() const { return _index; }
- const Timer& getRegisteredTime() const { return _registeredTime; }
- };
- class DefaultPieceStorage : public PieceStorage {
- private:
- SharedHandle<DownloadContext> _downloadContext;
- BitfieldMan* _bitfieldMan;
- SharedHandle<DiskAdaptor> _diskAdaptor;
- SharedHandle<DiskWriterFactory> _diskWriterFactory;
- std::deque<SharedHandle<Piece> > _usedPieces;
- size_t _endGamePieceNum;
- Logger* _logger;
- const Option* _option;
- std::deque<HaveEntry> _haves;
- SharedHandle<PieceStatMan> _pieceStatMan;
- SharedHandle<PieceSelector> _pieceSelector;
- bool getMissingPieceIndex(size_t& index,
- const unsigned char* bitfield, size_t length);
- SharedHandle<Piece> getMissingPiece(const unsigned char* bitfield,
- size_t length);
- SharedHandle<Piece> getMissingPiece(const BitfieldMan& bitfield);
- #ifdef ENABLE_BITTORRENT
- void createFastIndexBitfield(BitfieldMan& bitfield,
- const SharedHandle<Peer>& peer);
- #endif // ENABLE_BITTORRENT
- SharedHandle<Piece> checkOutPiece(size_t index);
- // size_t deleteUsedPiecesByFillRate(int fillRate, size_t toDelete);
- // void reduceUsedPieces(size_t upperBound);
- void deleteUsedPiece(const SharedHandle<Piece>& piece);
- SharedHandle<Piece> findUsedPiece(size_t index) const;
- size_t getInFlightPieceCompletedLength() const;
- public:
- // Setting randomPieceStatsOrdering to true means a piece is chosen in
- // random when more than 2 pieces has the same rarity.
- // If it is set to false, a piece whose index is smallest has the highest
- // priority.
- DefaultPieceStorage(const SharedHandle<DownloadContext>& downloadContext,
- const Option* option);
-
- virtual ~DefaultPieceStorage();
- #ifdef ENABLE_BITTORRENT
- virtual bool hasMissingPiece(const SharedHandle<Peer>& peer);
- virtual SharedHandle<Piece> getMissingPiece(const SharedHandle<Peer>& peer);
- virtual SharedHandle<Piece> getMissingFastPiece
- (const SharedHandle<Peer>& peer);
- virtual SharedHandle<Piece> getMissingPiece
- (const SharedHandle<Peer>& peer, const std::vector<size_t>& excludedIndexes);
- virtual SharedHandle<Piece> getMissingFastPiece
- (const SharedHandle<Peer>& peer, const std::vector<size_t>& excludedIndexes);
- #endif // ENABLE_BITTORRENT
- virtual bool hasMissingUnusedPiece();
- virtual SharedHandle<Piece> getSparseMissingUnusedPiece
- (const unsigned char* ignoreBitfield, size_t length);
- virtual SharedHandle<Piece> getMissingPiece(size_t index);
- virtual SharedHandle<Piece> getPiece(size_t index);
- virtual void completePiece(const SharedHandle<Piece>& piece);
- virtual void cancelPiece(const SharedHandle<Piece>& piece);
- virtual bool hasPiece(size_t index);
- virtual bool isPieceUsed(size_t index);
- virtual uint64_t getTotalLength();
- virtual uint64_t getFilteredTotalLength();
- virtual uint64_t getCompletedLength();
- virtual uint64_t getFilteredCompletedLength();
- virtual void initStorage();
- virtual void setupFileFilter();
-
- virtual void clearFileFilter();
- virtual bool downloadFinished();
- virtual bool allDownloadFinished();
- virtual void setBitfield(const unsigned char* bitfield,
- size_t bitfieldLength);
-
- virtual size_t getBitfieldLength();
- virtual const unsigned char* getBitfield();
- virtual void setEndGamePieceNum(size_t num) {
- _endGamePieceNum = num;
- }
- size_t getEndGamePieceNum() const {
- return _endGamePieceNum;
- }
- virtual bool isSelectiveDownloadingMode();
- virtual bool isEndGame();
-
- virtual SharedHandle<DiskAdaptor> getDiskAdaptor();
- virtual size_t getPieceLength(size_t index);
- virtual void advertisePiece(cuid_t cuid, size_t index);
- virtual void
- getAdvertisedPieceIndexes(std::vector<size_t>& indexes,
- cuid_t myCuid, const Timer& lastCheckTime);
- virtual void removeAdvertisedPiece(time_t elapsed);
- virtual void markAllPiecesDone();
- virtual void markPiecesDone(uint64_t length);
- virtual void markPieceMissing(size_t index);
- virtual void addInFlightPiece
- (const std::vector<SharedHandle<Piece> >& pieces);
- virtual size_t countInFlightPiece();
- virtual void getInFlightPieces
- (std::vector<SharedHandle<Piece> >& pieces);
- virtual void addPieceStats(size_t index);
- virtual void addPieceStats(const unsigned char* bitfield,
- size_t bitfieldLength);
-
- virtual void subtractPieceStats(const unsigned char* bitfield,
- size_t bitfieldLength);
- virtual void updatePieceStats(const unsigned char* newBitfield,
- size_t newBitfieldLength,
- const unsigned char* oldBitfield);
- /**
- * This method is made private for test purpose only.
- */
- void addUsedPiece(const SharedHandle<Piece>& piece);
- void setDiskWriterFactory
- (const SharedHandle<DiskWriterFactory>& diskWriterFactory);
- const SharedHandle<PieceStatMan>& getPieceStatMan() const
- {
- return _pieceStatMan;
- }
- void setPieceSelector(const SharedHandle<PieceSelector>& pieceSelector)
- {
- _pieceSelector = pieceSelector;
- }
- const SharedHandle<PieceSelector>& getPieceSelector() const
- {
- return _pieceSelector;
- }
-
- };
- typedef SharedHandle<DefaultPieceStorage> DefaultPieceStorageHandle;
- } // namespace aria2
- #endif // _D_DEFAULT_PIECE_STORAGE_H_
|