functionalscript 0.2.6 → 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 (428) hide show
  1. package/.github/workflows/ci.yml +19 -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} +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/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,114 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- import * as _ from '../types/module.f.mjs';
3
- import * as btreeFind from '../find/module.f.mjs';
4
- const { find } = btreeFind;
5
- import * as Cmp from '../../function/compare/module.f.mjs';
6
- import * as list from '../../list/module.f.mjs';
7
- const { fold } = list;
8
- /**
9
- * @template T
10
- * @typedef {_.Branch1<T> | _.Branch3<T>} Branch1To3
11
- */
12
- /** @type {<T>(b: _.Branch5<T> | _.Branch7<T>) => Branch1To3<T>} */
13
- const b57 = b => b.length === 5 ? [b] : [[b[0], b[1], b[2]], b[3], [b[4], b[5], b[6]]];
14
- /** @type {<T>(i: btreeFind.PathItem<T>) => (a: Branch1To3<T>) => Branch1To3<T>} */
15
- const reduceOp = ([i, x]) => a => {
16
- switch (i) {
17
- case 0: {
18
- switch (x.length) {
19
- case 3: {
20
- return [[...a, x[1], x[2]]];
21
- }
22
- case 5: {
23
- return b57([...a, x[1], x[2], x[3], x[4]]);
24
- }
25
- }
26
- }
27
- case 2: {
28
- switch (x.length) {
29
- case 3: {
30
- return [[x[0], x[1], ...a]];
31
- }
32
- case 5: {
33
- return b57([x[0], x[1], ...a, x[3], x[4]]);
34
- }
35
- }
36
- }
37
- case 4: {
38
- return b57([x[0], x[1], x[2], x[3], ...a]);
39
- }
40
- }
41
- };
42
- const reduceBranch = fold(reduceOp);
43
- /** @type {<T>(c: Cmp.Compare<T>) => (g: (value: T | null) => T) => (node: _.Node<T>) => _.Node<T>} */
44
- const nodeSet = c => g => node => {
45
- const { first, tail } = find(c)(node);
46
- const [i, x] = first;
47
- /** @typedef {typeof c extends Cmp.Compare<infer T> ? T : never} T */
48
- /** @type {() => Branch1To3<T>} */
49
- const f = () => {
50
- switch (i) {
51
- case 0: {
52
- // insert
53
- const value = g(null);
54
- switch (x.length) {
55
- case 1: {
56
- return [[value, x[0]]];
57
- }
58
- case 2: {
59
- return [[value], x[0], [x[1]]];
60
- }
61
- }
62
- }
63
- case 1: {
64
- // replace
65
- switch (x.length) {
66
- case 1: {
67
- return [[g(x[0])]];
68
- }
69
- case 2: {
70
- return [[g(x[0]), x[1]]];
71
- }
72
- case 3: {
73
- return [[x[0], g(x[1]), x[2]]];
74
- }
75
- case 5: {
76
- return [[x[0], g(x[1]), x[2], x[3], x[4]]];
77
- }
78
- }
79
- }
80
- case 2: {
81
- // insert
82
- const value = g(null);
83
- switch (x.length) {
84
- case 1: {
85
- return [[x[0], value]];
86
- }
87
- case 2: {
88
- return [[x[0]], value, [x[1]]];
89
- }
90
- }
91
- }
92
- case 3: {
93
- // replace
94
- switch (x.length) {
95
- case 2: {
96
- return [[x[0], g(x[1])]];
97
- }
98
- case 5: {
99
- return [[x[0], x[1], x[2], g(x[3]), x[4]]];
100
- }
101
- }
102
- }
103
- case 4: {
104
- // insert
105
- const [v0, v1] = x;
106
- return [[v0], v1, [g(null)]];
107
- }
108
- }
109
- };
110
- const r = reduceBranch(f())(tail);
111
- return r.length === 1 ? r[0] : r;
112
- };
113
- /** @type {<T>(c: Cmp.Compare<T>) => (f: (value: T|null) => T) => (tree: _.Tree<T>) => _.Node<T>} */
114
- export const set = c => f => tree => tree === null ? [f(null)] : nodeSet(c)(f)(tree);
@@ -1,2 +0,0 @@
1
- export default test;
2
- declare const test: (() => void)[];
@@ -1,390 +0,0 @@
1
- import * as _ from './module.f.mjs';
2
- import * as BTree from '../types/module.f.mjs';
3
- import * as s from '../../string/module.f.mjs';
4
- const { cmp } = s;
5
- import * as json from '../../../json/module.f.mjs';
6
- import * as o from '../../object/module.f.mjs';
7
- const { sort } = o;
8
- /** @type {(node: BTree.Node<string>) => (value: string) => BTree.Node<string>} */
9
- const set = node => value => _.set(cmp(value))(() => value)(node);
10
- const jsonStr = json.stringify(sort);
11
- const test = [
12
- () => {
13
- /** @type {BTree.Node<string>} */
14
- let _map = ['1'];
15
- for (let i = 2; i <= 10; i++)
16
- _map = set(_map)((i * i).toString());
17
- const r = jsonStr(_map);
18
- if (r !== '[[["1","100"],"16",["25","36"]],"4",[["49"],"64",["81","9"]]]') {
19
- throw r;
20
- }
21
- },
22
- () => {
23
- /** @type {BTree.Node<string>} */
24
- let _map = ['1'];
25
- for (let i = 2; i <= 11; i++)
26
- _map = set(_map)((i * i).toString());
27
- const r = jsonStr(_map);
28
- if (r !== '[[["1"],"100",["121"],"16",["25","36"]],"4",[["49"],"64",["81","9"]]]') {
29
- throw r;
30
- }
31
- },
32
- () => {
33
- /** @type {BTree.Node<string>} */
34
- let _map = ['1'];
35
- for (let i = 2; i <= 12; i++)
36
- _map = set(_map)((i * i).toString());
37
- const r = jsonStr(_map);
38
- if (r !== '[[["1"],"100",["121","144"],"16",["25","36"]],"4",[["49"],"64",["81","9"]]]') {
39
- throw r;
40
- }
41
- },
42
- () => {
43
- /** @type {BTree.Node<string>} */
44
- let _map = ['1'];
45
- for (let i = 2; i <= 13; i++)
46
- _map = set(_map)((i * i).toString());
47
- const r = jsonStr(_map);
48
- if (r !== '[[["1"],"100",["121","144"]],"16",[["169"],"25",["36"]],"4",[["49"],"64",["81","9"]]]') {
49
- throw r;
50
- }
51
- },
52
- () => {
53
- /** @type {BTree.Node<string>} */
54
- let _map = ['1'];
55
- for (let i = 2; i <= 14; i++)
56
- _map = set(_map)((i * i).toString());
57
- const r = jsonStr(_map);
58
- if (r !== '[[["1"],"100",["121","144"]],"16",[["169","196"],"25",["36"]],"4",[["49"],"64",["81","9"]]]') {
59
- throw r;
60
- }
61
- },
62
- () => {
63
- /** @type {BTree.Node<string>} */
64
- let _map = ['1'];
65
- for (let i = 2; i <= 15; i++)
66
- _map = set(_map)((i * i).toString());
67
- const r = jsonStr(_map);
68
- if (r !== '[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"],"25",["36"]],"4",[["49"],"64",["81","9"]]]') {
69
- throw r;
70
- }
71
- },
72
- () => {
73
- /** @type {BTree.Node<string>} */
74
- let _map = ['1'];
75
- for (let i = 2; i <= 16; i++)
76
- _map = set(_map)((i * i).toString());
77
- const r = jsonStr(_map);
78
- if (r !== '[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"],"25",["256","36"]],"4",[["49"],"64",["81","9"]]]') {
79
- throw r;
80
- }
81
- },
82
- () => {
83
- /** @type {BTree.Node<string>} */
84
- let _map = ['1'];
85
- for (let i = 2; i <= 17; i++)
86
- _map = set(_map)((i * i).toString());
87
- const r = jsonStr(_map);
88
- if (r !== '[[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"]]],"25",[[["256"],"289",["36"]],"4",[["49"],"64",["81","9"]]]]') {
89
- throw r;
90
- }
91
- },
92
- () => {
93
- /** @type {BTree.Node<string>} */
94
- let _map = ['1'];
95
- for (let i = 2; i <= 18; i++)
96
- _map = set(_map)((i * i).toString());
97
- const r = jsonStr(_map);
98
- if (r !==
99
- '[[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"]]],"25",[[["256"],"289",["324","36"]],"4",[["49"],"64",["81","9"]]]]') {
100
- throw r;
101
- }
102
- },
103
- () => {
104
- /** @type {BTree.Node<string>} */
105
- let _map = ['1'];
106
- for (let i = 2; i <= 19; i++)
107
- _map = set(_map)((i * i).toString());
108
- const r = jsonStr(_map);
109
- if (r !==
110
- '[[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"]]],"25",[[["256"],"289",["324"],"36",["361"]],"4",[["49"],"64",["81","9"]]]]') {
111
- throw r;
112
- }
113
- },
114
- () => {
115
- /** @type {BTree.Node<string>} */
116
- let _map = ['1'];
117
- for (let i = 2; i <= 20; i++)
118
- _map = set(_map)((i * i).toString());
119
- const r = jsonStr(_map);
120
- if (r !==
121
- '[[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"]]],' +
122
- '"25",' +
123
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400","49"],"64",["81","9"]]]]') {
124
- throw r;
125
- }
126
- },
127
- () => {
128
- /** @type {BTree.Node<string>} */
129
- let _map = ['1'];
130
- for (let i = 2; i <= 21; i++)
131
- _map = set(_map)((i * i).toString());
132
- const r = jsonStr(_map);
133
- if (r !==
134
- '[[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"]]],' +
135
- '"25",' +
136
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["49"],"64",["81","9"]]]]') {
137
- throw r;
138
- }
139
- },
140
- () => {
141
- /** @type {BTree.Node<string>} */
142
- let _map = ['1'];
143
- for (let i = 2; i <= 22; i++)
144
- _map = set(_map)((i * i).toString());
145
- const r = jsonStr(_map);
146
- if (r !==
147
- '[[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"]]],' +
148
- '"25",' +
149
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484","49"],"64",["81","9"]]]]') {
150
- throw r;
151
- }
152
- },
153
- () => {
154
- /** @type {BTree.Node<string>} */
155
- let _map = ['1'];
156
- for (let i = 2; i <= 23; i++)
157
- _map = set(_map)((i * i).toString());
158
- const r = jsonStr(_map);
159
- if (r !==
160
- '[[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"]]],' +
161
- '"25",' +
162
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]],"49",[["529"],"64",["81","9"]]]]') {
163
- throw r;
164
- }
165
- },
166
- () => {
167
- /** @type {BTree.Node<string>} */
168
- let _map = ['1'];
169
- for (let i = 2; i <= 24; i++)
170
- _map = set(_map)((i * i).toString());
171
- const r = jsonStr(_map);
172
- if (r !==
173
- '[[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"]]],' +
174
- '"25",' +
175
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]],"49",[["529","576"],"64",["81","9"]]]]') {
176
- throw r;
177
- }
178
- },
179
- () => {
180
- /** @type {BTree.Node<string>} */
181
- let _map = ['1'];
182
- for (let i = 2; i <= 25; i++)
183
- _map = set(_map)((i * i).toString());
184
- const r = jsonStr(_map);
185
- if (r !==
186
- '[[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"]]],' +
187
- '"25",' +
188
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]],"49",[["529"],"576",["625"],"64",["81","9"]]]]') {
189
- throw r;
190
- }
191
- },
192
- () => {
193
- /** @type {BTree.Node<string>} */
194
- let _map = ['1'];
195
- for (let i = 2; i <= 26; i++)
196
- _map = set(_map)((i * i).toString());
197
- const r = jsonStr(_map);
198
- if (r !==
199
- '[[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"]]],' +
200
- '"25",' +
201
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]]],' +
202
- '"49",' +
203
- '[[["529"],"576",["625"]],"64",[["676"],"81",["9"]]]]') {
204
- throw r;
205
- }
206
- },
207
- () => {
208
- /** @type {BTree.Node<string>} */
209
- let _map = ['1'];
210
- for (let i = 2; i <= 27; i++)
211
- _map = set(_map)((i * i).toString());
212
- const r = jsonStr(_map);
213
- if (r !==
214
- '[[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"]]],' +
215
- '"25",' +
216
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]]],' +
217
- '"49",' +
218
- '[[["529"],"576",["625"]],"64",[["676","729"],"81",["9"]]]]') {
219
- throw r;
220
- }
221
- },
222
- () => {
223
- /** @type {BTree.Node<string>} */
224
- let _map = ['1'];
225
- for (let i = 2; i <= 28; i++)
226
- _map = set(_map)((i * i).toString());
227
- const r = jsonStr(_map);
228
- if (r !==
229
- '[[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"]]],' +
230
- '"25",' +
231
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]]],' +
232
- '"49",' +
233
- '[[["529"],"576",["625"]],"64",[["676"],"729",["784"],"81",["9"]]]]') {
234
- throw r;
235
- }
236
- },
237
- () => {
238
- /** @type {BTree.Node<string>} */
239
- let _map = ['1'];
240
- for (let i = 2; i <= 29; i++)
241
- _map = set(_map)((i * i).toString());
242
- const r = jsonStr(_map);
243
- if (r !==
244
- '[[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"]]],' +
245
- '"25",' +
246
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]]],' +
247
- '"49",' +
248
- '[[["529"],"576",["625"]],"64",[["676"],"729",["784"],"81",["841","9"]]]]') {
249
- throw r;
250
- }
251
- },
252
- () => {
253
- /** @type {BTree.Node<string>} */
254
- let _map = ['1'];
255
- for (let i = 2; i <= 30; i++)
256
- _map = set(_map)((i * i).toString());
257
- const r = jsonStr(_map);
258
- if (r !==
259
- '[[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"]]],' +
260
- '"25",' +
261
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]]],' +
262
- '"49",' +
263
- '[[["529"],"576",["625"]],"64",[["676"],"729",["784"]],"81",[["841"],"9",["900"]]]]') {
264
- throw r;
265
- }
266
- },
267
- () => {
268
- /** @type {BTree.Node<string>} */
269
- let _map = ['1'];
270
- for (let i = 2; i <= 31; i++)
271
- _map = set(_map)((i * i).toString());
272
- const r = jsonStr(_map);
273
- if (r !==
274
- '[[[["1"],"100",["121","144"]],"16",[["169"],"196",["225"]]],' +
275
- '"25",' +
276
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]]],' +
277
- '"49",' +
278
- '[[["529"],"576",["625"]],"64",[["676"],"729",["784"]],"81",[["841"],"9",["900","961"]]]]') {
279
- throw r;
280
- }
281
- },
282
- () => {
283
- /** @type {BTree.Node<string>} */
284
- let _map = ['1'];
285
- for (let i = 2; i <= 32; i++)
286
- _map = set(_map)((i * i).toString());
287
- const r = jsonStr(_map);
288
- if (r !==
289
- '[[[["1"],"100",["1024"],"121",["144"]],"16",[["169"],"196",["225"]]],' +
290
- '"25",' +
291
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]]],' +
292
- '"49",' +
293
- '[[["529"],"576",["625"]],"64",[["676"],"729",["784"]],"81",[["841"],"9",["900","961"]]]]') {
294
- throw r;
295
- }
296
- },
297
- () => {
298
- /** @type {BTree.Node<string>} */
299
- let _map = ['1'];
300
- for (let i = 2; i <= 33; i++)
301
- _map = set(_map)((i * i).toString());
302
- const r = jsonStr(_map);
303
- if (r !==
304
- '[[[["1"],"100",["1024","1089"],"121",["144"]],"16",[["169"],"196",["225"]]],' +
305
- '"25",' +
306
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]]],' +
307
- '"49",' +
308
- '[[["529"],"576",["625"]],"64",[["676"],"729",["784"]],"81",[["841"],"9",["900","961"]]]]') {
309
- throw r;
310
- }
311
- },
312
- () => {
313
- /** @type {BTree.Node<string>} */
314
- let _map = ['1'];
315
- for (let i = 2; i <= 34; i++)
316
- _map = set(_map)((i * i).toString());
317
- const r = jsonStr(_map);
318
- if (r !==
319
- '[[[["1"],"100",["1024"]],"1089",[["1156"],"121",["144"]],"16",[["169"],"196",["225"]]],' +
320
- '"25",' +
321
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]]],' +
322
- '"49",' +
323
- '[[["529"],"576",["625"]],"64",[["676"],"729",["784"]],"81",[["841"],"9",["900","961"]]]]') {
324
- throw r;
325
- }
326
- },
327
- () => {
328
- /** @type {BTree.Node<string>} */
329
- let _map = ['1'];
330
- for (let i = 2; i <= 35; i++)
331
- _map = set(_map)((i * i).toString());
332
- const r = jsonStr(_map);
333
- if (r !==
334
- '[[[["1"],"100",["1024"]],"1089",[["1156"],"121",["1225","144"]],"16",[["169"],"196",["225"]]],' +
335
- '"25",' +
336
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]]],' +
337
- '"49",' +
338
- '[[["529"],"576",["625"]],"64",[["676"],"729",["784"]],"81",[["841"],"9",["900","961"]]]]') {
339
- throw r;
340
- }
341
- },
342
- () => {
343
- /** @type {BTree.Node<string>} */
344
- let _map = ['1'];
345
- for (let i = 2; i <= 36; i++)
346
- _map = set(_map)((i * i).toString());
347
- const r = jsonStr(_map);
348
- if (r !==
349
- '[[[["1"],"100",["1024"]],"1089",[["1156"],"121",["1225"],"1296",["144"]],"16",[["169"],"196",["225"]]],' +
350
- '"25",' +
351
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]]],' +
352
- '"49",' +
353
- '[[["529"],"576",["625"]],"64",[["676"],"729",["784"]],"81",[["841"],"9",["900","961"]]]]') {
354
- throw r;
355
- }
356
- },
357
- () => {
358
- /** @type {BTree.Node<string>} */
359
- let _map = ['1'];
360
- for (let i = 2; i <= 37; i++)
361
- _map = set(_map)((i * i).toString());
362
- const r = jsonStr(_map);
363
- if (r !==
364
- '[[[["1"],"100",["1024"]],"1089",[["1156"],"121",["1225"],"1296",["1369","144"]],"16",[["169"],"196",["225"]]],' +
365
- '"25",' +
366
- '[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]]],' +
367
- '"49",' +
368
- '[[["529"],"576",["625"]],"64",[["676"],"729",["784"]],"81",[["841"],"9",["900","961"]]]]') {
369
- throw r;
370
- }
371
- },
372
- () => {
373
- /** @type {BTree.Node<string>} */
374
- let _map = ['1'];
375
- for (let i = 2; i <= 38; i++)
376
- _map = set(_map)((i * i).toString());
377
- const r = jsonStr(_map);
378
- if (r !==
379
- '[[[[["1"],"100",["1024"]],"1089",[["1156"],"121",["1225"]]],' +
380
- '"1296",' +
381
- '[[["1369"],"144",["1444"]],"16",[["169"],"196",["225"]]]],' +
382
- '"25",' +
383
- '[[[["256"],"289",["324"],"36",["361"]],"4",[["400"],"441",["484"]]],' +
384
- '"49",' +
385
- '[[["529"],"576",["625"]],"64",[["676"],"729",["784"]],"81",[["841"],"9",["900","961"]]]]]') {
386
- throw r;
387
- }
388
- }
389
- ];
390
- export default test;
@@ -1,13 +0,0 @@
1
- declare namespace _default {
2
- export { valueTest1 };
3
- export { valuesTest2 };
4
- export { findTrue };
5
- export { find };
6
- export { test };
7
- }
8
- export default _default;
9
- declare function valueTest1(): void;
10
- declare function valuesTest2(): void;
11
- declare function findTrue(): void;
12
- declare function find(): void;
13
- declare function test(): void;
@@ -1,83 +0,0 @@
1
- import * as BTree from './types/module.f.mjs';
2
- import * as _ from './module.f.mjs';
3
- const { values } = _;
4
- import * as json from '../../json/module.f.mjs';
5
- import * as o from '../object/module.f.mjs';
6
- const { sort } = o;
7
- import * as str from '../string/module.f.mjs';
8
- const { cmp } = str;
9
- import * as list from '../list/module.f.mjs';
10
- import * as s from './set/module.f.mjs';
11
- import * as f from './find/module.f.mjs';
12
- const jsonStr = json.stringify(sort);
13
- /** @type {(sequence: list.List<json.Unknown>) => string} */
14
- const stringify = sequence => jsonStr(list.toArray(sequence));
15
- /** @type {(node: BTree.Node<string>) => (value: string) => BTree.Node<string>} */
16
- const set = node => value => s.set(cmp(value))(() => value)(node);
17
- const valueTest1 = () => {
18
- /** @type {BTree.Node<string>} */
19
- let _map = ['a'];
20
- _map = set(_map)('b');
21
- _map = set(_map)('c');
22
- _map = set(_map)('d');
23
- _map = set(_map)('e');
24
- _map = set(_map)('f');
25
- let result = stringify(values(_map));
26
- if (result !== '["a","b","c","d","e","f"]') {
27
- throw result;
28
- }
29
- };
30
- const valuesTest2 = () => {
31
- /** @type {BTree.Node<string>} */
32
- let _map = ['1'];
33
- for (let i = 2; i <= 10; i++)
34
- _map = set(_map)((i * i).toString());
35
- let result = stringify(values(_map));
36
- if (result !== '["1","100","16","25","36","4","49","64","81","9"]') {
37
- throw result;
38
- }
39
- };
40
- const findTrue = () => {
41
- /** @type {BTree.Node<string>} */
42
- let _map = ['a'];
43
- _map = set(_map)('b');
44
- _map = set(_map)('c');
45
- const result = f.value(f.find(cmp('b'))(_map).first);
46
- if (result !== 'b') {
47
- throw result;
48
- }
49
- };
50
- const find = () => {
51
- /** @type {BTree.Node<string>} */
52
- let _map = ['a'];
53
- _map = set(_map)('b');
54
- _map = set(_map)('c');
55
- const result = f.value(f.find(cmp('e'))(_map).first);
56
- if (result !== null) {
57
- throw result;
58
- }
59
- };
60
- const test = () => {
61
- /** @type {BTree.Node<string>} */
62
- let _map = ['a'];
63
- _map = set(_map)('b');
64
- _map = set(_map)('c');
65
- _map = set(_map)('d');
66
- _map = set(_map)('e');
67
- _map = set(_map)('f');
68
- //
69
- {
70
- /** @type {list.Result<string>} */
71
- let _item = list.next(values(_map));
72
- while (_item !== null) {
73
- _item = list.next(_item.tail);
74
- }
75
- }
76
- };
77
- export default {
78
- valueTest1,
79
- valuesTest2,
80
- findTrue,
81
- find,
82
- test,
83
- };
@@ -1,14 +0,0 @@
1
- export type Array1<T> = readonly [T];
2
- export type Array2<T> = readonly [T, T];
3
- export type Array3<T> = readonly [T, T, T];
4
- export type Index2 = 0 | 1;
5
- export type Index3 = 0 | 1 | 2;
6
- export type Index5 = 0 | 1 | 2 | 3 | 4;
7
- export type Leaf1<T> = Array1<T>;
8
- export type Leaf2<T> = Array2<T>;
9
- export type Branch3<T> = readonly [Node<T>, T, Node<T>];
10
- export type Branch5<T> = readonly [Node<T>, T, Node<T>, T, Node<T>];
11
- export type Node<T> = Leaf1<T> | Leaf2<T> | Branch3<T> | Branch5<T>;
12
- export type Tree<T> = Node<T> | null;
13
- export type Branch1<T> = readonly [Node<T>];
14
- export type Branch7<T> = readonly [...Branch5<T>, T, Node<T>];
@@ -1,50 +0,0 @@
1
- // @ts-self-types="./module.f.d.mts"
2
- export {};
3
- /**
4
- * @template T
5
- * @typedef {readonly[T]} Array1
6
- */
7
- /**
8
- * @template T
9
- * @typedef {readonly[T,T]} Array2
10
- */
11
- /**
12
- * @template T
13
- * @typedef {readonly[T,T,T]} Array3
14
- */
15
- /** @typedef {0|1} Index2 */
16
- /** @typedef {0|1|2} Index3 */
17
- /** @typedef {0|1|2|3|4} Index5 */
18
- //
19
- /**
20
- * @template T
21
- * @typedef {Array1<T>} Leaf1
22
- */
23
- /**
24
- * @template T
25
- * @typedef {Array2<T>} Leaf2
26
- */
27
- /**
28
- * @template T
29
- * @typedef {readonly [Node<T>, T, Node<T>]} Branch3
30
- */
31
- /**
32
- * @template T
33
- * @typedef {readonly [Node<T>, T, Node<T>, T, Node<T>]} Branch5
34
- */
35
- /**
36
- * @template T
37
- * @typedef { Leaf1<T> | Leaf2<T> | Branch3<T> | Branch5<T>} Node
38
- */
39
- /**
40
- * @template T
41
- * @typedef {Node<T> | null} Tree
42
- */
43
- /**
44
- * @template T
45
- * @typedef {readonly[Node<T>]} Branch1
46
- */
47
- /**
48
- * @template T
49
- * @typedef { readonly[...Branch5<T>, T, Node<T>] } Branch7
50
- */