functionalscript 0.2.0 → 0.2.2

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 (248) hide show
  1. package/dev/module.mjs +1 -1
  2. package/jsr.json +59 -59
  3. package/out/com/cpp/module.f.mjs +123 -0
  4. package/out/com/cpp/test.f.mjs +40 -0
  5. package/out/com/cpp/testlib.f.mjs +7 -0
  6. package/out/com/cs/module.f.mjs +95 -0
  7. package/out/com/cs/test.f.mjs +43 -0
  8. package/out/com/cs/testlib.f.mjs +7 -0
  9. package/out/com/rust/module.f.mjs +213 -0
  10. package/out/com/rust/test.f.mjs +123 -0
  11. package/out/com/rust/testlib.f.mjs +7 -0
  12. package/out/com/test/build.f.mjs +98 -0
  13. package/out/com/test/build.mjs +40 -0
  14. package/out/com/types/module.f.mjs +51 -0
  15. package/out/com/types/testlib.f.mjs +30 -0
  16. package/out/commonjs/build/module.f.mjs +107 -0
  17. package/out/commonjs/build/test.f.mjs +102 -0
  18. package/out/commonjs/module/function/module.f.mjs +15 -0
  19. package/out/commonjs/module/module.f.mjs +48 -0
  20. package/out/commonjs/module.f.mjs +10 -0
  21. package/out/commonjs/module.mjs +26 -0
  22. package/out/commonjs/package/dependencies/module.f.mjs +21 -0
  23. package/out/commonjs/package/dependencies/test.f.mjs +15 -0
  24. package/out/commonjs/package/module.f.mjs +40 -0
  25. package/out/commonjs/package/test.f.mjs +27 -0
  26. package/out/commonjs/path/module.f.mjs +171 -0
  27. package/out/commonjs/path/test.f.mjs +231 -0
  28. package/out/commonjs/test.mjs +87 -0
  29. package/out/dev/index.mjs +2 -0
  30. package/out/dev/module.f.mjs +2 -0
  31. package/out/dev/module.mjs +167 -0
  32. package/out/dev/test/module.f.mjs +134 -0
  33. package/out/dev/test.f.mjs +58 -0
  34. package/out/dev/test.mjs +52 -0
  35. package/out/djs/module.f.mjs +75 -0
  36. package/out/djs/parser/module.f.mjs +432 -0
  37. package/out/djs/parser/test.f.mjs +535 -0
  38. package/out/djs/test.f.mjs +84 -0
  39. package/out/djs/tokenizer/module.f.mjs +87 -0
  40. package/out/djs/tokenizer/test.f.mjs +480 -0
  41. package/out/fsc/module.f.mjs +105 -0
  42. package/out/fsc/test.f.mjs +19 -0
  43. package/out/fsm/module.f.mjs +80 -0
  44. package/out/fsm/test.f.mjs +138 -0
  45. package/out/html/module.f.mjs +94 -0
  46. package/out/html/test.f.mjs +45 -0
  47. package/out/issues/test.f.mjs +66 -0
  48. package/out/js/tokenizer/module.f.mjs +686 -0
  49. package/out/js/tokenizer/test.f.mjs +844 -0
  50. package/out/json/module.f.mjs +89 -0
  51. package/out/json/parser/module.f.mjs +224 -0
  52. package/out/json/parser/test.f.mjs +321 -0
  53. package/out/json/serializer/module.f.mjs +67 -0
  54. package/out/json/serializer/test.f.mjs +87 -0
  55. package/out/json/test.f.mjs +61 -0
  56. package/out/json/tokenizer/module.f.mjs +78 -0
  57. package/out/json/tokenizer/test.f.mjs +420 -0
  58. package/out/nanvm-lib/tests/test.f.mjs +87 -0
  59. package/out/nodejs/version/main.mjs +3 -0
  60. package/out/nodejs/version/module.f.mjs +34 -0
  61. package/out/nodejs/version/test.f.mjs +97 -0
  62. package/out/prime_field/module.f.mjs +87 -0
  63. package/out/prime_field/test.f.mjs +145 -0
  64. package/out/secp/module.f.mjs +113 -0
  65. package/out/secp/test.f.mjs +63 -0
  66. package/out/sha2/module.f.mjs +172 -0
  67. package/out/sha2/test.f.mjs +86 -0
  68. package/out/text/ascii/module.f.mjs +154 -0
  69. package/out/text/ascii/test.f.mjs +14 -0
  70. package/out/text/module.f.mjs +19 -0
  71. package/out/text/sgr/module.f.mjs +17 -0
  72. package/out/text/test.f.mjs +19 -0
  73. package/out/text/utf16/module.f.mjs +86 -0
  74. package/out/text/utf16/test.f.mjs +145 -0
  75. package/out/text/utf8/module.f.mjs +126 -0
  76. package/out/text/utf8/test.f.mjs +175 -0
  77. package/out/types/array/module.f.mjs +95 -0
  78. package/out/types/array/test.f.mjs +116 -0
  79. package/out/types/bigfloat/module.f.mjs +77 -0
  80. package/out/types/bigfloat/test.f.mjs +349 -0
  81. package/out/types/bigint/module.f.mjs +114 -0
  82. package/out/types/bigint/test.f.mjs +192 -0
  83. package/out/types/btree/find/module.f.mjs +137 -0
  84. package/out/types/btree/find/test.f.mjs +156 -0
  85. package/out/types/btree/module.f.mjs +34 -0
  86. package/out/types/btree/remove/module.f.mjs +209 -0
  87. package/out/types/btree/remove/test.f.mjs +638 -0
  88. package/out/types/btree/set/module.f.mjs +114 -0
  89. package/out/types/btree/set/test.f.mjs +390 -0
  90. package/out/types/btree/test.f.mjs +83 -0
  91. package/out/types/btree/types/module.f.mjs +50 -0
  92. package/out/types/byte_set/module.f.mjs +42 -0
  93. package/out/types/byte_set/test.f.mjs +123 -0
  94. package/out/types/function/compare/module.f.mjs +22 -0
  95. package/out/types/function/compare/test.f.mjs +8 -0
  96. package/out/types/function/module.f.mjs +44 -0
  97. package/out/types/function/operator/module.f.mjs +60 -0
  98. package/out/types/function/test.f.mjs +15 -0
  99. package/out/types/list/module.f.mjs +269 -0
  100. package/out/types/list/test.f.mjs +401 -0
  101. package/out/types/map/module.f.mjs +54 -0
  102. package/out/types/map/test.f.mjs +115 -0
  103. package/out/types/nibble_set/module.f.mjs +19 -0
  104. package/out/types/nibble_set/test.f.mjs +90 -0
  105. package/out/types/nullable/module.f.mjs +9 -0
  106. package/out/types/nullable/test.f.mjs +12 -0
  107. package/out/types/number/module.f.mjs +12 -0
  108. package/out/types/number/test.f.mjs +126 -0
  109. package/out/types/object/module.f.mjs +27 -0
  110. package/out/types/object/test.f.mjs +17 -0
  111. package/out/types/range/module.f.mjs +6 -0
  112. package/out/types/range/test.f.mjs +18 -0
  113. package/out/types/range_map/module.f.mjs +84 -0
  114. package/out/types/range_map/test.f.mjs +201 -0
  115. package/out/types/result/module.f.mjs +25 -0
  116. package/out/types/result/module.mjs +16 -0
  117. package/out/types/sorted_list/module.f.mjs +102 -0
  118. package/out/types/sorted_list/test.f.mjs +66 -0
  119. package/out/types/sorted_set/module.f.mjs +29 -0
  120. package/out/types/sorted_set/test.f.mjs +80 -0
  121. package/out/types/string/module.f.mjs +17 -0
  122. package/out/types/string/test.f.mjs +58 -0
  123. package/out/types/string_set/module.f.mjs +29 -0
  124. package/out/types/string_set/test.f.mjs +65 -0
  125. package/package.json +5 -4
  126. package/tsconfig.json +2 -2
  127. /package/{com → out/com}/cpp/module.f.d.mts +0 -0
  128. /package/{com → out/com}/cpp/test.f.d.mts +0 -0
  129. /package/{com → out/com}/cpp/testlib.f.d.mts +0 -0
  130. /package/{com → out/com}/cs/module.f.d.mts +0 -0
  131. /package/{com → out/com}/cs/test.f.d.mts +0 -0
  132. /package/{com → out/com}/cs/testlib.f.d.mts +0 -0
  133. /package/{com → out/com}/rust/module.f.d.mts +0 -0
  134. /package/{com → out/com}/rust/test.f.d.mts +0 -0
  135. /package/{com → out/com}/rust/testlib.f.d.mts +0 -0
  136. /package/{com → out/com}/test/build.d.mts +0 -0
  137. /package/{com → out/com}/test/build.f.d.mts +0 -0
  138. /package/{com → out/com}/types/module.f.d.mts +0 -0
  139. /package/{com → out/com}/types/testlib.f.d.mts +0 -0
  140. /package/{commonjs → out/commonjs}/build/module.f.d.mts +0 -0
  141. /package/{commonjs → out/commonjs}/build/test.f.d.mts +0 -0
  142. /package/{commonjs → out/commonjs}/module/function/module.f.d.mts +0 -0
  143. /package/{commonjs → out/commonjs}/module/module.f.d.mts +0 -0
  144. /package/{commonjs → out/commonjs}/module.d.mts +0 -0
  145. /package/{commonjs → out/commonjs}/module.f.d.mts +0 -0
  146. /package/{commonjs → out/commonjs}/package/dependencies/module.f.d.mts +0 -0
  147. /package/{commonjs → out/commonjs}/package/dependencies/test.f.d.mts +0 -0
  148. /package/{commonjs → out/commonjs}/package/module.f.d.mts +0 -0
  149. /package/{commonjs → out/commonjs}/package/test.f.d.mts +0 -0
  150. /package/{commonjs → out/commonjs}/path/module.f.d.mts +0 -0
  151. /package/{commonjs → out/commonjs}/path/test.f.d.mts +0 -0
  152. /package/{commonjs → out/commonjs}/test.d.mts +0 -0
  153. /package/{dev → out/dev}/index.d.mts +0 -0
  154. /package/{dev → out/dev}/module.d.mts +0 -0
  155. /package/{dev → out/dev}/module.f.d.mts +0 -0
  156. /package/{dev → out/dev}/test/module.f.d.mts +0 -0
  157. /package/{dev → out/dev}/test.d.mts +0 -0
  158. /package/{dev → out/dev}/test.f.d.mts +0 -0
  159. /package/{djs → out/djs}/module.f.d.mts +0 -0
  160. /package/{djs → out/djs}/parser/module.f.d.mts +0 -0
  161. /package/{djs → out/djs}/parser/test.f.d.mts +0 -0
  162. /package/{djs → out/djs}/test.f.d.mts +0 -0
  163. /package/{djs → out/djs}/tokenizer/module.f.d.mts +0 -0
  164. /package/{djs → out/djs}/tokenizer/test.f.d.mts +0 -0
  165. /package/{fsc → out/fsc}/module.f.d.mts +0 -0
  166. /package/{fsc → out/fsc}/test.f.d.mts +0 -0
  167. /package/{fsm → out/fsm}/module.f.d.mts +0 -0
  168. /package/{fsm → out/fsm}/test.f.d.mts +0 -0
  169. /package/{html → out/html}/module.f.d.mts +0 -0
  170. /package/{html → out/html}/test.f.d.mts +0 -0
  171. /package/{issues → out/issues}/test.f.d.mts +0 -0
  172. /package/{js → out/js}/tokenizer/module.f.d.mts +0 -0
  173. /package/{js → out/js}/tokenizer/test.f.d.mts +0 -0
  174. /package/{json → out/json}/module.f.d.mts +0 -0
  175. /package/{json → out/json}/parser/module.f.d.mts +0 -0
  176. /package/{json → out/json}/parser/test.f.d.mts +0 -0
  177. /package/{json → out/json}/serializer/module.f.d.mts +0 -0
  178. /package/{json → out/json}/serializer/test.f.d.mts +0 -0
  179. /package/{json → out/json}/test.f.d.mts +0 -0
  180. /package/{json → out/json}/tokenizer/module.f.d.mts +0 -0
  181. /package/{json → out/json}/tokenizer/test.f.d.mts +0 -0
  182. /package/{nanvm-lib → out/nanvm-lib}/tests/test.f.d.mts +0 -0
  183. /package/{nodejs → out/nodejs}/version/main.d.mts +0 -0
  184. /package/{nodejs → out/nodejs}/version/module.f.d.mts +0 -0
  185. /package/{nodejs → out/nodejs}/version/test.f.d.mts +0 -0
  186. /package/{prime_field → out/prime_field}/module.f.d.mts +0 -0
  187. /package/{prime_field → out/prime_field}/test.f.d.mts +0 -0
  188. /package/{secp → out/secp}/module.f.d.mts +0 -0
  189. /package/{secp → out/secp}/test.f.d.mts +0 -0
  190. /package/{sha2 → out/sha2}/module.f.d.mts +0 -0
  191. /package/{sha2 → out/sha2}/test.f.d.mts +0 -0
  192. /package/{text → out/text}/ascii/module.f.d.mts +0 -0
  193. /package/{text → out/text}/ascii/test.f.d.mts +0 -0
  194. /package/{text → out/text}/module.f.d.mts +0 -0
  195. /package/{text → out/text}/sgr/module.f.d.mts +0 -0
  196. /package/{text → out/text}/test.f.d.mts +0 -0
  197. /package/{text → out/text}/utf16/module.f.d.mts +0 -0
  198. /package/{text → out/text}/utf16/test.f.d.mts +0 -0
  199. /package/{text → out/text}/utf8/module.f.d.mts +0 -0
  200. /package/{text → out/text}/utf8/test.f.d.mts +0 -0
  201. /package/{types → out/types}/array/module.f.d.mts +0 -0
  202. /package/{types → out/types}/array/test.f.d.mts +0 -0
  203. /package/{types → out/types}/bigfloat/module.f.d.mts +0 -0
  204. /package/{types → out/types}/bigfloat/test.f.d.mts +0 -0
  205. /package/{types → out/types}/bigint/module.f.d.mts +0 -0
  206. /package/{types → out/types}/bigint/test.f.d.mts +0 -0
  207. /package/{types → out/types}/btree/find/module.f.d.mts +0 -0
  208. /package/{types → out/types}/btree/find/test.f.d.mts +0 -0
  209. /package/{types → out/types}/btree/module.f.d.mts +0 -0
  210. /package/{types → out/types}/btree/remove/module.f.d.mts +0 -0
  211. /package/{types → out/types}/btree/remove/test.f.d.mts +0 -0
  212. /package/{types → out/types}/btree/set/module.f.d.mts +0 -0
  213. /package/{types → out/types}/btree/set/test.f.d.mts +0 -0
  214. /package/{types → out/types}/btree/test.f.d.mts +0 -0
  215. /package/{types → out/types}/btree/types/module.f.d.mts +0 -0
  216. /package/{types → out/types}/byte_set/module.f.d.mts +0 -0
  217. /package/{types → out/types}/byte_set/test.f.d.mts +0 -0
  218. /package/{types → out/types}/function/compare/module.f.d.mts +0 -0
  219. /package/{types → out/types}/function/compare/test.f.d.mts +0 -0
  220. /package/{types → out/types}/function/module.f.d.mts +0 -0
  221. /package/{types → out/types}/function/operator/module.f.d.mts +0 -0
  222. /package/{types → out/types}/function/test.f.d.mts +0 -0
  223. /package/{types → out/types}/list/module.f.d.mts +0 -0
  224. /package/{types → out/types}/list/test.f.d.mts +0 -0
  225. /package/{types → out/types}/map/module.f.d.mts +0 -0
  226. /package/{types → out/types}/map/test.f.d.mts +0 -0
  227. /package/{types → out/types}/nibble_set/module.f.d.mts +0 -0
  228. /package/{types → out/types}/nibble_set/test.f.d.mts +0 -0
  229. /package/{types → out/types}/nullable/module.f.d.mts +0 -0
  230. /package/{types → out/types}/nullable/test.f.d.mts +0 -0
  231. /package/{types → out/types}/number/module.f.d.mts +0 -0
  232. /package/{types → out/types}/number/test.f.d.mts +0 -0
  233. /package/{types → out/types}/object/module.f.d.mts +0 -0
  234. /package/{types → out/types}/object/test.f.d.mts +0 -0
  235. /package/{types → out/types}/range/module.f.d.mts +0 -0
  236. /package/{types → out/types}/range/test.f.d.mts +0 -0
  237. /package/{types → out/types}/range_map/module.f.d.mts +0 -0
  238. /package/{types → out/types}/range_map/test.f.d.mts +0 -0
  239. /package/{types → out/types}/result/module.d.mts +0 -0
  240. /package/{types → out/types}/result/module.f.d.mts +0 -0
  241. /package/{types → out/types}/sorted_list/module.f.d.mts +0 -0
  242. /package/{types → out/types}/sorted_list/test.f.d.mts +0 -0
  243. /package/{types → out/types}/sorted_set/module.f.d.mts +0 -0
  244. /package/{types → out/types}/sorted_set/test.f.d.mts +0 -0
  245. /package/{types → out/types}/string/module.f.d.mts +0 -0
  246. /package/{types → out/types}/string/test.f.d.mts +0 -0
  247. /package/{types → out/types}/string_set/module.f.d.mts +0 -0
  248. /package/{types → out/types}/string_set/test.f.d.mts +0 -0
