mirror of
https://github.com/0glabs/0g-chain.git
synced 2025-04-02 23:05:18 +00:00
Merge pull request #132 from 0glabs/issue-gas-price-and-block-build
pref: skiplist using static rand generator
This commit is contained in:
commit
8d5e81154a
@ -2,7 +2,9 @@ package app
|
||||
|
||||
import (
|
||||
"context"
|
||||
"math/rand"
|
||||
"sync"
|
||||
"time"
|
||||
|
||||
"fmt"
|
||||
"math"
|
||||
@ -27,6 +29,9 @@ var (
|
||||
errMempoolTooManyTxs = errors.New("tx sender has too many txs in mempool")
|
||||
errMempoolIsFull = errors.New("mempool is full")
|
||||
errTxInMempool = errors.New("tx already in mempool")
|
||||
|
||||
staticSrc = rand.NewSource(time.Now().UnixNano())
|
||||
staticRng = rand.New(staticSrc)
|
||||
)
|
||||
|
||||
// PriorityNonceMempool is a mempool implementation that stores txs
|
||||
@ -160,6 +165,8 @@ func NewPriorityMempool(opts ...PriorityNonceMempoolOption) *PriorityNonceMempoo
|
||||
txRecord: make(map[txMeta]struct{}),
|
||||
}
|
||||
|
||||
mp.priorityIndex.SetRandSource(staticSrc)
|
||||
|
||||
for _, opt := range opts {
|
||||
opt(mp)
|
||||
}
|
||||
@ -218,6 +225,7 @@ func (mp *PriorityNonceMempool) Insert(ctx context.Context, tx sdk.Tx) error {
|
||||
senderIndex = skiplist.New(skiplist.LessThanFunc(func(a, b any) int {
|
||||
return skiplist.Uint64.Compare(b.(txMeta).nonce, a.(txMeta).nonce)
|
||||
}))
|
||||
senderIndex.SetRandSource(staticRng)
|
||||
|
||||
// initialize sender index if not found
|
||||
mp.senderIndices[txInfo.Sender] = senderIndex
|
||||
@ -306,7 +314,7 @@ func (mp *PriorityNonceMempool) doInsert(newKey txMeta, tx sdk.Tx, incrCnt bool)
|
||||
senderIndex = skiplist.New(skiplist.LessThanFunc(func(a, b any) int {
|
||||
return skiplist.Uint64.Compare(b.(txMeta).nonce, a.(txMeta).nonce)
|
||||
}))
|
||||
|
||||
senderIndex.SetRandSource(staticRng)
|
||||
// initialize sender index if not found
|
||||
mp.senderIndices[newKey.sender] = senderIndex
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user