-
Notifications
You must be signed in to change notification settings - Fork 179
/
chunk_statuses.go
69 lines (59 loc) · 2.02 KB
/
chunk_statuses.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
package stdmap
import (
"fmt"
"github.com/onflow/flow-go/model/flow"
"github.com/onflow/flow-go/model/verification"
)
// ChunkStatuses is an implementation of in-memory storage for maintaining the chunk status data objects.
type ChunkStatuses struct {
*Backend
}
func NewChunkStatuses(limit uint) *ChunkStatuses {
return &ChunkStatuses{
Backend: NewBackend(WithLimit(limit)),
}
}
func chunkStatus(entity flow.Entity) *verification.ChunkStatus {
chunk, ok := entity.(*verification.ChunkStatus)
if !ok {
panic(fmt.Sprintf("could not convert the entity into chunk status from the mempool: %v", entity))
}
return chunk
}
// ByID returns a chunk status by its chunk ID.
// There is a one-to-one correspondence between the chunk statuses in memory, and
// their chunk ID.
func (cs ChunkStatuses) ByID(chunkID flow.Identifier) (*verification.ChunkStatus, bool) {
entity, exists := cs.Backend.ByID(chunkID)
if !exists {
return nil, false
}
status := chunkStatus(entity)
return status, true
}
// Add provides insertion functionality into the memory pool.
// The insertion is only successful if there is no duplicate status with the same
// chunk ID in the memory. Otherwise, it aborts the insertion and returns false.
func (cs *ChunkStatuses) Add(status *verification.ChunkStatus) bool {
return cs.Backend.Add(status)
}
// Rem provides deletion functionality from the memory pool.
// If there is a chunk status with this ID, Rem removes it and returns true.
// Otherwise it returns false.
func (cs *ChunkStatuses) Rem(chunkID flow.Identifier) bool {
return cs.Backend.Rem(chunkID)
}
// All returns all chunk statuses stored in this memory pool.
func (cs ChunkStatuses) All() []*verification.ChunkStatus {
all := cs.Backend.All()
statuses := make([]*verification.ChunkStatus, 0, len(all))
for _, entity := range all {
chunk := chunkStatus(entity)
statuses = append(statuses, chunk)
}
return statuses
}
// Size returns total number of chunk statuses in the memory pool.
func (cs ChunkStatuses) Size() uint {
return cs.Backend.Size()
}