diff options
| author | Marc Vertes <mvertes@free.fr> | 2025-11-26 15:42:21 +0100 |
|---|---|---|
| committer | Marc Vertes <mvertes@free.fr> | 2025-11-26 15:42:21 +0100 |
| commit | aed20c1c453e50f716c454c0bd7e4995a0f5d898 (patch) | |
| tree | 91af798989300451113e5b865a20fb2eae777938 /vm/vm.go | |
| parent | 31054164870b413db797572b8e3d5a00c41d328e (diff) | |
Chore: improve tracing of code emits
Diffstat (limited to 'vm/vm.go')
| -rw-r--r-- | vm/vm.go | 5 |
1 files changed, 4 insertions, 1 deletions
@@ -55,6 +55,7 @@ const ( Return // [r1 .. ri] -- ; exit frame: sp = fp, fp = pop Sub // n1 n2 -- diff ; diff = n1 - n2 Subi // n1 -- diff ; diff = n1 - $1 + Swap // -- ) // Instruction represents a virtual machine bytecode instruction. @@ -65,7 +66,7 @@ type Instruction struct { } func (i Instruction) String() (s string) { - s = i.Op.String() + s = fmt.Sprintf("%4d: %v", i.Pos, i.Op) var sb strings.Builder for _, a := range i.Arg { sb.WriteString(fmt.Sprintf(" %v", a)) @@ -226,6 +227,8 @@ func (m *Machine) Run() (err error) { mem = mem[:sp-1] case Subi: mem[sp-1] = ValueOf(int(mem[sp-1].Data.Int()) - c.Arg[0]) + case Swap: + mem[sp-2], mem[sp-1] = mem[sp-1], mem[sp-2] case Index: mem[sp-2].Data = mem[sp-1].Data.Index(int(mem[sp-2].Data.Int())) mem = mem[:sp-1] |
