Files
prysm/beacon-chain/slasher/queue.go
terence 774b9a7159 Migrate Prysm repo to Offchain Labs organization ahead of Pectra V6 (#15140)
* Migrate Prysm repo to Offchain Labs organization ahead of Pectra upgrade v6

* Replace prysmaticlabs with OffchainLabs on general markdowns

* Update mock

* Gazelle and add mock.go to excluded generated mock file
2025-04-10 15:40:39 +00:00

84 lines
1.9 KiB
Go

package slasher
import (
"sync"
slashertypes "github.com/OffchainLabs/prysm/v6/beacon-chain/slasher/types"
)
// Struct for handling a thread-safe list of indexed attestation wrappers.
type attestationsQueue struct {
sync.RWMutex
items []*slashertypes.IndexedAttestationWrapper
}
// Struct for handling a thread-safe list of beacon block header wrappers.
type blocksQueue struct {
lock sync.RWMutex
items []*slashertypes.SignedBlockHeaderWrapper
}
func newAttestationsQueue() *attestationsQueue {
return &attestationsQueue{
items: make([]*slashertypes.IndexedAttestationWrapper, 0),
}
}
func newBlocksQueue() *blocksQueue {
return &blocksQueue{
items: make([]*slashertypes.SignedBlockHeaderWrapper, 0),
}
}
func (q *attestationsQueue) push(att *slashertypes.IndexedAttestationWrapper) {
q.Lock()
defer q.Unlock()
q.items = append(q.items, att)
}
func (q *attestationsQueue) dequeue() []*slashertypes.IndexedAttestationWrapper {
q.Lock()
defer q.Unlock()
items := q.items
q.items = make([]*slashertypes.IndexedAttestationWrapper, 0)
return items
}
func (q *attestationsQueue) size() int {
q.RLock()
defer q.RUnlock()
return len(q.items)
}
func (q *attestationsQueue) extend(atts []*slashertypes.IndexedAttestationWrapper) {
q.Lock()
defer q.Unlock()
q.items = append(q.items, atts...)
}
func (q *blocksQueue) push(blk *slashertypes.SignedBlockHeaderWrapper) {
q.lock.Lock()
defer q.lock.Unlock()
q.items = append(q.items, blk)
}
func (q *blocksQueue) dequeue() []*slashertypes.SignedBlockHeaderWrapper {
q.lock.Lock()
defer q.lock.Unlock()
items := q.items
q.items = make([]*slashertypes.SignedBlockHeaderWrapper, 0)
return items
}
func (q *blocksQueue) size() int {
q.lock.RLock()
defer q.lock.RUnlock()
return len(q.items)
}
func (q *blocksQueue) extend(blks []*slashertypes.SignedBlockHeaderWrapper) {
q.lock.Lock()
defer q.lock.Unlock()
q.items = append(q.items, blks...)
}