functionalscript 0.2.5 → 0.3.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.
Files changed (433) hide show
  1. package/.github/workflows/ci.yml +19 -4
  2. package/CHANGELOG.md +9 -0
  3. package/com/cpp/{module.f.mjs → module.f.ts} +65 -44
  4. package/com/cpp/{test.f.mjs → test.f.ts} +1 -1
  5. package/com/cpp/testlib.f.ts +8 -0
  6. package/com/cs/{module.f.mjs → module.f.ts} +47 -38
  7. package/com/cs/{test.f.mjs → test.f.ts} +2 -2
  8. package/com/cs/testlib.f.ts +8 -0
  9. package/com/rust/module.f.ts +287 -0
  10. package/com/rust/{test.f.mjs → test.f.ts} +1 -1
  11. package/com/rust/testlib.f.ts +8 -0
  12. package/com/test/{build.f.mjs → build.f.ts} +47 -45
  13. package/com/test/{build.mjs → build.ts} +7 -6
  14. package/com/types/module.f.ts +62 -0
  15. package/com/types/{testlib.f.mjs → testlib.f.ts} +2 -3
  16. package/commonjs/build/module.f.ts +100 -0
  17. package/commonjs/build/{test.f.mjs → test.f.ts} +21 -17
  18. package/commonjs/module/function/module.f.ts +13 -0
  19. package/commonjs/module/module.f.ts +41 -0
  20. package/commonjs/module.f.ts +7 -0
  21. package/commonjs/{module.mjs → module.ts} +12 -9
  22. package/commonjs/package/dependencies/module.f.ts +22 -0
  23. package/commonjs/package/dependencies/{test.f.mjs → test.f.ts} +1 -1
  24. package/commonjs/package/module.f.ts +31 -0
  25. package/commonjs/package/{test.f.mjs → test.f.ts} +1 -1
  26. package/commonjs/path/{module.f.mjs → module.f.ts} +72 -67
  27. package/commonjs/path/{test.f.mjs → test.f.ts} +25 -19
  28. package/commonjs/{test.mjs → test.ts} +5 -4
  29. package/crypto/prime_field/{module.f.mjs → module.f.ts} +40 -37
  30. package/crypto/prime_field/{test.f.mjs → test.f.ts} +7 -5
  31. package/crypto/secp/{module.f.mjs → module.f.ts} +44 -44
  32. package/crypto/secp/{test.f.mjs → test.f.ts} +16 -11
  33. package/crypto/sha2/{module.f.mjs → module.f.ts} +61 -46
  34. package/crypto/sha2/{test.f.mjs → test.f.ts} +12 -9
  35. package/deno.json +71 -0
  36. package/dev/README.md +8 -0
  37. package/dev/index.ts +3 -0
  38. package/dev/{module.f.mjs → module.f.ts} +0 -2
  39. package/dev/{module.mjs → module.ts} +65 -60
  40. package/dev/test/{module.f.mjs → module.f.ts} +57 -70
  41. package/dev/{test.f.mjs → test.f.ts} +7 -5
  42. package/dev/test.ts +53 -0
  43. package/djs/{module.f.mjs → module.f.ts} +31 -31
  44. package/djs/parser/{module.f.mjs → module.f.ts} +190 -182
  45. package/djs/parser/{test.f.mjs → test.f.ts} +173 -150
  46. package/djs/serializer/module.f.ts +90 -0
  47. package/djs/{test.f.mjs → test.f.ts} +4 -4
  48. package/djs/tokenizer/{module.f.mjs → module.f.ts} +35 -42
  49. package/djs/tokenizer/{test.f.mjs → test.f.ts} +9 -8
  50. package/fsc/{module.f.mjs → module.f.ts} +41 -44
  51. package/fsc/{test.f.mjs → test.f.ts} +8 -6
  52. package/fsm/module.f.ts +107 -0
  53. package/fsm/{test.f.mjs → test.f.ts} +10 -9
  54. package/html/README.md +10 -9
  55. package/html/module.f.ts +108 -0
  56. package/html/{test.f.mjs → test.f.ts} +10 -7
  57. package/issues/README.md +3 -0
  58. package/issues/lang/3110-function.md +25 -1
  59. package/issues/{test.f.mjs → test.f.ts} +3 -2
  60. package/js/tokenizer/module.f.ts +882 -0
  61. package/js/tokenizer/{test.f.mjs → test.f.ts} +11 -10
  62. package/json/module.f.ts +94 -0
  63. package/json/parser/{module.f.mjs → module.f.ts} +113 -109
  64. package/json/parser/{test.f.mjs → test.f.ts} +10 -9
  65. package/json/serializer/module.f.ts +70 -0
  66. package/json/serializer/{test.f.mjs → test.f.ts} +3 -3
  67. package/json/{test.f.mjs → test.f.ts} +3 -3
  68. package/json/tokenizer/{module.f.mjs → module.f.ts} +29 -36
  69. package/json/tokenizer/{test.f.mjs → test.f.ts} +9 -8
  70. package/nanvm-lib/src/extension.rs +15 -4
  71. package/nanvm-lib/src/interface.rs +7 -10
  72. package/nanvm-lib/src/lib.rs +3 -3
  73. package/nanvm-lib/src/naive.rs +10 -3
  74. package/nanvm-lib/src/nanenum.rs +5 -1
  75. package/nanvm-lib/tests/{test.f.mjs → test.f.ts} +7 -6
  76. package/nodejs/version/{main.mjs → main.ts} +1 -1
  77. package/nodejs/version/module.f.ts +42 -0
  78. package/nodejs/version/{test.f.mjs → test.f.ts} +11 -12
  79. package/package.json +9 -9
  80. package/text/ascii/{module.f.mjs → module.f.ts} +10 -8
  81. package/text/ascii/{test.f.mjs → test.f.ts} +4 -4
  82. package/text/module.f.ts +30 -0
  83. package/text/sgr/{module.f.mjs → module.f.ts} +3 -5
  84. package/text/{test.f.mjs → test.f.ts} +5 -4
  85. package/text/utf16/module.f.ts +108 -0
  86. package/text/utf16/{test.f.mjs → test.f.ts} +7 -6
  87. package/text/utf8/{module.f.mjs → module.f.ts} +29 -23
  88. package/text/utf8/{test.f.mjs → test.f.ts} +4 -4
  89. package/tsconfig.json +4 -1
  90. package/types/array/module.f.ts +89 -0
  91. package/types/array/{test.f.mjs → test.f.ts} +3 -3
  92. package/types/bigfloat/{module.f.mjs → module.f.ts} +25 -20
  93. package/types/bigfloat/{test.f.mjs → test.f.ts} +1 -1
  94. package/types/bigint/{module.f.mjs → module.f.ts} +29 -28
  95. package/types/bigint/{test.f.mjs → test.f.ts} +2 -2
  96. package/types/bit_vec/README.md +18 -0
  97. package/types/bit_vec/module.f.ts +185 -0
  98. package/types/bit_vec/test.f.ts +129 -0
  99. package/types/btree/find/module.f.ts +92 -0
  100. package/types/btree/find/{test.f.mjs → test.f.ts} +20 -16
  101. package/types/btree/{module.f.mjs → module.f.ts} +9 -9
  102. package/types/btree/remove/{module.f.mjs → module.f.ts} +43 -53
  103. package/types/btree/remove/{test.f.mjs → test.f.ts} +19 -15
  104. package/types/btree/set/{module.f.mjs → module.f.ts} +17 -20
  105. package/types/btree/set/{test.f.mjs → test.f.ts} +96 -66
  106. package/types/btree/{test.f.mjs → test.f.ts} +34 -26
  107. package/types/btree/types/module.f.ts +27 -0
  108. package/types/byte_set/module.f.ts +70 -0
  109. package/types/byte_set/{test.f.mjs → test.f.ts} +8 -7
  110. package/types/function/compare/module.f.ts +26 -0
  111. package/types/function/compare/{test.f.mjs → test.f.ts} +1 -1
  112. package/types/function/module.f.ts +43 -0
  113. package/types/function/operator/module.f.ts +63 -0
  114. package/types/function/test.f.ts +20 -0
  115. package/types/list/module.f.ts +345 -0
  116. package/types/list/{test.f.mjs → test.f.ts} +30 -24
  117. package/types/map/module.f.ts +65 -0
  118. package/types/map/{test.f.mjs → test.f.ts} +6 -5
  119. package/types/nibble_set/module.f.ts +34 -0
  120. package/types/nibble_set/{test.f.mjs → test.f.ts} +3 -3
  121. package/types/nullable/module.f.ts +9 -0
  122. package/types/nullable/{test.f.mjs → test.f.ts} +2 -2
  123. package/types/number/module.f.ts +16 -0
  124. package/types/number/{test.f.mjs → test.f.ts} +7 -5
  125. package/types/object/module.f.ts +30 -0
  126. package/types/object/{test.f.mjs → test.f.ts} +2 -2
  127. package/types/range/module.f.ts +10 -0
  128. package/types/range/{test.f.mjs → test.f.ts} +1 -1
  129. package/types/range_map/module.f.ts +70 -0
  130. package/types/range_map/{test.f.mjs → test.f.ts} +82 -57
  131. package/types/result/module.f.ts +20 -0
  132. package/types/result/{module.mjs → module.ts} +4 -3
  133. package/types/sorted_list/module.f.ts +83 -0
  134. package/types/sorted_list/{test.f.mjs → test.f.ts} +14 -12
  135. package/types/sorted_set/module.f.ts +36 -0
  136. package/types/sorted_set/{test.f.mjs → test.f.ts} +14 -12
  137. package/types/string/module.f.ts +24 -0
  138. package/types/string/{test.f.mjs → test.f.ts} +2 -2
  139. package/types/string_set/module.f.ts +37 -0
  140. package/types/string_set/{test.f.mjs → test.f.ts} +2 -2
  141. package/com/cpp/testlib.f.mjs +0 -8
  142. package/com/cs/testlib.f.mjs +0 -8
  143. package/com/rust/module.f.mjs +0 -272
  144. package/com/rust/testlib.f.mjs +0 -8
  145. package/com/types/module.f.mjs +0 -67
  146. package/commonjs/build/module.f.mjs +0 -100
  147. package/commonjs/module/function/module.f.mjs +0 -21
  148. package/commonjs/module/module.f.mjs +0 -53
  149. package/commonjs/module.f.mjs +0 -11
  150. package/commonjs/package/dependencies/module.f.mjs +0 -22
  151. package/commonjs/package/module.f.mjs +0 -36
  152. package/dev/index.mjs +0 -3
  153. package/dev/test.mjs +0 -60
  154. package/fsm/module.f.mjs +0 -99
  155. package/html/module.f.mjs +0 -102
  156. package/js/tokenizer/module.f.mjs +0 -872
  157. package/json/module.f.mjs +0 -89
  158. package/json/serializer/module.f.mjs +0 -87
  159. package/jsr.json +0 -66
  160. package/nodejs/version/module.f.mjs +0 -47
  161. package/out/com/cpp/module.f.d.mts +0 -7
  162. package/out/com/cpp/module.f.mjs +0 -130
  163. package/out/com/cpp/test.f.d.mts +0 -2
  164. package/out/com/cpp/test.f.mjs +0 -40
  165. package/out/com/cpp/testlib.f.d.mts +0 -2
  166. package/out/com/cpp/testlib.f.mjs +0 -7
  167. package/out/com/cs/module.f.d.mts +0 -7
  168. package/out/com/cs/module.f.mjs +0 -104
  169. package/out/com/cs/test.f.d.mts +0 -2
  170. package/out/com/cs/test.f.mjs +0 -43
  171. package/out/com/cs/testlib.f.d.mts +0 -2
  172. package/out/com/cs/testlib.f.mjs +0 -7
  173. package/out/com/rust/module.f.d.mts +0 -23
  174. package/out/com/rust/module.f.mjs +0 -224
  175. package/out/com/rust/test.f.d.mts +0 -2
  176. package/out/com/rust/test.f.mjs +0 -123
  177. package/out/com/rust/testlib.f.d.mts +0 -2
  178. package/out/com/rust/testlib.f.mjs +0 -7
  179. package/out/com/test/build.d.mts +0 -1
  180. package/out/com/test/build.f.d.mts +0 -26
  181. package/out/com/test/build.f.mjs +0 -98
  182. package/out/com/test/build.mjs +0 -40
  183. package/out/com/types/module.f.d.mts +0 -23
  184. package/out/com/types/module.f.mjs +0 -51
  185. package/out/com/types/testlib.f.d.mts +0 -44
  186. package/out/com/types/testlib.f.mjs +0 -30
  187. package/out/commonjs/build/module.f.d.mts +0 -20
  188. package/out/commonjs/build/module.f.mjs +0 -107
  189. package/out/commonjs/build/test.f.d.mts +0 -3
  190. package/out/commonjs/build/test.f.mjs +0 -102
  191. package/out/commonjs/module/function/module.f.d.mts +0 -5
  192. package/out/commonjs/module/function/module.f.mjs +0 -15
  193. package/out/commonjs/module/module.f.d.mts +0 -52
  194. package/out/commonjs/module/module.f.mjs +0 -48
  195. package/out/commonjs/module.d.mts +0 -3
  196. package/out/commonjs/module.f.d.mts +0 -2
  197. package/out/commonjs/module.f.mjs +0 -10
  198. package/out/commonjs/module.mjs +0 -26
  199. package/out/commonjs/package/dependencies/module.f.d.mts +0 -6
  200. package/out/commonjs/package/dependencies/module.f.mjs +0 -21
  201. package/out/commonjs/package/dependencies/test.f.d.mts +0 -2
  202. package/out/commonjs/package/dependencies/test.f.mjs +0 -15
  203. package/out/commonjs/package/module.f.d.mts +0 -21
  204. package/out/commonjs/package/module.f.mjs +0 -40
  205. package/out/commonjs/package/test.f.d.mts +0 -2
  206. package/out/commonjs/package/test.f.mjs +0 -27
  207. package/out/commonjs/path/module.f.d.mts +0 -60
  208. package/out/commonjs/path/module.f.mjs +0 -171
  209. package/out/commonjs/path/test.f.d.mts +0 -25
  210. package/out/commonjs/path/test.f.mjs +0 -231
  211. package/out/commonjs/test.d.mts +0 -8
  212. package/out/commonjs/test.mjs +0 -87
  213. package/out/crypto/prime_field/module.f.d.mts +0 -67
  214. package/out/crypto/prime_field/module.f.mjs +0 -110
  215. package/out/crypto/prime_field/test.f.d.mts +0 -13
  216. package/out/crypto/prime_field/test.f.mjs +0 -152
  217. package/out/crypto/secp/module.f.d.mts +0 -110
  218. package/out/crypto/secp/module.f.mjs +0 -173
  219. package/out/crypto/secp/test.f.d.mts +0 -5
  220. package/out/crypto/secp/test.f.mjs +0 -78
  221. package/out/crypto/sha2/module.f.d.mts +0 -15
  222. package/out/crypto/sha2/module.f.mjs +0 -172
  223. package/out/crypto/sha2/test.f.d.mts +0 -10
  224. package/out/crypto/sha2/test.f.mjs +0 -86
  225. package/out/dev/index.d.mts +0 -1
  226. package/out/dev/index.mjs +0 -2
  227. package/out/dev/module.d.mts +0 -26
  228. package/out/dev/module.f.d.mts +0 -1
  229. package/out/dev/module.f.mjs +0 -2
  230. package/out/dev/module.mjs +0 -167
  231. package/out/dev/test/module.f.d.mts +0 -25
  232. package/out/dev/test/module.f.mjs +0 -134
  233. package/out/dev/test.d.mts +0 -3
  234. package/out/dev/test.f.d.mts +0 -9
  235. package/out/dev/test.f.mjs +0 -58
  236. package/out/dev/test.mjs +0 -52
  237. package/out/djs/module.f.d.mts +0 -20
  238. package/out/djs/module.f.mjs +0 -79
  239. package/out/djs/parser/module.f.d.mts +0 -56
  240. package/out/djs/parser/module.f.mjs +0 -448
  241. package/out/djs/parser/test.f.d.mts +0 -13
  242. package/out/djs/parser/test.f.mjs +0 -569
  243. package/out/djs/test.f.d.mts +0 -12
  244. package/out/djs/test.f.mjs +0 -84
  245. package/out/djs/tokenizer/module.f.d.mts +0 -13
  246. package/out/djs/tokenizer/module.f.mjs +0 -91
  247. package/out/djs/tokenizer/test.f.d.mts +0 -7
  248. package/out/djs/tokenizer/test.f.mjs +0 -530
  249. package/out/fsc/module.f.d.mts +0 -7
  250. package/out/fsc/module.f.mjs +0 -105
  251. package/out/fsc/test.f.d.mts +0 -4
  252. package/out/fsc/test.f.mjs +0 -19
  253. package/out/fsm/module.f.d.mts +0 -14
  254. package/out/fsm/module.f.mjs +0 -80
  255. package/out/fsm/test.f.d.mts +0 -5
  256. package/out/fsm/test.f.mjs +0 -138
  257. package/out/html/module.f.d.mts +0 -17
  258. package/out/html/module.f.mjs +0 -80
  259. package/out/html/test.f.d.mts +0 -10
  260. package/out/html/test.f.mjs +0 -45
  261. package/out/issues/test.f.d.mts +0 -16
  262. package/out/issues/test.f.mjs +0 -66
  263. package/out/js/tokenizer/module.f.d.mts +0 -163
  264. package/out/js/tokenizer/module.f.mjs +0 -729
  265. package/out/js/tokenizer/test.f.d.mts +0 -9
  266. package/out/js/tokenizer/test.f.mjs +0 -906
  267. package/out/json/module.f.d.mts +0 -33
  268. package/out/json/module.f.mjs +0 -89
  269. package/out/json/parser/module.f.d.mts +0 -32
  270. package/out/json/parser/module.f.mjs +0 -224
  271. package/out/json/parser/test.f.d.mts +0 -5
  272. package/out/json/parser/test.f.mjs +0 -329
  273. package/out/json/serializer/module.f.d.mts +0 -36
  274. package/out/json/serializer/module.f.mjs +0 -67
  275. package/out/json/serializer/test.f.d.mts +0 -8
  276. package/out/json/serializer/test.f.mjs +0 -87
  277. package/out/json/test.f.d.mts +0 -8
  278. package/out/json/test.f.mjs +0 -61
  279. package/out/json/tokenizer/module.f.d.mts +0 -13
  280. package/out/json/tokenizer/module.f.mjs +0 -78
  281. package/out/json/tokenizer/test.f.d.mts +0 -6
  282. package/out/json/tokenizer/test.f.mjs +0 -420
  283. package/out/nanvm-lib/tests/test.f.d.mts +0 -36
  284. package/out/nanvm-lib/tests/test.f.mjs +0 -87
  285. package/out/nodejs/version/main.d.mts +0 -1
  286. package/out/nodejs/version/main.mjs +0 -3
  287. package/out/nodejs/version/module.f.d.mts +0 -12
  288. package/out/nodejs/version/module.f.mjs +0 -34
  289. package/out/nodejs/version/test.f.d.mts +0 -2
  290. package/out/nodejs/version/test.f.mjs +0 -97
  291. package/out/text/ascii/module.f.d.mts +0 -70
  292. package/out/text/ascii/module.f.mjs +0 -154
  293. package/out/text/ascii/test.f.d.mts +0 -4
  294. package/out/text/ascii/test.f.mjs +0 -14
  295. package/out/text/module.f.d.mts +0 -13
  296. package/out/text/module.f.mjs +0 -19
  297. package/out/text/sgr/module.f.d.mts +0 -12
  298. package/out/text/sgr/module.f.mjs +0 -17
  299. package/out/text/test.f.d.mts +0 -2
  300. package/out/text/test.f.mjs +0 -19
  301. package/out/text/utf16/module.f.d.mts +0 -12
  302. package/out/text/utf16/module.f.mjs +0 -86
  303. package/out/text/utf16/test.f.d.mts +0 -6
  304. package/out/text/utf16/test.f.mjs +0 -145
  305. package/out/text/utf8/module.f.d.mts +0 -10
  306. package/out/text/utf8/module.f.mjs +0 -126
  307. package/out/text/utf8/test.f.d.mts +0 -6
  308. package/out/text/utf8/test.f.mjs +0 -175
  309. package/out/types/array/module.f.d.mts +0 -31
  310. package/out/types/array/module.f.mjs +0 -95
  311. package/out/types/array/test.f.d.mts +0 -10
  312. package/out/types/array/test.f.mjs +0 -116
  313. package/out/types/bigfloat/module.f.d.mts +0 -6
  314. package/out/types/bigfloat/module.f.mjs +0 -77
  315. package/out/types/bigfloat/test.f.d.mts +0 -6
  316. package/out/types/bigfloat/test.f.mjs +0 -349
  317. package/out/types/bigint/module.f.d.mts +0 -29
  318. package/out/types/bigint/module.f.mjs +0 -114
  319. package/out/types/bigint/test.f.d.mts +0 -16
  320. package/out/types/bigint/test.f.mjs +0 -199
  321. package/out/types/bit_vec/module.f.d.mts +0 -72
  322. package/out/types/bit_vec/module.f.mjs +0 -83
  323. package/out/types/bit_vec/test.f.d.mts +0 -9
  324. package/out/types/bit_vec/test.f.mjs +0 -60
  325. package/out/types/btree/find/module.f.d.mts +0 -36
  326. package/out/types/btree/find/module.f.mjs +0 -137
  327. package/out/types/btree/find/test.f.d.mts +0 -2
  328. package/out/types/btree/find/test.f.mjs +0 -156
  329. package/out/types/btree/module.f.d.mts +0 -5
  330. package/out/types/btree/module.f.mjs +0 -34
  331. package/out/types/btree/remove/module.f.d.mts +0 -14
  332. package/out/types/btree/remove/module.f.mjs +0 -209
  333. package/out/types/btree/remove/test.f.d.mts +0 -7
  334. package/out/types/btree/remove/test.f.mjs +0 -638
  335. package/out/types/btree/set/module.f.d.mts +0 -5
  336. package/out/types/btree/set/module.f.mjs +0 -114
  337. package/out/types/btree/set/test.f.d.mts +0 -2
  338. package/out/types/btree/set/test.f.mjs +0 -390
  339. package/out/types/btree/test.f.d.mts +0 -13
  340. package/out/types/btree/test.f.mjs +0 -83
  341. package/out/types/btree/types/module.f.d.mts +0 -14
  342. package/out/types/btree/types/module.f.mjs +0 -50
  343. package/out/types/byte_set/module.f.d.mts +0 -25
  344. package/out/types/byte_set/module.f.mjs +0 -42
  345. package/out/types/byte_set/test.f.d.mts +0 -13
  346. package/out/types/byte_set/test.f.mjs +0 -123
  347. package/out/types/function/compare/module.f.d.mts +0 -23
  348. package/out/types/function/compare/module.f.mjs +0 -22
  349. package/out/types/function/compare/test.f.d.mts +0 -2
  350. package/out/types/function/compare/test.f.mjs +0 -8
  351. package/out/types/function/module.f.d.mts +0 -51
  352. package/out/types/function/module.f.mjs +0 -44
  353. package/out/types/function/operator/module.f.d.mts +0 -60
  354. package/out/types/function/operator/module.f.mjs +0 -60
  355. package/out/types/function/test.f.d.mts +0 -2
  356. package/out/types/function/test.f.mjs +0 -15
  357. package/out/types/list/module.f.d.mts +0 -82
  358. package/out/types/list/module.f.mjs +0 -269
  359. package/out/types/list/test.f.d.mts +0 -38
  360. package/out/types/list/test.f.mjs +0 -401
  361. package/out/types/map/module.f.d.mts +0 -21
  362. package/out/types/map/module.f.mjs +0 -54
  363. package/out/types/map/test.f.d.mts +0 -5
  364. package/out/types/map/test.f.mjs +0 -115
  365. package/out/types/nibble_set/module.f.d.mts +0 -16
  366. package/out/types/nibble_set/module.f.mjs +0 -19
  367. package/out/types/nibble_set/test.f.d.mts +0 -13
  368. package/out/types/nibble_set/test.f.mjs +0 -90
  369. package/out/types/nullable/module.f.d.mts +0 -9
  370. package/out/types/nullable/module.f.mjs +0 -9
  371. package/out/types/nullable/test.f.d.mts +0 -2
  372. package/out/types/nullable/test.f.mjs +0 -12
  373. package/out/types/number/module.f.d.mts +0 -7
  374. package/out/types/number/module.f.mjs +0 -12
  375. package/out/types/number/test.f.d.mts +0 -11
  376. package/out/types/number/test.f.mjs +0 -126
  377. package/out/types/object/module.f.d.mts +0 -22
  378. package/out/types/object/module.f.mjs +0 -27
  379. package/out/types/object/test.f.d.mts +0 -5
  380. package/out/types/object/test.f.mjs +0 -17
  381. package/out/types/range/module.f.d.mts +0 -6
  382. package/out/types/range/module.f.mjs +0 -6
  383. package/out/types/range/test.f.d.mts +0 -2
  384. package/out/types/range/test.f.mjs +0 -18
  385. package/out/types/range_map/module.f.d.mts +0 -19
  386. package/out/types/range_map/module.f.mjs +0 -84
  387. package/out/types/range_map/test.f.d.mts +0 -6
  388. package/out/types/range_map/test.f.mjs +0 -201
  389. package/out/types/result/module.d.mts +0 -7
  390. package/out/types/result/module.f.d.mts +0 -22
  391. package/out/types/result/module.f.mjs +0 -25
  392. package/out/types/result/module.mjs +0 -16
  393. package/out/types/sorted_list/module.f.d.mts +0 -53
  394. package/out/types/sorted_list/module.f.mjs +0 -102
  395. package/out/types/sorted_list/test.f.d.mts +0 -5
  396. package/out/types/sorted_list/test.f.mjs +0 -66
  397. package/out/types/sorted_set/module.f.d.mts +0 -19
  398. package/out/types/sorted_set/module.f.mjs +0 -29
  399. package/out/types/sorted_set/test.f.d.mts +0 -6
  400. package/out/types/sorted_set/test.f.mjs +0 -80
  401. package/out/types/string/module.f.d.mts +0 -9
  402. package/out/types/string/module.f.mjs +0 -17
  403. package/out/types/string/test.f.d.mts +0 -15
  404. package/out/types/string/test.f.mjs +0 -58
  405. package/out/types/string_set/module.f.d.mts +0 -13
  406. package/out/types/string_set/module.f.mjs +0 -29
  407. package/out/types/string_set/test.f.d.mts +0 -5
  408. package/out/types/string_set/test.f.mjs +0 -65
  409. package/text/module.f.mjs +0 -27
  410. package/text/utf16/module.f.mjs +0 -96
  411. package/types/array/module.f.mjs +0 -119
  412. package/types/bit_vec/module.f.mjs +0 -90
  413. package/types/bit_vec/test.f.mjs +0 -41
  414. package/types/btree/find/module.f.mjs +0 -125
  415. package/types/btree/types/module.f.mjs +0 -64
  416. package/types/byte_set/module.f.mjs +0 -61
  417. package/types/function/compare/module.f.mjs +0 -29
  418. package/types/function/module.f.mjs +0 -50
  419. package/types/function/operator/module.f.mjs +0 -78
  420. package/types/function/test.f.mjs +0 -17
  421. package/types/list/module.f.mjs +0 -320
  422. package/types/map/module.f.mjs +0 -67
  423. package/types/nibble_set/module.f.mjs +0 -28
  424. package/types/nullable/module.f.mjs +0 -11
  425. package/types/number/module.f.mjs +0 -16
  426. package/types/object/module.f.mjs +0 -33
  427. package/types/range/module.f.mjs +0 -8
  428. package/types/range_map/module.f.mjs +0 -84
  429. package/types/result/module.f.mjs +0 -28
  430. package/types/sorted_list/module.f.mjs +0 -107
  431. package/types/sorted_set/module.f.mjs +0 -38
  432. package/types/string/module.f.mjs +0 -22
  433. package/types/string_set/module.f.mjs +0 -36
