goscript 0.1.0 → 0.1.2

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 (495) hide show
  1. package/README.md +267 -255
  2. package/cmd/goscript/cmd-test.go +286 -0
  3. package/cmd/goscript/cmd-test_test.go +76 -0
  4. package/cmd/goscript/cmd_compile.go +9 -0
  5. package/cmd/goscript/main.go +1 -0
  6. package/compiler/build-flags.go +38 -0
  7. package/compiler/compile-request.go +33 -0
  8. package/compiler/compiler.go +1 -1
  9. package/compiler/compliance_test.go +0 -10
  10. package/compiler/config.go +2 -0
  11. package/compiler/gotest/owner.go +24 -0
  12. package/compiler/gotest/package-result.go +69 -0
  13. package/compiler/gotest/request.go +210 -0
  14. package/compiler/gotest/result.go +28 -0
  15. package/compiler/gotest/runner.go +1225 -0
  16. package/compiler/gotest/runner_test.go +1271 -0
  17. package/compiler/gotest/test.go +9 -0
  18. package/compiler/index.test.ts +1 -1
  19. package/compiler/lowered-program.go +80 -21
  20. package/compiler/lowering.go +6754 -602
  21. package/compiler/override-facts.go +357 -0
  22. package/compiler/override-registry.go +52 -190
  23. package/compiler/override-registry_test.go +182 -0
  24. package/compiler/package-graph.go +50 -27
  25. package/compiler/package-graph_test.go +99 -9
  26. package/compiler/package-test-function.go +9 -0
  27. package/compiler/package-test-graph-package.go +40 -0
  28. package/compiler/package-test-graph-variant.go +129 -0
  29. package/compiler/package-test-graph.go +112 -0
  30. package/compiler/package-test-graph_test.go +202 -0
  31. package/compiler/runtime-contract.go +229 -29
  32. package/compiler/runtime-contract_test.go +44 -30
  33. package/compiler/semantic-model-types.go +25 -6
  34. package/compiler/semantic-model.go +819 -74
  35. package/compiler/semantic-model_test.go +104 -0
  36. package/compiler/service.go +10 -4
  37. package/compiler/skeleton_test.go +2777 -524
  38. package/compiler/tsworkspace/owner-process-unix_test.go +72 -0
  39. package/compiler/tsworkspace/owner.go +342 -0
  40. package/compiler/tsworkspace/owner_test.go +93 -0
  41. package/compiler/tsworkspace/result.go +17 -0
  42. package/compiler/tsworkspace/tool-process-other.go +14 -0
  43. package/compiler/tsworkspace/tool-process-unix.go +19 -0
  44. package/compiler/typescript-emitter.go +576 -86
  45. package/compiler/wasm/compile.go +1 -1
  46. package/compiler/wasm/compile_test.go +61 -11
  47. package/compiler/wasm_api.go +172 -7
  48. package/dist/gs/builtin/builtin.d.ts +40 -3
  49. package/dist/gs/builtin/builtin.js +430 -22
  50. package/dist/gs/builtin/builtin.js.map +1 -1
  51. package/dist/gs/builtin/channel.d.ts +32 -10
  52. package/dist/gs/builtin/channel.js +119 -25
  53. package/dist/gs/builtin/channel.js.map +1 -1
  54. package/dist/gs/builtin/defer.d.ts +1 -0
  55. package/dist/gs/builtin/defer.js +12 -2
  56. package/dist/gs/builtin/defer.js.map +1 -1
  57. package/dist/gs/builtin/hostio.d.ts +9 -0
  58. package/dist/gs/builtin/hostio.js +25 -0
  59. package/dist/gs/builtin/hostio.js.map +1 -1
  60. package/dist/gs/builtin/map.js +40 -6
  61. package/dist/gs/builtin/map.js.map +1 -1
  62. package/dist/gs/builtin/print.js.map +1 -1
  63. package/dist/gs/builtin/slice.d.ts +64 -10
  64. package/dist/gs/builtin/slice.js +619 -244
  65. package/dist/gs/builtin/slice.js.map +1 -1
  66. package/dist/gs/builtin/type.d.ts +7 -2
  67. package/dist/gs/builtin/type.js +128 -29
  68. package/dist/gs/builtin/type.js.map +1 -1
  69. package/dist/gs/builtin/varRef.d.ts +7 -0
  70. package/dist/gs/builtin/varRef.js +23 -0
  71. package/dist/gs/builtin/varRef.js.map +1 -1
  72. package/dist/gs/bytes/buffer.gs.js +74 -70
  73. package/dist/gs/bytes/buffer.gs.js.map +1 -1
  74. package/dist/gs/bytes/iter.gs.js +13 -13
  75. package/dist/gs/bytes/iter.gs.js.map +1 -1
  76. package/dist/gs/bytes/reader.gs.js +20 -18
  77. package/dist/gs/bytes/reader.gs.js.map +1 -1
  78. package/dist/gs/compress/zlib/index.d.ts +26 -0
  79. package/dist/gs/compress/zlib/index.js +168 -0
  80. package/dist/gs/compress/zlib/index.js.map +1 -0
  81. package/dist/gs/context/context.d.ts +6 -5
  82. package/dist/gs/context/context.js +17 -12
  83. package/dist/gs/context/context.js.map +1 -1
  84. package/dist/gs/crypto/ecdh/index.d.ts +52 -0
  85. package/dist/gs/crypto/ecdh/index.js +226 -0
  86. package/dist/gs/crypto/ecdh/index.js.map +1 -0
  87. package/dist/gs/crypto/ed25519/index.d.ts +34 -0
  88. package/dist/gs/crypto/ed25519/index.js +160 -0
  89. package/dist/gs/crypto/ed25519/index.js.map +1 -0
  90. package/dist/gs/crypto/internal/constanttime/index.d.ts +4 -0
  91. package/dist/gs/crypto/internal/constanttime/index.js +18 -0
  92. package/dist/gs/crypto/internal/constanttime/index.js.map +1 -0
  93. package/dist/gs/crypto/internal/fips140deps/byteorder/index.d.ts +1 -0
  94. package/dist/gs/crypto/internal/fips140deps/byteorder/index.js +2 -0
  95. package/dist/gs/crypto/internal/fips140deps/byteorder/index.js.map +1 -0
  96. package/dist/gs/crypto/internal/fips140deps/godebug/index.d.ts +1 -0
  97. package/dist/gs/crypto/internal/fips140deps/godebug/index.js +2 -0
  98. package/dist/gs/crypto/internal/fips140deps/godebug/index.js.map +1 -0
  99. package/dist/gs/crypto/rand/index.d.ts +2 -0
  100. package/dist/gs/crypto/rand/index.js +85 -0
  101. package/dist/gs/crypto/rand/index.js.map +1 -1
  102. package/dist/gs/crypto/sha256/index.d.ts +8 -0
  103. package/dist/gs/crypto/sha256/index.js +118 -0
  104. package/dist/gs/crypto/sha256/index.js.map +1 -0
  105. package/dist/gs/crypto/sha512/index.d.ts +14 -0
  106. package/dist/gs/crypto/sha512/index.js +129 -0
  107. package/dist/gs/crypto/sha512/index.js.map +1 -0
  108. package/dist/gs/embed/index.d.ts +7 -0
  109. package/dist/gs/embed/index.js +16 -0
  110. package/dist/gs/embed/index.js.map +1 -0
  111. package/dist/gs/encoding/json/index.d.ts +4 -0
  112. package/dist/gs/encoding/json/index.js +33 -0
  113. package/dist/gs/encoding/json/index.js.map +1 -1
  114. package/dist/gs/errors/errors.d.ts +4 -0
  115. package/dist/gs/errors/errors.js +108 -4
  116. package/dist/gs/errors/errors.js.map +1 -1
  117. package/dist/gs/fmt/fmt.d.ts +4 -4
  118. package/dist/gs/fmt/fmt.js +42 -11
  119. package/dist/gs/fmt/fmt.js.map +1 -1
  120. package/dist/gs/github.com/aperturerobotics/protobuf-go-lite/index.d.ts +37 -2
  121. package/dist/gs/github.com/aperturerobotics/protobuf-go-lite/index.js +245 -1
  122. package/dist/gs/github.com/aperturerobotics/protobuf-go-lite/index.js.map +1 -1
  123. package/dist/gs/github.com/aperturerobotics/protobuf-go-lite/json/index.d.ts +189 -0
  124. package/dist/gs/github.com/aperturerobotics/protobuf-go-lite/json/index.js +861 -0
  125. package/dist/gs/github.com/aperturerobotics/protobuf-go-lite/json/index.js.map +1 -0
  126. package/dist/gs/github.com/aperturerobotics/starpc/srpc/index.d.ts +217 -0
  127. package/dist/gs/github.com/aperturerobotics/starpc/srpc/index.js +814 -0
  128. package/dist/gs/github.com/aperturerobotics/starpc/srpc/index.js.map +1 -0
  129. package/dist/gs/github.com/aperturerobotics/util/conc/index.d.ts +20 -0
  130. package/dist/gs/github.com/aperturerobotics/util/conc/index.js +134 -0
  131. package/dist/gs/github.com/aperturerobotics/util/conc/index.js.map +1 -0
  132. package/dist/gs/github.com/aperturerobotics/wasivm/wazero/kernel/runtime/browser/browser.js.map +1 -1
  133. package/dist/gs/github.com/hack-pad/safejs/internal/catch/index.d.ts +3 -0
  134. package/dist/gs/github.com/hack-pad/safejs/internal/catch/index.js +50 -0
  135. package/dist/gs/github.com/hack-pad/safejs/internal/catch/index.js.map +1 -0
  136. package/dist/gs/github.com/klauspost/compress/internal/le/index.d.ts +9 -0
  137. package/dist/gs/github.com/klauspost/compress/internal/le/index.js +72 -0
  138. package/dist/gs/github.com/klauspost/compress/internal/le/index.js.map +1 -0
  139. package/dist/gs/github.com/mr-tron/base58/base58/index.d.ts +27 -0
  140. package/dist/gs/github.com/mr-tron/base58/base58/index.js +172 -0
  141. package/dist/gs/github.com/mr-tron/base58/base58/index.js.map +1 -0
  142. package/dist/gs/github.com/zeebo/blake3/internal/consts/index.d.ts +21 -0
  143. package/dist/gs/github.com/zeebo/blake3/internal/consts/index.js +22 -0
  144. package/dist/gs/github.com/zeebo/blake3/internal/consts/index.js.map +1 -0
  145. package/dist/gs/go/internal/scannerhooks/index.d.ts +3 -0
  146. package/dist/gs/go/internal/scannerhooks/index.js +5 -0
  147. package/dist/gs/go/internal/scannerhooks/index.js.map +1 -0
  148. package/dist/gs/go/scanner/index.d.ts +13 -0
  149. package/dist/gs/go/scanner/index.js +35 -0
  150. package/dist/gs/go/scanner/index.js.map +1 -1
  151. package/dist/gs/go/token/index.d.ts +156 -0
  152. package/dist/gs/go/token/index.js +507 -4
  153. package/dist/gs/go/token/index.js.map +1 -1
  154. package/dist/gs/hash/fnv/index.d.ts +57 -0
  155. package/dist/gs/hash/fnv/index.js +299 -0
  156. package/dist/gs/hash/fnv/index.js.map +1 -0
  157. package/dist/gs/hash/index.d.ts +17 -0
  158. package/dist/gs/hash/index.js +94 -0
  159. package/dist/gs/hash/index.js.map +1 -0
  160. package/dist/gs/internal/abi/index.d.ts +4 -0
  161. package/dist/gs/internal/abi/index.js +10 -0
  162. package/dist/gs/internal/abi/index.js.map +1 -1
  163. package/dist/gs/internal/bytealg/index.d.ts +2 -0
  164. package/dist/gs/internal/bytealg/index.js +14 -0
  165. package/dist/gs/internal/bytealg/index.js.map +1 -1
  166. package/dist/gs/internal/byteorder/index.d.ts +8 -2
  167. package/dist/gs/internal/byteorder/index.js +56 -25
  168. package/dist/gs/internal/byteorder/index.js.map +1 -1
  169. package/dist/gs/internal/godebug/index.d.ts +12 -0
  170. package/dist/gs/internal/godebug/index.js +30 -0
  171. package/dist/gs/internal/godebug/index.js.map +1 -0
  172. package/dist/gs/io/fs/index.d.ts +1 -0
  173. package/dist/gs/io/fs/index.js +1 -0
  174. package/dist/gs/io/fs/index.js.map +1 -1
  175. package/dist/gs/io/fs/readlink.d.ts +8 -0
  176. package/dist/gs/io/fs/readlink.js +60 -0
  177. package/dist/gs/io/fs/readlink.js.map +1 -0
  178. package/dist/gs/io/fs/walk.d.ts +3 -3
  179. package/dist/gs/io/fs/walk.js +7 -7
  180. package/dist/gs/io/fs/walk.js.map +1 -1
  181. package/dist/gs/io/io.d.ts +40 -6
  182. package/dist/gs/io/io.js +151 -26
  183. package/dist/gs/io/io.js.map +1 -1
  184. package/dist/gs/iter/iter.d.ts +3 -2
  185. package/dist/gs/iter/iter.js.map +1 -1
  186. package/dist/gs/maps/iter.d.ts +5 -5
  187. package/dist/gs/maps/iter.js +48 -21
  188. package/dist/gs/maps/iter.js.map +1 -1
  189. package/dist/gs/maps/maps.d.ts +6 -6
  190. package/dist/gs/maps/maps.js +1 -1
  191. package/dist/gs/maps/maps.js.map +1 -1
  192. package/dist/gs/math/bits/index.d.ts +13 -4
  193. package/dist/gs/math/bits/index.js +70 -48
  194. package/dist/gs/math/bits/index.js.map +1 -1
  195. package/dist/gs/math/const.gs.d.ts +5 -5
  196. package/dist/gs/math/const.gs.js +4 -4
  197. package/dist/gs/math/const.gs.js.map +1 -1
  198. package/dist/gs/mime/index.d.ts +1 -0
  199. package/dist/gs/mime/index.js +52 -0
  200. package/dist/gs/mime/index.js.map +1 -0
  201. package/dist/gs/net/http/httptest/index.d.ts +30 -0
  202. package/dist/gs/net/http/httptest/index.js +101 -0
  203. package/dist/gs/net/http/httptest/index.js.map +1 -0
  204. package/dist/gs/net/http/index.d.ts +131 -0
  205. package/dist/gs/net/http/index.js +307 -0
  206. package/dist/gs/net/http/index.js.map +1 -0
  207. package/dist/gs/net/http/pprof/index.d.ts +8 -0
  208. package/dist/gs/net/http/pprof/index.js +59 -0
  209. package/dist/gs/net/http/pprof/index.js.map +1 -0
  210. package/dist/gs/os/dir_unix.gs.js +2 -2
  211. package/dist/gs/os/dir_unix.gs.js.map +1 -1
  212. package/dist/gs/os/error.gs.js +9 -7
  213. package/dist/gs/os/error.gs.js.map +1 -1
  214. package/dist/gs/os/types_js.gs.js +95 -15
  215. package/dist/gs/os/types_js.gs.js.map +1 -1
  216. package/dist/gs/path/filepath/match.js +165 -3
  217. package/dist/gs/path/filepath/match.js.map +1 -1
  218. package/dist/gs/path/filepath/path.d.ts +8 -4
  219. package/dist/gs/path/filepath/path.js +192 -8
  220. package/dist/gs/path/filepath/path.js.map +1 -1
  221. package/dist/gs/path/path.d.ts +4 -1
  222. package/dist/gs/path/path.js +16 -4
  223. package/dist/gs/path/path.js.map +1 -1
  224. package/dist/gs/reflect/index.d.ts +4 -3
  225. package/dist/gs/reflect/index.js +3 -2
  226. package/dist/gs/reflect/index.js.map +1 -1
  227. package/dist/gs/reflect/iter.js +2 -2
  228. package/dist/gs/reflect/iter.js.map +1 -1
  229. package/dist/gs/reflect/map.js +29 -0
  230. package/dist/gs/reflect/map.js.map +1 -1
  231. package/dist/gs/reflect/type.d.ts +31 -9
  232. package/dist/gs/reflect/type.js +536 -43
  233. package/dist/gs/reflect/type.js.map +1 -1
  234. package/dist/gs/reflect/types.d.ts +1 -0
  235. package/dist/gs/reflect/types.js +3 -1
  236. package/dist/gs/reflect/types.js.map +1 -1
  237. package/dist/gs/reflect/value.d.ts +4 -1
  238. package/dist/gs/reflect/value.js +39 -1
  239. package/dist/gs/reflect/value.js.map +1 -1
  240. package/dist/gs/reflect/visiblefields.js +1 -1
  241. package/dist/gs/reflect/visiblefields.js.map +1 -1
  242. package/dist/gs/runtime/debug/index.d.ts +41 -0
  243. package/dist/gs/runtime/debug/index.js +66 -0
  244. package/dist/gs/runtime/debug/index.js.map +1 -0
  245. package/dist/gs/runtime/pprof/index.d.ts +20 -0
  246. package/dist/gs/runtime/pprof/index.js +85 -0
  247. package/dist/gs/runtime/pprof/index.js.map +1 -0
  248. package/dist/gs/runtime/runtime.d.ts +35 -3
  249. package/dist/gs/runtime/runtime.js +72 -0
  250. package/dist/gs/runtime/runtime.js.map +1 -1
  251. package/dist/gs/runtime/trace/index.d.ts +19 -0
  252. package/dist/gs/runtime/trace/index.js +64 -0
  253. package/dist/gs/runtime/trace/index.js.map +1 -0
  254. package/dist/gs/slices/slices.d.ts +42 -8
  255. package/dist/gs/slices/slices.js +425 -11
  256. package/dist/gs/slices/slices.js.map +1 -1
  257. package/dist/gs/sort/slice.gs.d.ts +5 -3
  258. package/dist/gs/sort/slice.gs.js +60 -22
  259. package/dist/gs/sort/slice.gs.js.map +1 -1
  260. package/dist/gs/sort/sort.gs.d.ts +4 -4
  261. package/dist/gs/sort/sort.gs.js +11 -8
  262. package/dist/gs/sort/sort.gs.js.map +1 -1
  263. package/dist/gs/strings/builder.d.ts +1 -1
  264. package/dist/gs/strings/builder.js +29 -19
  265. package/dist/gs/strings/builder.js.map +1 -1
  266. package/dist/gs/strings/iter.js +140 -75
  267. package/dist/gs/strings/iter.js.map +1 -1
  268. package/dist/gs/strings/replace.js +2 -2
  269. package/dist/gs/strings/replace.js.map +1 -1
  270. package/dist/gs/strings/strings.js +52 -6
  271. package/dist/gs/strings/strings.js.map +1 -1
  272. package/dist/gs/sync/atomic/type.gs.d.ts +9 -8
  273. package/dist/gs/sync/atomic/type.gs.js +0 -2
  274. package/dist/gs/sync/atomic/type.gs.js.map +1 -1
  275. package/dist/gs/sync/sync.d.ts +8 -3
  276. package/dist/gs/sync/sync.js +66 -11
  277. package/dist/gs/sync/sync.js.map +1 -1
  278. package/dist/gs/syscall/constants.d.ts +36 -24
  279. package/dist/gs/syscall/constants.js +12 -0
  280. package/dist/gs/syscall/constants.js.map +1 -1
  281. package/dist/gs/syscall/errors.d.ts +117 -111
  282. package/dist/gs/syscall/errors.js +45 -0
  283. package/dist/gs/syscall/errors.js.map +1 -1
  284. package/dist/gs/syscall/fs.d.ts +37 -0
  285. package/dist/gs/syscall/fs.js +102 -0
  286. package/dist/gs/syscall/fs.js.map +1 -1
  287. package/dist/gs/syscall/js/index.d.ts +90 -0
  288. package/dist/gs/syscall/js/index.js +383 -0
  289. package/dist/gs/syscall/js/index.js.map +1 -0
  290. package/dist/gs/syscall/types.d.ts +26 -1
  291. package/dist/gs/syscall/types.js +45 -1
  292. package/dist/gs/syscall/types.js.map +1 -1
  293. package/dist/gs/testing/index.d.ts +1 -0
  294. package/dist/gs/testing/index.js +2 -0
  295. package/dist/gs/testing/index.js.map +1 -0
  296. package/dist/gs/testing/testing.d.ts +78 -0
  297. package/dist/gs/testing/testing.js +318 -0
  298. package/dist/gs/testing/testing.js.map +1 -0
  299. package/dist/gs/time/time.d.ts +41 -4
  300. package/dist/gs/time/time.js +227 -36
  301. package/dist/gs/time/time.js.map +1 -1
  302. package/dist/gs/unicode/unicode.d.ts +23 -1
  303. package/dist/gs/unicode/unicode.js +79 -10
  304. package/dist/gs/unicode/unicode.js.map +1 -1
  305. package/dist/gs/unicode/utf8/utf8.d.ts +4 -4
  306. package/dist/gs/unicode/utf8/utf8.js +24 -11
  307. package/dist/gs/unicode/utf8/utf8.js.map +1 -1
  308. package/dist/gs/unique/index.d.ts +11 -0
  309. package/dist/gs/unique/index.js +76 -0
  310. package/dist/gs/unique/index.js.map +1 -0
  311. package/go.mod +8 -8
  312. package/go.sum +14 -14
  313. package/gs/builtin/builtin.ts +585 -27
  314. package/gs/builtin/channel.ts +183 -29
  315. package/gs/builtin/defer.ts +13 -2
  316. package/gs/builtin/hostio.test.ts +1 -0
  317. package/gs/builtin/hostio.ts +38 -0
  318. package/gs/builtin/map.ts +46 -6
  319. package/gs/builtin/print.ts +12 -3
  320. package/gs/builtin/runtime-contract.test.ts +383 -10
  321. package/gs/builtin/slice.test.ts +70 -0
  322. package/gs/builtin/slice.ts +785 -265
  323. package/gs/builtin/type.ts +160 -41
  324. package/gs/builtin/varRef.ts +40 -1
  325. package/gs/bytes/buffer.gs.ts +74 -70
  326. package/gs/bytes/iter.gs.ts +13 -14
  327. package/gs/bytes/meta.json +8 -3
  328. package/gs/bytes/reader.gs.ts +20 -19
  329. package/gs/compress/zlib/index.test.ts +28 -0
  330. package/gs/compress/zlib/index.ts +200 -0
  331. package/gs/compress/zlib/meta.json +3 -0
  332. package/gs/context/context.test.ts +71 -0
  333. package/gs/context/context.ts +30 -29
  334. package/gs/crypto/ecdh/index.test.ts +43 -0
  335. package/gs/crypto/ecdh/index.ts +274 -0
  336. package/gs/crypto/ed25519/index.test.ts +41 -0
  337. package/gs/crypto/ed25519/index.ts +238 -0
  338. package/gs/crypto/ed25519/meta.json +13 -0
  339. package/gs/crypto/internal/constanttime/index.test.ts +25 -0
  340. package/gs/crypto/internal/constanttime/index.ts +22 -0
  341. package/gs/crypto/internal/fips140deps/byteorder/index.ts +1 -0
  342. package/gs/crypto/internal/fips140deps/godebug/index.ts +1 -0
  343. package/gs/crypto/rand/index.test.ts +89 -1
  344. package/gs/crypto/rand/index.ts +103 -1
  345. package/gs/crypto/rand/meta.json +4 -1
  346. package/gs/crypto/sha256/index.test.ts +78 -0
  347. package/gs/crypto/sha256/index.ts +150 -0
  348. package/gs/crypto/sha256/meta.json +9 -0
  349. package/gs/crypto/sha512/index.test.ts +31 -0
  350. package/gs/crypto/sha512/index.ts +161 -0
  351. package/gs/crypto/sha512/meta.json +11 -0
  352. package/gs/embed/index.ts +20 -0
  353. package/gs/embed/meta.json +5 -0
  354. package/gs/encoding/json/index.test.ts +39 -3
  355. package/gs/encoding/json/index.ts +45 -3
  356. package/gs/errors/errors.test.ts +85 -0
  357. package/gs/errors/errors.ts +132 -4
  358. package/gs/fmt/fmt.test.ts +3 -1
  359. package/gs/fmt/fmt.ts +55 -19
  360. package/gs/github.com/aperturerobotics/protobuf-go-lite/index.test.ts +128 -1
  361. package/gs/github.com/aperturerobotics/protobuf-go-lite/index.ts +342 -4
  362. package/gs/github.com/aperturerobotics/protobuf-go-lite/json/index.test.ts +180 -0
  363. package/gs/github.com/aperturerobotics/protobuf-go-lite/json/index.ts +1084 -0
  364. package/gs/github.com/aperturerobotics/starpc/srpc/index.test.ts +31 -0
  365. package/gs/github.com/aperturerobotics/starpc/srpc/index.ts +1233 -0
  366. package/gs/github.com/aperturerobotics/starpc/srpc/meta.json +46 -0
  367. package/gs/github.com/aperturerobotics/util/conc/index.test.ts +30 -0
  368. package/gs/github.com/aperturerobotics/util/conc/index.ts +172 -0
  369. package/gs/github.com/aperturerobotics/util/conc/meta.json +9 -0
  370. package/gs/github.com/aperturerobotics/wasivm/wazero/kernel/runtime/browser/browser.ts +1 -4
  371. package/gs/github.com/hack-pad/safejs/internal/catch/index.test.ts +35 -0
  372. package/gs/github.com/hack-pad/safejs/internal/catch/index.ts +65 -0
  373. package/gs/github.com/hack-pad/safejs/internal/catch/meta.json +9 -0
  374. package/gs/github.com/klauspost/compress/internal/le/index.test.ts +37 -0
  375. package/gs/github.com/klauspost/compress/internal/le/index.ts +115 -0
  376. package/gs/github.com/mr-tron/base58/base58/index.test.ts +70 -0
  377. package/gs/github.com/mr-tron/base58/base58/index.ts +231 -0
  378. package/gs/github.com/mr-tron/base58/base58/meta.json +3 -0
  379. package/gs/github.com/zeebo/blake3/internal/consts/index.test.ts +46 -0
  380. package/gs/github.com/zeebo/blake3/internal/consts/index.ts +26 -0
  381. package/gs/go/internal/scannerhooks/index.test.ts +14 -0
  382. package/gs/go/internal/scannerhooks/index.ts +9 -0
  383. package/gs/go/scanner/index.test.ts +22 -0
  384. package/gs/go/scanner/index.ts +47 -0
  385. package/gs/go/token/index.test.ts +47 -1
  386. package/gs/go/token/index.ts +583 -4
  387. package/gs/hash/fnv/index.test.ts +67 -0
  388. package/gs/hash/fnv/index.ts +351 -0
  389. package/gs/hash/fnv/meta.json +3 -0
  390. package/gs/hash/index.test.ts +37 -0
  391. package/gs/hash/index.ts +118 -0
  392. package/gs/hash/meta.json +5 -0
  393. package/gs/internal/abi/index.test.ts +18 -0
  394. package/gs/internal/abi/index.ts +14 -0
  395. package/gs/internal/bytealg/index.test.ts +18 -0
  396. package/gs/internal/bytealg/index.ts +16 -0
  397. package/gs/internal/byteorder/index.test.ts +39 -0
  398. package/gs/internal/byteorder/index.ts +100 -27
  399. package/gs/internal/godebug/index.test.ts +16 -0
  400. package/gs/internal/godebug/index.ts +35 -0
  401. package/gs/io/fs/index.ts +1 -0
  402. package/gs/io/fs/meta.json +5 -0
  403. package/gs/io/fs/readlink.test.ts +43 -0
  404. package/gs/io/fs/readlink.ts +69 -0
  405. package/gs/io/fs/walk.test.ts +61 -0
  406. package/gs/io/fs/walk.ts +17 -9
  407. package/gs/io/io.ts +177 -31
  408. package/gs/io/meta.json +10 -2
  409. package/gs/iter/iter.ts +8 -2
  410. package/gs/maps/iter.ts +75 -26
  411. package/gs/maps/maps.test.ts +23 -0
  412. package/gs/maps/maps.ts +13 -11
  413. package/gs/math/bits/index.test.ts +20 -0
  414. package/gs/math/bits/index.ts +107 -64
  415. package/gs/math/const.gs.test.ts +11 -5
  416. package/gs/math/const.gs.ts +5 -6
  417. package/gs/mime/index.ts +60 -0
  418. package/gs/net/http/httptest/index.test.ts +53 -0
  419. package/gs/net/http/httptest/index.ts +120 -0
  420. package/gs/net/http/index.test.ts +148 -0
  421. package/gs/net/http/index.ts +432 -0
  422. package/gs/net/http/meta.json +6 -0
  423. package/gs/net/http/pprof/index.test.ts +47 -0
  424. package/gs/net/http/pprof/index.ts +65 -0
  425. package/gs/os/dir_unix.gs.ts +2 -3
  426. package/gs/os/error.gs.ts +9 -10
  427. package/gs/os/error.test.ts +41 -0
  428. package/gs/os/file_unix_js.test.ts +55 -0
  429. package/gs/os/tempfile.gs.test.ts +37 -10
  430. package/gs/os/types_js.gs.ts +96 -17
  431. package/gs/path/filepath/match.test.ts +31 -12
  432. package/gs/path/filepath/match.ts +181 -3
  433. package/gs/path/filepath/meta.json +6 -0
  434. package/gs/path/filepath/path.test.ts +80 -0
  435. package/gs/path/filepath/path.ts +244 -11
  436. package/gs/path/path.ts +20 -5
  437. package/gs/reflect/field.test.ts +63 -0
  438. package/gs/reflect/index.ts +5 -1
  439. package/gs/reflect/iter.ts +2 -2
  440. package/gs/reflect/map.test.ts +42 -1
  441. package/gs/reflect/map.ts +39 -0
  442. package/gs/reflect/type.ts +728 -65
  443. package/gs/reflect/typefor.test.ts +100 -0
  444. package/gs/reflect/types.ts +3 -1
  445. package/gs/reflect/value.ts +50 -1
  446. package/gs/reflect/visiblefields.ts +1 -1
  447. package/gs/runtime/debug/index.test.ts +45 -0
  448. package/gs/runtime/debug/index.ts +96 -0
  449. package/gs/runtime/pprof/index.test.ts +36 -0
  450. package/gs/runtime/pprof/index.ts +104 -0
  451. package/gs/runtime/pprof/meta.json +6 -0
  452. package/gs/runtime/runtime.test.ts +19 -0
  453. package/gs/runtime/runtime.ts +98 -3
  454. package/gs/runtime/trace/index.test.ts +45 -0
  455. package/gs/runtime/trace/index.ts +97 -0
  456. package/gs/runtime/trace/meta.json +7 -0
  457. package/gs/slices/meta.json +2 -1
  458. package/gs/slices/slices.test.ts +180 -0
  459. package/gs/slices/slices.ts +502 -15
  460. package/gs/sort/meta.json +7 -0
  461. package/gs/sort/slice.gs.ts +85 -26
  462. package/gs/sort/slice.test.ts +40 -0
  463. package/gs/sort/sort.gs.ts +16 -13
  464. package/gs/strings/builder.test.ts +8 -0
  465. package/gs/strings/builder.ts +33 -20
  466. package/gs/strings/iter.test.ts +5 -7
  467. package/gs/strings/iter.ts +146 -71
  468. package/gs/strings/replace.test.ts +1 -4
  469. package/gs/strings/replace.ts +6 -6
  470. package/gs/strings/strings.test.ts +4 -0
  471. package/gs/strings/strings.ts +54 -6
  472. package/gs/sync/atomic/type.gs.ts +13 -14
  473. package/gs/sync/meta.json +3 -1
  474. package/gs/sync/sync.test.ts +69 -1
  475. package/gs/sync/sync.ts +72 -13
  476. package/gs/syscall/constants.ts +39 -24
  477. package/gs/syscall/errors.ts +165 -112
  478. package/gs/syscall/fs.ts +195 -0
  479. package/gs/syscall/js/index.ts +485 -0
  480. package/gs/syscall/js/meta.json +4 -0
  481. package/gs/syscall/net.test.ts +111 -0
  482. package/gs/syscall/types.ts +63 -2
  483. package/gs/testing/index.ts +1 -0
  484. package/gs/testing/meta.json +5 -0
  485. package/gs/testing/testing.test.ts +146 -0
  486. package/gs/testing/testing.ts +399 -0
  487. package/gs/time/meta.json +2 -2
  488. package/gs/time/time.test.ts +110 -0
  489. package/gs/time/time.ts +309 -57
  490. package/gs/unicode/unicode.test.ts +36 -0
  491. package/gs/unicode/unicode.ts +115 -9
  492. package/gs/unicode/utf8/utf8.test.ts +13 -0
  493. package/gs/unicode/utf8/utf8.ts +28 -16
  494. package/gs/unique/index.ts +98 -0
  495. package/package.json +3 -2
