build: make llgen, cltest, gentests call build.Do
This commit is contained in:
@@ -23,7 +23,6 @@ import (
|
|||||||
|
|
||||||
"github.com/goplus/llgo/cl"
|
"github.com/goplus/llgo/cl"
|
||||||
"github.com/goplus/llgo/internal/llgen"
|
"github.com/goplus/llgo/internal/llgen"
|
||||||
"github.com/goplus/llgo/ssa"
|
|
||||||
"github.com/goplus/mod"
|
"github.com/goplus/mod"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -31,15 +30,12 @@ func main() {
|
|||||||
dir, _, err := mod.FindGoMod(".")
|
dir, _, err := mod.FindGoMod(".")
|
||||||
check(err)
|
check(err)
|
||||||
|
|
||||||
ssa.Initialize(ssa.InitAll | ssa.InitNative)
|
|
||||||
llgen.Verbose = false
|
|
||||||
|
|
||||||
llgenDir(dir + "/cl/_testlibc")
|
llgenDir(dir + "/cl/_testlibc")
|
||||||
llgenDir(dir + "/cl/_testlibgo")
|
llgenDir(dir + "/cl/_testlibgo")
|
||||||
llgenDir(dir + "/cl/_testrt")
|
llgenDir(dir + "/cl/_testrt")
|
||||||
llgenDir(dir + "/cl/_testgo")
|
llgenDir(dir + "/cl/_testgo")
|
||||||
llgenDir(dir+"/cl/_testpy", "")
|
llgenDir(dir + "/cl/_testpy")
|
||||||
llgenDir(dir+"/cl/_testdata", "")
|
llgenDir(dir + "/cl/_testdata")
|
||||||
}
|
}
|
||||||
|
|
||||||
func isDbgSymEnabled(flagsFile string) bool {
|
func isDbgSymEnabled(flagsFile string) bool {
|
||||||
@@ -56,7 +52,7 @@ func isDbgSymEnabled(flagsFile string) bool {
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
func llgenDir(dir string, pkgPath ...string) {
|
func llgenDir(dir string) {
|
||||||
fis, err := os.ReadDir(dir)
|
fis, err := os.ReadDir(dir)
|
||||||
check(err)
|
check(err)
|
||||||
for _, fi := range fis {
|
for _, fi := range fis {
|
||||||
@@ -69,8 +65,7 @@ func llgenDir(dir string, pkgPath ...string) {
|
|||||||
check(os.Chdir(testDir))
|
check(os.Chdir(testDir))
|
||||||
dbg := isDbgSymEnabled("flags.txt")
|
dbg := isDbgSymEnabled("flags.txt")
|
||||||
cl.EnableDebugSymbols(dbg)
|
cl.EnableDebugSymbols(dbg)
|
||||||
|
llgen.SmartDoFile(testDir)
|
||||||
llgen.SmartDoFile("in.go", pkgPath...)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -17,6 +17,7 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
@@ -24,11 +25,10 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
if len(os.Args) < 2 {
|
flag.Parse()
|
||||||
fmt.Fprintln(os.Stderr, "Usage: llgen [flags] <pkg> [pkgPath]")
|
if len(flag.Args()) != 1 {
|
||||||
|
fmt.Fprintln(os.Stderr, "Usage: llgen [flags] <pkg>")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
llgen.Init()
|
llgen.SmartDoFile(flag.Args()[0])
|
||||||
args := os.Args[1:]
|
|
||||||
llgen.SmartDoFile(args[0], args[1:]...)
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -50,7 +50,7 @@ func InitDebug() {
|
|||||||
llssa.SetDebug(llssa.DbgFlagAll)
|
llssa.SetDebug(llssa.DbgFlagAll)
|
||||||
}
|
}
|
||||||
|
|
||||||
func FromDir(t *testing.T, sel, relDir string, byLLGen bool) {
|
func FromDir(t *testing.T, sel, relDir string) {
|
||||||
dir, err := os.Getwd()
|
dir, err := os.Getwd()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal("Getwd failed:", err)
|
t.Fatal("Getwd failed:", err)
|
||||||
@@ -66,7 +66,7 @@ func FromDir(t *testing.T, sel, relDir string, byLLGen bool) {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
t.Run(name, func(t *testing.T) {
|
t.Run(name, func(t *testing.T) {
|
||||||
testFrom(t, dir+"/"+name, sel, byLLGen)
|
testFrom(t, dir+"/"+name, sel)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -121,12 +121,11 @@ func isDbgSymEnabled(flagsFile string) bool {
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
func testFrom(t *testing.T, pkgDir, sel string, byLLGen bool) {
|
func testFrom(t *testing.T, pkgDir, sel string) {
|
||||||
if sel != "" && !strings.Contains(pkgDir, sel) {
|
if sel != "" && !strings.Contains(pkgDir, sel) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
log.Println("Parsing", pkgDir)
|
log.Println("Parsing", pkgDir)
|
||||||
in := pkgDir + "/in.go"
|
|
||||||
out := pkgDir + "/out.ll"
|
out := pkgDir + "/out.ll"
|
||||||
dbg := isDbgSymEnabled(pkgDir + "/flags.txt")
|
dbg := isDbgSymEnabled(pkgDir + "/flags.txt")
|
||||||
if dbg {
|
if dbg {
|
||||||
@@ -139,13 +138,9 @@ func testFrom(t *testing.T, pkgDir, sel string, byLLGen bool) {
|
|||||||
t.Fatal("ReadFile failed:", err)
|
t.Fatal("ReadFile failed:", err)
|
||||||
}
|
}
|
||||||
expected := string(b)
|
expected := string(b)
|
||||||
if byLLGen {
|
if v := llgen.GenFrom(pkgDir); v != expected && expected != ";" { // expected == ";" means skipping out.ll
|
||||||
if v := llgen.GenFrom(in); v != expected && expected != ";" { // expected == ";" means skipping out.ll
|
|
||||||
t.Fatalf("\n==> got:\n%s\n==> expected:\n%s\n", v, expected)
|
t.Fatalf("\n==> got:\n%s\n==> expected:\n%s\n", v, expected)
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
TestCompileEx(t, nil, in, expected, dbg)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestCompileEx(t *testing.T, src any, fname, expected string, dbg bool) {
|
func TestCompileEx(t *testing.T, src any, fname, expected string, dbg bool) {
|
||||||
|
|||||||
@@ -30,34 +30,37 @@ func testCompile(t *testing.T, src, expected string) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestFromTestgo(t *testing.T) {
|
func TestFromTestgo(t *testing.T) {
|
||||||
cltest.FromDir(t, "", "./_testgo", false)
|
cltest.FromDir(t, "", "./_testgo")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFromTestpy(t *testing.T) {
|
func TestFromTestpy(t *testing.T) {
|
||||||
cltest.FromDir(t, "", "./_testpy", false)
|
cltest.FromDir(t, "", "./_testpy")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFromTestlibgo(t *testing.T) {
|
func TestFromTestlibgo(t *testing.T) {
|
||||||
cltest.FromDir(t, "", "./_testlibgo", true)
|
cltest.FromDir(t, "", "./_testlibgo")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFromTestlibc(t *testing.T) {
|
func TestFromTestlibc(t *testing.T) {
|
||||||
cltest.FromDir(t, "", "./_testlibc", true)
|
cltest.FromDir(t, "", "./_testlibc")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFromTestrt(t *testing.T) {
|
func TestFromTestrt(t *testing.T) {
|
||||||
cl.SetDebug(cl.DbgFlagAll)
|
cl.SetDebug(cl.DbgFlagAll)
|
||||||
cltest.FromDir(t, "", "./_testrt", true)
|
cltest.FromDir(t, "", "./_testrt")
|
||||||
cl.SetDebug(0)
|
cl.SetDebug(0)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFromTestdata(t *testing.T) {
|
func TestFromTestdata(t *testing.T) {
|
||||||
cltest.FromDir(t, "", "./_testdata", false)
|
cltest.FromDir(t, "", "./_testdata")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGoPkgMath(t *testing.T) {
|
func TestGoPkgMath(t *testing.T) {
|
||||||
conf := build.NewDefaultConf(build.ModeInstall)
|
conf := build.NewDefaultConf(build.ModeInstall)
|
||||||
build.Do([]string{"math"}, conf)
|
_, err := build.Do([]string{"math"}, conf)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestVar(t *testing.T) {
|
func TestVar(t *testing.T) {
|
||||||
|
|||||||
@@ -18,6 +18,9 @@
|
|||||||
package build
|
package build
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
|
||||||
"github.com/goplus/llgo/cmd/internal/base"
|
"github.com/goplus/llgo/cmd/internal/base"
|
||||||
"github.com/goplus/llgo/internal/build"
|
"github.com/goplus/llgo/internal/build"
|
||||||
)
|
)
|
||||||
@@ -41,5 +44,9 @@ func runCmd(cmd *base.Command, args []string) {
|
|||||||
conf.OutFile = args[1]
|
conf.OutFile = args[1]
|
||||||
args = args[2:]
|
args = args[2:]
|
||||||
}
|
}
|
||||||
build.Do(args, conf)
|
_, err := build.Do(args, conf)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Fprintln(os.Stderr, err)
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -18,6 +18,9 @@
|
|||||||
package install
|
package install
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
|
||||||
"github.com/goplus/llgo/cmd/internal/base"
|
"github.com/goplus/llgo/cmd/internal/base"
|
||||||
"github.com/goplus/llgo/internal/build"
|
"github.com/goplus/llgo/internal/build"
|
||||||
)
|
)
|
||||||
@@ -34,5 +37,9 @@ func init() {
|
|||||||
|
|
||||||
func runCmd(cmd *base.Command, args []string) {
|
func runCmd(cmd *base.Command, args []string) {
|
||||||
conf := build.NewDefaultConf(build.ModeInstall)
|
conf := build.NewDefaultConf(build.ModeInstall)
|
||||||
build.Do(args, conf)
|
_, err := build.Do(args, conf)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Fprintln(os.Stderr, err)
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -19,6 +19,8 @@ package run
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
|
||||||
"github.com/goplus/llgo/cmd/internal/base"
|
"github.com/goplus/llgo/cmd/internal/base"
|
||||||
@@ -63,7 +65,11 @@ func runCmdEx(_ *base.Command, args []string, mode build.Mode) {
|
|||||||
args, runArgs, err := parseRunArgs(args)
|
args, runArgs, err := parseRunArgs(args)
|
||||||
check(err)
|
check(err)
|
||||||
conf.RunArgs = runArgs
|
conf.RunArgs = runArgs
|
||||||
build.Do(args, conf)
|
_, err = build.Do(args, conf)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Fprintln(os.Stderr, err)
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func parseRunArgs(args []string) ([]string, []string, error) {
|
func parseRunArgs(args []string) ([]string, []string, error) {
|
||||||
|
|||||||
@@ -53,6 +53,7 @@ const (
|
|||||||
ModeInstall
|
ModeInstall
|
||||||
ModeRun
|
ModeRun
|
||||||
ModeCmpTest
|
ModeCmpTest
|
||||||
|
ModeGen
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
@@ -119,7 +120,7 @@ const (
|
|||||||
loadSyntax = loadTypes | packages.NeedSyntax | packages.NeedTypesInfo
|
loadSyntax = loadTypes | packages.NeedSyntax | packages.NeedTypesInfo
|
||||||
)
|
)
|
||||||
|
|
||||||
func Do(args []string, conf *Config) {
|
func Do(args []string, conf *Config) ([]Package, error) {
|
||||||
flags, patterns, verbose := ParseArgs(args, buildFlags)
|
flags, patterns, verbose := ParseArgs(args, buildFlags)
|
||||||
cl.EnableDebugSymbols(IsDebugEnabled())
|
cl.EnableDebugSymbols(IsDebugEnabled())
|
||||||
flags = append(flags, "-tags", "llgo")
|
flags = append(flags, "-tags", "llgo")
|
||||||
@@ -159,7 +160,6 @@ func Do(args []string, conf *Config) {
|
|||||||
}
|
}
|
||||||
initial, err := packages.LoadEx(dedup, sizes, cfg, patterns...)
|
initial, err := packages.LoadEx(dedup, sizes, cfg, patterns...)
|
||||||
check(err)
|
check(err)
|
||||||
|
|
||||||
mode := conf.Mode
|
mode := conf.Mode
|
||||||
if len(initial) == 1 && len(initial[0].CompiledGoFiles) > 0 {
|
if len(initial) == 1 && len(initial[0].CompiledGoFiles) > 0 {
|
||||||
if mode == ModeBuild {
|
if mode == ModeBuild {
|
||||||
@@ -167,11 +167,10 @@ func Do(args []string, conf *Config) {
|
|||||||
}
|
}
|
||||||
} else if mode == ModeRun {
|
} else if mode == ModeRun {
|
||||||
if len(initial) > 1 {
|
if len(initial) > 1 {
|
||||||
fmt.Fprintln(os.Stderr, "cannot run multiple packages")
|
return nil, fmt.Errorf("cannot run multiple packages")
|
||||||
} else {
|
} else {
|
||||||
fmt.Fprintln(os.Stderr, "no Go files in matched packages")
|
return nil, fmt.Errorf("no Go files in matched packages")
|
||||||
}
|
}
|
||||||
return
|
|
||||||
}
|
}
|
||||||
|
|
||||||
altPkgPaths := altPkgs(initial, llssa.PkgRuntime)
|
altPkgPaths := altPkgs(initial, llssa.PkgRuntime)
|
||||||
@@ -203,12 +202,21 @@ func Do(args []string, conf *Config) {
|
|||||||
|
|
||||||
ctx := &context{env, cfg, progSSA, prog, dedup, patches, make(map[string]none), initial, mode, 0}
|
ctx := &context{env, cfg, progSSA, prog, dedup, patches, make(map[string]none), initial, mode, 0}
|
||||||
pkgs := buildAllPkgs(ctx, initial, verbose)
|
pkgs := buildAllPkgs(ctx, initial, verbose)
|
||||||
|
if mode == ModeGen {
|
||||||
|
for _, pkg := range pkgs {
|
||||||
|
if pkg.Package == initial[0] {
|
||||||
|
return []*aPackage{pkg}, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil, fmt.Errorf("initial package not found")
|
||||||
|
}
|
||||||
|
|
||||||
dpkg := buildAllPkgs(ctx, altPkgs[noRt:], verbose)
|
dpkg := buildAllPkgs(ctx, altPkgs[noRt:], verbose)
|
||||||
var linkArgs []string
|
var linkArgs []string
|
||||||
for _, pkg := range dpkg {
|
for _, pkg := range dpkg {
|
||||||
linkArgs = append(linkArgs, pkg.LinkArgs...)
|
linkArgs = append(linkArgs, pkg.LinkArgs...)
|
||||||
}
|
}
|
||||||
|
|
||||||
if mode != ModeBuild {
|
if mode != ModeBuild {
|
||||||
nErr := 0
|
nErr := 0
|
||||||
for _, pkg := range initial {
|
for _, pkg := range initial {
|
||||||
@@ -220,6 +228,7 @@ func Do(args []string, conf *Config) {
|
|||||||
os.Exit(nErr)
|
os.Exit(nErr)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return dpkg, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func setNeedRuntimeOrPyInit(pkg *packages.Package, needRuntime, needPyInit bool) {
|
func setNeedRuntimeOrPyInit(pkg *packages.Package, needRuntime, needPyInit bool) {
|
||||||
@@ -571,6 +580,8 @@ type aPackage struct {
|
|||||||
LinkArgs []string
|
LinkArgs []string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type Package = *aPackage
|
||||||
|
|
||||||
func allPkgs(ctx *context, initial []*packages.Package, verbose bool) (all []*aPackage, errs []*packages.Package) {
|
func allPkgs(ctx *context, initial []*packages.Package, verbose bool) (all []*aPackage, errs []*packages.Package) {
|
||||||
prog := ctx.progSSA
|
prog := ctx.progSSA
|
||||||
built := ctx.built
|
built := ctx.built
|
||||||
|
|||||||
@@ -16,41 +16,8 @@
|
|||||||
|
|
||||||
package llgen
|
package llgen
|
||||||
|
|
||||||
import (
|
|
||||||
"os"
|
|
||||||
|
|
||||||
"github.com/goplus/llgo/cl"
|
|
||||||
"github.com/goplus/llgo/internal/build"
|
|
||||||
"github.com/goplus/llgo/internal/mod"
|
|
||||||
|
|
||||||
llssa "github.com/goplus/llgo/ssa"
|
|
||||||
)
|
|
||||||
|
|
||||||
func Init() {
|
|
||||||
llssa.Initialize(llssa.InitAll)
|
|
||||||
llssa.SetDebug(llssa.DbgFlagAll)
|
|
||||||
cl.SetDebug(cl.DbgFlagAll)
|
|
||||||
cl.EnableDebugSymbols(build.IsDebugEnabled())
|
|
||||||
}
|
|
||||||
|
|
||||||
func PkgPath(dir string) string {
|
|
||||||
_, pkgPath, err := mod.Load(dir)
|
|
||||||
check(err)
|
|
||||||
return pkgPath
|
|
||||||
}
|
|
||||||
|
|
||||||
func Do(pkgPath, inFile, outFile string) {
|
|
||||||
ret := genFrom(inFile, pkgPath)
|
|
||||||
err := os.WriteFile(outFile, []byte(ret), 0644)
|
|
||||||
check(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
func check(err error) {
|
func check(err error) {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var (
|
|
||||||
Verbose = true
|
|
||||||
)
|
|
||||||
|
|||||||
@@ -17,107 +17,30 @@
|
|||||||
package llgen
|
package llgen
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"go/ast"
|
|
||||||
"go/types"
|
|
||||||
"os"
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/goplus/llgo/cl"
|
|
||||||
"github.com/goplus/llgo/internal/build"
|
"github.com/goplus/llgo/internal/build"
|
||||||
"github.com/goplus/llgo/internal/packages"
|
|
||||||
"golang.org/x/tools/go/ssa"
|
|
||||||
"golang.org/x/tools/go/ssa/ssautil"
|
|
||||||
|
|
||||||
llssa "github.com/goplus/llgo/ssa"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
|
||||||
loadFiles = packages.NeedName | packages.NeedFiles | packages.NeedCompiledGoFiles
|
|
||||||
loadImports = loadFiles | packages.NeedImports
|
|
||||||
loadTypes = loadImports | packages.NeedTypes | packages.NeedTypesSizes
|
|
||||||
loadSyntax = loadTypes | packages.NeedSyntax | packages.NeedTypesInfo
|
|
||||||
)
|
|
||||||
|
|
||||||
func initRtAndPy(prog llssa.Program, cfg *packages.Config) {
|
|
||||||
var pkgRtAndPy []*packages.Package
|
|
||||||
load := func() []*packages.Package {
|
|
||||||
if pkgRtAndPy == nil {
|
|
||||||
var err error
|
|
||||||
pkgRtAndPy, err = packages.LoadEx(nil, prog.TypeSizes, cfg, llssa.PkgRuntime, llssa.PkgPython)
|
|
||||||
check(err)
|
|
||||||
}
|
|
||||||
return pkgRtAndPy
|
|
||||||
}
|
|
||||||
|
|
||||||
prog.SetRuntime(func() *types.Package {
|
|
||||||
rt := load()
|
|
||||||
return rt[0].Types
|
|
||||||
})
|
|
||||||
prog.SetPython(func() *types.Package {
|
|
||||||
rt := load()
|
|
||||||
return rt[1].Types
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func GenFrom(fileOrPkg string) string {
|
func GenFrom(fileOrPkg string) string {
|
||||||
return genFrom(fileOrPkg, "")
|
pkg, err := genFrom(fileOrPkg)
|
||||||
|
check(err)
|
||||||
|
return pkg.LPkg.String()
|
||||||
}
|
}
|
||||||
|
|
||||||
func genFrom(fileOrPkg string, pkgPath string) string {
|
func genFrom(pkgPath string) (build.Package, error) {
|
||||||
prog := llssa.NewProgram(nil)
|
conf := &build.Config{
|
||||||
|
Mode: build.ModeGen,
|
||||||
cfg := &packages.Config{
|
AppExt: build.DefaultAppExt(),
|
||||||
Mode: loadSyntax | packages.NeedDeps,
|
|
||||||
BuildFlags: []string{"-tags", "llgo"},
|
|
||||||
}
|
}
|
||||||
|
pkgs, err := build.Do([]string{pkgPath}, conf)
|
||||||
dedup := packages.NewDeduper()
|
if err != nil {
|
||||||
dedup.SetPkgPath(func(path, name string) string {
|
return nil, err
|
||||||
if path == "command-line-arguments" {
|
|
||||||
if pkgPath != "" {
|
|
||||||
path = pkgPath
|
|
||||||
} else {
|
|
||||||
path = name
|
|
||||||
}
|
}
|
||||||
}
|
return pkgs[0], nil
|
||||||
return path
|
|
||||||
})
|
|
||||||
dedup.SetPreload(func(pkg *types.Package, files []*ast.File) {
|
|
||||||
cl.ParsePkgSyntax(prog, pkg, files)
|
|
||||||
})
|
|
||||||
|
|
||||||
initial, err := packages.LoadEx(dedup, prog.TypeSizes, cfg, fileOrPkg)
|
|
||||||
check(err)
|
|
||||||
|
|
||||||
buildMode := ssa.SanityCheckFunctions | ssa.InstantiateGenerics
|
|
||||||
if build.IsDebugEnabled() {
|
|
||||||
buildMode |= ssa.GlobalDebug
|
|
||||||
}
|
|
||||||
if !build.IsOptimizeEnabled() {
|
|
||||||
buildMode |= ssa.NaiveForm
|
|
||||||
}
|
|
||||||
_, pkgs := ssautil.AllPackages(initial, buildMode)
|
|
||||||
|
|
||||||
pkg := initial[0]
|
|
||||||
ssaPkg := pkgs[0]
|
|
||||||
ssaPkg.Build()
|
|
||||||
|
|
||||||
initRtAndPy(prog, cfg)
|
|
||||||
|
|
||||||
if Verbose {
|
|
||||||
ssaPkg.WriteTo(os.Stderr)
|
|
||||||
}
|
|
||||||
|
|
||||||
ret, err := cl.NewPackage(prog, ssaPkg, pkg.Syntax)
|
|
||||||
check(err)
|
|
||||||
|
|
||||||
if prog.NeedPyInit { // call PyInit if needed
|
|
||||||
ret.PyInit()
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret.String()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func DoFile(fileOrPkg, outFile string) {
|
func DoFile(fileOrPkg, outFile string) {
|
||||||
@@ -126,9 +49,12 @@ func DoFile(fileOrPkg, outFile string) {
|
|||||||
check(err)
|
check(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
func SmartDoFile(inFile string, pkgPath ...string) {
|
func SmartDoFile(pkgPath ...string) {
|
||||||
|
pkg, err := genFrom(pkgPath[0])
|
||||||
|
check(err)
|
||||||
|
|
||||||
const autgenFile = "llgo_autogen.ll"
|
const autgenFile = "llgo_autogen.ll"
|
||||||
dir, _ := filepath.Split(inFile)
|
dir, _ := filepath.Split(pkg.GoFiles[0])
|
||||||
absDir, _ := filepath.Abs(dir)
|
absDir, _ := filepath.Abs(dir)
|
||||||
absDir = filepath.ToSlash(absDir)
|
absDir = filepath.ToSlash(absDir)
|
||||||
fname := autgenFile
|
fname := autgenFile
|
||||||
@@ -142,10 +68,8 @@ func SmartDoFile(inFile string, pkgPath ...string) {
|
|||||||
return // skip to gen
|
return // skip to gen
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(pkgPath) > 0 {
|
if err = os.WriteFile(outFile, []byte(pkg.LPkg.String()), 0644); err != nil {
|
||||||
Do(pkgPath[0], inFile, outFile)
|
panic(err)
|
||||||
} else {
|
|
||||||
DoFile(inFile, outFile)
|
|
||||||
}
|
}
|
||||||
if false && fname == autgenFile {
|
if false && fname == autgenFile {
|
||||||
genZip(absDir, "llgo_autogen.lla", autgenFile)
|
genZip(absDir, "llgo_autogen.lla", autgenFile)
|
||||||
|
|||||||
@@ -30,27 +30,27 @@ func init() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestFromTestlibgo(t *testing.T) {
|
func TestFromTestlibgo(t *testing.T) {
|
||||||
cltest.FromDir(t, "", "../cl/_testlibgo", false)
|
cltest.FromDir(t, "", "../cl/_testlibgo")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFromTestgo(t *testing.T) {
|
func TestFromTestgo(t *testing.T) {
|
||||||
cltest.FromDir(t, "", "../cl/_testgo", false)
|
cltest.FromDir(t, "", "../cl/_testgo")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFromTestpy(t *testing.T) {
|
func TestFromTestpy(t *testing.T) {
|
||||||
cltest.FromDir(t, "", "../cl/_testpy", false)
|
cltest.FromDir(t, "", "../cl/_testpy")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFromTestlibc(t *testing.T) {
|
func TestFromTestlibc(t *testing.T) {
|
||||||
cltest.FromDir(t, "", "../cl/_testlibc", true)
|
cltest.FromDir(t, "", "../cl/_testlibc")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFromTestrt(t *testing.T) {
|
func TestFromTestrt(t *testing.T) {
|
||||||
cltest.FromDir(t, "", "../cl/_testrt", true)
|
cltest.FromDir(t, "", "../cl/_testrt")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFromTestdata(t *testing.T) {
|
func TestFromTestdata(t *testing.T) {
|
||||||
cltest.FromDir(t, "", "../cl/_testdata", false)
|
cltest.FromDir(t, "", "../cl/_testdata")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestMakeInterface(t *testing.T) {
|
func TestMakeInterface(t *testing.T) {
|
||||||
|
|||||||
Reference in New Issue
Block a user