Merge pull request #227 from goccy/feature/generate-vm-source

Generate VM source
This commit is contained in:
Masaaki Goshima 2021-05-19 12:54:59 +09:00 committed by GitHub
commit d3951e3213
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 5029 additions and 0 deletions

View File

@ -4,6 +4,9 @@ import (
"bytes"
"fmt"
"go/format"
"go/parser"
"go/printer"
"go/token"
"io/ioutil"
"path/filepath"
"runtime"
@ -273,6 +276,32 @@ func (t OpType) FieldToOmitEmptyField() OpType {
return ioutil.WriteFile(path, buf, 0644)
}
func generateVM() error {
file, err := ioutil.ReadFile("vm.go.tmpl")
if err != nil {
return err
}
fset := token.NewFileSet()
f, err := parser.ParseFile(fset, "", string(file), parser.ParseComments)
if err != nil {
return err
}
for _, pkg := range []string{"vm", "vm_indent", "vm_escaped", "vm_escaped_indent"} {
f.Name.Name = pkg
var buf bytes.Buffer
printer.Fprint(&buf, fset, f)
path := filepath.Join(repoRoot(), "internal", "encoder", pkg, "vm.go")
source, err := format.Source(buf.Bytes())
if err != nil {
return err
}
if err := ioutil.WriteFile(path, source, 0644); err != nil {
return err
}
}
return nil
}
func repoRoot() string {
_, file, _, _ := runtime.Caller(0)
relativePathFromRepoRoot := filepath.Join("internal", "cmd", "generator")
@ -281,6 +310,9 @@ func repoRoot() string {
//go:generate go run main.go
func main() {
if err := generateVM(); err != nil {
panic(err)
}
if err := _main(); err != nil {
panic(err)
}

File diff suppressed because it is too large Load Diff

View File

@ -1,3 +1,4 @@
// Code generated by internal/cmd/generator. DO NOT EDIT!
package vm
import (

View File

@ -1,3 +1,4 @@
// Code generated by internal/cmd/generator. DO NOT EDIT!
package vm_escaped
import (

View File

@ -1,3 +1,4 @@
// Code generated by internal/cmd/generator. DO NOT EDIT!
package vm_escaped_indent
import (

View File

@ -1,3 +1,4 @@
// Code generated by internal/cmd/generator. DO NOT EDIT!
package vm_indent
import (