Merge all our global consts and vars into global.go
For easier referral to other parties.
This commit is contained in:
parent
48871324f4
commit
da4d40ed7e
73
client.go
73
client.go
@ -7,7 +7,6 @@ import (
|
||||
"crypto/sha1"
|
||||
"encoding/hex"
|
||||
"errors"
|
||||
"expvar"
|
||||
"fmt"
|
||||
"io"
|
||||
"log"
|
||||
@ -39,78 +38,6 @@ import (
|
||||
"github.com/anacrolix/torrent/tracker"
|
||||
)
|
||||
|
||||
// I could move a lot of these counters to their own file, but I suspect they
|
||||
// may be attached to a Client someday.
|
||||
var (
|
||||
unwantedChunksReceived = expvar.NewInt("chunksReceivedUnwanted")
|
||||
unexpectedChunksReceived = expvar.NewInt("chunksReceivedUnexpected")
|
||||
chunksReceived = expvar.NewInt("chunksReceived")
|
||||
|
||||
peersAddedBySource = expvar.NewMap("peersAddedBySource")
|
||||
|
||||
uploadChunksPosted = expvar.NewInt("uploadChunksPosted")
|
||||
unexpectedCancels = expvar.NewInt("unexpectedCancels")
|
||||
postedCancels = expvar.NewInt("postedCancels")
|
||||
duplicateConnsAvoided = expvar.NewInt("duplicateConnsAvoided")
|
||||
|
||||
pieceHashedCorrect = expvar.NewInt("pieceHashedCorrect")
|
||||
pieceHashedNotCorrect = expvar.NewInt("pieceHashedNotCorrect")
|
||||
|
||||
unsuccessfulDials = expvar.NewInt("dialSuccessful")
|
||||
successfulDials = expvar.NewInt("dialUnsuccessful")
|
||||
|
||||
acceptUTP = expvar.NewInt("acceptUTP")
|
||||
acceptTCP = expvar.NewInt("acceptTCP")
|
||||
acceptReject = expvar.NewInt("acceptReject")
|
||||
|
||||
peerExtensions = expvar.NewMap("peerExtensions")
|
||||
completedHandshakeConnectionFlags = expvar.NewMap("completedHandshakeConnectionFlags")
|
||||
// Count of connections to peer with same client ID.
|
||||
connsToSelf = expvar.NewInt("connsToSelf")
|
||||
// Number of completed connections to a client we're already connected with.
|
||||
duplicateClientConns = expvar.NewInt("duplicateClientConns")
|
||||
receivedMessageTypes = expvar.NewMap("receivedMessageTypes")
|
||||
receivedKeepalives = expvar.NewInt("receivedKeepalives")
|
||||
supportedExtensionMessages = expvar.NewMap("supportedExtensionMessages")
|
||||
postedMessageTypes = expvar.NewMap("postedMessageTypes")
|
||||
postedKeepalives = expvar.NewInt("postedKeepalives")
|
||||
// Requests received for pieces we don't have.
|
||||
requestsReceivedForMissingPieces = expvar.NewInt("requestsReceivedForMissingPieces")
|
||||
)
|
||||
|
||||
const (
|
||||
// Justification for set bits follows.
|
||||
//
|
||||
// Extension protocol ([5]|=0x10):
|
||||
// http://www.bittorrent.org/beps/bep_0010.html
|
||||
//
|
||||
// Fast Extension ([7]|=0x04):
|
||||
// http://bittorrent.org/beps/bep_0006.html.
|
||||
// Disabled until AllowedFast is implemented.
|
||||
//
|
||||
// DHT ([7]|=1):
|
||||
// http://www.bittorrent.org/beps/bep_0005.html
|
||||
defaultExtensionBytes = "\x00\x00\x00\x00\x00\x10\x00\x01"
|
||||
|
||||
socketsPerTorrent = 80
|
||||
torrentPeersHighWater = 200
|
||||
torrentPeersLowWater = 50
|
||||
|
||||
// Limit how long handshake can take. This is to reduce the lingering
|
||||
// impact of a few bad apples. 4s loses 1% of successful handshakes that
|
||||
// are obtained with 60s timeout, and 5% of unsuccessful handshakes.
|
||||
handshakesTimeout = 20 * time.Second
|
||||
|
||||
// These are our extended message IDs.
|
||||
metadataExtendedId = iota + 1 // 0 is reserved for deleting keys
|
||||
pexExtendedId
|
||||
|
||||
// Updated occasionally to when there's been some changes to client
|
||||
// behaviour in case other clients are assuming anything of us. See also
|
||||
// `bep20`.
|
||||
extendedHandshakeClientVersion = "go.torrent dev 20150624"
|
||||
)
|
||||
|
||||
// Currently doesn't really queue, but should in the future.
|
||||
func (cl *Client) queuePieceCheck(t *Torrent, pieceIndex int) {
|
||||
piece := &t.pieces[pieceIndex]
|
||||
|
96
global.go
Normal file
96
global.go
Normal file
@ -0,0 +1,96 @@
|
||||
package torrent
|
||||
|
||||
import (
|
||||
"crypto"
|
||||
"expvar"
|
||||
"time"
|
||||
)
|
||||
|
||||
const (
|
||||
pieceHash = crypto.SHA1
|
||||
maxRequests = 250 // Maximum pending requests we allow peers to send us.
|
||||
defaultChunkSize = 0x4000 // 16KiB
|
||||
|
||||
// Updated occasionally to when there's been some changes to client
|
||||
// behaviour in case other clients are assuming anything of us. See also
|
||||
// `bep20`.
|
||||
extendedHandshakeClientVersion = "go.torrent dev 20150624"
|
||||
// Peer ID client identifier prefix. We'll update this occasionally to
|
||||
// reflect changes to client behaviour that other clients may depend on.
|
||||
// Also see `extendedHandshakeClientVersion`.
|
||||
bep20 = "-GT0001-"
|
||||
|
||||
nominalDialTimeout = time.Second * 30
|
||||
minDialTimeout = 5 * time.Second
|
||||
|
||||
// Justification for set bits follows.
|
||||
//
|
||||
// Extension protocol ([5]|=0x10):
|
||||
// http://www.bittorrent.org/beps/bep_0010.html
|
||||
//
|
||||
// Fast Extension ([7]|=0x04):
|
||||
// http://bittorrent.org/beps/bep_0006.html.
|
||||
// Disabled until AllowedFast is implemented.
|
||||
//
|
||||
// DHT ([7]|=1):
|
||||
// http://www.bittorrent.org/beps/bep_0005.html
|
||||
defaultExtensionBytes = "\x00\x00\x00\x00\x00\x10\x00\x01"
|
||||
|
||||
socketsPerTorrent = 80
|
||||
torrentPeersHighWater = 200
|
||||
torrentPeersLowWater = 50
|
||||
|
||||
// Limit how long handshake can take. This is to reduce the lingering
|
||||
// impact of a few bad apples. 4s loses 1% of successful handshakes that
|
||||
// are obtained with 60s timeout, and 5% of unsuccessful handshakes.
|
||||
handshakesTimeout = 20 * time.Second
|
||||
|
||||
// These are our extended message IDs. Peers will use these values to
|
||||
// select which extension a message is intended for.
|
||||
metadataExtendedId = iota + 1 // 0 is reserved for deleting keys
|
||||
pexExtendedId
|
||||
)
|
||||
|
||||
// I could move a lot of these counters to their own file, but I suspect they
|
||||
// may be attached to a Client someday.
|
||||
var (
|
||||
unwantedChunksReceived = expvar.NewInt("chunksReceivedUnwanted")
|
||||
unexpectedChunksReceived = expvar.NewInt("chunksReceivedUnexpected")
|
||||
chunksReceived = expvar.NewInt("chunksReceived")
|
||||
|
||||
peersAddedBySource = expvar.NewMap("peersAddedBySource")
|
||||
|
||||
uploadChunksPosted = expvar.NewInt("uploadChunksPosted")
|
||||
unexpectedCancels = expvar.NewInt("unexpectedCancels")
|
||||
postedCancels = expvar.NewInt("postedCancels")
|
||||
duplicateConnsAvoided = expvar.NewInt("duplicateConnsAvoided")
|
||||
|
||||
pieceHashedCorrect = expvar.NewInt("pieceHashedCorrect")
|
||||
pieceHashedNotCorrect = expvar.NewInt("pieceHashedNotCorrect")
|
||||
|
||||
unsuccessfulDials = expvar.NewInt("dialSuccessful")
|
||||
successfulDials = expvar.NewInt("dialUnsuccessful")
|
||||
|
||||
acceptUTP = expvar.NewInt("acceptUTP")
|
||||
acceptTCP = expvar.NewInt("acceptTCP")
|
||||
acceptReject = expvar.NewInt("acceptReject")
|
||||
|
||||
peerExtensions = expvar.NewMap("peerExtensions")
|
||||
completedHandshakeConnectionFlags = expvar.NewMap("completedHandshakeConnectionFlags")
|
||||
// Count of connections to peer with same client ID.
|
||||
connsToSelf = expvar.NewInt("connsToSelf")
|
||||
// Number of completed connections to a client we're already connected with.
|
||||
duplicateClientConns = expvar.NewInt("duplicateClientConns")
|
||||
receivedMessageTypes = expvar.NewMap("receivedMessageTypes")
|
||||
receivedKeepalives = expvar.NewInt("receivedKeepalives")
|
||||
supportedExtensionMessages = expvar.NewMap("supportedExtensionMessages")
|
||||
postedMessageTypes = expvar.NewMap("postedMessageTypes")
|
||||
postedKeepalives = expvar.NewInt("postedKeepalives")
|
||||
// Requests received for pieces we don't have.
|
||||
requestsReceivedForMissingPieces = expvar.NewInt("requestsReceivedForMissingPieces")
|
||||
|
||||
// Track the effectiveness of Torrent.connPieceInclinationPool.
|
||||
pieceInclinationsReused = expvar.NewInt("pieceInclinationsReused")
|
||||
pieceInclinationsNew = expvar.NewInt("pieceInclinationsNew")
|
||||
pieceInclinationsPut = expvar.NewInt("pieceInclinationsPut")
|
||||
)
|
14
misc.go
14
misc.go
@ -1,26 +1,12 @@
|
||||
package torrent
|
||||
|
||||
import (
|
||||
"crypto"
|
||||
"errors"
|
||||
"time"
|
||||
|
||||
"github.com/anacrolix/torrent/metainfo"
|
||||
pp "github.com/anacrolix/torrent/peer_protocol"
|
||||
)
|
||||
|
||||
const (
|
||||
pieceHash = crypto.SHA1
|
||||
maxRequests = 250 // Maximum pending requests we allow peers to send us.
|
||||
defaultChunkSize = 0x4000 // 16KiB
|
||||
// Peer ID client identifier prefix. We'll update this occasionally to
|
||||
// reflect changes to client behaviour that other clients may depend on.
|
||||
// Also see `extendedHandshakeClientVersion`.
|
||||
bep20 = "-GT0001-"
|
||||
nominalDialTimeout = time.Second * 30
|
||||
minDialTimeout = 5 * time.Second
|
||||
)
|
||||
|
||||
type chunkSpec struct {
|
||||
Begin, Length pp.Integer
|
||||
}
|
||||
|
@ -2,7 +2,6 @@ package torrent
|
||||
|
||||
import (
|
||||
"container/heap"
|
||||
"expvar"
|
||||
"fmt"
|
||||
"io"
|
||||
"log"
|
||||
@ -95,12 +94,6 @@ type Torrent struct {
|
||||
connPieceInclinationPool sync.Pool
|
||||
}
|
||||
|
||||
var (
|
||||
pieceInclinationsReused = expvar.NewInt("pieceInclinationsReused")
|
||||
pieceInclinationsNew = expvar.NewInt("pieceInclinationsNew")
|
||||
pieceInclinationsPut = expvar.NewInt("pieceInclinationsPut")
|
||||
)
|
||||
|
||||
func (t *Torrent) setDisplayName(dn string) {
|
||||
t.displayName = dn
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user