@@ -0,0 +1,89 @@
1
+ // @ts-self-types="./module.f.d.mts"
2
+ import * as list from '../types/list/module.f.mjs';
3
+ const { next, flat, map } = list;
4
+ import * as string from '../types/string/module.f.mjs';
5
+ const { concat } = string;
6
+ import * as object from '../types/object/module.f.mjs';
7
+ const { at } = object;
8
+ import * as f from '../types/function/module.f.mjs';
9
+ const { compose, fn } = f;
10
+ const { entries } = Object;
11
+ import * as s from './serializer/module.f.mjs';
12
+ const { objectWrap, arrayWrap, stringSerialize, numberSerialize, nullSerialize, boolSerialize } = s;
13
+ /**
14
+ * @typedef {{
15
+ * readonly [k in string]: Unknown
16
+ * }} Object
17
+ */
18
+ /** @typedef {readonly Unknown[]} Array */
19
+ /** @typedef {Object|boolean|string|number|null|Array} Unknown */
20
+ /** @type {(value: Unknown) => (path: list.List<string>) => (src: Unknown) => Unknown} */
21
+ export const setProperty = value => {
22
+ /** @type {(path: list.List<string>) => (src: Unknown) => Unknown} */
23
+ const f = path => src => {
24
+ const result = next(path);
25
+ if (result === null) {
26
+ return value;
27
+ }
28
+ const srcObject = (src === null || typeof src !== 'object' || src instanceof Array) ? {} : src;
29
+ const { first, tail } = result;
30
+ return { ...srcObject, [first]: f(tail)(at(first)(srcObject)) };
31
+ };
32
+ return f;
33
+ };
34
+ const colon = [':'];
35
+ /** @typedef {object.Entry<Unknown>} Entry*/
36
+ /** @typedef {(list.List<Entry>)} Entries */
37
+ /** @typedef {(entries: Entries) => Entries} MapEntries */
38
+ /** @type {(mapEntries: MapEntries) => (value: Unknown) => list.List<string>} */
39
+ export const serialize = sort => {
40
+ /** @type {(kv: readonly[string, Unknown]) => list.List<string>} */
41
+ const propertySerialize = ([k, v]) => flat([
42
+ stringSerialize(k),
43
+ colon,
44
+ f(v)
45
+ ]);
46
+ const mapPropertySerialize = map(propertySerialize);
47
+ /** @type {(object: Object) => list.List<string>} */
48
+ const objectSerialize = fn(entries)
49
+ .then(sort)
50
+ .then(mapPropertySerialize)
51
+ .then(objectWrap)
52
+ .result;
53
+ /** @type {(value: Unknown) => list.List<string>} */
54
+ const f = value => {
55
+ switch (typeof value) {
56
+ case 'boolean': {
57
+ return boolSerialize(value);
58
+ }
59
+ case 'number': {
60
+ return numberSerialize(value);
61
+ }
62
+ case 'string': {
63
+ return stringSerialize(value);
64
+ }
65
+ default: {
66
+ if (value === null) {
67
+ return nullSerialize;
68
+ }
69
+ if (value instanceof Array) {
70
+ return arraySerialize(value);
71
+ }
72
+ return objectSerialize(value);
73
+ }
74
+ }
75
+ };
76
+ const arraySerialize = compose(map(f))(arrayWrap);
77
+ return f;
78
+ };
79
+ /**
80
+ * The standard `JSON.stringify` rules determined by
81
+ * https://262.ecma-international.org/6.0/#sec-ordinary-object-internal-methods-and-internal-slots-ownpropertykeys
82
+ *
83
+ * @type {(mapEntries: MapEntries) => (value: Unknown) => string}
84
+ */
85
+ export const stringify = sort => compose(serialize(sort))(concat);
86
+ /** @type {(value: string) => Unknown} */
87
+ export const parse = JSON.parse;
88
+ /** @type {(value: Unknown) => value is Object} */
89
+ export const isObject = value => typeof value === 'object' && value !== null && !(value instanceof Array);
@@ -0,0 +1,224 @@
1
+ // @ts-self-types="./module.f.d.mts"
2
+ import * as result from '../../types/result/module.f.mjs';
3
+ import * as list from '../../types/list/module.f.mjs';
4
+ const { fold, first, drop, toArray } = list;
5
+ import * as Operator from '../../types/function/operator/module.f.mjs';
6
+ import * as Tokenizer from '../tokenizer/module.f.mjs';
7
+ import * as map from '../../types/map/module.f.mjs';
8
+ const { setReplace } = map;
9
+ import * as Json from '../module.f.mjs';
10
+ import * as o from '../../types/object/module.f.mjs';
11
+ const { fromMap } = o;
12
+ /**
13
+ * @typedef {{
14
+ * readonly kind: 'object'
15
+ * readonly values: map.Map<Json.Unknown>
16
+ * readonly key: string
17
+ * }} JsonObject
18
+ * */
19
+ /**
20
+ * @typedef {{
21
+ * readonly kind: 'array'
22
+ * readonly values: list.List<Json.Unknown>
23
+ * }} JsonArray
24
+ * */
25
+ /**
26
+ * @typedef {|
27
+ * JsonObject |
28
+ * JsonArray
29
+ * } JsonStackElement
30
+ */
31
+ /** @typedef {list.List<JsonStackElement>} JsonStack */
32
+ /**
33
+ * @typedef {{
34
+ * readonly status: '' | '[' | '[v' | '[,' | '{' | '{k' | '{:' | '{v' | '{,'
35
+ * readonly top: JsonStackElement | null
36
+ * readonly stack: JsonStack
37
+ * }} StateParse
38
+ */
39
+ /**
40
+ * @typedef {{
41
+ * readonly status: 'result'
42
+ * readonly value: Json.Unknown
43
+ * }} StateResult
44
+ */
45
+ /**
46
+ * @typedef {{
47
+ * readonly status: 'error'
48
+ * readonly message: string
49
+ * }} StateError
50
+ */
51
+ /**
52
+ * @typedef {|
53
+ * StateParse |
54
+ * StateResult |
55
+ * StateError
56
+ * } JsonState
57
+ */
58
+ /** @type {(obj: JsonObject) => (key: string) => JsonObject} */
59
+ const addKeyToObject = obj => key => ({ kind: 'object', values: obj.values, key: key });
60
+ /** @type {(obj: JsonObject) => (value: Json.Unknown) => JsonObject} */
61
+ const addValueToObject = obj => value => ({ kind: 'object', values: setReplace(obj.key)(value)(obj.values), key: '' });
62
+ /** @type {(array: JsonArray) => (value: Json.Unknown) => JsonArray} */
63
+ const addToArray = array => value => ({ kind: 'array', values: list.concat(array.values)([value]) });
64
+ /** @type {(state: StateParse) => (key: string) => JsonState} */
65
+ const pushKey = state => value => {
66
+ if (state.top?.kind === 'object') {
67
+ return { status: '{k', top: addKeyToObject(state.top)(value), stack: state.stack };
68
+ }
69
+ return { status: 'error', message: 'error' };
70
+ };
71
+ /** @type {(state: StateParse) => (value: Json.Unknown) => JsonState} */
72
+ const pushValue = state => value => {
73
+ if (state.top === null) {
74
+ return { status: 'result', value: value };
75
+ }
76
+ if (state.top.kind === 'array') {
77
+ return { status: '[v', top: addToArray(state.top)(value), stack: state.stack };
78
+ }
79
+ return { status: '{v', top: addValueToObject(state.top)(value), stack: state.stack };
80
+ };
81
+ /** @type {(state: StateParse) => JsonState} */
82
+ const startArray = state => {
83
+ const newStack = state.top === null ? null : { first: state.top, tail: state.stack };
84
+ return { status: '[', top: { kind: 'array', values: null }, stack: newStack };
85
+ };
86
+ /** @type {(state: StateParse) => JsonState} */
87
+ const endArray = state => {
88
+ const array = state.top !== null ? toArray(state.top.values) : null;
89
+ /** @type {StateParse} */
90
+ const newState = { status: '', top: first(null)(state.stack), stack: drop(1)(state.stack) };
91
+ return pushValue(newState)(array);
92
+ };
93
+ /** @type {(state: StateParse) => JsonState} */
94
+ const startObject = state => {
95
+ const newStack = state.top === null ? null : { first: state.top, tail: state.stack };
96
+ return { status: '{', top: { kind: 'object', values: null, key: '' }, stack: newStack };
97
+ };
98
+ /** @type {(state: StateParse) => JsonState} */
99
+ const endObject = state => {
100
+ const obj = state.top?.kind === 'object' ? fromMap(state.top.values) : null;
101
+ /** @type {StateParse} */
102
+ const newState = { status: '', top: first(null)(state.stack), stack: drop(1)(state.stack) };
103
+ return pushValue(newState)(obj);
104
+ };
105
+ /** @type {(token: Tokenizer.JsonToken) => Json.Unknown} */
106
+ const tokenToValue = token => {
107
+ switch (token.kind) {
108
+ case 'null': return null;
109
+ case 'false': return false;
110
+ case 'true': return true;
111
+ case 'number': return parseFloat(token.value);
112
+ case 'string': return token.value;
113
+ default: return null;
114
+ }
115
+ };
116
+ /** @type {(token: Tokenizer.JsonToken) => boolean} */
117
+ const isValueToken = token => {
118
+ switch (token.kind) {
119
+ case 'null':
120
+ case 'false':
121
+ case 'true':
122
+ case 'number':
123
+ case 'string': return true;
124
+ default: return false;
125
+ }
126
+ };
127
+ /** @type {(token: Tokenizer.JsonToken) => (state: StateParse) => JsonState}} */
128
+ const parseValueOp = token => state => {
129
+ if (isValueToken(token)) {
130
+ return pushValue(state)(tokenToValue(token));
131
+ }
132
+ if (token.kind === '[') {
133
+ return startArray(state);
134
+ }
135
+ if (token.kind === '{') {
136
+ return startObject(state);
137
+ }
138
+ return { status: 'error', message: 'unexpected token' };
139
+ };
140
+ /** @type {(token: Tokenizer.JsonToken) => (state: StateParse) => JsonState}} */
141
+ const parseArrayStartOp = token => state => {
142
+ if (isValueToken(token)) {
143
+ return pushValue(state)(tokenToValue(token));
144
+ }
145
+ if (token.kind === '[') {
146
+ return startArray(state);
147
+ }
148
+ if (token.kind === ']') {
149
+ return endArray(state);
150
+ }
151
+ if (token.kind === '{') {
152
+ return startObject(state);
153
+ }
154
+ return { status: 'error', message: 'unexpected token' };
155
+ };
156
+ /** @type {(token: Tokenizer.JsonToken) => (state: StateParse) => JsonState}} */
157
+ const parseArrayValueOp = token => state => {
158
+ if (token.kind === ']') {
159
+ return endArray(state);
160
+ }
161
+ if (token.kind === ',') {
162
+ return { status: '[,', top: state.top, stack: state.stack };
163
+ }
164
+ return { status: 'error', message: 'unexpected token' };
165
+ };
166
+ /** @type {(token: Tokenizer.JsonToken) => (state: StateParse) => JsonState}} */
167
+ const parseObjectStartOp = token => state => {
168
+ if (token.kind === 'string') {
169
+ return pushKey(state)(token.value);
170
+ }
171
+ if (token.kind === '}') {
172
+ return endObject(state);
173
+ }
174
+ return { status: 'error', message: 'unexpected token' };
175
+ };
176
+ /** @type {(token: Tokenizer.JsonToken) => (state: StateParse) => JsonState}} */
177
+ const parseObjectKeyOp = token => state => {
178
+ if (token.kind === ':') {
179
+ return { status: '{:', top: state.top, stack: state.stack };
180
+ }
181
+ return { status: 'error', message: 'unexpected token' };
182
+ };
183
+ /** @type {(token: Tokenizer.JsonToken) => (state: StateParse) => JsonState}} */
184
+ const parseObjectNextOp = token => state => {
185
+ if (token.kind === '}') {
186
+ return endObject(state);
187
+ }
188
+ if (token.kind === ',') {
189
+ return { status: '{,', top: state.top, stack: state.stack };
190
+ }
191
+ return { status: 'error', message: 'unexpected token' };
192
+ };
193
+ /** @type {(token: Tokenizer.JsonToken) => (state: StateParse) => JsonState}} */
194
+ const parseObjectCommaOp = token => state => {
195
+ if (token.kind === 'string') {
196
+ return pushKey(state)(token.value);
197
+ }
198
+ return { status: 'error', message: 'unexpected token' };
199
+ };
200
+ /** @type {Operator.Fold<Tokenizer.JsonToken, JsonState>} */
201
+ const foldOp = token => state => {
202
+ switch (state.status) {
203
+ case 'result': return { status: 'error', message: 'unexpected token' };
204
+ case 'error': return { status: 'error', message: state.message };
205
+ case '': return parseValueOp(token)(state);
206
+ case '[': return parseArrayStartOp(token)(state);
207
+ case '[v': return parseArrayValueOp(token)(state);
208
+ case '[,': return parseValueOp(token)(state);
209
+ case '{': return parseObjectStartOp(token)(state);
210
+ case '{k': return parseObjectKeyOp(token)(state);
211
+ case '{:': return parseValueOp(token)(state);
212
+ case '{v': return parseObjectNextOp(token)(state);
213
+ case '{,': return parseObjectCommaOp(token)(state);
214
+ }
215
+ };
216
+ /** @type {(tokenList: list.List<Tokenizer.JsonToken>) => result.Result<Json.Unknown, string>} */
217
+ export const parse = tokenList => {
218
+ const state = fold(foldOp)({ status: '', top: null, stack: null })(tokenList);
219
+ switch (state.status) {
220
+ case 'result': return result.ok(state.value);
221
+ case 'error': return result.error(state.message);
222
+ default: return result.error('unexpected end');
223
+ }
224
+ };
@@ -0,0 +1,321 @@
1
+ import * as parser from './module.f.mjs';
2
+ import * as tokenizer from '../tokenizer/module.f.mjs';
3
+ import * as list from '../../types/list/module.f.mjs';
4
+ const { toArray } = list;
5
+ import * as json from '../module.f.mjs';
6
+ import * as o from '../../types/object/module.f.mjs';
7
+ const { sort } = o;
8
+ import * as encoding from '../../text/utf16/module.f.mjs';
9
+ /** @type {(s: string) => readonly tokenizer.JsonToken[]} */
10
+ const tokenizeString = s => toArray(tokenizer.tokenize(encoding.stringToList(s)));
11
+ const stringify = json.stringify(sort);
12
+ export default {
13
+ valid: [
14
+ () => {
15
+ const tokenList = tokenizeString('null');
16
+ const obj = parser.parse(tokenList);
17
+ const result = stringify(obj);
18
+ if (result !== '["ok",null]') {
19
+ throw result;
20
+ }
21
+ },
22
+ () => {
23
+ const tokenList = tokenizeString('true');
24
+ const obj = parser.parse(tokenList);
25
+ const result = stringify(obj);
26
+ if (result !== '["ok",true]') {
27
+ throw result;
28
+ }
29
+ },
30
+ () => {
31
+ const tokenList = tokenizeString('false');
32
+ const obj = parser.parse(tokenList);
33
+ const result = stringify(obj);
34
+ if (result !== '["ok",false]') {
35
+ throw result;
36
+ }
37
+ },
38
+ () => {
39
+ const tokenList = tokenizeString('0.1');
40
+ const obj = parser.parse(tokenList);
41
+ const result = stringify(obj);
42
+ if (result !== '["ok",0.1]') {
43
+ throw result;
44
+ }
45
+ },
46
+ () => {
47
+ const tokenList = tokenizeString('1.1e+2');
48
+ const obj = parser.parse(tokenList);
49
+ const result = stringify(obj);
50
+ if (result !== '["ok",110]') {
51
+ throw result;
52
+ }
53
+ },
54
+ () => {
55
+ const tokenList = tokenizeString('"abc"');
56
+ const obj = parser.parse(tokenList);
57
+ const result = stringify(obj);
58
+ if (result !== '["ok","abc"]') {
59
+ throw result;
60
+ }
61
+ },
62
+ () => {
63
+ const tokenList = tokenizeString('[]');
64
+ const obj = parser.parse(tokenList);
65
+ const result = stringify(obj);
66
+ if (result !== '["ok",[]]') {
67
+ throw result;
68
+ }
69
+ },
70
+ () => {
71
+ const tokenList = tokenizeString('[1]');
72
+ const obj = parser.parse(tokenList);
73
+ const result = stringify(obj);
74
+ if (result !== '["ok",[1]]') {
75
+ throw result;
76
+ }
77
+ },
78
+ () => {
79
+ const tokenList = tokenizeString('[[]]');
80
+ const obj = parser.parse(tokenList);
81
+ const result = stringify(obj);
82
+ if (result !== '["ok",[[]]]') {
83
+ throw result;
84
+ }
85
+ },
86
+ () => {
87
+ const tokenList = tokenizeString('[0,[1,[2,[]]],3]');
88
+ const obj = parser.parse(tokenList);
89
+ const result = stringify(obj);
90
+ if (result !== '["ok",[0,[1,[2,[]]],3]]') {
91
+ throw result;
92
+ }
93
+ },
94
+ () => {
95
+ const tokenList = tokenizeString('{}');
96
+ const obj = parser.parse(tokenList);
97
+ const result = stringify(obj);
98
+ if (result !== '["ok",{}]') {
99
+ throw result;
100
+ }
101
+ },
102
+ () => {
103
+ const tokenList = tokenizeString('[{}]');
104
+ const obj = parser.parse(tokenList);
105
+ const result = stringify(obj);
106
+ if (result !== '["ok",[{}]]') {
107
+ throw result;
108
+ }
109
+ },
110
+ () => {
111
+ const tokenList = tokenizeString('{"a":true,"b":false,"c":null}');
112
+ const obj = parser.parse(tokenList);
113
+ const result = stringify(obj);
114
+ if (result !== '["ok",{"a":true,"b":false,"c":null}]') {
115
+ throw result;
116
+ }
117
+ },
118
+ () => {
119
+ const tokenList = tokenizeString('{"a":{"b":{"c":["d"]}}}');
120
+ const obj = parser.parse(tokenList);
121
+ const result = stringify(obj);
122
+ if (result !== '["ok",{"a":{"b":{"c":["d"]}}}]') {
123
+ throw result;
124
+ }
125
+ }
126
+ ],
127
+ invalid: [
128
+ () => {
129
+ const tokenList = tokenizeString('');
130
+ const obj = parser.parse(tokenList);
131
+ const result = stringify(obj);
132
+ if (result !== '["error","unexpected end"]') {
133
+ throw result;
134
+ }
135
+ },
136
+ () => {
137
+ const tokenList = tokenizeString('"123');
138
+ const obj = parser.parse(tokenList);
139
+ const result = stringify(obj);
140
+ if (result !== '["error","unexpected token"]') {
141
+ throw result;
142
+ }
143
+ },
144
+ () => {
145
+ const tokenList = tokenizeString('[,]');
146
+ const obj = parser.parse(tokenList);
147
+ const result = stringify(obj);
148
+ if (result !== '["error","unexpected token"]') {
149
+ throw result;
150
+ }
151
+ },
152
+ () => {
153
+ const tokenList = tokenizeString('[1 2]');
154
+ const obj = parser.parse(tokenList);
155
+ const result = stringify(obj);
156
+ if (result !== '["error","unexpected token"]') {
157
+ throw result;
158
+ }
159
+ },
160
+ () => {
161
+ const tokenList = tokenizeString('[1,,2]');
162
+ const obj = parser.parse(tokenList);
163
+ const result = stringify(obj);
164
+ if (result !== '["error","unexpected token"]') {
165
+ throw result;
166
+ }
167
+ },
168
+ () => {
169
+ const tokenList = tokenizeString('[]]');
170
+ const obj = parser.parse(tokenList);
171
+ const result = stringify(obj);
172
+ if (result !== '["error","unexpected token"]') {
173
+ throw result;
174
+ }
175
+ },
176
+ () => {
177
+ const tokenList = tokenizeString('["a"');
178
+ const obj = parser.parse(tokenList);
179
+ const result = stringify(obj);
180
+ if (result !== '["error","unexpected end"]') {
181
+ throw result;
182
+ }
183
+ },
184
+ () => {
185
+ const tokenList = tokenizeString('[1,]');
186
+ const obj = parser.parse(tokenList);
187
+ const result = stringify(obj);
188
+ if (result !== '["error","unexpected token"]') {
189
+ throw result;
190
+ }
191
+ },
192
+ () => {
193
+ const tokenList = tokenizeString('[,1]');
194
+ const obj = parser.parse(tokenList);
195
+ const result = stringify(obj);
196
+ if (result !== '["error","unexpected token"]') {
197
+ throw result;
198
+ }
199
+ },
200
+ () => {
201
+ const tokenList = tokenizeString('[:]');
202
+ const obj = parser.parse(tokenList);
203
+ const result = stringify(obj);
204
+ if (result !== '["error","unexpected token"]') {
205
+ throw result;
206
+ }
207
+ },
208
+ () => {
209
+ const tokenList = tokenizeString(']');
210
+ const obj = parser.parse(tokenList);
211
+ const result = stringify(obj);
212
+ if (result !== '["error","unexpected token"]') {
213
+ throw result;
214
+ }
215
+ },
216
+ () => {
217
+ const tokenList = tokenizeString('{,}');
218
+ const obj = parser.parse(tokenList);
219
+ const result = stringify(obj);
220
+ if (result !== '["error","unexpected token"]') {
221
+ throw result;
222
+ }
223
+ },
224
+ () => {
225
+ const tokenList = tokenizeString('{1:2}');
226
+ const obj = parser.parse(tokenList);
227
+ const result = stringify(obj);
228
+ if (result !== '["error","unexpected token"]') {
229
+ throw result;
230
+ }
231
+ },
232
+ () => {
233
+ const tokenList = tokenizeString('{"1"2}');
234
+ const obj = parser.parse(tokenList);
235
+ const result = stringify(obj);
236
+ if (result !== '["error","unexpected token"]') {
237
+ throw result;
238
+ }
239
+ },
240
+ () => {
241
+ const tokenList = tokenizeString('{"1"::2}');
242
+ const obj = parser.parse(tokenList);
243
+ const result = stringify(obj);
244
+ if (result !== '["error","unexpected token"]') {
245
+ throw result;
246
+ }
247
+ },
248
+ () => {
249
+ const tokenList = tokenizeString('{"1":2,,"3":4');
250
+ const obj = parser.parse(tokenList);
251
+ const result = stringify(obj);
252
+ if (result !== '["error","unexpected token"]') {
253
+ throw result;
254
+ }
255
+ },
256
+ () => {
257
+ const tokenList = tokenizeString('{}}');
258
+ const obj = parser.parse(tokenList);
259
+ const result = stringify(obj);
260
+ if (result !== '["error","unexpected token"]') {
261
+ throw result;
262
+ }
263
+ },
264
+ () => {
265
+ const tokenList = tokenizeString('{"1":2');
266
+ const obj = parser.parse(tokenList);
267
+ const result = stringify(obj);
268
+ if (result !== '["error","unexpected end"]') {
269
+ throw result;
270
+ }
271
+ },
272
+ () => {
273
+ const tokenList = tokenizeString('{"1":2,}');
274
+ const obj = parser.parse(tokenList);
275
+ const result = stringify(obj);
276
+ if (result !== '["error","unexpected token"]') {
277
+ throw result;
278
+ }
279
+ },
280
+ () => {
281
+ const tokenList = tokenizeString('{,"1":2}');
282
+ const obj = parser.parse(tokenList);
283
+ const result = stringify(obj);
284
+ if (result !== '["error","unexpected token"]') {
285
+ throw result;
286
+ }
287
+ },
288
+ () => {
289
+ const tokenList = tokenizeString('}');
290
+ const obj = parser.parse(tokenList);
291
+ const result = stringify(obj);
292
+ if (result !== '["error","unexpected token"]') {
293
+ throw result;
294
+ }
295
+ },
296
+ () => {
297
+ const tokenList = tokenizeString('[{]}');
298
+ const obj = parser.parse(tokenList);
299
+ const result = stringify(obj);
300
+ if (result !== '["error","unexpected token"]') {
301
+ throw result;
302
+ }
303
+ },
304
+ () => {
305
+ const tokenList = tokenizeString('{[}]');
306
+ const obj = parser.parse(tokenList);
307
+ const result = stringify(obj);
308
+ if (result !== '["error","unexpected token"]') {
309
+ throw result;
310
+ }
311
+ },
312
+ () => {
313
+ const tokenList = tokenizeString('10-5');
314
+ const obj = parser.parse(tokenList);
315
+ const result = stringify(obj);
316
+ if (result !== '["error","unexpected token"]') {
317
+ throw result;
318
+ }
319
+ },
320
+ ]
321
+ };