goscript 0.0.29 → 0.0.31

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.
Files changed (106) hide show
  1. package/compiler/compiler.go +8 -1
  2. package/compiler/index.ts +1 -1
  3. package/compiler/stmt-assign.go +14 -0
  4. package/dist/compiler/index.js +1 -1
  5. package/dist/compiler/index.js.map +1 -1
  6. package/dist/gs/builtin/channel.d.ts +6 -6
  7. package/dist/gs/builtin/channel.js +3 -3
  8. package/dist/gs/builtin/channel.js.map +1 -1
  9. package/dist/gs/builtin/slice.js +3 -9
  10. package/dist/gs/builtin/slice.js.map +1 -1
  11. package/dist/gs/context/context.js +2 -2
  12. package/dist/gs/context/context.js.map +1 -1
  13. package/dist/gs/internal/oserror/errors.d.ts +1 -1
  14. package/dist/gs/internal/oserror/errors.js +6 -6
  15. package/dist/gs/internal/oserror/index.d.ts +1 -1
  16. package/dist/gs/internal/oserror/index.js +1 -1
  17. package/dist/gs/internal/oserror/index.js.map +1 -1
  18. package/dist/gs/io/fs/format.d.ts +1 -1
  19. package/dist/gs/io/fs/format.js +12 -12
  20. package/dist/gs/io/fs/format.js.map +1 -1
  21. package/dist/gs/io/fs/fs.d.ts +2 -2
  22. package/dist/gs/io/fs/fs.js +258 -36
  23. package/dist/gs/io/fs/fs.js.map +1 -1
  24. package/dist/gs/io/fs/glob.d.ts +2 -2
  25. package/dist/gs/io/fs/glob.js +40 -14
  26. package/dist/gs/io/fs/glob.js.map +1 -1
  27. package/dist/gs/io/fs/index.d.ts +8 -8
  28. package/dist/gs/io/fs/index.js +8 -8
  29. package/dist/gs/io/fs/readdir.d.ts +2 -2
  30. package/dist/gs/io/fs/readdir.js +78 -9
  31. package/dist/gs/io/fs/readdir.js.map +1 -1
  32. package/dist/gs/io/fs/readfile.d.ts +2 -2
  33. package/dist/gs/io/fs/readfile.js +31 -13
  34. package/dist/gs/io/fs/readfile.js.map +1 -1
  35. package/dist/gs/io/fs/stat.d.ts +2 -2
  36. package/dist/gs/io/fs/stat.js +25 -2
  37. package/dist/gs/io/fs/stat.js.map +1 -1
  38. package/dist/gs/io/fs/sub.d.ts +2 -2
  39. package/dist/gs/io/fs/sub.js +264 -28
  40. package/dist/gs/io/fs/sub.js.map +1 -1
  41. package/dist/gs/io/fs/walk.d.ts +2 -2
  42. package/dist/gs/io/fs/walk.js +7 -7
  43. package/dist/gs/io/fs/walk.js.map +1 -1
  44. package/dist/gs/iter/iter.js +1 -1
  45. package/dist/gs/iter/iter.js.map +1 -1
  46. package/dist/gs/path/index.d.ts +2 -2
  47. package/dist/gs/path/index.js +2 -2
  48. package/dist/gs/path/match.d.ts +1 -1
  49. package/dist/gs/path/match.js +39 -33
  50. package/dist/gs/path/match.js.map +1 -1
  51. package/dist/gs/path/path.js +53 -24
  52. package/dist/gs/path/path.js.map +1 -1
  53. package/dist/gs/runtime/runtime.d.ts +3 -3
  54. package/dist/gs/runtime/runtime.js +3 -3
  55. package/dist/gs/runtime/runtime.js.map +1 -1
  56. package/dist/gs/strings/builder.d.ts +1 -1
  57. package/dist/gs/strings/builder.js +1 -1
  58. package/dist/gs/strings/builder.js.map +1 -1
  59. package/dist/gs/strings/clone.js.map +1 -1
  60. package/dist/gs/strings/compare.js.map +1 -1
  61. package/dist/gs/strings/replace.js +4 -2
  62. package/dist/gs/strings/replace.js.map +1 -1
  63. package/dist/gs/strings/strings.js +0 -12
  64. package/dist/gs/strings/strings.js.map +1 -1
  65. package/dist/gs/sync/sync.d.ts +5 -5
  66. package/dist/gs/sync/sync.js +5 -5
  67. package/dist/gs/sync/sync.js.map +1 -1
  68. package/dist/gs/time/time.d.ts +2 -2
  69. package/dist/gs/time/time.js +62 -16
  70. package/dist/gs/time/time.js.map +1 -1
  71. package/dist/gs/unsafe/unsafe.d.ts +8 -8
  72. package/dist/gs/unsafe/unsafe.js +8 -8
  73. package/dist/gs/unsafe/unsafe.js.map +1 -1
  74. package/gs/builtin/builtin.ts +1 -1
  75. package/gs/builtin/channel.ts +6 -6
  76. package/gs/builtin/slice.ts +3 -9
  77. package/gs/context/context.ts +2 -2
  78. package/gs/internal/oserror/errors.ts +7 -8
  79. package/gs/internal/oserror/index.ts +7 -1
  80. package/gs/io/fs/format.ts +39 -40
  81. package/gs/io/fs/fs.ts +446 -222
  82. package/gs/io/fs/glob.ts +164 -131
  83. package/gs/io/fs/index.ts +8 -8
  84. package/gs/io/fs/readdir.ts +188 -106
  85. package/gs/io/fs/readfile.ts +79 -58
  86. package/gs/io/fs/stat.ts +49 -25
  87. package/gs/io/fs/sub.ts +422 -181
  88. package/gs/io/fs/walk.ts +67 -63
  89. package/gs/iter/iter.ts +1 -1
  90. package/gs/path/index.ts +2 -2
  91. package/gs/path/match.ts +263 -250
  92. package/gs/path/path.ts +259 -232
  93. package/gs/runtime/runtime.ts +4 -4
  94. package/gs/strings/builder.test.ts +0 -1
  95. package/gs/strings/builder.ts +1 -1
  96. package/gs/strings/clone.ts +0 -2
  97. package/gs/strings/compare.ts +0 -2
  98. package/gs/strings/iter.test.ts +0 -1
  99. package/gs/strings/replace.test.ts +3 -4
  100. package/gs/strings/replace.ts +4 -7
  101. package/gs/strings/strings.test.ts +6 -6
  102. package/gs/strings/strings.ts +0 -14
  103. package/gs/sync/sync.ts +5 -5
  104. package/gs/time/time.ts +86 -29
  105. package/gs/unsafe/unsafe.ts +8 -8
  106. package/package.json +1 -1
