2023-11-01 10:32:09 +07:00
|
|
|
# Nimbus
|
2024-03-21 10:45:57 +00:00
|
|
|
# Copyright (c) 2020-2024 Status Research & Development GmbH
|
2023-11-01 10:32:09 +07:00
|
|
|
# Licensed under either of
|
|
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0)
|
|
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT) or
|
|
|
|
# http://opensource.org/licenses/MIT)
|
|
|
|
# at your option. This file may not be copied, modified, or distributed except
|
|
|
|
# according to those terms.
|
|
|
|
|
2019-01-10 15:23:18 +07:00
|
|
|
#
|
|
|
|
# helper tool to dump debugging data for persisted block
|
|
|
|
# usage: dumper [--datadir:your_path] --head:blockNumber
|
|
|
|
#
|
|
|
|
|
|
|
|
import
|
2023-08-04 12:10:09 +01:00
|
|
|
stint,
|
2022-12-02 11:39:12 +07:00
|
|
|
../nimbus/common/common,
|
2023-08-04 12:10:09 +01:00
|
|
|
../nimbus/db/core_db/persistent,
|
2022-12-02 11:39:12 +07:00
|
|
|
../nimbus/core/executor,
|
|
|
|
../nimbus/[vm_state, vm_types],
|
2023-08-04 12:10:09 +01:00
|
|
|
../nimbus/tracer,
|
|
|
|
./configuration # must be late (compilation annoyance)
|
2019-01-10 15:23:18 +07:00
|
|
|
|
2022-12-02 11:39:12 +07:00
|
|
|
proc dumpDebug(com: CommonRef, blockNumber: UInt256) =
|
2019-01-10 15:23:18 +07:00
|
|
|
var
|
2023-08-04 12:10:09 +01:00
|
|
|
capture = com.db.capture()
|
|
|
|
captureCom = com.clone(capture.recorder)
|
2019-01-10 15:23:18 +07:00
|
|
|
|
2023-08-04 12:10:09 +01:00
|
|
|
let transaction = capture.recorder.beginTransaction()
|
2019-02-07 11:10:04 +01:00
|
|
|
defer: transaction.dispose()
|
2021-10-28 16:42:39 +07:00
|
|
|
|
2022-04-08 11:54:11 +07:00
|
|
|
|
2019-01-10 15:23:18 +07:00
|
|
|
let
|
|
|
|
parentNumber = blockNumber - 1
|
2022-12-02 11:39:12 +07:00
|
|
|
parent = captureCom.db.getBlockHeader(parentNumber)
|
|
|
|
header = captureCom.db.getBlockHeader(blockNumber)
|
2019-01-10 15:23:18 +07:00
|
|
|
headerHash = header.blockHash
|
2022-12-02 11:39:12 +07:00
|
|
|
body = captureCom.db.getBlockBody(headerHash)
|
|
|
|
vmState = BaseVMState.new(parent, header, captureCom)
|
2019-01-10 15:23:18 +07:00
|
|
|
|
2022-12-02 11:39:12 +07:00
|
|
|
discard captureCom.db.setHead(parent, true)
|
2023-10-05 10:04:12 +07:00
|
|
|
discard vmState.processBlock(header, body)
|
2019-02-07 10:55:49 +07:00
|
|
|
|
2019-02-22 15:22:20 +07:00
|
|
|
transaction.rollback()
|
2024-03-21 10:45:57 +00:00
|
|
|
vmState.dumpDebuggingMetaData(header, body, false)
|
2019-01-10 15:23:18 +07:00
|
|
|
|
2020-07-21 13:15:06 +07:00
|
|
|
proc main() {.used.} =
|
2019-01-10 15:23:18 +07:00
|
|
|
let conf = getConfiguration()
|
2024-05-20 10:17:51 +00:00
|
|
|
let com = CommonRef.new(newCoreDbRef(DefaultDbPersistent, conf.dataDir))
|
2019-01-10 15:23:18 +07:00
|
|
|
|
|
|
|
if conf.head != 0.u256:
|
2022-12-02 11:39:12 +07:00
|
|
|
dumpDebug(com, conf.head)
|
2019-01-10 15:23:18 +07:00
|
|
|
|
|
|
|
when isMainModule:
|
|
|
|
var message: string
|
|
|
|
|
|
|
|
## Processing command line arguments
|
|
|
|
if processArguments(message) != Success:
|
|
|
|
echo message
|
|
|
|
quit(QuitFailure)
|
|
|
|
else:
|
|
|
|
if len(message) > 0:
|
|
|
|
echo message
|
|
|
|
quit(QuitSuccess)
|
|
|
|
|
|
|
|
try:
|
|
|
|
main()
|
|
|
|
except:
|
|
|
|
echo getCurrentExceptionMsg()
|