Fixed most of the tests
This commit is contained in:
		| @@ -10,21 +10,27 @@ import ( | ||||
|  | ||||
| type Execution struct { | ||||
| 	vm                VirtualMachine | ||||
| 	closure           *Closure | ||||
| 	address, input    []byte | ||||
| 	gas, price, value *big.Int | ||||
| 	Gas, price, value *big.Int | ||||
| 	object            *ethstate.StateObject | ||||
| } | ||||
|  | ||||
| func NewExecution(vm VirtualMachine, address, input []byte, gas, gasPrice, value *big.Int) *Execution { | ||||
| 	return &Execution{vm: vm, address: address, input: input, gas: gas, price: gasPrice, value: value} | ||||
| 	return &Execution{vm: vm, address: address, input: input, Gas: gas, price: gasPrice, value: value} | ||||
| } | ||||
|  | ||||
| func (self *Execution) Addr() []byte { | ||||
| 	return self.address | ||||
| } | ||||
|  | ||||
| func (self *Execution) Exec(codeAddr []byte, caller ClosureRef) (ret []byte, err error) { | ||||
| func (self *Execution) Exec(codeAddr []byte, caller ClosureRef) ([]byte, error) { | ||||
| 	// Retrieve the executing code | ||||
| 	code := self.vm.Env().State().GetCode(codeAddr) | ||||
|  | ||||
| 	return self.exec(code, codeAddr, caller) | ||||
| } | ||||
|  | ||||
| func (self *Execution) exec(code, caddr []byte, caller ClosureRef) (ret []byte, err error) { | ||||
| 	env := self.vm.Env() | ||||
|  | ||||
| 	snapshot := env.State().Copy() | ||||
| @@ -44,7 +50,7 @@ func (self *Execution) Exec(codeAddr []byte, caller ClosureRef) (ret []byte, err | ||||
|  | ||||
| 	object := caller.Object() | ||||
| 	if object.Balance.Cmp(self.value) < 0 { | ||||
| 		caller.ReturnGas(self.gas, self.price) | ||||
| 		caller.ReturnGas(self.Gas, self.price) | ||||
|  | ||||
| 		err = fmt.Errorf("Insufficient funds to transfer value. Req %v, has %v", self.value, object.Balance) | ||||
| 	} else { | ||||
| @@ -55,23 +61,23 @@ func (self *Execution) Exec(codeAddr []byte, caller ClosureRef) (ret []byte, err | ||||
| 		stateObject.AddAmount(self.value) | ||||
|  | ||||
| 		// Pre-compiled contracts (address.go) 1, 2 & 3. | ||||
| 		naddr := ethutil.BigD(codeAddr).Uint64() | ||||
| 		naddr := ethutil.BigD(caddr).Uint64() | ||||
| 		if p := Precompiled[naddr]; p != nil { | ||||
| 			if self.gas.Cmp(p.Gas) >= 0 { | ||||
| 			if self.Gas.Cmp(p.Gas) >= 0 { | ||||
| 				ret = p.Call(self.input) | ||||
| 				self.vm.Printf("NATIVE_FUNC(%x) => %x", naddr, ret) | ||||
| 			} | ||||
| 		} else { | ||||
| 			// Create a new callable closure | ||||
| 			c := NewClosure(msg, caller, stateObject, code, self.Gas, self.price) | ||||
| 			c.exe = self | ||||
|  | ||||
| 			if self.vm.Depth() == MaxCallDepth { | ||||
| 				return nil, fmt.Errorf("Max call depth exceeded (%d)", MaxCallDepth) | ||||
| 				c.UseGas(c.Gas) | ||||
|  | ||||
| 				return c.Return(nil), fmt.Errorf("Max call depth exceeded (%d)", MaxCallDepth) | ||||
| 			} | ||||
|  | ||||
| 			// Retrieve the executing code | ||||
| 			code := env.State().GetCode(codeAddr) | ||||
|  | ||||
| 			// Create a new callable closure | ||||
| 			c := NewClosure(msg, caller, stateObject, code, self.gas, self.price) | ||||
| 			c.exe = self | ||||
| 			// Executer the closure and get the return value (if any) | ||||
| 			ret, _, err = c.Call(self.vm, self.input) | ||||
|  | ||||
| @@ -81,3 +87,7 @@ func (self *Execution) Exec(codeAddr []byte, caller ClosureRef) (ret []byte, err | ||||
|  | ||||
| 	return | ||||
| } | ||||
|  | ||||
| func (self *Execution) Create(caller ClosureRef) (ret []byte, err error) { | ||||
| 	return self.exec(self.input, nil, caller) | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user