@@ -1,125 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- import * as _ from '../types/module.f.mjs'
3
- import * as List from '../../list/module.f.mjs'
4
- import * as cmp from '../../function/compare/module.f.mjs'
5
- const { index3, index5 } = cmp
6
- import * as Array from '../../array/module.f.mjs'
7
-
8
- /**
9
- * @template T
10
- * @typedef {readonly[cmp.Index3, _.Leaf1<T>]} FirstLeaf1
11
- */
12
-
13
- /**
14
- * @template T
15
- * @typedef {readonly[1, _.Branch3<T>]} FirstBranch3
16
- */
17
-
18
- /**
19
- * @template T
20
- * @typedef {readonly[cmp.Index5, _.Leaf2<T>]} FirstLeaf2
21
- */
22
-
23
- /**
24
- * @template T
25
- * @typedef {readonly[1|3, _.Branch5<T>]} FirstBranch5
26
- */
27
-
28
- /**
29
- * @template T
30
- * @typedef {FirstLeaf1<T> | FirstBranch3<T> | FirstLeaf2<T> | FirstBranch5<T>} First
31
- */
32
-
33
- /**
34
- * @template T
35
- * @typedef {readonly[0|2, _.Branch3<T>]} PathItem3
36
- */
37
-
38
- /**
39
- * @template T
40
- * @typedef {readonly[0|2|4, _.Branch5<T>]} PathItem5
41
- */
42
-
43
- /**
44
- * @template T
45
- * @typedef {PathItem3<T> | PathItem5<T>} PathItem
46
- */
47
-
48
- /** @type {<T>(item: PathItem<T>) => _.Node<T>} */
49
- const child = item =>
50
- /** @type {typeof item extends PathItem<infer T> ? _.Node<T> : never} */(item[1][item[0]])
51
-
52
- /**
53
- * @template T
54
- * @typedef {List.List<PathItem<T>>} Path
55
- */
56
-
57
- /**
58
- * @template T
59
- * @typedef {{
60
- * readonly first: First<T>,
61
- * readonly tail: Path<T>
62
- * }} Result<T>
63
- */
64
-
65
- /** @type {<T>(c: cmp.Compare<T>) => (node: _.Node<T>) => Result<T>} */
66
- export const find = c => {
67
- const i3 = index3(c)
68
- const i5 = index5(c)
69
- /** @typedef {typeof c extends cmp.Compare<infer T> ? T : never} T */
70
- /** @type {(prior: Path<T>) => (node: _.Node<T>) => Result<T>} */
71
- const f = tail => node => {
72
- /** @type {(index: Array.KeyOf<typeof node>) => Result<T>} */
73
- const append = index => {
74
- const first = /** @type {PathItem<T>} */([index, node])
75
- return f({ first, tail })(child(first))
76
- }
77
- /** @type {(index: Array.KeyOf<typeof node>) => Result<T>} */
78
- const done = index => ({ first: /** @type {First<T>} */([index, node]), tail })
79
- switch (node.length) {
80
- case 1: { return done(i3(node[0])) }
81
- case 2: { return done(i5(node)) }
82
- case 3: {
83
- const i = i3(node[1])
84
- switch (i) {
85
- case 0: case 2: { return append(i) }
86
- case 1: { return done(i) }
87
- }
88
- }
89
- case 5: {
90
- const i = i5([node[1], node[3]])
91
- switch (i) {
92
- case 0: case 2: case 4: { return append(i) }
93
- case 1: case 3: { return done(i) }
94
- }
95
- }
96
- }
97
- }
98
- return f(null)
99
- }
100
-
101
- /** @type {<T>(first: First<T>) => boolean} */
102
- export const isFound = ([i]) => {
103
- switch (i) {
104
- case 1: case 3: { return true }
105
- default: { return false }
106
- }
107
- }
108
-
109
- /** @type {<T>(first: First<T>) => T | null} */
110
- export const value = ([i, r]) => {
111
- switch (i) {
112
- case 1: {
113
- switch (r.length) {
114
- case 1: case 2: { return r[0] }
115
- default: { return r[1] }
116
- }
117
- }
118
- case 3: {
119
- return r.length === 2 ? r[1] : r[3]
120
- }
121
- default: {
122
- return null
123
- }
124
- }
125
- }
@@ -1,64 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
-
3
- /**
4
- * @template T
5
- * @typedef {readonly[T]} Array1
6
- */
7
-
8
- /**
9
- * @template T
10
- * @typedef {readonly[T,T]} Array2
11
- */
12
-
13
- /**
14
- * @template T
15
- * @typedef {readonly[T,T,T]} Array3
16
- */
17
-
18
- /** @typedef {0|1} Index2 */
19
-
20
- /** @typedef {0|1|2} Index3 */
21
-
22
- /** @typedef {0|1|2|3|4} Index5 */
23
-
24
- //
25
-
26
- /**
27
- * @template T
28
- * @typedef {Array1<T>} Leaf1
29
- */
30
-
31
- /**
32
- * @template T
33
- * @typedef {Array2<T>} Leaf2
34
- */
35
-
36
- /**
37
- * @template T
38
- * @typedef {readonly [Node<T>, T, Node<T>]} Branch3
39
- */
40
-
41
- /**
42
- * @template T
43
- * @typedef {readonly [Node<T>, T, Node<T>, T, Node<T>]} Branch5
44
- */
45
-
46
- /**
47
- * @template T
48
- * @typedef { Leaf1<T> | Leaf2<T> | Branch3<T> | Branch5<T>} Node
49
- */
50
-
51
- /**
52
- * @template T
53
- * @typedef {Node<T> | null} Tree
54
- */
55
-
56
- /**
57
- * @template T
58
- * @typedef {readonly[Node<T>]} Branch1
59
- */
60
-
61
- /**
62
- * @template T
63
- * @typedef { readonly[...Branch5<T>, T, Node<T>] } Branch7
64
- */
@@ -1,61 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- import * as f from '../function/module.f.mjs'
3
- const { compose } = f
4
- import * as RangeMap from '../range_map/module.f.mjs'
5
- import * as SortedSet from '../sorted_set/module.f.mjs'
6
- import * as list from '../list/module.f.mjs'
7
- const { reverse, countdown, flat, map } = list
8
-
9
- /** @typedef {bigint} ByteSet */
10
- /** @typedef {number} Byte */
11
-
12
- /** @type {(n: Byte) => (s: ByteSet) => boolean} */
13
- export const has = n => s => ((s >> BigInt(n)) & 1n) === 1n
14
-
15
- // create a set
16
-
17
- export const empty = 0n
18
-
19
- // 0 1 2 3 4 5 6 7 8 9 A B C D E F
20
- export const universe = 0xFFFF_FFFF_FFFF_FFFF_FFFF_FFFF_FFFF_FFFF_FFFF_FFFF_FFFF_FFFF_FFFF_FFFF_FFFF_FFFFn
21
-
22
- /** @type {(n: Byte) => ByteSet} */
23
- export const one = n => 1n << BigInt(n)
24
-
25
- /** @type {(r: readonly[Byte, Byte]) => ByteSet} */
26
- export const range = ([b, e]) => one(e - b + 1) - 1n << BigInt(b)
27
-
28
- // set operations
29
-
30
- /** @type {(a: ByteSet) => (b: ByteSet) => ByteSet} */
31
- export const union = a => b => a | b
32
-
33
- /** @type {(a: ByteSet) => (b: ByteSet) => ByteSet} */
34
- const intersect = a => b => a & b
35
-
36
- /** @type {(n: ByteSet) => ByteSet} */
37
- export const complement = n => universe ^ n
38
-
39
- /** @type {(a: ByteSet) => (b: ByteSet) => ByteSet} */
40
- const difference = compose(intersect)(compose(complement))
41
-
42
- // additional operations
43
-
44
- export const set = compose(one)(union)
45
-
46
- export const setRange = compose(range)(union)
47
-
48
- /** @type {(n: Byte) => (s: ByteSet) => ByteSet} */
49
- export const unset = n => s => difference(s)(one(n))
50
-
51
- const counter = reverse(countdown(256))
52
-
53
- /** @type {(n: ByteSet) => (s: string) => (i: number) => RangeMap.RangeMap<SortedSet.SortedSet<string>>} */
54
- const toRangeMapOp = n => s => i => {
55
- const current = has(i + 1)(n)
56
- const prev = has(i)(n)
57
- return current === prev ? null : [[prev ? [s] : [], i]]
58
- }
59
-
60
- /** @type {(n: ByteSet) => (s: string) => RangeMap.RangeMap<SortedSet.SortedSet<string>>} */
61
- export const toRangeMap = n => s => flat(map(toRangeMapOp(n)(s))(counter))
@@ -1,29 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- import * as Array from '../../array/module.f.mjs'
3
-
4
- /** @typedef {Array.Index3} Index3 */
5
- /** @typedef {Array.Index5} Index5 */
6
-
7
- /**
8
- * @template T
9
- * @typedef {Array.Array2<T>} Array2
10
- */
11
-
12
- /** @typedef {-1|0|1} Sign */
13
-
14
- /**
15
- * @template T
16
- * @typedef {(_: T) => Sign} Compare
17
- */
18
-
19
- /** @type {<T>(cmp: Compare<T>) => (value: T) => Index3} */
20
- export const index3 = cmp => value => /** @type {Index3} */ (cmp(value) + 1)
21
-
22
- /** @type {<T>(cmp: Compare<T>) => (v2: Array2<T>) => Index5} */
23
- export const index5 = cmp => ([v0, v1]) => {
24
- const _0 = cmp(v0)
25
- return /** @type {Index5} */ (_0 <= 0 ? _0 + 1 : cmp(v1) + 3)
26
- }
27
-
28
- /** @type {<T>(a: T) => (b: T) => Sign} */
29
- export const unsafeCmp = a => b => a < b ? -1 : a > b ? 1 : 0
@@ -1,50 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
-
3
- /**
4
- * A generic function type.
5
- *
6
- * @template I
7
- * @template O
8
- * @typedef {(_: I) => O} Func
9
- */
10
-
11
- /**
12
- * A postfix compose function.
13
- *
14
- * @type {<I, X>(g: Func<I, X>) => <O>(f: Func<X, O>) => Func<I, O>}
15
- */
16
- export const compose = g => f => x => f(g(x))
17
-
18
- /**
19
- * A generic identity function.
20
- *
21
- * @type {<T>(value: T) => T}
22
- */
23
- export const identity = value => value
24
-
25
- /**
26
- * Flips the arguments of a curried function.
27
- *
28
- * @type {<A, B, C>(f: (a: A) => (b: B) => C) => (b: B) => (a: A) => C}
29
- */
30
- export const flip = f => b => a => f(a)(b)
31
-
32
- /**
33
- * A functional utility type that enables seamless chaining of transformations.
34
- *
35
- * @template I,O
36
- * @typedef {{
37
- * readonly result: Func<I, O>
38
- * readonly then: <T>(g: Func<O, T>) => Fn<I, T>
39
- * }} Fn
40
- */
41
-
42
- /**
43
- * Creates an `Fn` instance from a function, enabling chaining of transformations.
44
- *
45
- * @type {<I, O>(f: (i: I) => O) => Fn<I, O>}
46
- */
47
- export const fn = result => ({
48
- result,
49
- then: g => fn(compose(result)(g))
50
- })
@@ -1,78 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- /**
3
- * @template A
4
- * @template B
5
- * @template R
6
- * @typedef {(a: A) => (b: B) => R} Binary
7
- */
8
-
9
- /**
10
- * @template I,O
11
- * @typedef {Binary<I, O, O>} Fold
12
- */
13
-
14
- /** @type {(separator: string) => Reduce<string>} */
15
- export const join = separator => value => prior => `${prior}${separator}${value}`
16
-
17
- /** @type {Reduce<string>} */
18
- export const concat = i => acc => `${acc}${i}`
19
-
20
- /**
21
- * @template T
22
- * @template R
23
- * @typedef {(value: T) => R} Unary
24
- */
25
-
26
- /** @type {Unary<boolean, boolean>} */
27
- export const logicalNot = v => !v
28
-
29
- /**
30
- * @template T
31
- * @typedef {Binary<T, T, boolean>} Equal
32
- */
33
-
34
- /** @type {<T>(a: T) => (b: T) => boolean} */
35
- export const strictEqual = a => b => a === b
36
-
37
- /**
38
- * @template I,O
39
- * @typedef {(input: I) => readonly[O, Scan<I,O>]} Scan
40
- */
41
-
42
- /**
43
- * @template I,S,O
44
- * @typedef {(prior: S) => (input: I) => readonly[O, S]} StateScan
45
- */
46
-
47
- /** @type {<I, S, O>(op: StateScan<I, S, O>) => (prior: S) => Scan<I, O>} */
48
- export const stateScanToScan = op => prior => i => {
49
- const [o, s] = op(prior)(i)
50
- return [o, stateScanToScan(op)(s)]
51
- }
52
-
53
- /** @type {<I, O>(fold: Fold<I, O>) => (prior: O) => Scan<I, O>} */
54
- export const foldToScan = fold => prior => i => {
55
- const result = fold(i)(prior)
56
- return [result, foldToScan(fold)(result)]
57
- }
58
-
59
- /**
60
- * @template T
61
- * @typedef {Fold<T, T>} Reduce
62
- */
63
-
64
- /** @type {<T>(fold: Reduce<T>) => Scan<T, T>} */
65
- export const reduceToScan = op => init => [init, foldToScan(op)(init)]
66
-
67
- /** @type {Reduce<number>} */
68
- export const addition = a => b => a + b
69
-
70
- /** @type {Reduce<number>} */
71
- export const min = a => b => a < b ? a : b
72
-
73
- /** @type {Reduce<number>} */
74
- export const max = a => b => a > b ? a : b
75
-
76
- export const increment = addition(1)
77
-
78
- export const counter = () => increment
@@ -1,17 +0,0 @@
1
- import * as _ from './module.f.mjs'
2
-
3
- const { fn } = _
4
-
5
- export default () => {
6
- /** @type {(x: string) => readonly[string]} */
7
- const f = x => [x]
8
- /** @type {(x: readonly[string]) => readonly[number]} */
9
- const g = ([x]) => [x.length]
10
- /** @type {(x: readonly[number]) => number} */
11
- const w = ([x]) => x
12
-
13
- const r = fn(f).then(g).then(w).result
14
-
15
- const result = r('hello')
16
- if (result !== 5) { throw r }
17
- }