forked from folbricht/desync
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnullchunk.go
23 lines (21 loc) · 821 Bytes
/
nullchunk.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
package desync
// NullChunk is used in places where it's common to see requests for chunks
// containing only 0-bytes. When a chunked file has large areas of 0-bytes,
// the chunking algorithm does not produce split boundaries, which results
// in many chunks of 0-bytes of size MAX (max chunk size). The NullChunk can be
// used to make requesting this kind of chunk more efficient by serving it
// from memory, rather that request it from disk or network and decompress
// it repeatedly.
type NullChunk struct {
Data []byte
ID ChunkID
}
// NewNullChunk returns an initialized chunk consisting of 0-bytes of 'size'
// which must mach the max size used in the index to be effective
func NewNullChunk(size uint64) *NullChunk {
b := make([]byte, int(size))
return &NullChunk{
Data: b,
ID: Digest.Sum(b),
}
}