@@ -1,30 +1,62 @@
1
1
  import { afterEach, describe, expect, it, vi } from 'vitest'
2
2
 
3
3
  import {
4
+ append,
5
+ bytesToUint8Array,
6
+ type Bytes,
4
7
  byte,
8
+ cap,
9
+ cloneArrayValue,
10
+ cloneStructValue,
5
11
  callGenericMethod,
6
12
  chanRecvWithOk,
7
13
  functionValue,
8
14
  genericZero,
15
+ goSlice,
9
16
  int,
17
+ arrayPointerFromIndexRef,
18
+ indexAddress,
19
+ indexRef,
10
20
  interfaceValue,
21
+ len,
22
+ makeSlice,
11
23
  makeChannel,
12
24
  makeMap,
13
25
  mapGet,
14
26
  mapSet,
15
27
  markAsStructValue,
16
28
  namedFunction,
29
+ namedValueInterfaceValue,
17
30
  newError,
18
31
  pointerValue,
19
32
  print,
20
33
  println,
34
+ rangeString,
21
35
  registerInterfaceType,
22
36
  registerStructType,
23
37
  resetHostRuntimeForTests,
38
+ selectStatement,
39
+ sliceToArray,
40
+ sliceHeaderRef,
41
+ stringHeaderRef,
24
42
  TypeKind,
25
43
  typeAssert,
44
+ typeAssertTuple,
26
45
  typedNil,
46
+ uint,
47
+ uint64Add,
48
+ uint64And,
49
+ uint64Div,
50
+ uint64Mod,
51
+ uint64Mul,
52
+ uint64Or,
53
+ uint64Shl,
54
+ uint64Shr,
55
+ uint64Sub,
56
+ uint64Xor,
57
+ uintShr,
27
58
  unref,
59
+ unsupportedPointerRef,
28
60
  varRef,
29
61
  } from './index.js'
