functionalscript 0.3.4 → 0.3.5

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 (457) hide show
  1. package/com/cpp/module.f.d.ts +10 -0
  2. package/com/cpp/module.f.js +107 -0
  3. package/com/cpp/test.f.d.ts +2 -0
  4. package/com/cpp/{test.f.ts → test.f.js} +9 -11
  5. package/com/cpp/testlib.f.d.ts +2 -0
  6. package/com/cpp/testlib.f.js +5 -0
  7. package/com/cs/module.f.d.ts +12 -0
  8. package/com/cs/module.f.js +80 -0
  9. package/com/cs/test.f.d.ts +2 -0
  10. package/com/cs/{test.f.ts → test.f.js} +9 -11
  11. package/com/cs/testlib.f.d.ts +2 -0
  12. package/com/cs/testlib.f.js +5 -0
  13. package/com/rust/module.f.d.ts +15 -0
  14. package/com/rust/module.f.js +169 -0
  15. package/com/rust/test.f.d.ts +2 -0
  16. package/com/rust/{test.f.ts → test.f.js} +7 -7
  17. package/com/rust/testlib.f.d.ts +2 -0
  18. package/com/rust/testlib.f.js +5 -0
  19. package/com/test/build.f.d.ts +20 -0
  20. package/com/test/build.f.js +58 -0
  21. package/com/types/module.f.d.ts +28 -0
  22. package/com/types/module.f.js +8 -0
  23. package/com/types/testlib.f.d.ts +44 -0
  24. package/com/types/{testlib.f.ts → testlib.f.js} +2 -3
  25. package/commonjs/build/module.f.d.ts +6 -0
  26. package/commonjs/build/module.f.js +69 -0
  27. package/commonjs/build/test.f.d.ts +2 -0
  28. package/commonjs/build/test.f.js +96 -0
  29. package/commonjs/module/function/{module.f.ts → module.f.d.ts} +5 -10
  30. package/commonjs/module/function/module.f.js +4 -0
  31. package/commonjs/module/module.f.d.ts +18 -0
  32. package/commonjs/module/module.f.js +12 -0
  33. package/commonjs/module.f.d.ts +6 -0
  34. package/commonjs/module.f.js +1 -0
  35. package/commonjs/package/dependencies/module.f.d.ts +7 -0
  36. package/commonjs/package/dependencies/module.f.js +13 -0
  37. package/commonjs/package/dependencies/test.f.d.ts +2 -0
  38. package/commonjs/package/dependencies/test.f.js +15 -0
  39. package/commonjs/package/module.f.d.ts +17 -0
  40. package/commonjs/package/module.f.js +18 -0
  41. package/commonjs/package/test.f.d.ts +2 -0
  42. package/commonjs/package/test.f.js +27 -0
  43. package/commonjs/path/module.f.d.ts +24 -0
  44. package/commonjs/path/module.f.js +114 -0
  45. package/commonjs/path/test.f.d.ts +25 -0
  46. package/commonjs/path/{test.f.ts → test.f.js} +123 -89
  47. package/crypto/prime_field/module.f.d.ts +43 -0
  48. package/crypto/prime_field/module.f.js +78 -0
  49. package/crypto/prime_field/test.f.d.ts +13 -0
  50. package/crypto/prime_field/test.f.js +149 -0
  51. package/crypto/secp/module.f.d.ts +68 -0
  52. package/crypto/secp/module.f.js +127 -0
  53. package/crypto/secp/test.f.d.ts +5 -0
  54. package/crypto/secp/test.f.js +72 -0
  55. package/crypto/sha2/module.f.d.ts +13 -0
  56. package/crypto/sha2/module.f.js +145 -0
  57. package/crypto/sha2/test.f.d.ts +9 -0
  58. package/crypto/sha2/test.f.js +82 -0
  59. package/dev/module.f.d.ts +1 -0
  60. package/dev/module.f.js +1 -0
  61. package/dev/test/module.f.d.ts +20 -0
  62. package/dev/test/module.f.js +75 -0
  63. package/dev/test.f.d.ts +9 -0
  64. package/dev/{test.f.ts → test.f.js} +22 -24
  65. package/djs/module.f.d.ts +17 -0
  66. package/djs/module.f.js +63 -0
  67. package/djs/parser/module.f.d.ts +12 -0
  68. package/djs/parser/module.f.js +333 -0
  69. package/djs/parser/test.f.d.ts +12 -0
  70. package/djs/parser/test.f.js +717 -0
  71. package/djs/serializer/module.f.d.ts +9 -0
  72. package/djs/serializer/module.f.js +81 -0
  73. package/djs/test/input.f.d.ts +2 -0
  74. package/djs/test/input.f.js +4 -0
  75. package/djs/test/m.f.d.ts +2 -0
  76. package/djs/test/m.f.js +1 -0
  77. package/djs/test.f.d.ts +12 -0
  78. package/djs/test.f.js +84 -0
  79. package/djs/tokenizer/module.f.d.ts +8 -0
  80. package/djs/tokenizer/module.f.js +60 -0
  81. package/djs/tokenizer/test.f.d.ts +7 -0
  82. package/djs/tokenizer/test.f.js +529 -0
  83. package/fsc/module.f.d.ts +5 -0
  84. package/fsc/module.f.js +75 -0
  85. package/fsc/test.f.d.ts +4 -0
  86. package/fsc/test.f.js +19 -0
  87. package/fsm/module.f.d.ts +13 -0
  88. package/fsm/module.f.js +59 -0
  89. package/fsm/test.f.d.ts +5 -0
  90. package/fsm/test.f.js +137 -0
  91. package/html/module.f.d.ts +13 -0
  92. package/html/module.f.js +58 -0
  93. package/html/test.f.d.ts +9 -0
  94. package/html/test.f.js +42 -0
  95. package/issues/test.f.d.ts +16 -0
  96. package/issues/test.f.js +70 -0
  97. package/js/tokenizer/module.f.d.ts +86 -0
  98. package/js/tokenizer/module.f.js +503 -0
  99. package/js/tokenizer/test.f.d.ts +9 -0
  100. package/js/tokenizer/test.f.js +905 -0
  101. package/json/module.f.d.ts +20 -0
  102. package/json/module.f.js +68 -0
  103. package/json/parser/module.f.d.ts +5 -0
  104. package/json/parser/module.f.js +155 -0
  105. package/json/parser/test.f.d.ts +5 -0
  106. package/json/parser/test.f.js +328 -0
  107. package/json/serializer/module.f.d.ts +7 -0
  108. package/json/serializer/module.f.js +21 -0
  109. package/json/serializer/test.f.d.ts +8 -0
  110. package/json/serializer/test.f.js +87 -0
  111. package/json/test.f.d.ts +8 -0
  112. package/json/test.f.js +61 -0
  113. package/json/tokenizer/module.f.d.ts +8 -0
  114. package/json/tokenizer/module.f.js +52 -0
  115. package/json/tokenizer/test.f.d.ts +6 -0
  116. package/json/tokenizer/test.f.js +419 -0
  117. package/nanvm-lib/tests/test.f.d.ts +27 -0
  118. package/nanvm-lib/tests/test.f.js +84 -0
  119. package/nodejs/version/module.f.d.ts +11 -0
  120. package/nodejs/version/module.f.js +16 -0
  121. package/nodejs/version/test.f.d.ts +2 -0
  122. package/nodejs/version/{test.f.ts → test.f.js} +13 -22
  123. package/package.json +9 -5
  124. package/text/ascii/module.f.d.ts +129 -0
  125. package/text/ascii/module.f.js +148 -0
  126. package/text/ascii/test.f.d.ts +4 -0
  127. package/text/ascii/test.f.js +14 -0
  128. package/text/module.f.d.ts +8 -0
  129. package/text/module.f.js +10 -0
  130. package/text/sgr/module.f.d.ts +8 -0
  131. package/text/sgr/module.f.js +8 -0
  132. package/text/test.f.d.ts +2 -0
  133. package/text/test.f.js +18 -0
  134. package/text/utf16/module.f.d.ts +9 -0
  135. package/text/utf16/module.f.js +66 -0
  136. package/text/utf16/test.f.d.ts +6 -0
  137. package/text/utf16/test.f.js +144 -0
  138. package/text/utf8/module.f.d.ts +6 -0
  139. package/text/utf8/module.f.js +112 -0
  140. package/text/utf8/test.f.d.ts +6 -0
  141. package/text/utf8/test.f.js +175 -0
  142. package/types/array/module.f.d.ts +21 -0
  143. package/types/array/module.f.js +23 -0
  144. package/types/array/test.f.d.ts +10 -0
  145. package/types/array/test.f.js +116 -0
  146. package/types/bigfloat/module.f.d.ts +3 -0
  147. package/types/bigfloat/module.f.js +66 -0
  148. package/types/bigfloat/test.f.d.ts +6 -0
  149. package/types/bigfloat/test.f.js +349 -0
  150. package/types/bigint/module.f.d.ts +54 -0
  151. package/types/bigint/{module.f.ts → module.f.js} +42 -65
  152. package/types/bigint/test.f.d.ts +16 -0
  153. package/types/bigint/test.f.js +199 -0
  154. package/types/bit_vec/module.f.d.ts +134 -0
  155. package/types/bit_vec/{module.f.ts → module.f.js} +47 -65
  156. package/types/bit_vec/test.f.d.ts +22 -0
  157. package/types/bit_vec/test.f.js +210 -0
  158. package/types/btree/find/module.f.d.ts +20 -0
  159. package/types/btree/find/module.f.js +84 -0
  160. package/types/btree/find/test.f.d.ts +2 -0
  161. package/types/btree/find/test.f.js +152 -0
  162. package/types/btree/module.f.d.ts +4 -0
  163. package/types/btree/module.f.js +31 -0
  164. package/types/btree/remove/module.f.d.ts +4 -0
  165. package/types/btree/remove/module.f.js +174 -0
  166. package/types/btree/remove/test.f.d.ts +5 -0
  167. package/types/btree/remove/test.f.js +634 -0
  168. package/types/btree/set/module.f.d.ts +3 -0
  169. package/types/btree/set/module.f.js +103 -0
  170. package/types/btree/set/test.f.d.ts +2 -0
  171. package/types/btree/set/test.f.js +360 -0
  172. package/types/btree/test.f.d.ts +8 -0
  173. package/types/btree/test.f.js +75 -0
  174. package/types/btree/types/module.f.d.ts +11 -0
  175. package/types/btree/types/module.f.js +1 -0
  176. package/types/byte_set/module.f.d.ts +16 -0
  177. package/types/byte_set/module.f.js +28 -0
  178. package/types/byte_set/test.f.d.ts +12 -0
  179. package/types/byte_set/test.f.js +122 -0
  180. package/types/function/compare/module.f.d.ts +10 -0
  181. package/types/function/compare/module.f.js +7 -0
  182. package/types/function/compare/test.f.d.ts +2 -0
  183. package/types/function/compare/test.f.js +8 -0
  184. package/types/function/module.f.d.ts +28 -0
  185. package/types/function/module.f.js +19 -0
  186. package/types/function/operator/module.f.d.ts +20 -0
  187. package/types/function/operator/module.f.js +18 -0
  188. package/types/function/test.f.d.ts +2 -0
  189. package/types/function/test.f.js +12 -0
  190. package/types/list/module.f.d.ts +50 -0
  191. package/types/list/module.f.js +171 -0
  192. package/types/list/test.f.d.ts +22 -0
  193. package/types/list/test.f.js +395 -0
  194. package/types/map/module.f.d.ts +14 -0
  195. package/types/map/module.f.js +31 -0
  196. package/types/map/test.f.d.ts +5 -0
  197. package/types/map/test.f.js +114 -0
  198. package/types/nibble_set/module.f.d.ts +10 -0
  199. package/types/nibble_set/module.f.js +9 -0
  200. package/types/nibble_set/test.f.d.ts +12 -0
  201. package/types/nibble_set/test.f.js +90 -0
  202. package/types/nullable/module.f.d.ts +3 -0
  203. package/types/nullable/module.f.js +2 -0
  204. package/types/nullable/test.f.d.ts +2 -0
  205. package/types/nullable/test.f.js +12 -0
  206. package/types/number/module.f.d.ts +6 -0
  207. package/types/number/module.f.js +8 -0
  208. package/types/number/test.f.d.ts +11 -0
  209. package/types/number/test.f.js +124 -0
  210. package/types/object/module.f.d.ts +10 -0
  211. package/types/object/module.f.js +12 -0
  212. package/types/object/test.f.d.ts +5 -0
  213. package/types/object/test.f.js +17 -0
  214. package/types/range/module.f.d.ts +3 -0
  215. package/types/range/module.f.js +2 -0
  216. package/types/range/test.f.d.ts +2 -0
  217. package/types/range/test.f.js +18 -0
  218. package/types/range_map/module.f.d.ts +14 -0
  219. package/types/range_map/module.f.js +51 -0
  220. package/types/range_map/test.f.d.ts +6 -0
  221. package/types/range_map/test.f.js +176 -0
  222. package/types/result/module.f.d.ts +7 -0
  223. package/types/result/module.f.js +8 -0
  224. package/types/sorted_list/module.f.d.ts +16 -0
  225. package/types/sorted_list/module.f.js +56 -0
  226. package/types/sorted_list/test.f.d.ts +5 -0
  227. package/types/sorted_list/test.f.js +64 -0
  228. package/types/sorted_set/module.f.d.ts +7 -0
  229. package/types/sorted_set/module.f.js +14 -0
  230. package/types/sorted_set/test.f.d.ts +6 -0
  231. package/types/sorted_set/test.f.js +78 -0
  232. package/types/string/module.f.d.ts +6 -0
  233. package/types/string/module.f.js +11 -0
  234. package/types/string/test.f.d.ts +15 -0
  235. package/types/string/test.f.js +58 -0
  236. package/types/string_set/module.f.d.ts +9 -0
  237. package/types/string_set/module.f.js +22 -0
  238. package/types/string_set/test.f.d.ts +5 -0
  239. package/types/string_set/test.f.js +65 -0
  240. package/.github/FUNDING.yml +0 -12
  241. package/.github/dependabot.yml +0 -11
  242. package/.github/workflows/ci.yml +0 -88
  243. package/.github/workflows/npm-publish.yml +0 -53
  244. package/CHANGELOG.md +0 -29
  245. package/Cargo.lock +0 -18
  246. package/Cargo.toml +0 -7
  247. package/com/README.md +0 -3
  248. package/com/cpp/README.md +0 -80
  249. package/com/cpp/module.f.ts +0 -180
  250. package/com/cpp/nanocom.hpp +0 -195
  251. package/com/cpp/testlib.f.ts +0 -8
  252. package/com/cs/module.f.ts +0 -145
  253. package/com/cs/testlib.f.ts +0 -8
  254. package/com/proposals.md +0 -28
  255. package/com/rust/module.f.ts +0 -287
  256. package/com/rust/nanocom/Cargo.lock +0 -7
  257. package/com/rust/nanocom/Cargo.toml +0 -15
  258. package/com/rust/nanocom/README.md +0 -56
  259. package/com/rust/nanocom/src/class.rs +0 -6
  260. package/com/rust/nanocom/src/cobject.rs +0 -90
  261. package/com/rust/nanocom/src/guid.rs +0 -15
  262. package/com/rust/nanocom/src/hresult.rs +0 -7
  263. package/com/rust/nanocom/src/interface.rs +0 -9
  264. package/com/rust/nanocom/src/iunknown.rs +0 -13
  265. package/com/rust/nanocom/src/lib.rs +0 -20
  266. package/com/rust/nanocom/src/object.rs +0 -34
  267. package/com/rust/nanocom/src/ref.rs +0 -57
  268. package/com/rust/nanocom/src/vmt.rs +0 -7
  269. package/com/rust/nanocom/tests/it.rs +0 -186
  270. package/com/rust/nanocom/tests/itmod.rs +0 -195
  271. package/com/rust/testlib.f.ts +0 -8
  272. package/com/test/build.f.ts +0 -111
  273. package/com/test/build.ts +0 -45
  274. package/com/test/cpp/main.cpp +0 -74
  275. package/com/test/cs/Program.cs +0 -31
  276. package/com/test/cs/cs.csproj +0 -16
  277. package/com/test/rust/Cargo.toml +0 -12
  278. package/com/test/rust/src/lib.rs +0 -56
  279. package/com/types/module.f.ts +0 -62
  280. package/commonjs/README.md +0 -94
  281. package/commonjs/build/module.f.ts +0 -100
  282. package/commonjs/build/test.f.ts +0 -107
  283. package/commonjs/module/module.f.ts +0 -41
  284. package/commonjs/module.f.ts +0 -7
  285. package/commonjs/module.ts +0 -31
  286. package/commonjs/package/dependencies/module.f.ts +0 -22
  287. package/commonjs/package/dependencies/test.f.ts +0 -8
  288. package/commonjs/package/module.f.ts +0 -31
  289. package/commonjs/package/test.f.ts +0 -12
  290. package/commonjs/path/README.md +0 -17
  291. package/commonjs/path/module.f.ts +0 -171
  292. package/commonjs/test.ts +0 -64
  293. package/crypto/README.md +0 -3
  294. package/crypto/prime_field/module.f.ts +0 -114
  295. package/crypto/prime_field/test.f.ts +0 -95
  296. package/crypto/secp/module.f.ts +0 -182
  297. package/crypto/secp/test.f.ts +0 -68
  298. package/crypto/sha2/module.f.ts +0 -215
  299. package/crypto/sha2/test.f.ts +0 -83
  300. package/deno.json +0 -71
  301. package/dev/README.md +0 -8
  302. package/dev/index.ts +0 -3
  303. package/dev/module.f.ts +0 -1
  304. package/dev/module.ts +0 -195
  305. package/dev/test/module.f.ts +0 -135
  306. package/dev/test.ts +0 -53
  307. package/djs/README.md +0 -54
  308. package/djs/module.f.ts +0 -76
  309. package/djs/parser/module.f.ts +0 -509
  310. package/djs/parser/test.f.ts +0 -461
  311. package/djs/serializer/module.f.ts +0 -90
  312. package/djs/test.f.ts +0 -67
  313. package/djs/tokenizer/module.f.ts +0 -99
  314. package/djs/tokenizer/test.f.ts +0 -364
  315. package/doc/LANGUAGE.md +0 -255
  316. package/doc/README.md +0 -61
  317. package/doc/byte-code.md +0 -59
  318. package/doc/fa.md +0 -174
  319. package/doc/predefined.md +0 -143
  320. package/doc/proposals.md +0 -21
  321. package/doc/vm/README.md +0 -24
  322. package/doc/vm-rearchitecture.md +0 -129
  323. package/doc/vm.md +0 -150
  324. package/fsc/README.md +0 -111
  325. package/fsc/module.f.ts +0 -122
  326. package/fsc/test.f.ts +0 -21
  327. package/fsm/README.md +0 -113
  328. package/fsm/module.f.ts +0 -107
  329. package/fsm/test.f.ts +0 -139
  330. package/funding.json +0 -61
  331. package/html/README.md +0 -32
  332. package/html/module.f.ts +0 -109
  333. package/html/test.f.ts +0 -37
  334. package/issues/01-test-debug.md +0 -3
  335. package/issues/02-esm.md +0 -8
  336. package/issues/03-djs.md +0 -57
  337. package/issues/05-publish.md +0 -40
  338. package/issues/11-fs-load.md +0 -13
  339. package/issues/17-djs-extension.md +0 -6
  340. package/issues/README.md +0 -42
  341. package/issues/lang/1000-json.md +0 -50
  342. package/issues/lang/2110-default-export.md +0 -11
  343. package/issues/lang/2120-const.md +0 -14
  344. package/issues/lang/2130-default-import.md +0 -10
  345. package/issues/lang/2210-block-comment.md +0 -12
  346. package/issues/lang/2220-namespace-import.md +0 -25
  347. package/issues/lang/2310-undefined.md +0 -7
  348. package/issues/lang/2320-bigint.md +0 -7
  349. package/issues/lang/2330-property-accessor.md +0 -225
  350. package/issues/lang/2340-operators.md +0 -41
  351. package/issues/lang/2350-grouping.md +0 -11
  352. package/issues/lang/2360-built-in.md +0 -81
  353. package/issues/lang/2410-identifier-property.md +0 -9
  354. package/issues/lang/2420-line-comment.md +0 -10
  355. package/issues/lang/2430-trailing-comma.md +0 -13
  356. package/issues/lang/2440-shorthand.md +0 -8
  357. package/issues/lang/2450-destructuring.md +0 -12
  358. package/issues/lang/3110-function.md +0 -35
  359. package/issues/lang/3120-parameters.md +0 -9
  360. package/issues/lang/3130-body-const.md +0 -12
  361. package/issues/lang/3220-let.md +0 -11
  362. package/issues/lang/3240-export.md +0 -44
  363. package/issues/lang/3370-type-inference.md +0 -69
  364. package/issues/lang/3380-promise.md +0 -22
  365. package/issues/lang/3390-class.md +0 -3
  366. package/issues/lang/3410-expression.md +0 -12
  367. package/issues/lang/3420-one-parameter.md +0 -10
  368. package/issues/lang/3430-assignments.md +0 -23
  369. package/issues/lang/README.md +0 -193
  370. package/issues/test.f.ts +0 -58
  371. package/js/tokenizer/module.f.ts +0 -882
  372. package/js/tokenizer/test.f.ts +0 -617
  373. package/json/html/README.md +0 -49
  374. package/json/module.f.ts +0 -94
  375. package/json/parser/module.f.ts +0 -221
  376. package/json/parser/test.f.ts +0 -255
  377. package/json/serializer/module.f.ts +0 -74
  378. package/json/serializer/test.f.ts +0 -64
  379. package/json/test.f.ts +0 -48
  380. package/json/tokenizer/module.f.ts +0 -85
  381. package/json/tokenizer/test.f.ts +0 -290
  382. package/nanvm-lib/Cargo.toml +0 -6
  383. package/nanvm-lib/src/extension.rs +0 -130
  384. package/nanvm-lib/src/interface.rs +0 -133
  385. package/nanvm-lib/src/lib.rs +0 -7
  386. package/nanvm-lib/src/naive.rs +0 -236
  387. package/nanvm-lib/src/nanenum.rs +0 -236
  388. package/nanvm-lib/src/nullish.rs +0 -7
  389. package/nanvm-lib/src/sign.rs +0 -5
  390. package/nanvm-lib/src/simple.rs +0 -32
  391. package/nanvm-lib/tests/test.f.ts +0 -80
  392. package/nanvm-lib/tests/test.rs +0 -108
  393. package/nodejs/version/main.ts +0 -4
  394. package/nodejs/version/module.f.ts +0 -42
  395. package/text/README.md +0 -110
  396. package/text/ascii/module.f.ts +0 -219
  397. package/text/ascii/test.f.ts +0 -14
  398. package/text/module.f.ts +0 -30
  399. package/text/sgr/README.md +0 -3
  400. package/text/sgr/module.f.ts +0 -11
  401. package/text/test.f.ts +0 -19
  402. package/text/utf16/module.f.ts +0 -120
  403. package/text/utf16/test.f.ts +0 -107
  404. package/text/utf8/module.f.ts +0 -116
  405. package/text/utf8/test.f.ts +0 -125
  406. package/tsconfig.json +0 -104
  407. package/types/array/module.f.ts +0 -89
  408. package/types/array/test.f.ts +0 -88
  409. package/types/bigfloat/module.f.ts +0 -93
  410. package/types/bigfloat/test.f.ts +0 -218
  411. package/types/bigint/README.md +0 -35
  412. package/types/bigint/test.f.ts +0 -144
  413. package/types/bit_vec/README.md +0 -18
  414. package/types/bit_vec/test.f.ts +0 -129
  415. package/types/btree/README.md +0 -160
  416. package/types/btree/find/module.f.ts +0 -92
  417. package/types/btree/find/test.f.ts +0 -122
  418. package/types/btree/module.f.ts +0 -35
  419. package/types/btree/remove/module.f.ts +0 -151
  420. package/types/btree/remove/test.f.ts +0 -498
  421. package/types/btree/set/module.f.ts +0 -89
  422. package/types/btree/set/test.f.ts +0 -415
  423. package/types/btree/test.f.ts +0 -92
  424. package/types/btree/types/module.f.ts +0 -27
  425. package/types/byte_set/module.f.ts +0 -73
  426. package/types/byte_set/test.f.ts +0 -84
  427. package/types/function/compare/module.f.ts +0 -26
  428. package/types/function/compare/test.f.ts +0 -7
  429. package/types/function/module.f.ts +0 -43
  430. package/types/function/operator/module.f.ts +0 -65
  431. package/types/function/test.f.ts +0 -20
  432. package/types/list/module.f.ts +0 -350
  433. package/types/list/test.f.ts +0 -327
  434. package/types/map/module.f.ts +0 -65
  435. package/types/map/test.f.ts +0 -76
  436. package/types/nibble_set/module.f.ts +0 -34
  437. package/types/nibble_set/test.f.ts +0 -57
  438. package/types/nullable/module.f.ts +0 -9
  439. package/types/nullable/test.f.ts +0 -9
  440. package/types/number/module.f.ts +0 -20
  441. package/types/number/test.f.ts +0 -194
  442. package/types/object/module.f.ts +0 -30
  443. package/types/object/test.f.ts +0 -14
  444. package/types/range/module.f.ts +0 -10
  445. package/types/range/test.f.ts +0 -9
  446. package/types/range_map/module.f.ts +0 -70
  447. package/types/range_map/test.f.ts +0 -189
  448. package/types/result/module.f.ts +0 -20
  449. package/types/result/module.ts +0 -18
  450. package/types/sorted_list/module.f.ts +0 -83
  451. package/types/sorted_list/test.f.ts +0 -57
  452. package/types/sorted_set/module.f.ts +0 -36
  453. package/types/sorted_set/test.f.ts +0 -67
  454. package/types/string/module.f.ts +0 -26
  455. package/types/string/test.f.ts +0 -43
  456. package/types/string_set/module.f.ts +0 -37
  457. package/types/string_set/test.f.ts +0 -34
