@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,1647 @@
1
+ // src/registry.ts
2
+ var tokenizers = /* @__PURE__ */ new Map();
3
+ var profiles = /* @__PURE__ */ new Map();
4
+ var patternCache = /* @__PURE__ */ new Map();
5
+ function registerLanguage(code, tokenizer, profile) {
6
+ tokenizers.set(code, tokenizer);
7
+ profiles.set(code, profile);
8
+ patternCache.delete(code);
9
+ }
10
+
11
+ // src/tokenizers/token-utils.ts
12
+ var TokenStreamImpl = class {
13
+ constructor(tokens, language) {
14
+ this.pos = 0;
15
+ this.tokens = tokens;
16
+ this.language = language;
17
+ }
18
+ peek(offset = 0) {
19
+ const index = this.pos + offset;
20
+ if (index < 0 || index >= this.tokens.length) {
21
+ return null;
22
+ }
23
+ return this.tokens[index];
24
+ }
25
+ advance() {
26
+ if (this.isAtEnd()) {
27
+ throw new Error("Unexpected end of token stream");
28
+ }
29
+ return this.tokens[this.pos++];
30
+ }
31
+ isAtEnd() {
32
+ return this.pos >= this.tokens.length;
33
+ }
34
+ mark() {
35
+ return { position: this.pos };
36
+ }
37
+ reset(mark) {
38
+ this.pos = mark.position;
39
+ }
40
+ position() {
41
+ return this.pos;
42
+ }
43
+ /**
44
+ * Get remaining tokens as an array.
45
+ */
46
+ remaining() {
47
+ return this.tokens.slice(this.pos);
48
+ }
49
+ /**
50
+ * Consume tokens while predicate is true.
51
+ */
52
+ takeWhile(predicate) {
53
+ const result = [];
54
+ while (!this.isAtEnd() && predicate(this.peek())) {
55
+ result.push(this.advance());
56
+ }
57
+ return result;
58
+ }
59
+ /**
60
+ * Skip tokens while predicate is true.
61
+ */
62
+ skipWhile(predicate) {
63
+ while (!this.isAtEnd() && predicate(this.peek())) {
64
+ this.advance();
65
+ }
66
+ }
67
+ };
68
+ function createPosition(start, end) {
69
+ return { start, end };
70
+ }
71
+ function createToken(value, kind, position, normalizedOrOptions) {
72
+ if (typeof normalizedOrOptions === "string") {
73
+ return { value, kind, position, normalized: normalizedOrOptions };
74
+ }
75
+ if (normalizedOrOptions) {
76
+ const { normalized: normalized2, stem, stemConfidence } = normalizedOrOptions;
77
+ return {
78
+ value,
79
+ kind,
80
+ position,
81
+ ...normalized2 !== void 0 && { normalized: normalized2 },
82
+ ...stem !== void 0 && { stem },
83
+ ...stemConfidence !== void 0 && { stemConfidence }
84
+ };
85
+ }
86
+ return { value, kind, position };
87
+ }
88
+ function isWhitespace(char) {
89
+ return /\s/.test(char);
90
+ }
91
+ function isSelectorStart(char) {
92
+ return char === "#" || char === "." || char === "[" || char === "@" || char === "*" || char === "<";
93
+ }
94
+ function isQuote(char) {
95
+ return char === '"' || char === "'" || char === "`" || char === "\u300C" || char === "\u300D";
96
+ }
97
+ function isDigit(char) {
98
+ return /\d/.test(char);
99
+ }
100
+ function isAsciiLetter(char) {
101
+ return /[a-zA-Z]/.test(char);
102
+ }
103
+ function isAsciiIdentifierChar(char) {
104
+ return /[a-zA-Z0-9_-]/.test(char);
105
+ }
106
+
107
+ // src/tokenizers/char-classifiers.ts
108
+ function createLatinCharClassifiers(letterPattern) {
109
+ const isLetter = (char) => letterPattern.test(char);
110
+ const isIdentifierChar = (char) => isLetter(char) || /[0-9_-]/.test(char);
111
+ return { isLetter, isIdentifierChar };
112
+ }
113
+
114
+ // src/tokenizers/extractors.ts
115
+ function extractCssSelector(input, startPos) {
116
+ if (startPos >= input.length) return null;
117
+ const char = input[startPos];
118
+ if (!isSelectorStart(char)) return null;
119
+ let pos = startPos;
120
+ let selector = "";
121
+ if (char === "#" || char === ".") {
122
+ selector += input[pos++];
123
+ while (pos < input.length && isAsciiIdentifierChar(input[pos])) {
124
+ selector += input[pos++];
125
+ }
126
+ if (selector.length <= 1) return null;
127
+ if (pos < input.length && input[pos] === "." && char === "#") {
128
+ const methodStart = pos + 1;
129
+ let methodEnd = methodStart;
130
+ while (methodEnd < input.length && isAsciiIdentifierChar(input[methodEnd])) {
131
+ methodEnd++;
132
+ }
133
+ if (methodEnd < input.length && input[methodEnd] === "(") {
134
+ return selector;
135
+ }
136
+ }
137
+ } else if (char === "[") {
138
+ let depth = 1;
139
+ let inQuote = false;
140
+ let quoteChar = null;
141
+ let escaped = false;
142
+ selector += input[pos++];
143
+ while (pos < input.length && depth > 0) {
144
+ const c = input[pos];
145
+ selector += c;
146
+ if (escaped) {
147
+ escaped = false;
148
+ } else if (c === "\\") {
149
+ escaped = true;
150
+ } else if (inQuote) {
151
+ if (c === quoteChar) {
152
+ inQuote = false;
153
+ quoteChar = null;
154
+ }
155
+ } else {
156
+ if (c === '"' || c === "'" || c === "`") {
157
+ inQuote = true;
158
+ quoteChar = c;
159
+ } else if (c === "[") {
160
+ depth++;
161
+ } else if (c === "]") {
162
+ depth--;
163
+ }
164
+ }
165
+ pos++;
166
+ }
167
+ if (depth !== 0) return null;
168
+ } else if (char === "@") {
169
+ selector += input[pos++];
170
+ while (pos < input.length && isAsciiIdentifierChar(input[pos])) {
171
+ selector += input[pos++];
172
+ }
173
+ if (selector.length <= 1) return null;
174
+ } else if (char === "*") {
175
+ selector += input[pos++];
176
+ while (pos < input.length && isAsciiIdentifierChar(input[pos])) {
177
+ selector += input[pos++];
178
+ }
179
+ if (selector.length <= 1) return null;
180
+ } else if (char === "<") {
181
+ selector += input[pos++];
182
+ if (pos >= input.length || !isAsciiLetter(input[pos])) return null;
183
+ while (pos < input.length && isAsciiIdentifierChar(input[pos])) {
184
+ selector += input[pos++];
185
+ }
186
+ while (pos < input.length) {
187
+ const modChar = input[pos];
188
+ if (modChar === ".") {
189
+ selector += input[pos++];
190
+ if (pos >= input.length || !isAsciiIdentifierChar(input[pos])) {
191
+ return null;
192
+ }
193
+ while (pos < input.length && isAsciiIdentifierChar(input[pos])) {
194
+ selector += input[pos++];
195
+ }
196
+ } else if (modChar === "#") {
197
+ selector += input[pos++];
198
+ if (pos >= input.length || !isAsciiIdentifierChar(input[pos])) {
199
+ return null;
200
+ }
201
+ while (pos < input.length && isAsciiIdentifierChar(input[pos])) {
202
+ selector += input[pos++];
203
+ }
204
+ } else if (modChar === "[") {
205
+ let depth = 1;
206
+ let inQuote = false;
207
+ let quoteChar = null;
208
+ let escaped = false;
209
+ selector += input[pos++];
210
+ while (pos < input.length && depth > 0) {
211
+ const c = input[pos];
212
+ selector += c;
213
+ if (escaped) {
214
+ escaped = false;
215
+ } else if (c === "\\") {
216
+ escaped = true;
217
+ } else if (inQuote) {
218
+ if (c === quoteChar) {
219
+ inQuote = false;
220
+ quoteChar = null;
221
+ }
222
+ } else {
223
+ if (c === '"' || c === "'" || c === "`") {
224
+ inQuote = true;
225
+ quoteChar = c;
226
+ } else if (c === "[") {
227
+ depth++;
228
+ } else if (c === "]") {
229
+ depth--;
230
+ }
231
+ }
232
+ pos++;
233
+ }
234
+ if (depth !== 0) return null;
235
+ } else {
236
+ break;
237
+ }
238
+ }
239
+ while (pos < input.length && isWhitespace(input[pos])) {
240
+ selector += input[pos++];
241
+ }
242
+ if (pos < input.length && input[pos] === "/") {
243
+ selector += input[pos++];
244
+ while (pos < input.length && isWhitespace(input[pos])) {
245
+ selector += input[pos++];
246
+ }
247
+ }
248
+ if (pos >= input.length || input[pos] !== ">") return null;
249
+ selector += input[pos++];
250
+ }
251
+ return selector || null;
252
+ }
253
+ function isPossessiveMarker(input, pos) {
254
+ if (pos >= input.length || input[pos] !== "'") return false;
255
+ if (pos + 1 >= input.length) return false;
256
+ const nextChar = input[pos + 1].toLowerCase();
257
+ if (nextChar !== "s") return false;
258
+ if (pos + 2 >= input.length) return true;
259
+ const afterS = input[pos + 2];
260
+ return isWhitespace(afterS) || afterS === "*" || !isAsciiIdentifierChar(afterS);
261
+ }
262
+ function extractStringLiteral(input, startPos) {
263
+ if (startPos >= input.length) return null;
264
+ const openQuote = input[startPos];
265
+ if (!isQuote(openQuote)) return null;
266
+ if (openQuote === "'" && isPossessiveMarker(input, startPos)) {
267
+ return null;
268
+ }
269
+ const closeQuoteMap = {
270
+ '"': '"',
271
+ "'": "'",
272
+ "`": "`",
273
+ "\u300C": "\u300D"
274
+ };
275
+ const closeQuote = closeQuoteMap[openQuote];
276
+ if (!closeQuote) return null;
277
+ let pos = startPos + 1;
278
+ let literal = openQuote;
279
+ let escaped = false;
280
+ while (pos < input.length) {
281
+ const char = input[pos];
282
+ literal += char;
283
+ if (escaped) {
284
+ escaped = false;
285
+ } else if (char === "\\") {
286
+ escaped = true;
287
+ } else if (char === closeQuote) {
288
+ return literal;
289
+ }
290
+ pos++;
291
+ }
292
+ return literal;
293
+ }
294
+ function isUrlStart(input, pos) {
295
+ if (pos >= input.length) return false;
296
+ const char = input[pos];
297
+ const next = input[pos + 1] || "";
298
+ const third = input[pos + 2] || "";
299
+ if (char === "/" && next !== "/" && /[a-zA-Z0-9._-]/.test(next)) {
300
+ return true;
301
+ }
302
+ if (char === "/" && next === "/" && /[a-zA-Z]/.test(third)) {
303
+ return true;
304
+ }
305
+ if (char === "." && (next === "/" || next === "." && third === "/")) {
306
+ return true;
307
+ }
308
+ const slice = input.slice(pos, pos + 8).toLowerCase();
309
+ if (slice.startsWith("http://") || slice.startsWith("https://")) {
310
+ return true;
311
+ }
312
+ return false;
313
+ }
314
+ function extractUrl(input, startPos) {
315
+ if (!isUrlStart(input, startPos)) return null;
316
+ let pos = startPos;
317
+ let url = "";
318
+ const urlChars = /[a-zA-Z0-9/:._\-?&=%@+~!$'()*,;[\]]/;
319
+ while (pos < input.length) {
320
+ const char = input[pos];
321
+ if (char === "#") {
322
+ if (url.length > 0 && /[a-zA-Z0-9/.]$/.test(url)) {
323
+ url += char;
324
+ pos++;
325
+ while (pos < input.length && /[a-zA-Z0-9_-]/.test(input[pos])) {
326
+ url += input[pos++];
327
+ }
328
+ }
329
+ break;
330
+ }
331
+ if (urlChars.test(char)) {
332
+ url += char;
333
+ pos++;
334
+ } else {
335
+ break;
336
+ }
337
+ }
338
+ if (url.length < 2) return null;
339
+ return url;
340
+ }
341
+ function extractNumber(input, startPos) {
342
+ if (startPos >= input.length) return null;
343
+ const char = input[startPos];
344
+ if (!isDigit(char) && char !== "-" && char !== "+") return null;
345
+ let pos = startPos;
346
+ let number = "";
347
+ if (input[pos] === "-" || input[pos] === "+") {
348
+ number += input[pos++];
349
+ }
350
+ if (pos >= input.length || !isDigit(input[pos])) {
351
+ return null;
352
+ }
353
+ while (pos < input.length && isDigit(input[pos])) {
354
+ number += input[pos++];
355
+ }
356
+ if (pos < input.length && input[pos] === ".") {
357
+ number += input[pos++];
358
+ while (pos < input.length && isDigit(input[pos])) {
359
+ number += input[pos++];
360
+ }
361
+ }
362
+ if (pos < input.length) {
363
+ const suffix = input.slice(pos, pos + 2);
364
+ if (suffix === "ms") {
365
+ number += "ms";
366
+ } else if (input[pos] === "s" || input[pos] === "m" || input[pos] === "h") {
367
+ number += input[pos];
368
+ }
369
+ }
370
+ return number;
371
+ }
372
+
373
+ // src/tokenizers/base-tokenizer.ts
374
+ var _BaseTokenizer = class _BaseTokenizer {
375
+ constructor() {
376
+ /** Keywords derived from profile, sorted longest-first for greedy matching */
377
+ this.profileKeywords = [];
378
+ /** Map for O(1) keyword lookups by lowercase native word */
379
+ this.profileKeywordMap = /* @__PURE__ */ new Map();
380
+ }
381
+ /**
382
+ * Check if current position is a property access (obj.prop) vs CSS selector (.active).
383
+ * Property access: no whitespace before '.', previous token is identifier/keyword/selector.
384
+ * Also detects standalone method calls: .identifier( pattern.
385
+ *
386
+ * Returns true if '.' was emitted as an operator token and pos should advance by 1.
387
+ * Returns false if this is a CSS selector and should be handled by trySelector().
388
+ */
389
+ tryPropertyAccess(input, pos, tokens) {
390
+ if (input[pos] !== ".") return false;
391
+ const lastToken = tokens[tokens.length - 1];
392
+ const hasWhitespaceBefore = lastToken && lastToken.position.end < pos;
393
+ const isPropertyAccess = lastToken && !hasWhitespaceBefore && (lastToken.kind === "identifier" || lastToken.kind === "keyword" || lastToken.kind === "selector");
394
+ if (isPropertyAccess) {
395
+ tokens.push(createToken(".", "operator", createPosition(pos, pos + 1)));
396
+ return true;
397
+ }
398
+ const methodStart = pos + 1;
399
+ let methodEnd = methodStart;
400
+ while (methodEnd < input.length && isAsciiIdentifierChar(input[methodEnd])) {
401
+ methodEnd++;
402
+ }
403
+ if (methodEnd < input.length && input[methodEnd] === "(") {
404
+ tokens.push(createToken(".", "operator", createPosition(pos, pos + 1)));
405
+ return true;
406
+ }
407
+ return false;
408
+ }
409
+ /**
410
+ * Initialize keyword mappings from a language profile.
411
+ * Builds a list of native→english mappings from:
412
+ * - profile.keywords (primary + alternatives)
413
+ * - profile.references (me, it, you, etc.)
414
+ * - profile.roleMarkers (into, from, with, etc.)
415
+ *
416
+ * Results are sorted longest-first for greedy matching (important for non-space languages).
417
+ * Extras take precedence over profile entries when there are duplicates.
418
+ *
419
+ * @param profile - Language profile containing keyword translations
420
+ * @param extras - Additional keyword entries to include (literals, positional, events)
421
+ */
422
+ initializeKeywordsFromProfile(profile, extras = []) {
423
+ const keywordMap = /* @__PURE__ */ new Map();
424
+ if (profile.keywords) {
425
+ for (const [normalized2, translation] of Object.entries(profile.keywords)) {
426
+ keywordMap.set(translation.primary, {
427
+ native: translation.primary,
428
+ normalized: translation.normalized || normalized2
429
+ });
430
+ if (translation.alternatives) {
431
+ for (const alt of translation.alternatives) {
432
+ keywordMap.set(alt, {
433
+ native: alt,
434
+ normalized: translation.normalized || normalized2
435
+ });
436
+ }
437
+ }
438
+ }
439
+ }
440
+ if (profile.references) {
441
+ for (const [normalized2, native] of Object.entries(profile.references)) {
442
+ keywordMap.set(native, { native, normalized: normalized2 });
443
+ }
444
+ for (const canonical of Object.keys(profile.references)) {
445
+ if (!keywordMap.has(canonical)) {
446
+ keywordMap.set(canonical, { native: canonical, normalized: canonical });
447
+ }
448
+ }
449
+ }
450
+ if (profile.roleMarkers) {
451
+ for (const [role, marker] of Object.entries(profile.roleMarkers)) {
452
+ if (marker.primary) {
453
+ keywordMap.set(marker.primary, { native: marker.primary, normalized: role });
454
+ }
455
+ if (marker.alternatives) {
456
+ for (const alt of marker.alternatives) {
457
+ keywordMap.set(alt, { native: alt, normalized: role });
458
+ }
459
+ }
460
+ }
461
+ }
462
+ for (const extra of extras) {
463
+ keywordMap.set(extra.native, extra);
464
+ }
465
+ this.profileKeywords = Array.from(keywordMap.values()).sort(
466
+ (a, b) => b.native.length - a.native.length
467
+ );
468
+ this.profileKeywordMap = /* @__PURE__ */ new Map();
469
+ for (const keyword of this.profileKeywords) {
470
+ this.profileKeywordMap.set(keyword.native.toLowerCase(), keyword);
471
+ const normalized2 = this.removeDiacritics(keyword.native);
472
+ if (normalized2 !== keyword.native && !this.profileKeywordMap.has(normalized2.toLowerCase())) {
473
+ this.profileKeywordMap.set(normalized2.toLowerCase(), keyword);
474
+ }
475
+ }
476
+ }
477
+ /**
478
+ * Remove diacritical marks from a word for normalization.
479
+ * Primarily for Arabic (shadda, fatha, kasra, damma, sukun, etc.)
480
+ * but could be extended for other languages.
481
+ *
482
+ * @param word - Word to normalize
483
+ * @returns Word without diacritics
484
+ */
485
+ removeDiacritics(word) {
486
+ return word.replace(/[\u064B-\u0652\u0670]/g, "");
487
+ }
488
+ /**
489
+ * Try to match a keyword from profile at the current position.
490
+ * Uses longest-first greedy matching (important for non-space languages).
491
+ *
492
+ * @param input - Input string
493
+ * @param pos - Current position
494
+ * @returns Token if matched, null otherwise
495
+ */
496
+ tryProfileKeyword(input, pos) {
497
+ for (const entry of this.profileKeywords) {
498
+ if (input.slice(pos).startsWith(entry.native)) {
499
+ return createToken(
500
+ entry.native,
501
+ "keyword",
502
+ createPosition(pos, pos + entry.native.length),
503
+ entry.normalized
504
+ );
505
+ }
506
+ }
507
+ return null;
508
+ }
509
+ /**
510
+ * Check if the remaining input starts with any known keyword.
511
+ * Useful for non-space languages to detect word boundaries.
512
+ *
513
+ * @param input - Input string
514
+ * @param pos - Current position
515
+ * @returns true if a keyword starts at this position
516
+ */
517
+ isKeywordStart(input, pos) {
518
+ const remaining = input.slice(pos);
519
+ return this.profileKeywords.some((entry) => remaining.startsWith(entry.native));
520
+ }
521
+ /**
522
+ * Look up a keyword by native word (case-insensitive).
523
+ * O(1) lookup using the keyword map.
524
+ *
525
+ * @param native - Native word to look up
526
+ * @returns KeywordEntry if found, undefined otherwise
527
+ */
528
+ lookupKeyword(native) {
529
+ return this.profileKeywordMap.get(native.toLowerCase());
530
+ }
531
+ /**
532
+ * Check if a word is a known keyword (case-insensitive).
533
+ * O(1) lookup using the keyword map.
534
+ *
535
+ * @param native - Native word to check
536
+ * @returns true if the word is a keyword
537
+ */
538
+ isKeyword(native) {
539
+ return this.profileKeywordMap.has(native.toLowerCase());
540
+ }
541
+ /**
542
+ * Set the morphological normalizer for this tokenizer.
543
+ */
544
+ setNormalizer(normalizer) {
545
+ this.normalizer = normalizer;
546
+ }
547
+ /**
548
+ * Try to normalize a word using the morphological normalizer.
549
+ * Returns null if no normalizer is set or normalization fails.
550
+ *
551
+ * Note: We don't check isNormalizable() here because the individual tokenizers
552
+ * historically called normalize() directly without that check. The normalize()
553
+ * method itself handles returning noChange() for words that can't be normalized.
554
+ */
555
+ tryNormalize(word) {
556
+ if (!this.normalizer) return null;
557
+ const result = this.normalizer.normalize(word);
558
+ if (result.stem !== word && result.confidence >= 0.7) {
559
+ return result;
560
+ }
561
+ return null;
562
+ }
563
+ /**
564
+ * Try morphological normalization and keyword lookup.
565
+ *
566
+ * If the word can be normalized to a stem that matches a known keyword,
567
+ * returns a keyword token with morphological metadata (stem, stemConfidence).
568
+ *
569
+ * This is the common pattern for handling conjugated verbs across languages:
570
+ * 1. Normalize the word (e.g., "toggled" → "toggle")
571
+ * 2. Look up the stem in the keyword map
572
+ * 3. Create a token with both the original form and stem metadata
573
+ *
574
+ * @param word - The word to normalize and look up
575
+ * @param startPos - Start position for the token
576
+ * @param endPos - End position for the token
577
+ * @returns Token if stem matches a keyword, null otherwise
578
+ */
579
+ tryMorphKeywordMatch(word, startPos, endPos) {
580
+ const result = this.tryNormalize(word);
581
+ if (!result) return null;
582
+ const stemEntry = this.lookupKeyword(result.stem);
583
+ if (!stemEntry) return null;
584
+ const tokenOptions = {
585
+ normalized: stemEntry.normalized,
586
+ stem: result.stem,
587
+ stemConfidence: result.confidence
588
+ };
589
+ return createToken(word, "keyword", createPosition(startPos, endPos), tokenOptions);
590
+ }
591
+ /**
592
+ * Try to extract a CSS selector at the current position.
593
+ */
594
+ trySelector(input, pos) {
595
+ const selector = extractCssSelector(input, pos);
596
+ if (selector) {
597
+ return createToken(selector, "selector", createPosition(pos, pos + selector.length));
598
+ }
599
+ return null;
600
+ }
601
+ /**
602
+ * Try to extract an event modifier at the current position.
603
+ * Event modifiers are .once, .debounce(N), .throttle(N), .queue(strategy)
604
+ */
605
+ tryEventModifier(input, pos) {
606
+ if (input[pos] !== ".") {
607
+ return null;
608
+ }
609
+ const match = input.slice(pos).match(/^\.(?:once|debounce|throttle|queue)(?:\(([^)]+)\))?(?:\s|$|\.)/);
610
+ if (!match) {
611
+ return null;
612
+ }
613
+ const fullMatch = match[0].replace(/(\s|\.)$/, "");
614
+ const modifierName = fullMatch.slice(1).split("(")[0];
615
+ const value = match[1];
616
+ const token = createToken(
617
+ fullMatch,
618
+ "event-modifier",
619
+ createPosition(pos, pos + fullMatch.length)
620
+ );
621
+ return {
622
+ ...token,
623
+ metadata: {
624
+ modifierName,
625
+ value: value ? modifierName === "queue" ? value : parseInt(value, 10) : void 0
626
+ }
627
+ };
628
+ }
629
+ /**
630
+ * Try to extract a string literal at the current position.
631
+ */
632
+ tryString(input, pos) {
633
+ const literal = extractStringLiteral(input, pos);
634
+ if (literal) {
635
+ return createToken(literal, "literal", createPosition(pos, pos + literal.length));
636
+ }
637
+ return null;
638
+ }
639
+ /**
640
+ * Try to extract a number at the current position.
641
+ */
642
+ tryNumber(input, pos) {
643
+ const number = extractNumber(input, pos);
644
+ if (number) {
645
+ return createToken(number, "literal", createPosition(pos, pos + number.length));
646
+ }
647
+ return null;
648
+ }
649
+ /**
650
+ * Try to match a time unit from a list of patterns.
651
+ *
652
+ * @param input - Input string
653
+ * @param pos - Position after the number
654
+ * @param timeUnits - Array of time unit mappings (native pattern → standard suffix)
655
+ * @param skipWhitespace - Whether to skip whitespace before time unit (default: false)
656
+ * @returns Object with matched suffix and new position, or null if no match
657
+ */
658
+ tryMatchTimeUnit(input, pos, timeUnits, skipWhitespace = false) {
659
+ let unitPos = pos;
660
+ if (skipWhitespace) {
661
+ while (unitPos < input.length && isWhitespace(input[unitPos])) {
662
+ unitPos++;
663
+ }
664
+ }
665
+ const remaining = input.slice(unitPos);
666
+ for (const unit of timeUnits) {
667
+ const candidate = remaining.slice(0, unit.length);
668
+ const matches = unit.caseInsensitive ? candidate.toLowerCase() === unit.pattern.toLowerCase() : candidate === unit.pattern;
669
+ if (matches) {
670
+ if (unit.notFollowedBy) {
671
+ const nextChar = remaining[unit.length] || "";
672
+ if (nextChar === unit.notFollowedBy) continue;
673
+ }
674
+ if (unit.checkBoundary) {
675
+ const nextChar = remaining[unit.length] || "";
676
+ if (isAsciiIdentifierChar(nextChar)) continue;
677
+ }
678
+ return { suffix: unit.suffix, endPos: unitPos + unit.length };
679
+ }
680
+ }
681
+ return null;
682
+ }
683
+ /**
684
+ * Parse a base number (sign, integer, decimal) without time units.
685
+ * Returns the number string and end position.
686
+ *
687
+ * @param input - Input string
688
+ * @param startPos - Start position
689
+ * @param allowSign - Whether to allow +/- sign (default: true)
690
+ * @returns Object with number string and end position, or null
691
+ */
692
+ parseBaseNumber(input, startPos, allowSign = true) {
693
+ let pos = startPos;
694
+ let number = "";
695
+ if (allowSign && (input[pos] === "-" || input[pos] === "+")) {
696
+ number += input[pos++];
697
+ }
698
+ if (pos >= input.length || !isDigit(input[pos])) {
699
+ return null;
700
+ }
701
+ while (pos < input.length && isDigit(input[pos])) {
702
+ number += input[pos++];
703
+ }
704
+ if (pos < input.length && input[pos] === ".") {
705
+ number += input[pos++];
706
+ while (pos < input.length && isDigit(input[pos])) {
707
+ number += input[pos++];
708
+ }
709
+ }
710
+ if (!number || number === "-" || number === "+") return null;
711
+ return { number, endPos: pos };
712
+ }
713
+ /**
714
+ * Try to extract a number with native language time units.
715
+ *
716
+ * This is a template method that handles the common pattern:
717
+ * 1. Parse the base number (sign, integer, decimal)
718
+ * 2. Try to match native language time units
719
+ * 3. Fall back to standard time units (ms, s, m, h)
720
+ *
721
+ * @param input - Input string
722
+ * @param pos - Start position
723
+ * @param nativeTimeUnits - Language-specific time unit mappings
724
+ * @param options - Configuration options
725
+ * @returns Token if number found, null otherwise
726
+ */
727
+ tryNumberWithTimeUnits(input, pos, nativeTimeUnits, options = {}) {
728
+ const { allowSign = true, skipWhitespace = false } = options;
729
+ const baseResult = this.parseBaseNumber(input, pos, allowSign);
730
+ if (!baseResult) return null;
731
+ let { number, endPos } = baseResult;
732
+ const allUnits = [...nativeTimeUnits, ..._BaseTokenizer.STANDARD_TIME_UNITS];
733
+ const timeMatch = this.tryMatchTimeUnit(input, endPos, allUnits, skipWhitespace);
734
+ if (timeMatch) {
735
+ number += timeMatch.suffix;
736
+ endPos = timeMatch.endPos;
737
+ }
738
+ return createToken(number, "literal", createPosition(pos, endPos));
739
+ }
740
+ /**
741
+ * Try to extract a URL at the current position.
742
+ * Handles /path, ./path, ../path, //domain.com, http://, https://
743
+ */
744
+ tryUrl(input, pos) {
745
+ const url = extractUrl(input, pos);
746
+ if (url) {
747
+ return createToken(url, "url", createPosition(pos, pos + url.length));
748
+ }
749
+ return null;
750
+ }
751
+ /**
752
+ * Try to extract a variable reference (:varname) at the current position.
753
+ * In hyperscript, :x refers to a local variable named x.
754
+ */
755
+ tryVariableRef(input, pos) {
756
+ if (input[pos] !== ":") return null;
757
+ if (pos + 1 >= input.length) return null;
758
+ if (!isAsciiIdentifierChar(input[pos + 1])) return null;
759
+ let endPos = pos + 1;
760
+ while (endPos < input.length && isAsciiIdentifierChar(input[endPos])) {
761
+ endPos++;
762
+ }
763
+ const varRef = input.slice(pos, endPos);
764
+ return createToken(varRef, "identifier", createPosition(pos, endPos));
765
+ }
766
+ /**
767
+ * Try to extract an operator or punctuation token at the current position.
768
+ * Handles two-character operators (==, !=, etc.) and single-character operators.
769
+ */
770
+ tryOperator(input, pos) {
771
+ const twoChar = input.slice(pos, pos + 2);
772
+ if (["==", "!=", "<=", ">=", "&&", "||", "->"].includes(twoChar)) {
773
+ return createToken(twoChar, "operator", createPosition(pos, pos + 2));
774
+ }
775
+ const oneChar = input[pos];
776
+ if (["<", ">", "!", "+", "-", "*", "/", "="].includes(oneChar)) {
777
+ return createToken(oneChar, "operator", createPosition(pos, pos + 1));
778
+ }
779
+ if (["(", ")", "{", "}", ",", ";", ":"].includes(oneChar)) {
780
+ return createToken(oneChar, "punctuation", createPosition(pos, pos + 1));
781
+ }
782
+ return null;
783
+ }
784
+ /**
785
+ * Try to match a multi-character particle from a list.
786
+ *
787
+ * Used by languages like Japanese, Korean, and Chinese that have
788
+ * multi-character particles (e.g., Japanese から, まで, より).
789
+ *
790
+ * @param input - Input string
791
+ * @param pos - Current position
792
+ * @param particles - Array of multi-character particles to match
793
+ * @returns Token if matched, null otherwise
794
+ */
795
+ tryMultiCharParticle(input, pos, particles) {
796
+ for (const particle of particles) {
797
+ if (input.slice(pos, pos + particle.length) === particle) {
798
+ return createToken(particle, "particle", createPosition(pos, pos + particle.length));
799
+ }
800
+ }
801
+ return null;
802
+ }
803
+ };
804
+ /**
805
+ * Configuration for native language time units.
806
+ * Maps patterns to their standard suffix (ms, s, m, h).
807
+ */
808
+ _BaseTokenizer.STANDARD_TIME_UNITS = [
809
+ { pattern: "ms", suffix: "ms", length: 2 },
810
+ { pattern: "s", suffix: "s", length: 1, checkBoundary: true },
811
+ { pattern: "m", suffix: "m", length: 1, checkBoundary: true, notFollowedBy: "s" },
812
+ { pattern: "h", suffix: "h", length: 1, checkBoundary: true }
813
+ ];
814
+ var BaseTokenizer = _BaseTokenizer;
815
+
816
+ // src/tokenizers/morphology/types.ts
817
+ function noChange(word) {
818
+ return { stem: word, confidence: 1 };
819
+ }
820
+ function normalized(stem, confidence, metadata) {
821
+ if (metadata) {
822
+ return { stem, confidence, metadata };
823
+ }
824
+ return { stem, confidence };
825
+ }
826
+
827
+ // src/tokenizers/morphology/italian-normalizer.ts
828
+ function isItalianSpecificLetter(char) {
829
+ return /[àèéìíîòóùúÀÈÉÌÍÎÒÓÙÚ]/.test(char);
830
+ }
831
+ function looksLikeItalianVerb(word) {
832
+ const lower = word.toLowerCase();
833
+ if (lower.endsWith("are") || lower.endsWith("ere") || lower.endsWith("ire")) return true;
834
+ if (lower.endsWith("ando") || lower.endsWith("endo")) return true;
835
+ if (lower.endsWith("ato") || lower.endsWith("uto") || lower.endsWith("ito")) return true;
836
+ if (lower.endsWith("arsi") || lower.endsWith("ersi") || lower.endsWith("irsi")) return true;
837
+ for (const char of word) {
838
+ if (isItalianSpecificLetter(char)) return true;
839
+ }
840
+ return false;
841
+ }
842
+ var REFLEXIVE_SUFFIXES = ["si", "mi", "ti", "ci", "vi"];
843
+ var ARE_ENDINGS = [
844
+ // Gerund (-ando)
845
+ { ending: "ando", stem: "are", confidence: 0.88, type: "gerund" },
846
+ // Past participle (-ato)
847
+ { ending: "ato", stem: "are", confidence: 0.88, type: "participle" },
848
+ { ending: "ata", stem: "are", confidence: 0.88, type: "participle" },
849
+ { ending: "ati", stem: "are", confidence: 0.88, type: "participle" },
850
+ { ending: "ate", stem: "are", confidence: 0.88, type: "participle" },
851
+ // Present indicative
852
+ { ending: "o", stem: "are", confidence: 0.75, type: "present" },
853
+ // io
854
+ { ending: "i", stem: "are", confidence: 0.72, type: "present" },
855
+ // tu
856
+ { ending: "a", stem: "are", confidence: 0.75, type: "present" },
857
+ // lui/lei
858
+ { ending: "iamo", stem: "are", confidence: 0.85, type: "present" },
859
+ // noi
860
+ { ending: "ate", stem: "are", confidence: 0.85, type: "present" },
861
+ // voi
862
+ { ending: "ano", stem: "are", confidence: 0.85, type: "present" },
863
+ // loro
864
+ // Imperfect
865
+ { ending: "avo", stem: "are", confidence: 0.88, type: "past" },
866
+ // io
867
+ { ending: "avi", stem: "are", confidence: 0.88, type: "past" },
868
+ // tu
869
+ { ending: "ava", stem: "are", confidence: 0.88, type: "past" },
870
+ // lui/lei
871
+ { ending: "avamo", stem: "are", confidence: 0.88, type: "past" },
872
+ // noi
873
+ { ending: "avate", stem: "are", confidence: 0.88, type: "past" },
874
+ // voi
875
+ { ending: "avano", stem: "are", confidence: 0.88, type: "past" },
876
+ // loro
877
+ // Preterite (passato remoto)
878
+ { ending: "ai", stem: "are", confidence: 0.85, type: "past" },
879
+ // io
880
+ { ending: "asti", stem: "are", confidence: 0.88, type: "past" },
881
+ // tu
882
+ { ending: "\xF2", stem: "are", confidence: 0.85, type: "past" },
883
+ // lui/lei
884
+ { ending: "ammo", stem: "are", confidence: 0.88, type: "past" },
885
+ // noi
886
+ { ending: "aste", stem: "are", confidence: 0.88, type: "past" },
887
+ // voi
888
+ { ending: "arono", stem: "are", confidence: 0.88, type: "past" },
889
+ // loro
890
+ // Subjunctive present
891
+ { ending: "i", stem: "are", confidence: 0.72, type: "subjunctive" },
892
+ // io/tu/lui (ambiguous)
893
+ { ending: "ino", stem: "are", confidence: 0.82, type: "subjunctive" },
894
+ // loro
895
+ // Imperative
896
+ { ending: "a", stem: "are", confidence: 0.75, type: "imperative" },
897
+ // tu
898
+ // Infinitive
899
+ { ending: "are", stem: "are", confidence: 0.92, type: "dictionary" }
900
+ ];
901
+ var ERE_ENDINGS = [
902
+ // Gerund (-endo)
903
+ { ending: "endo", stem: "ere", confidence: 0.88, type: "gerund" },
904
+ // Past participle (-uto)
905
+ { ending: "uto", stem: "ere", confidence: 0.85, type: "participle" },
906
+ { ending: "uta", stem: "ere", confidence: 0.85, type: "participle" },
907
+ { ending: "uti", stem: "ere", confidence: 0.85, type: "participle" },
908
+ { ending: "ute", stem: "ere", confidence: 0.85, type: "participle" },
909
+ // Present indicative
910
+ { ending: "o", stem: "ere", confidence: 0.72, type: "present" },
911
+ // io
912
+ { ending: "i", stem: "ere", confidence: 0.72, type: "present" },
913
+ // tu
914
+ { ending: "e", stem: "ere", confidence: 0.72, type: "present" },
915
+ // lui/lei
916
+ { ending: "iamo", stem: "ere", confidence: 0.85, type: "present" },
917
+ // noi
918
+ { ending: "ete", stem: "ere", confidence: 0.85, type: "present" },
919
+ // voi
920
+ { ending: "ono", stem: "ere", confidence: 0.82, type: "present" },
921
+ // loro
922
+ // Imperfect
923
+ { ending: "evo", stem: "ere", confidence: 0.88, type: "past" },
924
+ // io
925
+ { ending: "evi", stem: "ere", confidence: 0.88, type: "past" },
926
+ // tu
927
+ { ending: "eva", stem: "ere", confidence: 0.88, type: "past" },
928
+ // lui/lei
929
+ { ending: "evamo", stem: "ere", confidence: 0.88, type: "past" },
930
+ // noi
931
+ { ending: "evate", stem: "ere", confidence: 0.88, type: "past" },
932
+ // voi
933
+ { ending: "evano", stem: "ere", confidence: 0.88, type: "past" },
934
+ // loro
935
+ // Preterite
936
+ { ending: "ei", stem: "ere", confidence: 0.85, type: "past" },
937
+ // io
938
+ { ending: "etti", stem: "ere", confidence: 0.85, type: "past" },
939
+ // io (variant)
940
+ { ending: "esti", stem: "ere", confidence: 0.88, type: "past" },
941
+ // tu
942
+ { ending: "\xE9", stem: "ere", confidence: 0.85, type: "past" },
943
+ // lui/lei
944
+ { ending: "ette", stem: "ere", confidence: 0.85, type: "past" },
945
+ // lui/lei (variant)
946
+ { ending: "emmo", stem: "ere", confidence: 0.88, type: "past" },
947
+ // noi
948
+ { ending: "este", stem: "ere", confidence: 0.88, type: "past" },
949
+ // voi
950
+ { ending: "erono", stem: "ere", confidence: 0.88, type: "past" },
951
+ // loro
952
+ { ending: "ettero", stem: "ere", confidence: 0.88, type: "past" },
953
+ // loro (variant)
954
+ // Infinitive
955
+ { ending: "ere", stem: "ere", confidence: 0.92, type: "dictionary" }
956
+ ];
957
+ var IRE_ENDINGS = [
958
+ // Gerund (-endo)
959
+ { ending: "endo", stem: "ire", confidence: 0.85, type: "gerund" },
960
+ // Past participle (-ito)
961
+ { ending: "ito", stem: "ire", confidence: 0.85, type: "participle" },
962
+ { ending: "ita", stem: "ire", confidence: 0.85, type: "participle" },
963
+ { ending: "iti", stem: "ire", confidence: 0.85, type: "participle" },
964
+ { ending: "ite", stem: "ire", confidence: 0.85, type: "participle" },
965
+ // Present indicative (standard)
966
+ { ending: "o", stem: "ire", confidence: 0.7, type: "present" },
967
+ // io
968
+ { ending: "i", stem: "ire", confidence: 0.7, type: "present" },
969
+ // tu
970
+ { ending: "e", stem: "ire", confidence: 0.7, type: "present" },
971
+ // lui/lei
972
+ { ending: "iamo", stem: "ire", confidence: 0.85, type: "present" },
973
+ // noi
974
+ { ending: "ite", stem: "ire", confidence: 0.85, type: "present" },
975
+ // voi
976
+ { ending: "ono", stem: "ire", confidence: 0.78, type: "present" },
977
+ // loro
978
+ // Present indicative (-isco verbs)
979
+ { ending: "isco", stem: "ire", confidence: 0.85, type: "present" },
980
+ // io
981
+ { ending: "isci", stem: "ire", confidence: 0.85, type: "present" },
982
+ // tu
983
+ { ending: "isce", stem: "ire", confidence: 0.85, type: "present" },
984
+ // lui/lei
985
+ { ending: "iscono", stem: "ire", confidence: 0.88, type: "present" },
986
+ // loro
987
+ // Imperfect
988
+ { ending: "ivo", stem: "ire", confidence: 0.88, type: "past" },
989
+ // io
990
+ { ending: "ivi", stem: "ire", confidence: 0.88, type: "past" },
991
+ // tu
992
+ { ending: "iva", stem: "ire", confidence: 0.88, type: "past" },
993
+ // lui/lei
994
+ { ending: "ivamo", stem: "ire", confidence: 0.88, type: "past" },
995
+ // noi
996
+ { ending: "ivate", stem: "ire", confidence: 0.88, type: "past" },
997
+ // voi
998
+ { ending: "ivano", stem: "ire", confidence: 0.88, type: "past" },
999
+ // loro
1000
+ // Preterite
1001
+ { ending: "ii", stem: "ire", confidence: 0.85, type: "past" },
1002
+ // io
1003
+ { ending: "isti", stem: "ire", confidence: 0.88, type: "past" },
1004
+ // tu
1005
+ { ending: "\xEC", stem: "ire", confidence: 0.85, type: "past" },
1006
+ // lui/lei
1007
+ { ending: "immo", stem: "ire", confidence: 0.88, type: "past" },
1008
+ // noi
1009
+ { ending: "iste", stem: "ire", confidence: 0.88, type: "past" },
1010
+ // voi
1011
+ { ending: "irono", stem: "ire", confidence: 0.88, type: "past" },
1012
+ // loro
1013
+ // Infinitive
1014
+ { ending: "ire", stem: "ire", confidence: 0.92, type: "dictionary" }
1015
+ ];
1016
+ var ALL_ENDINGS = [...ARE_ENDINGS, ...ERE_ENDINGS, ...IRE_ENDINGS].sort(
1017
+ (a, b) => b.ending.length - a.ending.length
1018
+ );
1019
+ var ItalianMorphologicalNormalizer = class {
1020
+ constructor() {
1021
+ this.language = "it";
1022
+ }
1023
+ /**
1024
+ * Check if a word might be an Italian verb that can be normalized.
1025
+ */
1026
+ isNormalizable(word) {
1027
+ if (word.length < 3) return false;
1028
+ return looksLikeItalianVerb(word);
1029
+ }
1030
+ /**
1031
+ * Normalize an Italian word to its infinitive form.
1032
+ */
1033
+ normalize(word) {
1034
+ const lower = word.toLowerCase();
1035
+ if (lower.endsWith("are") || lower.endsWith("ere") || lower.endsWith("ire")) {
1036
+ if (!REFLEXIVE_SUFFIXES.some(
1037
+ (s) => lower.endsWith(s + "are") || lower.endsWith(s + "ere") || lower.endsWith(s + "ire")
1038
+ )) {
1039
+ return noChange(word);
1040
+ }
1041
+ }
1042
+ const reflexiveResult = this.tryReflexiveNormalization(lower);
1043
+ if (reflexiveResult) return reflexiveResult;
1044
+ const conjugationResult = this.tryConjugationNormalization(lower);
1045
+ if (conjugationResult) return conjugationResult;
1046
+ return noChange(word);
1047
+ }
1048
+ /**
1049
+ * Try to normalize a reflexive verb.
1050
+ * Reflexive verbs end with -si, -mi, -ti, -ci, -vi attached to infinitive.
1051
+ *
1052
+ * In Italian, reflexive infinitives drop the final -e before attaching the pronoun:
1053
+ * mostrare + si → mostrarsi (not mostraresi)
1054
+ * nascondere + si → nascondersi
1055
+ *
1056
+ * Examples:
1057
+ * mostrarsi → mostrare
1058
+ * nascondersi → nascondere
1059
+ */
1060
+ tryReflexiveNormalization(word) {
1061
+ for (const suffix of REFLEXIVE_SUFFIXES) {
1062
+ if (word.endsWith(suffix)) {
1063
+ const withoutReflexive = word.slice(0, -suffix.length);
1064
+ if (withoutReflexive.endsWith("ar") || withoutReflexive.endsWith("er") || withoutReflexive.endsWith("ir")) {
1065
+ const infinitive = withoutReflexive + "e";
1066
+ return normalized(infinitive, 0.88, {
1067
+ removedSuffixes: [suffix],
1068
+ conjugationType: "reflexive"
1069
+ });
1070
+ }
1071
+ if (withoutReflexive.endsWith("are") || withoutReflexive.endsWith("ere") || withoutReflexive.endsWith("ire")) {
1072
+ return normalized(withoutReflexive, 0.88, {
1073
+ removedSuffixes: [suffix],
1074
+ conjugationType: "reflexive"
1075
+ });
1076
+ }
1077
+ const innerResult = this.tryConjugationNormalization(withoutReflexive);
1078
+ if (innerResult && innerResult.stem !== withoutReflexive) {
1079
+ return normalized(innerResult.stem, innerResult.confidence * 0.95, {
1080
+ removedSuffixes: [suffix, ...innerResult.metadata?.removedSuffixes || []],
1081
+ conjugationType: "reflexive"
1082
+ });
1083
+ }
1084
+ }
1085
+ }
1086
+ return null;
1087
+ }
1088
+ /**
1089
+ * Try to normalize a conjugated verb to its infinitive.
1090
+ */
1091
+ tryConjugationNormalization(word) {
1092
+ for (const rule of ALL_ENDINGS) {
1093
+ if (word.endsWith(rule.ending)) {
1094
+ const stemBase = word.slice(0, -rule.ending.length);
1095
+ if (stemBase.length < 2) continue;
1096
+ const infinitive = stemBase + rule.stem;
1097
+ return normalized(infinitive, rule.confidence, {
1098
+ removedSuffixes: [rule.ending],
1099
+ conjugationType: rule.type
1100
+ });
1101
+ }
1102
+ }
1103
+ return null;
1104
+ }
1105
+ };
1106
+ var italianMorphologicalNormalizer = new ItalianMorphologicalNormalizer();
1107
+
1108
+ // src/generators/profiles/italian.ts
1109
+ var italianProfile = {
1110
+ code: "it",
1111
+ name: "Italian",
1112
+ nativeName: "Italiano",
1113
+ direction: "ltr",
1114
+ wordOrder: "SVO",
1115
+ markingStrategy: "preposition",
1116
+ usesSpaces: true,
1117
+ // Infinitive is standard for Italian software UI (Salvare, Annullare, Aprire)
1118
+ // This matches macOS, Windows, and web app conventions
1119
+ defaultVerbForm: "infinitive",
1120
+ verb: {
1121
+ position: "start",
1122
+ subjectDrop: true
1123
+ },
1124
+ references: {
1125
+ me: "io",
1126
+ // "I/me"
1127
+ it: "esso",
1128
+ // "it"
1129
+ you: "tu",
1130
+ // "you"
1131
+ result: "risultato",
1132
+ event: "evento",
1133
+ target: "obiettivo",
1134
+ body: "corpo"
1135
+ },
1136
+ possessive: {
1137
+ marker: "di",
1138
+ // Italian uses "di" for general possession
1139
+ markerPosition: "before-property",
1140
+ usePossessiveAdjectives: true,
1141
+ specialForms: {
1142
+ me: "mio",
1143
+ // "my" (possessive adjective)
1144
+ it: "suo",
1145
+ // "its"
1146
+ you: "tuo"
1147
+ // "your"
1148
+ },
1149
+ keywords: {
1150
+ // "my" variants (masculine/feminine singular/plural)
1151
+ mio: "me",
1152
+ mia: "me",
1153
+ miei: "me",
1154
+ mie: "me",
1155
+ // "your" variants
1156
+ tuo: "you",
1157
+ tua: "you",
1158
+ tuoi: "you",
1159
+ tue: "you",
1160
+ // "its/his/her" variants
1161
+ suo: "it",
1162
+ sua: "it",
1163
+ suoi: "it",
1164
+ sue: "it"
1165
+ }
1166
+ },
1167
+ roleMarkers: {
1168
+ destination: { primary: "in", alternatives: ["su", "a"], position: "before" },
1169
+ source: { primary: "da", alternatives: ["di"], position: "before" },
1170
+ patient: { primary: "", position: "before" },
1171
+ style: { primary: "con", position: "before" }
1172
+ },
1173
+ keywords: {
1174
+ // Class/Attribute operations
1175
+ toggle: { primary: "commutare", alternatives: ["alternare", "cambiare"], normalized: "toggle" },
1176
+ add: { primary: "aggiungere", alternatives: ["aggiungi"], normalized: "add" },
1177
+ remove: { primary: "rimuovere", alternatives: ["eliminare", "togliere"], normalized: "remove" },
1178
+ // Content operations
1179
+ put: { primary: "mettere", alternatives: ["inserire"], normalized: "put" },
1180
+ append: { primary: "aggiungere", normalized: "append" },
1181
+ prepend: { primary: "anteporre", normalized: "prepend" },
1182
+ take: { primary: "prendere", normalized: "take" },
1183
+ make: { primary: "fare", alternatives: ["creare"], normalized: "make" },
1184
+ clone: { primary: "clonare", alternatives: ["copiare"], normalized: "clone" },
1185
+ swap: { primary: "scambiare", alternatives: ["cambiare"], normalized: "swap" },
1186
+ morph: { primary: "trasformare", alternatives: ["convertire"], normalized: "morph" },
1187
+ // Variable operations
1188
+ set: { primary: "impostare", alternatives: ["definire"], normalized: "set" },
1189
+ get: { primary: "ottenere", alternatives: ["prendere"], normalized: "get" },
1190
+ increment: { primary: "incrementare", alternatives: ["aumentare"], normalized: "increment" },
1191
+ decrement: { primary: "decrementare", alternatives: ["diminuire"], normalized: "decrement" },
1192
+ log: { primary: "registrare", normalized: "log" },
1193
+ // Visibility
1194
+ show: { primary: "mostrare", alternatives: ["visualizzare"], normalized: "show" },
1195
+ hide: { primary: "nascondere", normalized: "hide" },
1196
+ transition: { primary: "transizione", alternatives: ["animare"], normalized: "transition" },
1197
+ // Events
1198
+ on: { primary: "su", alternatives: ["quando", "al"], normalized: "on" },
1199
+ trigger: { primary: "scatenare", alternatives: ["attivare"], normalized: "trigger" },
1200
+ send: { primary: "inviare", normalized: "send" },
1201
+ // DOM focus
1202
+ focus: { primary: "focalizzare", normalized: "focus" },
1203
+ blur: { primary: "sfuocare", normalized: "blur" },
1204
+ // Navigation
1205
+ go: { primary: "andare", alternatives: ["navigare", "vai"], normalized: "go" },
1206
+ // Async
1207
+ wait: { primary: "aspettare", alternatives: ["attendere"], normalized: "wait" },
1208
+ fetch: { primary: "recuperare", normalized: "fetch" },
1209
+ settle: { primary: "stabilizzare", normalized: "settle" },
1210
+ // Control flow
1211
+ if: { primary: "se", normalized: "if" },
1212
+ when: { primary: "quando", normalized: "when" },
1213
+ where: { primary: "dove", normalized: "where" },
1214
+ else: { primary: "altrimenti", normalized: "else" },
1215
+ repeat: { primary: "ripetere", normalized: "repeat" },
1216
+ for: { primary: "per", normalized: "for" },
1217
+ while: { primary: "mentre", normalized: "while" },
1218
+ continue: { primary: "continuare", normalized: "continue" },
1219
+ halt: { primary: "fermare", normalized: "halt" },
1220
+ throw: { primary: "lanciare", normalized: "throw" },
1221
+ call: { primary: "chiamare", normalized: "call" },
1222
+ return: { primary: "ritornare", normalized: "return" },
1223
+ then: { primary: "allora", alternatives: ["poi", "quindi"], normalized: "then" },
1224
+ and: { primary: "e", alternatives: ["anche"], normalized: "and" },
1225
+ end: { primary: "fine", normalized: "end" },
1226
+ // Advanced
1227
+ js: { primary: "js", normalized: "js" },
1228
+ async: { primary: "asincrono", normalized: "async" },
1229
+ tell: { primary: "dire", normalized: "tell" },
1230
+ default: { primary: "predefinito", normalized: "default" },
1231
+ init: { primary: "inizializzare", alternatives: ["inizia"], normalized: "init" },
1232
+ behavior: { primary: "comportamento", normalized: "behavior" },
1233
+ install: { primary: "installare", normalized: "install" },
1234
+ measure: { primary: "misurare", normalized: "measure" },
1235
+ beep: { primary: "beep", normalized: "beep" },
1236
+ break: { primary: "interrompere", normalized: "break" },
1237
+ copy: { primary: "copiare", normalized: "copy" },
1238
+ exit: { primary: "uscire", normalized: "exit" },
1239
+ pick: { primary: "scegliere", normalized: "pick" },
1240
+ render: { primary: "renderizzare", normalized: "render" },
1241
+ // Modifiers
1242
+ into: { primary: "in", alternatives: ["dentro"], normalized: "into" },
1243
+ before: { primary: "prima", normalized: "before" },
1244
+ after: { primary: "dopo", normalized: "after" },
1245
+ // Common event names (for event handler patterns)
1246
+ click: { primary: "clic", alternatives: ["clicca"], normalized: "click" },
1247
+ hover: { primary: "passaggio", alternatives: ["sorvolo"], normalized: "hover" },
1248
+ submit: { primary: "invio", alternatives: ["inviare"], normalized: "submit" },
1249
+ input: { primary: "inserimento", alternatives: ["input"], normalized: "input" },
1250
+ change: { primary: "cambio", alternatives: ["cambiamento"], normalized: "change" },
1251
+ // Event modifiers
1252
+ until: { primary: "fino", normalized: "until" },
1253
+ event: { primary: "evento", normalized: "event" },
1254
+ from: { primary: "da", alternatives: ["di"], normalized: "from" }
1255
+ },
1256
+ eventHandler: {
1257
+ keyword: { primary: "su", alternatives: ["al", "quando"], normalized: "on" },
1258
+ sourceMarker: { primary: "da", alternatives: ["di"], position: "before" },
1259
+ conditionalKeyword: { primary: "quando", alternatives: ["se"] },
1260
+ // Event marker: al (at/upon), used in SVO pattern
1261
+ // Pattern: al [event] [verb] [patient] su [destination?]
1262
+ // Example: al clic commutare .active su #button
1263
+ eventMarker: { primary: "al", alternatives: ["allo", "alla"], position: "before" },
1264
+ temporalMarkers: ["quando", "al"]
1265
+ // temporal conjunctions (when)
1266
+ }
1267
+ };
1268
+
1269
+ // src/tokenizers/italian.ts
1270
+ var { isLetter: isItalianLetter, isIdentifierChar: isItalianIdentifierChar } = createLatinCharClassifiers(/[a-zA-ZàèéìíîòóùúÀÈÉÌÍÎÒÓÙÚ]/);
1271
+ var ITALIAN_TIME_UNITS = [
1272
+ { pattern: "millisecondi", suffix: "ms", length: 12, caseInsensitive: true },
1273
+ { pattern: "millisecondo", suffix: "ms", length: 12, caseInsensitive: true },
1274
+ { pattern: "secondi", suffix: "s", length: 7, caseInsensitive: true },
1275
+ { pattern: "secondo", suffix: "s", length: 7, caseInsensitive: true },
1276
+ { pattern: "minuti", suffix: "m", length: 6, caseInsensitive: true },
1277
+ { pattern: "minuto", suffix: "m", length: 6, caseInsensitive: true },
1278
+ { pattern: "ore", suffix: "h", length: 3, caseInsensitive: true },
1279
+ { pattern: "ora", suffix: "h", length: 3, caseInsensitive: true }
1280
+ ];
1281
+ var PREPOSITIONS = /* @__PURE__ */ new Set([
1282
+ "in",
1283
+ // in, into
1284
+ "a",
1285
+ // to, at
1286
+ "di",
1287
+ // of, from
1288
+ "da",
1289
+ // from, by
1290
+ "con",
1291
+ // with
1292
+ "su",
1293
+ // on
1294
+ "per",
1295
+ // for
1296
+ "tra",
1297
+ // between
1298
+ "fra",
1299
+ // between (variant)
1300
+ "dopo",
1301
+ // after
1302
+ "prima",
1303
+ // before
1304
+ "dentro",
1305
+ // inside
1306
+ "fuori",
1307
+ // outside
1308
+ "sopra",
1309
+ // above
1310
+ "sotto",
1311
+ // under
1312
+ // Articulated prepositions
1313
+ "al",
1314
+ // a + il
1315
+ "allo",
1316
+ // a + lo
1317
+ "alla",
1318
+ // a + la
1319
+ "ai",
1320
+ // a + i
1321
+ "agli",
1322
+ // a + gli
1323
+ "alle",
1324
+ // a + le
1325
+ "del",
1326
+ // di + il
1327
+ "dello",
1328
+ // di + lo
1329
+ "della",
1330
+ // di + la
1331
+ "dei",
1332
+ // di + i
1333
+ "degli",
1334
+ // di + gli
1335
+ "delle",
1336
+ // di + le
1337
+ "dal",
1338
+ // da + il
1339
+ "dallo",
1340
+ // da + lo
1341
+ "dalla",
1342
+ // da + la
1343
+ "dai",
1344
+ // da + i
1345
+ "dagli",
1346
+ // da + gli
1347
+ "dalle",
1348
+ // da + le
1349
+ "nel",
1350
+ // in + il
1351
+ "nello",
1352
+ // in + lo
1353
+ "nella",
1354
+ // in + la
1355
+ "nei",
1356
+ // in + i
1357
+ "negli",
1358
+ // in + gli
1359
+ "nelle",
1360
+ // in + le
1361
+ "sul",
1362
+ // su + il
1363
+ "sullo",
1364
+ // su + lo
1365
+ "sulla",
1366
+ // su + la
1367
+ "sui",
1368
+ // su + i
1369
+ "sugli",
1370
+ // su + gli
1371
+ "sulle"
1372
+ // su + le
1373
+ ]);
1374
+ var ITALIAN_EXTRAS = [
1375
+ // Values/Literals
1376
+ { native: "vero", normalized: "true" },
1377
+ { native: "falso", normalized: "false" },
1378
+ { native: "nullo", normalized: "null" },
1379
+ { native: "indefinito", normalized: "undefined" },
1380
+ // Positional
1381
+ { native: "primo", normalized: "first" },
1382
+ { native: "prima", normalized: "first" },
1383
+ { native: "ultimo", normalized: "last" },
1384
+ { native: "ultima", normalized: "last" },
1385
+ { native: "prossimo", normalized: "next" },
1386
+ { native: "successivo", normalized: "next" },
1387
+ { native: "precedente", normalized: "previous" },
1388
+ { native: "vicino", normalized: "closest" },
1389
+ { native: "padre", normalized: "parent" },
1390
+ // Events
1391
+ { native: "clic", normalized: "click" },
1392
+ { native: "click", normalized: "click" },
1393
+ { native: "fare clic", normalized: "click" },
1394
+ { native: "input", normalized: "input" },
1395
+ { native: "cambio", normalized: "change" },
1396
+ { native: "invio", normalized: "submit" },
1397
+ { native: "tasto gi\xF9", normalized: "keydown" },
1398
+ { native: "tasto su", normalized: "keyup" },
1399
+ { native: "mouse sopra", normalized: "mouseover" },
1400
+ { native: "mouse fuori", normalized: "mouseout" },
1401
+ { native: "fuoco", normalized: "focus" },
1402
+ { native: "sfuocatura", normalized: "blur" },
1403
+ { native: "caricamento", normalized: "load" },
1404
+ { native: "scorrimento", normalized: "scroll" },
1405
+ // References
1406
+ { native: "io", normalized: "me" },
1407
+ { native: "me", normalized: "me" },
1408
+ { native: "destinazione", normalized: "target" },
1409
+ // Time units
1410
+ { native: "secondo", normalized: "s" },
1411
+ { native: "secondi", normalized: "s" },
1412
+ { native: "millisecondo", normalized: "ms" },
1413
+ { native: "millisecondi", normalized: "ms" },
1414
+ { native: "minuto", normalized: "m" },
1415
+ { native: "minuti", normalized: "m" },
1416
+ { native: "ora", normalized: "h" },
1417
+ { native: "ore", normalized: "h" },
1418
+ // Multi-word phrases
1419
+ { native: "fino a", normalized: "until" },
1420
+ { native: "prima di", normalized: "before" },
1421
+ { native: "dopo di", normalized: "after" },
1422
+ { native: "dentro di", normalized: "into" },
1423
+ { native: "fuori di", normalized: "out" },
1424
+ // Override profile conflicts (aggiungere is both add and append in profile, prefer add)
1425
+ { native: "aggiungere", normalized: "add" },
1426
+ // Imperative forms (profile has infinitives)
1427
+ { native: "aggiungi", normalized: "add" },
1428
+ { native: "rimuovi", normalized: "remove" },
1429
+ { native: "elimina", normalized: "remove" },
1430
+ { native: "togli", normalized: "remove" },
1431
+ { native: "metti", normalized: "put" },
1432
+ { native: "inserisci", normalized: "put" },
1433
+ { native: "prendi", normalized: "take" },
1434
+ { native: "fai", normalized: "make" },
1435
+ { native: "crea", normalized: "make" },
1436
+ { native: "clona", normalized: "clone" },
1437
+ { native: "copia", normalized: "clone" },
1438
+ { native: "imposta", normalized: "set" },
1439
+ { native: "ottieni", normalized: "get" },
1440
+ { native: "incrementa", normalized: "increment" },
1441
+ { native: "aumenta", normalized: "increment" },
1442
+ { native: "decrementa", normalized: "decrement" },
1443
+ { native: "diminuisci", normalized: "decrement" },
1444
+ { native: "registra", normalized: "log" },
1445
+ { native: "mostra", normalized: "show" },
1446
+ { native: "visualizza", normalized: "show" },
1447
+ { native: "nascondi", normalized: "hide" },
1448
+ { native: "anima", normalized: "transition" },
1449
+ { native: "scatena", normalized: "trigger" },
1450
+ { native: "attiva", normalized: "trigger" },
1451
+ { native: "invia", normalized: "send" },
1452
+ { native: "focalizza", normalized: "focus" },
1453
+ { native: "sfuoca", normalized: "blur" },
1454
+ { native: "vai", normalized: "go" },
1455
+ { native: "naviga", normalized: "go" },
1456
+ { native: "aspetta", normalized: "wait" },
1457
+ { native: "attendi", normalized: "wait" },
1458
+ { native: "recupera", normalized: "fetch" },
1459
+ { native: "stabilizza", normalized: "settle" },
1460
+ { native: "ripeti", normalized: "repeat" },
1461
+ { native: "continua", normalized: "continue" },
1462
+ { native: "ferma", normalized: "halt" },
1463
+ { native: "lancia", normalized: "throw" },
1464
+ { native: "chiama", normalized: "call" },
1465
+ { native: "ritorna", normalized: "return" },
1466
+ { native: "inizializza", normalized: "init" },
1467
+ { native: "installa", normalized: "install" },
1468
+ { native: "misura", normalized: "measure" },
1469
+ // Logical/conditional
1470
+ { native: "e", normalized: "and" },
1471
+ { native: "o", normalized: "or" },
1472
+ { native: "non", normalized: "not" },
1473
+ { native: "\xE8", normalized: "is" },
1474
+ { native: "esiste", normalized: "exists" },
1475
+ { native: "vuoto", normalized: "empty" },
1476
+ // Synonyms not in profile
1477
+ { native: "toggle", normalized: "toggle" },
1478
+ { native: "di", normalized: "tell" }
1479
+ ];
1480
+ var ItalianTokenizer = class extends BaseTokenizer {
1481
+ constructor() {
1482
+ super();
1483
+ this.language = "it";
1484
+ this.direction = "ltr";
1485
+ this.initializeKeywordsFromProfile(italianProfile, ITALIAN_EXTRAS);
1486
+ this.normalizer = new ItalianMorphologicalNormalizer();
1487
+ }
1488
+ tokenize(input) {
1489
+ const tokens = [];
1490
+ let pos = 0;
1491
+ while (pos < input.length) {
1492
+ if (isWhitespace(input[pos])) {
1493
+ pos++;
1494
+ continue;
1495
+ }
1496
+ if (isSelectorStart(input[pos])) {
1497
+ const modifierToken = this.tryEventModifier(input, pos);
1498
+ if (modifierToken) {
1499
+ tokens.push(modifierToken);
1500
+ pos = modifierToken.position.end;
1501
+ continue;
1502
+ }
1503
+ if (this.tryPropertyAccess(input, pos, tokens)) {
1504
+ pos++;
1505
+ continue;
1506
+ }
1507
+ const selectorToken = this.trySelector(input, pos);
1508
+ if (selectorToken) {
1509
+ tokens.push(selectorToken);
1510
+ pos = selectorToken.position.end;
1511
+ continue;
1512
+ }
1513
+ }
1514
+ if (isQuote(input[pos])) {
1515
+ const stringToken = this.tryString(input, pos);
1516
+ if (stringToken) {
1517
+ tokens.push(stringToken);
1518
+ pos = stringToken.position.end;
1519
+ continue;
1520
+ }
1521
+ }
1522
+ if (isUrlStart(input, pos)) {
1523
+ const urlToken = this.tryUrl(input, pos);
1524
+ if (urlToken) {
1525
+ tokens.push(urlToken);
1526
+ pos = urlToken.position.end;
1527
+ continue;
1528
+ }
1529
+ }
1530
+ if (isDigit(input[pos]) || input[pos] === "-" && pos + 1 < input.length && isDigit(input[pos + 1])) {
1531
+ const numberToken = this.extractItalianNumber(input, pos);
1532
+ if (numberToken) {
1533
+ tokens.push(numberToken);
1534
+ pos = numberToken.position.end;
1535
+ continue;
1536
+ }
1537
+ }
1538
+ const varToken = this.tryVariableRef(input, pos);
1539
+ if (varToken) {
1540
+ tokens.push(varToken);
1541
+ pos = varToken.position.end;
1542
+ continue;
1543
+ }
1544
+ const phraseToken = this.tryMultiWordPhrase(input, pos);
1545
+ if (phraseToken) {
1546
+ tokens.push(phraseToken);
1547
+ pos = phraseToken.position.end;
1548
+ continue;
1549
+ }
1550
+ if (isItalianLetter(input[pos])) {
1551
+ const wordToken = this.extractItalianWord(input, pos);
1552
+ if (wordToken) {
1553
+ tokens.push(wordToken);
1554
+ pos = wordToken.position.end;
1555
+ continue;
1556
+ }
1557
+ }
1558
+ const operatorToken = this.tryOperator(input, pos);
1559
+ if (operatorToken) {
1560
+ tokens.push(operatorToken);
1561
+ pos = operatorToken.position.end;
1562
+ continue;
1563
+ }
1564
+ pos++;
1565
+ }
1566
+ return new TokenStreamImpl(tokens, "it");
1567
+ }
1568
+ classifyToken(token) {
1569
+ const lower = token.toLowerCase();
1570
+ if (PREPOSITIONS.has(lower)) return "particle";
1571
+ if (this.isKeyword(lower)) return "keyword";
1572
+ if (token.startsWith("#") || token.startsWith(".") || token.startsWith("[") || token.startsWith("*") || token.startsWith("<"))
1573
+ return "selector";
1574
+ if (token.startsWith('"') || token.startsWith("'")) return "literal";
1575
+ if (/^\d/.test(token)) return "literal";
1576
+ if (["==", "!=", "<=", ">=", "<", ">", "&&", "||", "!"].includes(token)) return "operator";
1577
+ return "identifier";
1578
+ }
1579
+ /**
1580
+ * Try to match multi-word phrases that function as single units.
1581
+ * Multi-word phrases are included in profileKeywords and sorted longest-first,
1582
+ * so they'll be matched before their constituent words.
1583
+ */
1584
+ tryMultiWordPhrase(input, pos) {
1585
+ for (const entry of this.profileKeywords) {
1586
+ if (!entry.native.includes(" ")) continue;
1587
+ const phrase = entry.native;
1588
+ const candidate = input.slice(pos, pos + phrase.length).toLowerCase();
1589
+ if (candidate === phrase.toLowerCase()) {
1590
+ const nextPos = pos + phrase.length;
1591
+ if (nextPos >= input.length || isWhitespace(input[nextPos]) || !isItalianLetter(input[nextPos])) {
1592
+ return createToken(
1593
+ input.slice(pos, pos + phrase.length),
1594
+ "keyword",
1595
+ createPosition(pos, nextPos),
1596
+ entry.normalized
1597
+ );
1598
+ }
1599
+ }
1600
+ }
1601
+ return null;
1602
+ }
1603
+ /**
1604
+ * Extract an Italian word.
1605
+ *
1606
+ * Uses morphological normalization to handle:
1607
+ * - Reflexive verbs (mostrarsi → mostrare)
1608
+ * - Verb conjugations (alternando → alternare)
1609
+ */
1610
+ extractItalianWord(input, startPos) {
1611
+ let pos = startPos;
1612
+ let word = "";
1613
+ while (pos < input.length && isItalianIdentifierChar(input[pos])) {
1614
+ word += input[pos++];
1615
+ }
1616
+ if (!word) return null;
1617
+ const lower = word.toLowerCase();
1618
+ if (PREPOSITIONS.has(lower)) {
1619
+ return createToken(word, "particle", createPosition(startPos, pos));
1620
+ }
1621
+ const keywordEntry = this.lookupKeyword(lower);
1622
+ if (keywordEntry) {
1623
+ return createToken(word, "keyword", createPosition(startPos, pos), keywordEntry.normalized);
1624
+ }
1625
+ const morphToken = this.tryMorphKeywordMatch(lower, startPos, pos);
1626
+ if (morphToken) return morphToken;
1627
+ return createToken(word, "identifier", createPosition(startPos, pos));
1628
+ }
1629
+ /**
1630
+ * Extract a number, including Italian time unit suffixes.
1631
+ */
1632
+ extractItalianNumber(input, startPos) {
1633
+ return this.tryNumberWithTimeUnits(input, startPos, ITALIAN_TIME_UNITS, {
1634
+ allowSign: true,
1635
+ skipWhitespace: true
1636
+ });
1637
+ }
1638
+ };
1639
+ var italianTokenizer = new ItalianTokenizer();
1640
+
1641
+ // src/languages/it.ts
1642
+ registerLanguage("it", italianTokenizer, italianProfile);
1643
+ export {
1644
+ italianProfile,
1645
+ italianTokenizer
1646
+ };
1647
+ //# sourceMappingURL=it.js.map