forked from TrueCloudLab/neoneo-go
core: drop old transfer data during state jump
This commit is contained in:
parent
3a2b800e5f
commit
805d81e441
1 changed files with 8 additions and 2 deletions
|
@ -566,13 +566,19 @@ func (bc *Blockchain) jumpToStateInternal(p uint32, stage stateJumpStage) error
|
||||||
// After current state is updated, we need to remove outdated state-related data if so.
|
// After current state is updated, we need to remove outdated state-related data if so.
|
||||||
// The only outdated data we might have is genesis-related data, so check it.
|
// The only outdated data we might have is genesis-related data, so check it.
|
||||||
if p-bc.config.MaxTraceableBlocks > 0 {
|
if p-bc.config.MaxTraceableBlocks > 0 {
|
||||||
cache := bc.dao.GetWrapped()
|
cache := bc.dao.GetWrapped().(*dao.Simple)
|
||||||
writeBuf.Reset()
|
writeBuf.Reset()
|
||||||
err := cache.DeleteBlock(bc.headerHashes[0], writeBuf)
|
err := cache.DeleteBlock(bc.headerHashes[0], writeBuf)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("failed to remove outdated state data for the genesis block: %w", err)
|
return fmt.Errorf("failed to remove outdated state data for the genesis block: %w", err)
|
||||||
}
|
}
|
||||||
// TODO: remove NEP-17 transfers and NEP-17 transfer info for genesis block, #2096 related.
|
prefixes := []byte{byte(storage.STNEP11Transfers), byte(storage.STNEP17Transfers), byte(storage.STTokenTransferInfo)}
|
||||||
|
for i := range prefixes {
|
||||||
|
cache.Store.Seek(storage.SeekRange{Prefix: prefixes[i : i+1]}, func(k, v []byte) bool {
|
||||||
|
_ = cache.Store.Delete(k) // It's MemCachedStore which never returns an error.
|
||||||
|
return true
|
||||||
|
})
|
||||||
|
}
|
||||||
_, err = cache.Persist()
|
_, err = cache.Persist()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("failed to drop genesis block state: %w", err)
|
return fmt.Errorf("failed to drop genesis block state: %w", err)
|
||||||
|
|
Loading…
Reference in a new issue