functionalscript 0.2.6 → 0.3.1

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 (428) hide show
  1. package/.github/workflows/ci.yml +20 -4
  2. package/CHANGELOG.md +5 -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} +66 -61
  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/module.f.ts +108 -0
  55. package/html/{test.f.mjs → test.f.ts} +10 -7
  56. package/issues/lang/3110-function.md +25 -1
  57. package/issues/{test.f.mjs → test.f.ts} +3 -2
  58. package/js/tokenizer/module.f.ts +882 -0
  59. package/js/tokenizer/{test.f.mjs → test.f.ts} +11 -10
  60. package/json/module.f.ts +94 -0
  61. package/json/parser/{module.f.mjs → module.f.ts} +113 -109
  62. package/json/parser/{test.f.mjs → test.f.ts} +10 -9
  63. package/json/serializer/module.f.ts +70 -0
  64. package/json/serializer/{test.f.mjs → test.f.ts} +3 -3
  65. package/json/{test.f.mjs → test.f.ts} +3 -3
  66. package/json/tokenizer/{module.f.mjs → module.f.ts} +29 -36
  67. package/json/tokenizer/{test.f.mjs → test.f.ts} +9 -8
  68. package/nanvm-lib/src/extension.rs +15 -4
  69. package/nanvm-lib/src/interface.rs +7 -10
  70. package/nanvm-lib/src/lib.rs +3 -3
  71. package/nanvm-lib/src/naive.rs +10 -3
  72. package/nanvm-lib/src/nanenum.rs +5 -1
  73. package/nanvm-lib/tests/{test.f.mjs → test.f.ts} +7 -6
  74. package/nodejs/version/{main.mjs → main.ts} +1 -1
  75. package/nodejs/version/module.f.ts +42 -0
  76. package/nodejs/version/{test.f.mjs → test.f.ts} +11 -12
  77. package/package.json +9 -9
  78. package/text/ascii/{module.f.mjs → module.f.ts} +10 -8
  79. package/text/ascii/{test.f.mjs → test.f.ts} +4 -4
  80. package/text/module.f.ts +30 -0
  81. package/text/sgr/{module.f.mjs → module.f.ts} +3 -5
  82. package/text/{test.f.mjs → test.f.ts} +5 -4
  83. package/text/utf16/module.f.ts +108 -0
  84. package/text/utf16/{test.f.mjs → test.f.ts} +7 -6
  85. package/text/utf8/{module.f.mjs → module.f.ts} +29 -23
  86. package/text/utf8/{test.f.mjs → test.f.ts} +4 -4
  87. package/tsconfig.json +4 -1
  88. package/types/array/module.f.ts +89 -0
  89. package/types/array/{test.f.mjs → test.f.ts} +3 -3
  90. package/types/bigfloat/{module.f.mjs → module.f.ts} +25 -20
  91. package/types/bigfloat/{test.f.mjs → test.f.ts} +1 -1
  92. package/types/bigint/{module.f.mjs → module.f.ts} +29 -28
  93. package/types/bigint/{test.f.mjs → test.f.ts} +2 -2
  94. package/types/bit_vec/{module.f.mjs → module.f.ts} +16 -37
  95. package/types/bit_vec/{test.f.mjs → test.f.ts} +1 -1
  96. package/types/btree/find/module.f.ts +92 -0
  97. package/types/btree/find/{test.f.mjs → test.f.ts} +20 -16
  98. package/types/btree/{module.f.mjs → module.f.ts} +9 -9
  99. package/types/btree/remove/{module.f.mjs → module.f.ts} +43 -53
  100. package/types/btree/remove/{test.f.mjs → test.f.ts} +19 -15
  101. package/types/btree/set/{module.f.mjs → module.f.ts} +17 -20
  102. package/types/btree/set/{test.f.mjs → test.f.ts} +96 -66
  103. package/types/btree/{test.f.mjs → test.f.ts} +34 -26
  104. package/types/btree/types/module.f.ts +27 -0
  105. package/types/byte_set/module.f.ts +70 -0
  106. package/types/byte_set/{test.f.mjs → test.f.ts} +8 -7
  107. package/types/function/compare/module.f.ts +26 -0
  108. package/types/function/compare/{test.f.mjs → test.f.ts} +1 -1
  109. package/types/function/module.f.ts +43 -0
  110. package/types/function/operator/module.f.ts +63 -0
  111. package/types/function/test.f.ts +20 -0
  112. package/types/list/module.f.ts +345 -0
  113. package/types/list/{test.f.mjs → test.f.ts} +30 -24
  114. package/types/map/module.f.ts +65 -0
  115. package/types/map/{test.f.mjs → test.f.ts} +6 -5
  116. package/types/nibble_set/module.f.ts +34 -0
  117. package/types/nibble_set/{test.f.mjs → test.f.ts} +3 -3
  118. package/types/nullable/module.f.ts +9 -0
  119. package/types/nullable/{test.f.mjs → test.f.ts} +2 -2
  120. package/types/number/module.f.ts +16 -0
  121. package/types/number/{test.f.mjs → test.f.ts} +7 -5
  122. package/types/object/module.f.ts +30 -0
  123. package/types/object/{test.f.mjs → test.f.ts} +2 -2
  124. package/types/range/module.f.ts +10 -0
  125. package/types/range/{test.f.mjs → test.f.ts} +1 -1
  126. package/types/range_map/module.f.ts +70 -0
  127. package/types/range_map/{test.f.mjs → test.f.ts} +82 -57
  128. package/types/result/module.f.ts +20 -0
  129. package/types/result/{module.mjs → module.ts} +4 -3
  130. package/types/sorted_list/module.f.ts +83 -0
  131. package/types/sorted_list/{test.f.mjs → test.f.ts} +14 -12
  132. package/types/sorted_set/module.f.ts +36 -0
  133. package/types/sorted_set/{test.f.mjs → test.f.ts} +14 -12
  134. package/types/string/module.f.ts +24 -0
  135. package/types/string/{test.f.mjs → test.f.ts} +2 -2
  136. package/types/string_set/module.f.ts +37 -0
  137. package/types/string_set/{test.f.mjs → test.f.ts} +2 -2
  138. package/com/cpp/testlib.f.mjs +0 -8
  139. package/com/cs/testlib.f.mjs +0 -8
  140. package/com/rust/module.f.mjs +0 -272
  141. package/com/rust/testlib.f.mjs +0 -8
  142. package/com/types/module.f.mjs +0 -67
  143. package/commonjs/build/module.f.mjs +0 -100
  144. package/commonjs/module/function/module.f.mjs +0 -21
  145. package/commonjs/module/module.f.mjs +0 -53
  146. package/commonjs/module.f.mjs +0 -11
  147. package/commonjs/package/dependencies/module.f.mjs +0 -22
  148. package/commonjs/package/module.f.mjs +0 -36
  149. package/dev/index.mjs +0 -3
  150. package/dev/test.mjs +0 -60
  151. package/fsm/module.f.mjs +0 -99
  152. package/html/module.f.mjs +0 -102
  153. package/js/tokenizer/module.f.mjs +0 -872
  154. package/json/module.f.mjs +0 -89
  155. package/json/serializer/module.f.mjs +0 -87
  156. package/jsr.json +0 -66
  157. package/nodejs/version/module.f.mjs +0 -47
  158. package/out/com/cpp/module.f.d.mts +0 -7
  159. package/out/com/cpp/module.f.mjs +0 -130
  160. package/out/com/cpp/test.f.d.mts +0 -2
  161. package/out/com/cpp/test.f.mjs +0 -40
  162. package/out/com/cpp/testlib.f.d.mts +0 -2
  163. package/out/com/cpp/testlib.f.mjs +0 -7
  164. package/out/com/cs/module.f.d.mts +0 -7
  165. package/out/com/cs/module.f.mjs +0 -104
  166. package/out/com/cs/test.f.d.mts +0 -2
  167. package/out/com/cs/test.f.mjs +0 -43
  168. package/out/com/cs/testlib.f.d.mts +0 -2
  169. package/out/com/cs/testlib.f.mjs +0 -7
  170. package/out/com/rust/module.f.d.mts +0 -23
  171. package/out/com/rust/module.f.mjs +0 -224
  172. package/out/com/rust/test.f.d.mts +0 -2
  173. package/out/com/rust/test.f.mjs +0 -123
  174. package/out/com/rust/testlib.f.d.mts +0 -2
  175. package/out/com/rust/testlib.f.mjs +0 -7
  176. package/out/com/test/build.d.mts +0 -1
  177. package/out/com/test/build.f.d.mts +0 -26
  178. package/out/com/test/build.f.mjs +0 -98
  179. package/out/com/test/build.mjs +0 -40
  180. package/out/com/types/module.f.d.mts +0 -23
  181. package/out/com/types/module.f.mjs +0 -51
  182. package/out/com/types/testlib.f.d.mts +0 -44
  183. package/out/com/types/testlib.f.mjs +0 -30
  184. package/out/commonjs/build/module.f.d.mts +0 -20
  185. package/out/commonjs/build/module.f.mjs +0 -107
  186. package/out/commonjs/build/test.f.d.mts +0 -3
  187. package/out/commonjs/build/test.f.mjs +0 -102
  188. package/out/commonjs/module/function/module.f.d.mts +0 -5
  189. package/out/commonjs/module/function/module.f.mjs +0 -15
  190. package/out/commonjs/module/module.f.d.mts +0 -52
  191. package/out/commonjs/module/module.f.mjs +0 -48
  192. package/out/commonjs/module.d.mts +0 -3
  193. package/out/commonjs/module.f.d.mts +0 -2
  194. package/out/commonjs/module.f.mjs +0 -10
  195. package/out/commonjs/module.mjs +0 -26
  196. package/out/commonjs/package/dependencies/module.f.d.mts +0 -6
  197. package/out/commonjs/package/dependencies/module.f.mjs +0 -21
  198. package/out/commonjs/package/dependencies/test.f.d.mts +0 -2
  199. package/out/commonjs/package/dependencies/test.f.mjs +0 -15
  200. package/out/commonjs/package/module.f.d.mts +0 -21
  201. package/out/commonjs/package/module.f.mjs +0 -40
  202. package/out/commonjs/package/test.f.d.mts +0 -2
  203. package/out/commonjs/package/test.f.mjs +0 -27
  204. package/out/commonjs/path/module.f.d.mts +0 -60
  205. package/out/commonjs/path/module.f.mjs +0 -171
  206. package/out/commonjs/path/test.f.d.mts +0 -25
  207. package/out/commonjs/path/test.f.mjs +0 -231
  208. package/out/commonjs/test.d.mts +0 -8
  209. package/out/commonjs/test.mjs +0 -87
  210. package/out/crypto/prime_field/module.f.d.mts +0 -67
  211. package/out/crypto/prime_field/module.f.mjs +0 -110
  212. package/out/crypto/prime_field/test.f.d.mts +0 -13
  213. package/out/crypto/prime_field/test.f.mjs +0 -152
  214. package/out/crypto/secp/module.f.d.mts +0 -110
  215. package/out/crypto/secp/module.f.mjs +0 -173
  216. package/out/crypto/secp/test.f.d.mts +0 -5
  217. package/out/crypto/secp/test.f.mjs +0 -78
  218. package/out/crypto/sha2/module.f.d.mts +0 -15
  219. package/out/crypto/sha2/module.f.mjs +0 -172
  220. package/out/crypto/sha2/test.f.d.mts +0 -10
  221. package/out/crypto/sha2/test.f.mjs +0 -86
  222. package/out/dev/index.d.mts +0 -1
  223. package/out/dev/index.mjs +0 -2
  224. package/out/dev/module.d.mts +0 -26
  225. package/out/dev/module.f.d.mts +0 -1
  226. package/out/dev/module.f.mjs +0 -2
  227. package/out/dev/module.mjs +0 -167
  228. package/out/dev/test/module.f.d.mts +0 -25
  229. package/out/dev/test/module.f.mjs +0 -134
  230. package/out/dev/test.d.mts +0 -3
  231. package/out/dev/test.f.d.mts +0 -9
  232. package/out/dev/test.f.mjs +0 -58
  233. package/out/dev/test.mjs +0 -52
  234. package/out/djs/module.f.d.mts +0 -20
  235. package/out/djs/module.f.mjs +0 -79
  236. package/out/djs/parser/module.f.d.mts +0 -56
  237. package/out/djs/parser/module.f.mjs +0 -448
  238. package/out/djs/parser/test.f.d.mts +0 -13
  239. package/out/djs/parser/test.f.mjs +0 -569
  240. package/out/djs/test.f.d.mts +0 -12
  241. package/out/djs/test.f.mjs +0 -84
  242. package/out/djs/tokenizer/module.f.d.mts +0 -13
  243. package/out/djs/tokenizer/module.f.mjs +0 -91
  244. package/out/djs/tokenizer/test.f.d.mts +0 -7
  245. package/out/djs/tokenizer/test.f.mjs +0 -530
  246. package/out/fsc/module.f.d.mts +0 -7
  247. package/out/fsc/module.f.mjs +0 -105
  248. package/out/fsc/test.f.d.mts +0 -4
  249. package/out/fsc/test.f.mjs +0 -19
  250. package/out/fsm/module.f.d.mts +0 -14
  251. package/out/fsm/module.f.mjs +0 -80
  252. package/out/fsm/test.f.d.mts +0 -5
  253. package/out/fsm/test.f.mjs +0 -138
  254. package/out/html/module.f.d.mts +0 -17
  255. package/out/html/module.f.mjs +0 -80
  256. package/out/html/test.f.d.mts +0 -10
  257. package/out/html/test.f.mjs +0 -45
  258. package/out/issues/test.f.d.mts +0 -16
  259. package/out/issues/test.f.mjs +0 -66
  260. package/out/js/tokenizer/module.f.d.mts +0 -163
  261. package/out/js/tokenizer/module.f.mjs +0 -729
  262. package/out/js/tokenizer/test.f.d.mts +0 -9
  263. package/out/js/tokenizer/test.f.mjs +0 -906
  264. package/out/json/module.f.d.mts +0 -33
  265. package/out/json/module.f.mjs +0 -89
  266. package/out/json/parser/module.f.d.mts +0 -32
  267. package/out/json/parser/module.f.mjs +0 -224
  268. package/out/json/parser/test.f.d.mts +0 -5
  269. package/out/json/parser/test.f.mjs +0 -329
  270. package/out/json/serializer/module.f.d.mts +0 -36
  271. package/out/json/serializer/module.f.mjs +0 -67
  272. package/out/json/serializer/test.f.d.mts +0 -8
  273. package/out/json/serializer/test.f.mjs +0 -87
  274. package/out/json/test.f.d.mts +0 -8
  275. package/out/json/test.f.mjs +0 -61
  276. package/out/json/tokenizer/module.f.d.mts +0 -13
  277. package/out/json/tokenizer/module.f.mjs +0 -78
  278. package/out/json/tokenizer/test.f.d.mts +0 -6
  279. package/out/json/tokenizer/test.f.mjs +0 -420
  280. package/out/nanvm-lib/tests/test.f.d.mts +0 -36
  281. package/out/nanvm-lib/tests/test.f.mjs +0 -87
  282. package/out/nodejs/version/main.d.mts +0 -1
  283. package/out/nodejs/version/main.mjs +0 -3
  284. package/out/nodejs/version/module.f.d.mts +0 -12
  285. package/out/nodejs/version/module.f.mjs +0 -34
  286. package/out/nodejs/version/test.f.d.mts +0 -2
  287. package/out/nodejs/version/test.f.mjs +0 -97
  288. package/out/text/ascii/module.f.d.mts +0 -70
  289. package/out/text/ascii/module.f.mjs +0 -154
  290. package/out/text/ascii/test.f.d.mts +0 -4
  291. package/out/text/ascii/test.f.mjs +0 -14
  292. package/out/text/module.f.d.mts +0 -13
  293. package/out/text/module.f.mjs +0 -19
  294. package/out/text/sgr/module.f.d.mts +0 -12
  295. package/out/text/sgr/module.f.mjs +0 -17
  296. package/out/text/test.f.d.mts +0 -2
  297. package/out/text/test.f.mjs +0 -19
  298. package/out/text/utf16/module.f.d.mts +0 -12
  299. package/out/text/utf16/module.f.mjs +0 -86
  300. package/out/text/utf16/test.f.d.mts +0 -6
  301. package/out/text/utf16/test.f.mjs +0 -145
  302. package/out/text/utf8/module.f.d.mts +0 -10
  303. package/out/text/utf8/module.f.mjs +0 -126
  304. package/out/text/utf8/test.f.d.mts +0 -6
  305. package/out/text/utf8/test.f.mjs +0 -175
  306. package/out/types/array/module.f.d.mts +0 -31
  307. package/out/types/array/module.f.mjs +0 -95
  308. package/out/types/array/test.f.d.mts +0 -10
  309. package/out/types/array/test.f.mjs +0 -116
  310. package/out/types/bigfloat/module.f.d.mts +0 -6
  311. package/out/types/bigfloat/module.f.mjs +0 -77
  312. package/out/types/bigfloat/test.f.d.mts +0 -6
  313. package/out/types/bigfloat/test.f.mjs +0 -349
  314. package/out/types/bigint/module.f.d.mts +0 -29
  315. package/out/types/bigint/module.f.mjs +0 -114
  316. package/out/types/bigint/test.f.d.mts +0 -16
  317. package/out/types/bigint/test.f.mjs +0 -199
  318. package/out/types/bit_vec/module.f.d.mts +0 -158
  319. package/out/types/bit_vec/module.f.mjs +0 -194
  320. package/out/types/bit_vec/test.f.d.mts +0 -23
  321. package/out/types/bit_vec/test.f.mjs +0 -210
  322. package/out/types/btree/find/module.f.d.mts +0 -36
  323. package/out/types/btree/find/module.f.mjs +0 -137
  324. package/out/types/btree/find/test.f.d.mts +0 -2
  325. package/out/types/btree/find/test.f.mjs +0 -156
  326. package/out/types/btree/module.f.d.mts +0 -5
  327. package/out/types/btree/module.f.mjs +0 -34
  328. package/out/types/btree/remove/module.f.d.mts +0 -14
  329. package/out/types/btree/remove/module.f.mjs +0 -209
  330. package/out/types/btree/remove/test.f.d.mts +0 -7
  331. package/out/types/btree/remove/test.f.mjs +0 -638
  332. package/out/types/btree/set/module.f.d.mts +0 -5
  333. package/out/types/btree/set/module.f.mjs +0 -114
  334. package/out/types/btree/set/test.f.d.mts +0 -2
  335. package/out/types/btree/set/test.f.mjs +0 -390
  336. package/out/types/btree/test.f.d.mts +0 -13
  337. package/out/types/btree/test.f.mjs +0 -83
  338. package/out/types/btree/types/module.f.d.mts +0 -14
  339. package/out/types/btree/types/module.f.mjs +0 -50
  340. package/out/types/byte_set/module.f.d.mts +0 -25
  341. package/out/types/byte_set/module.f.mjs +0 -42
  342. package/out/types/byte_set/test.f.d.mts +0 -13
  343. package/out/types/byte_set/test.f.mjs +0 -123
  344. package/out/types/function/compare/module.f.d.mts +0 -23
  345. package/out/types/function/compare/module.f.mjs +0 -22
  346. package/out/types/function/compare/test.f.d.mts +0 -2
  347. package/out/types/function/compare/test.f.mjs +0 -8
  348. package/out/types/function/module.f.d.mts +0 -51
  349. package/out/types/function/module.f.mjs +0 -44
  350. package/out/types/function/operator/module.f.d.mts +0 -60
  351. package/out/types/function/operator/module.f.mjs +0 -60
  352. package/out/types/function/test.f.d.mts +0 -2
  353. package/out/types/function/test.f.mjs +0 -15
  354. package/out/types/list/module.f.d.mts +0 -82
  355. package/out/types/list/module.f.mjs +0 -269
  356. package/out/types/list/test.f.d.mts +0 -38
  357. package/out/types/list/test.f.mjs +0 -401
  358. package/out/types/map/module.f.d.mts +0 -21
  359. package/out/types/map/module.f.mjs +0 -54
  360. package/out/types/map/test.f.d.mts +0 -5
  361. package/out/types/map/test.f.mjs +0 -115
  362. package/out/types/nibble_set/module.f.d.mts +0 -16
  363. package/out/types/nibble_set/module.f.mjs +0 -19
  364. package/out/types/nibble_set/test.f.d.mts +0 -13
  365. package/out/types/nibble_set/test.f.mjs +0 -90
  366. package/out/types/nullable/module.f.d.mts +0 -9
  367. package/out/types/nullable/module.f.mjs +0 -9
  368. package/out/types/nullable/test.f.d.mts +0 -2
  369. package/out/types/nullable/test.f.mjs +0 -12
  370. package/out/types/number/module.f.d.mts +0 -7
  371. package/out/types/number/module.f.mjs +0 -12
  372. package/out/types/number/test.f.d.mts +0 -11
  373. package/out/types/number/test.f.mjs +0 -126
  374. package/out/types/object/module.f.d.mts +0 -22
  375. package/out/types/object/module.f.mjs +0 -27
  376. package/out/types/object/test.f.d.mts +0 -5
  377. package/out/types/object/test.f.mjs +0 -17
  378. package/out/types/range/module.f.d.mts +0 -6
  379. package/out/types/range/module.f.mjs +0 -6
  380. package/out/types/range/test.f.d.mts +0 -2
  381. package/out/types/range/test.f.mjs +0 -18
  382. package/out/types/range_map/module.f.d.mts +0 -19
  383. package/out/types/range_map/module.f.mjs +0 -84
  384. package/out/types/range_map/test.f.d.mts +0 -6
  385. package/out/types/range_map/test.f.mjs +0 -201
  386. package/out/types/result/module.d.mts +0 -7
  387. package/out/types/result/module.f.d.mts +0 -22
  388. package/out/types/result/module.f.mjs +0 -25
  389. package/out/types/result/module.mjs +0 -16
  390. package/out/types/sorted_list/module.f.d.mts +0 -53
  391. package/out/types/sorted_list/module.f.mjs +0 -102
  392. package/out/types/sorted_list/test.f.d.mts +0 -5
  393. package/out/types/sorted_list/test.f.mjs +0 -66
  394. package/out/types/sorted_set/module.f.d.mts +0 -19
  395. package/out/types/sorted_set/module.f.mjs +0 -29
  396. package/out/types/sorted_set/test.f.d.mts +0 -6
  397. package/out/types/sorted_set/test.f.mjs +0 -80
  398. package/out/types/string/module.f.d.mts +0 -9
  399. package/out/types/string/module.f.mjs +0 -17
  400. package/out/types/string/test.f.d.mts +0 -15
  401. package/out/types/string/test.f.mjs +0 -58
  402. package/out/types/string_set/module.f.d.mts +0 -13
  403. package/out/types/string_set/module.f.mjs +0 -29
  404. package/out/types/string_set/test.f.d.mts +0 -5
  405. package/out/types/string_set/test.f.mjs +0 -65
  406. package/text/module.f.mjs +0 -27
  407. package/text/utf16/module.f.mjs +0 -96
  408. package/types/array/module.f.mjs +0 -119
  409. package/types/btree/find/module.f.mjs +0 -125
  410. package/types/btree/types/module.f.mjs +0 -64
  411. package/types/byte_set/module.f.mjs +0 -61
  412. package/types/function/compare/module.f.mjs +0 -29
  413. package/types/function/module.f.mjs +0 -50
  414. package/types/function/operator/module.f.mjs +0 -78
  415. package/types/function/test.f.mjs +0 -17
  416. package/types/list/module.f.mjs +0 -320
  417. package/types/map/module.f.mjs +0 -67
  418. package/types/nibble_set/module.f.mjs +0 -28
  419. package/types/nullable/module.f.mjs +0 -11
  420. package/types/number/module.f.mjs +0 -16
  421. package/types/object/module.f.mjs +0 -33
  422. package/types/range/module.f.mjs +0 -8
  423. package/types/range_map/module.f.mjs +0 -84
  424. package/types/result/module.f.mjs +0 -28
  425. package/types/sorted_list/module.f.mjs +0 -107
  426. package/types/sorted_set/module.f.mjs +0 -38
  427. package/types/string/module.f.mjs +0 -22
  428. package/types/string_set/module.f.mjs +0 -36
