Skip to content

Commit

Permalink
Merge pull request ethereum#2219 from ethereum/addTraceTransaction
Browse files Browse the repository at this point in the history
adding `retrieveTrace` to the remix-plugin API
  • Loading branch information
yann300 authored Jul 24, 2019
2 parents 912bb8b + 2f9e364 commit 1d349b0
Show file tree
Hide file tree
Showing 2 changed files with 54 additions and 24 deletions.
8 changes: 6 additions & 2 deletions src/app/tabs/debugger-tab.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import * as packageJson from '../../../package.json'
const profile = {
name: 'debugger',
displayName: 'Debugger',
methods: ['debug'],
methods: ['debug', 'getTrace'],
events: [],
icon: '',
description: 'Debug transactions',
Expand Down Expand Up @@ -38,7 +38,11 @@ class DebuggerTab extends ViewPlugin {
}

debug (hash) {
if (this.debugger) this.debuggerUI.debug(hash)
if (this.debuggerUI) this.debuggerUI.debug(hash)
}

getTrace (hash) {
return this.debuggerUI.getTrace(hash)
}

debugger () {
Expand Down
70 changes: 48 additions & 22 deletions src/app/tabs/debugger/debuggerUI.js
Original file line number Diff line number Diff line change
Expand Up @@ -103,38 +103,64 @@ class DebuggerUI {
return this.isActive
}

startDebugging (blockNumber, txNumber, tx) {
const self = this
getDebugWeb3 () {
return new Promise((resolve, reject) => {
executionContext.detectNetwork((error, network) => {
let web3
if (error || !network) {
web3 = init.web3DebugNode(executionContext.web3())
} else {
const webDebugNode = init.web3DebugNode(network.name)
web3 = !webDebugNode ? executionContext.web3() : webDebugNode
}
init.extendWeb3(web3)
resolve(web3)
})
})
}

async startDebugging (blockNumber, txNumber, tx) {
if (this.debugger) this.unLoad()

let compilers = this.registry.get('compilersartefacts').api
let lastCompilationResult
if (compilers['__last']) lastCompilationResult = compilers['__last']

executionContext.detectNetwork((error, network) => {
let web3
if (error || !network) {
web3 = init.web3DebugNode(executionContext.web3())
} else {
var webDebugNode = init.web3DebugNode(network.name)
web3 = (!webDebugNode ? executionContext.web3() : webDebugNode)
}
init.extendWeb3(web3)
this.debugger = new Debugger({
let web3 = await this.getDebugWeb3()
this.debugger = new Debugger({
web3,
offsetToLineColumnConverter: this.registry.get('offsettolinecolumnconverter').api,
compiler: { lastCompilationResult }
})

this.listenToEvents()
this.debugger.debug(blockNumber, txNumber, tx, () => {
this.stepManager = new StepManagerUI(this.debugger.step_manager)
this.vmDebugger = new VmDebugger(this.debugger.vmDebuggerLogic)
this.txBrowser.setState({ blockNumber, txNumber, debugging: true })
this.renderDebugger()
}).catch((error) => {
toaster(error)
this.unLoad()
})
}

getTrace (hash) {
return new Promise(async (resolve, reject) => {
const compilers = this.registry.get('compilersartefacts').api
let lastCompilationResult
if (compilers['__last']) lastCompilationResult = compilers['__last']

const web3 = await this.getDebugWeb3()

const debug = new Debugger({
web3,
offsetToLineColumnConverter: this.registry.get('offsettolinecolumnconverter').api,
compiler: { lastCompilationResult }
})

this.listenToEvents()
this.debugger.debug(blockNumber, txNumber, tx, () => {
self.stepManager = new StepManagerUI(this.debugger.step_manager)
self.vmDebugger = new VmDebugger(this.debugger.vmDebuggerLogic)
self.txBrowser.setState({ blockNumber, txNumber, debugging: true })
self.renderDebugger()
}).catch((error) => {
toaster(error)
this.unLoad()
debug.debugger.traceManager.traceRetriever.getTrace(hash, (error, trace) => {
if (error) return reject(error)
resolve(trace)
})
})
}
Expand Down

0 comments on commit 1d349b0

Please sign in to comment.