erigon-pulse/cl/pool/operation_pool.go

61 lines
1.4 KiB
Go
Raw Normal View History

2023-09-27 17:09:36 +00:00
package pool
import (
"time"
2023-09-27 17:09:36 +00:00
"github.com/ledgerwatch/erigon/cl/phase1/core/state/lru"
)
const lifeSpan = 30 * time.Minute
var operationsMultiplier = 20 // Cap the amount of cached element to max_operations_per_block * operations_multiplier
2023-09-27 17:09:36 +00:00
type OperationPool[K comparable, T any] struct {
pool *lru.Cache[K, T] // Map the Signature to the underlying object
recentlySeen map[K]time.Time
lastPruned time.Time
2023-09-27 17:09:36 +00:00
}
func NewOperationPool[K comparable, T any](maxOperationsPerBlock int, matricName string) *OperationPool[K, T] {
pool, err := lru.New[K, T](matricName, maxOperationsPerBlock*operationsMultiplier)
2023-09-27 17:09:36 +00:00
if err != nil {
panic(err)
}
return &OperationPool[K, T]{
pool: pool,
recentlySeen: make(map[K]time.Time),
}
2023-09-27 17:09:36 +00:00
}
func (o *OperationPool[K, T]) Insert(k K, operation T) {
if _, ok := o.recentlySeen[k]; ok {
return
}
o.pool.Add(k, operation)
o.recentlySeen[k] = time.Now()
if time.Since(o.lastPruned) > lifeSpan {
deleteList := make([]K, 0, len(o.recentlySeen))
for k, t := range o.recentlySeen {
if time.Since(t) > lifeSpan {
deleteList = append(deleteList, k)
}
}
for _, k := range deleteList {
delete(o.recentlySeen, k)
}
o.lastPruned = time.Now()
}
2023-09-27 17:09:36 +00:00
}
func (o *OperationPool[K, T]) DeleteIfExist(k K) (removed bool) {
return o.pool.Remove(k)
2023-09-27 17:09:36 +00:00
}
func (o *OperationPool[K, T]) Has(k K) (hash bool) {
return o.pool.Contains(k)
}
func (o *OperationPool[K, T]) Raw() []T {
2023-09-27 17:09:36 +00:00
return o.pool.Values()
}