|
|
|
'use strict'
|
|
|
|
var remixCore = require('remix-core')
|
|
|
|
var TraceManager = remixCore.trace.TraceManager
|
|
|
|
var CodeManager = remixCore.code.CodeManager
|
|
|
|
var vmSendTx = require('../vmCall')
|
|
|
|
var remixLib = require('remix-lib')
|
|
|
|
|
|
|
|
var traceHelper = remixLib.helpers.trace
|
|
|
|
var global = remixLib.global
|
|
|
|
var SolidityProxy = require('../../../src/decoder/solidityProxy')
|
|
|
|
var InternalCallTree = require('../../../src/decoder/internalCallTree')
|
|
|
|
var EventManager = remixLib.EventManager
|
|
|
|
var helper = require('./helper')
|
|
|
|
|
|
|
|
module.exports = function (st, vm, privateKey, contractBytecode, compilationResult, cb) {
|
|
|
|
vmSendTx(vm, {nonce: 0, privateKey: privateKey}, null, 0, contractBytecode, function (error, txHash) {
|
|
|
|
if (error) {
|
|
|
|
st.fail(error)
|
|
|
|
} else {
|
|
|
|
global.web3.getTransaction(txHash, function (error, tx) {
|
|
|
|
if (error) {
|
|
|
|
st.fail(error)
|
|
|
|
} else {
|
|
|
|
tx.to = traceHelper.contractCreationToken('0')
|
|
|
|
var traceManager = new TraceManager()
|
|
|
|
var codeManager = new CodeManager(traceManager)
|
|
|
|
codeManager.clear()
|
|
|
|
var solidityProxy = new SolidityProxy(traceManager, codeManager)
|
|
|
|
solidityProxy.reset(compilationResult)
|
|
|
|
var debuggerEvent = new EventManager()
|
|
|
|
var callTree = new InternalCallTree(debuggerEvent, traceManager, solidityProxy, codeManager, { includeLocalVariables: true })
|
|
|
|
callTree.event.register('callTreeBuildFailed', (error) => {
|
|
|
|
st.fail(error)
|
|
|
|
})
|
|
|
|
callTree.event.register('callTreeNotReady', (reason) => {
|
|
|
|
st.fail(reason)
|
|
|
|
})
|
|
|
|
callTree.event.register('callTreeReady', (scopes, scopeStarts) => {
|
|
|
|
try {
|
|
|
|
st.equals(scopeStarts[0], '')
|
|
|
|
st.equals(scopeStarts[11], '1')
|
|
|
|
st.equals(scopeStarts[103], '2')
|
|
|
|
st.equals(scopeStarts[118], '2.1')
|
|
|
|
st.equals(scopeStarts[139], '3')
|
|
|
|
st.equals(scopeStarts[157], '4')
|
|
|
|
st.equals(scopeStarts[172], '4.1')
|
|
|
|
st.equals(scopes[''].locals['ui8'].type.typeName, 'uint8')
|
|
|
|
st.equals(scopes[''].locals['ui16'].type.typeName, 'uint16')
|
|
|
|
st.equals(scopes[''].locals['ui32'].type.typeName, 'uint32')
|
|
|
|
st.equals(scopes[''].locals['ui64'].type.typeName, 'uint64')
|
|
|
|
st.equals(scopes[''].locals['ui128'].type.typeName, 'uint128')
|
|
|
|
st.equals(scopes[''].locals['ui256'].type.typeName, 'uint256')
|
|
|
|
st.equals(scopes[''].locals['ui'].type.typeName, 'uint256')
|
|
|
|
st.equals(scopes[''].locals['i8'].type.typeName, 'int8')
|
|
|
|
st.equals(scopes[''].locals['i16'].type.typeName, 'int16')
|
|
|
|
st.equals(scopes[''].locals['i32'].type.typeName, 'int32')
|
|
|
|
st.equals(scopes[''].locals['i64'].type.typeName, 'int64')
|
|
|
|
st.equals(scopes[''].locals['i128'].type.typeName, 'int128')
|
|
|
|
st.equals(scopes[''].locals['i256'].type.typeName, 'int256')
|
|
|
|
st.equals(scopes[''].locals['i'].type.typeName, 'int256')
|
|
|
|
st.equals(scopes[''].locals['ishrink'].type.typeName, 'int32')
|
|
|
|
st.equals(scopes['2'].locals['ui8'].type.typeName, 'uint8')
|
|
|
|
st.equals(scopes['2.1'].locals['ui81'].type.typeName, 'uint8')
|
|
|
|
st.equals(scopes['3'].locals['ui81'].type.typeName, 'uint8')
|
|
|
|
st.equals(scopes['4'].locals['ui8'].type.typeName, 'uint8')
|
|
|
|
st.equals(scopes['4.1'].locals['ui81'].type.typeName, 'uint8')
|
|
|
|
} catch (e) {
|
|
|
|
st.fail(e.message)
|
|
|
|
}
|
|
|
|
|
|
|
|
helper.decodeLocals(st, 95, traceManager, callTree, function (locals) {
|
|
|
|
st.equals(Object.keys(locals).length, 16)
|
|
|
|
st.equals(locals['ui8'].value, '130')
|
|
|
|
st.equals(locals['ui16'].value, '456')
|
|
|
|
st.equals(locals['ui32'].value, '4356')
|
|
|
|
st.equals(locals['ui64'].value, '3543543543')
|
|
|
|
st.equals(locals['ui128'].value, '234567')
|
|
|
|
st.equals(locals['ui256'].value, '115792089237316195423570985008687907853269984665640564039457584007880697216513')
|
|
|
|
st.equals(locals['ui'].value, '123545666')
|
|
|
|
st.equals(locals['i8'].value, '-45')
|
|
|
|
st.equals(locals['i16'].value, '-1234')
|
|
|
|
st.equals(locals['i32'].value, '3455')
|
|
|
|
st.equals(locals['i64'].value, '-35566')
|
|
|
|
st.equals(locals['i128'].value, '-444444')
|
|
|
|
st.equals(locals['i256'].value, '3434343')
|
|
|
|
st.equals(locals['i'].value, '-32432423423')
|
|
|
|
st.equals(locals['ishrink'].value, '2')
|
|
|
|
})
|
|
|
|
|
|
|
|
helper.decodeLocals(st, 171, traceManager, callTree, function (locals) {
|
|
|
|
try {
|
|
|
|
st.equals(locals['ui8'].value, '123')
|
|
|
|
st.equals(Object.keys(locals).length, 1)
|
|
|
|
} catch (e) {
|
|
|
|
st.fail(e.message)
|
|
|
|
}
|
|
|
|
cb()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
traceManager.resolveTrace(tx, (error, result) => {
|
|
|
|
if (error) {
|
|
|
|
st.fail(error)
|
|
|
|
} else {
|
|
|
|
debuggerEvent.trigger('newTraceLoaded', [traceManager.trace])
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|