1
// libTorrent - BitTorrent library
2
// Copyright (C) 2005-2006, Jari Sundell
4
// This program is free software; you can redistribute it and/or modify
5
// it under the terms of the GNU General Public License as published by
6
// the Free Software Foundation; either version 2 of the License, or
7
// (at your option) any later version.
9
// This program is distributed in the hope that it will be useful,
10
// but WITHOUT ANY WARRANTY; without even the implied warranty of
11
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12
// GNU General Public License for more details.
14
// You should have received a copy of the GNU General Public License
15
// along with this program; if not, write to the Free Software
16
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18
// In addition, as a special exception, the copyright holders give
19
// permission to link the code of portions of this program with the
20
// OpenSSL library under certain conditions as described in each
21
// individual source file, and distribute linked combinations
24
// You must obey the GNU General Public License in all respects for
25
// all of the code used other than OpenSSL. If you modify file(s)
26
// with this exception, you may extend this exception to your version
27
// of the file(s), but you are not obligated to do so. If you do not
28
// wish to do so, delete this exception statement from your version.
29
// If you delete this exception statement from all source files in the
30
// program, then also delete it here.
32
// Contact: Jari Sundell <jaris@ifi.uio.no>
35
// 3185 Skoppum, NORWAY
37
#ifndef LIBTORRENT_TRANSFER_LIST_H
38
#define LIBTORRENT_TRANSFER_LIST_H
43
#include <torrent/common.h>
55
class TransferList : public std::vector<BlockList*> {
57
typedef std::vector<BlockList*> base_type;
59
using base_type::value_type;
60
using base_type::reference;
61
using base_type::difference_type;
63
using base_type::iterator;
64
using base_type::const_iterator;
65
using base_type::reverse_iterator;
66
using base_type::const_reverse_iterator;
67
using base_type::size;
68
using base_type::empty;
70
using base_type::begin;
72
using base_type::rbegin;
73
using base_type::rend;
76
m_slotCanceled(slot_canceled_type(slot_canceled_op(NULL), NULL)),
77
m_slotCompleted(slot_completed_type(slot_completed_op(NULL), NULL)),
78
m_slotQueued(slot_queued_type(slot_queued_op(NULL), NULL)),
79
m_slotCorrupt(slot_corrupt_type(slot_corrupt_op(NULL), NULL)) { }
81
iterator find(uint32_t index);
82
const_iterator find(uint32_t index) const;
84
// Internal to libTorrent:
88
iterator insert(const Piece& piece, uint32_t blockSize);
89
iterator erase(iterator itr);
91
void finished(BlockTransfer* transfer);
93
void hash_succeded(uint32_t index);
94
void hash_failed(uint32_t index, Chunk* chunk);
96
typedef std::mem_fun1_t<void, ChunkSelector, uint32_t> slot_canceled_op;
97
typedef std::binder1st<slot_canceled_op> slot_canceled_type;
99
typedef std::mem_fun1_t<void, DownloadMain, uint32_t> slot_completed_op;
100
typedef std::binder1st<slot_completed_op> slot_completed_type;
102
typedef std::mem_fun1_t<void, ChunkSelector, uint32_t> slot_queued_op;
103
typedef std::binder1st<slot_queued_op> slot_queued_type;
105
typedef std::mem_fun1_t<void, DownloadMain, PeerInfo*> slot_corrupt_op;
106
typedef std::binder1st<slot_corrupt_op> slot_corrupt_type;
108
void slot_canceled(slot_canceled_type s) { m_slotCanceled = s; }
109
void slot_completed(slot_completed_type s) { m_slotCompleted = s; }
110
void slot_queued(slot_queued_type s) { m_slotQueued = s; }
112
void slot_corrupt(slot_corrupt_type s) { m_slotCorrupt = s; }
115
TransferList(const TransferList&);
116
void operator = (const TransferList&);
118
unsigned int update_failed(BlockList* blockList, Chunk* chunk);
119
void mark_failed_peers(BlockList* blockList);
121
void retry_most_popular(BlockList* blockList, Chunk* chunk);
123
slot_canceled_type m_slotCanceled;
124
slot_completed_type m_slotCompleted;
125
slot_queued_type m_slotQueued;
126
slot_corrupt_type m_slotCorrupt;