mirror of
https://github.com/nim-lang/Nim.git
synced 2026-06-07 12:24:19 +00:00
improve vmgen.codeListing formatting (#10306)
* improve vmgen.codeListing formatting * address comments
This commit is contained in:
committed by
Andreas Rumpf
parent
06e3d3ab4d
commit
beed27b75d
@@ -86,7 +86,7 @@ proc codeListing(c: ControlFlowGraph, result: var string, start=0; last = -1) =
|
||||
result.add("\n")
|
||||
inc i
|
||||
if i in jumpTargets: result.add("L" & $i & ": End\n")
|
||||
|
||||
# consider calling `asciitables.alignTable`
|
||||
|
||||
proc echoCfg*(c: ControlFlowGraph; start=0; last = -1) {.deprecated.} =
|
||||
## echos the ControlFlowGraph for debugging purposes.
|
||||
|
||||
@@ -10,10 +10,6 @@
|
||||
## This file implements the new evaluation engine for Nim code.
|
||||
## An instruction is 1-3 int32s in memory, it is a register based VM.
|
||||
|
||||
const
|
||||
debugEchoCode = false
|
||||
traceCode = debugEchoCode
|
||||
|
||||
import ast except getstr
|
||||
|
||||
import
|
||||
@@ -26,6 +22,9 @@ from evaltempl import evalTemplate
|
||||
|
||||
from modulegraphs import ModuleGraph, PPassContext
|
||||
|
||||
const
|
||||
traceCode = debugEchoCode
|
||||
|
||||
when hasFFI:
|
||||
import evalffi
|
||||
|
||||
|
||||
@@ -33,6 +33,11 @@ import
|
||||
import platform
|
||||
from os import splitFile
|
||||
|
||||
const
|
||||
debugEchoCode* = defined(nimVMDebug)
|
||||
|
||||
when debugEchoCode:
|
||||
import asciitables
|
||||
when hasFFI:
|
||||
import evalffi
|
||||
|
||||
@@ -43,9 +48,10 @@ type
|
||||
TGenFlags = set[TGenFlag]
|
||||
|
||||
proc debugInfo(c: PCtx; info: TLineInfo): string =
|
||||
result = toFilename(c.config, info).splitFile.name & ":" & $info.line
|
||||
result = toFileLineCol(c.config, info)
|
||||
|
||||
proc codeListing(c: PCtx, result: var string, start=0; last = -1) =
|
||||
## for debugging purposes
|
||||
# first iteration: compute all necessary labels:
|
||||
var jumpTargets = initIntSet()
|
||||
let last = if last < 0: c.code.len-1 else: min(last, c.code.len-1)
|
||||
@@ -54,7 +60,9 @@ proc codeListing(c: PCtx, result: var string, start=0; last = -1) =
|
||||
if x.opcode in relativeJumps:
|
||||
jumpTargets.incl(i+x.regBx-wordExcess)
|
||||
|
||||
# for debugging purposes
|
||||
template toStr(opc: TOpcode): string = ($opc).substr(3)
|
||||
|
||||
result.add "code listing:\n"
|
||||
var i = start
|
||||
while i <= last:
|
||||
if i in jumpTargets: result.addf("L$1:\n", i)
|
||||
@@ -62,34 +70,39 @@ proc codeListing(c: PCtx, result: var string, start=0; last = -1) =
|
||||
|
||||
result.add($i)
|
||||
let opc = opcode(x)
|
||||
if opc in {opcConv, opcCast}:
|
||||
if opc in {opcIndCall, opcIndCallAsgn}:
|
||||
result.addf("\t$#\tr$#, r$#, nargs:$#", opc.toStr, x.regA,
|
||||
x.regB, x.regC)
|
||||
elif opc in {opcConv, opcCast}:
|
||||
let y = c.code[i+1]
|
||||
let z = c.code[i+2]
|
||||
result.addf("\t$#\tr$#, r$#, $#, $#", ($opc).substr(3), x.regA, x.regB,
|
||||
result.addf("\t$#\tr$#, r$#, $#, $#", opc.toStr, x.regA, x.regB,
|
||||
c.types[y.regBx-wordExcess].typeToString,
|
||||
c.types[z.regBx-wordExcess].typeToString)
|
||||
inc i, 2
|
||||
elif opc < firstABxInstr:
|
||||
result.addf("\t$#\tr$#, r$#, r$#", ($opc).substr(3), x.regA,
|
||||
result.addf("\t$#\tr$#, r$#, r$#", opc.toStr, x.regA,
|
||||
x.regB, x.regC)
|
||||
elif opc in relativeJumps:
|
||||
result.addf("\t$#\tr$#, L$#", ($opc).substr(3), x.regA,
|
||||
result.addf("\t$#\tr$#, L$#", opc.toStr, x.regA,
|
||||
i+x.regBx-wordExcess)
|
||||
elif opc in {opcLdConst, opcAsgnConst}:
|
||||
let idx = x.regBx-wordExcess
|
||||
result.addf("\t$#\tr$#, $# ($#)", ($opc).substr(3), x.regA,
|
||||
result.addf("\t$#\tr$#, $# ($#)", opc.toStr, x.regA,
|
||||
c.constants[idx].renderTree, $idx)
|
||||
elif opc in {opcMarshalLoad, opcMarshalStore}:
|
||||
let y = c.code[i+1]
|
||||
result.addf("\t$#\tr$#, r$#, $#", ($opc).substr(3), x.regA, x.regB,
|
||||
result.addf("\t$#\tr$#, r$#, $#", opc.toStr, x.regA, x.regB,
|
||||
c.types[y.regBx-wordExcess].typeToString)
|
||||
inc i
|
||||
else:
|
||||
result.addf("\t$#\tr$#, $#", ($opc).substr(3), x.regA, x.regBx-wordExcess)
|
||||
result.addf("\t$#\tr$#, $#", opc.toStr, x.regA, x.regBx-wordExcess)
|
||||
result.add("\t#")
|
||||
result.add(debugInfo(c, c.debug[i]))
|
||||
result.add("\n")
|
||||
inc i
|
||||
when debugEchoCode:
|
||||
result = result.alignTable
|
||||
|
||||
proc echoCode*(c: PCtx; start=0; last = -1) {.deprecated.} =
|
||||
var buf = ""
|
||||
|
||||
Reference in New Issue
Block a user