@lokascript/semantic 1.2.1 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (964) hide show
  1. package/dist/__test-utils__/index.d.ts +6 -0
  2. package/dist/__test-utils__/index.d.ts.map +1 -0
  3. package/dist/__test-utils__/test-helpers.d.ts +7 -0
  4. package/dist/__test-utils__/test-helpers.d.ts.map +1 -0
  5. package/dist/__types__/test-helpers.d.ts +67 -0
  6. package/dist/__types__/test-helpers.d.ts.map +1 -0
  7. package/dist/analysis/index.d.ts +106 -0
  8. package/dist/analysis/index.d.ts.map +1 -0
  9. package/dist/ast-builder/command-mappers.d.ts +50 -0
  10. package/dist/ast-builder/command-mappers.d.ts.map +1 -0
  11. package/dist/ast-builder/expression-parser/index.d.ts +14 -0
  12. package/dist/ast-builder/expression-parser/index.d.ts.map +1 -0
  13. package/dist/ast-builder/expression-parser/parser.d.ts +50 -0
  14. package/dist/ast-builder/expression-parser/parser.d.ts.map +1 -0
  15. package/dist/ast-builder/expression-parser/tokenizer.d.ts +44 -0
  16. package/dist/ast-builder/expression-parser/tokenizer.d.ts.map +1 -0
  17. package/dist/ast-builder/expression-parser/types.d.ts +111 -0
  18. package/dist/ast-builder/expression-parser/types.d.ts.map +1 -0
  19. package/dist/ast-builder/index.d.ts +183 -0
  20. package/dist/ast-builder/index.d.ts.map +1 -0
  21. package/dist/ast-builder/value-converters.d.ts +51 -0
  22. package/dist/ast-builder/value-converters.d.ts.map +1 -0
  23. package/dist/browser-ar.ar.global.js +2 -2
  24. package/dist/browser-ar.d.ts +47 -0
  25. package/dist/browser-ar.d.ts.map +1 -0
  26. package/dist/browser-bn.bn.global.js +2 -0
  27. package/dist/browser-bn.d.ts +47 -0
  28. package/dist/browser-bn.d.ts.map +1 -0
  29. package/dist/browser-core.core.global.js +2 -2
  30. package/dist/browser-core.d.ts +83 -0
  31. package/dist/browser-core.d.ts.map +1 -0
  32. package/dist/browser-de.d.ts +47 -0
  33. package/dist/browser-de.d.ts.map +1 -0
  34. package/dist/browser-de.de.global.js +2 -2
  35. package/dist/browser-east-asian.d.ts +59 -0
  36. package/dist/browser-east-asian.d.ts.map +1 -0
  37. package/dist/browser-east-asian.east-asian.global.js +2 -2
  38. package/dist/browser-en-tr.d.ts +50 -0
  39. package/dist/browser-en-tr.d.ts.map +1 -0
  40. package/dist/browser-en-tr.en-tr.global.js +2 -2
  41. package/dist/browser-en.d.ts +48 -0
  42. package/dist/browser-en.d.ts.map +1 -0
  43. package/dist/browser-en.en.global.js +2 -2
  44. package/dist/browser-es-en.d.ts +62 -0
  45. package/dist/browser-es-en.d.ts.map +1 -0
  46. package/dist/browser-es-en.es-en.global.js +2 -2
  47. package/dist/browser-es.d.ts +51 -0
  48. package/dist/browser-es.d.ts.map +1 -0
  49. package/dist/browser-es.es.global.js +2 -2
  50. package/dist/browser-fr.d.ts +47 -0
  51. package/dist/browser-fr.d.ts.map +1 -0
  52. package/dist/browser-fr.fr.global.js +2 -2
  53. package/dist/browser-hi.d.ts +47 -0
  54. package/dist/browser-hi.d.ts.map +1 -0
  55. package/dist/browser-hi.hi.global.js +2 -0
  56. package/dist/browser-id.d.ts +47 -0
  57. package/dist/browser-id.d.ts.map +1 -0
  58. package/dist/browser-id.id.global.js +2 -2
  59. package/dist/browser-it.d.ts +47 -0
  60. package/dist/browser-it.d.ts.map +1 -0
  61. package/dist/browser-it.it.global.js +2 -0
  62. package/dist/browser-ja.d.ts +47 -0
  63. package/dist/browser-ja.d.ts.map +1 -0
  64. package/dist/browser-ja.ja.global.js +2 -2
  65. package/dist/browser-ko.d.ts +47 -0
  66. package/dist/browser-ko.d.ts.map +1 -0
  67. package/dist/browser-ko.ko.global.js +2 -2
  68. package/dist/browser-lazy.d.ts +52 -0
  69. package/dist/browser-lazy.d.ts.map +1 -0
  70. package/dist/browser-lazy.lazy.global.js +2 -2
  71. package/dist/browser-ms.d.ts +47 -0
  72. package/dist/browser-ms.d.ts.map +1 -0
  73. package/dist/browser-ms.ms.global.js +2 -0
  74. package/dist/browser-pl.d.ts +47 -0
  75. package/dist/browser-pl.d.ts.map +1 -0
  76. package/dist/browser-pl.pl.global.js +2 -0
  77. package/dist/browser-priority.d.ts +83 -0
  78. package/dist/browser-priority.d.ts.map +1 -0
  79. package/dist/browser-priority.priority.global.js +2 -2
  80. package/dist/browser-pt.d.ts +47 -0
  81. package/dist/browser-pt.d.ts.map +1 -0
  82. package/dist/browser-pt.pt.global.js +2 -2
  83. package/dist/browser-qu.d.ts +47 -0
  84. package/dist/browser-qu.d.ts.map +1 -0
  85. package/dist/browser-qu.qu.global.js +2 -2
  86. package/dist/browser-ru.d.ts +47 -0
  87. package/dist/browser-ru.d.ts.map +1 -0
  88. package/dist/browser-ru.ru.global.js +2 -0
  89. package/dist/browser-sw.d.ts +47 -0
  90. package/dist/browser-sw.d.ts.map +1 -0
  91. package/dist/browser-sw.sw.global.js +2 -2
  92. package/dist/browser-th.d.ts +47 -0
  93. package/dist/browser-th.d.ts.map +1 -0
  94. package/dist/browser-th.th.global.js +2 -0
  95. package/dist/browser-tl.d.ts +47 -0
  96. package/dist/browser-tl.d.ts.map +1 -0
  97. package/dist/browser-tl.tl.global.js +2 -0
  98. package/dist/browser-tr.d.ts +47 -0
  99. package/dist/browser-tr.d.ts.map +1 -0
  100. package/dist/browser-tr.tr.global.js +2 -2
  101. package/dist/browser-uk.d.ts +47 -0
  102. package/dist/browser-uk.d.ts.map +1 -0
  103. package/dist/browser-uk.uk.global.js +2 -0
  104. package/dist/browser-vi.d.ts +47 -0
  105. package/dist/browser-vi.d.ts.map +1 -0
  106. package/dist/browser-vi.vi.global.js +2 -0
  107. package/dist/browser-western.d.ts +67 -0
  108. package/dist/browser-western.d.ts.map +1 -0
  109. package/dist/browser-western.western.global.js +2 -2
  110. package/dist/browser-zh.d.ts +47 -0
  111. package/dist/browser-zh.d.ts.map +1 -0
  112. package/dist/browser-zh.zh.global.js +2 -2
  113. package/dist/browser.d.ts +69 -0
  114. package/dist/browser.d.ts.map +1 -0
  115. package/dist/browser.global.js +2 -2
  116. package/dist/browser.global.js.map +1 -1
  117. package/dist/cache/index.d.ts +7 -0
  118. package/dist/cache/index.d.ts.map +1 -0
  119. package/dist/cache/semantic-cache.d.ts +138 -0
  120. package/dist/cache/semantic-cache.d.ts.map +1 -0
  121. package/dist/core-bridge.d.ts +154 -0
  122. package/dist/core-bridge.d.ts.map +1 -0
  123. package/dist/core.d.ts +24 -1235
  124. package/dist/core.d.ts.map +1 -0
  125. package/dist/core.js +6433 -1731
  126. package/dist/core.js.map +1 -1
  127. package/dist/explicit/converter.d.ts +98 -0
  128. package/dist/explicit/converter.d.ts.map +1 -0
  129. package/dist/explicit/index.d.ts +10 -0
  130. package/dist/explicit/index.d.ts.map +1 -0
  131. package/dist/explicit/parser.d.ts +25 -0
  132. package/dist/explicit/parser.d.ts.map +1 -0
  133. package/dist/explicit/renderer.d.ts +82 -0
  134. package/dist/explicit/renderer.d.ts.map +1 -0
  135. package/dist/generators/command-schemas.d.ts +358 -0
  136. package/dist/generators/command-schemas.d.ts.map +1 -0
  137. package/dist/generators/event-handlers-sov.d.ts +91 -0
  138. package/dist/generators/event-handlers-sov.d.ts.map +1 -0
  139. package/dist/generators/event-handlers-vso.d.ts +69 -0
  140. package/dist/generators/event-handlers-vso.d.ts.map +1 -0
  141. package/dist/generators/index.d.ts +12 -0
  142. package/dist/generators/index.d.ts.map +1 -0
  143. package/dist/generators/language-profiles.d.ts +65 -0
  144. package/dist/generators/language-profiles.d.ts.map +1 -0
  145. package/dist/generators/pattern-generator.d.ts +81 -0
  146. package/dist/generators/pattern-generator.d.ts.map +1 -0
  147. package/dist/generators/profiles/arabic.d.ts +9 -0
  148. package/dist/generators/profiles/arabic.d.ts.map +1 -0
  149. package/dist/generators/profiles/bengali.d.ts +9 -0
  150. package/dist/generators/profiles/bengali.d.ts.map +1 -0
  151. package/dist/generators/profiles/chinese.d.ts +9 -0
  152. package/dist/generators/profiles/chinese.d.ts.map +1 -0
  153. package/dist/generators/profiles/english.d.ts +8 -0
  154. package/dist/generators/profiles/english.d.ts.map +1 -0
  155. package/dist/generators/profiles/french.d.ts +9 -0
  156. package/dist/generators/profiles/french.d.ts.map +1 -0
  157. package/dist/generators/profiles/german.d.ts +9 -0
  158. package/dist/generators/profiles/german.d.ts.map +1 -0
  159. package/dist/generators/profiles/hebrew.d.ts +10 -0
  160. package/dist/generators/profiles/hebrew.d.ts.map +1 -0
  161. package/dist/generators/profiles/hindi.d.ts +9 -0
  162. package/dist/generators/profiles/hindi.d.ts.map +1 -0
  163. package/dist/generators/profiles/index.d.ts +36 -0
  164. package/dist/generators/profiles/index.d.ts.map +1 -0
  165. package/dist/generators/profiles/indonesian.d.ts +9 -0
  166. package/dist/generators/profiles/indonesian.d.ts.map +1 -0
  167. package/dist/generators/profiles/italian.d.ts +10 -0
  168. package/dist/generators/profiles/italian.d.ts.map +1 -0
  169. package/dist/generators/profiles/japanese.d.ts +9 -0
  170. package/dist/generators/profiles/japanese.d.ts.map +1 -0
  171. package/dist/generators/profiles/korean.d.ts +9 -0
  172. package/dist/generators/profiles/korean.d.ts.map +1 -0
  173. package/dist/generators/profiles/marker-templates.d.ts +119 -0
  174. package/dist/generators/profiles/marker-templates.d.ts.map +1 -0
  175. package/dist/generators/profiles/ms.d.ts +8 -0
  176. package/dist/generators/profiles/ms.d.ts.map +1 -0
  177. package/dist/generators/profiles/polish.d.ts +10 -0
  178. package/dist/generators/profiles/polish.d.ts.map +1 -0
  179. package/dist/generators/profiles/portuguese.d.ts +9 -0
  180. package/dist/generators/profiles/portuguese.d.ts.map +1 -0
  181. package/dist/generators/profiles/quechua.d.ts +9 -0
  182. package/dist/generators/profiles/quechua.d.ts.map +1 -0
  183. package/dist/generators/profiles/russian.d.ts +10 -0
  184. package/dist/generators/profiles/russian.d.ts.map +1 -0
  185. package/dist/generators/profiles/spanish.d.ts +9 -0
  186. package/dist/generators/profiles/spanish.d.ts.map +1 -0
  187. package/dist/generators/profiles/spanishMexico.d.ts +19 -0
  188. package/dist/generators/profiles/spanishMexico.d.ts.map +1 -0
  189. package/dist/generators/profiles/swahili.d.ts +9 -0
  190. package/dist/generators/profiles/swahili.d.ts.map +1 -0
  191. package/dist/generators/profiles/thai.d.ts +9 -0
  192. package/dist/generators/profiles/thai.d.ts.map +1 -0
  193. package/dist/generators/profiles/tl.d.ts +8 -0
  194. package/dist/generators/profiles/tl.d.ts.map +1 -0
  195. package/dist/generators/profiles/turkish.d.ts +9 -0
  196. package/dist/generators/profiles/turkish.d.ts.map +1 -0
  197. package/dist/generators/profiles/types.d.ts +170 -0
  198. package/dist/generators/profiles/types.d.ts.map +1 -0
  199. package/dist/generators/profiles/ukrainian.d.ts +10 -0
  200. package/dist/generators/profiles/ukrainian.d.ts.map +1 -0
  201. package/dist/generators/profiles/vietnamese.d.ts +10 -0
  202. package/dist/generators/profiles/vietnamese.d.ts.map +1 -0
  203. package/dist/generators/schema-error-codes.d.ts +60 -0
  204. package/dist/generators/schema-error-codes.d.ts.map +1 -0
  205. package/dist/generators/schema-validator.d.ts +77 -0
  206. package/dist/generators/schema-validator.d.ts.map +1 -0
  207. package/dist/index.cjs +5451 -2522
  208. package/dist/index.cjs.map +1 -1
  209. package/dist/index.d.ts +50 -3436
  210. package/dist/index.d.ts.map +1 -0
  211. package/dist/index.js +5448 -2526
  212. package/dist/index.js.map +1 -1
  213. package/dist/interchange/from-semantic.d.ts +23 -0
  214. package/dist/interchange/from-semantic.d.ts.map +1 -0
  215. package/dist/interchange/index.d.ts +7 -0
  216. package/dist/interchange/index.d.ts.map +1 -0
  217. package/dist/interchange/types.d.ts +132 -0
  218. package/dist/interchange/types.d.ts.map +1 -0
  219. package/dist/language-building-schema.d.ts +163 -0
  220. package/dist/language-building-schema.d.ts.map +1 -0
  221. package/dist/language-loader.d.ts +126 -0
  222. package/dist/language-loader.d.ts.map +1 -0
  223. package/dist/languages/_all.d.ts +66 -0
  224. package/dist/languages/_all.d.ts.map +1 -0
  225. package/dist/languages/ar.d.ts +6 -75
  226. package/dist/languages/ar.d.ts.map +1 -0
  227. package/dist/languages/ar.js +65 -14
  228. package/dist/languages/ar.js.map +1 -1
  229. package/dist/languages/bn.d.ts +10 -0
  230. package/dist/languages/bn.d.ts.map +1 -0
  231. package/dist/languages/bn.js +1163 -0
  232. package/dist/languages/bn.js.map +1 -0
  233. package/dist/languages/de.d.ts +6 -35
  234. package/dist/languages/de.d.ts.map +1 -0
  235. package/dist/languages/de.js +260 -22
  236. package/dist/languages/de.js.map +1 -1
  237. package/dist/languages/en.d.ts +13 -40
  238. package/dist/languages/en.d.ts.map +1 -0
  239. package/dist/languages/en.js +788 -241
  240. package/dist/languages/en.js.map +1 -1
  241. package/dist/languages/es-MX.d.ts +24 -0
  242. package/dist/languages/es-MX.d.ts.map +1 -0
  243. package/dist/languages/es-MX.js +1729 -0
  244. package/dist/languages/es-MX.js.map +1 -0
  245. package/dist/languages/es.d.ts +6 -49
  246. package/dist/languages/es.d.ts.map +1 -0
  247. package/dist/languages/es.js +60 -13
  248. package/dist/languages/es.js.map +1 -1
  249. package/dist/languages/fr.d.ts +6 -34
  250. package/dist/languages/fr.d.ts.map +1 -0
  251. package/dist/languages/fr.js +309 -22
  252. package/dist/languages/fr.js.map +1 -1
  253. package/dist/languages/he.d.ts +9 -0
  254. package/dist/languages/he.d.ts.map +1 -0
  255. package/dist/languages/he.js +1378 -0
  256. package/dist/languages/he.js.map +1 -0
  257. package/dist/languages/hi.d.ts +18 -0
  258. package/dist/languages/hi.d.ts.map +1 -0
  259. package/dist/languages/hi.js +1209 -0
  260. package/dist/languages/hi.js.map +1 -0
  261. package/dist/languages/id.d.ts +6 -32
  262. package/dist/languages/id.d.ts.map +1 -0
  263. package/dist/languages/id.js +60 -13
  264. package/dist/languages/id.js.map +1 -1
  265. package/dist/languages/index.d.ts +18 -0
  266. package/dist/languages/index.d.ts.map +1 -0
  267. package/dist/languages/it.d.ts +9 -0
  268. package/dist/languages/it.d.ts.map +1 -0
  269. package/dist/languages/it.js +1647 -0
  270. package/dist/languages/it.js.map +1 -0
  271. package/dist/languages/ja.d.ts +6 -50
  272. package/dist/languages/ja.d.ts.map +1 -0
  273. package/dist/languages/ja.js +60 -13
  274. package/dist/languages/ja.js.map +1 -1
  275. package/dist/languages/ko.d.ts +6 -55
  276. package/dist/languages/ko.d.ts.map +1 -0
  277. package/dist/languages/ko.js +64 -13
  278. package/dist/languages/ko.js.map +1 -1
  279. package/dist/languages/ms.d.ts +10 -0
  280. package/dist/languages/ms.d.ts.map +1 -0
  281. package/dist/languages/ms.js +1088 -0
  282. package/dist/languages/ms.js.map +1 -0
  283. package/dist/languages/pl.d.ts +12 -0
  284. package/dist/languages/pl.d.ts.map +1 -0
  285. package/dist/languages/pl.js +1586 -0
  286. package/dist/languages/pl.js.map +1 -0
  287. package/dist/languages/pt.d.ts +6 -34
  288. package/dist/languages/pt.d.ts.map +1 -0
  289. package/dist/languages/pt.js +344 -22
  290. package/dist/languages/pt.js.map +1 -1
  291. package/dist/languages/qu.d.ts +6 -44
  292. package/dist/languages/qu.d.ts.map +1 -0
  293. package/dist/languages/qu.js +105 -28
  294. package/dist/languages/qu.js.map +1 -1
  295. package/dist/languages/ru.d.ts +18 -0
  296. package/dist/languages/ru.d.ts.map +1 -0
  297. package/dist/languages/ru.js +1705 -0
  298. package/dist/languages/ru.js.map +1 -0
  299. package/dist/languages/sw.d.ts +6 -32
  300. package/dist/languages/sw.d.ts.map +1 -0
  301. package/dist/languages/sw.js +69 -17
  302. package/dist/languages/sw.js.map +1 -1
  303. package/dist/languages/th.d.ts +10 -0
  304. package/dist/languages/th.d.ts.map +1 -0
  305. package/dist/languages/th.js +1123 -0
  306. package/dist/languages/th.js.map +1 -0
  307. package/dist/languages/tl.d.ts +10 -0
  308. package/dist/languages/tl.d.ts.map +1 -0
  309. package/dist/languages/tl.js +1086 -0
  310. package/dist/languages/tl.js.map +1 -0
  311. package/dist/languages/tr.d.ts +6 -50
  312. package/dist/languages/tr.d.ts.map +1 -0
  313. package/dist/languages/tr.js +67 -16
  314. package/dist/languages/tr.js.map +1 -1
  315. package/dist/languages/uk.d.ts +18 -0
  316. package/dist/languages/uk.d.ts.map +1 -0
  317. package/dist/languages/uk.js +1691 -0
  318. package/dist/languages/uk.js.map +1 -0
  319. package/dist/languages/vi.d.ts +10 -0
  320. package/dist/languages/vi.d.ts.map +1 -0
  321. package/dist/languages/vi.js +1266 -0
  322. package/dist/languages/vi.js.map +1 -0
  323. package/dist/languages/zh.d.ts +6 -55
  324. package/dist/languages/zh.d.ts.map +1 -0
  325. package/dist/languages/zh.js +59 -13
  326. package/dist/languages/zh.js.map +1 -1
  327. package/dist/parser/index.d.ts +8 -0
  328. package/dist/parser/index.d.ts.map +1 -0
  329. package/dist/parser/pattern-matcher.d.ts +188 -0
  330. package/dist/parser/pattern-matcher.d.ts.map +1 -0
  331. package/dist/parser/semantic-parser.d.ts +238 -0
  332. package/dist/parser/semantic-parser.d.ts.map +1 -0
  333. package/dist/parser/utils/index.d.ts +9 -0
  334. package/dist/parser/utils/index.d.ts.map +1 -0
  335. package/dist/parser/utils/marker-resolution.d.ts +57 -0
  336. package/dist/parser/utils/marker-resolution.d.ts.map +1 -0
  337. package/dist/parser/utils/possessive-keywords.d.ts +31 -0
  338. package/dist/parser/utils/possessive-keywords.d.ts.map +1 -0
  339. package/dist/parser/utils/role-positioning.d.ts +42 -0
  340. package/dist/parser/utils/role-positioning.d.ts.map +1 -0
  341. package/dist/parser/utils/type-validation.d.ts +63 -0
  342. package/dist/parser/utils/type-validation.d.ts.map +1 -0
  343. package/dist/patterns/add/ar.d.ts +12 -0
  344. package/dist/patterns/add/ar.d.ts.map +1 -0
  345. package/dist/patterns/add/bn.d.ts +8 -0
  346. package/dist/patterns/add/bn.d.ts.map +1 -0
  347. package/dist/patterns/add/hi.d.ts +8 -0
  348. package/dist/patterns/add/hi.d.ts.map +1 -0
  349. package/dist/patterns/add/index.d.ts +31 -0
  350. package/dist/patterns/add/index.d.ts.map +1 -0
  351. package/dist/patterns/add/it.d.ts +11 -0
  352. package/dist/patterns/add/it.d.ts.map +1 -0
  353. package/dist/patterns/add/ja.d.ts +12 -0
  354. package/dist/patterns/add/ja.d.ts.map +1 -0
  355. package/dist/patterns/add/ko.d.ts +12 -0
  356. package/dist/patterns/add/ko.d.ts.map +1 -0
  357. package/dist/patterns/add/pl.d.ts +12 -0
  358. package/dist/patterns/add/pl.d.ts.map +1 -0
  359. package/dist/patterns/add/qu.d.ts +9 -0
  360. package/dist/patterns/add/qu.d.ts.map +1 -0
  361. package/dist/patterns/add/ru.d.ts +12 -0
  362. package/dist/patterns/add/ru.d.ts.map +1 -0
  363. package/dist/patterns/add/th.d.ts +8 -0
  364. package/dist/patterns/add/th.d.ts.map +1 -0
  365. package/dist/patterns/add/tr.d.ts +12 -0
  366. package/dist/patterns/add/tr.d.ts.map +1 -0
  367. package/dist/patterns/add/uk.d.ts +12 -0
  368. package/dist/patterns/add/uk.d.ts.map +1 -0
  369. package/dist/patterns/add/vi.d.ts +11 -0
  370. package/dist/patterns/add/vi.d.ts.map +1 -0
  371. package/dist/patterns/add/zh.d.ts +12 -0
  372. package/dist/patterns/add/zh.d.ts.map +1 -0
  373. package/dist/patterns/builders.d.ts +52 -0
  374. package/dist/patterns/builders.d.ts.map +1 -0
  375. package/dist/patterns/decrement/bn.d.ts +8 -0
  376. package/dist/patterns/decrement/bn.d.ts.map +1 -0
  377. package/dist/patterns/decrement/de.d.ts +12 -0
  378. package/dist/patterns/decrement/de.d.ts.map +1 -0
  379. package/dist/patterns/decrement/hi.d.ts +8 -0
  380. package/dist/patterns/decrement/hi.d.ts.map +1 -0
  381. package/dist/patterns/decrement/index.d.ts +28 -0
  382. package/dist/patterns/decrement/index.d.ts.map +1 -0
  383. package/dist/patterns/decrement/it.d.ts +11 -0
  384. package/dist/patterns/decrement/it.d.ts.map +1 -0
  385. package/dist/patterns/decrement/pl.d.ts +12 -0
  386. package/dist/patterns/decrement/pl.d.ts.map +1 -0
  387. package/dist/patterns/decrement/ru.d.ts +12 -0
  388. package/dist/patterns/decrement/ru.d.ts.map +1 -0
  389. package/dist/patterns/decrement/th.d.ts +8 -0
  390. package/dist/patterns/decrement/th.d.ts.map +1 -0
  391. package/dist/patterns/decrement/tr.d.ts +12 -0
  392. package/dist/patterns/decrement/tr.d.ts.map +1 -0
  393. package/dist/patterns/decrement/uk.d.ts +12 -0
  394. package/dist/patterns/decrement/uk.d.ts.map +1 -0
  395. package/dist/patterns/decrement/vi.d.ts +11 -0
  396. package/dist/patterns/decrement/vi.d.ts.map +1 -0
  397. package/dist/patterns/decrement/zh.d.ts +12 -0
  398. package/dist/patterns/decrement/zh.d.ts.map +1 -0
  399. package/dist/patterns/en.d.ts +13 -0
  400. package/dist/patterns/en.d.ts.map +1 -0
  401. package/dist/patterns/event-handler/ar.d.ts +12 -0
  402. package/dist/patterns/event-handler/ar.d.ts.map +1 -0
  403. package/dist/patterns/event-handler/bn.d.ts +8 -0
  404. package/dist/patterns/event-handler/bn.d.ts.map +1 -0
  405. package/dist/patterns/event-handler/de.d.ts +11 -0
  406. package/dist/patterns/event-handler/de.d.ts.map +1 -0
  407. package/dist/patterns/event-handler/en.d.ts +11 -0
  408. package/dist/patterns/event-handler/en.d.ts.map +1 -0
  409. package/dist/patterns/event-handler/es.d.ts +11 -0
  410. package/dist/patterns/event-handler/es.d.ts.map +1 -0
  411. package/dist/patterns/event-handler/fr.d.ts +11 -0
  412. package/dist/patterns/event-handler/fr.d.ts.map +1 -0
  413. package/dist/patterns/event-handler/he.d.ts +12 -0
  414. package/dist/patterns/event-handler/he.d.ts.map +1 -0
  415. package/dist/patterns/event-handler/hi.d.ts +9 -0
  416. package/dist/patterns/event-handler/hi.d.ts.map +1 -0
  417. package/dist/patterns/event-handler/id.d.ts +11 -0
  418. package/dist/patterns/event-handler/id.d.ts.map +1 -0
  419. package/dist/patterns/event-handler/index.d.ts +41 -0
  420. package/dist/patterns/event-handler/index.d.ts.map +1 -0
  421. package/dist/patterns/event-handler/it.d.ts +11 -0
  422. package/dist/patterns/event-handler/it.d.ts.map +1 -0
  423. package/dist/patterns/event-handler/ja.d.ts +12 -0
  424. package/dist/patterns/event-handler/ja.d.ts.map +1 -0
  425. package/dist/patterns/event-handler/ko.d.ts +12 -0
  426. package/dist/patterns/event-handler/ko.d.ts.map +1 -0
  427. package/dist/patterns/event-handler/ms.d.ts +14 -0
  428. package/dist/patterns/event-handler/ms.d.ts.map +1 -0
  429. package/dist/patterns/event-handler/pl.d.ts +12 -0
  430. package/dist/patterns/event-handler/pl.d.ts.map +1 -0
  431. package/dist/patterns/event-handler/pt.d.ts +11 -0
  432. package/dist/patterns/event-handler/pt.d.ts.map +1 -0
  433. package/dist/patterns/event-handler/qu.d.ts +11 -0
  434. package/dist/patterns/event-handler/qu.d.ts.map +1 -0
  435. package/dist/patterns/event-handler/ru.d.ts +12 -0
  436. package/dist/patterns/event-handler/ru.d.ts.map +1 -0
  437. package/dist/patterns/event-handler/shared.d.ts +15 -0
  438. package/dist/patterns/event-handler/shared.d.ts.map +1 -0
  439. package/dist/patterns/event-handler/sw.d.ts +11 -0
  440. package/dist/patterns/event-handler/sw.d.ts.map +1 -0
  441. package/dist/patterns/event-handler/th.d.ts +8 -0
  442. package/dist/patterns/event-handler/th.d.ts.map +1 -0
  443. package/dist/patterns/event-handler/tl.d.ts +9 -0
  444. package/dist/patterns/event-handler/tl.d.ts.map +1 -0
  445. package/dist/patterns/event-handler/tr.d.ts +12 -0
  446. package/dist/patterns/event-handler/tr.d.ts.map +1 -0
  447. package/dist/patterns/event-handler/uk.d.ts +12 -0
  448. package/dist/patterns/event-handler/uk.d.ts.map +1 -0
  449. package/dist/patterns/event-handler/vi.d.ts +11 -0
  450. package/dist/patterns/event-handler/vi.d.ts.map +1 -0
  451. package/dist/patterns/event-handler/zh.d.ts +11 -0
  452. package/dist/patterns/event-handler/zh.d.ts.map +1 -0
  453. package/dist/patterns/get/ar.d.ts +12 -0
  454. package/dist/patterns/get/ar.d.ts.map +1 -0
  455. package/dist/patterns/get/bn.d.ts +8 -0
  456. package/dist/patterns/get/bn.d.ts.map +1 -0
  457. package/dist/patterns/get/de.d.ts +12 -0
  458. package/dist/patterns/get/de.d.ts.map +1 -0
  459. package/dist/patterns/get/hi.d.ts +8 -0
  460. package/dist/patterns/get/hi.d.ts.map +1 -0
  461. package/dist/patterns/get/index.d.ts +29 -0
  462. package/dist/patterns/get/index.d.ts.map +1 -0
  463. package/dist/patterns/get/it.d.ts +11 -0
  464. package/dist/patterns/get/it.d.ts.map +1 -0
  465. package/dist/patterns/get/ja.d.ts +12 -0
  466. package/dist/patterns/get/ja.d.ts.map +1 -0
  467. package/dist/patterns/get/ko.d.ts +12 -0
  468. package/dist/patterns/get/ko.d.ts.map +1 -0
  469. package/dist/patterns/get/pl.d.ts +12 -0
  470. package/dist/patterns/get/pl.d.ts.map +1 -0
  471. package/dist/patterns/get/ru.d.ts +12 -0
  472. package/dist/patterns/get/ru.d.ts.map +1 -0
  473. package/dist/patterns/get/th.d.ts +8 -0
  474. package/dist/patterns/get/th.d.ts.map +1 -0
  475. package/dist/patterns/get/uk.d.ts +12 -0
  476. package/dist/patterns/get/uk.d.ts.map +1 -0
  477. package/dist/patterns/get/vi.d.ts +11 -0
  478. package/dist/patterns/get/vi.d.ts.map +1 -0
  479. package/dist/patterns/grammar-transformed/index.d.ts +20 -0
  480. package/dist/patterns/grammar-transformed/index.d.ts.map +1 -0
  481. package/dist/patterns/grammar-transformed/ja.d.ts +12 -0
  482. package/dist/patterns/grammar-transformed/ja.d.ts.map +1 -0
  483. package/dist/patterns/grammar-transformed/ko.d.ts +12 -0
  484. package/dist/patterns/grammar-transformed/ko.d.ts.map +1 -0
  485. package/dist/patterns/grammar-transformed/tr.d.ts +12 -0
  486. package/dist/patterns/grammar-transformed/tr.d.ts.map +1 -0
  487. package/dist/patterns/hide/ar.d.ts +12 -0
  488. package/dist/patterns/hide/ar.d.ts.map +1 -0
  489. package/dist/patterns/hide/bn.d.ts +8 -0
  490. package/dist/patterns/hide/bn.d.ts.map +1 -0
  491. package/dist/patterns/hide/de.d.ts +12 -0
  492. package/dist/patterns/hide/de.d.ts.map +1 -0
  493. package/dist/patterns/hide/hi.d.ts +8 -0
  494. package/dist/patterns/hide/hi.d.ts.map +1 -0
  495. package/dist/patterns/hide/index.d.ts +31 -0
  496. package/dist/patterns/hide/index.d.ts.map +1 -0
  497. package/dist/patterns/hide/it.d.ts +11 -0
  498. package/dist/patterns/hide/it.d.ts.map +1 -0
  499. package/dist/patterns/hide/ja.d.ts +12 -0
  500. package/dist/patterns/hide/ja.d.ts.map +1 -0
  501. package/dist/patterns/hide/ko.d.ts +12 -0
  502. package/dist/patterns/hide/ko.d.ts.map +1 -0
  503. package/dist/patterns/hide/pl.d.ts +12 -0
  504. package/dist/patterns/hide/pl.d.ts.map +1 -0
  505. package/dist/patterns/hide/ru.d.ts +12 -0
  506. package/dist/patterns/hide/ru.d.ts.map +1 -0
  507. package/dist/patterns/hide/th.d.ts +8 -0
  508. package/dist/patterns/hide/th.d.ts.map +1 -0
  509. package/dist/patterns/hide/tr.d.ts +12 -0
  510. package/dist/patterns/hide/tr.d.ts.map +1 -0
  511. package/dist/patterns/hide/uk.d.ts +12 -0
  512. package/dist/patterns/hide/uk.d.ts.map +1 -0
  513. package/dist/patterns/hide/vi.d.ts +11 -0
  514. package/dist/patterns/hide/vi.d.ts.map +1 -0
  515. package/dist/patterns/hide/zh.d.ts +12 -0
  516. package/dist/patterns/hide/zh.d.ts.map +1 -0
  517. package/dist/patterns/increment/bn.d.ts +8 -0
  518. package/dist/patterns/increment/bn.d.ts.map +1 -0
  519. package/dist/patterns/increment/de.d.ts +12 -0
  520. package/dist/patterns/increment/de.d.ts.map +1 -0
  521. package/dist/patterns/increment/hi.d.ts +8 -0
  522. package/dist/patterns/increment/hi.d.ts.map +1 -0
  523. package/dist/patterns/increment/index.d.ts +28 -0
  524. package/dist/patterns/increment/index.d.ts.map +1 -0
  525. package/dist/patterns/increment/it.d.ts +11 -0
  526. package/dist/patterns/increment/it.d.ts.map +1 -0
  527. package/dist/patterns/increment/pl.d.ts +12 -0
  528. package/dist/patterns/increment/pl.d.ts.map +1 -0
  529. package/dist/patterns/increment/ru.d.ts +12 -0
  530. package/dist/patterns/increment/ru.d.ts.map +1 -0
  531. package/dist/patterns/increment/th.d.ts +8 -0
  532. package/dist/patterns/increment/th.d.ts.map +1 -0
  533. package/dist/patterns/increment/tr.d.ts +12 -0
  534. package/dist/patterns/increment/tr.d.ts.map +1 -0
  535. package/dist/patterns/increment/uk.d.ts +12 -0
  536. package/dist/patterns/increment/uk.d.ts.map +1 -0
  537. package/dist/patterns/increment/vi.d.ts +11 -0
  538. package/dist/patterns/increment/vi.d.ts.map +1 -0
  539. package/dist/patterns/increment/zh.d.ts +12 -0
  540. package/dist/patterns/increment/zh.d.ts.map +1 -0
  541. package/dist/patterns/index.d.ts +21 -0
  542. package/dist/patterns/index.d.ts.map +1 -0
  543. package/dist/patterns/languages/en/control-flow.d.ts +40 -0
  544. package/dist/patterns/languages/en/control-flow.d.ts.map +1 -0
  545. package/dist/patterns/languages/en/fetch.d.ts +22 -0
  546. package/dist/patterns/languages/en/fetch.d.ts.map +1 -0
  547. package/dist/patterns/languages/en/index.d.ts +22 -0
  548. package/dist/patterns/languages/en/index.d.ts.map +1 -0
  549. package/dist/patterns/languages/en/repeat.d.ts +22 -0
  550. package/dist/patterns/languages/en/repeat.d.ts.map +1 -0
  551. package/dist/patterns/languages/en/set.d.ts +23 -0
  552. package/dist/patterns/languages/en/set.d.ts.map +1 -0
  553. package/dist/patterns/languages/en/swap.d.ts +19 -0
  554. package/dist/patterns/languages/en/swap.d.ts.map +1 -0
  555. package/dist/patterns/languages/en/temporal.d.ts +24 -0
  556. package/dist/patterns/languages/en/temporal.d.ts.map +1 -0
  557. package/dist/patterns/put/ar.d.ts +12 -0
  558. package/dist/patterns/put/ar.d.ts.map +1 -0
  559. package/dist/patterns/put/bn.d.ts +8 -0
  560. package/dist/patterns/put/bn.d.ts.map +1 -0
  561. package/dist/patterns/put/en.d.ts +11 -0
  562. package/dist/patterns/put/en.d.ts.map +1 -0
  563. package/dist/patterns/put/es.d.ts +11 -0
  564. package/dist/patterns/put/es.d.ts.map +1 -0
  565. package/dist/patterns/put/hi.d.ts +8 -0
  566. package/dist/patterns/put/hi.d.ts.map +1 -0
  567. package/dist/patterns/put/id.d.ts +15 -0
  568. package/dist/patterns/put/id.d.ts.map +1 -0
  569. package/dist/patterns/put/index.d.ts +33 -0
  570. package/dist/patterns/put/index.d.ts.map +1 -0
  571. package/dist/patterns/put/it.d.ts +11 -0
  572. package/dist/patterns/put/it.d.ts.map +1 -0
  573. package/dist/patterns/put/ja.d.ts +12 -0
  574. package/dist/patterns/put/ja.d.ts.map +1 -0
  575. package/dist/patterns/put/ko.d.ts +12 -0
  576. package/dist/patterns/put/ko.d.ts.map +1 -0
  577. package/dist/patterns/put/pl.d.ts +12 -0
  578. package/dist/patterns/put/pl.d.ts.map +1 -0
  579. package/dist/patterns/put/ru.d.ts +12 -0
  580. package/dist/patterns/put/ru.d.ts.map +1 -0
  581. package/dist/patterns/put/th.d.ts +8 -0
  582. package/dist/patterns/put/th.d.ts.map +1 -0
  583. package/dist/patterns/put/tr.d.ts +12 -0
  584. package/dist/patterns/put/tr.d.ts.map +1 -0
  585. package/dist/patterns/put/uk.d.ts +12 -0
  586. package/dist/patterns/put/uk.d.ts.map +1 -0
  587. package/dist/patterns/put/vi.d.ts +11 -0
  588. package/dist/patterns/put/vi.d.ts.map +1 -0
  589. package/dist/patterns/put/zh.d.ts +12 -0
  590. package/dist/patterns/put/zh.d.ts.map +1 -0
  591. package/dist/patterns/registry.d.ts +53 -0
  592. package/dist/patterns/registry.d.ts.map +1 -0
  593. package/dist/patterns/remove/ar.d.ts +12 -0
  594. package/dist/patterns/remove/ar.d.ts.map +1 -0
  595. package/dist/patterns/remove/bn.d.ts +8 -0
  596. package/dist/patterns/remove/bn.d.ts.map +1 -0
  597. package/dist/patterns/remove/hi.d.ts +8 -0
  598. package/dist/patterns/remove/hi.d.ts.map +1 -0
  599. package/dist/patterns/remove/index.d.ts +31 -0
  600. package/dist/patterns/remove/index.d.ts.map +1 -0
  601. package/dist/patterns/remove/it.d.ts +11 -0
  602. package/dist/patterns/remove/it.d.ts.map +1 -0
  603. package/dist/patterns/remove/ja.d.ts +12 -0
  604. package/dist/patterns/remove/ja.d.ts.map +1 -0
  605. package/dist/patterns/remove/ko.d.ts +12 -0
  606. package/dist/patterns/remove/ko.d.ts.map +1 -0
  607. package/dist/patterns/remove/pl.d.ts +12 -0
  608. package/dist/patterns/remove/pl.d.ts.map +1 -0
  609. package/dist/patterns/remove/qu.d.ts +9 -0
  610. package/dist/patterns/remove/qu.d.ts.map +1 -0
  611. package/dist/patterns/remove/ru.d.ts +12 -0
  612. package/dist/patterns/remove/ru.d.ts.map +1 -0
  613. package/dist/patterns/remove/th.d.ts +8 -0
  614. package/dist/patterns/remove/th.d.ts.map +1 -0
  615. package/dist/patterns/remove/tr.d.ts +12 -0
  616. package/dist/patterns/remove/tr.d.ts.map +1 -0
  617. package/dist/patterns/remove/uk.d.ts +12 -0
  618. package/dist/patterns/remove/uk.d.ts.map +1 -0
  619. package/dist/patterns/remove/vi.d.ts +11 -0
  620. package/dist/patterns/remove/vi.d.ts.map +1 -0
  621. package/dist/patterns/remove/zh.d.ts +12 -0
  622. package/dist/patterns/remove/zh.d.ts.map +1 -0
  623. package/dist/patterns/set/ar.d.ts +12 -0
  624. package/dist/patterns/set/ar.d.ts.map +1 -0
  625. package/dist/patterns/set/bn.d.ts +8 -0
  626. package/dist/patterns/set/bn.d.ts.map +1 -0
  627. package/dist/patterns/set/de.d.ts +12 -0
  628. package/dist/patterns/set/de.d.ts.map +1 -0
  629. package/dist/patterns/set/es.d.ts +12 -0
  630. package/dist/patterns/set/es.d.ts.map +1 -0
  631. package/dist/patterns/set/fr.d.ts +12 -0
  632. package/dist/patterns/set/fr.d.ts.map +1 -0
  633. package/dist/patterns/set/hi.d.ts +8 -0
  634. package/dist/patterns/set/hi.d.ts.map +1 -0
  635. package/dist/patterns/set/id.d.ts +12 -0
  636. package/dist/patterns/set/id.d.ts.map +1 -0
  637. package/dist/patterns/set/index.d.ts +35 -0
  638. package/dist/patterns/set/index.d.ts.map +1 -0
  639. package/dist/patterns/set/it.d.ts +11 -0
  640. package/dist/patterns/set/it.d.ts.map +1 -0
  641. package/dist/patterns/set/ja.d.ts +12 -0
  642. package/dist/patterns/set/ja.d.ts.map +1 -0
  643. package/dist/patterns/set/ko.d.ts +12 -0
  644. package/dist/patterns/set/ko.d.ts.map +1 -0
  645. package/dist/patterns/set/pl.d.ts +12 -0
  646. package/dist/patterns/set/pl.d.ts.map +1 -0
  647. package/dist/patterns/set/pt.d.ts +12 -0
  648. package/dist/patterns/set/pt.d.ts.map +1 -0
  649. package/dist/patterns/set/ru.d.ts +12 -0
  650. package/dist/patterns/set/ru.d.ts.map +1 -0
  651. package/dist/patterns/set/th.d.ts +8 -0
  652. package/dist/patterns/set/th.d.ts.map +1 -0
  653. package/dist/patterns/set/tr.d.ts +12 -0
  654. package/dist/patterns/set/tr.d.ts.map +1 -0
  655. package/dist/patterns/set/uk.d.ts +12 -0
  656. package/dist/patterns/set/uk.d.ts.map +1 -0
  657. package/dist/patterns/set/vi.d.ts +11 -0
  658. package/dist/patterns/set/vi.d.ts.map +1 -0
  659. package/dist/patterns/set/zh.d.ts +12 -0
  660. package/dist/patterns/set/zh.d.ts.map +1 -0
  661. package/dist/patterns/show/ar.d.ts +12 -0
  662. package/dist/patterns/show/ar.d.ts.map +1 -0
  663. package/dist/patterns/show/bn.d.ts +8 -0
  664. package/dist/patterns/show/bn.d.ts.map +1 -0
  665. package/dist/patterns/show/de.d.ts +12 -0
  666. package/dist/patterns/show/de.d.ts.map +1 -0
  667. package/dist/patterns/show/fr.d.ts +12 -0
  668. package/dist/patterns/show/fr.d.ts.map +1 -0
  669. package/dist/patterns/show/hi.d.ts +8 -0
  670. package/dist/patterns/show/hi.d.ts.map +1 -0
  671. package/dist/patterns/show/index.d.ts +32 -0
  672. package/dist/patterns/show/index.d.ts.map +1 -0
  673. package/dist/patterns/show/it.d.ts +11 -0
  674. package/dist/patterns/show/it.d.ts.map +1 -0
  675. package/dist/patterns/show/ja.d.ts +12 -0
  676. package/dist/patterns/show/ja.d.ts.map +1 -0
  677. package/dist/patterns/show/ko.d.ts +12 -0
  678. package/dist/patterns/show/ko.d.ts.map +1 -0
  679. package/dist/patterns/show/pl.d.ts +12 -0
  680. package/dist/patterns/show/pl.d.ts.map +1 -0
  681. package/dist/patterns/show/ru.d.ts +12 -0
  682. package/dist/patterns/show/ru.d.ts.map +1 -0
  683. package/dist/patterns/show/th.d.ts +8 -0
  684. package/dist/patterns/show/th.d.ts.map +1 -0
  685. package/dist/patterns/show/tr.d.ts +12 -0
  686. package/dist/patterns/show/tr.d.ts.map +1 -0
  687. package/dist/patterns/show/uk.d.ts +12 -0
  688. package/dist/patterns/show/uk.d.ts.map +1 -0
  689. package/dist/patterns/show/vi.d.ts +11 -0
  690. package/dist/patterns/show/vi.d.ts.map +1 -0
  691. package/dist/patterns/show/zh.d.ts +12 -0
  692. package/dist/patterns/show/zh.d.ts.map +1 -0
  693. package/dist/patterns/take/ar.d.ts +12 -0
  694. package/dist/patterns/take/ar.d.ts.map +1 -0
  695. package/dist/patterns/take/index.d.ts +18 -0
  696. package/dist/patterns/take/index.d.ts.map +1 -0
  697. package/dist/patterns/toggle/ar.d.ts +12 -0
  698. package/dist/patterns/toggle/ar.d.ts.map +1 -0
  699. package/dist/patterns/toggle/bn.d.ts +8 -0
  700. package/dist/patterns/toggle/bn.d.ts.map +1 -0
  701. package/dist/patterns/toggle/en.d.ts +11 -0
  702. package/dist/patterns/toggle/en.d.ts.map +1 -0
  703. package/dist/patterns/toggle/es.d.ts +11 -0
  704. package/dist/patterns/toggle/es.d.ts.map +1 -0
  705. package/dist/patterns/toggle/hi.d.ts +9 -0
  706. package/dist/patterns/toggle/hi.d.ts.map +1 -0
  707. package/dist/patterns/toggle/index.d.ts +33 -0
  708. package/dist/patterns/toggle/index.d.ts.map +1 -0
  709. package/dist/patterns/toggle/it.d.ts +11 -0
  710. package/dist/patterns/toggle/it.d.ts.map +1 -0
  711. package/dist/patterns/toggle/ja.d.ts +12 -0
  712. package/dist/patterns/toggle/ja.d.ts.map +1 -0
  713. package/dist/patterns/toggle/ko.d.ts +12 -0
  714. package/dist/patterns/toggle/ko.d.ts.map +1 -0
  715. package/dist/patterns/toggle/pl.d.ts +12 -0
  716. package/dist/patterns/toggle/pl.d.ts.map +1 -0
  717. package/dist/patterns/toggle/qu.d.ts +9 -0
  718. package/dist/patterns/toggle/qu.d.ts.map +1 -0
  719. package/dist/patterns/toggle/ru.d.ts +12 -0
  720. package/dist/patterns/toggle/ru.d.ts.map +1 -0
  721. package/dist/patterns/toggle/th.d.ts +9 -0
  722. package/dist/patterns/toggle/th.d.ts.map +1 -0
  723. package/dist/patterns/toggle/tr.d.ts +12 -0
  724. package/dist/patterns/toggle/tr.d.ts.map +1 -0
  725. package/dist/patterns/toggle/uk.d.ts +12 -0
  726. package/dist/patterns/toggle/uk.d.ts.map +1 -0
  727. package/dist/patterns/toggle/vi.d.ts +11 -0
  728. package/dist/patterns/toggle/vi.d.ts.map +1 -0
  729. package/dist/patterns/toggle/zh.d.ts +11 -0
  730. package/dist/patterns/toggle/zh.d.ts.map +1 -0
  731. package/dist/public-api.d.ts +190 -0
  732. package/dist/public-api.d.ts.map +1 -0
  733. package/dist/registry.d.ts +225 -0
  734. package/dist/registry.d.ts.map +1 -0
  735. package/dist/tokenizers/arabic.d.ts +67 -0
  736. package/dist/tokenizers/arabic.d.ts.map +1 -0
  737. package/dist/tokenizers/base-tokenizer.d.ts +240 -0
  738. package/dist/tokenizers/base-tokenizer.d.ts.map +1 -0
  739. package/dist/tokenizers/base.d.ts +14 -0
  740. package/dist/tokenizers/base.d.ts.map +1 -0
  741. package/dist/tokenizers/bengali.d.ts +22 -0
  742. package/dist/tokenizers/bengali.d.ts.map +1 -0
  743. package/dist/tokenizers/char-classifiers.d.ts +56 -0
  744. package/dist/tokenizers/char-classifiers.d.ts.map +1 -0
  745. package/dist/tokenizers/chinese.d.ts +47 -0
  746. package/dist/tokenizers/chinese.d.ts.map +1 -0
  747. package/dist/tokenizers/english.d.ts +34 -0
  748. package/dist/tokenizers/english.d.ts.map +1 -0
  749. package/dist/tokenizers/extractors.d.ts +61 -0
  750. package/dist/tokenizers/extractors.d.ts.map +1 -0
  751. package/dist/tokenizers/french.d.ts +26 -0
  752. package/dist/tokenizers/french.d.ts.map +1 -0
  753. package/dist/tokenizers/german.d.ts +27 -0
  754. package/dist/tokenizers/german.d.ts.map +1 -0
  755. package/dist/tokenizers/he.d.ts +58 -0
  756. package/dist/tokenizers/he.d.ts.map +1 -0
  757. package/dist/tokenizers/hindi.d.ts +25 -0
  758. package/dist/tokenizers/hindi.d.ts.map +1 -0
  759. package/dist/tokenizers/index.d.ts +64 -0
  760. package/dist/tokenizers/index.d.ts.map +1 -0
  761. package/dist/tokenizers/indonesian.d.ts +24 -0
  762. package/dist/tokenizers/indonesian.d.ts.map +1 -0
  763. package/dist/tokenizers/italian.d.ts +41 -0
  764. package/dist/tokenizers/italian.d.ts.map +1 -0
  765. package/dist/tokenizers/japanese.d.ts +42 -0
  766. package/dist/tokenizers/japanese.d.ts.map +1 -0
  767. package/dist/tokenizers/korean.d.ts +47 -0
  768. package/dist/tokenizers/korean.d.ts.map +1 -0
  769. package/dist/tokenizers/morphology/arabic-normalizer.d.ts +37 -0
  770. package/dist/tokenizers/morphology/arabic-normalizer.d.ts.map +1 -0
  771. package/dist/tokenizers/morphology/french-normalizer.d.ts +46 -0
  772. package/dist/tokenizers/morphology/french-normalizer.d.ts.map +1 -0
  773. package/dist/tokenizers/morphology/german-normalizer.d.ts +55 -0
  774. package/dist/tokenizers/morphology/german-normalizer.d.ts.map +1 -0
  775. package/dist/tokenizers/morphology/index.d.ts +20 -0
  776. package/dist/tokenizers/morphology/index.d.ts.map +1 -0
  777. package/dist/tokenizers/morphology/italian-normalizer.d.ts +52 -0
  778. package/dist/tokenizers/morphology/italian-normalizer.d.ts.map +1 -0
  779. package/dist/tokenizers/morphology/japanese-normalizer.d.ts +43 -0
  780. package/dist/tokenizers/morphology/japanese-normalizer.d.ts.map +1 -0
  781. package/dist/tokenizers/morphology/korean-normalizer.d.ts +45 -0
  782. package/dist/tokenizers/morphology/korean-normalizer.d.ts.map +1 -0
  783. package/dist/tokenizers/morphology/polish-normalizer.d.ts +61 -0
  784. package/dist/tokenizers/morphology/polish-normalizer.d.ts.map +1 -0
  785. package/dist/tokenizers/morphology/portuguese-normalizer.d.ts +51 -0
  786. package/dist/tokenizers/morphology/portuguese-normalizer.d.ts.map +1 -0
  787. package/dist/tokenizers/morphology/russian-normalizer.d.ts +72 -0
  788. package/dist/tokenizers/morphology/russian-normalizer.d.ts.map +1 -0
  789. package/dist/tokenizers/morphology/spanish-normalizer.d.ts +49 -0
  790. package/dist/tokenizers/morphology/spanish-normalizer.d.ts.map +1 -0
  791. package/dist/tokenizers/morphology/turkish-normalizer.d.ts +52 -0
  792. package/dist/tokenizers/morphology/turkish-normalizer.d.ts.map +1 -0
  793. package/dist/tokenizers/morphology/types.d.ts +110 -0
  794. package/dist/tokenizers/morphology/types.d.ts.map +1 -0
  795. package/dist/tokenizers/morphology/ukrainian-normalizer.d.ts +76 -0
  796. package/dist/tokenizers/morphology/ukrainian-normalizer.d.ts.map +1 -0
  797. package/dist/tokenizers/ms.d.ts +22 -0
  798. package/dist/tokenizers/ms.d.ts.map +1 -0
  799. package/dist/tokenizers/polish.d.ts +25 -0
  800. package/dist/tokenizers/polish.d.ts.map +1 -0
  801. package/dist/tokenizers/portuguese.d.ts +26 -0
  802. package/dist/tokenizers/portuguese.d.ts.map +1 -0
  803. package/dist/tokenizers/quechua.d.ts +36 -0
  804. package/dist/tokenizers/quechua.d.ts.map +1 -0
  805. package/dist/tokenizers/russian.d.ts +25 -0
  806. package/dist/tokenizers/russian.d.ts.map +1 -0
  807. package/dist/tokenizers/spanish.d.ts +41 -0
  808. package/dist/tokenizers/spanish.d.ts.map +1 -0
  809. package/dist/tokenizers/swahili.d.ts +24 -0
  810. package/dist/tokenizers/swahili.d.ts.map +1 -0
  811. package/dist/tokenizers/thai.d.ts +24 -0
  812. package/dist/tokenizers/thai.d.ts.map +1 -0
  813. package/dist/tokenizers/tl.d.ts +22 -0
  814. package/dist/tokenizers/tl.d.ts.map +1 -0
  815. package/dist/tokenizers/token-utils.d.ts +97 -0
  816. package/dist/tokenizers/token-utils.d.ts.map +1 -0
  817. package/dist/tokenizers/turkish.d.ts +42 -0
  818. package/dist/tokenizers/turkish.d.ts.map +1 -0
  819. package/dist/tokenizers/ukrainian.d.ts +25 -0
  820. package/dist/tokenizers/ukrainian.d.ts.map +1 -0
  821. package/dist/tokenizers/vietnamese.d.ts +47 -0
  822. package/dist/tokenizers/vietnamese.d.ts.map +1 -0
  823. package/dist/types/grammar-types.d.ts +224 -0
  824. package/dist/types/grammar-types.d.ts.map +1 -0
  825. package/dist/types/unified-profile.d.ts +167 -0
  826. package/dist/types/unified-profile.d.ts.map +1 -0
  827. package/dist/types.d.ts +401 -0
  828. package/dist/types.d.ts.map +1 -0
  829. package/dist/utils/confidence-calculator.d.ts +43 -0
  830. package/dist/utils/confidence-calculator.d.ts.map +1 -0
  831. package/dist/validators/command-validator.d.ts +83 -0
  832. package/dist/validators/command-validator.d.ts.map +1 -0
  833. package/dist/validators/index.d.ts +7 -0
  834. package/dist/validators/index.d.ts.map +1 -0
  835. package/package.json +86 -6
  836. package/src/ast-builder/command-mappers.ts +9 -1
  837. package/src/ast-builder/expression-parser/parser.ts +13 -2
  838. package/src/ast-builder/index.ts +20 -6
  839. package/src/browser-bn.ts +162 -0
  840. package/src/browser-east-asian.ts +1 -1
  841. package/src/browser-hi.ts +162 -0
  842. package/src/browser-it.ts +162 -0
  843. package/src/browser-ms.ts +162 -0
  844. package/src/browser-pl.ts +162 -0
  845. package/src/browser-priority.ts +1 -1
  846. package/src/browser-ru.ts +162 -0
  847. package/src/browser-th.ts +162 -0
  848. package/src/browser-tl.ts +162 -0
  849. package/src/browser-uk.ts +162 -0
  850. package/src/browser-vi.ts +162 -0
  851. package/src/browser-western.ts +1 -1
  852. package/src/core-bridge.ts +43 -16
  853. package/src/core.ts +13 -0
  854. package/src/explicit/parser.ts +4 -2
  855. package/src/explicit/renderer.ts +1 -1
  856. package/src/generators/command-schemas.ts +214 -2
  857. package/src/generators/event-handlers-sov.ts +686 -0
  858. package/src/generators/event-handlers-vso.ts +489 -0
  859. package/src/generators/pattern-generator.ts +93 -736
  860. package/src/generators/profiles/arabic.ts +11 -1
  861. package/src/generators/profiles/bengali.ts +6 -0
  862. package/src/generators/profiles/chinese.ts +6 -0
  863. package/src/generators/profiles/english.ts +6 -0
  864. package/src/generators/profiles/french.ts +6 -0
  865. package/src/generators/profiles/german.ts +6 -0
  866. package/src/generators/profiles/hebrew.ts +6 -0
  867. package/src/generators/profiles/hindi.ts +6 -0
  868. package/src/generators/profiles/indonesian.ts +6 -0
  869. package/src/generators/profiles/italian.ts +6 -0
  870. package/src/generators/profiles/japanese.ts +6 -0
  871. package/src/generators/profiles/korean.ts +6 -0
  872. package/src/generators/profiles/ms.ts +6 -0
  873. package/src/generators/profiles/polish.ts +6 -0
  874. package/src/generators/profiles/portuguese.ts +6 -0
  875. package/src/generators/profiles/quechua.ts +35 -13
  876. package/src/generators/profiles/russian.ts +6 -0
  877. package/src/generators/profiles/spanish.ts +6 -0
  878. package/src/generators/profiles/spanishMexico.ts +6 -0
  879. package/src/generators/profiles/swahili.ts +14 -3
  880. package/src/generators/profiles/thai.ts +6 -0
  881. package/src/generators/profiles/tl.ts +22 -9
  882. package/src/generators/profiles/turkish.ts +7 -1
  883. package/src/generators/profiles/ukrainian.ts +6 -0
  884. package/src/generators/profiles/vietnamese.ts +6 -0
  885. package/src/generators/schema-validator.ts +8 -3
  886. package/src/index.ts +54 -0
  887. package/src/interchange/from-semantic.ts +440 -0
  888. package/src/interchange/index.ts +26 -0
  889. package/src/interchange/types.ts +186 -0
  890. package/src/parser/pattern-matcher.ts +65 -15
  891. package/src/parser/semantic-parser.ts +850 -8
  892. package/src/patterns/add/index.ts +1 -9
  893. package/src/patterns/builders.ts +2 -2
  894. package/src/patterns/decrement/index.ts +1 -9
  895. package/src/patterns/event-handler/shared.ts +30 -0
  896. package/src/patterns/event-handler/tl.ts +39 -19
  897. package/src/patterns/get/index.ts +1 -9
  898. package/src/patterns/hide/index.ts +1 -9
  899. package/src/patterns/increment/index.ts +1 -9
  900. package/src/patterns/put/index.ts +1 -9
  901. package/src/patterns/registry.ts +2 -2
  902. package/src/patterns/remove/index.ts +1 -9
  903. package/src/patterns/set/index.ts +1 -9
  904. package/src/patterns/show/index.ts +1 -9
  905. package/src/patterns/toggle/index.ts +1 -9
  906. package/src/tokenizers/arabic.ts +14 -1
  907. package/src/tokenizers/base-tokenizer.ts +644 -0
  908. package/src/tokenizers/base.ts +39 -1297
  909. package/src/tokenizers/bengali.ts +37 -10
  910. package/src/tokenizers/char-classifiers.ts +79 -0
  911. package/src/tokenizers/chinese.ts +7 -0
  912. package/src/tokenizers/english.ts +8 -1
  913. package/src/tokenizers/extractors.ts +452 -0
  914. package/src/tokenizers/french.ts +16 -1
  915. package/src/tokenizers/german.ts +16 -1
  916. package/src/tokenizers/he.ts +14 -1
  917. package/src/tokenizers/hindi.ts +14 -1
  918. package/src/tokenizers/indonesian.ts +14 -1
  919. package/src/tokenizers/italian.ts +14 -1
  920. package/src/tokenizers/japanese.ts +14 -1
  921. package/src/tokenizers/korean.ts +19 -1
  922. package/src/tokenizers/morphology/index.ts +17 -0
  923. package/src/tokenizers/morphology/polish-normalizer.ts +147 -131
  924. package/src/tokenizers/morphology/russian-normalizer.ts +397 -0
  925. package/src/tokenizers/morphology/ukrainian-normalizer.ts +366 -0
  926. package/src/tokenizers/ms.ts +14 -1
  927. package/src/tokenizers/polish.ts +16 -1
  928. package/src/tokenizers/portuguese.ts +16 -1
  929. package/src/tokenizers/quechua.ts +30 -1
  930. package/src/tokenizers/russian.ts +16 -1
  931. package/src/tokenizers/spanish.ts +14 -1
  932. package/src/tokenizers/swahili.ts +14 -1
  933. package/src/tokenizers/thai.ts +14 -1
  934. package/src/tokenizers/tl.ts +14 -1
  935. package/src/tokenizers/token-utils.ts +205 -0
  936. package/src/tokenizers/turkish.ts +21 -2
  937. package/src/tokenizers/ukrainian.ts +16 -1
  938. package/src/tokenizers/vietnamese.ts +7 -0
  939. package/src/types.ts +41 -2
  940. package/src/validators/command-validator.ts +17 -40
  941. package/dist/index.d.cts +0 -3470
  942. package/dist/types-BY3Id07j.d.ts +0 -615
  943. package/src/bridge.ts +0 -275
  944. package/src/generators/event-handler-generator.ts +0 -115
  945. package/src/patterns/add/ms.ts +0 -30
  946. package/src/patterns/add/tl.ts +0 -30
  947. package/src/patterns/decrement/ms.ts +0 -30
  948. package/src/patterns/decrement/tl.ts +0 -30
  949. package/src/patterns/get/ms.ts +0 -30
  950. package/src/patterns/get/tl.ts +0 -30
  951. package/src/patterns/hide/ms.ts +0 -30
  952. package/src/patterns/hide/tl.ts +0 -30
  953. package/src/patterns/increment/ms.ts +0 -30
  954. package/src/patterns/increment/tl.ts +0 -30
  955. package/src/patterns/put/ms.ts +0 -30
  956. package/src/patterns/put/tl.ts +0 -30
  957. package/src/patterns/remove/ms.ts +0 -30
  958. package/src/patterns/remove/tl.ts +0 -30
  959. package/src/patterns/set/ms.ts +0 -30
  960. package/src/patterns/set/tl.ts +0 -30
  961. package/src/patterns/show/ms.ts +0 -30
  962. package/src/patterns/show/tl.ts +0 -30
  963. package/src/patterns/toggle/ms.ts +0 -30
  964. package/src/patterns/toggle/tl.ts +0 -30
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/registry.ts","../../src/tokenizers/token-utils.ts","../../src/tokenizers/char-classifiers.ts","../../src/tokenizers/extractors.ts","../../src/tokenizers/base-tokenizer.ts","../../src/generators/profiles/ukrainian.ts","../../src/tokenizers/morphology/types.ts","../../src/tokenizers/morphology/ukrainian-normalizer.ts","../../src/tokenizers/ukrainian.ts","../../src/languages/uk.ts"],"sourcesContent":["/**\n * Language Registry\n *\n * Central registration point for language support in the semantic parser.\n * Languages self-register when their modules are imported, enabling\n * tree-shaking for minimal bundles.\n *\n * @example\n * ```typescript\n * // Import only the languages you need\n * import '@lokascript/semantic/languages/en';\n * import '@lokascript/semantic/languages/es';\n *\n * // Now parse works for registered languages\n * import { parse } from '@lokascript/semantic';\n * parse('toggle .active', 'en'); // Works\n * parse('alternar .activo', 'es'); // Works\n * parse('切り替え .active', 'ja'); // Error: Language not registered\n * ```\n */\n\nimport type { LanguageTokenizer, LanguagePattern, TokenStream } from './types';\n\n// Re-export profile types from generators for convenience\nexport type {\n LanguageProfile,\n WordOrder,\n MarkingStrategy,\n RoleMarker,\n VerbConfig,\n PossessiveConfig,\n KeywordTranslation,\n TokenizationConfig,\n} from './generators/language-profiles';\n\nimport type { LanguageProfile } from './generators/language-profiles';\n\n// =============================================================================\n// External Pattern Source Interface\n// =============================================================================\n\n/**\n * Interface for external pattern sources (e.g., @lokascript/patterns-reference database).\n * External sources can provide additional patterns at runtime.\n */\nexport interface ExternalPatternsSource {\n /** Unique identifier for the source */\n id: string;\n /** Human-readable name */\n name: string;\n /** Get patterns for a specific language */\n getPatternsForLanguage(language: string): Promise<ExternalPatternEntry[]>;\n /** Get patterns for a specific command */\n getPatternsForCommand(command: string, language?: string): Promise<ExternalPatternEntry[]>;\n /** Check if source has patterns for a language */\n hasPatterns(language: string): Promise<boolean>;\n /** Get all supported languages */\n getSupportedLanguages(): Promise<string[]>;\n}\n\n/**\n * Pattern entry from external source.\n */\nexport interface ExternalPatternEntry {\n id: string;\n code: string;\n command: string | null;\n language: string;\n confidence: number;\n verified: boolean;\n title?: string;\n category?: string;\n}\n\n// =============================================================================\n// Registry State\n// =============================================================================\n\nconst tokenizers = new Map<string, LanguageTokenizer>();\nconst profiles = new Map<string, LanguageProfile>();\nconst patternCache = new Map<string, LanguagePattern[]>();\n\n// External pattern sources (e.g., @lokascript/patterns-reference database)\nconst externalSources = new Map<string, ExternalPatternsSource>();\n\n// Pattern generator function - set by patterns module to avoid circular deps\nlet patternGenerator: ((profile: LanguageProfile) => LanguagePattern[]) | null = null;\n\n// =============================================================================\n// Profile Inheritance\n// =============================================================================\n\n/**\n * Deep merge two objects, with variant values overriding base values.\n * Arrays are replaced, not merged.\n */\nfunction deepMerge<T extends object>(base: T, variant: Partial<T>): T {\n const result = { ...base } as T;\n\n for (const key of Object.keys(variant) as (keyof T)[]) {\n const variantValue = variant[key];\n const baseValue = base[key];\n\n if (variantValue === undefined) {\n continue;\n }\n\n // If both are objects (but not arrays), merge recursively\n if (\n typeof variantValue === 'object' &&\n variantValue !== null &&\n !Array.isArray(variantValue) &&\n typeof baseValue === 'object' &&\n baseValue !== null &&\n !Array.isArray(baseValue)\n ) {\n result[key] = deepMerge(\n baseValue as object,\n variantValue as Partial<typeof baseValue>\n ) as T[keyof T];\n } else {\n // Replace value (including arrays)\n result[key] = variantValue as T[keyof T];\n }\n }\n\n return result;\n}\n\n/**\n * Merge a variant profile with its base profile.\n * The variant's fields override the base, with deep merging for nested objects.\n *\n * @example\n * ```typescript\n * const esMX = mergeProfiles(spanishProfile, {\n * code: 'es-MX',\n * name: 'Spanish (Mexico)',\n * keywords: {\n * toggle: { primary: 'alternar', alternatives: ['dale', 'cambiar'] },\n * },\n * });\n * ```\n */\nexport function mergeProfiles(\n base: LanguageProfile,\n variant: Partial<LanguageProfile>\n): LanguageProfile {\n return deepMerge(base, variant);\n}\n\n/**\n * Resolve a profile, applying inheritance if the profile has an `extends` field.\n * Returns the merged profile with base language properties inherited.\n */\nexport function resolveProfile(profile: LanguageProfile): LanguageProfile {\n if (!profile.extends) {\n return profile;\n }\n\n const baseProfile = profiles.get(profile.extends);\n if (!baseProfile) {\n console.warn(\n `[Registry] Profile '${profile.code}' extends '${profile.extends}' but base is not registered. ` +\n `Make sure to import the base language before the variant.`\n );\n return profile;\n }\n\n // Recursively resolve base profile (in case it also extends something)\n const resolvedBase = resolveProfile(baseProfile);\n\n // Merge, with variant overriding base\n return mergeProfiles(resolvedBase, profile);\n}\n\n// =============================================================================\n// Registration Functions\n// =============================================================================\n\n/**\n * Register a language with its tokenizer and profile.\n * Called automatically by language modules when imported.\n * If the profile has an `extends` field, it will inherit from the base profile.\n */\nexport function registerLanguage(\n code: string,\n tokenizer: LanguageTokenizer,\n profile: LanguageProfile\n): void {\n tokenizers.set(code, tokenizer);\n // Store the original profile (inheritance is resolved at query time)\n profiles.set(code, profile);\n // Clear pattern cache for this language if it was previously cached\n patternCache.delete(code);\n}\n\n/**\n * Register only a tokenizer (for backwards compatibility).\n */\nexport function registerTokenizer(tokenizer: LanguageTokenizer): void {\n tokenizers.set(tokenizer.language, tokenizer);\n}\n\n/**\n * Register only a profile (for backwards compatibility).\n */\nexport function registerProfile(profile: LanguageProfile): void {\n profiles.set(profile.code, profile);\n patternCache.delete(profile.code);\n}\n\n/**\n * Set the pattern generator function.\n * Called by patterns module to inject the generator without circular deps.\n */\nexport function setPatternGenerator(\n generator: (profile: LanguageProfile) => LanguagePattern[]\n): void {\n patternGenerator = generator;\n}\n\n// Direct pattern registration map (for tree-shaking)\nconst registeredPatterns = new Map<string, LanguagePattern[]>();\n\n/**\n * Register patterns directly for a language.\n * This enables tree-shaking by allowing each language module to register\n * only its own patterns.\n */\nexport function registerPatterns(code: string, patterns: LanguagePattern[]): void {\n registeredPatterns.set(code, patterns);\n // Clear cached patterns if any\n patternCache.delete(code);\n}\n\n/**\n * Check if patterns are directly registered for a language.\n */\nexport function hasRegisteredPatterns(code: string): boolean {\n return registeredPatterns.has(code);\n}\n\n/**\n * Get directly registered patterns for a language.\n */\nexport function getRegisteredPatterns(code: string): LanguagePattern[] | undefined {\n return registeredPatterns.get(code);\n}\n\n// =============================================================================\n// External Pattern Sources\n// =============================================================================\n\n/**\n * Register an external pattern source.\n * External sources (like @lokascript/patterns-reference) can provide\n * additional patterns at runtime.\n *\n * @example\n * ```typescript\n * import { registerPatternsSource } from '@lokascript/semantic';\n * import { createPatternsProvider } from '@lokascript/patterns-reference';\n *\n * const provider = createPatternsProvider();\n * registerPatternsSource(provider);\n * ```\n */\nexport function registerPatternsSource(source: ExternalPatternsSource): void {\n externalSources.set(source.id, source);\n}\n\n/**\n * Unregister an external pattern source.\n */\nexport function unregisterPatternsSource(sourceId: string): boolean {\n return externalSources.delete(sourceId);\n}\n\n/**\n * Get a registered external pattern source.\n */\nexport function getPatternsSource(sourceId: string): ExternalPatternsSource | undefined {\n return externalSources.get(sourceId);\n}\n\n/**\n * Get all registered external pattern sources.\n */\nexport function getAllPatternsSources(): ExternalPatternsSource[] {\n return Array.from(externalSources.values());\n}\n\n/**\n * Check if any external pattern sources are registered.\n */\nexport function hasExternalSources(): boolean {\n return externalSources.size > 0;\n}\n\n/**\n * Query patterns from all external sources for a language.\n * Returns patterns sorted by confidence.\n */\nexport async function queryExternalPatterns(language: string): Promise<ExternalPatternEntry[]> {\n if (externalSources.size === 0) {\n return [];\n }\n\n const allPatterns: ExternalPatternEntry[] = [];\n\n for (const source of externalSources.values()) {\n try {\n const patterns = await source.getPatternsForLanguage(language);\n allPatterns.push(...patterns);\n } catch (error) {\n console.warn(\n `[Registry] Failed to query patterns from ${source.name}:`,\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n // Sort by confidence (highest first)\n return allPatterns.sort((a, b) => b.confidence - a.confidence);\n}\n\n/**\n * Query patterns from all external sources for a command.\n */\nexport async function queryExternalPatternsForCommand(\n command: string,\n language?: string\n): Promise<ExternalPatternEntry[]> {\n if (externalSources.size === 0) {\n return [];\n }\n\n const allPatterns: ExternalPatternEntry[] = [];\n\n for (const source of externalSources.values()) {\n try {\n const patterns = await source.getPatternsForCommand(command, language);\n allPatterns.push(...patterns);\n } catch (error) {\n console.warn(\n `[Registry] Failed to query patterns from ${source.name}:`,\n error instanceof Error ? error.message : String(error)\n );\n }\n }\n\n return allPatterns.sort((a, b) => b.confidence - a.confidence);\n}\n\n// =============================================================================\n// Language Code Utilities\n// =============================================================================\n\n/**\n * Extract the base language code from a BCP 47 tag.\n * Examples: 'es-MX' → 'es', 'pt-BR' → 'pt', 'en' → 'en'\n */\nexport function getBaseLanguageCode(code: string): string {\n return code.split('-')[0];\n}\n\n/**\n * Check if a code is a language variant (has region subtag).\n * Examples: 'es-MX' → true, 'pt' → false\n */\nexport function isLanguageVariant(code: string): boolean {\n return code.includes('-');\n}\n\n// =============================================================================\n// Query Functions\n// =============================================================================\n\n/**\n * Get a tokenizer for the specified language.\n * Supports fallback: if 'es-MX' is not registered, falls back to 'es'.\n * @throws Error if neither the variant nor base language is registered\n */\nexport function getTokenizer(code: string): LanguageTokenizer {\n // Try exact match first\n let tokenizer = tokenizers.get(code);\n\n // Fallback: es-MX → es\n if (!tokenizer && isLanguageVariant(code)) {\n const baseCode = getBaseLanguageCode(code);\n tokenizer = tokenizers.get(baseCode);\n }\n\n if (!tokenizer) {\n const registered = Array.from(tokenizers.keys()).join(', ');\n throw new Error(\n `Language '${code}' is not registered. ` +\n `Registered languages: ${registered || 'none'}. ` +\n `Import the language module first: import '@lokascript/semantic/languages/${code}';`\n );\n }\n return tokenizer;\n}\n\n/**\n * Get a profile for the specified language.\n * Supports fallback: if 'es-MX' is not registered, falls back to 'es'.\n * @throws Error if neither the variant nor base language is registered\n */\nexport function getProfile(code: string): LanguageProfile {\n // Try exact match first\n let profile = profiles.get(code);\n\n // Fallback: es-MX → es\n if (!profile && isLanguageVariant(code)) {\n const baseCode = getBaseLanguageCode(code);\n profile = profiles.get(baseCode);\n }\n\n if (!profile) {\n const registered = Array.from(profiles.keys()).join(', ');\n throw new Error(\n `Language profile '${code}' is not registered. ` +\n `Registered languages: ${registered || 'none'}. ` +\n `Import the language module first: import '@lokascript/semantic/languages/${code}';`\n );\n }\n\n // Resolve inheritance if profile extends another\n return resolveProfile(profile);\n}\n\n/**\n * Try to get a tokenizer, returning undefined if not registered.\n * Supports fallback: if 'es-MX' is not registered, falls back to 'es'.\n */\nexport function tryGetTokenizer(code: string): LanguageTokenizer | undefined {\n let tokenizer = tokenizers.get(code);\n if (!tokenizer && isLanguageVariant(code)) {\n tokenizer = tokenizers.get(getBaseLanguageCode(code));\n }\n return tokenizer;\n}\n\n/**\n * Try to get a profile, returning undefined if not registered.\n * Supports fallback: if 'es-MX' is not registered, falls back to 'es'.\n */\nexport function tryGetProfile(code: string): LanguageProfile | undefined {\n let profile = profiles.get(code);\n if (!profile && isLanguageVariant(code)) {\n profile = profiles.get(getBaseLanguageCode(code));\n }\n // Resolve inheritance if profile extends another\n return profile ? resolveProfile(profile) : undefined;\n}\n\n/**\n * Get all registered language codes.\n */\nexport function getRegisteredLanguages(): string[] {\n return Array.from(tokenizers.keys());\n}\n\n/**\n * Check if a language is registered (exact match or base language fallback).\n */\nexport function isLanguageRegistered(code: string): boolean {\n if (tokenizers.has(code) && profiles.has(code)) {\n return true;\n }\n // Check fallback for variants\n if (isLanguageVariant(code)) {\n const baseCode = getBaseLanguageCode(code);\n return tokenizers.has(baseCode) && profiles.has(baseCode);\n }\n return false;\n}\n\n/**\n * Check if a language is supported (exact match or base language fallback).\n * For backwards compatibility with tokenizers API.\n */\nexport function isLanguageSupported(code: string): boolean {\n if (tokenizers.has(code)) {\n return true;\n }\n // Check fallback for variants\n if (isLanguageVariant(code)) {\n return tokenizers.has(getBaseLanguageCode(code));\n }\n return false;\n}\n\n// =============================================================================\n// Tokenization\n// =============================================================================\n\n/**\n * Tokenize input in the specified language.\n * @throws Error if language is not registered\n */\nexport function tokenize(input: string, language: string): TokenStream {\n const tokenizer = getTokenizer(language);\n return tokenizer.tokenize(input);\n}\n\n// =============================================================================\n// Pattern Access (Lazy Generation)\n// =============================================================================\n\n/**\n * Get patterns for a specific language.\n * First checks for directly registered patterns (for tree-shaking),\n * then falls back to pattern generator.\n * Supports fallback: if 'es-MX' is not registered, falls back to 'es'.\n * @throws Error if language is not registered\n */\nexport function getPatternsForLanguage(code: string): LanguagePattern[] {\n // Check cache first (try exact, then base language)\n let cached = patternCache.get(code);\n if (!cached && isLanguageVariant(code)) {\n cached = patternCache.get(getBaseLanguageCode(code));\n }\n if (cached) {\n return cached;\n }\n\n // Check for directly registered patterns (tree-shakeable path)\n // Try exact match, then base language fallback\n let registered = registeredPatterns.get(code);\n if (!registered && isLanguageVariant(code)) {\n registered = registeredPatterns.get(getBaseLanguageCode(code));\n }\n if (registered) {\n patternCache.set(code, registered);\n return registered;\n }\n\n // Fall back to pattern generator\n if (!patternGenerator) {\n throw new Error(\n `No patterns registered for language '${code}'. ` +\n 'Either import the language module or set a pattern generator.'\n );\n }\n\n // Get profile (throws if not registered) - has built-in fallback\n const profile = getProfile(code);\n const patterns = patternGenerator(profile);\n patternCache.set(code, patterns);\n return patterns;\n}\n\n/**\n * Get patterns for a specific language and command.\n */\nexport function getPatternsForLanguageAndCommand(\n language: string,\n command: string\n): LanguagePattern[] {\n return getPatternsForLanguage(language)\n .filter(p => p.command === command)\n .sort((a, b) => b.priority - a.priority);\n}\n\n/**\n * Clear the pattern cache for a language (useful for testing).\n */\nexport function clearPatternCache(code?: string): void {\n if (code) {\n patternCache.delete(code);\n } else {\n patternCache.clear();\n }\n}\n\n// =============================================================================\n// Backwards Compatibility\n// =============================================================================\n\n/**\n * Get all profiles as a record (for backwards compatibility).\n * Note: Only returns registered profiles.\n */\nexport function getAllProfiles(): Record<string, LanguageProfile> {\n const result: Record<string, LanguageProfile> = {};\n for (const [code, profile] of profiles) {\n result[code] = profile;\n }\n return result;\n}\n\n/**\n * Get all tokenizers as a record (for backwards compatibility).\n * Note: Only returns registered tokenizers.\n */\nexport function getAllTokenizers(): Record<string, LanguageTokenizer> {\n const result: Record<string, LanguageTokenizer> = {};\n for (const [code, tokenizer] of tokenizers) {\n result[code] = tokenizer;\n }\n return result;\n}\n","/**\n * Token Utilities\n *\n * Core token creation, stream implementation, and character classification.\n * These are the foundational building blocks used by all tokenizers.\n */\n\nimport type { LanguageToken, TokenKind, TokenStream, StreamMark, SourcePosition } from '../types';\n\n// =============================================================================\n// Time Unit Configuration\n// =============================================================================\n\n/**\n * Configuration for a native language time unit pattern.\n * Used by tryNumberWithTimeUnits() to match language-specific time units.\n */\nexport interface TimeUnitMapping {\n /** The pattern to match (e.g., 'segundos', 'ミリ秒') */\n readonly pattern: string;\n /** The standard suffix to use (ms, s, m, h) */\n readonly suffix: string;\n /** Length of the pattern (for optimization) */\n readonly length: number;\n /** Whether to check for word boundary after the pattern */\n readonly checkBoundary?: boolean;\n /** Character that cannot follow the pattern (e.g., 's' for 'm' to avoid 'ms') */\n readonly notFollowedBy?: string;\n /** Whether to do case-insensitive matching */\n readonly caseInsensitive?: boolean;\n}\n\n// =============================================================================\n// Token Stream Implementation\n// =============================================================================\n\n/**\n * Concrete implementation of TokenStream.\n */\nexport class TokenStreamImpl implements TokenStream {\n readonly tokens: readonly LanguageToken[];\n readonly language: string;\n private pos: number = 0;\n\n constructor(tokens: LanguageToken[], language: string) {\n this.tokens = tokens;\n this.language = language;\n }\n\n peek(offset: number = 0): LanguageToken | null {\n const index = this.pos + offset;\n if (index < 0 || index >= this.tokens.length) {\n return null;\n }\n return this.tokens[index];\n }\n\n advance(): LanguageToken {\n if (this.isAtEnd()) {\n throw new Error('Unexpected end of token stream');\n }\n return this.tokens[this.pos++];\n }\n\n isAtEnd(): boolean {\n return this.pos >= this.tokens.length;\n }\n\n mark(): StreamMark {\n return { position: this.pos };\n }\n\n reset(mark: StreamMark): void {\n this.pos = mark.position;\n }\n\n position(): number {\n return this.pos;\n }\n\n /**\n * Get remaining tokens as an array.\n */\n remaining(): LanguageToken[] {\n return this.tokens.slice(this.pos);\n }\n\n /**\n * Consume tokens while predicate is true.\n */\n takeWhile(predicate: (token: LanguageToken) => boolean): LanguageToken[] {\n const result: LanguageToken[] = [];\n while (!this.isAtEnd() && predicate(this.peek()!)) {\n result.push(this.advance());\n }\n return result;\n }\n\n /**\n * Skip tokens while predicate is true.\n */\n skipWhile(predicate: (token: LanguageToken) => boolean): void {\n while (!this.isAtEnd() && predicate(this.peek()!)) {\n this.advance();\n }\n }\n}\n\n// =============================================================================\n// Shared Tokenization Utilities\n// =============================================================================\n\n/**\n * Create a source position from start and end offsets.\n */\nexport function createPosition(start: number, end: number): SourcePosition {\n return { start, end };\n}\n\n/**\n * Options for creating a token with optional morphological data.\n */\nexport interface CreateTokenOptions {\n /** Explicitly normalized form from keyword map */\n normalized?: string;\n /** Morphologically normalized stem */\n stem?: string;\n /** Confidence in the stem (0.0-1.0) */\n stemConfidence?: number;\n}\n\n/**\n * Create a language token.\n */\nexport function createToken(\n value: string,\n kind: TokenKind,\n position: SourcePosition,\n normalizedOrOptions?: string | CreateTokenOptions\n): LanguageToken {\n // Handle legacy string argument for backward compatibility\n if (typeof normalizedOrOptions === 'string') {\n return { value, kind, position, normalized: normalizedOrOptions };\n }\n\n // Handle options object\n if (normalizedOrOptions) {\n const { normalized, stem, stemConfidence } = normalizedOrOptions;\n return {\n value,\n kind,\n position,\n ...(normalized !== undefined && { normalized }),\n ...(stem !== undefined && { stem }),\n ...(stemConfidence !== undefined && { stemConfidence }),\n };\n }\n\n return { value, kind, position };\n}\n\n/**\n * Check if a character is whitespace.\n */\nexport function isWhitespace(char: string): boolean {\n return /\\s/.test(char);\n}\n\n/**\n * Check if a string starts with a CSS selector prefix.\n * Includes JSX-style element selectors: <form />, <div>\n */\nexport function isSelectorStart(char: string): boolean {\n return (\n char === '#' || char === '.' || char === '[' || char === '@' || char === '*' || char === '<'\n );\n}\n\n/**\n * Check if a character is a quote (string delimiter).\n */\nexport function isQuote(char: string): boolean {\n return char === '\"' || char === \"'\" || char === '`' || char === '「' || char === '」';\n}\n\n/**\n * Check if a character is a digit.\n */\nexport function isDigit(char: string): boolean {\n return /\\d/.test(char);\n}\n\n/**\n * Check if a character is an ASCII letter.\n */\nexport function isAsciiLetter(char: string): boolean {\n return /[a-zA-Z]/.test(char);\n}\n\n/**\n * Check if a character is part of an ASCII identifier.\n */\nexport function isAsciiIdentifierChar(char: string): boolean {\n return /[a-zA-Z0-9_-]/.test(char);\n}\n","/**\n * Character Classifiers\n *\n * Unicode range classification and Latin character classifier factories.\n * Used by language-specific tokenizers to define character sets.\n */\n\n// =============================================================================\n// Unicode Range Classification\n// =============================================================================\n\n/**\n * Unicode range tuple: [start, end] (inclusive).\n */\nexport type UnicodeRange = readonly [number, number];\n\n/**\n * Create a character classifier for Unicode ranges.\n * Returns a function that checks if a character's code point falls within any of the ranges.\n *\n * @example\n * // Japanese Hiragana\n * const isHiragana = createUnicodeRangeClassifier([[0x3040, 0x309f]]);\n *\n * // Korean (Hangul syllables + Jamo)\n * const isKorean = createUnicodeRangeClassifier([\n * [0xac00, 0xd7a3], // Hangul syllables\n * [0x1100, 0x11ff], // Hangul Jamo\n * [0x3130, 0x318f], // Hangul Compatibility Jamo\n * ]);\n */\nexport function createUnicodeRangeClassifier(\n ranges: readonly UnicodeRange[]\n): (char: string) => boolean {\n return (char: string): boolean => {\n const code = char.charCodeAt(0);\n return ranges.some(([start, end]) => code >= start && code <= end);\n };\n}\n\n/**\n * Combine multiple character classifiers into one.\n * Returns true if any of the classifiers return true.\n *\n * @example\n * const isJapanese = combineClassifiers(isHiragana, isKatakana, isKanji);\n */\nexport function combineClassifiers(\n ...classifiers: Array<(char: string) => boolean>\n): (char: string) => boolean {\n return (char: string): boolean => classifiers.some(fn => fn(char));\n}\n\n/**\n * Character classifiers for a Latin-based language.\n */\nexport interface LatinCharClassifiers {\n /** Check if character is a letter in this language (including accented chars). */\n isLetter: (char: string) => boolean;\n /** Check if character is part of an identifier (letter, digit, underscore, hyphen). */\n isIdentifierChar: (char: string) => boolean;\n}\n\n/**\n * Create character classifiers for a Latin-based language.\n * Returns isLetter and isIdentifierChar functions based on the provided regex.\n *\n * @example\n * // Spanish letters\n * const { isLetter, isIdentifierChar } = createLatinCharClassifiers(/[a-zA-ZáéíóúüñÁÉÍÓÚÜÑ]/);\n *\n * // German letters\n * const { isLetter, isIdentifierChar } = createLatinCharClassifiers(/[a-zA-ZäöüÄÖÜß]/);\n */\nexport function createLatinCharClassifiers(letterPattern: RegExp): LatinCharClassifiers {\n const isLetter = (char: string): boolean => letterPattern.test(char);\n const isIdentifierChar = (char: string): boolean => isLetter(char) || /[0-9_-]/.test(char);\n return { isLetter, isIdentifierChar };\n}\n","/**\n * Extraction Utilities\n *\n * Pure functions for extracting CSS selectors, string literals, URLs, and numbers\n * from input strings. These are language-independent and used by all tokenizers.\n */\n\nimport {\n isSelectorStart,\n isWhitespace,\n isAsciiIdentifierChar,\n isAsciiLetter,\n isQuote,\n isDigit,\n} from './token-utils';\n\n// =============================================================================\n// CSS Selector Tokenization\n// =============================================================================\n\n/**\n * Extract a CSS selector from the input string starting at pos.\n * CSS selectors are universal across languages.\n *\n * Supported formats:\n * - #id\n * - .class\n * - [attribute]\n * - [attribute=value]\n * - @attribute (shorthand)\n * - *property (CSS property shorthand)\n * - Complex selectors with combinators (limited)\n *\n * Method call handling:\n * - #dialog.showModal() → stops after #dialog (method call, not compound selector)\n * - #box.active → compound selector (no parens)\n */\nexport function extractCssSelector(input: string, startPos: number): string | null {\n if (startPos >= input.length) return null;\n\n const char = input[startPos];\n if (!isSelectorStart(char)) return null;\n\n let pos = startPos;\n let selector = '';\n\n // Handle different selector types\n if (char === '#' || char === '.') {\n // ID or class selector: #id, .class\n selector += input[pos++];\n while (pos < input.length && isAsciiIdentifierChar(input[pos])) {\n selector += input[pos++];\n }\n // Must have at least one character after prefix\n if (selector.length <= 1) return null;\n\n // Check for method call pattern: #id.method() or .class.method()\n // If we see .identifier followed by (, don't consume it - it's a method call\n if (pos < input.length && input[pos] === '.' && char === '#') {\n // Look ahead to see if this is a method call\n const methodStart = pos + 1;\n let methodEnd = methodStart;\n while (methodEnd < input.length && isAsciiIdentifierChar(input[methodEnd])) {\n methodEnd++;\n }\n // If followed by (, it's a method call - stop here\n if (methodEnd < input.length && input[methodEnd] === '(') {\n return selector;\n }\n }\n } else if (char === '[') {\n // Attribute selector: [attr] or [attr=value] or [attr=\"value\"]\n // Need to track quote state to avoid counting brackets inside quotes\n let depth = 1;\n let inQuote = false;\n let quoteChar: string | null = null;\n let escaped = false;\n\n selector += input[pos++]; // [\n\n while (pos < input.length && depth > 0) {\n const c = input[pos];\n selector += c;\n\n if (escaped) {\n // Skip escaped character\n escaped = false;\n } else if (c === '\\\\') {\n // Next character is escaped\n escaped = true;\n } else if (inQuote) {\n // Inside a quoted string\n if (c === quoteChar) {\n inQuote = false;\n quoteChar = null;\n }\n } else {\n // Not inside a quoted string\n if (c === '\"' || c === \"'\" || c === '`') {\n inQuote = true;\n quoteChar = c;\n } else if (c === '[') {\n depth++;\n } else if (c === ']') {\n depth--;\n }\n }\n pos++;\n }\n if (depth !== 0) return null;\n } else if (char === '@') {\n // Attribute shorthand: @disabled\n selector += input[pos++];\n while (pos < input.length && isAsciiIdentifierChar(input[pos])) {\n selector += input[pos++];\n }\n if (selector.length <= 1) return null;\n } else if (char === '*') {\n // CSS property shorthand: *display\n selector += input[pos++];\n while (pos < input.length && isAsciiIdentifierChar(input[pos])) {\n selector += input[pos++];\n }\n if (selector.length <= 1) return null;\n } else if (char === '<') {\n // HTML literal selector with optional modifiers and attributes:\n // - <div>\n // - <div.class>\n // - <div#id>\n // - <div.class#id>\n // - <button[disabled]/>\n // - <div.card/>\n // - <div.class#id[attr=\"value\"]/>\n selector += input[pos++]; // <\n\n // Must be followed by an identifier (tag name)\n if (pos >= input.length || !isAsciiLetter(input[pos])) return null;\n\n // Extract tag name\n while (pos < input.length && isAsciiIdentifierChar(input[pos])) {\n selector += input[pos++];\n }\n\n // Process modifiers and attributes\n // Can have multiple .class, one #id, and multiple [attr] in any order\n while (pos < input.length) {\n const modChar = input[pos];\n\n if (modChar === '.') {\n // Class modifier\n selector += input[pos++]; // .\n if (pos >= input.length || !isAsciiIdentifierChar(input[pos])) {\n return null; // Invalid - class name required after .\n }\n while (pos < input.length && isAsciiIdentifierChar(input[pos])) {\n selector += input[pos++];\n }\n } else if (modChar === '#') {\n // ID modifier\n selector += input[pos++]; // #\n if (pos >= input.length || !isAsciiIdentifierChar(input[pos])) {\n return null; // Invalid - ID required after #\n }\n while (pos < input.length && isAsciiIdentifierChar(input[pos])) {\n selector += input[pos++];\n }\n } else if (modChar === '[') {\n // Attribute modifier: [disabled] or [type=\"button\"]\n // Need to track quote state to avoid counting brackets inside quotes\n let depth = 1;\n let inQuote = false;\n let quoteChar: string | null = null;\n let escaped = false;\n\n selector += input[pos++]; // [\n\n while (pos < input.length && depth > 0) {\n const c = input[pos];\n selector += c;\n\n if (escaped) {\n escaped = false;\n } else if (c === '\\\\') {\n escaped = true;\n } else if (inQuote) {\n if (c === quoteChar) {\n inQuote = false;\n quoteChar = null;\n }\n } else {\n if (c === '\"' || c === \"'\" || c === '`') {\n inQuote = true;\n quoteChar = c;\n } else if (c === '[') {\n depth++;\n } else if (c === ']') {\n depth--;\n }\n }\n pos++;\n }\n if (depth !== 0) return null; // Unclosed bracket\n } else {\n // No more modifiers\n break;\n }\n }\n\n // Skip whitespace before optional self-closing /\n while (pos < input.length && isWhitespace(input[pos])) {\n selector += input[pos++];\n }\n\n // Optional self-closing /\n if (pos < input.length && input[pos] === '/') {\n selector += input[pos++];\n // Skip whitespace after /\n while (pos < input.length && isWhitespace(input[pos])) {\n selector += input[pos++];\n }\n }\n\n // Must end with >\n if (pos >= input.length || input[pos] !== '>') return null;\n selector += input[pos++]; // >\n }\n\n return selector || null;\n}\n\n// =============================================================================\n// String Literal Tokenization\n// =============================================================================\n\n/**\n * Check if a single quote at pos is a possessive marker ('s).\n * Returns true if this looks like possessive, not a string start.\n *\n * Examples:\n * - #element's *opacity → possessive (returns true)\n * - 'hello' → string (returns false)\n * - it's value → possessive (returns true)\n */\nexport function isPossessiveMarker(input: string, pos: number): boolean {\n if (pos >= input.length || input[pos] !== \"'\") return false;\n\n // Check if followed by 's' or 'S'\n if (pos + 1 >= input.length) return false;\n const nextChar = input[pos + 1].toLowerCase();\n if (nextChar !== 's') return false;\n\n // After 's, should be end, whitespace, or special char (not alphanumeric)\n if (pos + 2 >= input.length) return true; // end of input\n const afterS = input[pos + 2];\n return isWhitespace(afterS) || afterS === '*' || !isAsciiIdentifierChar(afterS);\n}\n\n/**\n * Extract a string literal from the input starting at pos.\n * Handles both ASCII quotes and Unicode quotes.\n *\n * Note: Single quotes that look like possessive markers ('s) are skipped.\n */\nexport function extractStringLiteral(input: string, startPos: number): string | null {\n if (startPos >= input.length) return null;\n\n const openQuote = input[startPos];\n if (!isQuote(openQuote)) return null;\n\n // Check for possessive marker - don't treat as string\n if (openQuote === \"'\" && isPossessiveMarker(input, startPos)) {\n return null;\n }\n\n // Map opening quotes to closing quotes\n const closeQuoteMap: Record<string, string> = {\n '\"': '\"',\n \"'\": \"'\",\n '`': '`',\n '「': '」',\n };\n\n const closeQuote = closeQuoteMap[openQuote];\n if (!closeQuote) return null;\n\n let pos = startPos + 1;\n let literal = openQuote;\n let escaped = false;\n\n while (pos < input.length) {\n const char = input[pos];\n literal += char;\n\n if (escaped) {\n escaped = false;\n } else if (char === '\\\\') {\n escaped = true;\n } else if (char === closeQuote) {\n // Found closing quote\n return literal;\n }\n pos++;\n }\n\n // Unclosed string - return what we have\n return literal;\n}\n\n// =============================================================================\n// URL Tokenization\n// =============================================================================\n\n/**\n * Check if the input at position starts a URL.\n * Detects: /path, ./path, ../path, //domain.com, http://, https://\n */\nexport function isUrlStart(input: string, pos: number): boolean {\n if (pos >= input.length) return false;\n\n const char = input[pos];\n const next = input[pos + 1] || '';\n const third = input[pos + 2] || '';\n\n // Absolute path: /something (but not just /)\n // Must be followed by alphanumeric or path char, not another / (that's protocol-relative)\n if (char === '/' && next !== '/' && /[a-zA-Z0-9._-]/.test(next)) {\n return true;\n }\n\n // Protocol-relative: //domain.com\n if (char === '/' && next === '/' && /[a-zA-Z]/.test(third)) {\n return true;\n }\n\n // Relative path: ./ or ../\n if (char === '.' && (next === '/' || (next === '.' && third === '/'))) {\n return true;\n }\n\n // Full URL: http:// or https://\n const slice = input.slice(pos, pos + 8).toLowerCase();\n if (slice.startsWith('http://') || slice.startsWith('https://')) {\n return true;\n }\n\n return false;\n}\n\n/**\n * Extract a URL from the input starting at pos.\n * Handles paths, query strings, and fragments.\n *\n * Fragment (#) handling:\n * - /page#section → includes fragment as part of URL\n * - #id alone → not a URL (CSS selector)\n */\nexport function extractUrl(input: string, startPos: number): string | null {\n if (!isUrlStart(input, startPos)) return null;\n\n let pos = startPos;\n let url = '';\n\n // Core URL characters (RFC 3986 unreserved + sub-delims + path/query chars)\n // Includes: letters, digits, and - . _ ~ : / ? # [ ] @ ! $ & ' ( ) * + , ; = %\n const urlChars = /[a-zA-Z0-9/:._\\-?&=%@+~!$'()*,;[\\]]/;\n\n while (pos < input.length) {\n const char = input[pos];\n\n // Special handling for #\n if (char === '#') {\n // Only include # if we have path content before it (it's a fragment)\n // If # appears at URL start or after certain chars, stop (might be CSS selector)\n if (url.length > 0 && /[a-zA-Z0-9/.]$/.test(url)) {\n // Include fragment\n url += char;\n pos++;\n // Consume fragment identifier (letters, digits, underscore, hyphen)\n while (pos < input.length && /[a-zA-Z0-9_-]/.test(input[pos])) {\n url += input[pos++];\n }\n }\n // Stop either way - fragment consumed or # is separate token\n break;\n }\n\n if (urlChars.test(char)) {\n url += char;\n pos++;\n } else {\n break;\n }\n }\n\n // Minimum length validation\n if (url.length < 2) return null;\n\n return url;\n}\n\n// =============================================================================\n// Number Tokenization\n// =============================================================================\n\n/**\n * Extract a number from the input starting at pos.\n * Handles integers and decimals.\n */\nexport function extractNumber(input: string, startPos: number): string | null {\n if (startPos >= input.length) return null;\n\n const char = input[startPos];\n if (!isDigit(char) && char !== '-' && char !== '+') return null;\n\n let pos = startPos;\n let number = '';\n\n // Optional sign\n if (input[pos] === '-' || input[pos] === '+') {\n number += input[pos++];\n }\n\n // Must have at least one digit\n if (pos >= input.length || !isDigit(input[pos])) {\n return null;\n }\n\n // Integer part\n while (pos < input.length && isDigit(input[pos])) {\n number += input[pos++];\n }\n\n // Optional decimal part\n if (pos < input.length && input[pos] === '.') {\n number += input[pos++];\n while (pos < input.length && isDigit(input[pos])) {\n number += input[pos++];\n }\n }\n\n // Optional duration suffix (s, ms, m, h)\n if (pos < input.length) {\n const suffix = input.slice(pos, pos + 2);\n if (suffix === 'ms') {\n number += 'ms';\n } else if (input[pos] === 's' || input[pos] === 'm' || input[pos] === 'h') {\n number += input[pos];\n }\n }\n\n return number;\n}\n","/**\n * Base Tokenizer Class\n *\n * Abstract base class for language-specific tokenizers.\n * Provides keyword management, morphological normalization,\n * and high-level token extraction methods.\n */\n\nimport type { LanguageToken, TokenKind, TokenStream, LanguageTokenizer } from '../types';\nimport type { MorphologicalNormalizer, NormalizationResult } from './morphology/types';\nimport {\n createToken,\n createPosition,\n isWhitespace,\n isDigit,\n isAsciiIdentifierChar,\n type TimeUnitMapping,\n type CreateTokenOptions,\n} from './token-utils';\nimport { extractCssSelector, extractStringLiteral, extractNumber, extractUrl } from './extractors';\n\n// =============================================================================\n// Types\n// =============================================================================\n\n/**\n * Keyword entry for tokenizer - maps native word to normalized English form.\n */\nexport interface KeywordEntry {\n readonly native: string;\n readonly normalized: string;\n}\n\n/**\n * Profile interface for keyword derivation.\n * Matches the structure of LanguageProfile but only includes fields needed for tokenization.\n */\nexport interface TokenizerProfile {\n readonly keywords?: Record<\n string,\n { primary: string; alternatives?: string[]; normalized?: string }\n >;\n readonly references?: Record<string, string>;\n readonly roleMarkers?: Record<\n string,\n { primary: string; alternatives?: string[]; position?: string }\n >;\n}\n\n// =============================================================================\n// Base Tokenizer Class\n// =============================================================================\n\n/**\n * Abstract base class for language-specific tokenizers.\n * Provides common functionality for CSS selectors, strings, and numbers.\n */\nexport abstract class BaseTokenizer implements LanguageTokenizer {\n abstract readonly language: string;\n abstract readonly direction: 'ltr' | 'rtl';\n\n /** Optional morphological normalizer for this language */\n protected normalizer?: MorphologicalNormalizer;\n\n /** Keywords derived from profile, sorted longest-first for greedy matching */\n protected profileKeywords: KeywordEntry[] = [];\n\n /** Map for O(1) keyword lookups by lowercase native word */\n protected profileKeywordMap: Map<string, KeywordEntry> = new Map();\n\n abstract tokenize(input: string): TokenStream;\n abstract classifyToken(token: string): TokenKind;\n\n /**\n * Check if current position is a property access (obj.prop) vs CSS selector (.active).\n * Property access: no whitespace before '.', previous token is identifier/keyword/selector.\n * Also detects standalone method calls: .identifier( pattern.\n *\n * Returns true if '.' was emitted as an operator token and pos should advance by 1.\n * Returns false if this is a CSS selector and should be handled by trySelector().\n */\n protected tryPropertyAccess(input: string, pos: number, tokens: LanguageToken[]): boolean {\n if (input[pos] !== '.') return false;\n\n const lastToken = tokens[tokens.length - 1];\n // Property access requires NO whitespace between tokens (e.g., \"obj.prop\")\n const hasWhitespaceBefore = lastToken && lastToken.position.end < pos;\n const isPropertyAccess =\n lastToken &&\n !hasWhitespaceBefore &&\n (lastToken.kind === 'identifier' ||\n lastToken.kind === 'keyword' ||\n lastToken.kind === 'selector');\n\n if (isPropertyAccess) {\n tokens.push(createToken('.', 'operator', createPosition(pos, pos + 1)));\n return true;\n }\n\n // Check for method call pattern at start: .identifier(\n const methodStart = pos + 1;\n let methodEnd = methodStart;\n while (methodEnd < input.length && isAsciiIdentifierChar(input[methodEnd])) {\n methodEnd++;\n }\n if (methodEnd < input.length && input[methodEnd] === '(') {\n tokens.push(createToken('.', 'operator', createPosition(pos, pos + 1)));\n return true;\n }\n\n return false;\n }\n\n /**\n * Initialize keyword mappings from a language profile.\n * Builds a list of native→english mappings from:\n * - profile.keywords (primary + alternatives)\n * - profile.references (me, it, you, etc.)\n * - profile.roleMarkers (into, from, with, etc.)\n *\n * Results are sorted longest-first for greedy matching (important for non-space languages).\n * Extras take precedence over profile entries when there are duplicates.\n *\n * @param profile - Language profile containing keyword translations\n * @param extras - Additional keyword entries to include (literals, positional, events)\n */\n protected initializeKeywordsFromProfile(\n profile: TokenizerProfile,\n extras: KeywordEntry[] = []\n ): void {\n // Use a Map to deduplicate, with extras taking precedence\n const keywordMap = new Map<string, KeywordEntry>();\n\n // Extract from keywords (command translations)\n if (profile.keywords) {\n for (const [normalized, translation] of Object.entries(profile.keywords)) {\n // Primary translation\n keywordMap.set(translation.primary, {\n native: translation.primary,\n normalized: translation.normalized || normalized,\n });\n\n // Alternative forms\n if (translation.alternatives) {\n for (const alt of translation.alternatives) {\n keywordMap.set(alt, {\n native: alt,\n normalized: translation.normalized || normalized,\n });\n }\n }\n }\n }\n\n // Extract from references (me, it, you, etc.)\n if (profile.references) {\n for (const [normalized, native] of Object.entries(profile.references)) {\n keywordMap.set(native, { native, normalized });\n }\n // Also register English canonical forms as universal fallbacks.\n // Users frequently mix English references (me, it, you) into non-English\n // hyperscript (e.g., \"alternar .active on me\"). Without this, the English\n // word \"me\" would be unrecognized in non-English token streams.\n for (const canonical of Object.keys(profile.references)) {\n if (!keywordMap.has(canonical)) {\n keywordMap.set(canonical, { native: canonical, normalized: canonical });\n }\n }\n }\n\n // Extract from roleMarkers (into, from, with, etc.)\n if (profile.roleMarkers) {\n for (const [role, marker] of Object.entries(profile.roleMarkers)) {\n if (marker.primary) {\n keywordMap.set(marker.primary, { native: marker.primary, normalized: role });\n }\n if (marker.alternatives) {\n for (const alt of marker.alternatives) {\n keywordMap.set(alt, { native: alt, normalized: role });\n }\n }\n }\n }\n\n // Add extra entries (literals, positional, events) - these OVERRIDE profile entries\n for (const extra of extras) {\n keywordMap.set(extra.native, extra);\n }\n\n // Convert to array and sort longest-first for greedy matching\n this.profileKeywords = Array.from(keywordMap.values()).sort(\n (a, b) => b.native.length - a.native.length\n );\n\n // Build Map for O(1) lookups (case-insensitive + diacritic-insensitive)\n // This allows matching both 'بدّل' (with shadda) and 'بدل' (without) to the same entry\n this.profileKeywordMap = new Map();\n for (const keyword of this.profileKeywords) {\n // Add original form (with diacritics if present)\n this.profileKeywordMap.set(keyword.native.toLowerCase(), keyword);\n\n // Add diacritic-normalized form (for Arabic, Turkish, etc.)\n const normalized = this.removeDiacritics(keyword.native);\n if (normalized !== keyword.native && !this.profileKeywordMap.has(normalized.toLowerCase())) {\n this.profileKeywordMap.set(normalized.toLowerCase(), keyword);\n }\n }\n }\n\n /**\n * Remove diacritical marks from a word for normalization.\n * Primarily for Arabic (shadda, fatha, kasra, damma, sukun, etc.)\n * but could be extended for other languages.\n *\n * @param word - Word to normalize\n * @returns Word without diacritics\n */\n protected removeDiacritics(word: string): string {\n // Arabic diacritics: U+064B-U+0652 (fatha, kasra, damma, sukun, shadda, etc.)\n // U+0670 (superscript alif)\n return word.replace(/[\\u064B-\\u0652\\u0670]/g, '');\n }\n\n /**\n * Try to match a keyword from profile at the current position.\n * Uses longest-first greedy matching (important for non-space languages).\n *\n * @param input - Input string\n * @param pos - Current position\n * @returns Token if matched, null otherwise\n */\n protected tryProfileKeyword(input: string, pos: number): LanguageToken | null {\n for (const entry of this.profileKeywords) {\n if (input.slice(pos).startsWith(entry.native)) {\n return createToken(\n entry.native,\n 'keyword',\n createPosition(pos, pos + entry.native.length),\n entry.normalized\n );\n }\n }\n return null;\n }\n\n /**\n * Check if the remaining input starts with any known keyword.\n * Useful for non-space languages to detect word boundaries.\n *\n * @param input - Input string\n * @param pos - Current position\n * @returns true if a keyword starts at this position\n */\n protected isKeywordStart(input: string, pos: number): boolean {\n const remaining = input.slice(pos);\n return this.profileKeywords.some(entry => remaining.startsWith(entry.native));\n }\n\n /**\n * Look up a keyword by native word (case-insensitive).\n * O(1) lookup using the keyword map.\n *\n * @param native - Native word to look up\n * @returns KeywordEntry if found, undefined otherwise\n */\n protected lookupKeyword(native: string): KeywordEntry | undefined {\n return this.profileKeywordMap.get(native.toLowerCase());\n }\n\n /**\n * Check if a word is a known keyword (case-insensitive).\n * O(1) lookup using the keyword map.\n *\n * @param native - Native word to check\n * @returns true if the word is a keyword\n */\n protected isKeyword(native: string): boolean {\n return this.profileKeywordMap.has(native.toLowerCase());\n }\n\n /**\n * Set the morphological normalizer for this tokenizer.\n */\n setNormalizer(normalizer: MorphologicalNormalizer): void {\n this.normalizer = normalizer;\n }\n\n /**\n * Try to normalize a word using the morphological normalizer.\n * Returns null if no normalizer is set or normalization fails.\n *\n * Note: We don't check isNormalizable() here because the individual tokenizers\n * historically called normalize() directly without that check. The normalize()\n * method itself handles returning noChange() for words that can't be normalized.\n */\n protected tryNormalize(word: string): NormalizationResult | null {\n if (!this.normalizer) return null;\n\n const result = this.normalizer.normalize(word);\n\n // Only return if actually normalized (stem differs from input)\n if (result.stem !== word && result.confidence >= 0.7) {\n return result;\n }\n\n return null;\n }\n\n /**\n * Try morphological normalization and keyword lookup.\n *\n * If the word can be normalized to a stem that matches a known keyword,\n * returns a keyword token with morphological metadata (stem, stemConfidence).\n *\n * This is the common pattern for handling conjugated verbs across languages:\n * 1. Normalize the word (e.g., \"toggled\" → \"toggle\")\n * 2. Look up the stem in the keyword map\n * 3. Create a token with both the original form and stem metadata\n *\n * @param word - The word to normalize and look up\n * @param startPos - Start position for the token\n * @param endPos - End position for the token\n * @returns Token if stem matches a keyword, null otherwise\n */\n protected tryMorphKeywordMatch(\n word: string,\n startPos: number,\n endPos: number\n ): LanguageToken | null {\n const result = this.tryNormalize(word);\n if (!result) return null;\n\n // Check if the stem is a known keyword\n const stemEntry = this.lookupKeyword(result.stem);\n if (!stemEntry) return null;\n\n const tokenOptions: CreateTokenOptions = {\n normalized: stemEntry.normalized,\n stem: result.stem,\n stemConfidence: result.confidence,\n };\n return createToken(word, 'keyword', createPosition(startPos, endPos), tokenOptions);\n }\n\n /**\n * Try to extract a CSS selector at the current position.\n */\n protected trySelector(input: string, pos: number): LanguageToken | null {\n const selector = extractCssSelector(input, pos);\n if (selector) {\n return createToken(selector, 'selector', createPosition(pos, pos + selector.length));\n }\n return null;\n }\n\n /**\n * Try to extract an event modifier at the current position.\n * Event modifiers are .once, .debounce(N), .throttle(N), .queue(strategy)\n */\n protected tryEventModifier(input: string, pos: number): LanguageToken | null {\n // Must start with a dot\n if (input[pos] !== '.') {\n return null;\n }\n\n // Match pattern: .(once|debounce|throttle|queue) followed by optional (value)\n const match = input\n .slice(pos)\n .match(/^\\.(?:once|debounce|throttle|queue)(?:\\(([^)]+)\\))?(?:\\s|$|\\.)/);\n if (!match) {\n return null;\n }\n\n const fullMatch = match[0].replace(/(\\s|\\.)$/, ''); // Remove trailing space or dot\n const modifierName = fullMatch.slice(1).split('(')[0]; // Extract modifier name\n const value = match[1]; // Extract value from parentheses if present\n\n // Create token with metadata\n const token = createToken(\n fullMatch,\n 'event-modifier',\n createPosition(pos, pos + fullMatch.length)\n );\n\n // Add metadata for the modifier\n return {\n ...token,\n metadata: {\n modifierName,\n value: value ? (modifierName === 'queue' ? value : parseInt(value, 10)) : undefined,\n },\n };\n }\n\n /**\n * Try to extract a string literal at the current position.\n */\n protected tryString(input: string, pos: number): LanguageToken | null {\n const literal = extractStringLiteral(input, pos);\n if (literal) {\n return createToken(literal, 'literal', createPosition(pos, pos + literal.length));\n }\n return null;\n }\n\n /**\n * Try to extract a number at the current position.\n */\n protected tryNumber(input: string, pos: number): LanguageToken | null {\n const number = extractNumber(input, pos);\n if (number) {\n return createToken(number, 'literal', createPosition(pos, pos + number.length));\n }\n return null;\n }\n\n /**\n * Configuration for native language time units.\n * Maps patterns to their standard suffix (ms, s, m, h).\n */\n protected static readonly STANDARD_TIME_UNITS: readonly TimeUnitMapping[] = [\n { pattern: 'ms', suffix: 'ms', length: 2 },\n { pattern: 's', suffix: 's', length: 1, checkBoundary: true },\n { pattern: 'm', suffix: 'm', length: 1, checkBoundary: true, notFollowedBy: 's' },\n { pattern: 'h', suffix: 'h', length: 1, checkBoundary: true },\n ];\n\n /**\n * Try to match a time unit from a list of patterns.\n *\n * @param input - Input string\n * @param pos - Position after the number\n * @param timeUnits - Array of time unit mappings (native pattern → standard suffix)\n * @param skipWhitespace - Whether to skip whitespace before time unit (default: false)\n * @returns Object with matched suffix and new position, or null if no match\n */\n protected tryMatchTimeUnit(\n input: string,\n pos: number,\n timeUnits: readonly TimeUnitMapping[],\n skipWhitespace = false\n ): { suffix: string; endPos: number } | null {\n let unitPos = pos;\n\n // Optionally skip whitespace before time unit\n if (skipWhitespace) {\n while (unitPos < input.length && isWhitespace(input[unitPos])) {\n unitPos++;\n }\n }\n\n const remaining = input.slice(unitPos);\n\n // Check each time unit pattern\n for (const unit of timeUnits) {\n const candidate = remaining.slice(0, unit.length);\n const matches = unit.caseInsensitive\n ? candidate.toLowerCase() === unit.pattern.toLowerCase()\n : candidate === unit.pattern;\n\n if (matches) {\n // Check notFollowedBy constraint (e.g., 'm' should not match 'ms')\n if (unit.notFollowedBy) {\n const nextChar = remaining[unit.length] || '';\n if (nextChar === unit.notFollowedBy) continue;\n }\n\n // Check word boundary if required\n if (unit.checkBoundary) {\n const nextChar = remaining[unit.length] || '';\n if (isAsciiIdentifierChar(nextChar)) continue;\n }\n\n return { suffix: unit.suffix, endPos: unitPos + unit.length };\n }\n }\n\n return null;\n }\n\n /**\n * Parse a base number (sign, integer, decimal) without time units.\n * Returns the number string and end position.\n *\n * @param input - Input string\n * @param startPos - Start position\n * @param allowSign - Whether to allow +/- sign (default: true)\n * @returns Object with number string and end position, or null\n */\n protected parseBaseNumber(\n input: string,\n startPos: number,\n allowSign = true\n ): { number: string; endPos: number } | null {\n let pos = startPos;\n let number = '';\n\n // Optional sign\n if (allowSign && (input[pos] === '-' || input[pos] === '+')) {\n number += input[pos++];\n }\n\n // Must have at least one digit\n if (pos >= input.length || !isDigit(input[pos])) {\n return null;\n }\n\n // Integer part\n while (pos < input.length && isDigit(input[pos])) {\n number += input[pos++];\n }\n\n // Optional decimal\n if (pos < input.length && input[pos] === '.') {\n number += input[pos++];\n while (pos < input.length && isDigit(input[pos])) {\n number += input[pos++];\n }\n }\n\n if (!number || number === '-' || number === '+') return null;\n\n return { number, endPos: pos };\n }\n\n /**\n * Try to extract a number with native language time units.\n *\n * This is a template method that handles the common pattern:\n * 1. Parse the base number (sign, integer, decimal)\n * 2. Try to match native language time units\n * 3. Fall back to standard time units (ms, s, m, h)\n *\n * @param input - Input string\n * @param pos - Start position\n * @param nativeTimeUnits - Language-specific time unit mappings\n * @param options - Configuration options\n * @returns Token if number found, null otherwise\n */\n protected tryNumberWithTimeUnits(\n input: string,\n pos: number,\n nativeTimeUnits: readonly TimeUnitMapping[],\n options: { allowSign?: boolean; skipWhitespace?: boolean } = {}\n ): LanguageToken | null {\n const { allowSign = true, skipWhitespace = false } = options;\n\n // Parse base number\n const baseResult = this.parseBaseNumber(input, pos, allowSign);\n if (!baseResult) return null;\n\n let { number, endPos } = baseResult;\n\n // Try native time units first, then standard\n const allUnits = [...nativeTimeUnits, ...BaseTokenizer.STANDARD_TIME_UNITS];\n const timeMatch = this.tryMatchTimeUnit(input, endPos, allUnits, skipWhitespace);\n\n if (timeMatch) {\n number += timeMatch.suffix;\n endPos = timeMatch.endPos;\n }\n\n return createToken(number, 'literal', createPosition(pos, endPos));\n }\n\n /**\n * Try to extract a URL at the current position.\n * Handles /path, ./path, ../path, //domain.com, http://, https://\n */\n protected tryUrl(input: string, pos: number): LanguageToken | null {\n const url = extractUrl(input, pos);\n if (url) {\n return createToken(url, 'url', createPosition(pos, pos + url.length));\n }\n return null;\n }\n\n /**\n * Try to extract a variable reference (:varname) at the current position.\n * In hyperscript, :x refers to a local variable named x.\n */\n protected tryVariableRef(input: string, pos: number): LanguageToken | null {\n if (input[pos] !== ':') return null;\n if (pos + 1 >= input.length) return null;\n if (!isAsciiIdentifierChar(input[pos + 1])) return null;\n\n let endPos = pos + 1;\n while (endPos < input.length && isAsciiIdentifierChar(input[endPos])) {\n endPos++;\n }\n\n const varRef = input.slice(pos, endPos);\n return createToken(varRef, 'identifier', createPosition(pos, endPos));\n }\n\n /**\n * Try to extract an operator or punctuation token at the current position.\n * Handles two-character operators (==, !=, etc.) and single-character operators.\n */\n protected tryOperator(input: string, pos: number): LanguageToken | null {\n // Two-character operators\n const twoChar = input.slice(pos, pos + 2);\n if (['==', '!=', '<=', '>=', '&&', '||', '->'].includes(twoChar)) {\n return createToken(twoChar, 'operator', createPosition(pos, pos + 2));\n }\n\n // Single-character operators\n const oneChar = input[pos];\n if (['<', '>', '!', '+', '-', '*', '/', '='].includes(oneChar)) {\n return createToken(oneChar, 'operator', createPosition(pos, pos + 1));\n }\n\n // Punctuation\n if (['(', ')', '{', '}', ',', ';', ':'].includes(oneChar)) {\n return createToken(oneChar, 'punctuation', createPosition(pos, pos + 1));\n }\n\n return null;\n }\n\n /**\n * Try to match a multi-character particle from a list.\n *\n * Used by languages like Japanese, Korean, and Chinese that have\n * multi-character particles (e.g., Japanese から, まで, より).\n *\n * @param input - Input string\n * @param pos - Current position\n * @param particles - Array of multi-character particles to match\n * @returns Token if matched, null otherwise\n */\n protected tryMultiCharParticle(\n input: string,\n pos: number,\n particles: readonly string[]\n ): LanguageToken | null {\n for (const particle of particles) {\n if (input.slice(pos, pos + particle.length) === particle) {\n return createToken(particle, 'particle', createPosition(pos, pos + particle.length));\n }\n }\n return null;\n }\n}\n","/**\n * Ukrainian Language Profile\n *\n * SVO word order, prepositions, space-separated.\n * Ukrainian is a fusional language with rich verb conjugation.\n * Uses infinitive form in software UI (industry standard).\n */\n\nimport type { LanguageProfile } from './types';\n\nexport const ukrainianProfile: LanguageProfile = {\n code: 'uk',\n name: 'Ukrainian',\n nativeName: 'Українська',\n direction: 'ltr',\n wordOrder: 'SVO',\n markingStrategy: 'preposition',\n usesSpaces: true,\n defaultVerbForm: 'infinitive',\n verb: {\n position: 'start',\n subjectDrop: true,\n suffixes: ['ти', 'тися', 'ити', 'итися', 'ати', 'атися', 'іти', 'ітися'],\n },\n references: {\n me: 'я',\n it: 'це',\n you: 'ти',\n result: 'результат',\n event: 'подія',\n target: 'ціль',\n body: 'body',\n },\n possessive: {\n marker: '',\n markerPosition: 'after-object',\n usePossessiveAdjectives: true,\n specialForms: {\n me: 'мій',\n it: 'його',\n you: 'твій',\n },\n keywords: {\n // \"my\" variants (masculine/feminine/neuter/plural)\n мій: 'me',\n моя: 'me',\n моє: 'me',\n мої: 'me',\n // \"your\" variants\n твій: 'you',\n твоя: 'you',\n твоє: 'you',\n твої: 'you',\n // \"its/his/her\" forms\n його: 'it', // his/its\n її: 'it', // her/its (feminine)\n },\n },\n roleMarkers: {\n destination: { primary: 'в', alternatives: ['на', 'до'], position: 'before' },\n source: { primary: 'з', alternatives: ['від', 'із'], position: 'before' },\n patient: { primary: '', position: 'before' },\n style: { primary: 'з', alternatives: ['із'], position: 'before' },\n },\n keywords: {\n // Class/Attribute operations (infinitive form)\n toggle: {\n primary: 'перемкнути',\n alternatives: ['перемкни'],\n normalized: 'toggle',\n form: 'infinitive',\n },\n add: { primary: 'додати', alternatives: ['додай'], normalized: 'add', form: 'infinitive' },\n remove: {\n primary: 'видалити',\n alternatives: ['видали', 'прибрати', 'прибери'],\n normalized: 'remove',\n form: 'infinitive',\n },\n // Content operations\n put: {\n primary: 'покласти',\n alternatives: ['поклади', 'помістити', 'помісти', 'вставити', 'встав'],\n normalized: 'put',\n form: 'infinitive',\n },\n append: {\n primary: 'додати_в_кінець',\n alternatives: ['дописати'],\n normalized: 'append',\n form: 'infinitive',\n },\n prepend: { primary: 'додати_на_початок', normalized: 'prepend', form: 'infinitive' },\n take: { primary: 'взяти', alternatives: ['візьми'], normalized: 'take', form: 'infinitive' },\n make: { primary: 'створити', alternatives: ['створи'], normalized: 'make', form: 'infinitive' },\n clone: {\n primary: 'клонувати',\n alternatives: ['клонуй'],\n normalized: 'clone',\n form: 'infinitive',\n },\n swap: {\n primary: 'поміняти',\n alternatives: ['поміняй'],\n normalized: 'swap',\n form: 'infinitive',\n },\n morph: {\n primary: 'трансформувати',\n alternatives: ['трансформуй'],\n normalized: 'morph',\n form: 'infinitive',\n },\n // Variable operations\n set: {\n primary: 'встановити',\n alternatives: ['встанови', 'задати', 'задай'],\n normalized: 'set',\n form: 'infinitive',\n },\n get: { primary: 'отримати', alternatives: ['отримай'], normalized: 'get', form: 'infinitive' },\n increment: {\n primary: 'збільшити',\n alternatives: ['збільш'],\n normalized: 'increment',\n form: 'infinitive',\n },\n decrement: {\n primary: 'зменшити',\n alternatives: ['зменш'],\n normalized: 'decrement',\n form: 'infinitive',\n },\n log: { primary: 'записати', alternatives: ['запиши'], normalized: 'log', form: 'infinitive' },\n // Visibility\n show: { primary: 'показати', alternatives: ['покажи'], normalized: 'show', form: 'infinitive' },\n hide: {\n primary: 'сховати',\n alternatives: ['сховай', 'приховати', 'приховай'],\n normalized: 'hide',\n form: 'infinitive',\n },\n transition: {\n primary: 'анімувати',\n alternatives: ['анімуй'],\n normalized: 'transition',\n form: 'infinitive',\n },\n // Events\n on: { primary: 'при', alternatives: ['коли'], normalized: 'on' },\n trigger: {\n primary: 'викликати',\n alternatives: ['виклич'],\n normalized: 'trigger',\n form: 'infinitive',\n },\n send: {\n primary: 'надіслати',\n alternatives: ['надішли'],\n normalized: 'send',\n form: 'infinitive',\n },\n // DOM focus\n focus: {\n primary: 'сфокусувати',\n alternatives: ['сфокусуй', 'фокус'],\n normalized: 'focus',\n form: 'infinitive',\n },\n blur: {\n primary: 'розфокусувати',\n alternatives: ['розфокусуй'],\n normalized: 'blur',\n form: 'infinitive',\n },\n // Common event names (for event handler patterns)\n click: { primary: 'кліку', alternatives: ['клік', 'натисканні'], normalized: 'click' },\n hover: { primary: 'наведенні', alternatives: ['наведення'], normalized: 'hover' },\n submit: { primary: 'відправці', alternatives: ['відправка'], normalized: 'submit' },\n input: { primary: 'введенні', alternatives: ['введення'], normalized: 'input' },\n change: { primary: 'зміні', alternatives: ['зміна'], normalized: 'change' },\n // Navigation\n go: {\n primary: 'перейти',\n alternatives: ['перейди', 'йти', 'йди'],\n normalized: 'go',\n form: 'infinitive',\n },\n // Async\n wait: {\n primary: 'чекати',\n alternatives: ['чекай', 'зачекай'],\n normalized: 'wait',\n form: 'infinitive',\n },\n fetch: {\n primary: 'завантажити',\n alternatives: ['завантаж'],\n normalized: 'fetch',\n form: 'infinitive',\n },\n settle: { primary: 'стабілізувати', normalized: 'settle', form: 'infinitive' },\n // Control flow\n if: { primary: 'якщо', normalized: 'if' },\n when: { primary: 'коли', normalized: 'when' },\n where: { primary: 'де', normalized: 'where' },\n else: { primary: 'інакше', normalized: 'else' },\n repeat: {\n primary: 'повторити',\n alternatives: ['повтори'],\n normalized: 'repeat',\n form: 'infinitive',\n },\n for: { primary: 'для', alternatives: ['кожний'], normalized: 'for' },\n while: { primary: 'поки', normalized: 'while' },\n continue: {\n primary: 'продовжити',\n alternatives: ['продовжуй'],\n normalized: 'continue',\n form: 'infinitive',\n },\n halt: {\n primary: 'зупинити',\n alternatives: ['зупинись', 'стоп'],\n normalized: 'halt',\n form: 'infinitive',\n },\n throw: { primary: 'кинути', alternatives: ['кинь'], normalized: 'throw', form: 'infinitive' },\n call: {\n primary: 'викликати',\n alternatives: ['виклич'],\n normalized: 'call',\n form: 'infinitive',\n },\n return: {\n primary: 'повернути',\n alternatives: ['поверни'],\n normalized: 'return',\n form: 'infinitive',\n },\n then: { primary: 'потім', alternatives: ['далі', 'тоді'], normalized: 'then' },\n and: { primary: 'і', alternatives: ['та'], normalized: 'and' },\n end: { primary: 'кінець', normalized: 'end' },\n // Advanced\n js: { primary: 'js', normalized: 'js' },\n async: { primary: 'асинхронно', alternatives: ['async'], normalized: 'async' },\n tell: { primary: 'сказати', alternatives: ['скажи'], normalized: 'tell', form: 'infinitive' },\n default: { primary: 'за_замовчуванням', normalized: 'default' },\n init: {\n primary: 'ініціалізувати',\n alternatives: ['ініціалізуй'],\n normalized: 'init',\n form: 'infinitive',\n },\n behavior: { primary: 'поведінка', normalized: 'behavior' },\n install: { primary: 'встановити_пакет', normalized: 'install', form: 'infinitive' },\n measure: {\n primary: 'виміряти',\n alternatives: ['виміряй'],\n normalized: 'measure',\n form: 'infinitive',\n },\n beep: { primary: 'звук', normalized: 'beep' },\n break: { primary: 'перервати', normalized: 'break' },\n copy: { primary: 'копіювати', normalized: 'copy' },\n exit: { primary: 'вийти', normalized: 'exit' },\n pick: { primary: 'вибрати', normalized: 'pick' },\n render: { primary: 'відобразити', normalized: 'render' },\n // Modifiers\n into: { primary: 'в', alternatives: ['у'], normalized: 'into' },\n before: { primary: 'до', alternatives: ['перед'], normalized: 'before' },\n after: { primary: 'після', normalized: 'after' },\n // Event modifiers\n until: { primary: 'до', alternatives: ['поки_не'], normalized: 'until' },\n event: { primary: 'подія', normalized: 'event' },\n from: { primary: 'з', alternatives: ['від', 'із'], normalized: 'from' },\n },\n eventHandler: {\n keyword: { primary: 'при', alternatives: ['коли'], normalized: 'on' },\n sourceMarker: { primary: 'на', alternatives: ['в', 'при'], position: 'before' },\n // Event marker: при (at/on/upon), used in SVO pattern\n // Pattern: при [event] [verb] [patient] на [destination?]\n // Example: при кліку перемкнути .active на #button\n eventMarker: { primary: 'при', alternatives: ['коли'], position: 'before' },\n temporalMarkers: ['коли', 'якщо'], // temporal conjunctions (when, if)\n },\n};\n","/**\n * Morphological Normalizer Types\n *\n * Defines interfaces for language-specific morphological analysis.\n * Normalizers reduce conjugated/inflected forms to canonical stems\n * that can be matched against keyword dictionaries.\n */\n\n/**\n * Result of morphological normalization.\n */\nexport interface NormalizationResult {\n /** The extracted stem/root form */\n readonly stem: string;\n\n /** Confidence in the normalization (0.0-1.0) */\n readonly confidence: number;\n\n /** Optional metadata about the transformation */\n readonly metadata?: NormalizationMetadata;\n}\n\n/**\n * Metadata about morphological transformations applied.\n */\nexport interface NormalizationMetadata {\n /** Prefixes that were removed */\n readonly removedPrefixes?: readonly string[];\n\n /** Suffixes that were removed */\n readonly removedSuffixes?: readonly string[];\n\n /** Type of conjugation detected */\n readonly conjugationType?: ConjugationType;\n\n /** Original form classification */\n readonly originalForm?: string;\n\n /** Applied transformation rules (for debugging) */\n readonly appliedRules?: readonly string[];\n}\n\n/**\n * Types of verb conjugation/inflection.\n */\nexport type ConjugationType =\n // Tense\n | 'present'\n | 'past'\n | 'future'\n | 'progressive'\n | 'perfect'\n // Mood\n | 'imperative'\n | 'subjunctive'\n | 'conditional'\n // Voice\n | 'passive'\n | 'causative'\n // Politeness (Japanese/Korean)\n | 'polite'\n | 'humble'\n | 'honorific'\n // Form\n | 'negative'\n | 'potential'\n | 'volitional'\n // Japanese conditional forms\n | 'conditional-tara' // たら/したら - if/when (completed action)\n | 'conditional-to' // と/すると - when (habitual/expected)\n | 'conditional-ba' // ば/すれば - if (hypothetical)\n // Korean-specific\n | 'connective' // 하고, 해서 etc.\n | 'conditional-myeon' // -(으)면 - if/when (general conditional)\n | 'temporal-ttae' // -(으)ㄹ 때 - when (at the time of)\n | 'causal-nikka' // -(으)니까 - because/since\n // Korean honorific forms (-시- infix)\n | 'honorific-conditional' // -하시면 - if (honorific)\n | 'honorific-temporal' // -하실 때 - when (honorific)\n | 'honorific-causal' // -하시니까 - because (honorific)\n | 'honorific-past' // -하셨어요 - past (honorific)\n | 'honorific-polite' // -하십니다 - polite (honorific)\n // Korean sequential forms\n | 'sequential-after' // -고 나서 - after doing\n | 'sequential-before' // -기 전에 - before doing\n | 'immediate' // -자마자 - as soon as\n | 'obligation' // -아야/어야 해 - must do, should do\n // Spanish-specific\n | 'reflexive'\n | 'reflexive-imperative'\n | 'gerund'\n | 'participle'\n // Arabic-specific\n | 'conditional-idha' // إذا - if/when (hypothetical)\n | 'temporal-indama' // عندما - when (temporal conjunction)\n | 'temporal-hina' // حين - at the time of\n | 'temporal-lamma' // لمّا - when (past emphasis)\n | 'past-verb' // فعل ماضي - past tense verb\n // Turkish-specific\n | 'conditional-se' // -se/-sa - if (hypothetical)\n | 'temporal-ince' // -ince/-ınca/-unca/-ünce - when/as\n | 'temporal-dikce' // -dikçe/-dıkça/-dukça/-dükçe - as/while\n | 'aorist' // -ir/-ar - habitual/general\n | 'optative' // -eyim/-ayım/-elim/-alım - let me/us\n | 'necessitative' // -meli/-malı - must/should\n // Japanese request/contracted forms\n | 'request' // てください/でください - polite request\n | 'casual-request' // てくれ/でくれ - casual request\n | 'contracted' // ちゃう/じゃう - contracted completion (てしまう)\n | 'contracted-past' // ちゃった/じゃった - contracted past completion\n // Compound\n | 'compound' // Multi-layer suffixes (ていなかった, 하고나서였어)\n | 'te-form' // Japanese て-form\n | 'dictionary'; // Base/infinitive form\n\n/**\n * Interface for language-specific morphological normalizers.\n *\n * Normalizers attempt to reduce inflected word forms to their\n * canonical stems. This enables matching conjugated verbs against\n * keyword dictionaries that only contain base forms.\n *\n * Example (Japanese):\n * 切り替えた (past) → { stem: '切り替え', confidence: 0.85 }\n * 切り替えます (polite) → { stem: '切り替え', confidence: 0.85 }\n *\n * Example (Spanish):\n * mostrarse (reflexive infinitive) → { stem: 'mostrar', confidence: 0.85 }\n * alternando (gerund) → { stem: 'alternar', confidence: 0.85 }\n */\nexport interface MorphologicalNormalizer {\n /** Language code this normalizer handles */\n readonly language: string;\n\n /**\n * Normalize a word to its canonical stem form.\n *\n * @param word - The word to normalize\n * @returns Normalization result with stem and confidence\n */\n normalize(word: string): NormalizationResult;\n\n /**\n * Check if a word appears to be a verb form that can be normalized.\n * Optional optimization to skip normalization for non-verb tokens.\n *\n * @param word - The word to check\n * @returns true if the word might be a normalizable verb form\n */\n isNormalizable?(word: string): boolean;\n}\n\n/**\n * Configuration for suffix-based normalization rules.\n * Used by agglutinative languages (Japanese, Korean, Turkish).\n */\nexport interface SuffixRule {\n /** The suffix pattern to match */\n readonly pattern: string;\n\n /** Confidence when this suffix is stripped */\n readonly confidence: number;\n\n /** What to replace the suffix with (empty string for simple removal) */\n readonly replacement?: string;\n\n /** Conjugation type this suffix indicates */\n readonly conjugationType?: ConjugationType;\n\n /** Minimum stem length after stripping (to avoid over-stripping) */\n readonly minStemLength?: number;\n}\n\n/**\n * Configuration for prefix-based normalization rules.\n * Used primarily by Arabic for article/conjunction prefixes.\n */\nexport interface PrefixRule {\n /** The prefix pattern to match */\n readonly pattern: string;\n\n /** Confidence penalty when this prefix is stripped */\n readonly confidencePenalty: number;\n\n /** What the prefix indicates (for metadata) */\n readonly prefixType?: 'article' | 'conjunction' | 'preposition' | 'verb-marker';\n\n /** Minimum remaining characters after stripping (to avoid over-stripping) */\n readonly minRemaining?: number;\n}\n\n/**\n * Helper to create a \"no change\" normalization result.\n */\nexport function noChange(word: string): NormalizationResult {\n return { stem: word, confidence: 1.0 };\n}\n\n/**\n * Helper to create a normalization result with metadata.\n */\nexport function normalized(\n stem: string,\n confidence: number,\n metadata?: NormalizationMetadata\n): NormalizationResult {\n if (metadata) {\n return { stem, confidence, metadata };\n }\n return { stem, confidence };\n}\n","/**\n * Ukrainian Morphological Normalizer\n *\n * Reduces Ukrainian verb conjugations to their infinitive forms.\n * Ukrainian is a fusional language closely related to Russian with rich verb morphology:\n * - Two aspects: perfective and imperfective\n * - Three tenses: present, past, future\n * - Person/number agreement in present tense (6 forms)\n * - Gender/number agreement in past tense (4 forms)\n * - Imperative mood (2 forms: singular and plural)\n * - Reflexive verbs (suffix -ся/-сь)\n *\n * Key differences from Russian:\n * - Infinitive ends in -ти (not -ть): робити, ходити\n * - Past masculine ends in -в (not -л): робив, ходив\n * - Unique vowels: і, ї, є, ґ\n *\n * For software UI, Ukrainian uses INFINITIVE form (industry standard):\n * - перемкнути (toggle), додати (add), видалити (remove)\n *\n * Examples:\n * перемкни → перемкнути (imperative → infinitive)\n * додав → додати (past → infinitive)\n * видаляє → видаляти (present → infinitive)\n */\n\nimport type { MorphologicalNormalizer, NormalizationResult } from './types';\nimport { noChange, normalized } from './types';\n\n/**\n * Check if a word contains Ukrainian/Cyrillic characters.\n */\nfunction hasUkrainianChars(word: string): boolean {\n return /[а-яА-ЯіІїЇєЄґҐьЬ']/.test(word);\n}\n\n/**\n * Common imperative → infinitive mappings for Ukrainian software UI keywords.\n * These are irregular or semi-regular forms from the language profile.\n */\nconst IMPERATIVE_TO_INFINITIVE = new Map<string, string>([\n // Core commands (from Ukrainian language profile)\n ['перемкни', 'перемкнути'],\n ['додай', 'додати'],\n ['видали', 'видалити'],\n ['прибери', 'прибрати'],\n ['поклади', 'покласти'],\n ['помісти', 'помістити'],\n ['встав', 'вставити'],\n ['візьми', 'взяти'],\n ['створи', 'створити'],\n ['клонуй', 'клонувати'],\n ['поміняй', 'поміняти'],\n ['трансформуй', 'трансформувати'],\n ['встанови', 'встановити'],\n ['задай', 'задати'],\n ['отримай', 'отримати'],\n ['збільш', 'збільшити'],\n ['зменш', 'зменшити'],\n ['запиши', 'записати'],\n ['покажи', 'показати'],\n ['сховай', 'сховати'],\n ['приховай', 'приховати'],\n ['анімуй', 'анімувати'],\n ['виклич', 'викликати'],\n ['надішли', 'надіслати'],\n ['сфокусуй', 'сфокусувати'],\n ['розфокусуй', 'розфокусувати'],\n ['перейди', 'перейти'],\n ['йди', 'йти'],\n ['чекай', 'чекати'],\n ['зачекай', 'зачекати'],\n ['завантаж', 'завантажити'],\n ['повтори', 'повторити'],\n ['продовжуй', 'продовжити'],\n ['кинь', 'кинути'],\n ['поверни', 'повернути'],\n ['скажи', 'сказати'],\n ['ініціалізуй', 'ініціалізувати'],\n ['виміряй', 'виміряти'],\n]);\n\n/**\n * Ukrainian morphological normalizer.\n */\nexport class UkrainianMorphologicalNormalizer implements MorphologicalNormalizer {\n readonly language = 'uk';\n\n /**\n * Check if a word might be a Ukrainian verb that can be normalized.\n */\n isNormalizable(word: string): boolean {\n if (word.length < 3) return false;\n return hasUkrainianChars(word);\n }\n\n /**\n * Normalize a Ukrainian word to its infinitive form.\n */\n normalize(word: string): NormalizationResult {\n const lower = word.toLowerCase();\n\n // Handle reflexive verbs: strip -ся/-сь, normalize, re-add -ся\n if (lower.endsWith('ся') || lower.endsWith('сь')) {\n const reflexiveResult = this.tryReflexiveNormalization(lower);\n if (reflexiveResult) return reflexiveResult;\n }\n\n // Already in infinitive form (-ти, -тися)?\n if (lower.endsWith('ти') || lower.endsWith('чи')) {\n return noChange(word);\n }\n\n // Try imperative → infinitive (lookup table only — high confidence)\n const imperativeLookup = this.tryImperativeLookup(lower);\n if (imperativeLookup) return imperativeLookup;\n\n // Try past tense → infinitive (before generic patterns — -али/-или are longer)\n const pastResult = this.tryPastTenseNormalization(lower);\n if (pastResult) return pastResult;\n\n // Try present tense → infinitive\n const presentResult = this.tryPresentTenseNormalization(lower);\n if (presentResult) return presentResult;\n\n // Try generic imperative patterns (fallback — lower confidence)\n const imperativeGeneric = this.tryGenericImperativeNormalization(lower);\n if (imperativeGeneric) return imperativeGeneric;\n\n // No normalization needed\n return noChange(word);\n }\n\n /**\n * Try to normalize reflexive verbs (-ся/-сь).\n */\n private tryReflexiveNormalization(word: string): NormalizationResult | null {\n const base = word.slice(0, -2);\n\n // Already reflexive infinitive (-тися)?\n if (word.endsWith('тися') || word.endsWith('чися')) {\n return noChange(word);\n }\n\n // Normalize the base verb\n const baseResult = this.normalizeNonReflexive(base);\n if (baseResult.confidence < 1.0) {\n const infinitive = baseResult.stem.endsWith('ти')\n ? baseResult.stem.slice(0, -2) + 'тися'\n : baseResult.stem + 'ся';\n return normalized(infinitive, baseResult.confidence * 0.95, {\n removedSuffixes: ['ся', ...(baseResult.metadata?.removedSuffixes || [])],\n conjugationType: 'reflexive',\n });\n }\n\n return null;\n }\n\n /**\n * Normalize a non-reflexive verb form.\n */\n private normalizeNonReflexive(word: string): NormalizationResult {\n if (word.endsWith('ти') || word.endsWith('чи')) {\n return noChange(word);\n }\n\n const imperativeLookup = this.tryImperativeLookup(word);\n if (imperativeLookup) return imperativeLookup;\n\n const pastResult = this.tryPastTenseNormalization(word);\n if (pastResult) return pastResult;\n\n const presentResult = this.tryPresentTenseNormalization(word);\n if (presentResult) return presentResult;\n\n const imperativeGeneric = this.tryGenericImperativeNormalization(word);\n if (imperativeGeneric) return imperativeGeneric;\n\n return noChange(word);\n }\n\n /**\n * Try imperative → infinitive via lookup table only.\n */\n private tryImperativeLookup(word: string): NormalizationResult | null {\n if (IMPERATIVE_TO_INFINITIVE.has(word)) {\n return normalized(IMPERATIVE_TO_INFINITIVE.get(word)!, 0.95, {\n removedSuffixes: ['imperative'],\n conjugationType: 'imperative',\n });\n }\n return null;\n }\n\n /**\n * Try generic imperative patterns (lower confidence fallback).\n */\n private tryGenericImperativeNormalization(word: string): NormalizationResult | null {\n // -йте (plural imperative for -ати verbs: читайте → читати)\n if (word.endsWith('йте') && word.length > 5) {\n return normalized(word.slice(0, -3) + 'ти', 0.8, {\n removedSuffixes: ['йте'],\n conjugationType: 'imperative',\n });\n }\n\n // -іть (2nd person plural/formal imperative)\n if (word.endsWith('іть') && word.length > 5) {\n return normalized(word.slice(0, -3) + 'ити', 0.8, {\n removedSuffixes: ['іть'],\n conjugationType: 'imperative',\n });\n }\n\n // -й → -ти (e.g., читай → читати)\n if (word.endsWith('й') && word.length > 3) {\n return normalized(word.slice(0, -1) + 'ти', 0.75, {\n removedSuffixes: ['й'],\n conjugationType: 'imperative',\n });\n }\n\n // -и (2nd person singular for -ити verbs)\n // e.g., говори → говорити\n if (word.endsWith('и') && word.length > 3) {\n return normalized(word + 'ти', 0.7, {\n removedSuffixes: ['и→ити'],\n conjugationType: 'imperative',\n });\n }\n\n return null;\n }\n\n /**\n * Try past tense → infinitive.\n *\n * Ukrainian past tense endings (differs from Russian):\n * - masculine: -в (робив → робити)\n * - feminine: -ла (робила → робити)\n * - neuter: -ло (робило → робити)\n * - plural: -ли (робили → робити)\n */\n private tryPastTenseNormalization(word: string): NormalizationResult | null {\n // Feminine/neuter/plural forms (longer suffixes first)\n if (word.endsWith('ала') && word.length > 4) {\n return normalized(word.slice(0, -3) + 'ати', 0.85, {\n removedSuffixes: ['ала'],\n conjugationType: 'past',\n });\n }\n if (word.endsWith('ила') && word.length > 4) {\n return normalized(word.slice(0, -3) + 'ити', 0.85, {\n removedSuffixes: ['ила'],\n conjugationType: 'past',\n });\n }\n if (word.endsWith('али') && word.length > 4) {\n return normalized(word.slice(0, -3) + 'ати', 0.85, {\n removedSuffixes: ['али'],\n conjugationType: 'past',\n });\n }\n if (word.endsWith('или') && word.length > 4) {\n return normalized(word.slice(0, -3) + 'ити', 0.85, {\n removedSuffixes: ['или'],\n conjugationType: 'past',\n });\n }\n\n // Masculine past: -ав → -ати, -ив → -ити\n if (word.endsWith('ав') && word.length > 3) {\n return normalized(word.slice(0, -2) + 'ати', 0.82, {\n removedSuffixes: ['ав'],\n conjugationType: 'past',\n });\n }\n if (word.endsWith('ив') && word.length > 3) {\n return normalized(word.slice(0, -2) + 'ити', 0.82, {\n removedSuffixes: ['ив'],\n conjugationType: 'past',\n });\n }\n\n return null;\n }\n\n /**\n * Try present tense → infinitive.\n *\n * Ukrainian present tense endings:\n * 1st conj: -ю/-у, -еш/-єш, -е/-є, -емо/-ємо, -ете/-єте, -ють/-уть\n * 2nd conj: -ю/-у, -иш, -ить, -имо, -ите, -ять/-ать\n */\n private tryPresentTenseNormalization(word: string): NormalizationResult | null {\n // 2nd conjugation (more specific, check first)\n if (word.endsWith('иш') && word.length > 3) {\n return normalized(word.slice(0, -2) + 'ити', 0.8, {\n removedSuffixes: ['иш'],\n conjugationType: 'present',\n });\n }\n if (word.endsWith('ить') && word.length > 4) {\n return normalized(word.slice(0, -3) + 'ити', 0.78, {\n removedSuffixes: ['ить'],\n conjugationType: 'present',\n });\n }\n if (word.endsWith('имо') && word.length > 4) {\n return normalized(word.slice(0, -3) + 'ити', 0.8, {\n removedSuffixes: ['имо'],\n conjugationType: 'present',\n });\n }\n if (word.endsWith('ять') && word.length > 4) {\n return normalized(word.slice(0, -3) + 'ити', 0.78, {\n removedSuffixes: ['ять'],\n conjugationType: 'present',\n });\n }\n\n // 1st conjugation\n if (word.endsWith('єш') && word.length > 3) {\n return normalized(word.slice(0, -2) + 'ати', 0.78, {\n removedSuffixes: ['єш'],\n conjugationType: 'present',\n });\n }\n if (word.endsWith('еш') && word.length > 3) {\n return normalized(word.slice(0, -2) + 'ати', 0.75, {\n removedSuffixes: ['еш'],\n conjugationType: 'present',\n });\n }\n if (word.endsWith('є') && word.length > 2) {\n return normalized(word.slice(0, -1) + 'ати', 0.72, {\n removedSuffixes: ['є'],\n conjugationType: 'present',\n });\n }\n if (word.endsWith('ємо') && word.length > 4) {\n return normalized(word.slice(0, -3) + 'ати', 0.8, {\n removedSuffixes: ['ємо'],\n conjugationType: 'present',\n });\n }\n if (word.endsWith('ють') && word.length > 4) {\n return normalized(word.slice(0, -3) + 'ати', 0.78, {\n removedSuffixes: ['ють'],\n conjugationType: 'present',\n });\n }\n if (word.endsWith('уть') && word.length > 4) {\n return normalized(word.slice(0, -3) + 'ати', 0.75, {\n removedSuffixes: ['уть'],\n conjugationType: 'present',\n });\n }\n\n return null;\n }\n}\n\n// Export singleton instance\nexport const ukrainianMorphologicalNormalizer = new UkrainianMorphologicalNormalizer();\n","/**\n * Ukrainian Tokenizer\n *\n * Tokenizes Ukrainian hyperscript input.\n * Ukrainian characteristics:\n * - SVO word order (relatively free, but SVO is common)\n * - Space-separated words\n * - Prepositions\n * - Cyrillic alphabet (with unique letters і, ї, є, ґ)\n * - Fusional morphology with verb conjugations\n * - Imperative form used in software UI (infinitive also common)\n */\n\nimport type { LanguageToken, TokenKind, TokenStream } from '../types';\nimport {\n BaseTokenizer,\n TokenStreamImpl,\n createToken,\n createPosition,\n createLatinCharClassifiers,\n isWhitespace,\n isSelectorStart,\n isQuote,\n isDigit,\n isUrlStart,\n type KeywordEntry,\n} from './base';\nimport { ukrainianProfile } from '../generators/profiles/ukrainian';\nimport { UkrainianMorphologicalNormalizer } from './morphology/ukrainian-normalizer';\n\n// =============================================================================\n// Ukrainian Character Classification\n// =============================================================================\n\nconst { isLetter: isUkrainianLetter, isIdentifierChar: isUkrainianIdentifierChar } =\n createLatinCharClassifiers(/[a-zA-Zа-яА-ЯіІїЇєЄґҐьЬ']/);\n\n// =============================================================================\n// Ukrainian Prepositions\n// =============================================================================\n\nconst PREPOSITIONS = new Set([\n 'в', // in\n 'у', // in\n 'на', // on\n 'з', // with, from\n 'із', // with (variant)\n 'зі', // with (before consonant clusters)\n 'до', // to\n 'від', // from\n 'о', // about\n 'об', // about (before vowels)\n 'при', // at, during\n 'для', // for\n 'під', // under\n 'над', // above\n 'перед', // in front of\n 'між', // between\n 'через', // through\n 'без', // without\n 'по', // along, by\n 'за', // behind, for\n 'про', // about\n 'після', // after\n 'навколо', // around\n 'проти', // against\n 'замість', // instead of\n 'крім', // except\n 'серед', // among\n 'к', // to (less common)\n]);\n\n// =============================================================================\n// Ukrainian Extras (keywords not in profile)\n// =============================================================================\n\n/**\n * Extra keywords not covered by the profile:\n * - Literals (true, false)\n * - Positional words\n * - Event names\n * - Time units\n * - Additional verb forms\n */\nconst UKRAINIAN_EXTRAS: KeywordEntry[] = [\n // Values/Literals\n { native: 'істина', normalized: 'true' },\n { native: 'правда', normalized: 'true' },\n { native: 'хибність', normalized: 'false' },\n { native: 'null', normalized: 'null' },\n { native: 'невизначено', normalized: 'undefined' },\n\n // Positional\n { native: 'перший', normalized: 'first' },\n { native: 'перша', normalized: 'first' },\n { native: 'перше', normalized: 'first' },\n { native: 'останній', normalized: 'last' },\n { native: 'остання', normalized: 'last' },\n { native: 'останнє', normalized: 'last' },\n { native: 'наступний', normalized: 'next' },\n { native: 'наступна', normalized: 'next' },\n { native: 'попередній', normalized: 'previous' },\n { native: 'попередня', normalized: 'previous' },\n { native: 'найближчий', normalized: 'closest' },\n { native: 'батько', normalized: 'parent' },\n\n // Events\n { native: 'клік', normalized: 'click' },\n { native: 'натискання', normalized: 'click' },\n { native: 'click', normalized: 'click' },\n { native: 'зміна', normalized: 'change' },\n { native: 'надсилання', normalized: 'submit' },\n { native: 'клавіша', normalized: 'keydown' },\n { native: 'наведення', normalized: 'mouseover' },\n { native: 'відведення', normalized: 'mouseout' },\n { native: 'завантаження', normalized: 'load' },\n { native: 'прокрутка', normalized: 'scroll' },\n { native: 'введення', normalized: 'input' },\n\n // References - possessive forms\n { native: 'мій', normalized: 'my' },\n { native: 'моя', normalized: 'my' },\n { native: 'моє', normalized: 'my' },\n { native: 'мої', normalized: 'my' },\n\n // Time units\n { native: 'секунда', normalized: 's' },\n { native: 'секунди', normalized: 's' },\n { native: 'секунд', normalized: 's' },\n { native: 'мілісекунда', normalized: 'ms' },\n { native: 'мілісекунди', normalized: 'ms' },\n { native: 'мілісекунд', normalized: 'ms' },\n { native: 'хвилина', normalized: 'm' },\n { native: 'хвилини', normalized: 'm' },\n { native: 'хвилин', normalized: 'm' },\n { native: 'година', normalized: 'h' },\n { native: 'години', normalized: 'h' },\n { native: 'годин', normalized: 'h' },\n\n // Logical/conditional\n { native: 'або', normalized: 'or' },\n { native: 'не', normalized: 'not' },\n { native: 'є', normalized: 'is' },\n { native: 'існує', normalized: 'exists' },\n { native: 'порожній', normalized: 'empty' },\n { native: 'порожня', normalized: 'empty' },\n { native: 'порожнє', normalized: 'empty' },\n];\n\n// =============================================================================\n// Ukrainian Tokenizer\n// =============================================================================\n\nexport class UkrainianTokenizer extends BaseTokenizer {\n readonly language = 'uk';\n readonly direction = 'ltr' as const;\n\n constructor() {\n super();\n // Initialize keywords from profile + extras (single source of truth)\n this.initializeKeywordsFromProfile(ukrainianProfile, UKRAINIAN_EXTRAS);\n this.normalizer = new UkrainianMorphologicalNormalizer();\n }\n\n tokenize(input: string): TokenStream {\n const tokens: LanguageToken[] = [];\n let pos = 0;\n\n while (pos < input.length) {\n if (isWhitespace(input[pos])) {\n pos++;\n continue;\n }\n\n if (isSelectorStart(input[pos])) {\n // Check for event modifier first (.once, .debounce(), etc.)\n const modifierToken = this.tryEventModifier(input, pos);\n if (modifierToken) {\n tokens.push(modifierToken);\n pos = modifierToken.position.end;\n continue;\n }\n\n // Check for property access (obj.prop) vs CSS selector (.active)\n if (this.tryPropertyAccess(input, pos, tokens)) {\n pos++;\n continue;\n }\n\n const selectorToken = this.trySelector(input, pos);\n if (selectorToken) {\n tokens.push(selectorToken);\n pos = selectorToken.position.end;\n continue;\n }\n }\n\n if (isQuote(input[pos])) {\n const stringToken = this.tryString(input, pos);\n if (stringToken) {\n tokens.push(stringToken);\n pos = stringToken.position.end;\n continue;\n }\n }\n\n if (isUrlStart(input, pos)) {\n const urlToken = this.tryUrl(input, pos);\n if (urlToken) {\n tokens.push(urlToken);\n pos = urlToken.position.end;\n continue;\n }\n }\n\n if (\n isDigit(input[pos]) ||\n (input[pos] === '-' && pos + 1 < input.length && isDigit(input[pos + 1]))\n ) {\n const numberToken = this.extractNumber(input, pos);\n if (numberToken) {\n tokens.push(numberToken);\n pos = numberToken.position.end;\n continue;\n }\n }\n\n const varToken = this.tryVariableRef(input, pos);\n if (varToken) {\n tokens.push(varToken);\n pos = varToken.position.end;\n continue;\n }\n\n if (isUkrainianLetter(input[pos])) {\n const wordToken = this.extractWord(input, pos);\n if (wordToken) {\n tokens.push(wordToken);\n pos = wordToken.position.end;\n continue;\n }\n }\n\n const operatorToken = this.tryOperator(input, pos);\n if (operatorToken) {\n tokens.push(operatorToken);\n pos = operatorToken.position.end;\n continue;\n }\n\n pos++;\n }\n\n return new TokenStreamImpl(tokens, 'uk');\n }\n\n classifyToken(token: string): TokenKind {\n const lower = token.toLowerCase();\n if (PREPOSITIONS.has(lower)) return 'particle';\n // O(1) Map lookup instead of O(n) array search\n if (this.isKeyword(lower)) return 'keyword';\n if (\n token.startsWith('#') ||\n token.startsWith('.') ||\n token.startsWith('[') ||\n token.startsWith('*') ||\n token.startsWith('<')\n )\n return 'selector';\n if (token.startsWith('\"') || token.startsWith(\"'\")) return 'literal';\n if (/^\\d/.test(token)) return 'literal';\n return 'identifier';\n }\n\n private extractWord(input: string, startPos: number): LanguageToken | null {\n let pos = startPos;\n let word = '';\n\n while (pos < input.length && isUkrainianIdentifierChar(input[pos])) {\n word += input[pos++];\n }\n\n if (!word) return null;\n\n const lower = word.toLowerCase();\n\n // Check if it's a preposition first\n if (PREPOSITIONS.has(lower)) {\n return createToken(word, 'particle', createPosition(startPos, pos));\n }\n\n // O(1) Map lookup instead of O(n) array search\n const keywordEntry = this.lookupKeyword(lower);\n if (keywordEntry) {\n return createToken(word, 'keyword', createPosition(startPos, pos), keywordEntry.normalized);\n }\n\n return createToken(word, 'identifier', createPosition(startPos, pos));\n }\n\n private extractNumber(input: string, startPos: number): LanguageToken | null {\n let pos = startPos;\n let number = '';\n\n if (input[pos] === '-' || input[pos] === '+') {\n number += input[pos++];\n }\n\n while (pos < input.length && isDigit(input[pos])) {\n number += input[pos++];\n }\n\n if (pos < input.length && input[pos] === '.') {\n number += input[pos++];\n while (pos < input.length && isDigit(input[pos])) {\n number += input[pos++];\n }\n }\n\n // Check for time units\n let unitPos = pos;\n while (unitPos < input.length && isWhitespace(input[unitPos])) {\n unitPos++;\n }\n\n const remaining = input.slice(unitPos).toLowerCase();\n if (remaining.startsWith('мілісекунд') || remaining.startsWith('мс')) {\n if (remaining.startsWith('мілісекунд')) {\n number += 'ms';\n pos = unitPos + 10; // \"мілісекунд\"\n // Handle inflection endings\n if (remaining.length > 10 && /[аи]/.test(remaining[10])) {\n pos++;\n }\n } else {\n number += 'ms';\n pos = unitPos + 2;\n }\n } else if (remaining.startsWith('секунд') || remaining.startsWith('сек')) {\n if (remaining.startsWith('секунд')) {\n number += 's';\n pos = unitPos + 6;\n // Handle inflection endings\n if (remaining.length > 6 && /[аи]/.test(remaining[6])) {\n pos++;\n }\n } else {\n number += 's';\n pos = unitPos + 3;\n }\n } else if (remaining.startsWith('хвилин') || remaining.startsWith('хв')) {\n if (remaining.startsWith('хвилин')) {\n number += 'm';\n pos = unitPos + 6;\n // Handle inflection endings\n if (remaining.length > 6 && /[аи]/.test(remaining[6])) {\n pos++;\n }\n } else {\n number += 'm';\n pos = unitPos + 2;\n }\n } else if (remaining.startsWith('годин')) {\n number += 'h';\n pos = unitPos + 5;\n // Handle inflection endings\n if (remaining.length > 5 && /[аи]/.test(remaining[5])) {\n pos++;\n }\n } else if (remaining.startsWith('ms')) {\n number += 'ms';\n pos = unitPos + 2;\n } else if (remaining.startsWith('s') && !remaining.startsWith('se')) {\n number += 's';\n pos = unitPos + 1;\n }\n\n if (!number || number === '-' || number === '+') return null;\n\n return createToken(number, 'literal', createPosition(startPos, pos));\n }\n}\n\nexport const ukrainianTokenizer = new UkrainianTokenizer();\n","/**\n * Ukrainian Language Module\n *\n * Self-registering module that sets up Ukrainian language support.\n * Import this module to enable Ukrainian in the semantic parser.\n *\n * @example\n * ```typescript\n * // Enable Ukrainian\n * import '@lokascript/semantic/languages/uk';\n *\n * // Or import everything\n * import '@lokascript/semantic/languages/_all';\n * ```\n */\n\nimport { registerLanguage } from '../registry';\nimport { ukrainianTokenizer } from '../tokenizers/ukrainian';\nimport { ukrainianProfile } from '../generators/profiles/ukrainian';\n\n// Re-export for direct access\nexport { ukrainianTokenizer } from '../tokenizers/ukrainian';\nexport { ukrainianProfile } from '../generators/profiles/ukrainian';\n\n// Self-register on import\nregisterLanguage('uk', ukrainianTokenizer, ukrainianProfile);\n"],"mappings":"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","names":["normalized","normalized"]}
@@ -0,0 +1,10 @@
1
+ /**
2
+ * Vietnamese Language Module
3
+ *
4
+ * Self-registering module that initializes Vietnamese language support.
5
+ * Import this file to enable Vietnamese semantic parsing.
6
+ */
7
+ import { vietnameseTokenizer } from '../tokenizers/vietnamese';
8
+ import { vietnameseProfile } from '../generators/profiles/vietnamese';
9
+ export { vietnameseTokenizer, vietnameseProfile };
10
+ //# sourceMappingURL=vi.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vi.d.ts","sourceRoot":"","sources":["../../src/languages/vi.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAC;AAMtE,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,CAAC"}