|
|
@ -253,24 +253,20 @@ func (self *StateTransition) Eval(script []byte, context *StateObject) (ret []by |
|
|
|
Value: self.value, |
|
|
|
Value: self.value, |
|
|
|
}) |
|
|
|
}) |
|
|
|
vm.Verbose = true |
|
|
|
vm.Verbose = true |
|
|
|
ret, _, err = closure.Call(vm, self.data, nil) |
|
|
|
|
|
|
|
deepErr = vm.err != nil |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* |
|
|
|
ret, err, deepErr = Call(vm, closure, self.data) |
|
|
|
var testAddr = ethutil.FromHex("ec4f34c97e43fbb2816cfd95e388353c7181dab1") |
|
|
|
|
|
|
|
if bytes.Compare(testAddr, context.Address()) == 0 { |
|
|
|
return |
|
|
|
trie := context.state.trie |
|
|
|
|
|
|
|
trie.NewIterator().Each(func(key string, v *ethutil.Value) { |
|
|
|
|
|
|
|
v.Decode() |
|
|
|
|
|
|
|
fmt.Printf("%x : %x\n", key, v.Str()) |
|
|
|
|
|
|
|
}) |
|
|
|
|
|
|
|
fmt.Println("\n\n") |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
*/ |
|
|
|
|
|
|
|
|
|
|
|
func Call(vm *Vm, closure *Closure, data []byte) (ret []byte, err error, deepErr bool) { |
|
|
|
|
|
|
|
ret, _, err = closure.Call(vm, data, nil) |
|
|
|
|
|
|
|
deepErr = vm.err != nil |
|
|
|
|
|
|
|
|
|
|
|
Paranoia := ethutil.Config.Paranoia |
|
|
|
Paranoia := ethutil.Config.Paranoia |
|
|
|
if Paranoia { |
|
|
|
if Paranoia { |
|
|
|
var ( |
|
|
|
var ( |
|
|
|
|
|
|
|
context = closure.object |
|
|
|
trie = context.state.trie |
|
|
|
trie = context.state.trie |
|
|
|
trie2 = ethutil.NewTrie(ethutil.Config.Db, "") |
|
|
|
trie2 = ethutil.NewTrie(ethutil.Config.Db, "") |
|
|
|
) |
|
|
|
) |
|
|
@ -282,6 +278,8 @@ func (self *StateTransition) Eval(script []byte, context *StateObject) (ret []by |
|
|
|
a := ethutil.NewValue(trie2.Root).Bytes() |
|
|
|
a := ethutil.NewValue(trie2.Root).Bytes() |
|
|
|
b := ethutil.NewValue(context.state.trie.Root).Bytes() |
|
|
|
b := ethutil.NewValue(context.state.trie.Root).Bytes() |
|
|
|
if bytes.Compare(a, b) != 0 { |
|
|
|
if bytes.Compare(a, b) != 0 { |
|
|
|
|
|
|
|
// TODO FIXME ASAP
|
|
|
|
|
|
|
|
context.state.trie = trie2 |
|
|
|
/* |
|
|
|
/* |
|
|
|
statelogger.Debugf("(o): %x\n", trie.Root) |
|
|
|
statelogger.Debugf("(o): %x\n", trie.Root) |
|
|
|
trie.NewIterator().Each(func(key string, v *ethutil.Value) { |
|
|
|
trie.NewIterator().Each(func(key string, v *ethutil.Value) { |
|
|
@ -296,7 +294,7 @@ func (self *StateTransition) Eval(script []byte, context *StateObject) (ret []by |
|
|
|
}) |
|
|
|
}) |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
|
|
|
|
|
|
|
|
return nil, fmt.Errorf("PARANOIA: Different state object roots during copy"), false |
|
|
|
//return nil, fmt.Errorf("PARANOIA: Different state object roots during copy"), false
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|