@@ -1,24 +1,54 @@
1
- import * as $ from "@goscript/builtin/builtin.js";
2
- import { FS } from "./fs.js";
1
+ import * as $ from '@goscript/builtin/builtin.js'
2
+ import { FS } from './fs.js'
3
3
 
4
- import * as io from "@goscript/io/index.js"
4
+ import * as io from '@goscript/io/index.js'
5
5
 
6
- export type ReadFileFS = null | {
7
- // ReadFile reads the named file and returns its contents.
8
- // A successful call returns a nil error, not io.EOF.
9
- // (Because ReadFile reads the whole file, the expected EOF
10
- // from the final Read is not treated as an error to be reported.)
11
- //
12
- // The caller is permitted to modify the returned byte slice.
13
- // This method should return a copy of the underlying data.
14
- ReadFile(name: string): [Uint8Array, $.GoError]
15
- } & FS
6
+ export type ReadFileFS =
7
+ | null
8
+ | ({
9
+ // ReadFile reads the named file and returns its contents.
10
+ // A successful call returns a nil error, not io.EOF.
11
+ // (Because ReadFile reads the whole file, the expected EOF
12
+ // from the final Read is not treated as an error to be reported.)
13
+ //
14
+ // The caller is permitted to modify the returned byte slice.
15
+ // This method should return a copy of the underlying data.
16
+ ReadFile(name: string): [Uint8Array, $.GoError]
17
+ } & FS)
16
18
 
