goscript 0.1.3 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +5 -2
- package/cmd/go_js_wasm_exec/main.go +201 -0
- package/cmd/go_js_wasm_exec/main_test.go +83 -0
- package/cmd/goscript/{cmd_compile.go → cmd-compile.go} +35 -8
- package/cmd/goscript/cmd-test.go +14 -0
- package/cmd/goscript/cmd-test_test.go +1 -1
- package/cmd/goscript/cmd_compile_test.go +105 -6
- package/compiler/build-flags.go +9 -10
- package/compiler/compile-request.go +12 -9
- package/compiler/compliance_test.go +0 -1
- package/compiler/config.go +2 -0
- package/compiler/gotest/request.go +28 -0
- package/compiler/gotest/runner.go +353 -27
- package/compiler/gotest/runner_test.go +400 -1
- package/compiler/gotest/testdata/browserapi/browserapi_test.go +20 -0
- package/compiler/gotest/testdata/browserapi/go.mod +3 -0
- package/compiler/lowered-program.go +24 -17
- package/compiler/lowering.go +988 -263
- package/compiler/lowering_bench_test.go +364 -0
- package/compiler/override-facts.go +15 -0
- package/compiler/override-parity-verifier.go +450 -0
- package/compiler/override-parity.go +122 -0
- package/compiler/override-registry_test.go +559 -0
- package/compiler/package-graph.go +61 -4
- package/compiler/package-graph_test.go +30 -0
- package/compiler/protobuf-ts-binding.go +514 -0
- package/compiler/protobuf-ts-binding_test.go +172 -0
- package/compiler/semantic-model-types.go +17 -4
- package/compiler/semantic-model.go +709 -72
- package/compiler/semantic-model_test.go +219 -0
- package/compiler/service.go +20 -1
- package/compiler/skeleton_test.go +1008 -20
- package/compiler/typescript-emitter.go +147 -15
- package/dist/gs/builtin/builtin.d.ts +2 -2
- package/dist/gs/builtin/builtin.js +20 -0
- package/dist/gs/builtin/builtin.js.map +1 -1
- package/dist/gs/builtin/slice.d.ts +2 -1
- package/dist/gs/builtin/slice.js +34 -4
- package/dist/gs/builtin/slice.js.map +1 -1
- package/dist/gs/builtin/type.d.ts +14 -6
- package/dist/gs/builtin/type.js +224 -64
- package/dist/gs/builtin/type.js.map +1 -1
- package/dist/gs/builtin/varRef.d.ts +11 -0
- package/dist/gs/builtin/varRef.js +57 -2
- package/dist/gs/builtin/varRef.js.map +1 -1
- package/dist/gs/bytes/buffer.gs.js +1 -1
- package/dist/gs/bytes/buffer.gs.js.map +1 -1
- package/dist/gs/bytes/reader.gs.js +1 -1
- package/dist/gs/bytes/reader.gs.js.map +1 -1
- package/dist/gs/compress/zlib/index.d.ts +13 -6
- package/dist/gs/compress/zlib/index.js +131 -35
- package/dist/gs/compress/zlib/index.js.map +1 -1
- package/dist/gs/crypto/sha1/index.js +2 -5
- package/dist/gs/crypto/sha1/index.js.map +1 -1
- package/dist/gs/crypto/sha256/index.js +2 -5
- package/dist/gs/crypto/sha256/index.js.map +1 -1
- package/dist/gs/crypto/sha512/index.js +2 -5
- package/dist/gs/crypto/sha512/index.js.map +1 -1
- package/dist/gs/embed/index.d.ts +6 -0
- package/dist/gs/embed/index.js +210 -5
- package/dist/gs/embed/index.js.map +1 -1
- package/dist/gs/encoding/json/index.d.ts +114 -0
- package/dist/gs/encoding/json/index.js +544 -36
- package/dist/gs/encoding/json/index.js.map +1 -1
- package/dist/gs/fmt/fmt.d.ts +3 -3
- package/dist/gs/fmt/fmt.js +29 -16
- package/dist/gs/fmt/fmt.js.map +1 -1
- package/dist/gs/github.com/aperturerobotics/protobuf-go-lite/index.d.ts +100 -0
- package/dist/gs/github.com/aperturerobotics/protobuf-go-lite/index.js +564 -0
- package/dist/gs/github.com/aperturerobotics/protobuf-go-lite/index.js.map +1 -1
- package/dist/gs/github.com/go-git/go-billy/v6/osfs/index.d.ts +45 -0
- package/dist/gs/github.com/go-git/go-billy/v6/osfs/index.js +229 -0
- package/dist/gs/github.com/go-git/go-billy/v6/osfs/index.js.map +1 -0
- package/dist/gs/github.com/pkg/errors/errors.js +54 -30
- package/dist/gs/github.com/pkg/errors/errors.js.map +1 -1
- package/dist/gs/go/scanner/index.d.ts +2 -0
- package/dist/gs/go/scanner/index.js +29 -5
- package/dist/gs/go/scanner/index.js.map +1 -1
- package/dist/gs/go/token/index.js +22 -6
- package/dist/gs/go/token/index.js.map +1 -1
- package/dist/gs/hash/index.d.ts +6 -0
- package/dist/gs/hash/index.js +20 -0
- package/dist/gs/hash/index.js.map +1 -1
- package/dist/gs/internal/goarch/index.d.ts +43 -3
- package/dist/gs/internal/goarch/index.js +42 -10
- package/dist/gs/internal/goarch/index.js.map +1 -1
- package/dist/gs/io/fs/fs.js +26 -14
- package/dist/gs/io/fs/fs.js.map +1 -1
- package/dist/gs/io/fs/readdir.js +8 -4
- package/dist/gs/io/fs/readdir.js.map +1 -1
- package/dist/gs/io/fs/sub.js +8 -1
- package/dist/gs/io/fs/sub.js.map +1 -1
- package/dist/gs/io/io.d.ts +12 -6
- package/dist/gs/io/io.js +87 -42
- package/dist/gs/io/io.js.map +1 -1
- package/dist/gs/math/bits/index.d.ts +31 -5
- package/dist/gs/math/bits/index.js +29 -28
- package/dist/gs/math/bits/index.js.map +1 -1
- package/dist/gs/mime/index.d.ts +16 -0
- package/dist/gs/mime/index.js +315 -6
- package/dist/gs/mime/index.js.map +1 -1
- package/dist/gs/net/http/httptest/index.d.ts +12 -0
- package/dist/gs/net/http/httptest/index.js +85 -6
- package/dist/gs/net/http/httptest/index.js.map +1 -1
- package/dist/gs/net/http/index.d.ts +303 -6
- package/dist/gs/net/http/index.js +1615 -58
- package/dist/gs/net/http/index.js.map +1 -1
- package/dist/gs/os/dir_unix.gs.js +1 -1
- package/dist/gs/os/dir_unix.gs.js.map +1 -1
- package/dist/gs/os/error.gs.js +1 -1
- package/dist/gs/os/error.gs.js.map +1 -1
- package/dist/gs/os/exec.gs.d.ts +1 -0
- package/dist/gs/os/exec.gs.js +4 -8
- package/dist/gs/os/exec.gs.js.map +1 -1
- package/dist/gs/os/exec_posix.gs.js +1 -1
- package/dist/gs/os/exec_posix.gs.js.map +1 -1
- package/dist/gs/os/index.d.ts +1 -1
- package/dist/gs/os/index.js +1 -1
- package/dist/gs/os/index.js.map +1 -1
- package/dist/gs/os/proc.gs.d.ts +4 -0
- package/dist/gs/os/proc.gs.js +12 -6
- package/dist/gs/os/proc.gs.js.map +1 -1
- package/dist/gs/os/root_js.gs.js +1 -1
- package/dist/gs/os/root_js.gs.js.map +1 -1
- package/dist/gs/os/types.gs.js +1 -1
- package/dist/gs/os/types.gs.js.map +1 -1
- package/dist/gs/os/types_js.gs.d.ts +6 -2
- package/dist/gs/os/types_js.gs.js +170 -9
- package/dist/gs/os/types_js.gs.js.map +1 -1
- package/dist/gs/os/types_unix.gs.js +1 -1
- package/dist/gs/os/types_unix.gs.js.map +1 -1
- package/dist/gs/path/path.js +11 -7
- package/dist/gs/path/path.js.map +1 -1
- package/dist/gs/reflect/index.d.ts +5 -4
- package/dist/gs/reflect/index.js +4 -3
- package/dist/gs/reflect/index.js.map +1 -1
- package/dist/gs/reflect/map.js +15 -0
- package/dist/gs/reflect/map.js.map +1 -1
- package/dist/gs/reflect/type.d.ts +26 -6
- package/dist/gs/reflect/type.js +1498 -279
- package/dist/gs/reflect/type.js.map +1 -1
- package/dist/gs/reflect/types.d.ts +14 -6
- package/dist/gs/reflect/types.js +35 -1
- package/dist/gs/reflect/types.js.map +1 -1
- package/dist/gs/reflect/value.d.ts +1 -0
- package/dist/gs/reflect/value.js +83 -41
- package/dist/gs/reflect/value.js.map +1 -1
- package/dist/gs/reflect/visiblefields.js +4 -140
- package/dist/gs/reflect/visiblefields.js.map +1 -1
- package/dist/gs/runtime/pprof/index.d.ts +8 -2
- package/dist/gs/runtime/pprof/index.js +50 -30
- package/dist/gs/runtime/pprof/index.js.map +1 -1
- package/dist/gs/runtime/runtime.js +5 -4
- package/dist/gs/runtime/runtime.js.map +1 -1
- package/dist/gs/runtime/trace/index.js +5 -19
- package/dist/gs/runtime/trace/index.js.map +1 -1
- package/dist/gs/strconv/atoi.gs.js +1 -1
- package/dist/gs/strconv/atoi.gs.js.map +1 -1
- package/dist/gs/strconv/complex.gs.d.ts +3 -0
- package/dist/gs/strconv/complex.gs.js +148 -0
- package/dist/gs/strconv/complex.gs.js.map +1 -0
- package/dist/gs/strconv/index.d.ts +1 -0
- package/dist/gs/strconv/index.js +1 -0
- package/dist/gs/strconv/index.js.map +1 -1
- package/dist/gs/strings/builder.js +1 -1
- package/dist/gs/strings/reader.d.ts +1 -1
- package/dist/gs/strings/reader.js +11 -7
- package/dist/gs/strings/reader.js.map +1 -1
- package/dist/gs/strings/replace.js +15 -7
- package/dist/gs/strings/replace.js.map +1 -1
- package/dist/gs/strings/strings.d.ts +5 -0
- package/dist/gs/strings/strings.js +57 -5
- package/dist/gs/strings/strings.js.map +1 -1
- package/dist/gs/sync/atomic/type.gs.js +9 -9
- package/dist/gs/sync/atomic/type.gs.js.map +1 -1
- package/dist/gs/sync/atomic/value.gs.js +2 -2
- package/dist/gs/sync/atomic/value.gs.js.map +1 -1
- package/dist/gs/sync/sync.d.ts +2 -1
- package/dist/gs/sync/sync.js +37 -16
- package/dist/gs/sync/sync.js.map +1 -1
- package/dist/gs/syscall/env.js +22 -14
- package/dist/gs/syscall/env.js.map +1 -1
- package/dist/gs/syscall/js/index.js +9 -0
- package/dist/gs/syscall/js/index.js.map +1 -1
- package/dist/gs/testing/testing.js +59 -15
- package/dist/gs/testing/testing.js.map +1 -1
- package/dist/gs/time/time.d.ts +24 -1
- package/dist/gs/time/time.js +43 -3
- package/dist/gs/time/time.js.map +1 -1
- package/dist/gs/unique/index.js +7 -1
- package/dist/gs/unique/index.js.map +1 -1
- package/go.mod +3 -3
- package/go.sum +16 -0
- package/gs/builtin/builtin.ts +25 -2
- package/gs/builtin/runtime-contract.test.ts +260 -18
- package/gs/builtin/slice.ts +51 -4
- package/gs/builtin/type.ts +310 -63
- package/gs/builtin/varRef.ts +85 -2
- package/gs/bytes/buffer.gs.ts +1 -1
- package/gs/bytes/reader.gs.ts +1 -1
- package/gs/compress/zlib/index.test.ts +159 -1
- package/gs/compress/zlib/index.ts +164 -37
- package/gs/compress/zlib/meta.json +4 -1
- package/gs/compress/zlib/parity.json +51 -0
- package/gs/crypto/sha1/index.test.ts +19 -2
- package/gs/crypto/sha1/index.ts +3 -6
- package/gs/crypto/sha256/index.test.ts +14 -2
- package/gs/crypto/sha256/index.ts +3 -6
- package/gs/crypto/sha512/index.test.ts +17 -2
- package/gs/crypto/sha512/index.ts +3 -6
- package/gs/embed/index.test.ts +87 -0
- package/gs/embed/index.ts +229 -5
- package/gs/encoding/json/index.test.ts +360 -6
- package/gs/encoding/json/index.ts +679 -38
- package/gs/encoding/json/parity.json +81 -0
- package/gs/fmt/fmt.test.ts +41 -3
- package/gs/fmt/fmt.ts +40 -17
- package/gs/fmt/meta.json +6 -1
- package/gs/github.com/aperturerobotics/protobuf-go-lite/index.test.ts +211 -3
- package/gs/github.com/aperturerobotics/protobuf-go-lite/index.ts +857 -1
- package/gs/github.com/go-git/go-billy/v6/osfs/index.test.ts +110 -0
- package/gs/github.com/go-git/go-billy/v6/osfs/index.ts +280 -0
- package/gs/github.com/go-git/go-billy/v6/osfs/meta.json +8 -0
- package/gs/github.com/pkg/errors/errors.ts +54 -30
- package/gs/go/scanner/index.test.ts +39 -56
- package/gs/go/scanner/index.ts +33 -5
- package/gs/go/scanner/parity.json +27 -0
- package/gs/go/token/index.ts +22 -6
- package/gs/hash/index.test.ts +20 -33
- package/gs/hash/index.ts +28 -0
- package/gs/hash/parity.json +21 -0
- package/gs/internal/goarch/index.test.ts +32 -0
- package/gs/internal/goarch/index.ts +45 -13
- package/gs/internal/goarch/parity.json +144 -0
- package/gs/io/fs/fs.ts +26 -14
- package/gs/io/fs/readdir.test.ts +38 -0
- package/gs/io/fs/readdir.ts +8 -4
- package/gs/io/fs/sub.ts +8 -1
- package/gs/io/io.test.ts +77 -6
- package/gs/io/io.ts +115 -52
- package/gs/io/meta.json +7 -1
- package/gs/io/parity.json +162 -0
- package/gs/math/bits/index.test.ts +14 -1
- package/gs/math/bits/index.ts +75 -32
- package/gs/math/bits/parity.json +156 -0
- package/gs/mime/index.test.ts +90 -0
- package/gs/mime/index.ts +369 -6
- package/gs/mime/parity.json +36 -0
- package/gs/net/http/httptest/index.test.ts +98 -2
- package/gs/net/http/httptest/index.ts +101 -6
- package/gs/net/http/httptest/parity.json +15 -0
- package/gs/net/http/index.test.ts +797 -12
- package/gs/net/http/index.ts +1874 -136
- package/gs/net/http/meta.json +16 -1
- package/gs/net/http/parity.json +193 -0
- package/gs/os/dir_unix.gs.ts +1 -1
- package/gs/os/error.gs.ts +1 -1
- package/gs/os/exec.gs.ts +4 -8
- package/gs/os/exec_posix.gs.ts +1 -1
- package/gs/os/file_unix_js.test.ts +52 -0
- package/gs/os/index.test.ts +9 -0
- package/gs/os/index.ts +1 -0
- package/gs/os/meta.json +4 -0
- package/gs/os/parity.json +9 -0
- package/gs/os/proc.gs.ts +18 -5
- package/gs/os/proc.test.ts +26 -0
- package/gs/os/readdir.test.ts +56 -0
- package/gs/os/root_js.gs.ts +1 -1
- package/gs/os/types.gs.ts +1 -1
- package/gs/os/types_js.gs.ts +170 -9
- package/gs/os/types_unix.gs.ts +1 -1
- package/gs/path/path.ts +11 -7
- package/gs/reflect/deepequal.test.ts +10 -1
- package/gs/reflect/field.test.ts +37 -15
- package/gs/reflect/function-types.test.ts +518 -22
- package/gs/reflect/index.ts +8 -6
- package/gs/reflect/map.ts +20 -0
- package/gs/reflect/meta.json +6 -4
- package/gs/reflect/parity.json +234 -0
- package/gs/reflect/sliceat.test.ts +156 -0
- package/gs/reflect/structof.test.ts +401 -0
- package/gs/reflect/type.ts +1980 -365
- package/gs/reflect/typefor.test.ts +540 -10
- package/gs/reflect/types.ts +43 -18
- package/gs/reflect/value.ts +105 -45
- package/gs/reflect/visiblefields.ts +5 -168
- package/gs/runtime/parity.json +24 -0
- package/gs/runtime/pprof/index.test.ts +29 -7
- package/gs/runtime/pprof/index.ts +56 -30
- package/gs/runtime/pprof/parity.json +27 -0
- package/gs/runtime/runtime.test.ts +3 -1
- package/gs/runtime/runtime.ts +4 -3
- package/gs/runtime/trace/index.test.ts +5 -3
- package/gs/runtime/trace/index.ts +8 -20
- package/gs/runtime/trace/parity.json +36 -0
- package/gs/strconv/atoi.gs.ts +1 -1
- package/gs/strconv/complex.gs.ts +174 -0
- package/gs/strconv/complex.test.ts +65 -0
- package/gs/strconv/index.ts +1 -0
- package/gs/strconv/parity.json +120 -0
- package/gs/strings/builder.ts +1 -1
- package/gs/strings/meta.json +5 -2
- package/gs/strings/parity.json +186 -0
- package/gs/strings/reader.test.ts +2 -2
- package/gs/strings/reader.ts +11 -7
- package/gs/strings/replace.ts +15 -7
- package/gs/strings/strings.test.ts +22 -2
- package/gs/strings/strings.ts +64 -6
- package/gs/sync/atomic/type.gs.ts +9 -9
- package/gs/sync/atomic/value.gs.ts +2 -2
- package/gs/sync/meta.json +1 -0
- package/gs/sync/sync.test.ts +41 -1
- package/gs/sync/sync.ts +41 -16
- package/gs/syscall/env.ts +29 -14
- package/gs/syscall/js/index.test.ts +18 -0
- package/gs/syscall/js/index.ts +12 -0
- package/gs/testing/testing.test.ts +99 -3
- package/gs/testing/testing.ts +95 -24
- package/gs/time/parity.json +225 -0
- package/gs/time/time.test.ts +20 -2
- package/gs/time/time.ts +49 -7
- package/gs/unique/index.ts +7 -1
- package/package.json +4 -2
- package/dist/gs/github.com/aperturerobotics/starpc/srpc/index.d.ts +0 -217
- package/dist/gs/github.com/aperturerobotics/starpc/srpc/index.js +0 -814
- package/dist/gs/github.com/aperturerobotics/starpc/srpc/index.js.map +0 -1
- package/gs/github.com/aperturerobotics/starpc/srpc/index.test.ts +0 -31
- package/gs/github.com/aperturerobotics/starpc/srpc/index.ts +0 -1233
- package/gs/github.com/aperturerobotics/starpc/srpc/meta.json +0 -46
- /package/compiler/{wasm_api.go → wasm-api.go} +0 -0
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
package compiler
|
|
2
|
+
|
|
3
|
+
import (
|
|
4
|
+
"context"
|
|
5
|
+
"errors"
|
|
6
|
+
"go/ast"
|
|
7
|
+
"os"
|
|
8
|
+
"path/filepath"
|
|
9
|
+
"strings"
|
|
10
|
+
"testing"
|
|
11
|
+
|
|
12
|
+
"golang.org/x/tools/go/packages"
|
|
13
|
+
)
|
|
14
|
+
|
|
15
|
+
func TestProtobufTypeScriptBindingSkipsPbGoEmission(t *testing.T) {
|
|
16
|
+
dir := t.TempDir()
|
|
17
|
+
writeTestFile(t, dir, "go.mod", "module example.test/protobufbinding\n\ngo 1.25\n")
|
|
18
|
+
writeTestFile(t, dir, "foo.pb.go", `package protobufbinding
|
|
19
|
+
|
|
20
|
+
type Foo struct {
|
|
21
|
+
Name string
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
type Object struct {
|
|
25
|
+
Name string
|
|
26
|
+
}
|
|
27
|
+
`)
|
|
28
|
+
writeTestFile(t, dir, "foo.pb.ts", `export interface Foo {
|
|
29
|
+
name?: string
|
|
30
|
+
}
|
|
31
|
+
export const Foo = {} as any
|
|
32
|
+
export interface Object$ {
|
|
33
|
+
name?: string
|
|
34
|
+
}
|
|
35
|
+
export const Object$ = {} as any
|
|
36
|
+
`)
|
|
37
|
+
writeTestFile(t, dir, "use.go", `package protobufbinding
|
|
38
|
+
|
|
39
|
+
func NewFoo() Foo {
|
|
40
|
+
return Foo{Name: "bound"}
|
|
41
|
+
}
|
|
42
|
+
`)
|
|
43
|
+
|
|
44
|
+
out := filepath.Join(dir, "out")
|
|
45
|
+
comp, err := NewCompiler(&Config{
|
|
46
|
+
Dir: dir,
|
|
47
|
+
OutputPath: out,
|
|
48
|
+
ProtobufTypeScriptBinding: true,
|
|
49
|
+
}, nil, nil)
|
|
50
|
+
if err != nil {
|
|
51
|
+
t.Fatal(err)
|
|
52
|
+
}
|
|
53
|
+
if _, err := comp.CompilePackages(context.Background(), "."); err != nil {
|
|
54
|
+
t.Fatalf("compile with protobuf TypeScript binding: %v", err)
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
pkgDir := filepath.Join(out, "@goscript", "example.test", "protobufbinding")
|
|
58
|
+
if _, err := os.Stat(filepath.Join(pkgDir, "foo.pb.gs.ts")); !errors.Is(err, os.ErrNotExist) {
|
|
59
|
+
t.Fatalf("bound protobuf file should not emit foo.pb.gs.ts, stat err=%v", err)
|
|
60
|
+
}
|
|
61
|
+
binding := readTestFile(t, filepath.Join(pkgDir, "foo.pb.ts"))
|
|
62
|
+
if !strings.Contains(binding, `import * as __protobuf_ts`) || !strings.Contains(binding, `foo.pb.js`) ||
|
|
63
|
+
!strings.Contains(binding, `class Foo`) || !strings.Contains(binding, `__protobufTypeScriptMessage = __protobuf_ts.Foo`) {
|
|
64
|
+
t.Fatalf("binding file should adapt sibling foo.pb.js, got:\n%s", binding)
|
|
65
|
+
}
|
|
66
|
+
if !strings.Contains(binding, `class Object`) || !strings.Contains(binding, `__protobufTypeScriptMessage = __protobuf_ts.Object$`) {
|
|
67
|
+
t.Fatalf("binding file should use protobuf-es-lite safe identifier for Object, got:\n%s", binding)
|
|
68
|
+
}
|
|
69
|
+
if !strings.Contains(binding, `__protobufTypeScriptMessage = __protobuf_ts.Foo;`) ||
|
|
70
|
+
!strings.Contains(binding, `__protobufTypeScriptFields = {};`) {
|
|
71
|
+
t.Fatalf("binding metadata assignments should be semicolon-terminated to avoid ASI calls, got:\n%s", binding)
|
|
72
|
+
}
|
|
73
|
+
index := readTestFile(t, filepath.Join(pkgDir, "index.ts"))
|
|
74
|
+
if !strings.Contains(index, `export { Foo, Object } from "./foo.pb.ts"`) {
|
|
75
|
+
t.Fatalf("package index should re-export binding file, got:\n%s", index)
|
|
76
|
+
}
|
|
77
|
+
use := readTestFile(t, filepath.Join(pkgDir, "use.gs.ts"))
|
|
78
|
+
if !strings.Contains(use, `from "./foo.pb.ts"`) {
|
|
79
|
+
t.Fatalf("non-protobuf file should import bound protobuf declarations, got:\n%s", use)
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
func TestProtobufTypeScriptBindingReportsMissingSibling(t *testing.T) {
|
|
84
|
+
dir := t.TempDir()
|
|
85
|
+
writeTestFile(t, dir, "go.mod", "module example.test/missingpbts\n\ngo 1.25\n")
|
|
86
|
+
writeTestFile(t, dir, "foo.pb.go", `package missingpbts
|
|
87
|
+
|
|
88
|
+
type Foo struct{}
|
|
89
|
+
`)
|
|
90
|
+
|
|
91
|
+
comp, err := NewCompiler(&Config{
|
|
92
|
+
Dir: dir,
|
|
93
|
+
OutputPath: filepath.Join(dir, "out"),
|
|
94
|
+
ProtobufTypeScriptBinding: true,
|
|
95
|
+
}, nil, nil)
|
|
96
|
+
if err != nil {
|
|
97
|
+
t.Fatal(err)
|
|
98
|
+
}
|
|
99
|
+
result, err := comp.CompilePackages(context.Background(), ".")
|
|
100
|
+
if err == nil {
|
|
101
|
+
t.Fatal("expected missing sibling .pb.ts to fail")
|
|
102
|
+
}
|
|
103
|
+
if result == nil {
|
|
104
|
+
t.Fatal("expected diagnostics result")
|
|
105
|
+
}
|
|
106
|
+
for _, diag := range result.Diagnostics {
|
|
107
|
+
if diag.Code == "goscript/protobuf-ts-binding:missing" {
|
|
108
|
+
return
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
t.Fatalf("missing protobuf binding diagnostic not found: %#v", result.Diagnostics)
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
func TestProtobufTypeScriptBindingSkipsFilesOutsideSourceRoot(t *testing.T) {
|
|
115
|
+
dir := t.TempDir()
|
|
116
|
+
outside := filepath.Join(t.TempDir(), "outside.pb.go")
|
|
117
|
+
writeTestFile(t, dir, "go.mod", "module example.test/outsidepb\n\ngo 1.25\n")
|
|
118
|
+
writeTestFile(t, dir, "use.go", `package outsidepb
|
|
119
|
+
`)
|
|
120
|
+
|
|
121
|
+
semPkg := &semanticPackage{
|
|
122
|
+
pkgPath: "example.test/outsidepb",
|
|
123
|
+
source: &packages.Package{
|
|
124
|
+
CompiledGoFiles: []string{outside},
|
|
125
|
+
GoFiles: []string{outside},
|
|
126
|
+
Syntax: make([]*ast.File, 1),
|
|
127
|
+
},
|
|
128
|
+
}
|
|
129
|
+
bindings, diagnostics := protobufTypeScriptBindings(semPkg, LoweringOptions{
|
|
130
|
+
SourceRoot: dir,
|
|
131
|
+
OutputPath: filepath.Join(dir, "out"),
|
|
132
|
+
ProtobufTypeScriptBinding: true,
|
|
133
|
+
})
|
|
134
|
+
if len(diagnostics) != 0 {
|
|
135
|
+
t.Fatalf("outside source root diagnostics = %#v", diagnostics)
|
|
136
|
+
}
|
|
137
|
+
if len(bindings) != 0 {
|
|
138
|
+
t.Fatalf("outside source root bindings = %#v", bindings)
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
func TestProtobufTypeScriptBindingRootFindsParentModule(t *testing.T) {
|
|
143
|
+
dir := t.TempDir()
|
|
144
|
+
writeTestFile(t, dir, "go.mod", "module example.test/root\n\ngo 1.25\n")
|
|
145
|
+
nested := filepath.Join(dir, ".bldr", "build", "plugin")
|
|
146
|
+
if err := os.MkdirAll(nested, 0o755); err != nil {
|
|
147
|
+
t.Fatal(err)
|
|
148
|
+
}
|
|
149
|
+
if got := protobufTypeScriptBindingRoot(nested); got != dir {
|
|
150
|
+
t.Fatalf("binding root = %q, want %q", got, dir)
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
func writeTestFile(t *testing.T, root, rel, data string) {
|
|
155
|
+
t.Helper()
|
|
156
|
+
path := filepath.Join(root, rel)
|
|
157
|
+
if err := os.MkdirAll(filepath.Dir(path), 0o755); err != nil {
|
|
158
|
+
t.Fatal(err)
|
|
159
|
+
}
|
|
160
|
+
if err := os.WriteFile(path, []byte(data), 0o644); err != nil {
|
|
161
|
+
t.Fatal(err)
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
func readTestFile(t *testing.T, path string) string {
|
|
166
|
+
t.Helper()
|
|
167
|
+
data, err := os.ReadFile(path)
|
|
168
|
+
if err != nil {
|
|
169
|
+
t.Fatal(err)
|
|
170
|
+
}
|
|
171
|
+
return string(data)
|
|
172
|
+
}
|
|
@@ -12,12 +12,17 @@ type SemanticModel struct {
|
|
|
12
12
|
addressTaken map[types.Object]bool
|
|
13
13
|
needsVarRef map[types.Object]bool
|
|
14
14
|
functions map[*types.Func]*semanticFunction
|
|
15
|
+
functionCallers map[*types.Func][]*semanticFunction
|
|
15
16
|
functionsByFullName map[string]*semanticFunction
|
|
16
17
|
functionLookupMisses map[*types.Func]bool
|
|
18
|
+
functionFullNames map[*types.Func]string
|
|
17
19
|
types map[*types.Named]*semanticType
|
|
18
20
|
values map[types.Object]*semanticValue
|
|
19
21
|
generatedImports map[string]map[string]bool
|
|
22
|
+
generatedImportTypes map[string]map[types.Type]bool
|
|
20
23
|
interfaceImplementations []semanticInterfaceImplementation
|
|
24
|
+
asyncInterfaceMethods map[string]bool
|
|
25
|
+
asyncInterfaceMethodObjs map[*types.Func]bool
|
|
21
26
|
}
|
|
22
27
|
|
|
23
28
|
type semanticPackage struct {
|
|
@@ -63,6 +68,10 @@ type semanticField struct {
|
|
|
63
68
|
doc string
|
|
64
69
|
tag string
|
|
65
70
|
embedded bool
|
|
71
|
+
pkgPath string
|
|
72
|
+
index []int
|
|
73
|
+
offset int64
|
|
74
|
+
exported bool
|
|
66
75
|
}
|
|
67
76
|
|
|
68
77
|
type semanticValue struct {
|
|
@@ -89,10 +98,9 @@ type semanticFunction struct {
|
|
|
89
98
|
}
|
|
90
99
|
|
|
91
100
|
type semanticInterfaceImplementation struct {
|
|
92
|
-
typ
|
|
93
|
-
iface
|
|
94
|
-
pointer
|
|
95
|
-
asyncMethods map[string]bool
|
|
101
|
+
typ *types.Named
|
|
102
|
+
iface *types.Named
|
|
103
|
+
pointer bool
|
|
96
104
|
}
|
|
97
105
|
|
|
98
106
|
type semanticInterfaceImplementationGraphEntry struct {
|
|
@@ -103,6 +111,11 @@ type semanticInterfaceImplementationGraphEntry struct {
|
|
|
103
111
|
implMethods map[string]*types.Func
|
|
104
112
|
}
|
|
105
113
|
|
|
114
|
+
type semanticAnonymousInterfaceImplementation struct {
|
|
115
|
+
ifaceMethods map[string]*types.Func
|
|
116
|
+
implMethods map[string]*types.Func
|
|
117
|
+
}
|
|
118
|
+
|
|
106
119
|
type semanticImplementationMethodSet struct {
|
|
107
120
|
typ *types.Named
|
|
108
121
|
receiver types.Type
|