@@ -1,28 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- /** @typedef {number} NibbleSet */
3
- /** @typedef {number} Nibble */
4
-
5
- export const empty = 0
6
-
7
- export const universe = 0xFFFF
8
-
9
- /** @type {(n: Nibble) => NibbleSet} */
10
- const one = n => 1 << n
11
-
12
- /** @type {(n: Nibble) => (s: NibbleSet) => boolean} */
13
- export const has = n => s => ((s >> n) & 1) === 1
14
-
15
- /** @type {(n: Nibble) => (s: NibbleSet) => NibbleSet} */
16
- export const set = n => s => s | one(n)
17
-
18
- /** @type {(n: NibbleSet) => NibbleSet} */
19
- export const complement = s => universe ^ s
20
-
21
- /** @type {(n: Nibble) => (s: NibbleSet) => NibbleSet} */
22
- export const unset = n => s => s & complement(one(n))
23
-
24
- /** @type {(r: readonly[number, number]) => NibbleSet} */
25
- const range = ([a, b]) => one(b - a + 1) - 1 << a
26
-
27
- /** @type {(r: readonly[number, number]) => (s: NibbleSet) => NibbleSet} */
28
- export const setRange = r => s => s | range(r)
@@ -1,11 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- /**
3
- * @template T
4
- * @typedef {T|null} Nullable
5
- */
6
-
7
- /** @type {<T, R>(f: (value: T) => R) => (value: Nullable<T>) => Nullable<R>} */
8
- export const map = f => value => value === null ? null : f(value)
9
-
10
- /** @type {<T, R>(f: (_: T) => R) => (none: () => R) => (_: Nullable<T>) => Nullable<R>} */
11
- export const match = f => none => value => value === null ? none() : f(value)
@@ -1,16 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- import * as list from '../list/module.f.mjs'
3
- const { reduce } = list
4
- import * as operator from '../function/operator/module.f.mjs'
5
- const { addition, min: minOp, max: maxOp } = operator
6
- import * as compare from '../function/compare/module.f.mjs'
7
- const { unsafeCmp } = compare
8
-
9
- export const sum = reduce(addition)(0)
10
-
11
- export const min = reduce(minOp)(null)
12
-
13
- export const max = reduce(maxOp)(null)
14
-
15
- /** @type {(a: number) => (b: number) => compare.Sign} */
16
- export const cmp = unsafeCmp
@@ -1,33 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- import * as list from '../list/module.f.mjs'
3
- const { iterable } = list
4
- import * as btMap from '../map/module.f.mjs'
5
- const { entries: mapEntries, fromEntries: mapFromEntries } = btMap
6
- const { getOwnPropertyDescriptor, fromEntries: objectFromEntries } = Object
7
-
8
- /**
9
- * @template T
10
- * @typedef {{
11
- * readonly [k in string]: T
12
- * }} Map
13
- */
14
-
15
- /**
16
- * @template T
17
- * @typedef {readonly[string, T]} Entry
18
- */
19
-
20
- /** @type {(name: string) => <T>(object: Map<T>) => T|null} */
21
- export const at = name => object => {
22
- const r = getOwnPropertyDescriptor(object, name)
23
- return r === void 0 ? null : r.value
24
- }
25
-
26
- /** @type {<T>(e: list.List<Entry<T>>) => list.List<Entry<T>>} */
27
- export const sort = e => mapEntries(mapFromEntries(e))
28
-
29
- /** @type {<T>(e: list.List<Entry<T>>) => Map<T>} */
30
- export const fromEntries = e => objectFromEntries(iterable(e))
31
-
32
- /** @type {<T>(m: btMap.Map<T>) => Map<T>} */
33
- export const fromMap = m => fromEntries(mapEntries(m))
@@ -1,8 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- /** @typedef {readonly[number,number]} Range */
3
-
4
- /** @type {(range: Range) => (i: number) => boolean} */
5
- export const contains = ([b, e]) => i => b <= i && i <= e
6
-
7
- /** @type {(i: number) => Range} */
8
- export const one = a => [a, a]
@@ -1,84 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- import * as sortedList from '../sorted_list/module.f.mjs'
3
- const { genericMerge } = sortedList
4
- import * as list from '../list/module.f.mjs'
5
- const { next } = list
6
- import * as Option from '../nullable/module.f.mjs'
7
- import * as number from '../number/module.f.mjs'
8
- const { cmp } = number
9
- import * as O from '../function/operator/module.f.mjs'
10
- import * as Range from '../range/module.f.mjs'
11
-
12
- /**
13
- * @template T
14
- * @typedef {[T, number]} Entry
15
- */
16
-
17
- /**
18
- * @template T
19
- * @typedef {sortedList.SortedList<Entry<T>>} RangeMap
20
- */
21
-
22
- /**
23
- * @template T
24
- * @typedef {readonly Entry<T>[]} RangeMapArray
25
- */
26
-
27
- /**
28
- * @template T
29
- * @typedef {{
30
- * readonly union: O.Reduce<T>
31
- * readonly equal: O.Equal<T>
32
- * }} Operators
33
- */
34
-
35
- /**
36
- * @template T
37
- * @typedef {Option.Nullable<Entry<T>>} RangeState
38
- */
39
-
40
- /**
41
- * @template T
42
- * @typedef {O.Reduce<RangeMap<T>>} RangeMerge
43
- */
44
-
45
- /** @type {<T>(union: O.Reduce<T>) => (equal: O.Equal<T>) => sortedList.ReduceOp<Entry<T>, RangeState<T>>} */
46
- const reduceOp = union => equal => state => ([aItem, aMax]) => ([bItem, bMax]) => {
47
- const sign = cmp(aMax)(bMax)
48
- const min = sign === 1 ? bMax : aMax
49
- const u = union(aItem)(bItem)
50
- const newState = state !== null && equal(state[0])(u) ? null : state
51
- return [newState, sign, [u, min]]
52
- }
53
-
54
- /** @type {<T>(equal: O.Equal<T>) => sortedList.TailReduce<Entry<T>, RangeState<T>>} */
55
- const tailReduce = equal => state => tail => {
56
- if (state === null) { return tail }
57
- const tailResult = next(tail)
58
- if (tailResult === null) { return [state] }
59
- if (equal(state[0])(tailResult.first[0])) { return tailResult }
60
- return { first: state, tail: tailResult }
61
- }
62
-
63
- /** @type {<T>(op: Operators<T>) => RangeMerge<T>} */
64
- export const merge = ({ union, equal }) => genericMerge({ reduceOp: reduceOp(union)(equal), tailReduce: tailReduce(equal) })(null)
65
-
66
- /** @type {<T>(def: T) => (value: number) => (rm: RangeMapArray<T>) => T} */
67
- export const get = def => value => rm => {
68
- const len = rm.length
69
- let b = 0
70
- let e = len - 1
71
- while (true) {
72
- if (b >= len) { return def }
73
- if (e - b < 0) { return rm[b][0] }
74
- const mid = b + (e - b >> 1)
75
- if (value <= rm[mid][1]) {
76
- e = mid - 1
77
- } else {
78
- b = mid + 1
79
- }
80
- }
81
- }
82
-
83
- /** @type {<T>(def: T) => (r: Range.Range) => (value: T) => RangeMapArray<T>} */
84
- export const fromRange = def => ([a, b]) => v => [[def, a - 1], [v, b]]
@@ -1,28 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- /**
3
- * @template T
4
- * @typedef {readonly['ok', T]} Ok
5
- */
6
-
7
- /**
8
- * @template E
9
- * @typedef {readonly['error', E]} Error
10
- */
11
-
12
- /**
13
- * @template T
14
- * @template E
15
- * @typedef {Ok<T>|Error<E>} Result
16
- */
17
-
18
- /** @type {<T>(value: T) => Ok<T>} */
19
- export const ok = value => ['ok', value]
20
-
21
- /** @type {<E>(e: E) => Error<E>} */
22
- export const error = e => ['error', e]
23
-
24
- /** @type {<T, E>(r: Result<T, E>) => T} */
25
- export const unwrap = ([kind, v]) => {
26
- if (kind === 'error') { throw v }
27
- return v
28
- }
@@ -1,107 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- import * as compare from '../function/compare/module.f.mjs'
3
- import * as list from '../list/module.f.mjs'
4
- import * as option from '../nullable/module.f.mjs'
5
- const { next } = list
6
- import * as f from '../function/module.f.mjs'
7
- const { identity } = f
8
-
9
- /**
10
- * @template T
11
- * @typedef {list.List<T>} SortedList
12
- */
13
-
14
- /**
15
- * @template T
16
- * @typedef {readonly T[]} SortedArray
17
- */
18
-
19
- /**
20
- * @template T
21
- * @typedef {(a: T) => (b: T) => compare.Sign} Cmp
22
- */
23
-
24
- /**
25
- * @template T
26
- * @template S
27
- * @typedef {(state: S) => (a: T) => (b: T) => readonly[option.Nullable<T>, compare.Sign, S]} ReduceOp
28
- */
29
-
30
- /**
31
- * @template T
32
- * @template S
33
- * @typedef {(state: S) => (tail: list.List<T>) => list.List<T>} TailReduce
34
- */
35
-
36
- /**
37
- * @template T
38
- * @template S
39
- * @typedef {{
40
- * readonly reduceOp: ReduceOp<T,S>
41
- * readonly tailReduce: TailReduce<T,S>
42
- * }} MergeReduce
43
- */
44
-
45
- /** @type {<T,S>(reduce: MergeReduce<T,S>) => (state: S) => (a: list.List<T>) => (b: list.List<T>) => list.List<T>} */
46
- export const genericMerge = ({ reduceOp, tailReduce }) => {
47
- /** @typedef {typeof reduceOp extends ReduceOp<infer T, infer S> ? [T, S] : never} TS */
48
- /** @typedef {TS[0]} T */
49
- /** @typedef {TS[1]} S */
50
- /** @type {(state: S) => (a: list.List<T>) => (b: list.List<T>) => list.List<T>} */
51
- const f = state => a => b => () => {
52
- const aResult = next(a)
53
- if (aResult === null) { return tailReduce(state)(b) }
54
- const bResult = next(b)
55
- if (bResult === null) { return tailReduce(state)(aResult) }
56
- const [first, sign, stateNext] = reduceOp(state)(aResult.first)(bResult.first)
57
- const aNext = sign === 1 ? a : aResult.tail
58
- const bNext = sign === -1 ? b : bResult.tail
59
- const tail = f(stateNext)(aNext)(bNext)
60
- return first === null ? tail : { first, tail }
61
- }
62
- return f
63
- }
64
-
65
- /**
66
- * @template T
67
- * @typedef {ReduceOp<T, null>} CmpReduceOp
68
- */
69
-
70
- /** @type {<T>(cmp: Cmp<T>) => (a: SortedList<T>) => (b: SortedList<T>) => SortedList<T>} */
71
- export const merge = cmp => {
72
- /** @typedef {typeof cmp extends Cmp<infer T> ? T : never} T*/
73
- /** @type {TailReduce<T, null>} */
74
- const tailReduce = mergeTail
75
- return genericMerge({ reduceOp: cmpReduce(cmp), tailReduce })(null)
76
- }
77
-
78
- /** @type {<T>(cmp: Cmp<T>) => CmpReduceOp<T>} */
79
- const cmpReduce = cmp => () => a => b => {
80
- const sign = cmp(a)(b)
81
- return [sign === 1 ? b : a, sign, null]
82
- }
83
-
84
- /** @type {() => <T>(tail: list.List<T>) => list.List<T>} */
85
- const mergeTail = () => identity
86
-
87
- /** @type {<T>(cmp: Cmp<T>) => (value: T) => (array: SortedArray<T>) => T|null} */
88
- export const find = cmp => value => array => {
89
- let b = 0
90
- let e = array.length - 1
91
- while (true) {
92
- if (e - b < 0) return null
93
- const mid = b + (e - b >> 1)
94
- const sign = cmp(value)(array[mid])
95
- switch(sign) {
96
- case -1: {
97
- e = mid - 1
98
- break
99
- }
100
- case 0: { return value }
101
- case 1: {
102
- b = mid + 1
103
- break
104
- }
105
- }
106
- }
107
- }
@@ -1,38 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- import * as Compare from '../function/compare/module.f.mjs'
3
- import * as list from "../list/module.f.mjs"
4
- const { toArray } = list
5
- import * as sortedList from '../sorted_list/module.f.mjs'
6
- const { merge, genericMerge, find } = sortedList
7
-
8
- /**
9
- * @template T
10
- * @typedef {readonly T[]} SortedSet
11
- */
12
-
13
- /**
14
- * @template T
15
- * @typedef {(a: T) => (b: T) => Compare.Sign} Cmp
16
- */
17
-
18
- /** @typedef {number} Byte */
19
-
20
- /** @type {<T>(cmp: Cmp<T>) => (a: SortedSet<T>) => (b: SortedSet<T>) => SortedSet<T>} */
21
- export const union = cmp => a => b => toArray(merge(cmp)(a)(b))
22
-
23
- /** @type {<T>(cmp: Cmp<T>) => (a: SortedSet<T>) => (b: SortedSet<T>) => SortedSet<T>} */
24
- export const intersect = cmp => a => b => toArray(intersectMerge(cmp)(a)(b))
25
-
26
- const tailReduce = () => () => null
27
-
28
- /** @type {<T>(cmp: Cmp<T>) => (a: sortedList.SortedList<T>) => (b: sortedList.SortedList<T>) => sortedList.SortedList<T>} */
29
- const intersectMerge = cmp => genericMerge({ reduceOp: intersectReduce(cmp), tailReduce })(null)
30
-
31
- /** @type {<T,S>(cmp: Cmp<T>) => sortedList.ReduceOp<T,S>} */
32
- const intersectReduce = cmp => state => a => b => {
33
- const sign = cmp(a)(b)
34
- return [sign === 0 ? a : null, sign, state]
35
- }
36
-
37
- /** @type {<T>(cmp: Cmp<T>) => (value: T) => (set: SortedSet<T>) => boolean} */
38
- export const has = cmp => value => set => find(cmp)(value)(set) === value
@@ -1,22 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- import * as list from '../list/module.f.mjs'
3
- const { reduce: listReduce, repeat: listRepeat } = list
4
- import * as f from '../function/module.f.mjs'
5
- const { compose } = f
6
- import * as compare from '../function/compare/module.f.mjs'
7
- const { unsafeCmp } = compare
8
- import * as op from '../function/operator/module.f.mjs'
9
- const { join: joinOp, concat: concatOp } = op
10
-
11
- /** @type {(o: op.Reduce<string>) => (input: list.List<string>) => string} */
12
- const reduce = o => listReduce(o)('')
13
-
14
- export const join = compose(joinOp)(reduce)
15
-
16
- export const concat = reduce(concatOp)
17
-
18
- /** @type {(n: string) => (v: number) => string} */
19
- export const repeat = v => compose(listRepeat(v))(concat)
20
-
21
- /** @type {(a: string) => (b: string) => compare.Sign} */
22
- export const cmp = unsafeCmp
@@ -1,36 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- import * as BtreeTypes from '../btree/types/module.f.mjs'
3
- import * as btree from '../btree/module.f.mjs'
4
- import * as btf from '../btree/find/module.f.mjs'
5
- const { find, isFound } = btf
6
- import * as btr from '../btree/remove/module.f.mjs'
7
- const { remove: btreeRemove } = btr
8
- import * as bts from '../btree/set/module.f.mjs'
9
- const { set: btreeSet } = bts
10
- export const {
11
- /** @type {(s: StringSet) => list.List<string>} */
12
- values,
13
- empty,
14
- } = btree
15
- import * as string from "../string/module.f.mjs"
16
- const { cmp } = string
17
- import * as list from '../list/module.f.mjs'
18
- const { fold } = list
19
- import * as f from '../function/module.f.mjs'
20
- const { compose } = f
21
-
22
- /** @typedef {BtreeTypes.Tree<string>} StringSet */
23
-
24
- /** @type {(value: string) => (set: StringSet) => boolean} */
25
- export const contains = value => {
26
- const f = find(cmp(value))
27
- return s => s !== null && isFound(f(s).first)
28
- }
29
-
30
- /** @type {(value: string) => (s: StringSet) => StringSet} */
31
- export const set = value => btreeSet(cmp(value))(() => value)
32
-
33
- export const fromValues = fold(set)(null)
34
-
35
- /** @type {(value: string) => (s: StringSet) => StringSet} */
36
- export const remove = compose(cmp)(btreeRemove)