go-json/internal/encoder/vm/debug_vm.go

35 lines
772 B
Go
Raw Normal View History

2021-05-18 08:48:13 +03:00
package vm
import (
"fmt"
"github.com/goccy/go-json/internal/encoder"
)
2021-05-31 16:25:33 +03:00
func DebugRun(ctx *encoder.RuntimeContext, b []byte, codeSet *encoder.OpcodeSet) ([]byte, error) {
2021-05-18 08:48:13 +03:00
defer func() {
2021-05-31 19:25:05 +03:00
var code *encoder.Opcode
2021-06-01 07:40:15 +03:00
if (ctx.Option.Flag & encoder.HTMLEscapeOption) != 0 {
2021-05-31 19:25:05 +03:00
code = codeSet.EscapeKeyCode
} else {
code = codeSet.NoescapeKeyCode
}
2021-05-18 08:48:13 +03:00
if err := recover(); err != nil {
fmt.Println("=============[DEBUG]===============")
fmt.Println("* [TYPE]")
fmt.Println(codeSet.Type)
fmt.Printf("\n")
fmt.Println("* [ALL OPCODE]")
2021-05-31 19:25:05 +03:00
fmt.Println(code.Dump())
2021-05-18 08:48:13 +03:00
fmt.Printf("\n")
fmt.Println("* [CONTEXT]")
fmt.Printf("%+v\n", ctx)
fmt.Println("===================================")
panic(err)
}
}()
2021-05-31 16:25:33 +03:00
return Run(ctx, b, codeSet)
2021-05-18 08:48:13 +03:00
}