forked from TrueCloudLab/neoneo-go
Merge pull request #996 from nspcc-dev/dont-change-cached-until-persist-2.x
dao: split GetStorageItem for Cached into external and internal versions
This commit is contained in:
commit
90536d533d
1 changed files with 22 additions and 2 deletions
|
@ -261,6 +261,18 @@ func copyItem(si *state.StorageItem) *state.StorageItem {
|
||||||
|
|
||||||
// GetStorageItem returns StorageItem if it exists in the given store.
|
// GetStorageItem returns StorageItem if it exists in the given store.
|
||||||
func (cd *Cached) GetStorageItem(scripthash util.Uint160, key []byte) *state.StorageItem {
|
func (cd *Cached) GetStorageItem(scripthash util.Uint160, key []byte) *state.StorageItem {
|
||||||
|
return cd.getStorageItemInt(scripthash, key, true)
|
||||||
|
}
|
||||||
|
|
||||||
|
// getStorageItemNoCache is non-caching GetStorageItem version.
|
||||||
|
func (cd *Cached) getStorageItemNoCache(scripthash util.Uint160, key []byte) *state.StorageItem {
|
||||||
|
return cd.getStorageItemInt(scripthash, key, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
// getStorageItemInt is an internal GetStorageItem that can either cache read
|
||||||
|
// (for upper Cached) or not do so (for lower Cached that should only be updated
|
||||||
|
// on persist).
|
||||||
|
func (cd *Cached) getStorageItemInt(scripthash util.Uint160, key []byte, putToCache bool) *state.StorageItem {
|
||||||
ti := cd.storage.getItem(scripthash, key)
|
ti := cd.storage.getItem(scripthash, key)
|
||||||
if ti != nil {
|
if ti != nil {
|
||||||
if ti.State == delOp {
|
if ti.State == delOp {
|
||||||
|
@ -269,9 +281,17 @@ func (cd *Cached) GetStorageItem(scripthash util.Uint160, key []byte) *state.Sto
|
||||||
return copyItem(&ti.StorageItem)
|
return copyItem(&ti.StorageItem)
|
||||||
}
|
}
|
||||||
|
|
||||||
si := cd.DAO.GetStorageItem(scripthash, key)
|
// Gets shouldn't affect lower Cached.storage until Persist.
|
||||||
|
var si *state.StorageItem
|
||||||
|
if lowerCached, ok := cd.DAO.(*Cached); ok {
|
||||||
|
si = lowerCached.getStorageItemNoCache(scripthash, key)
|
||||||
|
} else {
|
||||||
|
si = cd.DAO.GetStorageItem(scripthash, key)
|
||||||
|
}
|
||||||
if si != nil {
|
if si != nil {
|
||||||
|
if putToCache {
|
||||||
cd.storage.put(scripthash, key, getOp, si)
|
cd.storage.put(scripthash, key, getOp, si)
|
||||||
|
}
|
||||||
return copyItem(si)
|
return copyItem(si)
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
|
Loading…
Reference in a new issue