30
62
 
@@ -90,14 +122,97 @@ describe('builtin runtime contract helpers', () => {
90
122
 
91
123
  it('exposes numeric, varref, map, and error helpers', () => {
92
124
  expect(int(1.9)).toBe(1)
125
+ expect(int(3n)).toBe(3)
126
+ expect(uint(257, 8)).toBe(1)
127
+ expect(uint(-1.9, 8)).toBe(255)
128
+ expect(uint(0x1_0000_0005, 32)).toBe(5)
129
+ expect(uint(42, 64)).toBe(42)
130
+ expect(uint(-1n, 8)).toBe(255)
93
131
  expect(byte(257)).toBe(1)
132
+ expect(uint(uint64Shl(1n, 63), 32)).toBe(0)
133
+ expect(uint(uint64Shr(uint64Shl(1n, 63), 60), 32)).toBe(8)
134
+ expect(uint(uint64Mul(0xffffffffffffffffn, 3), 32)).toBe(0xfffffffd)
135
+ expect(uint64Div(0xffffffffffffffffn, 4114)).toBe(4483895010624587)
136
+ expect(uint64Mod(0xffffffffffffffffn, 4114)).toBe(697)
137
+ expect(uint(uint64Add(0xffffffffffffffffn, 2), 32)).toBe(1)
138
+ expect(uint(uint64Sub(1n, 2), 32)).toBe(0xffffffff)
139
+ expect(uint(uint64And(0xf0n, 0x3cn), 32)).toBe(0x30)
140
+ expect(uint(uint64Or(0xf0n, 0x0fn), 32)).toBe(0xff)
141
+ expect(uint(uint64Xor(0xf0n, 0xffn), 32)).toBe(0x0f)
142
+ expect(uintShr(0x80000000, 31, 32)).toBe(1)
143
+ expect(uintShr(0x80000000, 32, 32)).toBe(0)
144
+ expect(uintShr(0xff, 4, 8)).toBe(15)
94
145
 
95
146
  const value = varRef(4)
96
147
  value.value = 8
97
148
  expect(unref(value)).toBe(8)
98
149
  expect(pointerValue(value)).toBe(8)
150
+ const pointerAssert = typeAssert<typeof value>(value, {
151
+ kind: TypeKind.Pointer,
152
+ elemType: { kind: TypeKind.Basic, name: 'int' },
153
+ })
154
+ expect(pointerAssert).toEqual({ value, ok: true })
155
+ const nilNamedSlice = varRef(null)
156
+ const nilNamedSliceIface = interfaceValue(
157
+ nilNamedSlice,
158
+ '*main.ObjectIdentifier',
159
+ )
160
+ expect(
161
+ typeAssert<typeof nilNamedSlice>(nilNamedSliceIface, {
162
+ kind: TypeKind.Pointer,
163
+ elemType: 'main.ObjectIdentifier',
164
+ }),
165
+ ).toEqual({ value: nilNamedSlice, ok: true })
99
166
  expect(pointerValue({ ok: true })).toEqual({ ok: true })
167
+ const namedPointerBox = namedValueInterfaceValue(
168
+ varRef(new Uint8Array([1, 2])),
169
+ '*main.Bytes',
170
+ {},
171
+ )
172
+ expect(pointerValue(namedPointerBox)).toEqual(new Uint8Array([1, 2]))
173
+ const namedPointerMethodBox = namedValueInterfaceValue(
174
+ varRef(new Uint8Array([1, 2, 3])),
175
+ '*main.Bytes',
176
+ { Len: (receiver: any) => len(receiver.value) },
177
+ )
178
+ expect(pointerValue(namedPointerMethodBox)).toBe(namedPointerMethodBox)
179
+ expect(pointerValue(namedPointerMethodBox).Len()).toBe(3)
180
+ expect(len(pointerValue(namedPointerMethodBox))).toBe(3)
181
+ expect(bytesToUint8Array(pointerValue(namedPointerMethodBox))).toEqual(
182
+ new Uint8Array([1, 2, 3]),
183
+ )
184
+ expect(bytesToUint8Array(goSlice(pointerValue(namedPointerMethodBox), 1))).toEqual(
185
+ new Uint8Array([2, 3]),
186
+ )
187
+ const namedStringBox = namedValueInterfaceValue('id', 'main.Name', {
188
+ String: (receiver: string) => `name:${receiver}`,
189
+ })
190
+ expect(pointerValue(namedStringBox)).toBe(namedStringBox)
191
+ expect(pointerValue(namedStringBox).String()).toBe('name:id')
192
+ expect(cloneStructValue({ clone: () => ({ ok: true }) })).toEqual({
193
+ ok: true,
194
+ })
195
+ expect(
196
+ cloneStructValue({ __goscriptClone: () => ({ internal: true }) }),
197
+ ).toEqual({ internal: true })
198
+ const fixedBytes = new Uint8Array([1, 2, 3])
199
+ const clonedBytes = cloneArrayValue(fixedBytes)
200
+ expect(clonedBytes).toEqual(fixedBytes)
201
+ expect(clonedBytes).not.toBe(fixedBytes)
202
+ const fixedWords = [
203
+ [1, 2],
204
+ [3, 4],
205
+ ]
206
+ const clonedWords = cloneArrayValue(fixedWords)
207
+ expect(clonedWords).toEqual(fixedWords)
208
+ expect(clonedWords).not.toBe(fixedWords)
209
+ expect(clonedWords[0]).not.toBe(fixedWords[0])
100
210
  expect(() => pointerValue(null)).toThrow('nil pointer dereference')
211
+ const unsupported = unsupportedPointerRef<number>(0)
212
+ expect(() => unsupported.value).toThrow('unsafe pointer dereference')
213
+ expect(() => {
214
+ unsupported.value = 1
215
+ }).toThrow('unsafe pointer dereference')
101
216
 
102
217
  const m = makeMap<string, number>()
103
218
  mapSet(m, 'answer', 42)
@@ -105,6 +220,211 @@ describe('builtin runtime contract helpers', () => {
105
220
  expect(mapGet(m, 'missing', 0)).toEqual([0, false])
106
221
 
107
222
  expect(newError('bad')?.Error()).toBe('bad')
223
+ expect(rangeString('a¢€')).toEqual([
224
+ [0, 97],
225
+ [1, 162],
226
+ [3, 8364],
227
+ ])
228
+ })
229
+
230
+ it('matches struct map keys by Go comparable value', () => {
231
+ class Key {
232
+ public _fields: {
233
+ name: ReturnType<typeof varRef<string>>
234
+ id: ReturnType<typeof varRef<number>>
235
+ }
236
+
237
+ constructor(name: string, id: number) {
238
+ this._fields = {
239
+ name: varRef(name),
240
+ id: varRef(id),
241
+ }
242
+ }
243
+ }
244
+
245
+ const m = makeMap<Key, string>()
246
+ mapSet(m, markAsStructValue(new Key('so-1', 7)), 'pending')
247
+ mapSet(m, markAsStructValue(new Key('so-1', 7)), 'accepted')
248
+
249
+ expect(m.size).toBe(1)
250
+ expect(mapGet(m, markAsStructValue(new Key('so-1', 7)), '')).toEqual([
251
+ 'accepted',
252
+ true,
253
+ ])
254
+ expect(mapGet(m, markAsStructValue(new Key('so-2', 7)), '')).toEqual([
255
+ '',
256
+ false,
257
+ ])
258
+ })
259
+
260
+ it('does not compare runtime internals as generated struct values', () => {
261
+ class RuntimeType {
262
+ constructor(
263
+ private readonly name: string,
264
+ public readonly _fields: unknown[],
265
+ ) {}
266
+
267
+ String(): string {
268
+ return this.name
269
+ }
270
+ }
271
+
272
+ const m = makeMap<RuntimeType, string>()
273
+ mapSet(m, new RuntimeType('gob.wireType', []), 'wire')
274
+
275
+ expect(mapGet(m, new RuntimeType('gob.arrayType', []), '')).toEqual([
276
+ '',
277
+ false,
278
+ ])
279
+ })
280
+
281
+ it('tries duplicate runtime type registrations for colliding package names', () => {
282
+ class HashInterfaceImpl {
283
+ Write(_p: Bytes): [number, null] {
284
+ return [0, null]
285
+ }
286
+ }
287
+ class HashMessage {}
288
+
289
+ registerInterfaceType('collision.Hash', null, [
290
+ {
291
+ name: 'Write',
292
+ args: [
293
+ {
294
+ name: 'p',
295
+ type: {
296
+ kind: TypeKind.Slice,
297
+ elemType: { kind: TypeKind.Basic, name: 'uint8' },
298
+ },
299
+ },
300
+ ],
301
+ returns: [],
302
+ },
303
+ ])
304
+ registerStructType(
305
+ 'collision.Hash',
306
+ new HashMessage(),
307
+ [],
308
+ HashMessage,
309
+ {},
310
+ )
311
+
312
+ expect(typeAssertTuple(new HashInterfaceImpl(), 'collision.Hash')[1]).toBe(
313
+ true,
314
+ )
315
+ expect(
316
+ typeAssertTuple(markAsStructValue(new HashMessage()), 'collision.Hash')[1],
317
+ ).toBe(true)
318
+ })
319
+
320
+ it('asserts interface-boxed named primitive values by declared type', () => {
321
+ const boxed = namedValueInterfaceValue(13, 'main.MyInt', {
322
+ Double: (receiver: number) => receiver * 2,
323
+ })
324
+
325
+ expect(
326
+ typeAssertTuple<number>(boxed, {
327
+ kind: TypeKind.Basic,
328
+ name: 'int',
329
+ typeName: 'main.MyInt',
330
+ }),
331
+ ).toEqual([13, true])
332
+ })
333
+
334
+ it('exposes addressable slice and array index references', () => {
335
+ const values = [1, 2, 3]
336
+ const second = indexRef(values, 1)
337
+ second.value = 8
338
+ expect(values).toEqual([1, 8, 3])
339
+ expect(pointerValue(second)).toBe(8)
340
+
341
+ const view = goSlice(values, 1, 3)
342
+ const firstInView = indexRef(view, 0)
343
+ firstInView.value = 11
344
+ expect(values).toEqual([1, 11, 3])
345
+ expect(Object.getOwnPropertyDescriptor(view, '0')?.value).toBe(11)
346
+
347
+ const bytes = new Uint8Array([4, 5])
348
+ const firstByte = indexRef<number>(bytes, 0)
349
+ firstByte.value = 9
350
+ expect(Array.from(bytes)).toEqual([9, 5])
351
+
352
+ const byteBacking = makeSlice<number>(8, undefined, 'byte')
353
+ const shortBytes = goSlice(byteBacking as Uint8Array, 0, 2)
354
+ expect(len(shortBytes)).toBe(2)
355
+ expect(cap(shortBytes)).toBe(8)
356
+ const fullBytes = goSlice(shortBytes, 0, 8)
357
+ fullBytes![7] = 12
358
+ expect((byteBacking as Uint8Array)[7]).toBe(12)
359
+
360
+ const arrayPointer = arrayPointerFromIndexRef(indexRef(byteBacking, 1), 3)
361
+ const arrayView = pointerValue(arrayPointer) as Uint8Array
362
+ expect(len(arrayView)).toBe(3)
363
+ arrayView[2] = 19
364
+ expect((byteBacking as Uint8Array)[3]).toBe(19)
365
+
366
+ shortBytes![0] = 14
367
+ expect(bytesToUint8Array(shortBytes)).toEqual(new Uint8Array([14, 0]))
368
+
369
+ class Entry {
370
+ value = ''
371
+ }
372
+ const entries = makeSlice<Entry>(1, 3, undefined, () => new Entry())
373
+ const expanded = goSlice(entries, 0, 3)
374
+ const extra = indexRef(expanded, 2)
375
+ extra.value.value = 'zero-backed'
376
+ expect(pointerValue(extra).value).toBe('zero-backed')
377
+
378
+ const base = makeSlice<number>(1, 4, 'number')
379
+ base![0] = 7
380
+ const beforeAppend = goSlice(base, 0, 1)
381
+ const afterAppend = append(beforeAppend, 8, 9)
382
+ expect(len(beforeAppend)).toBe(1)
383
+ expect(len(afterAppend)).toBe(3)
384
+ expect([...afterAppend!]).toEqual([7, 8, 9])
385
+ expect(beforeAppend![0]).toBe(7)
386
+
387
+ const splitLeft = goSlice(afterAppend, 0, 1, 1)
388
+ expect(len(splitLeft)).toBe(1)
389
+ expect(cap(splitLeft)).toBe(1)
390
+ expect([...splitLeft!]).toEqual([7])
391
+
392
+ const text = varRef('abc')
393
+ const headerBytes = varRef(makeSlice<number>(0, 0, 'byte'))
394
+ const strh = pointerValue(stringHeaderRef(text))
395
+ const sh = pointerValue(sliceHeaderRef(headerBytes))
396
+ sh.Data = strh.Data
397
+ sh.Len = strh.Len
398
+ sh.Cap = strh.Len
399
+ expect(bytesToUint8Array(headerBytes.value)).toEqual(new Uint8Array([97, 98, 99]))
400
+ })
401
+
402
+ it('exposes stable synthetic slice index addresses', () => {
403
+ const values = [1, 2, 3, 4]
404
+ const left = goSlice(values, 1, 3)
405
+ const right = goSlice(values, 2, 4)
406
+ const other = [8, 9]
407
+
408
+ expect(indexAddress(left, 0)).toBe(indexAddress(values, 1))
409
+ expect(indexAddress(left, 1)).toBe(indexAddress(right, 0))
410
+ expect(indexAddress(left, 1)).toBeGreaterThan(indexAddress(left, 0))
411
+ expect(indexAddress(other, 0)).not.toBe(indexAddress(left, 0))
412
+ })
413
+
414
+ it('copies slices into fixed arrays with Go length checks', () => {
415
+ const source = goSlice([1, 2, 3], 1, 3)
416
+ const array = sliceToArray<number>(source, 2)
417
+ array[0] = 9
418
+
419
+ expect(array).toEqual([9, 3])
420
+ expect(source![0]).toBe(2)
421
+ expect(() => sliceToArray<number>(source, 3)).toThrow(
422
+ 'cannot convert slice with length 2 to array with length 3',
423
+ )
424
+
425
+ expect(sliceToArray<number>(new Uint8Array([4, 5, 6]), 2, 'byte')).toEqual(
426
+ new Uint8Array([4, 5]),
427
+ )
108
428
  })
109
429
 
110
430
  it('exposes value and type descriptor helpers', () => {
@@ -135,6 +455,21 @@ describe('builtin runtime contract helpers', () => {
135
455
  expect(typeAssert<Runner>(new Runner(), runnerInterface).ok).toBe(true)
136
456
  expect(typeAssert<Runner>(null, runnerInterface).ok).toBe(false)
137
457
 
458
+ const emptyInterface = registerInterfaceType('phase5.EmptyInterface', null, [])
459
+ const fn = functionValue(() => 'ok', {
460
+ kind: TypeKind.Function,
461
+ params: [],
462
+ results: [{ kind: TypeKind.Basic, name: 'string' }],
463
+ })
464
+ expect(typeAssert<typeof fn>(fn, emptyInterface)).toEqual({
465
+ ok: true,
466
+ value: fn,
467
+ })
468
+ expect(typeAssert<number>(3, emptyInterface)).toEqual({
469
+ ok: true,
470
+ value: 3,
471
+ })
472
+
138
473
  const nil = typedNil('*main.Example')
139
474
  expect(nil.__isTypedNil).toBe(true)
140
475
  expect(nil.__goType).toBe('*main.Example')
@@ -161,11 +496,9 @@ describe('builtin runtime contract helpers', () => {
161
496
  [{ name: 'Name', args: [], returns: [{ type: 'string' }] }],
162
497
  TypedDog,
163
498
  )
164
- const dogInterface = registerInterfaceType(
165
- 'phase5.DogInterface',
166
- null,
167
- [{ name: 'Name', args: [], returns: [{ type: 'string' }] }],
168
- )
499
+ const dogInterface = registerInterfaceType('phase5.DogInterface', null, [
500
+ { name: 'Name', args: [], returns: [{ type: 'string' }] },
501
+ ])
169
502
  const nilDog = interfaceValue<{ Name(): string } | null>(
170
503
  null,
171
504
  '*phase5.TypedDog',
@@ -180,11 +513,16 @@ describe('builtin runtime contract helpers', () => {
180
513
  }),
181
514
  ).toEqual({ value: null, ok: true })
182
515
 
183
- const greet = namedFunction((name: string) => `hello ${name}`, 'phase5.Greet')
184
- expect(typeAssert<typeof greet>(greet, {
185
- kind: TypeKind.Function,
186
- name: 'phase5.Greet',
187
- }).ok).toBe(true)
516
+ const greet = namedFunction(
517
+ (name: string) => `hello ${name}`,
518
+ 'phase5.Greet',
519
+ )
520
+ expect(
521
+ typeAssert<typeof greet>(greet, {
522
+ kind: TypeKind.Function,
523
+ name: 'phase5.Greet',
524
+ }).ok,
525
+ ).toBe(true)
188
526
  expect(
189
527
  typeAssert<{ Name: string }>(
190
528
  { Name: 'Alice' },
@@ -222,9 +560,44 @@ describe('builtin runtime contract helpers', () => {
222
560
 
223
561
  it('exposes channel helpers used by future lowering', async () => {
224
562
  const channel = makeChannel<number>(1, 0, 'both')
563
+ expect(cap(channel)).toBe(1)
225
564
  await channel.send(7)
565
+ expect(len(channel)).toBe(1)
566
+ expect(cap(channel)).toBe(1)
226
567
  expect(await chanRecvWithOk(channel)).toEqual({ value: 7, ok: true })
568
+ expect(len(channel)).toBe(0)
227
569
  channel.close()
228
570
  expect(await chanRecvWithOk(channel)).toEqual({ value: 0, ok: false })
229
571
  })
572
+
573
+ it('cancels losing select receive cases', async () => {
574
+ const signal = makeChannel<string>(1, '', 'both')
575
+ const timeout = makeChannel<string>(0, '', 'both')
576
+ queueMicrotask(() => timeout.close())
577
+
578
+ await selectStatement(
579
+ [
580
+ {
581
+ id: 0,
582
+ isSend: false,
583
+ channel: signal,
584
+ onSelected: async () => 'signal',
585
+ },
586
+ {
587
+ id: 1,
588
+ isSend: false,
589
+ channel: timeout,
590
+ onSelected: async () => 'timeout',
591
+ },
592
+ ],
593
+ false,
594
+ )
595
+
596
+ await signal.send('value')
597
+ const received = await Promise.race([
598
+ signal.receive(),
599
+ new Promise<string>((resolve) => setTimeout(() => resolve('timeout'), 20)),
600
+ ])
601
+ expect(received).toBe('value')
602
+ })
230
603
  })
@@ -0,0 +1,70 @@
1
+ import { describe, expect, it } from 'vitest'
2
+
3
+ import { makeMap, mapGet, mapSet } from './map.js'
4
+ import {
5
+ bytesToString,
6
+ copy,
7
+ indexString,
8
+ len,
9
+ sliceString,
10
+ stringCompare,
11
+ stringEqual,
12
+ stringToBytes,
13
+ } from './slice.js'
14
+
15
+ describe('builtin string byte representation', () => {
16
+ it('round-trips non-UTF-8 byte strings without external provenance', () => {
17
+ const original = new Uint8Array([0, 255, 128, 65, 66])
18
+ const str = bytesToString(original)
19
+
20
+ expect(Array.from(stringToBytes(str))).toEqual(Array.from(original))
21
+ expect(len(str)).toBe(original.length)
22
+ expect(indexString(str, 1)).toBe(255)
23
+ expect(Array.from(stringToBytes(sliceString(str, 1, 4)))).toEqual([
24
+ 255, 128, 65,
25
+ ])
26
+ })
27
+
28
+ it('copies UTF-8 strings by bytes', () => {
29
+ const dst = new Uint8Array(3)
30
+
31
+ expect(copy(dst, '你')).toBe(3)
32
+ expect(Array.from(dst)).toEqual([0xe4, 0xbd, 0xa0])
33
+ })
34
+
35
+ it('compares byte-backed string aliases by bytes', () => {
36
+ const peerID = new Uint8Array([0, 255, 65])
37
+
38
+ expect(stringEqual(peerID, bytesToString(peerID))).toBe(true)
39
+ expect(stringEqual(peerID, '')).toBe(false)
40
+ expect(stringEqual(new Uint8Array(0), '')).toBe(true)
41
+ })
42
+
43
+ it('matches byte-backed strings as map keys', () => {
44
+ const raw = new Uint8Array([10, 36, 8, 1, 18, 32, 222, 187])
45
+ const key = bytesToString(raw)
46
+ const m = makeMap<string, string>()
47
+
48
+ mapSet(m, key, 'cached')
49
+
50
+ expect(mapGet(m, bytesToString(raw), '')).toEqual(['cached', true])
51
+ })
52
+
53
+ it('orders byte-backed strings by Go string bytes', () => {
54
+ expect(
55
+ stringCompare(new Uint8Array([0, 255]), new Uint8Array([1])),
56
+ ).toBeLessThan(0)
57
+ expect(
58
+ stringCompare(new Uint8Array([1]), new Uint8Array([0, 255])),
59
+ ).toBeGreaterThan(0)
60
+ expect(
61
+ stringCompare(new Uint8Array([1, 2]), new Uint8Array([1, 2, 0])),
62
+ ).toBeLessThan(0)
63
+ expect(
64
+ stringCompare(
65
+ bytesToString(new Uint8Array([255])),
66
+ new Uint8Array([255]),
67
+ ),
68
+ ).toBe(0)
69
+ })
70
+ })