17
19
  $.registerInterfaceType(
18
20
  'ReadFileFS',
19
21
  null, // Zero value for interface is null
20
- [{ name: "ReadFile", args: [{ name: "name", type: { kind: $.TypeKind.Basic, name: "string" } }], returns: [{ type: { kind: $.TypeKind.Slice, elemType: { kind: $.TypeKind.Basic, name: "number" } } }, { type: { kind: $.TypeKind.Interface, name: 'GoError', methods: [{ name: 'Error', args: [], returns: [{ type: { kind: $.TypeKind.Basic, name: 'string' } }] }] } }] }]
21
- );
22
+ [
23
+ {
24
+ name: 'ReadFile',
25
+ args: [
26
+ { name: 'name', type: { kind: $.TypeKind.Basic, name: 'string' } },
27
+ ],
28
+ returns: [
29
+ {
30
+ type: {
31
+ kind: $.TypeKind.Slice,
32
+ elemType: { kind: $.TypeKind.Basic, name: 'number' },
33
+ },
34
+ },
35
+ {
36
+ type: {
37
+ kind: $.TypeKind.Interface,
38
+ name: 'GoError',
39
+ methods: [
40
+ {
41
+ name: 'Error',
42
+ args: [],
43
+ returns: [{ type: { kind: $.TypeKind.Basic, name: 'string' } }],
44
+ },
45
+ ],
46
+ },
47
+ },
48
+ ],
49
+ },
50
+ ],
51
+ )
22
52
 
23
53
  // ReadFile reads the named file from the file system fs and returns its contents.
24
54
  // A successful call returns a nil error, not [io.EOF].
