~ubuntu-branches/ubuntu/wily/libtorrent/wily-proposed

« back to all changes in this revision

Viewing changes to src/torrent/data/block_list.h

  • Committer: Bazaar Package Importer
  • Author(s): Rogério Brito
  • Date: 2011-03-20 01:06:18 UTC
  • mfrom: (1.1.13 upstream) (4.1.9 sid)
  • Revision ID: james.westby@ubuntu.com-20110320010618-g3wyylccqzqko73c
Tags: 0.12.7-5
* Use Steinar's "real" patch for IPv6. Addresses #490277, #618275,
  and Closes: #617791.
* Adapt libtorrent-0.12.6-ipv6-07.patch. It FTBFS otherwise.
* Add proper attibution to the IPv6 patch.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
// libTorrent - BitTorrent library
 
2
// Copyright (C) 2005-2007, Jari Sundell
 
3
//
 
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.
 
8
// 
 
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.
 
13
// 
 
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
 
17
//
 
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
 
22
// including the two.
 
23
//
 
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.
 
31
//
 
32
// Contact:  Jari Sundell <jaris@ifi.uio.no>
 
33
//
 
34
//           Skomakerveien 33
 
35
//           3185 Skoppum, NORWAY
 
36
 
 
37
#ifndef LIBTORRENT_BLOCK_LIST_H
 
38
#define LIBTORRENT_BLOCK_LIST_H
 
39
 
 
40
#include <vector>
 
41
#include <torrent/common.h>
 
42
#include <torrent/data/block.h>
 
43
#include <torrent/data/piece.h>
 
44
 
 
45
namespace torrent {
 
46
 
 
47
class LIBTORRENT_EXPORT BlockList : public std::vector<Block> {
 
48
public:
 
49
  typedef std::vector<Block> base_type;
 
50
  typedef uint32_t           size_type;
 
51
 
 
52
  using base_type::value_type;
 
53
  using base_type::reference;
 
54
  using base_type::difference_type;
 
55
 
 
56
  using base_type::iterator;
 
57
  using base_type::reverse_iterator;
 
58
  using base_type::size;
 
59
  using base_type::empty;
 
60
 
 
61
  using base_type::begin;
 
62
  using base_type::end;
 
63
  using base_type::rbegin;
 
64
  using base_type::rend;
 
65
 
 
66
  using base_type::operator[];
 
67
 
 
68
  BlockList(const Piece& piece, uint32_t blockLength);
 
69
  ~BlockList();
 
70
 
 
71
  bool                is_all_finished() const       { return m_finished == size(); }
 
72
 
 
73
  const Piece&        piece() const                 { return m_piece; }
 
74
 
 
75
  uint32_t            index() const                 { return m_piece.index(); }
 
76
 
 
77
  priority_t          priority() const              { return m_priority; }
 
78
  void                set_priority(priority_t p)    { m_priority = p; }
 
79
 
 
80
  size_type           finished() const              { return m_finished; }
 
81
  void                inc_finished()                { m_finished++; }
 
82
  void                clear_finished()              { m_finished = 0; }
 
83
  
 
84
  uint32_t            failed() const                { return m_failed; }
 
85
 
 
86
  // Temporary, just increment for now.
 
87
  void                inc_failed()                  { m_failed++; }
 
88
 
 
89
  uint32_t            attempt() const               { return m_attempt; }
 
90
  void                set_attempt(uint32_t a)       { m_attempt = a; }
 
91
 
 
92
  // Set when the chunk was initially requested from a seeder. This
 
93
  // allows us to quickly determine if it is a suitable chunk to
 
94
  // request from another seeder, e.g by already knowing it is a rare
 
95
  // piece.
 
96
  bool                by_seeder() const             { return m_bySeeder; }
 
97
  void                set_by_seeder(bool state)     { m_bySeeder = state; }
 
98
 
 
99
private:
 
100
  BlockList(const BlockList&);
 
101
  void operator = (const BlockList&);
 
102
 
 
103
  Piece               m_piece;
 
104
  priority_t          m_priority;
 
105
 
 
106
  size_type           m_finished;
 
107
  uint32_t            m_failed;
 
108
  uint32_t            m_attempt;
 
109
 
 
110
  bool                m_bySeeder;
 
111
};
 
112
 
 
113
}
 
114
 
 
115
#endif