source: trunk/libtransmission/torrent.h @ 8709

Last change on this file since 8709 was 8709, checked in by charles, 12 years ago

(trunk libT) revert most of r8693 as a quick fix for a possible alignment issue on a NAS

  • Property svn:keywords set to Date Rev Author Id
File size: 10.0 KB
Line 
1/*
2 * This file Copyright (C) 2009 Charles Kerr <charles@transmissionbt.com>
3 *
4 * This file is licensed by the GPL version 2.  Works owned by the
5 * Transmission project are granted a special exemption to clause 2(b)
6 * so that the bulk of its code can remain under the MIT license.
7 * This exemption does not extend to derived works not owned by
8 * the Transmission project.
9 *
10 * $Id: torrent.h 8709 2009-06-16 19:31:17Z charles $
11 */
12
13#ifndef __TRANSMISSION__
14 #error only libtransmission should #include this header.
15#endif
16
17#ifndef TR_TORRENT_H
18#define TR_TORRENT_H 1
19
20#include "completion.h" /* tr_completion */
21#include "ratecontrol.h" /* tr_ratecontrol */
22#include "session.h" /* tr_globalLock(), tr_globalUnlock() */
23#include "utils.h" /* tr_bitfield */
24
25struct tr_bandwidth;
26struct tr_ratecontrol;
27struct tr_torrent_peers;
28
29/**
30***  Package-visible ctor API
31**/
32
33void        tr_ctorSetSave( tr_ctor * ctor,
34                            tr_bool   saveMetadataInOurTorrentsDir );
35
36int         tr_ctorGetSave( const tr_ctor * ctor );
37
38void        tr_ctorInitTorrentPriorities( const tr_ctor * ctor, tr_torrent * tor );
39
40void        tr_ctorInitTorrentWanted( const tr_ctor * ctor, tr_torrent * tor );
41
42/**
43***
44**/
45
46/* just like tr_torrentSetFileDLs but doesn't trigger a fastresume save */
47void        tr_torrentInitFileDLs( tr_torrent *      tor,
48                                   tr_file_index_t * files,
49                                   tr_file_index_t   fileCount,
50                                   tr_bool           do_download );
51
52void        tr_torrentRecheckCompleteness( tr_torrent * );
53
54void        tr_torrentResetTransferStats( tr_torrent * );
55
56void        tr_torrentSetHasPiece( tr_torrent *     tor,
57                                   tr_piece_index_t pieceIndex,
58                                   tr_bool          has );
59
60void        tr_torrentChangeMyPort( tr_torrent * session );
61
62tr_torrent* tr_torrentFindFromHash( tr_session *    session,
63                                    const uint8_t * hash );
64
65tr_torrent* tr_torrentFindFromHashString( tr_session * session,
66                                          const char * hashString );
67
68tr_torrent* tr_torrentFindFromObfuscatedHash( tr_session    * session,
69                                              const uint8_t * hash );
70
71tr_bool     tr_torrentIsPieceTransferAllowed( const tr_torrent * torrent,
72                                              tr_direction       direction );
73
74
75
76#define tr_block( a, b ) _tr_block( tor, a, b )
77tr_block_index_t _tr_block( const tr_torrent * tor,
78                            tr_piece_index_t   index,
79                            uint32_t           offset );
80
81tr_bool          tr_torrentReqIsValid( const tr_torrent * tor,
82                                       tr_piece_index_t   index,
83                                       uint32_t           offset,
84                                       uint32_t           length );
85
86uint64_t         tr_pieceOffset( const tr_torrent * tor,
87                                 tr_piece_index_t   index,
88                                 uint32_t           offset,
89                                 uint32_t           length );
90
91void             tr_torrentInitFilePriority( tr_torrent       * tor,
92                                             tr_file_index_t    fileIndex,
93                                             tr_priority_t      priority );
94
95int              tr_torrentCountUncheckedPieces( const tr_torrent * );
96
97tr_bool          tr_torrentIsFileChecked( const tr_torrent  * tor,
98                                          tr_file_index_t     file );
99
100void             tr_torrentSetPieceChecked( tr_torrent       * tor,
101                                            tr_piece_index_t   piece,
102                                            tr_bool            isChecked );
103
104void             tr_torrentSetFileChecked( tr_torrent       * tor,
105                                           tr_file_index_t    file,
106                                           tr_bool            isChecked );
107
108void             tr_torrentUncheck( tr_torrent * tor );
109
110int              tr_torrentPromoteTracker( tr_torrent   * tor,
111                                           int            trackerIndex );
112
113time_t*          tr_torrentGetMTimes( const tr_torrent  * tor,
114                                      size_t            * setmeCount );
115
116tr_torrent*      tr_torrentNext( tr_session  * session,
117                                 tr_torrent  * current );
118
119void             tr_torrentCheckSeedRatio( tr_torrent * tor );
120
121
122
123typedef enum
124{
125    TR_VERIFY_NONE,
126    TR_VERIFY_WAIT,
127    TR_VERIFY_NOW
128}
129tr_verify_state;
130
131void             tr_torrentSetVerifyState( tr_torrent      * tor,
132                                           tr_verify_state   state );
133
134struct tr_torrent
135{
136    tr_session *             session;
137    tr_info                  info;
138
139    struct tr_ratecontrol    swarmSpeed;
140
141    int                      magicNumber;
142
143    int                      error;
144    char                     errorString[128];
145
146    uint8_t                  obfuscatedHash[SHA_DIGEST_LENGTH];
147
148    /* If the initiator of the connection receives a handshake in which the
149     * peer_id does not match the expected peerid, then the initiator is
150     * expected to drop the connection. Note that the initiator presumably
151     * received the peer information from the tracker, which includes the
152     * peer_id that was registered by the peer. The peer_id from the tracker
153     * and in the handshake are expected to match.
154     */
155    uint8_t * peer_id;
156
157    /* Where to download */
158    char * downloadDir;
159
160    /* How many bytes we ask for per request */
161    uint32_t                   blockSize;
162    tr_block_index_t           blockCount;
163
164    uint32_t                   lastBlockSize;
165    uint32_t                   lastPieceSize;
166
167    uint32_t                   blockCountInPiece;
168    uint32_t                   blockCountInLastPiece;
169
170    struct tr_completion       completion;
171
172    struct tr_bitfield         checkedPieces;
173    tr_completeness            completeness;
174
175    struct tr_tracker *        tracker;
176    struct tr_publisher_tag *  trackerSubscription;
177
178    time_t                     dhtAnnounceAt;
179    tr_bool                    dhtAnnounceInProgress;
180
181    uint64_t                   downloadedCur;
182    uint64_t                   downloadedPrev;
183    uint64_t                   uploadedCur;
184    uint64_t                   uploadedPrev;
185    uint64_t                   corruptCur;
186    uint64_t                   corruptPrev;
187
188    time_t                     addedDate;
189    time_t                     activityDate;
190    time_t                     doneDate;
191    time_t                     startDate;
192    time_t                     anyDate;
193
194    tr_torrent_completeness_func *   completeness_func;
195    void *                     completeness_func_user_data;
196
197    tr_torrent_ratio_limit_hit_func * ratio_limit_hit_func;
198    void *                     ratio_limit_hit_func_user_data;
199
200    tr_bool                    isRunning;
201    tr_bool                    isDeleting;
202    tr_bool                    needsSeedRatioCheck;
203    tr_bool                    startAfterVerify;
204
205    uint16_t                   maxConnectedPeers;
206
207    tr_verify_state            verifyState;
208
209    time_t                     lastStatTime;
210    tr_stat                    stats;
211
212    tr_torrent *               next;
213
214    int                        uniqueId;
215
216    struct tr_bandwidth      * bandwidth;
217
218    struct tr_torrent_peers  * torrentPeers;
219
220    double                     desiredRatio;
221    tr_ratiolimit              ratioLimitMode;
222};
223
224/* get the index of this piece's first block */
225static TR_INLINE tr_block_index_t
226tr_torPieceFirstBlock( const tr_torrent * tor, const tr_piece_index_t piece )
227{
228    return piece * tor->blockCountInPiece;
229}
230
231/* what piece index is this block in? */
232static TR_INLINE tr_piece_index_t
233tr_torBlockPiece( const tr_torrent * tor, const tr_block_index_t block )
234{
235    return block / tor->blockCountInPiece;
236}
237
238/* how many blocks are in this piece? */
239static TR_INLINE uint32_t
240tr_torPieceCountBlocks( const tr_torrent * tor, const tr_piece_index_t piece )
241{
242    return piece == tor->info.pieceCount - 1 ? tor->blockCountInLastPiece
243                                             : tor->blockCountInPiece;
244}
245
246/* how many bytes are in this piece? */
247static TR_INLINE uint32_t
248tr_torPieceCountBytes( const tr_torrent * tor, const tr_piece_index_t piece )
249{
250    return piece == tor->info.pieceCount - 1 ? tor->lastPieceSize
251                                             : tor->info.pieceSize;
252}
253
254/* how many bytes are in this block? */
255static TR_INLINE uint32_t
256tr_torBlockCountBytes( const tr_torrent * tor, const tr_block_index_t block )
257{
258    return block == tor->blockCount - 1 ? tor->lastBlockSize
259                                        : tor->blockSize;
260}
261
262static TR_INLINE void tr_torrentLock( const tr_torrent * tor )
263{
264    tr_globalLock( tor->session );
265}
266
267static TR_INLINE void tr_torrentUnlock( const tr_torrent * tor )
268{
269    tr_globalUnlock( tor->session );
270}
271
272static TR_INLINE tr_bool
273tr_torrentExists( const tr_session * session, const uint8_t *   torrentHash )
274{
275    return tr_torrentFindFromHash( (tr_session*)session, torrentHash ) != NULL;
276}
277
278static TR_INLINE tr_bool
279tr_torrentIsSeed( const tr_torrent * tor )
280{
281    return tor->completeness != TR_LEECH;
282}
283
284static TR_INLINE tr_bool tr_torrentIsPrivate( const tr_torrent * tor )
285{
286    return ( tor != NULL ) && tor->info.isPrivate;
287}
288
289static TR_INLINE tr_bool tr_torrentAllowsPex( const tr_torrent * tor )
290{
291    return ( tor != NULL  ) && tor->session->isPexEnabled && !tr_torrentIsPrivate( tor );
292}
293
294static TR_INLINE tr_bool tr_torrentAllowsDHT( const tr_torrent * tor )
295{
296    return ( tor != NULL  ) && tor->session->isDHTEnabled && !tr_torrentIsPrivate( tor );
297}
298
299static TR_INLINE tr_bool tr_torrentIsPieceChecked( const tr_torrent  * tor, tr_piece_index_t i )
300{
301    return tr_bitfieldHasFast( &tor->checkedPieces, i );
302}
303
304/***
305****
306***/
307
308enum
309{
310    TORRENT_MAGIC_NUMBER = 95549
311};
312
313static inline tr_bool tr_isTorrent( const tr_torrent * tor )
314{
315    return ( tor != NULL )
316        && ( tor->magicNumber == TORRENT_MAGIC_NUMBER )
317        && ( tr_isSession( tor->session ) );
318}
319
320#endif
Note: See TracBrowser for help on using the repository browser.