aboutsummaryrefslogtreecommitdiffstats
path: root/xeth/xeth.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2015-02-01 22:29:57 +0800
committerobscuren <geffobscura@gmail.com>2015-02-01 22:29:57 +0800
commitd52878c744fd7acce727feb41c2d4296e56826d3 (patch)
tree6b9f101f57a5ac0902b80f252214caa5ed63eb8c /xeth/xeth.go
parent0d97c3ce1322083fb9683a5afec004b2626b620a (diff)
downloaddexon-d52878c744fd7acce727feb41c2d4296e56826d3.tar
dexon-d52878c744fd7acce727feb41c2d4296e56826d3.tar.gz
dexon-d52878c744fd7acce727feb41c2d4296e56826d3.tar.bz2
dexon-d52878c744fd7acce727feb41c2d4296e56826d3.tar.lz
dexon-d52878c744fd7acce727feb41c2d4296e56826d3.tar.xz
dexon-d52878c744fd7acce727feb41c2d4296e56826d3.tar.zst
dexon-d52878c744fd7acce727feb41c2d4296e56826d3.zip
Removed some VMEnv & Added VmType() to vm.Environment
Diffstat (limited to 'xeth/xeth.go')
-rw-r--r--xeth/xeth.go24
1 files changed, 14 insertions, 10 deletions
diff --git a/xeth/xeth.go b/xeth/xeth.go
index a65fa1331..0e71a0ed9 100644
--- a/xeth/xeth.go
+++ b/xeth/xeth.go
@@ -224,18 +224,22 @@ func (self *XEth) Call(toStr, valueStr, gasStr, gasPriceStr, dataStr string) (st
}
var (
- statedb = self.chainManager.TransState()
- initiator = state.NewStateObject(self.eth.KeyManager().KeyPair().Address(), self.eth.Db())
- block = self.chainManager.CurrentBlock()
- to = statedb.GetOrNewStateObject(fromHex(toStr))
- data = fromHex(dataStr)
- gas = ethutil.Big(gasStr)
- price = ethutil.Big(gasPriceStr)
- value = ethutil.Big(valueStr)
+ statedb = self.chainManager.TransState()
+ key = self.eth.KeyManager().KeyPair()
+ from = state.NewStateObject(key.Address(), self.eth.Db())
+ block = self.chainManager.CurrentBlock()
+ to = statedb.GetOrNewStateObject(fromHex(toStr))
+ data = fromHex(dataStr)
+ gas = ethutil.Big(gasStr)
+ price = ethutil.Big(gasPriceStr)
+ value = ethutil.Big(valueStr)
)
- vmenv := NewEnv(self.chainManager, statedb, block, value, initiator.Address())
- res, err := vmenv.Call(initiator, to.Address(), data, gas, price, value)
+ msg := types.NewTransactionMessage(fromHex(toStr), value, gas, price, data)
+ msg.Sign(key.PrivateKey)
+ vmenv := core.NewEnv(statedb, self.chainManager, msg, block)
+
+ res, err := vmenv.Call(from, to.Address(), data, gas, price, value)
if err != nil {
return "", err
}