execComputation and applyMessage unification

This commit is contained in:
andri lim 2019-03-19 23:54:54 +07:00
parent be79bc8740
commit b6587bddfd
No known key found for this signature in database
GPG Key ID: 31702AE10541E6B9
2 changed files with 25 additions and 39 deletions

View File

@ -162,41 +162,46 @@ proc transferBalance(computation: var BaseComputation, opCode: static[Op]): bool
result = true result = true
proc executeOpcodes*(computation: var BaseComputation) proc executeOpcodes*(computation: var BaseComputation) {.gcsafe.}
proc applyMessage(fork: Fork, computation: var BaseComputation, opCode: static[Op]) = proc applyMessage*(computation: var BaseComputation, opCode: static[Op]): bool =
var snapshot = computation.snapshot() var snapshot = computation.snapshot()
defer: snapshot.dispose() defer: snapshot.dispose()
when opCode in {CallCode, Call, Create}: when opCode in {CallCode, Call, Create}:
if not computation.transferBalance(opCode): if not computation.transferBalance(opCode):
snapshot.revert() snapshot.revert()
return return
if computation.gasMeter.gasRemaining < 0: if computation.gasMeter.gasRemaining < 0:
snapshot.commit() snapshot.commit()
return return
var success = true
try: try:
executeOpcodes(computation) executeOpcodes(computation)
success = not computation.isError result = not computation.isError
except VMError: except VMError:
success = false result = false
debug "applyMessage failed", debug "applyMessage VM Error",
msg = getCurrentExceptionMsg(),
depth = computation.msg.depth
except ValueError:
result = false
debug "applyMessage Value Error",
msg = getCurrentExceptionMsg(), msg = getCurrentExceptionMsg(),
depth = computation.msg.depth depth = computation.msg.depth
if success and computation.msg.isCreate: if result and computation.msg.isCreate:
var fork = computation.getFork
let contractFailed = not computation.writeContract(fork) let contractFailed = not computation.writeContract(fork)
success = not(contractFailed and fork == FkHomestead) result = not(contractFailed and fork == FkHomestead)
if success: if result:
snapshot.commit() snapshot.commit()
else: else:
snapshot.revert(true) snapshot.revert(true)
proc addChildComputation(fork: Fork, computation: var BaseComputation, child: BaseComputation) = proc addChildComputation(computation: var BaseComputation, child: BaseComputation) =
if child.isError: if child.isError:
if child.msg.isCreate: if child.msg.isCreate:
computation.returnData = child.output computation.returnData = child.output
@ -216,9 +221,8 @@ proc addChildComputation(fork: Fork, computation: var BaseComputation, child: Ba
proc applyChildComputation*(parentComp, childComp: var BaseComputation, opCode: static[Op]) = proc applyChildComputation*(parentComp, childComp: var BaseComputation, opCode: static[Op]) =
## Apply the vm message childMsg as a child computation. ## Apply the vm message childMsg as a child computation.
var fork = parentComp.getFork discard childComp.applyMessage(opCode)
fork.applyMessage(childComp, opCode) parentComp.addChildComputation(childComp)
fork.addChildComputation(parentComp, childComp)
proc registerAccountForDeletion*(c: var BaseComputation, beneficiary: EthAddress) = proc registerAccountForDeletion*(c: var BaseComputation, beneficiary: EthAddress) =
if c.msg.storageAddress in c.accountsToDelete: if c.msg.storageAddress in c.accountsToDelete:

View File

@ -64,36 +64,18 @@ proc setupComputation*(vmState: BaseVMState, tx: Transaction, sender, recipient:
doAssert result.isOriginComputation doAssert result.isOriginComputation
proc execComputation*(computation: var BaseComputation): bool = proc execComputation*(computation: var BaseComputation): bool =
var snapshot = computation.snapshot() if computation.msg.isCreate:
defer: snapshot.dispose() result = computation.applyMessage(Create)
else:
result = computation.applyMessage(Call)
computation.vmState.mutateStateDB: computation.vmState.mutateStateDB:
db.subBalance(computation.msg.origin, computation.msg.value) for deletedAccount in computation.getAccountsForDeletion:
db.addBalance(computation.msg.storageAddress, computation.msg.value) db.deleteAccount deletedAccount
try:
computation.executeOpcodes()
computation.vmState.mutateStateDB:
for deletedAccount in computation.getAccountsForDeletion:
db.deleteAccount deletedAccount
result = not computation.isError
except VMError:
result = false
debug "execComputation() VM Error", error = getCurrentExceptionMsg()
except ValueError:
result = false
debug "execComputation() Value Error", msg = getCurrentExceptionMsg()
if result and computation.msg.isCreate:
let fork = computation.getFork
let contractFailed = not computation.writeContract(fork)
result = not(contractFailed and fork == FkHomestead)
if result: if result:
snapshot.commit()
computation.vmState.addLogs(computation.logEntries) computation.vmState.addLogs(computation.logEntries)
else: else:
snapshot.revert()
if computation.tracingEnabled: computation.traceError() if computation.tracingEnabled: computation.traceError()
proc refundGas*(computation: BaseComputation, tx: Transaction, sender: EthAddress): GasInt = proc refundGas*(computation: BaseComputation, tx: Transaction, sender: EthAddress): GasInt =