@@ -1,194 +0,0 @@
1
- import * as _ from './module.f.ts'
2
- const { sum, min, max, cmp } = _
3
-
4
- export default {
5
- sum: () => {
6
- const result = sum([2, 3, 4, 5])
7
- if (result !== 14) { throw result }
8
- },
9
- min: {
10
- empty: () => {
11
- const result = min([])
12
- if (result !== null) { throw result }
13
- },
14
- multi: () => {
15
- const result = min([1, 2, 12, -4, 8])
16
- if (result !== -4) { throw result }
17
- }
18
- },
19
- max: () => {
20
- const result = max([1, 2, 12, -4, 8])
21
- if (result !== 12) { throw result }
22
- },
23
- cmp: () => {
24
- const result = cmp(4)(5)
25
- if (result !== -1) { throw result }
26
- },
27
- standard: () => {
28
- const check
29
- : (a: bigint) => (a: bigint) => void
30
- = a => b => {
31
- if (BigInt(Number(a)) != b) { throw [a, b] }
32
- }
33
-
34
- const eq
35
- : (v: bigint) => void
36
- = v => check(v)(v)
37
-
38
- // 53, 0x35 bits.
39
- // 3 2 1 0
40
- // 4_3210_FEDC_BA98_7654_3210_FEDC_BA98_7654_3210_FEDC_BA98_7654_3210
41
- eq(0b1_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000n)
42
- eq(0b1_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0001n)
43
- eq(0b1_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0010n)
44
- eq(0b1_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0011n)
45
- eq(0b1_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0100n)
46
- //
47
- eq(0b1_1101_0010_0110_1110_1000_0010_1000_1101_0000_0001_0011_0100_1000n)
48
- eq(0b1_0101_0110_0110_0101_0110_0011_1100_0110_0110_0100_1100_1111_0001n)
49
- eq(0b1_1011_0011_0010_1010_1110_1101_1000_1111_0010_0100_1100_0010_1010n)
50
- eq(0b1_1010_0101_0010_0001_1000_1100_1010_1110_0110_0011_0001_0010_0011n)
51
- eq(0b1_0011_0001_0101_1101_1000_1111_0111_1100_0011_1100_0000_1010_1100n)
52
- //
53
- eq(0b1_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111n)
54
- eq(0b1_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1110n)
55
- eq(0b1_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1101n)
56
- eq(0b1_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1100n)
57
- eq(0b1_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1011n)
58
- eq(0b1_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1010n)
59
- eq(0b1_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1001n)
60
- eq(0b1_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1000n)
61
-
62
- // 54, 0x35+1 bits.
63
- // 3 2 1 0
64
- // 4_3210_FEDC_BA98_7654_3210_FEDC_BA98_7654_3210_FEDC_BA98_7654_3210_1
65
- check
66
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0n)
67
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0n)
68
- check
69
- (0b01_1101_0111_0110_0101_1001_1101_0101_0010_1101_1011_0110_0111_1011_0n)
70
- (0b01_1101_0111_0110_0101_1001_1101_0101_0010_1101_1011_0110_0111_1011_0n)
71
- check
72
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_0n)
73
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_0n)
74
- // round down
75
- check
76
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_1n)
77
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0n)
78
- check
79
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0010_1n)
80
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0010_0n)
81
- check
82
- (0b01_0100_1101_0100_1111_1101_1010_0110_1100_1111_1010_1000_1111_0010_1n)
83
- (0b01_0100_1101_0100_1111_1101_1010_0110_1100_1111_1010_1000_1111_0010_0n)
84
- check
85
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1110_1n)
86
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1110_0n)
87
- // round up
88
- check
89
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0001_1n)
90
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0010_0n)
91
- check
92
- (0b01_1011_1101_1010_0011_1010_1111_0111_1101_0001_1110_1111_1001_1011_1n)
93
- (0b01_1011_1101_1010_0011_1010_1111_0111_1101_0001_1110_1111_1001_1100_0n)
94
- check
95
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1n)
96
- (0b10_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0n)
97
-
98
- // 55, 0x35+2 bits.
99
- // 3 2 1 0
100
- // 4_3210_FEDC_BA98_7654_3210_FEDC_BA98_7654_3210_FEDC_BA98_7654_3210_12
101
- // 0_xx: down, down, up
102
- // 0_00
103
- check
104
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_00n)
105
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_00n)
106
- check
107
- (0b01_1011_1000_1010_1100_0110_1010_1010_0110_1100_0010_1010_1111_0000_00n)
108
- (0b01_1011_1000_1010_1100_0110_1010_1010_0110_1100_0010_1010_1111_0000_00n)
109
- check
110
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1110_00n)
111
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1110_00n)
112
- // 0_01 round down
113
- check
114
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_01n)
115
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_00n)
116
- check
117
- (0b01_1111_1101_1010_1111_0011_1100_0011_1010_1001_1100_1010_1110_1000_01n)
118
- (0b01_1111_1101_1010_1111_0011_1100_0011_1010_1001_1100_1010_1110_1000_00n)
119
- check
120
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1110_01n)
121
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1110_00n)
122
- // 0_10 round down
123
- check
124
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_10n)
125
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_00n)
126
- check
127
- (0b01_0010_0011_1101_1100_0011_0001_1000_1101_0011_0011_0011_1111_0110_10n)
128
- (0b01_0010_0011_1101_1100_0011_0001_1000_1101_0011_0011_0011_1111_0110_00n)
129
- check
130
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1110_10n)
131
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1110_00n)
132
- // 0_11 round up
133
- check
134
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_11n)
135
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0001_00n)
136
- check
137
- (0b01_0010_0111_0000_1101_1011_0111_0010_0100_1101_1100_0010_0111_0000_11n)
138
- (0b01_0010_0111_0000_1101_1011_0111_0010_0100_1101_1100_0010_0111_0001_00n)
139
- check
140
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1110_11n)
141
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_00n)
142
- // 1_xx: down, up, up
143
- // 1_00
144
- check
145
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0001_00n)
146
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0001_00n)
147
- check
148
- (0b01_1000_0001_1111_0001_1011_1101_0000_1001_1111_0011_0011_0111_0101_00n)
149
- (0b01_1000_0001_1111_0001_1011_1101_0000_1001_1111_0011_0011_0111_0101_00n)
150
- check
151
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1110_11n)
152
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_00n)
153
- // 1_01 round down
154
- check
155
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0001_01n)
156
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0001_00n)
157
- check
158
- (0b01_0100_1000_1100_1010_0010_1111_1011_0111_1011_1010_1011_0100_0001_01n)
159
- (0b01_0100_1000_1100_1010_0010_1111_1011_0111_1011_1010_1011_0100_0001_00n)
160
- check
161
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_01n)
162
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_00n)
163
- // 1_10 round up
164
- check
165
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0001_10n)
166
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0010_00n)
167
- check
168
- (0b01_1111_1011_1100_1010_1111_0010_1010_1111_1101_0110_0101_1001_0011_10n)
169
- (0b01_1111_1011_1100_1010_1111_0010_1010_1111_1101_0110_0101_1001_0100_00n)
170
- check
171
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_10n)
172
- (0b10_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_00n)
173
- // 1_11 round up
174
- check
175
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0001_11n)
176
- (0b01_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0010_00n)
177
- check
178
- (0b01_1111_0001_1001_1000_1110_0011_1011_0011_0100_0111_0010_0000_0101_11n)
179
- (0b01_1111_0001_1001_1000_1110_0011_1011_0011_0100_0111_0010_0000_0110_00n)
180
- check
181
- (0b01_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_1111_11n)
182
- (0b10_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_0000_00n)
183
-
184
- // 57, 0x35+4 bits.
185
- // 3 2 1 0
186
- // 4_3210_FEDC_BA98_7654_3210_FEDC_BA98_7654_3210_FEDC_BA98_7654_3210_1234
187
- check
188
- (0b01_0111_0001_0111_1101_1011_0100_1111_1110_0010_1111_0010_0010_1111_1110n)
189
- (0b01_0111_0001_0111_1101_1011_0100_1111_1110_0010_1111_0010_0011_0000_0000n)
190
- check
191
- (0b01_1111_1010_1111_0011_0101_0111_1001_1111_1001_1101_0111_0000_0001_0100n)
192
- (0b01_1111_1010_1111_0011_0101_0111_1001_1111_1001_1101_0111_0000_0001_0000n)
193
- }
194
- }
@@ -1,30 +0,0 @@
1
- import * as list from '../list/module.f.ts'
2
- const { iterable } = list
3
- import * as btMap from '../map/module.f.ts'
4
- const { entries: mapEntries, fromEntries: mapFromEntries } = btMap
5
- const { getOwnPropertyDescriptor, fromEntries: objectFromEntries } = Object
6
-
7
- export type Map<T> = {
8
- readonly [k in string]: T
9
- }
10
-
11
- export type Entry<T> = readonly[string, T]
12
-
13
- export const at
14
- : (name: string) => <T>(object: Map<T>) => T|null
15
- = name => object => {
16
- const r = getOwnPropertyDescriptor(object, name)
17
- return r === void 0 ? null : r.value
18
- }
19
-
20
- export const sort
21
- : <T>(e: list.List<Entry<T>>) => list.List<Entry<T>>
22
- = e => mapEntries(mapFromEntries(e))
23
-
24
- export const fromEntries
25
- : <T>(e: list.List<Entry<T>>) => Map<T>
26
- = e => objectFromEntries(iterable(e))
27
-
28
- export const fromMap
29
- : <T>(m: btMap.Map<T>) => Map<T>
30
- = m => fromEntries(mapEntries(m))
@@ -1,14 +0,0 @@
1
- import * as _ from './module.f.ts'
2
-
3
- export default {
4
- ctor: () => {
5
- const a = {}
6
- const value = _.at('constructor')(a)
7
- if (value !== null) { throw value }
8
- },
9
- property: () => {
10
- const a = { constructor: 42 }
11
- const value = _.at('constructor')(a)
12
- if (value !== 42) { throw value }
13
- }
14
- }
@@ -1,10 +0,0 @@
1
-
2
- export type Range = readonly[number,number]
3
-
4
- export const contains
5
- : (range: Range) => (i: number) => boolean
6
- = ([b, e]) => i => b <= i && i <= e
7
-
8
- export const one
9
- : (i: number) => Range
10
- = a => [a, a]
@@ -1,9 +0,0 @@
1
- import * as _ from './module.f.ts'
2
-
3
- export default () => {
4
- if (!_.contains([0, 5])(1)) { throw 1 }
5
- if (!_.contains([0, 5])(0)) { throw 0 }
6
- if (!_.contains([0, 5])(5)) { throw 5 }
7
- if (_.contains([0, 5])(-1)) { throw -1 }
8
- if (_.contains([0, 5])(6)) { throw 6 }
9
- }
@@ -1,70 +0,0 @@
1
- import * as sortedList from '../sorted_list/module.f.ts'
2
- const { genericMerge } = sortedList
3
- import * as list from '../list/module.f.ts'
4
- const { next } = list
5
- import * as Option from '../nullable/module.f.ts'
6
- import * as number from '../number/module.f.ts'
7
- const { cmp } = number
8
- import * as O from '../function/operator/module.f.ts'
9
- import * as Range from '../range/module.f.ts'
10
-
11
- export type Entry<T> =[T, number]
12
-
13
- export type RangeMap<T> = sortedList.SortedList<Entry<T>>
14
-
15
- export type RangeMapArray<T> = readonly Entry<T>[]
16
-
17
- export type Operators<T> = {
18
- readonly union: O.Reduce<T>
19
- readonly equal: O.Equal<T>
20
- }
21
-
22
- type RangeState<T> = Option.Nullable<Entry<T>>
23
-
24
- export type RangeMerge<T> = O.Reduce<RangeMap<T>>
25
-
26
- const reduceOp
27
- : <T>(union: O.Reduce<T>) => (equal: O.Equal<T>) => sortedList.ReduceOp<Entry<T>, RangeState<T>>
28
- = union => equal => state => ([aItem, aMax]) => ([bItem, bMax]) => {
29
- const sign = cmp(aMax)(bMax)
30
- const min = sign === 1 ? bMax : aMax
31
- const u = union(aItem)(bItem)
32
- const newState = state !== null && equal(state[0])(u) ? null : state
33
- return [newState, sign, [u, min]]
34
- }
35
-
36
- const tailReduce
37
- : <T>(equal: O.Equal<T>) => sortedList.TailReduce<Entry<T>, RangeState<T>>
38
- = equal => state => tail => {
39
- if (state === null) { return tail }
40
- const tailResult = next(tail)
41
- if (tailResult === null) { return [state] }
42
- if (equal(state[0])(tailResult.first[0])) { return tailResult }
43
- return { first: state, tail: tailResult }
44
- }
45
-
46
- export const merge
47
- : <T>(op: Operators<T>) => RangeMerge<T>
48
- = ({ union, equal }) => genericMerge({ reduceOp: reduceOp(union)(equal), tailReduce: tailReduce(equal) })(null)
49
-
50
- export const get
51
- : <T>(def: T) => (value: number) => (rm: RangeMapArray<T>) => T
52
- = def => value => rm => {
53
- const len = rm.length
54
- let b = 0
55
- let e = len - 1
56
- while (true) {
57
- if (b >= len) { return def }
58
- if (e - b < 0) { return rm[b][0] }
59
- const mid = b + (e - b >> 1)
60
- if (value <= rm[mid][1]) {
61
- e = mid - 1
62
- } else {
63
- b = mid + 1
64
- }
65
- }
66
- }
67
-
68
- export const fromRange
69
- : <T>(def: T) => (r: Range.Range) => (value: T) => RangeMapArray<T>
70
- = def => ([a, b]) => v => [[def, a - 1], [v, b]]
@@ -1,189 +0,0 @@
1
- import * as _ from './module.f.ts'
2
- import * as compare from '../function/compare/module.f.ts'
3
- const { unsafeCmp } = compare
4
- import * as json from '../../json/module.f.ts'
5
- import * as object from '../object/module.f.ts'
6
- const { sort } = object
7
- import * as sortedSet from '../sorted_set/module.f.ts'
8
- import * as list from '../list/module.f.ts'
9
- import * as operator from '../function/operator/module.f.ts'
10
-
11
- const stringify
12
- : (a: readonly json.Unknown[]) => string
13
- = json.stringify(sort)
14
-
15
- const op
16
- : _.Operators<sortedSet.SortedSet<string>>
17
- = { union: sortedSet.union(unsafeCmp), equal: list.equal(operator.strictEqual) }
18
-
19
- export default {
20
- merge: [
21
- () => {
22
- const a
23
- : _.RangeMap<sortedSet.SortedSet<string>>
24
- = [[['a'], 1], [['b'], 2]]
25
- const b
26
- : _.RangeMap<sortedSet.SortedSet<string>>
27
- = null
28
- const merged = _.merge(op)(a)(b)
29
- const result = stringify(list.toArray(merged))
30
- if (result !== '[[["a"],1],[["b"],2]]') { throw result }
31
- },
32
- () => {
33
- const a
34
- : _.RangeMap<sortedSet.SortedSet<string>>
35
- = null
36
- const b
37
- : _.RangeMap<sortedSet.SortedSet<string>>
38
- = [[['a'], 1], [['b'], 2]]
39
- const merged = _.merge(op)(a)(b)
40
- const result = stringify(list.toArray(merged))
41
- if (result !== '[[["a"],1],[["b"],2]]') { throw result }
42
- },
43
- () => {
44
- const a
45
- : _.RangeMap<sortedSet.SortedSet<string>>
46
- = [[['a'], 1], [['b'], 2]]
47
- const b
48
- : _.RangeMap<sortedSet.SortedSet<string>>
49
- = [[['a'], 1], [['b'], 2]]
50
- const merged = _.merge(op)(a)(b)
51
- const result = stringify(list.toArray(merged))
52
- if (result !== '[[["a"],1],[["b"],2]]') { throw result }
53
- },
54
- () => {
55
- const a
56
- : _.RangeMap<sortedSet.SortedSet<string>>
57
- = [[['a'], 1], [['c'], 3]]
58
- const b
59
- : _.RangeMap<sortedSet.SortedSet<string>>
60
- = [[['b'], 2], [['d'], 4]]
61
- const merged = _.merge(op)(a)(b)
62
- const result = stringify(list.toArray(merged))
63
- if (result !== '[[["a","b"],1],[["b","c"],2],[["c","d"],3],[["d"],4]]') { throw result }
64
- },
65
- () => {
66
- const a
67
- : _.RangeMap<sortedSet.SortedSet<string>>
68
- = [[['a'], 1], [['d'], 4]]
69
- const b
70
- : _.RangeMap<sortedSet.SortedSet<string>>
71
- = [[['b'], 2], [['c'], 3]]
72
- const merged = _.merge(op)(a)(b)
73
- const result = stringify(list.toArray(merged))
74
- if (result !== '[[["a","b"],1],[["b","d"],2],[["c","d"],3],[["d"],4]]') { throw result }
75
- },
76
- () => {
77
- const a
78
- : _.RangeMap<sortedSet.SortedSet<string>>
79
- = [[['a'], 1], [['b'], 2]]
80
- const b
81
- : _.RangeMap<sortedSet.SortedSet<string>>
82
- = [[['b'], 1], [['a'], 2]]
83
- const merged = _.merge(op)(a)(b)
84
- const result = stringify(list.toArray(merged))
85
- if (result !== '[[["a","b"],2]]') { throw result }
86
- },
87
- () => {
88
- const a
89
- : _.RangeMap<sortedSet.SortedSet<string>>
90
- = [[['a'], 1], [['b'], 2], [['a'], 3]]
91
- const b
92
- : _.RangeMap<sortedSet.SortedSet<string>>
93
- = [[['a'], 5]]
94
- const merged = _.merge(op)(a)(b)
95
- const result = stringify(list.toArray(merged))
96
- if (result !== '[[["a"],1],[["a","b"],2],[["a"],5]]') { throw result }
97
- }
98
- ],
99
- get: () => {
100
- const sortedSetEmpty
101
- : sortedSet.SortedSet<string>
102
- = []
103
- const get = _.get(sortedSetEmpty)
104
- return [
105
- () => {
106
- const rm
107
- : _.RangeMapArray<sortedSet.SortedSet<string>>
108
- = [[['a'], 10], [['b'], 20], [['c'], 30]]
109
- const result = stringify(get(5)(rm))
110
- if (result !== '["a"]') { throw result }
111
- },
112
- () => {
113
- const rm
114
- : _.RangeMapArray<sortedSet.SortedSet<string>>
115
- = [[['a'], 10], [['b'], 20], [['c'], 30]]
116
- const result = stringify(get(10)(rm))
117
- if (result !== '["a"]') { throw result }
118
- },
119
- () => {
120
- const rm
121
- : _.RangeMapArray<sortedSet.SortedSet<string>>
122
- = [[['a'], 10], [['b'], 20], [['c'], 30]]
123
- const result = stringify(get(15)(rm))
124
- if (result !== '["b"]') { throw result }
125
- },
126
- () => {
127
- const rm
128
- : _.RangeMapArray<sortedSet.SortedSet<string>>
129
- = [[['a'], 10], [['b'], 20], [['c'], 30]]
130
- const result = stringify(get(20)(rm))
131
- if (result !== '["b"]') { throw result }
132
- },
133
- () => {
134
- const rm
135
- : _.RangeMapArray<sortedSet.SortedSet<string>>
136
- = [[['a'], 10], [['b'], 20], [['c'], 30]]
137
- const result = stringify(get(25)(rm))
138
- if (result !== '["c"]') { throw result }
139
- },
140
- () => {
141
- const rm
142
- : _.RangeMapArray<sortedSet.SortedSet<string>>
143
- = [[['a'], 10], [['b'], 20], [['c'], 30]]
144
- const result = stringify(get(30)(rm))
145
- if (result !== '["c"]') { throw result }
146
- },
147
- () => {
148
- const rm
149
- : _.RangeMapArray<sortedSet.SortedSet<string>>
150
- = [[['a'], 10], [['b'], 20], [['c'], 30]]
151
- const result = stringify(get(35)(rm))
152
- if (result !== '[]') { throw result }
153
- },
154
- () => {
155
- const rm
156
- : _.RangeMapArray<sortedSet.SortedSet<string>>
157
- = []
158
- const result = stringify(get(10)(rm))
159
- if (result !== '[]') { throw result }
160
- }
161
- ]
162
- },
163
- fromRange: () => {
164
- const def = -1
165
- const rm = _.fromRange(def)([1, 7])(42)
166
- return [
167
- () => {
168
- const result = _.get(def)(0)(rm)
169
- if (result !== -1) { throw result }
170
- },
171
- () => {
172
- const result = _.get(def)(1)(rm)
173
- if (result !== 42) { throw result }
174
- },
175
- () => {
176
- const result = _.get(def)(3)(rm)
177
- if (result !== 42) { throw result }
178
- },
179
- () => {
180
- const result = _.get(def)(7)(rm)
181
- if (result !== 42) { throw result }
182
- },
183
- () => {
184
- const result = _.get(def)(9)(rm)
185
- if (result !== -1) { throw result }
186
- },
187
- ]
188
- }
189
- }
@@ -1,20 +0,0 @@
1
- type Ok<T> = readonly['ok', T]
2
-
3
- type Error<E> = readonly['error', E]
4
-
5
- export type Result<T, E> = Ok<T>|Error<E>
6
-
7
- export const ok
8
- : <T>(value: T) => Ok<T>
9
- = value => ['ok', value]
10
-
11
- export const error
12
- : <E>(e: E) => Error<E>
13
- = e => ['error', e]
14
-
15
- export const unwrap
16
- : <T, E>(r: Result<T, E>) => T
17
- = ([kind, v]) => {
18
- if (kind === 'error') { throw v }
19
- return v
20
- }
@@ -1,18 +0,0 @@
1
- import * as result from './module.f.ts'
2
- const { ok, error } = result
3
-
4
- const tryCatch
5
- : <T>(f: () => T) => result.Result<T, unknown>
6
- = f => {
7
- // Side effect: `try catch` is not allowed in FunctionalScript.
8
- try {
9
- return ok(f())
10
- } catch (e) {
11
- return error(e)
12
- }
13
- }
14
-
15
- export default {
16
- /** @readonly */
17
- tryCatch,
18
- }
@@ -1,83 +0,0 @@
1
- import * as compare from '../function/compare/module.f.ts'
2
- import * as list from '../list/module.f.ts'
3
- import * as option from '../nullable/module.f.ts'
4
- const { next } = list
5
- import * as f from '../function/module.f.ts'
6
- const { identity } = f
7
-
8
- export type SortedList<T> = list.List<T>
9
-
10
- type SortedArray<T> = readonly T[]
11
-
12
- type Cmp<T> =(a: T) => (b: T) => compare.Sign
13
-
14
- export type ReduceOp<T, S> = (state: S) => (a: T) => (b: T) => readonly[option.Nullable<T>, compare.Sign, S]
15
-
16
- export type TailReduce<T, S> = (state: S) => (tail: list.List<T>) => list.List<T>
17
-
18
- type MergeReduce<T, S> = {
19
- readonly reduceOp: ReduceOp<T,S>
20
- readonly tailReduce: TailReduce<T,S>
21
- }
22
-
23
- export const genericMerge
24
- = <T,S>({ reduceOp, tailReduce }: MergeReduce<T,S>)
25
- : (state: S) => (a: list.List<T>) => (b: list.List<T>) => list.List<T> => {
26
- const f
27
- : (state: S) => (a: list.List<T>) => (b: list.List<T>) => list.List<T>
28
- = state => a => b => () => {
29
- const aResult = next(a)
30
- if (aResult === null) { return tailReduce(state)(b) }
31
- const bResult = next(b)
32
- if (bResult === null) { return tailReduce(state)(aResult) }
33
- const [first, sign, stateNext] = reduceOp(state)(aResult.first)(bResult.first)
34
- const aNext = sign === 1 ? a : aResult.tail
35
- const bNext = sign === -1 ? b : bResult.tail
36
- const tail = f(stateNext)(aNext)(bNext)
37
- return first === null ? tail : { first, tail }
38
- }
39
- return f
40
- }
41
-
42
- type CmpReduceOp<T> = ReduceOp<T, null>
43
-
44
- export const merge
45
- = <T>(cmp: Cmp<T>)
46
- : (a: SortedList<T>) => (b: SortedList<T>) => SortedList<T> => {
47
- const tailReduce: TailReduce<T, null> = mergeTail
48
- return genericMerge({ reduceOp: cmpReduce(cmp), tailReduce })(null)
49
- }
50
-
51
- const cmpReduce
52
- : <T>(cmp: Cmp<T>) => CmpReduceOp<T>
53
- = cmp => () => a => b => {
54
- const sign = cmp(a)(b)
55
- return [sign === 1 ? b : a, sign, null]
56
- }
57
-
58
- const mergeTail
59
- : () => <T>(tail: list.List<T>) => list.List<T>
60
- = () => identity
61
-
62
- export const find
63
- : <T>(cmp: Cmp<T>) => (value: T) => (array: SortedArray<T>) => T|null
64
- = cmp => value => array => {
65
- let b = 0
66
- let e = array.length - 1
67
- while (true) {
68
- if (e - b < 0) return null
69
- const mid = b + (e - b >> 1)
70
- const sign = cmp(value)(array[mid])
71
- switch(sign) {
72
- case -1: {
73
- e = mid - 1
74
- break
75
- }
76
- case 0: { return value }
77
- case 1: {
78
- b = mid + 1
79
- break
80
- }
81
- }
82
- }
83
- }