functionalscript 0.3.4 → 0.3.6

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,882 +0,0 @@
1
- import * as operator from '../../types/function/operator/module.f.ts'
2
- import * as range_map from '../../types/range_map/module.f.ts'
3
- const { merge, fromRange, get } = range_map
4
- import * as list from '../../types/list/module.f.ts'
5
- import * as map from '../../types/map/module.f.ts'
6
- const { at } = map
7
- import * as _range from '../../types/range/module.f.ts'
8
- const { one } = _range
9
- const { empty, stateScan, flat, toArray, reduce: listReduce, scan } = list
10
- import * as bigfloatT from '../../types/bigfloat/module.f.ts'
11
- const { fromCharCode } = String
12
- import * as ascii from '../../text/ascii/module.f.ts'
13
- const { range } = ascii
14
- const {
15
- //
16
- backspace,
17
- ht,
18
- lf,
19
- ff,
20
- cr,
21
- //
22
- exclamationMark,
23
- percentSign,
24
- ampersand,
25
- asterisk,
26
- lessThanSign,
27
- equalsSign,
28
- greaterThanSign,
29
- questionMark,
30
- circumflexAccent,
31
- verticalLine,
32
- tilde,
33
- //
34
- space,
35
- quotationMark,
36
- leftParenthesis,
37
- rightParenthesis,
38
- plusSign,
39
- comma,
40
- hyphenMinus,
41
- fullStop,
42
- solidus,
43
- //
44
- digitRange,
45
- digit0,
46
- colon,
47
- //
48
- latinCapitalLetterRange,
49
- latinCapitalLetterA,
50
- latinCapitalLetterE,
51
- //
52
- leftSquareBracket,
53
- reverseSolidus,
54
- rightSquareBracket,
55
- lowLine,
56
- //
57
- latinSmallLetterRange,
58
- latinSmallLetterA,
59
- latinSmallLetterB,
60
- latinSmallLetterE,
61
- latinSmallLetterF,
62
- latinSmallLetterN,
63
- latinSmallLetterR,
64
- latinSmallLetterT,
65
- latinSmallLetterU,
66
- //
67
- leftCurlyBracket,
68
- rightCurlyBracket,
69
- dollarSign
70
- } = ascii
71
-
72
- export type StringToken = {
73
- readonly kind: 'string'
74
- readonly value: string
75
- }
76
-
77
- export type NumberToken = {
78
- readonly kind: 'number'
79
- readonly value: string
80
- readonly bf: bigfloatT.BigFloat
81
- }
82
-
83
- export type BigIntToken = {
84
- readonly kind: 'bigint'
85
- readonly value: bigint
86
- }
87
-
88
- export type ErrorToken = {readonly kind: 'error', message: ErrorMessage}
89
-
90
- export type WhitespaceToken = {readonly kind: 'ws'}
91
-
92
- export type NewLineToken = {readonly kind: 'nl'}
93
-
94
- type TrueToken = {readonly kind: 'true'}
95
-
96
- type FalseToken = {readonly kind: 'false'}
97
-
98
- type NullToken = {readonly kind: 'null'}
99
-
100
- type UndefinedToken = {readonly kind: 'undefined'}
101
-
102
- type KeywordToken = |
103
- {readonly kind: 'arguments' | 'await' | 'break' | 'case' | 'catch' | 'class' | 'const' | 'continue' } |
104
- {readonly kind: 'debugger' | 'default' | 'delete' | 'do' | 'else' | 'enum' | 'eval' | 'export' } |
105
- {readonly kind: 'extends' | 'finally' | 'for' | 'function' | 'if' | 'implements' | 'import' | 'in' } |
106
- {readonly kind: 'instanceof' | 'interface' | 'let' | 'new' | 'package' | 'private' | 'protected' | 'public' } |
107
- {readonly kind: 'return' | 'static' | 'super' | 'switch' | 'this' | 'throw' | 'try' | 'typeof' } |
108
- {readonly kind: 'var' | 'void' | 'while' | 'with' | 'yield' }
109
-
110
- export type IdToken = {
111
- readonly kind: 'id'
112
- readonly value: string
113
- }
114
-
115
- type OperatorToken =|
116
- {readonly kind: '{' | '}' | ':' | ',' | '[' | ']' } |
117
- {readonly kind: '.' | '=' } |
118
- {readonly kind: '(' | ')' } |
119
- {readonly kind: '==' | '!=' | '===' | '!==' | '>' | '>=' | '<' | '<=' } |
120
- {readonly kind: '+' | '-' | '*' | '/' | '%' | '++' | '--' | '**' } |
121
- {readonly kind: '+=' | '-=' | '*=' | '/=' | '%=' | '**='} |
122
- {readonly kind: '&' | '|' | '^' | '~' | '<<' | '>>' | '>>>' } |
123
- {readonly kind: '&=' | '|=' | '^=' | '<<=' | '>>=' | '>>>='} |
124
- {readonly kind: '&&' | '||' | '!' | '??' } |
125
- {readonly kind: '&&=' | '||=' | '??=' } |
126
- {readonly kind: '?' | '?.' | '=>'}
127
-
128
- export type CommentToken = {
129
- readonly kind: '//' | '/*'
130
- readonly value: string
131
- }
132
-
133
- export type JsToken = |
134
- KeywordToken |
135
- TrueToken |
136
- FalseToken |
137
- NullToken |
138
- WhitespaceToken |
139
- NewLineToken |
140
- StringToken |
141
- NumberToken |
142
- ErrorToken |
143
- IdToken |
144
- BigIntToken |
145
- UndefinedToken |
146
- OperatorToken |
147
- CommentToken
148
-
149
- const rangeOneNine = range('19')
150
-
151
- const rangeSetNewLine = [
152
- one(lf),
153
- one(cr)
154
- ]
155
-
156
- const rangeSetWhiteSpace = [
157
- one(ht),
158
- one(space)
159
- ]
160
-
161
- const rangeSetTerminalForNumber = [
162
- ...rangeSetWhiteSpace,
163
- ...rangeSetNewLine,
164
- one(exclamationMark),
165
- one(percentSign),
166
- one(ampersand),
167
- one(leftParenthesis),
168
- one(rightParenthesis),
169
- one(asterisk),
170
- one(comma),
171
- one(solidus),
172
- one(colon),
173
- one(lessThanSign),
174
- one(equalsSign),
175
- one(greaterThanSign),
176
- one(questionMark),
177
- one(circumflexAccent),
178
- one(leftSquareBracket),
179
- one(rightSquareBracket),
180
- one(leftCurlyBracket),
181
- one(verticalLine),
182
- one(rightCurlyBracket),
183
- one(tilde),
184
- ]
185
-
186
- const rangeSmallAF = range('af')
187
- const rangeCapitalAF = range('AF')
188
-
189
- const rangeIdStart = [
190
- latinSmallLetterRange,
191
- latinCapitalLetterRange,
192
- one(lowLine),
193
- one(dollarSign)
194
- ]
195
-
196
- const rangeOpStart = [
197
- one(exclamationMark),
198
- one(percentSign),
199
- one(ampersand),
200
- one(leftParenthesis),
201
- one(rightParenthesis),
202
- one(asterisk),
203
- one(plusSign),
204
- one(comma),
205
- one(hyphenMinus),
206
- one(fullStop),
207
- one(solidus),
208
- one(colon),
209
- one(lessThanSign),
210
- one(equalsSign),
211
- one(greaterThanSign),
212
- one(questionMark),
213
- one(circumflexAccent),
214
- one(leftSquareBracket),
215
- one(rightSquareBracket),
216
- one(leftCurlyBracket),
217
- one(verticalLine),
218
- one(rightCurlyBracket),
219
- one(tilde)
220
- ]
221
-
222
- const rangeId = [digitRange, ...rangeIdStart]
223
-
224
- type TokenizerState = |
225
- InitialState |
226
- ParseIdState |
227
- ParseStringState |
228
- ParseEscapeCharState |
229
- ParseUnicodeCharState |
230
- ParseNumberState |
231
- InvalidNumberState |
232
- ParseOperatorState |
233
- ParseWhitespaceState |
234
- ParseNewLineState |
235
- ParseCommentState |
236
- EofState
237
-
238
- type ErrorMessage = |
239
- '" are missing' |
240
- 'unescaped character' |
241
- 'invalid hex value' |
242
- 'unexpected character' |
243
- 'invalid number' |
244
- 'invalid token' |
245
- '*\/ expected' |
246
- 'unterminated string literal' |
247
- 'eof'
248
-
249
- type InitialState = { readonly kind: 'initial'}
250
-
251
- type ParseIdState = { readonly kind: 'id', readonly value: string}
252
-
253
- type ParseWhitespaceState = { readonly kind: 'ws'}
254
-
255
- type ParseNewLineState = { readonly kind: 'nl'}
256
-
257
- type ParseStringState = { readonly kind: 'string', readonly value: string}
258
-
259
- type ParseEscapeCharState = { readonly kind: 'escapeChar', readonly value: string}
260
-
261
- type ParseOperatorState = { readonly kind: 'op', readonly value: string}
262
-
263
- type ParseMinusState = { readonly kind: '-'}
264
-
265
- type ParseCommentState = {
266
- readonly kind: '//' | '/*' | '/**'
267
- readonly value: string
268
- readonly newLine: boolean
269
- }
270
-
271
- type ParseUnicodeCharState = {
272
- readonly kind: 'unicodeChar'
273
- readonly value: string
274
- readonly unicode: number
275
- readonly hexIndex: number
276
- }
277
-
278
- type ParseNumberState = {
279
- readonly kind: 'number'
280
- readonly numberKind: '0' | 'int' | '.' | 'fractional' | 'e' | 'e+' | 'e-' | 'expDigits' | 'bigint'
281
- readonly value: string
282
- readonly b: ParseNumberBuffer
283
- }
284
-
285
- type ParseNumberBuffer = {
286
- readonly s: -1n | 1n
287
- readonly m: bigint
288
- readonly f: number
289
- readonly es: -1 | 1
290
- readonly e: number
291
- }
292
-
293
- type InvalidNumberState = { readonly kind: 'invalidNumber'}
294
-
295
- type EofState = { readonly kind: 'eof'}
296
-
297
- type CharCodeOrEof = number|null
298
-
299
- type ToToken = (input: number) => readonly[list.List<JsToken>, TokenizerState]
300
-
301
- type CreateToToken<T> = (state: T) => ToToken
302
-
303
- type RangeSet = list.List<_range.Range>
304
-
305
- type RangeFunc<T> = (def: CreateToToken<T>) => (RangeMapToToken<T>)
306
-
307
- type RangeMapToToken<T> = range_map.RangeMapArray<CreateToToken<T>>
308
-
309
- const appendChar
310
- : (old: string) => (input: number) => string
311
- = old => input => `${old}${fromCharCode(input)}`
312
-
313
- const union
314
- : <T>(def: CreateToToken<T>) => (a: CreateToToken<T>) => (b: CreateToToken<T>) => CreateToToken<T>
315
- = def => a => b => {
316
- if (a === def || a === b) { return b }
317
- if (b === def) { return a }
318
- throw [a, b]
319
- }
320
-
321
- const rangeMapMerge
322
- : <T>(def: CreateToToken<T>) => range_map.RangeMerge<CreateToToken<T>>
323
- = def => merge({
324
- union: union(def),
325
- equal: operator.strictEqual,
326
- })
327
-
328
- const rangeFunc
329
- : <T>(r: _range.Range) => (f: CreateToToken<T>) => RangeFunc<T>
330
- = r => f => def => fromRange(def)(r)(f)
331
-
332
- const scanRangeOp
333
- : <T>(def: CreateToToken<T>) => (operator.Scan<RangeFunc<T>, RangeMapToToken<T>>)
334
- = def => f => [f(def), scanRangeOp(def)]
335
-
336
- const reduceRangeMap
337
- : <T>(def: CreateToToken<T>) => (a: list.List<RangeFunc<T>>) => RangeMapToToken<T>
338
- = def => a => {
339
- const rm = scan(scanRangeOp(def))(a)
340
- return toArray(listReduce(rangeMapMerge(def))(empty)(rm))
341
- }
342
-
343
- const scanRangeSetOp
344
- : <T>(def: CreateToToken<T>) => (f: CreateToToken<T>) => (operator.Scan<_range.Range, RangeMapToToken<T>>)
345
- = def => f => r => [fromRange(def)(r)(f), scanRangeSetOp(def)(f)]
346
-
347
- const rangeSetFunc
348
- : <T>(rs: list.List<_range.Range>) => (f: CreateToToken<T>) => RangeFunc<T>
349
- = rs => f => def => {
350
- const rm = scan(scanRangeSetOp(def)(f))(rs)
351
- return toArray(listReduce(rangeMapMerge(def))(empty)(rm))
352
- }
353
-
354
- const create = <T>(def: CreateToToken<T>) => (a: list.List<RangeFunc<T>>): CreateToToken<T> => {
355
- const i = reduceRangeMap(def)(a)
356
- const x
357
- : (v: number) => (i: RangeMapToToken<T>) => (v: T) => ToToken
358
- = get(def)
359
- return v => c => x(c)(i)(v)(c)
360
- }
361
-
362
- const digitToBigInt
363
- : (digit: number) => bigint
364
- = d => BigInt(d - digit0)
365
-
366
- const startNumber
367
- : (digit: number) => ParseNumberBuffer
368
- = digit => ({ s: 1n, m: digitToBigInt(digit), f: 0, es: 1, e: 0 })
369
-
370
- const startNegativeNumber
371
- : ParseNumberBuffer
372
- = { s: -1n, m: 0n, f: 0, es: 1, e: 0 }
373
-
374
- const addIntDigit
375
- : (digit: number) => (b: ParseNumberBuffer) => ParseNumberBuffer
376
- = digit => b => ({ ... b, m: b.m * 10n + digitToBigInt(digit)})
377
-
378
- const addFracDigit
379
- : (digit: number) => (b: ParseNumberBuffer) => ParseNumberBuffer
380
- = digit => b => ({ ... b, m: b.m * 10n + digitToBigInt(digit), f: b.f - 1})
381
-
382
- const addExpDigit
383
- : (digit: number) => (b: ParseNumberBuffer) => ParseNumberBuffer
384
- = digit => b => ({ ... b, e: b.e * 10 + digit - digit0})
385
-
386
- const bufferToNumberToken
387
- : (s: ParseNumberState) => JsToken
388
- = ({numberKind, value, b}) =>
389
- {
390
- if (numberKind === 'bigint')
391
- return { kind: 'bigint', value: b.s * b.m }
392
- return { kind: 'number', value: value, bf: [b.s * b.m, b.f + b.es * b.e] }
393
- }
394
-
395
- /**
396
- * @link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Lexical_grammar#keywords
397
- */
398
- const keywordEntries
399
- : list.List<map.Entry<JsToken>>
400
- = [
401
- ['arguments', { kind: 'arguments'}],
402
- ['await', { kind: 'await'}],
403
- ['break', { kind: 'break'}],
404
- ['case', { kind: 'case'}],
405
- ['catch', { kind: 'catch'}],
406
- ['class', { kind: 'class'}],
407
- ['const', { kind: 'const'}],
408
- ['continue', { kind: 'continue'}],
409
- ['debugger', { kind: 'debugger'}],
410
- ['default', { kind: 'default'}],
411
- ['delete', { kind: 'delete'}],
412
- ['do', { kind: 'do'}],
413
- ['else', { kind: 'else'}],
414
- ['enum', { kind: 'enum'}],
415
- ['eval', { kind: 'eval'}],
416
- ['export', { kind: 'export'}],
417
- ['extends', { kind: 'extends'}],
418
- ['false', { kind: 'false'}],
419
- ['finally', { kind: 'finally'}],
420
- ['for', { kind: 'for'}],
421
- ['function', { kind: 'function'}],
422
- ['if', { kind: 'if'}],
423
- ['implements', { kind: 'implements'}],
424
- ['import', { kind: 'import'}],
425
- ['in', { kind: 'in'}],
426
- ['instanceof', { kind: 'instanceof'}],
427
- ['interface', { kind: 'interface'}],
428
- ['let', { kind: 'let'}],
429
- ['new', { kind: 'new'}],
430
- ['null', { kind: 'null'}],
431
- ['package', { kind: 'package'}],
432
- ['private', { kind: 'private'}],
433
- ['protected', { kind: 'protected'}],
434
- ['public', { kind: 'public'}],
435
- ['return', { kind: 'return'}],
436
- ['static', { kind: 'static'}],
437
- ['super', { kind: 'super'}],
438
- ['switch', { kind: 'switch'}],
439
- ['this', { kind: 'this'}],
440
- ['throw', { kind: 'throw'}],
441
- ['true', { kind: 'true'}],
442
- ['try', { kind: 'try'}],
443
- ['typeof', { kind: 'typeof'}],
444
- ['undefined', { kind: 'undefined'}],
445
- ['var', { kind: 'var'}],
446
- ['void', { kind: 'void'}],
447
- ['while', { kind: 'while'}],
448
- ['with', { kind: 'with'}],
449
- ['yield', { kind: 'yield'}],
450
- ]
451
-
452
- const keywordMap = map.fromEntries(keywordEntries)
453
-
454
- export const isKeywordToken
455
- : (token: JsToken) => Boolean
456
- = token => at(token.kind)(keywordMap) !== null
457
-
458
- /**
459
- * @link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators
460
- */
461
- const operatorEntries
462
- : list.List<map.Entry<JsToken>>
463
- = [
464
- ['!', { kind: '!'}],
465
- ['!=', { kind: '!='}],
466
- ['!==', { kind: '!=='}],
467
- ['%', { kind: '%'}],
468
- ['%=', { kind: '%='}],
469
- ['&', { kind: '&'}],
470
- ['&&', { kind: '&&'}],
471
- ['&&=', { kind: '&&='}],
472
- ['&=', { kind: '&='}],
473
- ['(', { kind: '('}],
474
- [')', { kind: ')'}],
475
- ['*', { kind: '*'}],
476
- ['**', { kind: '**'}],
477
- ['**=', { kind: '**='}],
478
- ['*=', { kind: '*='}],
479
- ['+', { kind: '+'}],
480
- ['++', { kind: '++'}],
481
- ['+=', { kind: '+='}],
482
- [',', { kind: ','}],
483
- ['-', { kind: '-'}],
484
- ['--', { kind: '--'}],
485
- ['-=', { kind: '-='}],
486
- ['.', { kind: '.'}],
487
- ['/', { kind: '/'}],
488
- ['/=', { kind: '/='}],
489
- [':', { kind: ':'}],
490
- ['<', { kind: '<'}],
491
- ['<<', { kind: '<<'}],
492
- ['<<=', { kind: '<<='}],
493
- ['<=', {kind: '<='}],
494
- ['=', { kind: '='}],
495
- ['==', { kind: '=='}],
496
- ['===', { kind: '==='}],
497
- ['=>', {kind: '=>'}],
498
- ['>', { kind: '>'}],
499
- ['>=', { kind: '>='}],
500
- ['>>', { kind: '>>'}],
501
- ['>>=', {kind: '>>='}],
502
- ['>>>', {kind: '>>>'}],
503
- ['>>>=', {kind: '>>>='}],
504
- ['?', { kind: '?'}],
505
- ['?.', { kind: '?.'}],
506
- ['??', { kind: '??'}],
507
- ['??=', { kind: '??='}],
508
- ['^', { kind: '^'}],
509
- ['^=', { kind: '^='}],
510
- ['[', { kind: '['}],
511
- [']', { kind: ']'}],
512
- ['{', { kind: '{'}],
513
- ['|', { kind: '|'}],
514
- ['|=', { kind: '|='}],
515
- ['||', { kind: '||'}],
516
- ['||=', { kind: '||='}],
517
- ['}', { kind: '}'}],
518
- ['~', { kind: '~' }]
519
- ]
520
-
521
- const operatorMap = map.fromEntries(operatorEntries)
522
-
523
- const getOperatorToken
524
- : (op: string) => JsToken
525
- = op => at(op)(operatorMap) ?? { kind: 'error', message: 'invalid token' }
526
-
527
- const hasOperatorToken
528
- : (op: string) => Boolean
529
- = op => at(op)(operatorMap) !== null
530
-
531
- const initialStateOp
532
- : (state: InitialState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
533
- = create((state: TokenizerState) => () => [[{ kind: 'error', message: 'unexpected character' }], state])([
534
- rangeFunc<TokenizerState>(rangeOneNine)(() => input => [empty, { kind: 'number', value: fromCharCode(input), b: startNumber(input), numberKind: 'int' }]),
535
- rangeSetFunc<TokenizerState>(rangeIdStart)(() => input => [empty, { kind: 'id', value: fromCharCode(input) }]),
536
- rangeSetFunc<TokenizerState>(rangeSetWhiteSpace)(() => () => [empty, { kind: 'ws' }]),
537
- rangeSetFunc<TokenizerState>(rangeSetNewLine)(() => () => [empty, { kind: 'nl' }]),
538
- rangeFunc<TokenizerState>(one(quotationMark))(() => () => [empty, { kind: 'string', value: '' }]),
539
- rangeFunc<TokenizerState>(one(digit0))(() => input => [empty, { kind: 'number', value: fromCharCode(input), b: startNumber(input), numberKind: '0' }]),
540
- rangeSetFunc<TokenizerState>(rangeOpStart)(() => input => [empty, { kind: 'op', value: fromCharCode(input) }])
541
- ])
542
-
543
- const invalidNumberToToken
544
- : (state: ParseNumberState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
545
- = () => input => {
546
- const next = tokenizeOp({ kind: 'initial' })(input)
547
- return [{ first: { kind: 'error', message: 'invalid number' }, tail: next[0] }, next[1]]
548
- }
549
-
550
- const fullStopToToken
551
- : (state: ParseNumberState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
552
- = state => input => {
553
- switch (state.numberKind) {
554
- case '0':
555
- case 'int': return [empty, { kind: 'number', value: appendChar(state.value)(input), b: state.b, numberKind: '.' }]
556
- default: return tokenizeOp({ kind: 'invalidNumber' })(input)
557
- }
558
- }
559
-
560
- const digit0ToToken
561
- : (state: ParseNumberState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
562
- = state => input => {
563
- switch (state.numberKind) {
564
- case '0': return tokenizeOp({ kind: 'invalidNumber' })(input)
565
- case '.':
566
- case 'fractional': return [empty, { kind: 'number', value: appendChar(state.value)(input), b: addFracDigit(input)(state.b), numberKind: 'fractional' }]
567
- case 'e':
568
- case 'e+':
569
- case 'e-':
570
- case 'expDigits': return [empty, { kind: 'number', value: appendChar(state.value)(input), b: addExpDigit(input)(state.b), numberKind: 'expDigits' }]
571
- default: return [empty, { kind: 'number', value: appendChar(state.value)(input), b: addIntDigit(input)(state.b), numberKind: state.numberKind }]
572
- }
573
- }
574
-
575
- const digit19ToToken
576
- : (state: ParseNumberState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
577
- = state => input => {
578
- switch (state.numberKind) {
579
- case '0': return tokenizeOp({ kind: 'invalidNumber' })(input)
580
- case '.':
581
- case 'fractional': return [empty, { kind: 'number', value: appendChar(state.value)(input), b: addFracDigit(input)(state.b), numberKind: 'fractional' }]
582
- case 'e':
583
- case 'e+':
584
- case 'e-':
585
- case 'expDigits': return [empty, { kind: 'number', value: appendChar(state.value)(input), b: addExpDigit(input)(state.b), numberKind: 'expDigits' }]
586
- default: return [empty, { kind: 'number', value: appendChar(state.value)(input), b: addIntDigit(input)(state.b), numberKind: 'int' }]
587
- }
588
- }
589
-
590
- const expToToken
591
- : (state: ParseNumberState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
592
- = state => input => {
593
- switch (state.numberKind) {
594
- case '0':
595
- case 'int':
596
- case 'fractional': return [empty, { kind: 'number', value: appendChar(state.value)(input), b: state.b, numberKind: 'e' }]
597
- default: return tokenizeOp({ kind: 'invalidNumber' })(input)
598
- }
599
- }
600
-
601
- const hyphenMinusToToken
602
- : (state: ParseNumberState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
603
- = state => input => {
604
- switch (state.numberKind) {
605
- case 'e': return [empty, { kind: 'number', value: appendChar(state.value)(input), b: { ... state.b, es: -1}, numberKind: 'e-' }]
606
- default: return terminalToToken(state)(input)
607
- }
608
- }
609
-
610
- const plusSignToToken
611
- : (state: ParseNumberState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
612
- = state => input => {
613
- switch (state.numberKind) {
614
- case 'e': return [empty, { kind: 'number', value: appendChar(state.value)(input), b: state.b, numberKind: 'e+' }]
615
- default: return tokenizeOp({ kind: 'invalidNumber' })(input)
616
- }
617
- }
618
-
619
- const terminalToToken
620
- : (state: ParseNumberState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
621
- = state => input => {
622
- switch (state.numberKind) {
623
- case '.':
624
- case 'e':
625
- case 'e+':
626
- case 'e-':
627
- {
628
- const next = tokenizeOp({ kind: 'initial' })(input)
629
- return [{ first: { kind: 'error', message: 'invalid number' }, tail: next[0] }, next[1]]
630
- }
631
- default:
632
- {
633
- const next = tokenizeOp({ kind: 'initial' })(input)
634
- return [{ first: bufferToNumberToken(state), tail: next[0] }, next[1]]
635
- }
636
- }
637
- }
638
-
639
- const bigintToToken
640
- : (state: ParseNumberState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
641
- = state => input => {
642
- switch (state.numberKind) {
643
- case '0':
644
- case 'int':
645
- {
646
- return [empty, { kind: 'number', value: state.value, b: state.b, numberKind: 'bigint' }]
647
- }
648
- default:
649
- {
650
- const next = tokenizeOp({ kind: 'initial' })(input)
651
- return [{ first: { kind: 'error', message: 'invalid number' }, tail: next[0] }, next[1]]
652
- }
653
- }
654
- }
655
-
656
- const parseNumberStateOp
657
- : (state: ParseNumberState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
658
- = create(invalidNumberToToken)([
659
- rangeFunc<ParseNumberState>(one(fullStop))(fullStopToToken),
660
- rangeFunc<ParseNumberState>(one(digit0))(digit0ToToken),
661
- rangeFunc<ParseNumberState>(rangeOneNine)(digit19ToToken),
662
- rangeSetFunc<ParseNumberState>([one(latinSmallLetterE), one(latinCapitalLetterE)])(expToToken),
663
- rangeFunc<ParseNumberState>(one(hyphenMinus))(hyphenMinusToToken),
664
- rangeFunc<ParseNumberState>(one(plusSign))(plusSignToToken),
665
- rangeSetFunc<ParseNumberState>(rangeSetTerminalForNumber)(terminalToToken),
666
- rangeFunc<ParseNumberState>(one(latinSmallLetterN))(bigintToToken),
667
- ])
668
-
669
- const invalidNumberStateOp
670
- : (state: InvalidNumberState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
671
- = create(() => () => [empty, { kind: 'invalidNumber' }])([
672
- rangeSetFunc(rangeSetTerminalForNumber)(() => input => {
673
- const next = tokenizeOp({ kind: 'initial' })(input)
674
- return [{ first: { kind: 'error', message: 'invalid number' }, tail: next[0] }, next[1]]
675
- })
676
- ])
677
-
678
- const parseStringStateOp
679
- : (state: ParseStringState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
680
- = create((state: ParseStringState) => input => [empty, { kind: 'string', value: appendChar(state.value)(input) }])([
681
- rangeFunc<ParseStringState>(one(quotationMark))(state => () => [[{ kind: 'string', value: state.value }], { kind: 'initial' }]),
682
- rangeFunc<ParseStringState>(one(reverseSolidus))(state => () => [empty, { kind: 'escapeChar', value: state.value }]),
683
- rangeSetFunc<ParseStringState>(rangeSetNewLine)(() => () => [[{ kind: 'error', message: 'unterminated string literal'}], { kind: 'nl'}])
684
- ])
685
-
686
- const parseEscapeDefault
687
- : (state: ParseEscapeCharState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
688
- = state => input => {
689
- const next = tokenizeOp({ kind: 'string', value: state.value })(input)
690
- return [{ first: { kind: 'error', message: 'unescaped character' }, tail: next[0] }, next[1]]
691
- }
692
-
693
- const parseEscapeCharStateOp
694
- : (state: ParseEscapeCharState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
695
- = create(parseEscapeDefault)([
696
- rangeSetFunc<ParseEscapeCharState>([one(quotationMark), one(reverseSolidus), one(solidus)])(state => input => [empty, { kind: 'string', value: appendChar(state.value)(input) }]),
697
- rangeFunc<ParseEscapeCharState>(one(latinSmallLetterB))(state => () => [empty, { kind: 'string', value: appendChar(state.value)(backspace) }]),
698
- rangeFunc<ParseEscapeCharState>(one(latinSmallLetterF))(state => () => [empty, { kind: 'string', value: appendChar(state.value)(ff) }]),
699
- rangeFunc<ParseEscapeCharState>(one(latinSmallLetterN))(state => () => [empty, { kind: 'string', value: appendChar(state.value)(lf) }]),
700
- rangeFunc<ParseEscapeCharState>(one(latinSmallLetterR))(state => () => [empty, { kind: 'string', value: appendChar(state.value)(cr) }]),
701
- rangeFunc<ParseEscapeCharState>(one(latinSmallLetterT))(state => () => [empty, { kind: 'string', value: appendChar(state.value)(ht) }]),
702
- rangeFunc<ParseEscapeCharState>(one(latinSmallLetterU))(state => () => [empty, { kind: 'unicodeChar', value: state.value, unicode: 0, hexIndex: 0 }]),
703
- ])
704
-
705
- const parseUnicodeCharDefault
706
- : (state: ParseUnicodeCharState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
707
- = state => input => {
708
- const next = tokenizeOp({ kind: 'string', value: state.value })(input)
709
- return [{ first: { kind: 'error', message: 'invalid hex value' }, tail: next[0] }, next[1]]
710
- }
711
-
712
- const parseUnicodeCharHex
713
- : (offser: number) => (state: ParseUnicodeCharState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
714
- = offset => state => input => {
715
- const hexValue = input - offset
716
- const newUnicode = state.unicode | (hexValue << (3 - state.hexIndex) * 4)
717
- return [empty, state.hexIndex === 3 ?
718
- { kind: 'string', value: appendChar(state.value)(newUnicode) } :
719
- { kind: 'unicodeChar', value: state.value, unicode: newUnicode, hexIndex: state.hexIndex + 1 }]
720
- }
721
-
722
- const parseUnicodeCharStateOp
723
- : (state: ParseUnicodeCharState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
724
- = create(parseUnicodeCharDefault)([
725
- rangeFunc<ParseUnicodeCharState>(digitRange)(parseUnicodeCharHex(digit0)),
726
- rangeFunc<ParseUnicodeCharState>(rangeSmallAF)(parseUnicodeCharHex(latinSmallLetterA - 10)),
727
- rangeFunc<ParseUnicodeCharState>(rangeCapitalAF)(parseUnicodeCharHex(latinCapitalLetterA - 10))
728
- ])
729
-
730
- const idToToken
731
- : (s: string) => JsToken
732
- = s => at(s)(keywordMap) ?? { kind: 'id', value: s }
733
-
734
- const parseIdDefault
735
- : (state: ParseIdState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
736
- = state => input => {
737
- const keyWordToken = idToToken(state.value)
738
- const next = tokenizeOp({ kind: 'initial' })(input)
739
- return [{ first: keyWordToken, tail: next[0] }, next[1]]
740
- }
741
-
742
- const parseIdStateOp
743
- : (state: ParseIdState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
744
- = create(parseIdDefault)([
745
- rangeSetFunc<ParseIdState>(rangeId)(state => input => [empty, { kind: 'id', value: appendChar(state.value)(input) }])
746
- ])
747
-
748
- const parseOperatorStateOp
749
- : (state: ParseOperatorState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
750
- = state => input => {
751
- const nextStateValue = appendChar(state.value)(input)
752
- switch (nextStateValue)
753
- {
754
- case '//': return [empty, { kind: '//', value: '', newLine: false }]
755
- case '/*': return [empty, { kind: '/*', value: '', newLine: false }]
756
- default: {
757
- if (hasOperatorToken(nextStateValue))
758
- return [empty, { kind: 'op', value: nextStateValue }]
759
- const next = tokenizeOp({ kind: 'initial' })(input)
760
- return [{ first: getOperatorToken(state.value), tail: next[0] }, next[1]]
761
- }
762
- }
763
- }
764
-
765
- const parseSinglelineCommentStateOp
766
- : (state: ParseCommentState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
767
- = create((state: ParseCommentState) => input => [empty, { ...state, value: appendChar(state.value)(input) }])([
768
- rangeSetFunc<ParseCommentState>(rangeSetNewLine)(state => () => [[{ kind: '//', value: state.value }], { kind: 'nl' }])
769
- ])
770
-
771
- const parseMultilineCommentStateOp
772
- : (state: ParseCommentState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
773
- = create((state: ParseCommentState) => input => [empty, { ...state, value: appendChar(state.value)(input) }])([
774
- rangeFunc<ParseCommentState>(one(asterisk))(state => () => [empty, { ...state, kind: '/**' }]),
775
- rangeSetFunc<ParseCommentState>(rangeSetNewLine)(state => input => [empty, { ...state, value: appendChar(state.value)(input), newLine: true }]),
776
- ])
777
-
778
- const parseMultilineCommentAsteriskStateOp
779
- : (state: ParseCommentState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
780
- = create((state: ParseCommentState) => input => [empty, { ...state, kind: '/*', value: appendChar(appendChar(state.value)(asterisk))(input)}])([
781
- rangeFunc<ParseCommentState>(one(asterisk))(state => () => [empty, { ...state, value: appendChar(state.value)(asterisk) }]),
782
- rangeSetFunc<ParseCommentState>(rangeSetNewLine)(state => input => [empty, { kind: '/*', value: appendChar(appendChar(state.value)(asterisk))(input), newLine: true }]),
783
- rangeFunc<ParseCommentState>(one(solidus))(state => () => {
784
- const tokens
785
- : list.List<JsToken>
786
- = state.newLine ? [{ kind: '/*', value: state.value }, { kind: 'nl' }] : [{ kind: '/*', value: state.value }]
787
- return [tokens, { kind: 'initial' }]
788
- })
789
- ])
790
-
791
- const parseWhitespaceDefault
792
- : (state: ParseWhitespaceState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
793
- = () => input => {
794
- const next = tokenizeOp({ kind: 'initial' })(input)
795
- return [{ first: { kind: 'ws' }, tail: next[0] }, next[1]]
796
- }
797
-
798
- const parseWhitespaceStateOp
799
- : (state: ParseWhitespaceState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
800
- = create(parseWhitespaceDefault)([
801
- rangeSetFunc<ParseWhitespaceState>(rangeSetWhiteSpace)(state => () => [empty, state]),
802
- rangeSetFunc<ParseWhitespaceState>(rangeSetNewLine)(() => () => [empty, { kind: 'nl' }])
803
- ])
804
-
805
- const parseNewLineDefault
806
- : (state: ParseNewLineState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
807
- = state => input => {
808
- const next = tokenizeOp({ kind: 'initial' })(input)
809
- return [{ first: { kind: 'nl' }, tail: next[0] }, next[1]]
810
- }
811
-
812
- const parseNewLineStateOp
813
- : (state: ParseNewLineState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
814
- = create(parseNewLineDefault)([
815
- rangeSetFunc<ParseNewLineState>(rangeSetWhiteSpace)(state => () => [empty, state]),
816
- rangeSetFunc<ParseNewLineState>(rangeSetNewLine)(state => () => [empty, state])
817
- ])
818
-
819
- const eofStateOp
820
- : (state: EofState) => (input: number) => readonly[list.List<JsToken>, TokenizerState]
821
- = create((state: EofState) => () => [[{ kind: 'error', message: 'eof' }], state])([])
822
-
823
- const tokenizeCharCodeOp
824
- :operator.StateScan<number, TokenizerState, list.List<JsToken>>
825
- = state => {
826
- switch (state.kind) {
827
- case 'initial': return initialStateOp(state)
828
- case 'id': return parseIdStateOp(state)
829
- case 'string': return parseStringStateOp(state)
830
- case 'escapeChar': return parseEscapeCharStateOp(state)
831
- case 'unicodeChar': return parseUnicodeCharStateOp(state)
832
- case 'invalidNumber': return invalidNumberStateOp(state)
833
- case 'number': return parseNumberStateOp(state)
834
- case 'op': return parseOperatorStateOp(state)
835
- case '//': return parseSinglelineCommentStateOp(state)
836
- case '/*': return parseMultilineCommentStateOp(state)
837
- case '/**': return parseMultilineCommentAsteriskStateOp(state)
838
- case 'ws': return parseWhitespaceStateOp(state)
839
- case 'nl': return parseNewLineStateOp(state)
840
- case 'eof': return eofStateOp(state)
841
- }
842
- }
843
-
844
- const tokenizeEofOp
845
- : (state: TokenizerState) => readonly[list.List<JsToken>, TokenizerState]
846
- = state => {
847
- switch (state.kind) {
848
- case 'initial': return [empty, { kind: 'eof' }]
849
- case 'id': return [[idToToken(state.value)], { kind: 'eof' }]
850
- case 'string':
851
- case 'escapeChar':
852
- case 'unicodeChar': return [[{ kind: 'error', message: '" are missing' }], { kind: 'eof' }]
853
- case 'invalidNumber': return [[{ kind: 'error', message: 'invalid number' }], { kind: 'eof' }]
854
- case 'number':
855
- switch (state.numberKind) {
856
- case '.':
857
- case 'e':
858
- case 'e+':
859
- case 'e-': return [[{ kind: 'error', message: 'invalid number' }], { kind: 'eof', }]
860
- default: return [[bufferToNumberToken(state)], { kind: 'eof' }]
861
- }
862
- case 'op': return [[getOperatorToken(state.value)], { kind: 'eof' }]
863
- case '//': return [[{kind: '//', value: state.value}], { kind: 'eof' }]
864
- case '/*':
865
- case '/**': return [[{ kind: 'error', message: '*/ expected' }], { kind: 'eof', }]
866
- case 'ws': return [[{kind: 'ws'}], { kind: 'eof' }]
867
- case 'nl': return [[{kind: 'nl'}], { kind: 'eof' }]
868
- case 'eof': return [[{ kind: 'error', message: 'eof' }], state]
869
- }
870
- }
871
-
872
- const tokenizeOp
873
- : operator.StateScan<CharCodeOrEof, TokenizerState, list.List<JsToken>>
874
- = state => input => input === null ? tokenizeEofOp(state) : tokenizeCharCodeOp(state)(input)
875
-
876
- const scanTokenize = stateScan(tokenizeOp)
877
-
878
- const initial = scanTokenize({ kind: 'initial' })
879
-
880
- export const tokenize
881
- = (input: list.List<number>): list.List<JsToken> =>
882
- flat(initial(flat<number|null>([input satisfies list.List<CharCodeOrEof>, [null]])))