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"
|
"crypto/sha1"
|
||||||
"encoding/hex"
|
"encoding/hex"
|
||||||
"errors"
|
"errors"
|
||||||
"expvar"
|
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
@ -39,78 +38,6 @@ import (
|
|||||||
"github.com/anacrolix/torrent/tracker"
|
"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.
|
// Currently doesn't really queue, but should in the future.
|
||||||
func (cl *Client) queuePieceCheck(t *Torrent, pieceIndex int) {
|
func (cl *Client) queuePieceCheck(t *Torrent, pieceIndex int) {
|
||||||
piece := &t.pieces[pieceIndex]
|
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
|
package torrent
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"crypto"
|
|
||||||
"errors"
|
"errors"
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/anacrolix/torrent/metainfo"
|
"github.com/anacrolix/torrent/metainfo"
|
||||||
pp "github.com/anacrolix/torrent/peer_protocol"
|
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 {
|
type chunkSpec struct {
|
||||||
Begin, Length pp.Integer
|
Begin, Length pp.Integer
|
||||||
}
|
}
|
||||||
|
@ -2,7 +2,6 @@ package torrent
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"container/heap"
|
"container/heap"
|
||||||
"expvar"
|
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
@ -95,12 +94,6 @@ type Torrent struct {
|
|||||||
connPieceInclinationPool sync.Pool
|
connPieceInclinationPool sync.Pool
|
||||||
}
|
}
|
||||||
|
|
||||||
var (
|
|
||||||
pieceInclinationsReused = expvar.NewInt("pieceInclinationsReused")
|
|
||||||
pieceInclinationsNew = expvar.NewInt("pieceInclinationsNew")
|
|
||||||
pieceInclinationsPut = expvar.NewInt("pieceInclinationsPut")
|
|
||||||
)
|
|
||||||
|
|
||||||
func (t *Torrent) setDisplayName(dn string) {
|
func (t *Torrent) setDisplayName(dn string) {
|
||||||
t.displayName = dn
|
t.displayName = dn
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user