core: fix wrong data being read in interops (part of #501)
When74590551
introduced this code we had no proper caching layer, so there were these strange fallbacks in the code.fc0031e5
should'd removed them, but failed to do so, so do it now and fix processing of transactions that touch storage for the same key (address) in the same block.
This commit is contained in:
parent
2b0ad6146d
commit
c034aae378
1 changed files with 1 additions and 10 deletions
|
@ -410,9 +410,6 @@ func (ic *interopContext) storageDelete(v *vm.VM) error {
|
|||
}
|
||||
key := v.Estack().Pop().Bytes()
|
||||
si := getStorageItemFromStore(ic.mem, stc.ScriptHash, key)
|
||||
if si == nil {
|
||||
si = ic.bc.GetStorageItem(stc.ScriptHash, key)
|
||||
}
|
||||
if si != nil && si.IsConst {
|
||||
return errors.New("storage item is constant")
|
||||
}
|
||||
|
@ -432,9 +429,6 @@ func (ic *interopContext) storageGet(v *vm.VM) error {
|
|||
}
|
||||
key := v.Estack().Pop().Bytes()
|
||||
si := getStorageItemFromStore(ic.mem, stc.ScriptHash, key)
|
||||
if si == nil {
|
||||
si = ic.bc.GetStorageItem(stc.ScriptHash, key)
|
||||
}
|
||||
if si != nil && si.Value != nil {
|
||||
v.Estack().PushVal(si.Value)
|
||||
} else {
|
||||
|
@ -478,12 +472,9 @@ func (ic *interopContext) putWithContextAndFlags(stc *StorageContext, key []byte
|
|||
return err
|
||||
}
|
||||
si := getStorageItemFromStore(ic.mem, stc.ScriptHash, key)
|
||||
if si == nil {
|
||||
si = ic.bc.GetStorageItem(stc.ScriptHash, key)
|
||||
if si == nil {
|
||||
si = &StorageItem{}
|
||||
}
|
||||
}
|
||||
if si.IsConst {
|
||||
return errors.New("storage item exists and is read-only")
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue