You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
83 lines
1.5 KiB
83 lines
1.5 KiB
3 years ago
|
package local_cache
|
||
|
|
||
|
import (
|
||
|
"github.com/ethereum/go-ethereum/ethdb"
|
||
|
"sync"
|
||
|
)
|
||
|
|
||
|
type LocalCacheBatch struct {
|
||
|
db *LocalCacheDatabase
|
||
|
lock sync.Mutex
|
||
|
|
||
|
size int
|
||
|
batchWriteKey [][]byte
|
||
|
batchWriteValue [][]byte
|
||
|
batchDeleteKey [][]byte
|
||
|
}
|
||
|
|
||
|
func newLocalCacheBatch(db *LocalCacheDatabase) *LocalCacheBatch {
|
||
|
return &LocalCacheBatch{db: db}
|
||
|
}
|
||
|
|
||
|
func (b *LocalCacheBatch) Put(key []byte, value []byte) error {
|
||
|
b.lock.Lock()
|
||
|
defer b.lock.Unlock()
|
||
|
|
||
|
b.batchWriteKey = append(b.batchWriteKey, key)
|
||
|
b.batchWriteValue = append(b.batchWriteValue, value)
|
||
|
b.size += len(key) + len(value)
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (b *LocalCacheBatch) Delete(key []byte) error {
|
||
|
b.lock.Lock()
|
||
|
defer b.lock.Unlock()
|
||
|
|
||
|
b.batchDeleteKey = append(b.batchDeleteKey, key)
|
||
|
b.size += len(key)
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (b *LocalCacheBatch) ValueSize() int {
|
||
|
return b.size
|
||
|
}
|
||
|
|
||
|
func (b *LocalCacheBatch) Write() error {
|
||
|
b.lock.Lock()
|
||
|
defer b.lock.Unlock()
|
||
|
|
||
|
return b.db.batchWrite(b)
|
||
|
}
|
||
|
|
||
|
func (b *LocalCacheBatch) Reset() {
|
||
|
b.lock.Lock()
|
||
|
defer b.lock.Unlock()
|
||
|
|
||
|
b.batchWriteKey = b.batchWriteKey[:0]
|
||
|
b.batchWriteValue = b.batchWriteValue[:0]
|
||
|
b.batchDeleteKey = b.batchDeleteKey[:0]
|
||
|
b.size = 0
|
||
|
}
|
||
|
|
||
|
func (b *LocalCacheBatch) Replay(w ethdb.KeyValueWriter) error {
|
||
|
if len(b.batchWriteKey) > 0 {
|
||
|
for i, key := range b.batchWriteKey {
|
||
|
err := w.Put(key, b.batchWriteValue[i])
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if len(b.batchDeleteKey) > 0 {
|
||
|
for _, key := range b.batchDeleteKey {
|
||
|
err := w.Delete(key)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return nil
|
||
|
}
|