松露调试器:类型错误:无法读取的未定义的属性“行”

问题描述 投票:1回答:1

我试图用松露4.1.0调试代码的密实度。调试器能够正常启动,显示第一行,但你无法通过合同的一步!

如在终端显示的错误的完整堆栈跟踪是:

 TypeError: Cannot read property 'line' of undefined
     at Object.formatRangeLines (/usr/local/lib/node_modules/truffle/build/webpack:/~/truffle-debug-utils/index.js:201:1)
     at printState (/usr/local/lib/node_modules/truffle/build/webpack:/~/truffle-core/lib/commands/debug.js:125:1)
     at Object.interpreter (/usr/local/lib/node_modules/truffle/build/webpack:/~/truffle-core/lib/commands/debug.js:404:1)
     at ReplManager.interpret (/usr/local/lib/node_modules/truffle/build/webpack:/~/truffle-core/lib/repl.js:119:1)
     at bound (domain.js:280:14)
     at REPLServer.runBound [as eval] (domain.js:293:12)
     at REPLServer.<anonymous> (repl.js:539:10)
     at emitOne (events.js:96:13)
     at REPLServer.emit (events.js:188:7)
     at REPLServer.Interface._onLine (readline.js:232:10)
     at REPLServer.Interface._line (readline.js:583:8)
     at REPLServer.Interface._ttyWrite (readline.js:860:14)
     at REPLServer.self._ttyWrite (repl.js:612:7)
     at ReadStream.onkeypress (readline.js:119:10)
     at emitTwo (events.js:106:13)
     at ReadStream.emit (events.js:191:7)
     at emitKeys (internal/readline.js:389:14)
     at next (native)
     at ReadStream.onData (readline.js:970:36)
     at emitOne (events.js:96:13)
     at ReadStream.emit (events.js:188:7)
     at readableAddChunk (_stream_readable.js:176:18)
     at ReadStream.Readable.push (_stream_readable.js:134:10)
     at TTY.onread (net.js:547:20)

挖掘到方法formatRangeLines: function(source, range, contextBefore)console.log(range);它打印:

{ start: undefined, end: undefined }

事实上,除了在这个块存取range.start时提出:

var startBeforeIndex = Math.max(
  range.start.line - contextBefore, 0
);

有什么建议么?谢谢,

debugging ethereum solidity truffle
1个回答
0
投票

更新:这个问题在松露版本4.1.4得到解决(reference)。

但是,如果你更新你的松露版本,但仍然面临的问题。试着在你的控制台上运行(这是强制更新所有已编译的智能合同字节码根据最新的版本是):

truffle migrate --reset --compile-all


由于在松露调试器的当前版本中的错误(即实验版),调试器不能跳跃到另一个文件。

该缺陷是这里提出:https://github.com/trufflesuite/truffle/issues/826

因此,要克服当前的错误,所有的智能合约代码必须是在一个文件中。希望有一个工具,可以帮助这一点:https://github.com/poanetwork/solidity-flattener

© www.soinside.com 2019 - 2024. All rights reserved.