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
package/gs/go/token/index.ts
CHANGED
|
@@ -285,12 +285,28 @@ export class Position {
|
|
|
285
285
|
},
|
|
286
286
|
],
|
|
287
287
|
Position,
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
288
|
+
[
|
|
289
|
+
{
|
|
290
|
+
name: 'Filename',
|
|
291
|
+
key: 'Filename',
|
|
292
|
+
type: { kind: $.TypeKind.Basic, name: 'string' },
|
|
293
|
+
},
|
|
294
|
+
{
|
|
295
|
+
name: 'Offset',
|
|
296
|
+
key: 'Offset',
|
|
297
|
+
type: { kind: $.TypeKind.Basic, name: 'int' },
|
|
298
|
+
},
|
|
299
|
+
{
|
|
300
|
+
name: 'Line',
|
|
301
|
+
key: 'Line',
|
|
302
|
+
type: { kind: $.TypeKind.Basic, name: 'int' },
|
|
303
|
+
},
|
|
304
|
+
{
|
|
305
|
+
name: 'Column',
|
|
306
|
+
key: 'Column',
|
|
307
|
+
type: { kind: $.TypeKind.Basic, name: 'int' },
|
|
308
|
+
},
|
|
309
|
+
],
|
|
294
310
|
)
|
|
295
311
|
}
|
|
296
312
|
|
package/gs/hash/index.test.ts
CHANGED
|
@@ -1,37 +1,24 @@
|
|
|
1
1
|
import { describe, expect, it } from 'vitest'
|
|
2
2
|
|
|
3
|
-
import * as $ from '
|
|
4
|
-
|
|
5
|
-
import './index.js'
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
return 64
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
describe('hash runtime contracts', () => {
|
|
28
|
-
it('registers Hash for runtime type assertions', () => {
|
|
29
|
-
const [value, ok] = $.typeAssertTuple<FakeHash>(
|
|
30
|
-
new FakeHash(),
|
|
31
|
-
'hash.Hash',
|
|
32
|
-
)
|
|
33
|
-
|
|
34
|
-
expect(ok).toBe(true)
|
|
35
|
-
expect(value).toBeInstanceOf(FakeHash)
|
|
3
|
+
import * as $ from '@goscript/builtin/index.js'
|
|
4
|
+
|
|
5
|
+
import type { XOF } from './index.js'
|
|
6
|
+
|
|
7
|
+
describe('hash override', () => {
|
|
8
|
+
it('exports the XOF interface shape', () => {
|
|
9
|
+
const xof: XOF = {
|
|
10
|
+
Write(p: $.Bytes): [number, $.GoError] {
|
|
11
|
+
return [$.len(p), null]
|
|
12
|
+
},
|
|
13
|
+
Read(p: $.Bytes): [number, $.GoError] {
|
|
14
|
+
return [$.len(p), null]
|
|
15
|
+
},
|
|
16
|
+
Reset(): void {},
|
|
17
|
+
BlockSize(): number {
|
|
18
|
+
return 1
|
|
19
|
+
},
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
expect(xof.BlockSize()).toBe(1)
|
|
36
23
|
})
|
|
37
24
|
})
|
package/gs/hash/index.ts
CHANGED
|
@@ -16,6 +16,13 @@ export interface Hash64 extends Hash {
|
|
|
16
16
|
Sum64(): bigint
|
|
17
17
|
}
|
|
18
18
|
|
|
19
|
+
export interface XOF {
|
|
20
|
+
Write(p: $.Bytes): [number, $.GoError]
|
|
21
|
+
Read(p: $.Bytes): [number, $.GoError]
|
|
22
|
+
Reset(): void
|
|
23
|
+
BlockSize(): number
|
|
24
|
+
}
|
|
25
|
+
|
|
19
26
|
export interface Cloner {
|
|
20
27
|
Clone(): [Hash, $.GoError]
|
|
21
28
|
}
|
|
@@ -116,3 +123,24 @@ $.registerInterfaceType('hash.Cloner', null, [
|
|
|
116
123
|
],
|
|
117
124
|
},
|
|
118
125
|
])
|
|
126
|
+
|
|
127
|
+
$.registerInterfaceType('hash.XOF', null, [
|
|
128
|
+
{
|
|
129
|
+
name: 'Write',
|
|
130
|
+
args: [{ name: 'p', type: bytesType }],
|
|
131
|
+
returns: [
|
|
132
|
+
{ name: 'n', type: intType },
|
|
133
|
+
{ name: 'err', type: errorType },
|
|
134
|
+
],
|
|
135
|
+
},
|
|
136
|
+
{
|
|
137
|
+
name: 'Read',
|
|
138
|
+
args: [{ name: 'p', type: bytesType }],
|
|
139
|
+
returns: [
|
|
140
|
+
{ name: 'n', type: intType },
|
|
141
|
+
{ name: 'err', type: errorType },
|
|
142
|
+
],
|
|
143
|
+
},
|
|
144
|
+
{ name: 'Reset', args: [], returns: [] },
|
|
145
|
+
{ name: 'BlockSize', args: [], returns: [{ name: '_r0', type: intType }] },
|
|
146
|
+
])
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
{
|
|
2
|
+
"schemaVersion": 1,
|
|
3
|
+
"strict": true,
|
|
4
|
+
"symbols": {
|
|
5
|
+
"Cloner": {
|
|
6
|
+
"status": "real"
|
|
7
|
+
},
|
|
8
|
+
"Hash": {
|
|
9
|
+
"status": "real"
|
|
10
|
+
},
|
|
11
|
+
"Hash32": {
|
|
12
|
+
"status": "real"
|
|
13
|
+
},
|
|
14
|
+
"Hash64": {
|
|
15
|
+
"status": "real"
|
|
16
|
+
},
|
|
17
|
+
"XOF": {
|
|
18
|
+
"status": "real"
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest'
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
ArchFamily,
|
|
5
|
+
BigEndian,
|
|
6
|
+
DefaultPhysPageSize,
|
|
7
|
+
GOARCH,
|
|
8
|
+
Int64Align,
|
|
9
|
+
IsAmd64,
|
|
10
|
+
IsWasm,
|
|
11
|
+
PCQuantum,
|
|
12
|
+
PtrBits,
|
|
13
|
+
PtrSize,
|
|
14
|
+
StackAlign,
|
|
15
|
+
WASM,
|
|
16
|
+
} from './index.js'
|
|
17
|
+
|
|
18
|
+
describe('internal/goarch override', () => {
|
|
19
|
+
it('matches JS/WASM Go architecture constants', () => {
|
|
20
|
+
expect(GOARCH).toBe('wasm')
|
|
21
|
+
expect(IsWasm).toBe(1)
|
|
22
|
+
expect(IsAmd64).toBe(0)
|
|
23
|
+
expect(PtrSize).toBe(8)
|
|
24
|
+
expect(PtrBits).toBe(64)
|
|
25
|
+
expect(Int64Align).toBe(PtrSize)
|
|
26
|
+
expect(StackAlign).toBe(PtrSize)
|
|
27
|
+
expect(BigEndian).toBe(false)
|
|
28
|
+
expect(DefaultPhysPageSize).toBe(65536)
|
|
29
|
+
expect(PCQuantum).toBe(1)
|
|
30
|
+
expect(ArchFamily).toBe(WASM)
|
|
31
|
+
})
|
|
32
|
+
})
|
|
@@ -1,18 +1,50 @@
|
|
|
1
|
-
|
|
2
|
-
// This replaces the auto-generated version with appropriate values for JS
|
|
1
|
+
export type ArchFamilyType = number
|
|
3
2
|
|
|
4
|
-
|
|
5
|
-
export const
|
|
3
|
+
export const AMD64: ArchFamilyType = 0
|
|
4
|
+
export const ARM: ArchFamilyType = 1
|
|
5
|
+
export const ARM64: ArchFamilyType = 2
|
|
6
|
+
export const I386: ArchFamilyType = 3
|
|
7
|
+
export const LOONG64: ArchFamilyType = 4
|
|
8
|
+
export const MIPS: ArchFamilyType = 5
|
|
9
|
+
export const MIPS64: ArchFamilyType = 6
|
|
10
|
+
export const PPC64: ArchFamilyType = 7
|
|
11
|
+
export const RISCV64: ArchFamilyType = 8
|
|
12
|
+
export const S390X: ArchFamilyType = 9
|
|
13
|
+
export const WASM: ArchFamilyType = 10
|
|
6
14
|
|
|
7
|
-
|
|
8
|
-
export const BigEndian = false
|
|
15
|
+
export const GOARCH = 'wasm'
|
|
9
16
|
|
|
10
|
-
|
|
11
|
-
export const
|
|
17
|
+
export const Is386 = 0
|
|
18
|
+
export const IsAmd64 = 0
|
|
19
|
+
export const IsAmd64p32 = 0
|
|
20
|
+
export const IsArm = 0
|
|
21
|
+
export const IsArmbe = 0
|
|
22
|
+
export const IsArm64 = 0
|
|
23
|
+
export const IsArm64be = 0
|
|
24
|
+
export const IsLoong64 = 0
|
|
25
|
+
export const IsMips = 0
|
|
26
|
+
export const IsMipsle = 0
|
|
27
|
+
export const IsMips64 = 0
|
|
28
|
+
export const IsMips64le = 0
|
|
29
|
+
export const IsMips64p32 = 0
|
|
30
|
+
export const IsMips64p32le = 0
|
|
31
|
+
export const IsPpc = 0
|
|
32
|
+
export const IsPpc64 = 0
|
|
33
|
+
export const IsPpc64le = 0
|
|
34
|
+
export const IsRiscv = 0
|
|
35
|
+
export const IsRiscv64 = 0
|
|
36
|
+
export const IsS390 = 0
|
|
37
|
+
export const IsS390x = 0
|
|
38
|
+
export const IsSparc = 0
|
|
39
|
+
export const IsSparc64 = 0
|
|
40
|
+
export const IsWasm = 1
|
|
12
41
|
|
|
13
|
-
|
|
14
|
-
export const
|
|
42
|
+
export const PtrSize = 8
|
|
43
|
+
export const PtrBits = PtrSize * 8
|
|
44
|
+
export const Int64Align = PtrSize
|
|
45
|
+
export const BigEndian = false
|
|
46
|
+
export const ArchFamily: ArchFamilyType = WASM
|
|
47
|
+
export const DefaultPhysPageSize = 65536
|
|
48
|
+
export const PCQuantum = 1
|
|
15
49
|
export const MinFrameSize = 0
|
|
16
|
-
|
|
17
|
-
// CPU cache line size (not really applicable in JS, but some code might reference it)
|
|
18
|
-
export const CacheLineSize = 64
|
|
50
|
+
export const StackAlign = PtrSize
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
{
|
|
2
|
+
"schemaVersion": 1,
|
|
3
|
+
"strict": true,
|
|
4
|
+
"symbols": {
|
|
5
|
+
"AMD64": {
|
|
6
|
+
"status": "real"
|
|
7
|
+
},
|
|
8
|
+
"ArchFamily": {
|
|
9
|
+
"status": "real"
|
|
10
|
+
},
|
|
11
|
+
"ArchFamilyType": {
|
|
12
|
+
"status": "real"
|
|
13
|
+
},
|
|
14
|
+
"ARM": {
|
|
15
|
+
"status": "real"
|
|
16
|
+
},
|
|
17
|
+
"ARM64": {
|
|
18
|
+
"status": "real"
|
|
19
|
+
},
|
|
20
|
+
"BigEndian": {
|
|
21
|
+
"status": "real"
|
|
22
|
+
},
|
|
23
|
+
"DefaultPhysPageSize": {
|
|
24
|
+
"status": "real"
|
|
25
|
+
},
|
|
26
|
+
"GOARCH": {
|
|
27
|
+
"status": "real"
|
|
28
|
+
},
|
|
29
|
+
"I386": {
|
|
30
|
+
"status": "real"
|
|
31
|
+
},
|
|
32
|
+
"Int64Align": {
|
|
33
|
+
"status": "real"
|
|
34
|
+
},
|
|
35
|
+
"Is386": {
|
|
36
|
+
"status": "real"
|
|
37
|
+
},
|
|
38
|
+
"IsAmd64": {
|
|
39
|
+
"status": "real"
|
|
40
|
+
},
|
|
41
|
+
"IsAmd64p32": {
|
|
42
|
+
"status": "real"
|
|
43
|
+
},
|
|
44
|
+
"IsArm": {
|
|
45
|
+
"status": "real"
|
|
46
|
+
},
|
|
47
|
+
"IsArm64": {
|
|
48
|
+
"status": "real"
|
|
49
|
+
},
|
|
50
|
+
"IsArm64be": {
|
|
51
|
+
"status": "real"
|
|
52
|
+
},
|
|
53
|
+
"IsArmbe": {
|
|
54
|
+
"status": "real"
|
|
55
|
+
},
|
|
56
|
+
"IsLoong64": {
|
|
57
|
+
"status": "real"
|
|
58
|
+
},
|
|
59
|
+
"IsMips": {
|
|
60
|
+
"status": "real"
|
|
61
|
+
},
|
|
62
|
+
"IsMips64": {
|
|
63
|
+
"status": "real"
|
|
64
|
+
},
|
|
65
|
+
"IsMips64le": {
|
|
66
|
+
"status": "real"
|
|
67
|
+
},
|
|
68
|
+
"IsMips64p32": {
|
|
69
|
+
"status": "real"
|
|
70
|
+
},
|
|
71
|
+
"IsMips64p32le": {
|
|
72
|
+
"status": "real"
|
|
73
|
+
},
|
|
74
|
+
"IsMipsle": {
|
|
75
|
+
"status": "real"
|
|
76
|
+
},
|
|
77
|
+
"IsPpc": {
|
|
78
|
+
"status": "real"
|
|
79
|
+
},
|
|
80
|
+
"IsPpc64": {
|
|
81
|
+
"status": "real"
|
|
82
|
+
},
|
|
83
|
+
"IsPpc64le": {
|
|
84
|
+
"status": "real"
|
|
85
|
+
},
|
|
86
|
+
"IsRiscv": {
|
|
87
|
+
"status": "real"
|
|
88
|
+
},
|
|
89
|
+
"IsRiscv64": {
|
|
90
|
+
"status": "real"
|
|
91
|
+
},
|
|
92
|
+
"IsS390": {
|
|
93
|
+
"status": "real"
|
|
94
|
+
},
|
|
95
|
+
"IsS390x": {
|
|
96
|
+
"status": "real"
|
|
97
|
+
},
|
|
98
|
+
"IsSparc": {
|
|
99
|
+
"status": "real"
|
|
100
|
+
},
|
|
101
|
+
"IsSparc64": {
|
|
102
|
+
"status": "real"
|
|
103
|
+
},
|
|
104
|
+
"IsWasm": {
|
|
105
|
+
"status": "real"
|
|
106
|
+
},
|
|
107
|
+
"LOONG64": {
|
|
108
|
+
"status": "real"
|
|
109
|
+
},
|
|
110
|
+
"MinFrameSize": {
|
|
111
|
+
"status": "real"
|
|
112
|
+
},
|
|
113
|
+
"MIPS": {
|
|
114
|
+
"status": "real"
|
|
115
|
+
},
|
|
116
|
+
"MIPS64": {
|
|
117
|
+
"status": "real"
|
|
118
|
+
},
|
|
119
|
+
"PCQuantum": {
|
|
120
|
+
"status": "real"
|
|
121
|
+
},
|
|
122
|
+
"PPC64": {
|
|
123
|
+
"status": "real"
|
|
124
|
+
},
|
|
125
|
+
"PtrBits": {
|
|
126
|
+
"status": "real"
|
|
127
|
+
},
|
|
128
|
+
"PtrSize": {
|
|
129
|
+
"status": "real"
|
|
130
|
+
},
|
|
131
|
+
"RISCV64": {
|
|
132
|
+
"status": "real"
|
|
133
|
+
},
|
|
134
|
+
"S390X": {
|
|
135
|
+
"status": "real"
|
|
136
|
+
},
|
|
137
|
+
"StackAlign": {
|
|
138
|
+
"status": "real"
|
|
139
|
+
},
|
|
140
|
+
"WASM": {
|
|
141
|
+
"status": "real"
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
}
|
package/gs/io/fs/fs.ts
CHANGED
|
@@ -618,20 +618,32 @@ export class PathError {
|
|
|
618
618
|
},
|
|
619
619
|
],
|
|
620
620
|
PathError,
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
kind: $.TypeKind.
|
|
626
|
-
name: 'GoError',
|
|
627
|
-
methods: [
|
|
628
|
-
{
|
|
629
|
-
name: 'Error',
|
|
630
|
-
args: [],
|
|
631
|
-
returns: [{ type: { kind: $.TypeKind.Basic, name: 'string' } }],
|
|
632
|
-
},
|
|
633
|
-
],
|
|
621
|
+
[
|
|
622
|
+
{
|
|
623
|
+
name: 'Op',
|
|
624
|
+
key: 'Op',
|
|
625
|
+
type: { kind: $.TypeKind.Basic, name: 'string' },
|
|
634
626
|
},
|
|
635
|
-
|
|
627
|
+
{
|
|
628
|
+
name: 'Path',
|
|
629
|
+
key: 'Path',
|
|
630
|
+
type: { kind: $.TypeKind.Basic, name: 'string' },
|
|
631
|
+
},
|
|
632
|
+
{
|
|
633
|
+
name: 'Err',
|
|
634
|
+
key: 'Err',
|
|
635
|
+
type: {
|
|
636
|
+
kind: $.TypeKind.Interface,
|
|
637
|
+
name: 'GoError',
|
|
638
|
+
methods: [
|
|
639
|
+
{
|
|
640
|
+
name: 'Error',
|
|
641
|
+
args: [],
|
|
642
|
+
returns: [{ type: { kind: $.TypeKind.Basic, name: 'string' } }],
|
|
643
|
+
},
|
|
644
|
+
],
|
|
645
|
+
},
|
|
646
|
+
},
|
|
647
|
+
],
|
|
636
648
|
)
|
|
637
649
|
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest'
|
|
2
|
+
import * as $ from '@goscript/builtin/index.js'
|
|
3
|
+
|
|
4
|
+
import { File, FileInfo, ReadDir } from './index.js'
|
|
5
|
+
|
|
6
|
+
describe('io/fs ReadDir override', () => {
|
|
7
|
+
it('returns a nil entry slice without sorting when directory read fails', () => {
|
|
8
|
+
const readErr = $.newError('read failed')
|
|
9
|
+
const file: File & {
|
|
10
|
+
ReadDir(n: number): [null, $.GoError]
|
|
11
|
+
} = {
|
|
12
|
+
Close(): $.GoError {
|
|
13
|
+
return null
|
|
14
|
+
},
|
|
15
|
+
Read(_p0: Uint8Array): [number, $.GoError] {
|
|
16
|
+
return [0, readErr]
|
|
17
|
+
},
|
|
18
|
+
Stat(): [FileInfo, $.GoError] {
|
|
19
|
+
return [null, readErr]
|
|
20
|
+
},
|
|
21
|
+
ReadDir(_n: number): [null, $.GoError] {
|
|
22
|
+
return [null, readErr]
|
|
23
|
+
},
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
const [list, err] = ReadDir(
|
|
27
|
+
{
|
|
28
|
+
Open(_name: string): [File, $.GoError] {
|
|
29
|
+
return [file, null]
|
|
30
|
+
},
|
|
31
|
+
},
|
|
32
|
+
'dir',
|
|
33
|
+
)
|
|
34
|
+
|
|
35
|
+
expect(list).toBeNull()
|
|
36
|
+
expect(err).toBe(readErr)
|
|
37
|
+
})
|
|
38
|
+
})
|
package/gs/io/fs/readdir.ts
CHANGED
|
@@ -92,9 +92,13 @@ export function ReadDir(
|
|
|
92
92
|
|
|
93
93
|
let list: $.Slice<DirEntry>
|
|
94
94
|
;[list, err] = dir!.ReadDir(-1)
|
|
95
|
-
list
|
|
96
|
-
|
|
97
|
-
|
|
95
|
+
if (list) {
|
|
96
|
+
list.sort((a: DirEntry, b: DirEntry): number => {
|
|
97
|
+
return $.pointerValue<Exclude<DirEntry, null>>(a)
|
|
98
|
+
.Name()
|
|
99
|
+
.localeCompare($.pointerValue<Exclude<DirEntry, null>>(b).Name())
|
|
100
|
+
})
|
|
101
|
+
}
|
|
98
102
|
return [list, err]
|
|
99
103
|
}
|
|
100
104
|
|
|
@@ -194,7 +198,7 @@ class dirInfo {
|
|
|
194
198
|
},
|
|
195
199
|
],
|
|
196
200
|
dirInfo,
|
|
197
|
-
{ fileInfo: 'FileInfo' },
|
|
201
|
+
[{ name: 'fileInfo', key: 'fileInfo', type: 'FileInfo' }],
|
|
198
202
|
)
|
|
199
203
|
}
|
|
200
204
|
|
package/gs/io/fs/sub.ts
CHANGED
|
@@ -444,6 +444,13 @@ class subFS {
|
|
|
444
444
|
},
|
|
445
445
|
],
|
|
446
446
|
subFS,
|
|
447
|
-
|
|
447
|
+
[
|
|
448
|
+
{ name: 'fsys', key: 'fsys', type: 'FS' },
|
|
449
|
+
{
|
|
450
|
+
name: 'dir',
|
|
451
|
+
key: 'dir',
|
|
452
|
+
type: { kind: $.TypeKind.Basic, name: 'string' },
|
|
453
|
+
},
|
|
454
|
+
],
|
|
448
455
|
)
|
|
449
456
|
}
|
package/gs/io/io.test.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as $ from '@goscript/builtin/index.js'
|
|
2
|
-
import { LimitedReader, MultiWriter, TeeReader } from './index.js'
|
|
2
|
+
import { LimitedReader, MultiWriter, NopCloser, Pipe, TeeReader } from './index.js'
|
|
3
3
|
import { describe, expect, test } from 'vitest'
|
|
4
4
|
|
|
5
5
|
class sliceReader {
|
|
@@ -9,7 +9,7 @@ class sliceReader {
|
|
|
9
9
|
const n = Math.min($.len(p), this.data.length)
|
|
10
10
|
p!.set(this.data.subarray(0, n), 0)
|
|
11
11
|
this.data = this.data.subarray(n)
|
|
12
|
-
return [n, n === 0 ? new Error('EOF') as $.GoError : null]
|
|
12
|
+
return [n, n === 0 ? (new Error('EOF') as $.GoError) : null]
|
|
13
13
|
}
|
|
14
14
|
}
|
|
15
15
|
|
|
@@ -37,28 +37,99 @@ describe('io override', () => {
|
|
|
37
37
|
expect(Buffer.from(buf.subarray(0, n)).toString('utf8')).toBe('abc')
|
|
38
38
|
})
|
|
39
39
|
|
|
40
|
-
test('TeeReader accepts nullable generated interface values', () => {
|
|
40
|
+
test('TeeReader accepts nullable generated interface values', async () => {
|
|
41
41
|
const writer = new captureWriter()
|
|
42
42
|
const reader = TeeReader(new sliceReader($.stringToBytes('abc')), writer)
|
|
43
43
|
const buf = new Uint8Array(4)
|
|
44
44
|
|
|
45
|
-
const [n, err] = reader.Read(buf)
|
|
45
|
+
const [n, err] = await reader.Read(buf)
|
|
46
46
|
|
|
47
47
|
expect(err).toBeNull()
|
|
48
48
|
expect(n).toBe(3)
|
|
49
49
|
expect(Buffer.from(writer.chunks).toString('utf8')).toBe('abc')
|
|
50
50
|
})
|
|
51
51
|
|
|
52
|
-
test('
|
|
52
|
+
test('NopCloser accepts nullable generated interface values', () => {
|
|
53
|
+
const reader: sliceReader | null = new sliceReader($.stringToBytes('abc'))
|
|
54
|
+
const body = NopCloser(reader)
|
|
55
|
+
const buf = new Uint8Array(4)
|
|
56
|
+
|
|
57
|
+
const [n, err] = body.Read(buf)
|
|
58
|
+
|
|
59
|
+
expect(err).toBeNull()
|
|
60
|
+
expect(n).toBe(3)
|
|
61
|
+
expect(body.Close()).toBeNull()
|
|
62
|
+
})
|
|
63
|
+
|
|
64
|
+
test('TeeReader awaits async readers and writers', async () => {
|
|
65
|
+
const chunks: number[] = []
|
|
66
|
+
const reader = TeeReader(
|
|
67
|
+
{
|
|
68
|
+
async Read(p: $.Bytes): Promise<[number, $.GoError]> {
|
|
69
|
+
await Promise.resolve()
|
|
70
|
+
p!.set($.stringToBytes('abc'), 0)
|
|
71
|
+
return [3, null]
|
|
72
|
+
},
|
|
73
|
+
} as any,
|
|
74
|
+
{
|
|
75
|
+
async Write(p: $.Bytes): Promise<[number, $.GoError]> {
|
|
76
|
+
await Promise.resolve()
|
|
77
|
+
chunks.push(...Array.from(p ?? []))
|
|
78
|
+
return [$.len(p), null]
|
|
79
|
+
},
|
|
80
|
+
} as any,
|
|
81
|
+
)
|
|
82
|
+
const buf = new Uint8Array(4)
|
|
83
|
+
|
|
84
|
+
const [n, err] = await reader.Read(buf)
|
|
85
|
+
|
|
86
|
+
expect(err).toBeNull()
|
|
87
|
+
expect(n).toBe(3)
|
|
88
|
+
expect(Buffer.from(chunks).toString('utf8')).toBe('abc')
|
|
89
|
+
})
|
|
90
|
+
|
|
91
|
+
test('MultiWriter accepts nullable generated interface values', async () => {
|
|
53
92
|
const first = new captureWriter()
|
|
54
93
|
const second = new captureWriter()
|
|
55
94
|
const writer = MultiWriter(first, second)
|
|
56
95
|
|
|
57
|
-
const [n, err] = writer.Write($.stringToBytes('abc'))
|
|
96
|
+
const [n, err] = await writer.Write($.stringToBytes('abc'))
|
|
58
97
|
|
|
59
98
|
expect(err).toBeNull()
|
|
60
99
|
expect(n).toBe(3)
|
|
61
100
|
expect(Buffer.from(first.chunks).toString('utf8')).toBe('abc')
|
|
62
101
|
expect(Buffer.from(second.chunks).toString('utf8')).toBe('abc')
|
|
63
102
|
})
|
|
103
|
+
|
|
104
|
+
test('MultiWriter awaits async generated writers', async () => {
|
|
105
|
+
const chunks: number[] = []
|
|
106
|
+
const writer = MultiWriter({
|
|
107
|
+
async Write(p: $.Bytes): Promise<[number, $.GoError]> {
|
|
108
|
+
await Promise.resolve()
|
|
109
|
+
chunks.push(...Array.from(p ?? []))
|
|
110
|
+
return [$.len(p), null]
|
|
111
|
+
},
|
|
112
|
+
})
|
|
113
|
+
|
|
114
|
+
const [n, err] = await writer.Write($.stringToBytes('abc'))
|
|
115
|
+
|
|
116
|
+
expect(err).toBeNull()
|
|
117
|
+
expect(n).toBe(3)
|
|
118
|
+
expect(Buffer.from(chunks).toString('utf8')).toBe('abc')
|
|
119
|
+
})
|
|
120
|
+
|
|
121
|
+
test('PipeReader waits for a later write', async () => {
|
|
122
|
+
const [reader, writer] = Pipe()
|
|
123
|
+
const buf = new Uint8Array(5)
|
|
124
|
+
|
|
125
|
+
const read = reader.Read(buf)
|
|
126
|
+
const [written, writeErr] = await writer.Write($.stringToBytes('later'))
|
|
127
|
+
const [readBytes, readErr] = await read
|
|
128
|
+
|
|
129
|
+
expect(writeErr).toBeNull()
|
|
130
|
+
expect(written).toBe(5)
|
|
131
|
+
expect(readErr).toBeNull()
|
|
132
|
+
expect(readBytes).toBe(5)
|
|
133
|
+
expect(Buffer.from(buf).toString('utf8')).toBe('later')
|
|
134
|
+
})
|
|
64
135
|
})
|