functionalscript 0.2.0 → 0.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (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,19 @@
1
+ import * as _ from './module.f.mjs';
2
+ import * as ascii from '../text/ascii/module.f.mjs';
3
+ const { one } = ascii;
4
+ import * as j from '../json/module.f.mjs';
5
+ const { stringify } = j;
6
+ const s = stringify(i => i);
7
+ /** @type {(v: string) => string} */
8
+ const f = v => {
9
+ const n = one(v);
10
+ return s(_.init(n)[0]);
11
+ };
12
+ export default {
13
+ a: () => {
14
+ const x = f('1');
15
+ if (x != '["1"]') {
16
+ throw x;
17
+ }
18
+ }
19
+ };
@@ -0,0 +1,80 @@
1
+ // @ts-self-types="./module.f.d.mts"
2
+ import * as list from '../types/list/module.f.mjs';
3
+ const { equal, isEmpty, fold, toArray, scan, foldScan, empty: emptyList } = list;
4
+ import * as byteSet from '../types/byte_set/module.f.mjs';
5
+ const { toRangeMap, union: byteSetUnion, one, empty } = byteSet;
6
+ import * as sortedSet from '../types/sorted_set/module.f.mjs';
7
+ const { intersect, union: sortedSetUnion } = sortedSet;
8
+ import * as rangeMap from '../types/range_map/module.f.mjs';
9
+ const { merge } = rangeMap;
10
+ import * as cmp from '../types/function/compare/module.f.mjs';
11
+ const { unsafeCmp } = cmp;
12
+ import * as operator from '../types/function/operator/module.f.mjs';
13
+ const { strictEqual } = operator;
14
+ import * as j from '../json/module.f.mjs';
15
+ const { stringify } = j;
16
+ import * as f from '../types/function/module.f.mjs';
17
+ const { identity } = f;
18
+ import * as utf16 from '../text/utf16/module.f.mjs';
19
+ const { stringToList } = utf16;
20
+ /** @typedef {readonly[string, byteSet.ByteSet, string]} Rule */
21
+ /** @typedef {list.List<Rule>} Grammar */
22
+ /**
23
+ * @typedef {{
24
+ * readonly[state in string]: rangeMap.RangeMapArray<string>
25
+ * }} Dfa
26
+ */
27
+ const stringifyIdentity = stringify(identity);
28
+ /** @type {(s: string) => byteSet.ByteSet} */
29
+ export const toRange = s => {
30
+ const [b, e] = toArray(stringToList(s));
31
+ return byteSet.range([b, e]);
32
+ };
33
+ /** @type {operator.Fold<number, byteSet.ByteSet>} */
34
+ const toUnionOp = i => bs => byteSetUnion(bs)(one(i));
35
+ /** @type {(s: string) => byteSet.ByteSet} */
36
+ export const toUnion = s => {
37
+ const codePoints = stringToList(s);
38
+ return fold(toUnionOp)(empty)(codePoints);
39
+ };
40
+ /** @type {rangeMap.Operators<sortedSet.SortedSet<string>>} */
41
+ const mergeOp = { union: sortedSetUnion(unsafeCmp), equal: equal(strictEqual) };
42
+ /** @type {(s: string) => (set: sortedSet.SortedSet<string>) => boolean} */
43
+ const hasState = s => set => !isEmpty(intersect(unsafeCmp)([s])(set));
44
+ /** @type {(set: sortedSet.SortedSet<string>) => operator.Fold<Rule, rangeMap.RangeMap<sortedSet.SortedSet<string>>>} */
45
+ const foldOp = set => ([ruleIn, bs, ruleOut]) => rm => {
46
+ if (hasState(ruleIn)(set)) {
47
+ return merge(mergeOp)(rm)(toRangeMap(bs)(ruleOut));
48
+ }
49
+ return rm;
50
+ };
51
+ /** @type {operator.Scan<rangeMap.Entry<sortedSet.SortedSet<string>>, rangeMap.Entry<string>>} */
52
+ const stringifyOp = ([sortedSet, max]) => [[stringifyIdentity(sortedSet), max], stringifyOp];
53
+ const scanStringify = scan(stringifyOp);
54
+ /** @type {operator.Scan<rangeMap.Entry<sortedSet.SortedSet<string>>, sortedSet.SortedSet<string>>} */
55
+ const fetchOp = ([item, _]) => [item, fetchOp];
56
+ const scanFetch = scan(fetchOp);
57
+ /** @type {(grammar: Grammar) => operator.Fold<sortedSet.SortedSet<string>, Dfa>} */
58
+ const addEntry = grammar => set => dfa => {
59
+ const s = stringifyIdentity(set);
60
+ if (s in dfa) {
61
+ return dfa;
62
+ }
63
+ const setMap = fold(foldOp(set))(emptyList)(grammar);
64
+ const stringMap = toArray(scanStringify(setMap));
65
+ const newDfa = { ...dfa, [s]: stringMap };
66
+ const newStates = scanFetch(setMap);
67
+ return fold(addEntry(grammar))(newDfa)(newStates);
68
+ };
69
+ /** @type {string[]} */
70
+ const emptyState = [];
71
+ const emptyStateStringify = stringifyIdentity(emptyState);
72
+ const initialState = [''];
73
+ const initialStateStringify = stringifyIdentity(initialState);
74
+ /** @type {(grammar: Grammar) => Dfa} */
75
+ export const dfa = grammar => addEntry(grammar)(initialState)({});
76
+ const get = rangeMap.get(emptyStateStringify);
77
+ /** @type {(dfa: Dfa) => operator.Fold<number, string>} */
78
+ const runOp = dfa => input => s => get(input)(dfa[s]);
79
+ /** @type {(dfa: Dfa) => (input: list.List<number>) => list.List<string>} */
80
+ export const run = dfa => input => foldScan(runOp(dfa))(initialStateStringify)(input);
@@ -0,0 +1,138 @@
1
+ import * as _ from './module.f.mjs';
2
+ import * as byteSet from '../types/byte_set/module.f.mjs';
3
+ import * as o from '../types/object/module.f.mjs';
4
+ const { sort, fromEntries } = o;
5
+ import * as json from '../json/module.f.mjs';
6
+ import * as f from '../types/function/module.f.mjs';
7
+ const { identity } = f;
8
+ import * as list from '../types/list/module.f.mjs';
9
+ const { toArray } = list;
10
+ import * as utf16 from '../text/utf16/module.f.mjs';
11
+ const { stringToList } = utf16;
12
+ const stringifyIdentity = json.stringify(identity);
13
+ const buildDfa = () => {
14
+ const lowercaseAlpha = _.toRange('az');
15
+ const uppercaseAlpha = _.toRange('AZ');
16
+ const alpha = byteSet.union(lowercaseAlpha)(uppercaseAlpha);
17
+ const idSymbol = _.toUnion('_$');
18
+ const idBegin = byteSet.union(alpha)(idSymbol);
19
+ const digit = _.toRange('09');
20
+ const idNext = byteSet.union(idBegin)(digit);
21
+ const dot = _.toUnion('.');
22
+ /** @type {_.Grammar} */
23
+ const grammar = [
24
+ ['', digit, 'int'],
25
+ ['int', digit, 'int'],
26
+ ['', digit, 'floatBegin'],
27
+ ['floatBegin', digit, 'floatBegin'],
28
+ ['floatBegin', dot, 'floatDot'],
29
+ ['floatDot', digit, 'float'],
30
+ ['float', digit, 'float'],
31
+ ['', idBegin, 'id'],
32
+ ['id', idNext, 'id']
33
+ ];
34
+ return _.dfa(grammar);
35
+ };
36
+ export default {
37
+ dfa: () => {
38
+ const dfa = buildDfa();
39
+ const entries = Object.entries(dfa);
40
+ const sortedEntries = sort(entries);
41
+ const obj = fromEntries(sortedEntries);
42
+ const result = stringifyIdentity(obj);
43
+ const expectedObj = {
44
+ '[""]': [
45
+ ['[]', 35],
46
+ ['["id"]', 36],
47
+ ['[]', 47],
48
+ ['["floatBegin","int"]', 57],
49
+ ['[]', 64],
50
+ ['["id"]', 90],
51
+ ['[]', 94],
52
+ ['["id"]', 95],
53
+ ['[]', 96],
54
+ ['["id"]', 122]
55
+ ],
56
+ '["float"]': [['[]', 47], ['["float"]', 57]],
57
+ '["floatBegin","int"]': [
58
+ ['[]', 45],
59
+ ['["floatDot"]', 46],
60
+ ['[]', 47],
61
+ ['["floatBegin","int"]', 57]
62
+ ],
63
+ '["floatDot"]': [['[]', 47], ['["float"]', 57]],
64
+ '["id"]': [
65
+ ['[]', 35],
66
+ ['["id"]', 36],
67
+ ['[]', 47],
68
+ ['["id"]', 57],
69
+ ['[]', 64],
70
+ ['["id"]', 90],
71
+ ['[]', 94],
72
+ ['["id"]', 95],
73
+ ['[]', 96],
74
+ ['["id"]', 122]
75
+ ],
76
+ '[]': []
77
+ };
78
+ const expectedResult = stringifyIdentity(expectedObj);
79
+ if (result !== expectedResult) {
80
+ throw result;
81
+ }
82
+ },
83
+ run: [
84
+ () => {
85
+ const dfa = buildDfa();
86
+ const input = stringToList('a1');
87
+ const result = stringifyIdentity(toArray(_.run(dfa)(input)));
88
+ const expectedOutput = [
89
+ '["id"]',
90
+ '["id"]'
91
+ ];
92
+ const expectedResult = stringifyIdentity(expectedOutput);
93
+ if (result !== expectedResult) {
94
+ throw result;
95
+ }
96
+ },
97
+ () => {
98
+ const dfa = buildDfa();
99
+ const input = stringToList('0.1');
100
+ const result = stringifyIdentity(toArray(_.run(dfa)(input)));
101
+ const expectedOutput = [
102
+ '["floatBegin","int"]',
103
+ '["floatDot"]',
104
+ '["float"]'
105
+ ];
106
+ const expectedResult = stringifyIdentity(expectedOutput);
107
+ if (result !== expectedResult) {
108
+ throw result;
109
+ }
110
+ },
111
+ () => {
112
+ const dfa = buildDfa();
113
+ const input = stringToList('//');
114
+ const result = stringifyIdentity(toArray(_.run(dfa)(input)));
115
+ const expectedOutput = [
116
+ '[]',
117
+ '[]'
118
+ ];
119
+ const expectedResult = stringifyIdentity(expectedOutput);
120
+ if (result !== expectedResult) {
121
+ throw result;
122
+ }
123
+ },
124
+ () => {
125
+ const dfa = buildDfa();
126
+ const input = stringToList('::');
127
+ const result = stringifyIdentity(toArray(_.run(dfa)(input)));
128
+ const expectedOutput = [
129
+ '[]',
130
+ '[]'
131
+ ];
132
+ const expectedResult = stringifyIdentity(expectedOutput);
133
+ if (result !== expectedResult) {
134
+ throw result;
135
+ }
136
+ }
137
+ ]
138
+ };
@@ -0,0 +1,94 @@
1
+ // @ts-self-types="./module.f.d.mts"
2
+ import * as list from '../types/list/module.f.mjs';
3
+ const { map, flatMap, flat, concat: listConcat } = list;
4
+ import * as s from '../types/string/module.f.mjs';
5
+ const { concat: stringConcat } = s;
6
+ import * as O from '../types/object/module.f.mjs';
7
+ import * as f from '../types/function/module.f.mjs';
8
+ const { compose } = f;
9
+ import * as utf16 from '../text/utf16/module.f.mjs';
10
+ const { stringToList } = utf16;
11
+ const { fromCharCode } = String;
12
+ const { entries } = Object;
13
+ /** @typedef {string} Tag */
14
+ // https://developer.mozilla.org/en-US/docs/Glossary/Void_element
15
+ const voidTagList = [
16
+ 'area',
17
+ 'base',
18
+ 'br',
19
+ 'col',
20
+ 'embed',
21
+ 'hr',
22
+ 'img',
23
+ 'input',
24
+ 'link',
25
+ 'meta',
26
+ 'param',
27
+ 'source',
28
+ 'track',
29
+ 'wbr',
30
+ ];
31
+ /** @type {(tag: string) => boolean} */
32
+ const isVoid = tag => voidTagList.includes(tag);
33
+ /** @typedef {readonly[Tag]} Element1*/
34
+ /** @typedef {readonly[Tag, Attributes]} Element2A */
35
+ /** @typedef {readonly[Tag, readonly Node[]]} Element2N */
36
+ /** @typedef {readonly[Tag, Attributes, Nodes]} Element3*/
37
+ /** @typedef {Element1 | Element2A | Element2N | Element3} Element */
38
+ /**
39
+ * @typedef {{
40
+ * readonly[k in string]: string
41
+ * }} Attributes
42
+ */
43
+ /** @typedef {list.List<Node>} Nodes */
44
+ /** @typedef {Element | string} Node */
45
+ /**
46
+ * https://stackoverflow.com/questions/7381974/which-characters-need-to-be-escaped-in-html
47
+ *
48
+ * @type {(code: number) => string}
49
+ */
50
+ const escapeCharCode = code => {
51
+ switch (code) {
52
+ case 0x22: return '&quot;';
53
+ case 0x26: return '&amp;';
54
+ case 0x3C: return '&lt;';
55
+ case 0x3E: return '&gt;';
56
+ default: return fromCharCode(code);
57
+ }
58
+ };
59
+ const escape = compose(stringToList)(map(escapeCharCode));
60
+ /** @type {(n: Node) => list.List<string>} */
61
+ const node = n => typeof n === 'string' ? escape(n) : element(n);
62
+ const nodes = flatMap(node);
63
+ /** @type {(a: O.Entry<string>) => list.List<string>} */
64
+ const attribute = ([name, value]) => flat([[' ', name, '="'], escape(value), ['"']]);
65
+ /** @type {(a: Attributes) => list.List<string>} */
66
+ const attributes = compose(entries)(flatMap(attribute));
67
+ const open = (/** @type {Element2A} */ [tag, a]) => flat([[`<`, tag], attributes(a), [`>`]]);
68
+ const close = (/** @type {string}*/ tag) => ['</', tag, '>'];
69
+ /** @type {(_: Element3) => list.List<string>} */
70
+ const element3 = ([tag, a, ns]) => flat([open([tag, a]), nodes(ns), close(tag)]);
71
+ /** @type {(_: Element2A) => list.List<string>} */
72
+ const element2a = e => {
73
+ const [tag] = e;
74
+ return flat([open(e), isVoid(tag) ? [] : close(tag)]);
75
+ };
76
+ /** @type {(element: Element) => list.List<string>} */
77
+ export const element = e => {
78
+ switch (e.length) {
79
+ case 1: {
80
+ return element2a([e[0], {}]);
81
+ }
82
+ case 2: {
83
+ const [tag, a] = e;
84
+ return a instanceof Array ?
85
+ element3([tag, {}, a]) :
86
+ element2a([tag, a]);
87
+ }
88
+ default: {
89
+ return element3(e);
90
+ }
91
+ }
92
+ };
93
+ export const html = compose(element)(listConcat(['<!DOCTYPE html>']));
94
+ export const htmlToString = compose(html)(stringConcat);
@@ -0,0 +1,45 @@
1
+ import * as _ from './module.f.mjs';
2
+ export default {
3
+ empty: () => {
4
+ const r = _.htmlToString(['html', []]);
5
+ if (r !== '<!DOCTYPE html><html></html>') {
6
+ throw r;
7
+ }
8
+ },
9
+ empty2: () => {
10
+ const r = _.htmlToString(['html']);
11
+ if (r !== '<!DOCTYPE html><html></html>') {
12
+ throw r;
13
+ }
14
+ },
15
+ void: () => {
16
+ const r = _.htmlToString(['area']);
17
+ if (r !== '<!DOCTYPE html><area>') {
18
+ throw r;
19
+ }
20
+ },
21
+ some: () => {
22
+ /** @type {_.Element} */
23
+ const x = ['div', {}, ['<div>&amp;</div>', ['a', { href: 'hello"' }, []]]];
24
+ const s = _.htmlToString(x);
25
+ if (s !== '<!DOCTYPE html><div>&lt;div&gt;&amp;amp;&lt;/div&gt;<a href="hello&quot;"></a></div>') {
26
+ throw s;
27
+ }
28
+ },
29
+ some2: () => {
30
+ /** @type {_.Element} */
31
+ const x = ['div', ['<div>&amp;</div>', ['a', { href: 'hello"' }, []]]];
32
+ const s = _.htmlToString(x);
33
+ if (s !== '<!DOCTYPE html><div>&lt;div&gt;&amp;amp;&lt;/div&gt;<a href="hello&quot;"></a></div>') {
34
+ throw s;
35
+ }
36
+ },
37
+ someVoid: () => {
38
+ /** @type {_.Element} */
39
+ const x = ['div', [['br', { id: '5' }], '<div>&amp;</div>', ['a', { href: 'hello"' }, []]]];
40
+ const s = _.htmlToString(x);
41
+ if (s !== '<!DOCTYPE html><div><br id="5">&lt;div&gt;&amp;amp;&lt;/div&gt;<a href="hello&quot;"></a></div>') {
42
+ throw s;
43
+ }
44
+ }
45
+ };
@@ -0,0 +1,66 @@
1
+ /** @type {(a: unknown) => (i: any) =>unknown} */
2
+ const at = a => i => Object.getOwnPropertyDescriptor(a, i)?.value;
3
+ export default {
4
+ ownProperty: {
5
+ nullish: () => {
6
+ /* // panic
7
+ const v = Object.getOwnPropertyDescriptor(null, 0)
8
+ if (v !== undefined) {
9
+ throw v
10
+ }
11
+ */
12
+ /* // panic
13
+ const v = Object.getOwnPropertyDescriptor(undefined, 0)
14
+ if (v !== undefined) {
15
+ throw v
16
+ }
17
+ */
18
+ },
19
+ bool: () => {
20
+ const v = at(true)('x');
21
+ if (v !== undefined) {
22
+ throw v;
23
+ }
24
+ },
25
+ array: () => {
26
+ const a = ['42'];
27
+ {
28
+ const v = at(a)('0');
29
+ if (v !== '42') {
30
+ throw v;
31
+ }
32
+ }
33
+ {
34
+ const v = at(a)(0);
35
+ if (v !== '42') {
36
+ throw v;
37
+ }
38
+ }
39
+ },
40
+ object: {
41
+ null: () => {
42
+ const o = { null: 'hello' };
43
+ const v = at(o)(null);
44
+ if (v !== 'hello') {
45
+ throw v;
46
+ }
47
+ },
48
+ undefined: () => {
49
+ const o = { undefined: 'hello' };
50
+ const v = at(o)(undefined);
51
+ if (v !== 'hello') {
52
+ throw v;
53
+ }
54
+ }
55
+ },
56
+ string: {
57
+ number: () => {
58
+ const o = 'hello';
59
+ const v = at(o)(1);
60
+ if (v !== 'e') {
61
+ throw v;
62
+ }
63
+ }
64
+ }
65
+ }
66
+ };