~ubuntu-branches/debian/wheezy/libtorrent/wheezy

« back to all changes in this revision

Viewing changes to src/data/hash_queue.h

  • Committer: Bazaar Package Importer
  • Author(s): Rogério Brito
  • Date: 2011-03-09 20:04:41 UTC
  • mfrom: (1.3.4 upstream) (7.1.5 sid)
  • Revision ID: james.westby@ubuntu.com-20110309200441-ffi9aaqdyd72d8xl
Tags: 0.12.7-4
* Steal patch from upstream's bug tracking system to enable IPv6.
* Refresh patches to apply cleanly.
* This should, hopefully, be a good step towards addressing #490277.

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_DATA_HASH_QUEUE_H
 
38
#define LIBTORRENT_DATA_HASH_QUEUE_H
 
39
 
 
40
#include <deque>
 
41
#include <rak/priority_queue_default.h>
 
42
 
 
43
#include "hash_queue_node.h"
 
44
#include "chunk_handle.h"
 
45
 
 
46
namespace torrent {
 
47
 
 
48
class HashChunk;
 
49
 
 
50
// Calculating hash of incore memory is blindingly fast, it's always
 
51
// the loading from swap/disk that takes time. So with the exception
 
52
// of large resumed downloads, try to check the hash immediately. This
 
53
// helps us in getting as much done as possible while the pages are in
 
54
// memory.
 
55
 
 
56
class HashQueue : private std::deque<HashQueueNode> {
 
57
public:
 
58
  typedef std::deque<HashQueueNode>     base_type;
 
59
  typedef HashQueueNode::slot_done_type slot_done_type;
 
60
 
 
61
  using base_type::iterator;
 
62
 
 
63
  using base_type::empty;
 
64
 
 
65
  using base_type::begin;
 
66
  using base_type::end;
 
67
 
 
68
  HashQueue();
 
69
  ~HashQueue() { clear(); }
 
70
 
 
71
  void                push_back(ChunkHandle handle, slot_done_type d);
 
72
 
 
73
  bool                has(HashQueueNode::id_type id);
 
74
  bool                has(HashQueueNode::id_type id, uint32_t index);
 
75
 
 
76
  void                remove(HashQueueNode::id_type id);
 
77
  void                clear();
 
78
 
 
79
  void                work();
 
80
 
 
81
  uint32_t            read_ahead() const             { return m_readAhead; }
 
82
  void                set_read_ahead(uint32_t bytes) { m_readAhead = bytes; }
 
83
 
 
84
  uint32_t            interval() const               { return m_interval; }
 
85
  void                set_interval(uint32_t usec)    { m_interval = usec; }
 
86
 
 
87
  uint32_t            max_tries() const              { return m_maxTries; }
 
88
  void                set_max_tries(uint32_t tries)  { m_maxTries = tries; }
 
89
 
 
90
private:
 
91
  bool                check(bool force);
 
92
 
 
93
  inline void         willneed(int bytes);
 
94
 
 
95
  uint16_t            m_tries;
 
96
  rak::priority_item  m_taskWork;
 
97
 
 
98
  uint32_t            m_readAhead;
 
99
  uint32_t            m_interval;
 
100
  uint32_t            m_maxTries;
 
101
};
 
102
 
 
103
}
 
104
 
 
105
#endif