@@ -29,49 +59,40 @@ $.registerInterfaceType(
29
59
  // Otherwise ReadFile calls fs.Open and uses Read and Close
30
60
  // on the returned [File].
31
61
  export function ReadFile(fsys: FS, name: string): [Uint8Array, $.GoError] {
32
- using __defer = new $.DisposableStack();
33
- {
34
- let { value: fsysTyped, ok: ok } = $.typeAssert<ReadFileFS>(fsys, 'ReadFileFS')
35
- if (ok) {
36
- return fsysTyped!.ReadFile(name)
37
- }
38
- }
62
+ using __defer = new $.DisposableStack()
63
+ {
64
+ let { value: fsysTyped, ok: ok } = $.typeAssert<ReadFileFS>(
65
+ fsys,
66
+ 'ReadFileFS',
67
+ )
68
+ if (ok) {
69
+ return fsysTyped!.ReadFile(name)
70
+ }
71
+ }
39
72
 
40
- let [file, err] = fsys!.Open(name)
41
- if (err != null) {
42
- return [new Uint8Array(0), err]
43
- }
44
- __defer.defer(() => {
45
- file!.Close()
46
- });
73
+ let [file, err] = fsys!.Open(name)
74
+ if (err != null) {
75
+ return [new Uint8Array(0), err]
76
+ }
77
+ __defer.defer(() => {
78
+ file!.Close()
79
+ })
47
80
 
48
- let size: number = 0
49
- {
50
- let [info, err] = file!.Stat()
51
- if (err == null) {
52
- let size64 = info!.Size()
53
- if (((size64 as number) as number) == size64) {
54
- size = (size64 as number)
55
- }
56
- }
57
- }
58
-
59
- let data = new Uint8Array(0)
60
- for (; ; ) {
61
- if ($.len(data) >= $.cap(data)) {
62
- // Grow the array by creating a new larger one
63
- let newData = new Uint8Array($.len(data) * 2 + 1)
64
- newData.set(data)
65
- data = newData
66
- }
67
- let [n, err] = file!.Read(data.subarray($.len(data), $.cap(data)))
68
- data = data.subarray(0, $.len(data) + n)
69
- if (err != null) {
70
- if (err == io.EOF) {
71
- err = null
72
- }
73
- return [data, err]
74
- }
75
- }
81
+ let data = new Uint8Array(0)
82
+ for (;;) {
83
+ if ($.len(data) >= $.cap(data)) {
84
+ // Grow the array by creating a new larger one
85
+ let newData = new Uint8Array($.len(data) * 2 + 1)
86
+ newData.set(data)
87
+ data = newData
88
+ }
89
+ let [n, err] = file!.Read(data.subarray($.len(data), $.cap(data)))
90
+ data = data.subarray(0, $.len(data) + n)
91
+ if (err != null) {
92
+ if (err == io.EOF) {
93
+ err = null
94
+ }
95
+ return [data, err]
96
+ }
97
+ }
76
98
  }
77
-
package/gs/io/fs/stat.ts CHANGED
@@ -1,38 +1,62 @@
1
- import * as $ from "@goscript/builtin/builtin.js";
2
- import { FS, FileInfo } from "./fs.js";
1
+ import * as $ from '@goscript/builtin/builtin.js'
2
+ import { FS, FileInfo } from './fs.js'
3
3
 
4
- export type StatFS = null | {
5
- // Stat returns a FileInfo describing the file.
6
- // If there is an error, it should be of type *PathError.
7
- Stat(name: string): [FileInfo, $.GoError]
8
- } & FS
4
+ export type StatFS =
5
+ | null
6
+ | ({
7
+ // Stat returns a FileInfo describing the file.
8
+ // If there is an error, it should be of type *PathError.
9
+ Stat(name: string): [FileInfo, $.GoError]
10
+ } & FS)
9
11
 
10
12
  $.registerInterfaceType(
11
13
  'StatFS',
12
14
  null, // Zero value for interface is null
13
- [{ name: "Stat", args: [{ name: "name", type: { kind: $.TypeKind.Basic, name: "string" } }], returns: [{ type: "FileInfo" }, { type: { kind: $.TypeKind.Interface, name: 'GoError', methods: [{ name: 'Error', args: [], returns: [{ type: { kind: $.TypeKind.Basic, name: 'string' } }] }] } }] }]
14
- );
15
+ [
16
+ {
17
+ name: 'Stat',
18
+ args: [
19
+ { name: 'name', type: { kind: $.TypeKind.Basic, name: 'string' } },
20
+ ],
21
+ returns: [
22
+ { type: 'FileInfo' },
23
+ {
24
+ type: {
25
+ kind: $.TypeKind.Interface,
26
+ name: 'GoError',
27
+ methods: [
28
+ {
29
+ name: 'Error',
30
+ args: [],
31
+ returns: [{ type: { kind: $.TypeKind.Basic, name: 'string' } }],
32
+ },
33
+ ],
34
+ },
35
+ },
36
+ ],
37
+ },
38
+ ],
39
+ )
15
40
 
16
41
  // Stat returns a [FileInfo] describing the named file from the file system.
17
42
  //
18
43
  // If fs implements [StatFS], Stat calls fs.Stat.
19
44
  // Otherwise, Stat opens the [File] to stat it.
20
45
  export function Stat(fsys: FS, name: string): [FileInfo, $.GoError] {
21
- using __defer = new $.DisposableStack();
22
- {
23
- let { value: fsysTyped, ok: ok } = $.typeAssert<StatFS>(fsys, 'StatFS')
24
- if (ok) {
25
- return fsysTyped!.Stat(name)
26
- }
27
- }
46
+ using __defer = new $.DisposableStack()
47
+ {
48
+ let { value: fsysTyped, ok: ok } = $.typeAssert<StatFS>(fsys, 'StatFS')
49
+ if (ok) {
50
+ return fsysTyped!.Stat(name)
51
+ }
52
+ }
28
53
 
29
- let [file, err] = fsys!.Open(name)
30
- if (err != null) {
31
- return [null, err]
32
- }
33
- __defer.defer(() => {
34
- file!.Close()
35
- });
36
- return file!.Stat()
54
+ let [file, err] = fsys!.Open(name)
55
+ if (err != null) {
56
+ return [null, err]
57
+ }
58
+ __defer.defer(() => {
59
+ file!.Close()
60
+ })
61
+ return file!.Stat()
37
62
  }
38
-