@aster-cloud/aster-lang-ts 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1151) hide show
  1. package/README.md +144 -0
  2. package/dist/peg/headers-parser.js +1887 -0
  3. package/dist/scripts/aster.d.ts +3 -0
  4. package/dist/scripts/aster.d.ts.map +1 -0
  5. package/dist/scripts/aster.js +304 -0
  6. package/dist/scripts/aster.js.map +1 -0
  7. package/dist/scripts/build-example-packages.d.ts +3 -0
  8. package/dist/scripts/build-example-packages.d.ts.map +1 -0
  9. package/dist/scripts/build-example-packages.js +78 -0
  10. package/dist/scripts/build-example-packages.js.map +1 -0
  11. package/dist/scripts/build-peg.d.ts +3 -0
  12. package/dist/scripts/build-peg.d.ts.map +1 -0
  13. package/dist/scripts/build-peg.js +13 -0
  14. package/dist/scripts/build-peg.js.map +1 -0
  15. package/dist/scripts/cleanup-examples.d.ts +3 -0
  16. package/dist/scripts/cleanup-examples.d.ts.map +1 -0
  17. package/dist/scripts/cleanup-examples.js +40 -0
  18. package/dist/scripts/cleanup-examples.js.map +1 -0
  19. package/dist/scripts/clear-method-cache.d.ts +3 -0
  20. package/dist/scripts/clear-method-cache.d.ts.map +1 -0
  21. package/dist/scripts/clear-method-cache.js +20 -0
  22. package/dist/scripts/clear-method-cache.js.map +1 -0
  23. package/dist/scripts/cli.d.ts +3 -0
  24. package/dist/scripts/cli.d.ts.map +1 -0
  25. package/dist/scripts/cli.js +51 -0
  26. package/dist/scripts/cli.js.map +1 -0
  27. package/dist/scripts/determinism.d.ts +3 -0
  28. package/dist/scripts/determinism.d.ts.map +1 -0
  29. package/dist/scripts/determinism.js +124 -0
  30. package/dist/scripts/determinism.js.map +1 -0
  31. package/dist/scripts/emit-classfiles-core.d.ts +3 -0
  32. package/dist/scripts/emit-classfiles-core.d.ts.map +1 -0
  33. package/dist/scripts/emit-classfiles-core.js +86 -0
  34. package/dist/scripts/emit-classfiles-core.js.map +1 -0
  35. package/dist/scripts/emit-classfiles.d.ts +3 -0
  36. package/dist/scripts/emit-classfiles.d.ts.map +1 -0
  37. package/dist/scripts/emit-classfiles.js +401 -0
  38. package/dist/scripts/emit-classfiles.js.map +1 -0
  39. package/dist/scripts/emit-core.d.ts +3 -0
  40. package/dist/scripts/emit-core.d.ts.map +1 -0
  41. package/dist/scripts/emit-core.js +52 -0
  42. package/dist/scripts/emit-core.js.map +1 -0
  43. package/dist/scripts/emit-hints.d.ts +3 -0
  44. package/dist/scripts/emit-hints.d.ts.map +1 -0
  45. package/dist/scripts/emit-hints.js +75 -0
  46. package/dist/scripts/emit-hints.js.map +1 -0
  47. package/dist/scripts/format-examples.d.ts +3 -0
  48. package/dist/scripts/format-examples.d.ts.map +1 -0
  49. package/dist/scripts/format-examples.js +55 -0
  50. package/dist/scripts/format-examples.js.map +1 -0
  51. package/dist/scripts/generate_error_code_docs.d.ts +8 -0
  52. package/dist/scripts/generate_error_code_docs.d.ts.map +1 -0
  53. package/dist/scripts/generate_error_code_docs.js +128 -0
  54. package/dist/scripts/generate_error_code_docs.js.map +1 -0
  55. package/dist/scripts/generate_error_codes.d.ts +3 -0
  56. package/dist/scripts/generate_error_codes.d.ts.map +1 -0
  57. package/dist/scripts/generate_error_codes.js +224 -0
  58. package/dist/scripts/generate_error_codes.js.map +1 -0
  59. package/dist/scripts/golden.d.ts +3 -0
  60. package/dist/scripts/golden.d.ts.map +1 -0
  61. package/dist/scripts/golden.js +405 -0
  62. package/dist/scripts/golden.js.map +1 -0
  63. package/dist/scripts/health-check.d.ts +3 -0
  64. package/dist/scripts/health-check.d.ts.map +1 -0
  65. package/dist/scripts/health-check.js +42 -0
  66. package/dist/scripts/health-check.js.map +1 -0
  67. package/dist/scripts/inspect-method-cache.d.ts +3 -0
  68. package/dist/scripts/inspect-method-cache.d.ts.map +1 -0
  69. package/dist/scripts/inspect-method-cache.js +24 -0
  70. package/dist/scripts/inspect-method-cache.js.map +1 -0
  71. package/dist/scripts/lsp-build-index.d.ts +3 -0
  72. package/dist/scripts/lsp-build-index.d.ts.map +1 -0
  73. package/dist/scripts/lsp-build-index.js +60 -0
  74. package/dist/scripts/lsp-build-index.js.map +1 -0
  75. package/dist/scripts/lsp-capmanifest-codeaction-smoke.d.ts +3 -0
  76. package/dist/scripts/lsp-capmanifest-codeaction-smoke.d.ts.map +1 -0
  77. package/dist/scripts/lsp-capmanifest-codeaction-smoke.js +161 -0
  78. package/dist/scripts/lsp-capmanifest-codeaction-smoke.js.map +1 -0
  79. package/dist/scripts/lsp-client-helper.d.ts +30 -0
  80. package/dist/scripts/lsp-client-helper.d.ts.map +1 -0
  81. package/dist/scripts/lsp-client-helper.js +192 -0
  82. package/dist/scripts/lsp-client-helper.js.map +1 -0
  83. package/dist/scripts/lsp-client-helper.test.d.ts +7 -0
  84. package/dist/scripts/lsp-client-helper.test.d.ts.map +1 -0
  85. package/dist/scripts/lsp-client-helper.test.js +45 -0
  86. package/dist/scripts/lsp-client-helper.test.js.map +1 -0
  87. package/dist/scripts/lsp-codeaction-smoke.d.ts +3 -0
  88. package/dist/scripts/lsp-codeaction-smoke.d.ts.map +1 -0
  89. package/dist/scripts/lsp-codeaction-smoke.js +98 -0
  90. package/dist/scripts/lsp-codeaction-smoke.js.map +1 -0
  91. package/dist/scripts/lsp-harness.d.ts +3 -0
  92. package/dist/scripts/lsp-harness.d.ts.map +1 -0
  93. package/dist/scripts/lsp-harness.js +33 -0
  94. package/dist/scripts/lsp-harness.js.map +1 -0
  95. package/dist/scripts/lsp-health-smoke.d.ts +3 -0
  96. package/dist/scripts/lsp-health-smoke.d.ts.map +1 -0
  97. package/dist/scripts/lsp-health-smoke.js +98 -0
  98. package/dist/scripts/lsp-health-smoke.js.map +1 -0
  99. package/dist/scripts/lsp-health.d.ts +3 -0
  100. package/dist/scripts/lsp-health.d.ts.map +1 -0
  101. package/dist/scripts/lsp-health.js +22 -0
  102. package/dist/scripts/lsp-health.js.map +1 -0
  103. package/dist/scripts/lsp-highlight-smoke.d.ts +3 -0
  104. package/dist/scripts/lsp-highlight-smoke.d.ts.map +1 -0
  105. package/dist/scripts/lsp-highlight-smoke.js +124 -0
  106. package/dist/scripts/lsp-highlight-smoke.js.map +1 -0
  107. package/dist/scripts/lsp-missing-header-codeaction-smoke.d.ts +3 -0
  108. package/dist/scripts/lsp-missing-header-codeaction-smoke.d.ts.map +1 -0
  109. package/dist/scripts/lsp-missing-header-codeaction-smoke.js +78 -0
  110. package/dist/scripts/lsp-missing-header-codeaction-smoke.js.map +1 -0
  111. package/dist/scripts/lsp-multi-rename.test.d.ts +3 -0
  112. package/dist/scripts/lsp-multi-rename.test.d.ts.map +1 -0
  113. package/dist/scripts/lsp-multi-rename.test.js +81 -0
  114. package/dist/scripts/lsp-multi-rename.test.js.map +1 -0
  115. package/dist/scripts/lsp-punct-codeaction-smoke.d.ts +3 -0
  116. package/dist/scripts/lsp-punct-codeaction-smoke.d.ts.map +1 -0
  117. package/dist/scripts/lsp-punct-codeaction-smoke.js +71 -0
  118. package/dist/scripts/lsp-punct-codeaction-smoke.js.map +1 -0
  119. package/dist/scripts/lsp-signaturehelp-smoke.d.ts +3 -0
  120. package/dist/scripts/lsp-signaturehelp-smoke.d.ts.map +1 -0
  121. package/dist/scripts/lsp-signaturehelp-smoke.js +129 -0
  122. package/dist/scripts/lsp-signaturehelp-smoke.js.map +1 -0
  123. package/dist/scripts/lsp-smoke.d.ts +3 -0
  124. package/dist/scripts/lsp-smoke.d.ts.map +1 -0
  125. package/dist/scripts/lsp-smoke.js +54 -0
  126. package/dist/scripts/lsp-smoke.js.map +1 -0
  127. package/dist/scripts/lsp-streaming-progress-smoke.d.ts +3 -0
  128. package/dist/scripts/lsp-streaming-progress-smoke.d.ts.map +1 -0
  129. package/dist/scripts/lsp-streaming-progress-smoke.js +116 -0
  130. package/dist/scripts/lsp-streaming-progress-smoke.js.map +1 -0
  131. package/dist/scripts/lsp-workspace-diagnostics-smoke.d.ts +3 -0
  132. package/dist/scripts/lsp-workspace-diagnostics-smoke.d.ts.map +1 -0
  133. package/dist/scripts/lsp-workspace-diagnostics-smoke.js +81 -0
  134. package/dist/scripts/lsp-workspace-diagnostics-smoke.js.map +1 -0
  135. package/dist/scripts/perf-assert-report.d.ts +8 -0
  136. package/dist/scripts/perf-assert-report.d.ts.map +1 -0
  137. package/dist/scripts/perf-assert-report.js +44 -0
  138. package/dist/scripts/perf-assert-report.js.map +1 -0
  139. package/dist/scripts/perf-assert.d.ts +3 -0
  140. package/dist/scripts/perf-assert.d.ts.map +1 -0
  141. package/dist/scripts/perf-assert.js +29 -0
  142. package/dist/scripts/perf-assert.js.map +1 -0
  143. package/dist/scripts/perf-benchmark.d.ts +9 -0
  144. package/dist/scripts/perf-benchmark.d.ts.map +1 -0
  145. package/dist/scripts/perf-benchmark.js +272 -0
  146. package/dist/scripts/perf-benchmark.js.map +1 -0
  147. package/dist/scripts/perf-diagnostics.d.ts +7 -0
  148. package/dist/scripts/perf-diagnostics.d.ts.map +1 -0
  149. package/dist/scripts/perf-diagnostics.js +87 -0
  150. package/dist/scripts/perf-diagnostics.js.map +1 -0
  151. package/dist/scripts/perf-lsp-e2e-v2.d.ts +15 -0
  152. package/dist/scripts/perf-lsp-e2e-v2.d.ts.map +1 -0
  153. package/dist/scripts/perf-lsp-e2e-v2.js +323 -0
  154. package/dist/scripts/perf-lsp-e2e-v2.js.map +1 -0
  155. package/dist/scripts/perf-lsp-e2e.d.ts +3 -0
  156. package/dist/scripts/perf-lsp-e2e.d.ts.map +1 -0
  157. package/dist/scripts/perf-lsp-e2e.js +331 -0
  158. package/dist/scripts/perf-lsp-e2e.js.map +1 -0
  159. package/dist/scripts/perf-lsp-internal.d.ts +11 -0
  160. package/dist/scripts/perf-lsp-internal.d.ts.map +1 -0
  161. package/dist/scripts/perf-lsp-internal.js +163 -0
  162. package/dist/scripts/perf-lsp-internal.js.map +1 -0
  163. package/dist/scripts/perf-lsp-ipc.d.ts +11 -0
  164. package/dist/scripts/perf-lsp-ipc.d.ts.map +1 -0
  165. package/dist/scripts/perf-lsp-ipc.js +127 -0
  166. package/dist/scripts/perf-lsp-ipc.js.map +1 -0
  167. package/dist/scripts/perf-lsp.d.ts +3 -0
  168. package/dist/scripts/perf-lsp.d.ts.map +1 -0
  169. package/dist/scripts/perf-lsp.js +87 -0
  170. package/dist/scripts/perf-lsp.js.map +1 -0
  171. package/dist/scripts/perf-utils.d.ts +29 -0
  172. package/dist/scripts/perf-utils.d.ts.map +1 -0
  173. package/dist/scripts/perf-utils.js +40 -0
  174. package/dist/scripts/perf-utils.js.map +1 -0
  175. package/dist/scripts/profile-medium-project.d.ts +7 -0
  176. package/dist/scripts/profile-medium-project.d.ts.map +1 -0
  177. package/dist/scripts/profile-medium-project.js +152 -0
  178. package/dist/scripts/profile-medium-project.js.map +1 -0
  179. package/dist/scripts/repl.d.ts +3 -0
  180. package/dist/scripts/repl.d.ts.map +1 -0
  181. package/dist/scripts/repl.js +88 -0
  182. package/dist/scripts/repl.js.map +1 -0
  183. package/dist/scripts/scaffold.d.ts +3 -0
  184. package/dist/scripts/scaffold.d.ts.map +1 -0
  185. package/dist/scripts/scaffold.js +73 -0
  186. package/dist/scripts/scaffold.js.map +1 -0
  187. package/dist/scripts/seed-method-cache.d.ts +3 -0
  188. package/dist/scripts/seed-method-cache.d.ts.map +1 -0
  189. package/dist/scripts/seed-method-cache.js +37 -0
  190. package/dist/scripts/seed-method-cache.js.map +1 -0
  191. package/dist/scripts/test-comments-golden.d.ts +3 -0
  192. package/dist/scripts/test-comments-golden.d.ts.map +1 -0
  193. package/dist/scripts/test-comments-golden.js +36 -0
  194. package/dist/scripts/test-comments-golden.js.map +1 -0
  195. package/dist/scripts/test-lossless-golden.d.ts +3 -0
  196. package/dist/scripts/test-lossless-golden.d.ts.map +1 -0
  197. package/dist/scripts/test-lossless-golden.js +42 -0
  198. package/dist/scripts/test-lossless-golden.js.map +1 -0
  199. package/dist/scripts/test-lossless.d.ts +3 -0
  200. package/dist/scripts/test-lossless.d.ts.map +1 -0
  201. package/dist/scripts/test-lossless.js +26 -0
  202. package/dist/scripts/test-lossless.js.map +1 -0
  203. package/dist/scripts/test-lsp-index.d.ts +3 -0
  204. package/dist/scripts/test-lsp-index.d.ts.map +1 -0
  205. package/dist/scripts/test-lsp-index.js +37 -0
  206. package/dist/scripts/test-lsp-index.js.map +1 -0
  207. package/dist/scripts/test-medium-diagnostics.d.ts +7 -0
  208. package/dist/scripts/test-medium-diagnostics.d.ts.map +1 -0
  209. package/dist/scripts/test-medium-diagnostics.js +129 -0
  210. package/dist/scripts/test-medium-diagnostics.js.map +1 -0
  211. package/dist/scripts/typecheck-cli.d.ts +3 -0
  212. package/dist/scripts/typecheck-cli.d.ts.map +1 -0
  213. package/dist/scripts/typecheck-cli.js +104 -0
  214. package/dist/scripts/typecheck-cli.js.map +1 -0
  215. package/dist/scripts/update-eff-violation-expected.d.ts +3 -0
  216. package/dist/scripts/update-eff-violation-expected.d.ts.map +1 -0
  217. package/dist/scripts/update-eff-violation-expected.js +57 -0
  218. package/dist/scripts/update-eff-violation-expected.js.map +1 -0
  219. package/dist/scripts/update-golden-ast.d.ts +3 -0
  220. package/dist/scripts/update-golden-ast.d.ts.map +1 -0
  221. package/dist/scripts/update-golden-ast.js +61 -0
  222. package/dist/scripts/update-golden-ast.js.map +1 -0
  223. package/dist/scripts/validate_error_codes.d.ts +12 -0
  224. package/dist/scripts/validate_error_codes.d.ts.map +1 -0
  225. package/dist/scripts/validate_error_codes.js +114 -0
  226. package/dist/scripts/validate_error_codes.js.map +1 -0
  227. package/dist/scripts/verify-capabilities.d.ts +3 -0
  228. package/dist/scripts/verify-capabilities.d.ts.map +1 -0
  229. package/dist/scripts/verify-capabilities.js +23 -0
  230. package/dist/scripts/verify-capabilities.js.map +1 -0
  231. package/dist/scripts/verify-classes.d.ts +3 -0
  232. package/dist/scripts/verify-classes.d.ts.map +1 -0
  233. package/dist/scripts/verify-classes.js +32 -0
  234. package/dist/scripts/verify-classes.js.map +1 -0
  235. package/dist/scripts/verify-examples.d.ts +3 -0
  236. package/dist/scripts/verify-examples.d.ts.map +1 -0
  237. package/dist/scripts/verify-examples.js +79 -0
  238. package/dist/scripts/verify-examples.js.map +1 -0
  239. package/dist/scripts/verify-fuzz.d.ts +3 -0
  240. package/dist/scripts/verify-fuzz.d.ts.map +1 -0
  241. package/dist/scripts/verify-fuzz.js +88 -0
  242. package/dist/scripts/verify-fuzz.js.map +1 -0
  243. package/dist/scripts/verify-jar-checksum.d.ts +3 -0
  244. package/dist/scripts/verify-jar-checksum.d.ts.map +1 -0
  245. package/dist/scripts/verify-jar-checksum.js +63 -0
  246. package/dist/scripts/verify-jar-checksum.js.map +1 -0
  247. package/dist/scripts/verify-nullstrict.d.ts +3 -0
  248. package/dist/scripts/verify-nullstrict.d.ts.map +1 -0
  249. package/dist/scripts/verify-nullstrict.js +20 -0
  250. package/dist/scripts/verify-nullstrict.js.map +1 -0
  251. package/dist/src/ai/generation-cache.d.ts +36 -0
  252. package/dist/src/ai/generation-cache.d.ts.map +1 -0
  253. package/dist/src/ai/generation-cache.js +91 -0
  254. package/dist/src/ai/generation-cache.js.map +1 -0
  255. package/dist/src/ai/generator.d.ts +105 -0
  256. package/dist/src/ai/generator.d.ts.map +1 -0
  257. package/dist/src/ai/generator.js +103 -0
  258. package/dist/src/ai/generator.js.map +1 -0
  259. package/dist/src/ai/llm-provider.d.ts +31 -0
  260. package/dist/src/ai/llm-provider.d.ts.map +1 -0
  261. package/dist/src/ai/llm-provider.js +17 -0
  262. package/dist/src/ai/llm-provider.js.map +1 -0
  263. package/dist/src/ai/prompt-manager.d.ts +48 -0
  264. package/dist/src/ai/prompt-manager.d.ts.map +1 -0
  265. package/dist/src/ai/prompt-manager.js +70 -0
  266. package/dist/src/ai/prompt-manager.js.map +1 -0
  267. package/dist/src/ai/provenance.d.ts +70 -0
  268. package/dist/src/ai/provenance.d.ts.map +1 -0
  269. package/dist/src/ai/provenance.js +95 -0
  270. package/dist/src/ai/provenance.js.map +1 -0
  271. package/dist/src/ai/providers/anthropic.d.ts +14 -0
  272. package/dist/src/ai/providers/anthropic.d.ts.map +1 -0
  273. package/dist/src/ai/providers/anthropic.js +56 -0
  274. package/dist/src/ai/providers/anthropic.js.map +1 -0
  275. package/dist/src/ai/providers/openai.d.ts +15 -0
  276. package/dist/src/ai/providers/openai.d.ts.map +1 -0
  277. package/dist/src/ai/providers/openai.js +58 -0
  278. package/dist/src/ai/providers/openai.js.map +1 -0
  279. package/dist/src/ai/validator.d.ts +68 -0
  280. package/dist/src/ai/validator.d.ts.map +1 -0
  281. package/dist/src/ai/validator.js +108 -0
  282. package/dist/src/ai/validator.js.map +1 -0
  283. package/dist/src/ast/ast.d.ts +49 -0
  284. package/dist/src/ast/ast.d.ts.map +1 -0
  285. package/dist/src/ast/ast.js +191 -0
  286. package/dist/src/ast/ast.js.map +1 -0
  287. package/dist/src/ast/ast_visitor.d.ts +66 -0
  288. package/dist/src/ast/ast_visitor.d.ts.map +1 -0
  289. package/dist/src/ast/ast_visitor.js +176 -0
  290. package/dist/src/ast/ast_visitor.js.map +1 -0
  291. package/dist/src/ast/index.d.ts +13 -0
  292. package/dist/src/ast/index.d.ts.map +1 -0
  293. package/dist/src/ast/index.js +12 -0
  294. package/dist/src/ast/index.js.map +1 -0
  295. package/dist/src/cli/commands/ai-generate.d.ts +39 -0
  296. package/dist/src/cli/commands/ai-generate.d.ts.map +1 -0
  297. package/dist/src/cli/commands/ai-generate.js +146 -0
  298. package/dist/src/cli/commands/ai-generate.js.map +1 -0
  299. package/dist/src/cli/commands/install.d.ts +7 -0
  300. package/dist/src/cli/commands/install.d.ts.map +1 -0
  301. package/dist/src/cli/commands/install.js +146 -0
  302. package/dist/src/cli/commands/install.js.map +1 -0
  303. package/dist/src/cli/commands/list.d.ts +6 -0
  304. package/dist/src/cli/commands/list.d.ts.map +1 -0
  305. package/dist/src/cli/commands/list.js +158 -0
  306. package/dist/src/cli/commands/list.js.map +1 -0
  307. package/dist/src/cli/commands/search.d.ts +2 -0
  308. package/dist/src/cli/commands/search.d.ts.map +1 -0
  309. package/dist/src/cli/commands/search.js +174 -0
  310. package/dist/src/cli/commands/search.js.map +1 -0
  311. package/dist/src/cli/commands/update.d.ts +2 -0
  312. package/dist/src/cli/commands/update.d.ts.map +1 -0
  313. package/dist/src/cli/commands/update.js +244 -0
  314. package/dist/src/cli/commands/update.js.map +1 -0
  315. package/dist/src/cli/policy-converter.d.ts +10 -0
  316. package/dist/src/cli/policy-converter.d.ts.map +1 -0
  317. package/dist/src/cli/policy-converter.js +188 -0
  318. package/dist/src/cli/policy-converter.js.map +1 -0
  319. package/dist/src/cli/utils/error-handler.d.ts +4 -0
  320. package/dist/src/cli/utils/error-handler.d.ts.map +1 -0
  321. package/dist/src/cli/utils/error-handler.js +91 -0
  322. package/dist/src/cli/utils/error-handler.js.map +1 -0
  323. package/dist/src/cli/utils/logger.d.ts +8 -0
  324. package/dist/src/cli/utils/logger.d.ts.map +1 -0
  325. package/dist/src/cli/utils/logger.js +20 -0
  326. package/dist/src/cli/utils/logger.js.map +1 -0
  327. package/dist/src/config/config-service.d.ts +79 -0
  328. package/dist/src/config/config-service.d.ts.map +1 -0
  329. package/dist/src/config/config-service.js +112 -0
  330. package/dist/src/config/config-service.js.map +1 -0
  331. package/dist/src/config/effect_config.d.ts +111 -0
  332. package/dist/src/config/effect_config.d.ts.map +1 -0
  333. package/dist/src/config/effect_config.js +248 -0
  334. package/dist/src/config/effect_config.js.map +1 -0
  335. package/dist/src/config/effects.d.ts +33 -0
  336. package/dist/src/config/effects.d.ts.map +1 -0
  337. package/dist/src/config/effects.js +34 -0
  338. package/dist/src/config/effects.js.map +1 -0
  339. package/dist/src/config/lexicons/de-DE.d.ts +12 -0
  340. package/dist/src/config/lexicons/de-DE.d.ts.map +1 -0
  341. package/dist/src/config/lexicons/de-DE.js +129 -0
  342. package/dist/src/config/lexicons/de-DE.js.map +1 -0
  343. package/dist/src/config/lexicons/en-US.d.ts +15 -0
  344. package/dist/src/config/lexicons/en-US.d.ts.map +1 -0
  345. package/dist/src/config/lexicons/en-US.js +136 -0
  346. package/dist/src/config/lexicons/en-US.js.map +1 -0
  347. package/dist/src/config/lexicons/identifiers/domains/finance.loan.zh-CN.d.ts +13 -0
  348. package/dist/src/config/lexicons/identifiers/domains/finance.loan.zh-CN.d.ts.map +1 -0
  349. package/dist/src/config/lexicons/identifiers/domains/finance.loan.zh-CN.js +307 -0
  350. package/dist/src/config/lexicons/identifiers/domains/finance.loan.zh-CN.js.map +1 -0
  351. package/dist/src/config/lexicons/identifiers/domains/insurance.auto.zh-CN.d.ts +25 -0
  352. package/dist/src/config/lexicons/identifiers/domains/insurance.auto.zh-CN.d.ts.map +1 -0
  353. package/dist/src/config/lexicons/identifiers/domains/insurance.auto.zh-CN.js +355 -0
  354. package/dist/src/config/lexicons/identifiers/domains/insurance.auto.zh-CN.js.map +1 -0
  355. package/dist/src/config/lexicons/identifiers/examples/canonicalizer-integration.d.ts +47 -0
  356. package/dist/src/config/lexicons/identifiers/examples/canonicalizer-integration.d.ts.map +1 -0
  357. package/dist/src/config/lexicons/identifiers/examples/canonicalizer-integration.js +142 -0
  358. package/dist/src/config/lexicons/identifiers/examples/canonicalizer-integration.js.map +1 -0
  359. package/dist/src/config/lexicons/identifiers/index.d.ts +34 -0
  360. package/dist/src/config/lexicons/identifiers/index.d.ts.map +1 -0
  361. package/dist/src/config/lexicons/identifiers/index.js +37 -0
  362. package/dist/src/config/lexicons/identifiers/index.js.map +1 -0
  363. package/dist/src/config/lexicons/identifiers/registry.d.ts +112 -0
  364. package/dist/src/config/lexicons/identifiers/registry.d.ts.map +1 -0
  365. package/dist/src/config/lexicons/identifiers/registry.js +188 -0
  366. package/dist/src/config/lexicons/identifiers/registry.js.map +1 -0
  367. package/dist/src/config/lexicons/identifiers/types.d.ts +129 -0
  368. package/dist/src/config/lexicons/identifiers/types.d.ts.map +1 -0
  369. package/dist/src/config/lexicons/identifiers/types.js +146 -0
  370. package/dist/src/config/lexicons/identifiers/types.js.map +1 -0
  371. package/dist/src/config/lexicons/index.d.ts +33 -0
  372. package/dist/src/config/lexicons/index.d.ts.map +1 -0
  373. package/dist/src/config/lexicons/index.js +50 -0
  374. package/dist/src/config/lexicons/index.js.map +1 -0
  375. package/dist/src/config/lexicons/registry.d.ts +41 -0
  376. package/dist/src/config/lexicons/registry.d.ts.map +1 -0
  377. package/dist/src/config/lexicons/registry.js +205 -0
  378. package/dist/src/config/lexicons/registry.js.map +1 -0
  379. package/dist/src/config/lexicons/template.d.ts +67 -0
  380. package/dist/src/config/lexicons/template.d.ts.map +1 -0
  381. package/dist/src/config/lexicons/template.js +442 -0
  382. package/dist/src/config/lexicons/template.js.map +1 -0
  383. package/dist/src/config/lexicons/types.d.ts +169 -0
  384. package/dist/src/config/lexicons/types.d.ts.map +1 -0
  385. package/dist/src/config/lexicons/types.js +62 -0
  386. package/dist/src/config/lexicons/types.js.map +1 -0
  387. package/dist/src/config/lexicons/zh-CN.d.ts +21 -0
  388. package/dist/src/config/lexicons/zh-CN.d.ts.map +1 -0
  389. package/dist/src/config/lexicons/zh-CN.js +139 -0
  390. package/dist/src/config/lexicons/zh-CN.js.map +1 -0
  391. package/dist/src/config/runtime.d.ts +2 -0
  392. package/dist/src/config/runtime.d.ts.map +1 -0
  393. package/dist/src/config/runtime.js +13 -0
  394. package/dist/src/config/runtime.js.map +1 -0
  395. package/dist/src/config/semantic.d.ts +262 -0
  396. package/dist/src/config/semantic.d.ts.map +1 -0
  397. package/dist/src/config/semantic.js +394 -0
  398. package/dist/src/config/semantic.js.map +1 -0
  399. package/dist/src/config/token-kind.d.ts +177 -0
  400. package/dist/src/config/token-kind.d.ts.map +1 -0
  401. package/dist/src/config/token-kind.js +298 -0
  402. package/dist/src/config/token-kind.js.map +1 -0
  403. package/dist/src/core/core_ir.d.ts +50 -0
  404. package/dist/src/core/core_ir.d.ts.map +1 -0
  405. package/dist/src/core/core_ir.js +139 -0
  406. package/dist/src/core/core_ir.js.map +1 -0
  407. package/dist/src/core/core_ir_json.d.ts +62 -0
  408. package/dist/src/core/core_ir_json.d.ts.map +1 -0
  409. package/dist/src/core/core_ir_json.js +81 -0
  410. package/dist/src/core/core_ir_json.js.map +1 -0
  411. package/dist/src/core/index.d.ts +18 -0
  412. package/dist/src/core/index.d.ts.map +1 -0
  413. package/dist/src/core/index.js +16 -0
  414. package/dist/src/core/index.js.map +1 -0
  415. package/dist/src/core/pretty_core.d.ts +3 -0
  416. package/dist/src/core/pretty_core.d.ts.map +1 -0
  417. package/dist/src/core/pretty_core.js +177 -0
  418. package/dist/src/core/pretty_core.js.map +1 -0
  419. package/dist/src/core/visitor.d.ts +51 -0
  420. package/dist/src/core/visitor.d.ts.map +1 -0
  421. package/dist/src/core/visitor.js +117 -0
  422. package/dist/src/core/visitor.js.map +1 -0
  423. package/dist/src/cst/cst.d.ts +32 -0
  424. package/dist/src/cst/cst.d.ts.map +1 -0
  425. package/dist/src/cst/cst.js +2 -0
  426. package/dist/src/cst/cst.js.map +1 -0
  427. package/dist/src/cst/cst_builder.d.ts +5 -0
  428. package/dist/src/cst/cst_builder.d.ts.map +1 -0
  429. package/dist/src/cst/cst_builder.js +101 -0
  430. package/dist/src/cst/cst_builder.js.map +1 -0
  431. package/dist/src/cst/cst_printer.d.ts +8 -0
  432. package/dist/src/cst/cst_printer.d.ts.map +1 -0
  433. package/dist/src/cst/cst_printer.js +47 -0
  434. package/dist/src/cst/cst_printer.js.map +1 -0
  435. package/dist/src/cst/index.d.ts +14 -0
  436. package/dist/src/cst/index.d.ts.map +1 -0
  437. package/dist/src/cst/index.js +13 -0
  438. package/dist/src/cst/index.js.map +1 -0
  439. package/dist/src/diagnostics/diagnostics.d.ts +138 -0
  440. package/dist/src/diagnostics/diagnostics.d.ts.map +1 -0
  441. package/dist/src/diagnostics/diagnostics.js +249 -0
  442. package/dist/src/diagnostics/diagnostics.js.map +1 -0
  443. package/dist/src/diagnostics/error_codes.d.ts +88 -0
  444. package/dist/src/diagnostics/error_codes.d.ts.map +1 -0
  445. package/dist/src/diagnostics/error_codes.js +551 -0
  446. package/dist/src/diagnostics/error_codes.js.map +1 -0
  447. package/dist/src/diagnostics/index.d.ts +14 -0
  448. package/dist/src/diagnostics/index.d.ts.map +1 -0
  449. package/dist/src/diagnostics/index.js +14 -0
  450. package/dist/src/diagnostics/index.js.map +1 -0
  451. package/dist/src/effects/capabilities.d.ts +18 -0
  452. package/dist/src/effects/capabilities.d.ts.map +1 -0
  453. package/dist/src/effects/capabilities.js +101 -0
  454. package/dist/src/effects/capabilities.js.map +1 -0
  455. package/dist/src/effects/effect_inference.d.ts +17 -0
  456. package/dist/src/effects/effect_inference.d.ts.map +1 -0
  457. package/dist/src/effects/effect_inference.js +557 -0
  458. package/dist/src/effects/effect_inference.js.map +1 -0
  459. package/dist/src/effects/effect_signature.d.ts +13 -0
  460. package/dist/src/effects/effect_signature.d.ts.map +1 -0
  461. package/dist/src/effects/effect_signature.js +2 -0
  462. package/dist/src/effects/effect_signature.js.map +1 -0
  463. package/dist/src/effects/index.d.ts +14 -0
  464. package/dist/src/effects/index.d.ts.map +1 -0
  465. package/dist/src/effects/index.js +13 -0
  466. package/dist/src/effects/index.js.map +1 -0
  467. package/dist/src/formatter.d.ts +7 -0
  468. package/dist/src/formatter.d.ts.map +1 -0
  469. package/dist/src/formatter.js +383 -0
  470. package/dist/src/formatter.js.map +1 -0
  471. package/dist/src/frontend/canonicalizer.d.ts +55 -0
  472. package/dist/src/frontend/canonicalizer.d.ts.map +1 -0
  473. package/dist/src/frontend/canonicalizer.js +348 -0
  474. package/dist/src/frontend/canonicalizer.js.map +1 -0
  475. package/dist/src/frontend/index.d.ts +17 -0
  476. package/dist/src/frontend/index.d.ts.map +1 -0
  477. package/dist/src/frontend/index.js +16 -0
  478. package/dist/src/frontend/index.js.map +1 -0
  479. package/dist/src/frontend/keyword-translator.d.ts +134 -0
  480. package/dist/src/frontend/keyword-translator.d.ts.map +1 -0
  481. package/dist/src/frontend/keyword-translator.js +188 -0
  482. package/dist/src/frontend/keyword-translator.js.map +1 -0
  483. package/dist/src/frontend/lexer.d.ts +59 -0
  484. package/dist/src/frontend/lexer.d.ts.map +1 -0
  485. package/dist/src/frontend/lexer.js +536 -0
  486. package/dist/src/frontend/lexer.js.map +1 -0
  487. package/dist/src/frontend/tokens.d.ts +12 -0
  488. package/dist/src/frontend/tokens.d.ts.map +1 -0
  489. package/dist/src/frontend/tokens.js +12 -0
  490. package/dist/src/frontend/tokens.js.map +1 -0
  491. package/dist/src/index.d.ts +36 -0
  492. package/dist/src/index.d.ts.map +1 -0
  493. package/dist/src/index.js +37 -0
  494. package/dist/src/index.js.map +1 -0
  495. package/dist/src/jvm/emitter.d.ts +3 -0
  496. package/dist/src/jvm/emitter.d.ts.map +1 -0
  497. package/dist/src/jvm/emitter.js +609 -0
  498. package/dist/src/jvm/emitter.js.map +1 -0
  499. package/dist/src/lower_to_core.d.ts +53 -0
  500. package/dist/src/lower_to_core.d.ts.map +1 -0
  501. package/dist/src/lower_to_core.js +528 -0
  502. package/dist/src/lower_to_core.js.map +1 -0
  503. package/dist/src/lsp/analysis.d.ts +50 -0
  504. package/dist/src/lsp/analysis.d.ts.map +1 -0
  505. package/dist/src/lsp/analysis.js +399 -0
  506. package/dist/src/lsp/analysis.js.map +1 -0
  507. package/dist/src/lsp/codeaction.d.ts +21 -0
  508. package/dist/src/lsp/codeaction.d.ts.map +1 -0
  509. package/dist/src/lsp/codeaction.js +531 -0
  510. package/dist/src/lsp/codeaction.js.map +1 -0
  511. package/dist/src/lsp/completion.d.ts +81 -0
  512. package/dist/src/lsp/completion.d.ts.map +1 -0
  513. package/dist/src/lsp/completion.js +345 -0
  514. package/dist/src/lsp/completion.js.map +1 -0
  515. package/dist/src/lsp/config.d.ts +34 -0
  516. package/dist/src/lsp/config.d.ts.map +1 -0
  517. package/dist/src/lsp/config.js +23 -0
  518. package/dist/src/lsp/config.js.map +1 -0
  519. package/dist/src/lsp/diagnostics.d.ts +87 -0
  520. package/dist/src/lsp/diagnostics.d.ts.map +1 -0
  521. package/dist/src/lsp/diagnostics.js +474 -0
  522. package/dist/src/lsp/diagnostics.js.map +1 -0
  523. package/dist/src/lsp/formatting.d.ts +16 -0
  524. package/dist/src/lsp/formatting.d.ts.map +1 -0
  525. package/dist/src/lsp/formatting.js +75 -0
  526. package/dist/src/lsp/formatting.js.map +1 -0
  527. package/dist/src/lsp/health.d.ts +74 -0
  528. package/dist/src/lsp/health.d.ts.map +1 -0
  529. package/dist/src/lsp/health.js +106 -0
  530. package/dist/src/lsp/health.js.map +1 -0
  531. package/dist/src/lsp/index.d.ts +14 -0
  532. package/dist/src/lsp/index.d.ts.map +1 -0
  533. package/dist/src/lsp/index.js +17 -0
  534. package/dist/src/lsp/index.js.map +1 -0
  535. package/dist/src/lsp/module_cache.d.ts +39 -0
  536. package/dist/src/lsp/module_cache.d.ts.map +1 -0
  537. package/dist/src/lsp/module_cache.js +308 -0
  538. package/dist/src/lsp/module_cache.js.map +1 -0
  539. package/dist/src/lsp/navigation/definition.d.ts +20 -0
  540. package/dist/src/lsp/navigation/definition.d.ts.map +1 -0
  541. package/dist/src/lsp/navigation/definition.js +96 -0
  542. package/dist/src/lsp/navigation/definition.js.map +1 -0
  543. package/dist/src/lsp/navigation/document-symbol.d.ts +20 -0
  544. package/dist/src/lsp/navigation/document-symbol.d.ts.map +1 -0
  545. package/dist/src/lsp/navigation/document-symbol.js +196 -0
  546. package/dist/src/lsp/navigation/document-symbol.js.map +1 -0
  547. package/dist/src/lsp/navigation/hover.d.ts +20 -0
  548. package/dist/src/lsp/navigation/hover.d.ts.map +1 -0
  549. package/dist/src/lsp/navigation/hover.js +147 -0
  550. package/dist/src/lsp/navigation/hover.js.map +1 -0
  551. package/dist/src/lsp/navigation/references.d.ts +17 -0
  552. package/dist/src/lsp/navigation/references.d.ts.map +1 -0
  553. package/dist/src/lsp/navigation/references.js +104 -0
  554. package/dist/src/lsp/navigation/references.js.map +1 -0
  555. package/dist/src/lsp/navigation/rename.d.ts +22 -0
  556. package/dist/src/lsp/navigation/rename.d.ts.map +1 -0
  557. package/dist/src/lsp/navigation/rename.js +161 -0
  558. package/dist/src/lsp/navigation/rename.js.map +1 -0
  559. package/dist/src/lsp/navigation/shared.d.ts +175 -0
  560. package/dist/src/lsp/navigation/shared.d.ts.map +1 -0
  561. package/dist/src/lsp/navigation/shared.js +470 -0
  562. package/dist/src/lsp/navigation/shared.js.map +1 -0
  563. package/dist/src/lsp/navigation.d.ts +23 -0
  564. package/dist/src/lsp/navigation.d.ts.map +1 -0
  565. package/dist/src/lsp/navigation.js +28 -0
  566. package/dist/src/lsp/navigation.js.map +1 -0
  567. package/dist/src/lsp/pii_diagnostics.d.ts +15 -0
  568. package/dist/src/lsp/pii_diagnostics.d.ts.map +1 -0
  569. package/dist/src/lsp/pii_diagnostics.js +624 -0
  570. package/dist/src/lsp/pii_diagnostics.js.map +1 -0
  571. package/dist/src/lsp/server.d.ts +3 -0
  572. package/dist/src/lsp/server.d.ts.map +1 -0
  573. package/dist/src/lsp/server.js +406 -0
  574. package/dist/src/lsp/server.js.map +1 -0
  575. package/dist/src/lsp/shared-state.d.ts +15 -0
  576. package/dist/src/lsp/shared-state.d.ts.map +1 -0
  577. package/dist/src/lsp/shared-state.js +21 -0
  578. package/dist/src/lsp/shared-state.js.map +1 -0
  579. package/dist/src/lsp/symbols.d.ts +35 -0
  580. package/dist/src/lsp/symbols.d.ts.map +1 -0
  581. package/dist/src/lsp/symbols.js +124 -0
  582. package/dist/src/lsp/symbols.js.map +1 -0
  583. package/dist/src/lsp/task-queue.d.ts +172 -0
  584. package/dist/src/lsp/task-queue.d.ts.map +1 -0
  585. package/dist/src/lsp/task-queue.js +310 -0
  586. package/dist/src/lsp/task-queue.js.map +1 -0
  587. package/dist/src/lsp/token-index.d.ts +45 -0
  588. package/dist/src/lsp/token-index.d.ts.map +1 -0
  589. package/dist/src/lsp/token-index.js +114 -0
  590. package/dist/src/lsp/token-index.js.map +1 -0
  591. package/dist/src/lsp/tokens.d.ts +33 -0
  592. package/dist/src/lsp/tokens.d.ts.map +1 -0
  593. package/dist/src/lsp/tokens.js +259 -0
  594. package/dist/src/lsp/tokens.js.map +1 -0
  595. package/dist/src/lsp/type-guards.d.ts +80 -0
  596. package/dist/src/lsp/type-guards.d.ts.map +1 -0
  597. package/dist/src/lsp/type-guards.js +132 -0
  598. package/dist/src/lsp/type-guards.js.map +1 -0
  599. package/dist/src/lsp/utils.d.ts +4 -0
  600. package/dist/src/lsp/utils.d.ts.map +1 -0
  601. package/dist/src/lsp/utils.js +52 -0
  602. package/dist/src/lsp/utils.js.map +1 -0
  603. package/dist/src/lsp/workspace/document-indexer.d.ts +14 -0
  604. package/dist/src/lsp/workspace/document-indexer.d.ts.map +1 -0
  605. package/dist/src/lsp/workspace/document-indexer.js +88 -0
  606. package/dist/src/lsp/workspace/document-indexer.js.map +1 -0
  607. package/dist/src/lsp/workspace/file-watcher.d.ts +137 -0
  608. package/dist/src/lsp/workspace/file-watcher.d.ts.map +1 -0
  609. package/dist/src/lsp/workspace/file-watcher.js +307 -0
  610. package/dist/src/lsp/workspace/file-watcher.js.map +1 -0
  611. package/dist/src/lsp/workspace/index-manager.d.ts +48 -0
  612. package/dist/src/lsp/workspace/index-manager.d.ts.map +1 -0
  613. package/dist/src/lsp/workspace/index-manager.js +131 -0
  614. package/dist/src/lsp/workspace/index-manager.js.map +1 -0
  615. package/dist/src/lsp/workspace/symbol-finder.d.ts +13 -0
  616. package/dist/src/lsp/workspace/symbol-finder.d.ts.map +1 -0
  617. package/dist/src/lsp/workspace/symbol-finder.js +69 -0
  618. package/dist/src/lsp/workspace/symbol-finder.js.map +1 -0
  619. package/dist/src/lsp/workspace/types.d.ts +77 -0
  620. package/dist/src/lsp/workspace/types.d.ts.map +1 -0
  621. package/dist/src/lsp/workspace/types.js +6 -0
  622. package/dist/src/lsp/workspace/types.js.map +1 -0
  623. package/dist/src/lsp/workspace/workspace-scanner.d.ts +11 -0
  624. package/dist/src/lsp/workspace/workspace-scanner.d.ts.map +1 -0
  625. package/dist/src/lsp/workspace/workspace-scanner.js +115 -0
  626. package/dist/src/lsp/workspace/workspace-scanner.js.map +1 -0
  627. package/dist/src/manifest.d.ts +48 -0
  628. package/dist/src/manifest.d.ts.map +1 -0
  629. package/dist/src/manifest.js +10 -0
  630. package/dist/src/manifest.js.map +1 -0
  631. package/dist/src/package/config.d.ts +28 -0
  632. package/dist/src/package/config.d.ts.map +1 -0
  633. package/dist/src/package/config.js +59 -0
  634. package/dist/src/package/config.js.map +1 -0
  635. package/dist/src/package/dependency-graph.d.ts +42 -0
  636. package/dist/src/package/dependency-graph.d.ts.map +1 -0
  637. package/dist/src/package/dependency-graph.js +144 -0
  638. package/dist/src/package/dependency-graph.js.map +1 -0
  639. package/dist/src/package/lockfile.d.ts +20 -0
  640. package/dist/src/package/lockfile.d.ts.map +1 -0
  641. package/dist/src/package/lockfile.js +146 -0
  642. package/dist/src/package/lockfile.js.map +1 -0
  643. package/dist/src/package/manifest-parser.d.ts +22 -0
  644. package/dist/src/package/manifest-parser.d.ts.map +1 -0
  645. package/dist/src/package/manifest-parser.js +275 -0
  646. package/dist/src/package/manifest-parser.js.map +1 -0
  647. package/dist/src/package/package-cache.d.ts +56 -0
  648. package/dist/src/package/package-cache.d.ts.map +1 -0
  649. package/dist/src/package/package-cache.js +166 -0
  650. package/dist/src/package/package-cache.js.map +1 -0
  651. package/dist/src/package/package-installer.d.ts +67 -0
  652. package/dist/src/package/package-installer.d.ts.map +1 -0
  653. package/dist/src/package/package-installer.js +310 -0
  654. package/dist/src/package/package-installer.js.map +1 -0
  655. package/dist/src/package/package-registry.d.ts +70 -0
  656. package/dist/src/package/package-registry.d.ts.map +1 -0
  657. package/dist/src/package/package-registry.js +480 -0
  658. package/dist/src/package/package-registry.js.map +1 -0
  659. package/dist/src/package/resolver.d.ts +50 -0
  660. package/dist/src/package/resolver.d.ts.map +1 -0
  661. package/dist/src/package/resolver.js +236 -0
  662. package/dist/src/package/resolver.js.map +1 -0
  663. package/dist/src/package/version-utils.d.ts +53 -0
  664. package/dist/src/package/version-utils.d.ts.map +1 -0
  665. package/dist/src/package/version-utils.js +61 -0
  666. package/dist/src/package/version-utils.js.map +1 -0
  667. package/dist/src/parser/constraint-parser.d.ts +42 -0
  668. package/dist/src/parser/constraint-parser.d.ts.map +1 -0
  669. package/dist/src/parser/constraint-parser.js +192 -0
  670. package/dist/src/parser/constraint-parser.js.map +1 -0
  671. package/dist/src/parser/context.d.ts +56 -0
  672. package/dist/src/parser/context.d.ts.map +1 -0
  673. package/dist/src/parser/context.js +177 -0
  674. package/dist/src/parser/context.js.map +1 -0
  675. package/dist/src/parser/decl-parser.d.ts +52 -0
  676. package/dist/src/parser/decl-parser.d.ts.map +1 -0
  677. package/dist/src/parser/decl-parser.js +461 -0
  678. package/dist/src/parser/decl-parser.js.map +1 -0
  679. package/dist/src/parser/expr-stmt-parser.d.ts +51 -0
  680. package/dist/src/parser/expr-stmt-parser.d.ts.map +1 -0
  681. package/dist/src/parser/expr-stmt-parser.js +1317 -0
  682. package/dist/src/parser/expr-stmt-parser.js.map +1 -0
  683. package/dist/src/parser/field-variant-parser.d.ts +47 -0
  684. package/dist/src/parser/field-variant-parser.d.ts.map +1 -0
  685. package/dist/src/parser/field-variant-parser.js +142 -0
  686. package/dist/src/parser/field-variant-parser.js.map +1 -0
  687. package/dist/src/parser/import-parser.d.ts +40 -0
  688. package/dist/src/parser/import-parser.d.ts.map +1 -0
  689. package/dist/src/parser/import-parser.js +91 -0
  690. package/dist/src/parser/import-parser.js.map +1 -0
  691. package/dist/src/parser/parser-tools.d.ts +52 -0
  692. package/dist/src/parser/parser-tools.d.ts.map +1 -0
  693. package/dist/src/parser/parser-tools.js +50 -0
  694. package/dist/src/parser/parser-tools.js.map +1 -0
  695. package/dist/src/parser/span-utils.d.ts +16 -0
  696. package/dist/src/parser/span-utils.d.ts.map +1 -0
  697. package/dist/src/parser/span-utils.js +90 -0
  698. package/dist/src/parser/span-utils.js.map +1 -0
  699. package/dist/src/parser/type-inference.d.ts +90 -0
  700. package/dist/src/parser/type-inference.d.ts.map +1 -0
  701. package/dist/src/parser/type-inference.js +287 -0
  702. package/dist/src/parser/type-inference.js.map +1 -0
  703. package/dist/src/parser/type-parser.d.ts +24 -0
  704. package/dist/src/parser/type-parser.d.ts.map +1 -0
  705. package/dist/src/parser/type-parser.js +338 -0
  706. package/dist/src/parser/type-parser.js.map +1 -0
  707. package/dist/src/parser.d.ts +12 -0
  708. package/dist/src/parser.d.ts.map +1 -0
  709. package/dist/src/parser.js +25 -0
  710. package/dist/src/parser.js.map +1 -0
  711. package/dist/src/typecheck/async.d.ts +57 -0
  712. package/dist/src/typecheck/async.d.ts.map +1 -0
  713. package/dist/src/typecheck/async.js +369 -0
  714. package/dist/src/typecheck/async.js.map +1 -0
  715. package/dist/src/typecheck/capabilities.d.ts +20 -0
  716. package/dist/src/typecheck/capabilities.d.ts.map +1 -0
  717. package/dist/src/typecheck/capabilities.js +86 -0
  718. package/dist/src/typecheck/capabilities.js.map +1 -0
  719. package/dist/src/typecheck/context.d.ts +31 -0
  720. package/dist/src/typecheck/context.d.ts.map +1 -0
  721. package/dist/src/typecheck/context.js +34 -0
  722. package/dist/src/typecheck/context.js.map +1 -0
  723. package/dist/src/typecheck/diagnostics.d.ts +15 -0
  724. package/dist/src/typecheck/diagnostics.d.ts.map +1 -0
  725. package/dist/src/typecheck/diagnostics.js +92 -0
  726. package/dist/src/typecheck/diagnostics.js.map +1 -0
  727. package/dist/src/typecheck/effects.d.ts +16 -0
  728. package/dist/src/typecheck/effects.d.ts.map +1 -0
  729. package/dist/src/typecheck/effects.js +122 -0
  730. package/dist/src/typecheck/effects.js.map +1 -0
  731. package/dist/src/typecheck/expression.d.ts +12 -0
  732. package/dist/src/typecheck/expression.d.ts.map +1 -0
  733. package/dist/src/typecheck/expression.js +306 -0
  734. package/dist/src/typecheck/expression.js.map +1 -0
  735. package/dist/src/typecheck/generics.d.ts +6 -0
  736. package/dist/src/typecheck/generics.d.ts.map +1 -0
  737. package/dist/src/typecheck/generics.js +131 -0
  738. package/dist/src/typecheck/generics.js.map +1 -0
  739. package/dist/src/typecheck/index.d.ts +6 -0
  740. package/dist/src/typecheck/index.d.ts.map +1 -0
  741. package/dist/src/typecheck/index.js +3 -0
  742. package/dist/src/typecheck/index.js.map +1 -0
  743. package/dist/src/typecheck/module.d.ts +9 -0
  744. package/dist/src/typecheck/module.d.ts.map +1 -0
  745. package/dist/src/typecheck/module.js +223 -0
  746. package/dist/src/typecheck/module.js.map +1 -0
  747. package/dist/src/typecheck/pattern.d.ts +6 -0
  748. package/dist/src/typecheck/pattern.d.ts.map +1 -0
  749. package/dist/src/typecheck/pattern.js +80 -0
  750. package/dist/src/typecheck/pattern.js.map +1 -0
  751. package/dist/src/typecheck/statement.d.ts +13 -0
  752. package/dist/src/typecheck/statement.d.ts.map +1 -0
  753. package/dist/src/typecheck/statement.js +176 -0
  754. package/dist/src/typecheck/statement.js.map +1 -0
  755. package/dist/src/typecheck/symbol_table.d.ts +63 -0
  756. package/dist/src/typecheck/symbol_table.d.ts.map +1 -0
  757. package/dist/src/typecheck/symbol_table.js +208 -0
  758. package/dist/src/typecheck/symbol_table.js.map +1 -0
  759. package/dist/src/typecheck/type_system.d.ts +30 -0
  760. package/dist/src/typecheck/type_system.d.ts.map +1 -0
  761. package/dist/src/typecheck/type_system.js +529 -0
  762. package/dist/src/typecheck/type_system.js.map +1 -0
  763. package/dist/src/typecheck/utils.d.ts +45 -0
  764. package/dist/src/typecheck/utils.d.ts.map +1 -0
  765. package/dist/src/typecheck/utils.js +110 -0
  766. package/dist/src/typecheck/utils.js.map +1 -0
  767. package/dist/src/typecheck/workflow.d.ts +8 -0
  768. package/dist/src/typecheck/workflow.d.ts.map +1 -0
  769. package/dist/src/typecheck/workflow.js +247 -0
  770. package/dist/src/typecheck/workflow.js.map +1 -0
  771. package/dist/src/typecheck-pii.d.ts +3 -0
  772. package/dist/src/typecheck-pii.d.ts.map +1 -0
  773. package/dist/src/typecheck-pii.js +534 -0
  774. package/dist/src/typecheck-pii.js.map +1 -0
  775. package/dist/src/typecheck.d.ts +7 -0
  776. package/dist/src/typecheck.d.ts.map +1 -0
  777. package/dist/src/typecheck.js +2 -0
  778. package/dist/src/typecheck.js.map +1 -0
  779. package/dist/src/types/base.d.ts +423 -0
  780. package/dist/src/types/base.d.ts.map +1 -0
  781. package/dist/src/types/base.js +18 -0
  782. package/dist/src/types/base.js.map +1 -0
  783. package/dist/src/types.d.ts +531 -0
  784. package/dist/src/types.d.ts.map +1 -0
  785. package/dist/src/types.js +47 -0
  786. package/dist/src/types.js.map +1 -0
  787. package/dist/src/utils/logger.d.ts +28 -0
  788. package/dist/src/utils/logger.d.ts.map +1 -0
  789. package/dist/src/utils/logger.js +60 -0
  790. package/dist/src/utils/logger.js.map +1 -0
  791. package/dist/test/benchmark.d.ts +3 -0
  792. package/dist/test/benchmark.d.ts.map +1 -0
  793. package/dist/test/benchmark.js +106 -0
  794. package/dist/test/benchmark.js.map +1 -0
  795. package/dist/test/cli/commands/install.test.d.ts +2 -0
  796. package/dist/test/cli/commands/install.test.d.ts.map +1 -0
  797. package/dist/test/cli/commands/install.test.js +97 -0
  798. package/dist/test/cli/commands/install.test.js.map +1 -0
  799. package/dist/test/cli/commands/list.test.d.ts +2 -0
  800. package/dist/test/cli/commands/list.test.d.ts.map +1 -0
  801. package/dist/test/cli/commands/list.test.js +98 -0
  802. package/dist/test/cli/commands/list.test.js.map +1 -0
  803. package/dist/test/cli/commands/search.test.d.ts +2 -0
  804. package/dist/test/cli/commands/search.test.d.ts.map +1 -0
  805. package/dist/test/cli/commands/search.test.js +133 -0
  806. package/dist/test/cli/commands/search.test.js.map +1 -0
  807. package/dist/test/cli/commands/update.test.d.ts +2 -0
  808. package/dist/test/cli/commands/update.test.d.ts.map +1 -0
  809. package/dist/test/cli/commands/update.test.js +205 -0
  810. package/dist/test/cli/commands/update.test.js.map +1 -0
  811. package/dist/test/cli/integration.test.d.ts +2 -0
  812. package/dist/test/cli/integration.test.d.ts.map +1 -0
  813. package/dist/test/cli/integration.test.js +51 -0
  814. package/dist/test/cli/integration.test.js.map +1 -0
  815. package/dist/test/cli/registry-utils.d.ts +6 -0
  816. package/dist/test/cli/registry-utils.d.ts.map +1 -0
  817. package/dist/test/cli/registry-utils.js +35 -0
  818. package/dist/test/cli/registry-utils.js.map +1 -0
  819. package/dist/test/cli/utils/error-handler.test.d.ts +2 -0
  820. package/dist/test/cli/utils/error-handler.test.d.ts.map +1 -0
  821. package/dist/test/cli/utils/error-handler.test.js +108 -0
  822. package/dist/test/cli/utils/error-handler.test.js.map +1 -0
  823. package/dist/test/compiler/depends-on.test.d.ts +2 -0
  824. package/dist/test/compiler/depends-on.test.d.ts.map +1 -0
  825. package/dist/test/compiler/depends-on.test.js +184 -0
  826. package/dist/test/compiler/depends-on.test.js.map +1 -0
  827. package/dist/test/compiler/inventory-capability.test.d.ts +2 -0
  828. package/dist/test/compiler/inventory-capability.test.d.ts.map +1 -0
  829. package/dist/test/compiler/inventory-capability.test.js +22 -0
  830. package/dist/test/compiler/inventory-capability.test.js.map +1 -0
  831. package/dist/test/compiler/payment-capability.test.d.ts +2 -0
  832. package/dist/test/compiler/payment-capability.test.d.ts.map +1 -0
  833. package/dist/test/compiler/payment-capability.test.js +22 -0
  834. package/dist/test/compiler/payment-capability.test.js.map +1 -0
  835. package/dist/test/compiler/workflow-emitter-helpers.d.ts +3 -0
  836. package/dist/test/compiler/workflow-emitter-helpers.d.ts.map +1 -0
  837. package/dist/test/compiler/workflow-emitter-helpers.js +44 -0
  838. package/dist/test/compiler/workflow-emitter-helpers.js.map +1 -0
  839. package/dist/test/e2e/package-management.test.d.ts +2 -0
  840. package/dist/test/e2e/package-management.test.d.ts.map +1 -0
  841. package/dist/test/e2e/package-management.test.js +51 -0
  842. package/dist/test/e2e/package-management.test.js.map +1 -0
  843. package/dist/test/e2e/runner/golden-runner.d.ts +3 -0
  844. package/dist/test/e2e/runner/golden-runner.d.ts.map +1 -0
  845. package/dist/test/e2e/runner/golden-runner.js +212 -0
  846. package/dist/test/e2e/runner/golden-runner.js.map +1 -0
  847. package/dist/test/fuzz/formatter-fuzz.test.d.ts +3 -0
  848. package/dist/test/fuzz/formatter-fuzz.test.d.ts.map +1 -0
  849. package/dist/test/fuzz/formatter-fuzz.test.js +44 -0
  850. package/dist/test/fuzz/formatter-fuzz.test.js.map +1 -0
  851. package/dist/test/fuzz/fuzz.test.d.ts +3 -0
  852. package/dist/test/fuzz/fuzz.test.d.ts.map +1 -0
  853. package/dist/test/fuzz/fuzz.test.js +141 -0
  854. package/dist/test/fuzz/fuzz.test.js.map +1 -0
  855. package/dist/test/fuzz/lossless-fuzz.test.d.ts +3 -0
  856. package/dist/test/fuzz/lossless-fuzz.test.d.ts.map +1 -0
  857. package/dist/test/fuzz/lossless-fuzz.test.js +116 -0
  858. package/dist/test/fuzz/lossless-fuzz.test.js.map +1 -0
  859. package/dist/test/generators.d.ts +53 -0
  860. package/dist/test/generators.d.ts.map +1 -0
  861. package/dist/test/generators.js +253 -0
  862. package/dist/test/generators.js.map +1 -0
  863. package/dist/test/helpers/test-factories.d.ts +24 -0
  864. package/dist/test/helpers/test-factories.d.ts.map +1 -0
  865. package/dist/test/helpers/test-factories.js +30 -0
  866. package/dist/test/helpers/test-factories.js.map +1 -0
  867. package/dist/test/helpers/test-utils.d.ts +19 -0
  868. package/dist/test/helpers/test-utils.d.ts.map +1 -0
  869. package/dist/test/helpers/test-utils.js +30 -0
  870. package/dist/test/helpers/test-utils.js.map +1 -0
  871. package/dist/test/integration/capabilities/capabilities.test.d.ts +3 -0
  872. package/dist/test/integration/capabilities/capabilities.test.d.ts.map +1 -0
  873. package/dist/test/integration/capabilities/capabilities.test.js +63 -0
  874. package/dist/test/integration/capabilities/capabilities.test.js.map +1 -0
  875. package/dist/test/integration/capabilities/config-service.test.d.ts +11 -0
  876. package/dist/test/integration/capabilities/config-service.test.d.ts.map +1 -0
  877. package/dist/test/integration/capabilities/config-service.test.js +125 -0
  878. package/dist/test/integration/capabilities/config-service.test.js.map +1 -0
  879. package/dist/test/integration/capabilities/effect-config.test.d.ts +3 -0
  880. package/dist/test/integration/capabilities/effect-config.test.d.ts.map +1 -0
  881. package/dist/test/integration/capabilities/effect-config.test.js +196 -0
  882. package/dist/test/integration/capabilities/effect-config.test.js.map +1 -0
  883. package/dist/test/integration/compliance/compliance-smoke.test.d.ts +14 -0
  884. package/dist/test/integration/compliance/compliance-smoke.test.d.ts.map +1 -0
  885. package/dist/test/integration/compliance/compliance-smoke.test.js +222 -0
  886. package/dist/test/integration/compliance/compliance-smoke.test.js.map +1 -0
  887. package/dist/test/integration/lsp/lsp-client-helper.test.d.ts +7 -0
  888. package/dist/test/integration/lsp/lsp-client-helper.test.d.ts.map +1 -0
  889. package/dist/test/integration/lsp/lsp-client-helper.test.js +45 -0
  890. package/dist/test/integration/lsp/lsp-client-helper.test.js.map +1 -0
  891. package/dist/test/integration/lsp/lsp-completion.test.d.ts +7 -0
  892. package/dist/test/integration/lsp/lsp-completion.test.d.ts.map +1 -0
  893. package/dist/test/integration/lsp/lsp-completion.test.js +178 -0
  894. package/dist/test/integration/lsp/lsp-completion.test.js.map +1 -0
  895. package/dist/test/integration/lsp/lsp-diagnostics.test.d.ts +7 -0
  896. package/dist/test/integration/lsp/lsp-diagnostics.test.d.ts.map +1 -0
  897. package/dist/test/integration/lsp/lsp-diagnostics.test.js +105 -0
  898. package/dist/test/integration/lsp/lsp-diagnostics.test.js.map +1 -0
  899. package/dist/test/integration/lsp/lsp-file-watcher.test.d.ts +7 -0
  900. package/dist/test/integration/lsp/lsp-file-watcher.test.d.ts.map +1 -0
  901. package/dist/test/integration/lsp/lsp-file-watcher.test.js +401 -0
  902. package/dist/test/integration/lsp/lsp-file-watcher.test.js.map +1 -0
  903. package/dist/test/integration/lsp/lsp-health-metrics.test.d.ts +7 -0
  904. package/dist/test/integration/lsp/lsp-health-metrics.test.d.ts.map +1 -0
  905. package/dist/test/integration/lsp/lsp-health-metrics.test.js +285 -0
  906. package/dist/test/integration/lsp/lsp-health-metrics.test.js.map +1 -0
  907. package/dist/test/integration/lsp/lsp-modules.test.d.ts +7 -0
  908. package/dist/test/integration/lsp/lsp-modules.test.d.ts.map +1 -0
  909. package/dist/test/integration/lsp/lsp-modules.test.js +193 -0
  910. package/dist/test/integration/lsp/lsp-modules.test.js.map +1 -0
  911. package/dist/test/integration/lsp/lsp-multi-rename.test.d.ts +3 -0
  912. package/dist/test/integration/lsp/lsp-multi-rename.test.d.ts.map +1 -0
  913. package/dist/test/integration/lsp/lsp-multi-rename.test.js +81 -0
  914. package/dist/test/integration/lsp/lsp-multi-rename.test.js.map +1 -0
  915. package/dist/test/integration/lsp/lsp-navigation.test.d.ts +7 -0
  916. package/dist/test/integration/lsp/lsp-navigation.test.d.ts.map +1 -0
  917. package/dist/test/integration/lsp/lsp-navigation.test.js +332 -0
  918. package/dist/test/integration/lsp/lsp-navigation.test.js.map +1 -0
  919. package/dist/test/integration/lsp/lsp-process-lifecycle.test.d.ts +7 -0
  920. package/dist/test/integration/lsp/lsp-process-lifecycle.test.d.ts.map +1 -0
  921. package/dist/test/integration/lsp/lsp-process-lifecycle.test.js +257 -0
  922. package/dist/test/integration/lsp/lsp-process-lifecycle.test.js.map +1 -0
  923. package/dist/test/integration/lsp/lsp-task-queue.test.d.ts +7 -0
  924. package/dist/test/integration/lsp/lsp-task-queue.test.d.ts.map +1 -0
  925. package/dist/test/integration/lsp/lsp-task-queue.test.js +267 -0
  926. package/dist/test/integration/lsp/lsp-task-queue.test.js.map +1 -0
  927. package/dist/test/integration/pipeline/pipeline.test.d.ts +13 -0
  928. package/dist/test/integration/pipeline/pipeline.test.d.ts.map +1 -0
  929. package/dist/test/integration/pipeline/pipeline.test.js +310 -0
  930. package/dist/test/integration/pipeline/pipeline.test.js.map +1 -0
  931. package/dist/test/perf/perf-utils.test.d.ts +3 -0
  932. package/dist/test/perf/perf-utils.test.d.ts.map +1 -0
  933. package/dist/test/perf/perf-utils.test.js +144 -0
  934. package/dist/test/perf/perf-utils.test.js.map +1 -0
  935. package/dist/test/performance/package-installer.perf.test.d.ts +9 -0
  936. package/dist/test/performance/package-installer.perf.test.d.ts.map +1 -0
  937. package/dist/test/performance/package-installer.perf.test.js +80 -0
  938. package/dist/test/performance/package-installer.perf.test.js.map +1 -0
  939. package/dist/test/policy-converter/round-trip.test.d.ts +2 -0
  940. package/dist/test/policy-converter/round-trip.test.d.ts.map +1 -0
  941. package/dist/test/policy-converter/round-trip.test.js +83 -0
  942. package/dist/test/policy-converter/round-trip.test.js.map +1 -0
  943. package/dist/test/property/lsp-props.test.d.ts +3 -0
  944. package/dist/test/property/lsp-props.test.d.ts.map +1 -0
  945. package/dist/test/property/lsp-props.test.js +43 -0
  946. package/dist/test/property/lsp-props.test.js.map +1 -0
  947. package/dist/test/property/property.test.d.ts +3 -0
  948. package/dist/test/property/property.test.d.ts.map +1 -0
  949. package/dist/test/property/property.test.js +456 -0
  950. package/dist/test/property/property.test.js.map +1 -0
  951. package/dist/test/regression/type-checker-golden.test.d.ts +8 -0
  952. package/dist/test/regression/type-checker-golden.test.d.ts.map +1 -0
  953. package/dist/test/regression/type-checker-golden.test.js +172 -0
  954. package/dist/test/regression/type-checker-golden.test.js.map +1 -0
  955. package/dist/test/type-checker/cross-module-packages.test.d.ts +2 -0
  956. package/dist/test/type-checker/cross-module-packages.test.d.ts.map +1 -0
  957. package/dist/test/type-checker/cross-module-packages.test.js +51 -0
  958. package/dist/test/type-checker/cross-module-packages.test.js.map +1 -0
  959. package/dist/test/type-checker/pii-propagation.test.d.ts +2 -0
  960. package/dist/test/type-checker/pii-propagation.test.d.ts.map +1 -0
  961. package/dist/test/type-checker/pii-propagation.test.js +656 -0
  962. package/dist/test/type-checker/pii-propagation.test.js.map +1 -0
  963. package/dist/test/unit/async/async-discipline.test.d.ts +12 -0
  964. package/dist/test/unit/async/async-discipline.test.d.ts.map +1 -0
  965. package/dist/test/unit/async/async-discipline.test.js +492 -0
  966. package/dist/test/unit/async/async-discipline.test.js.map +1 -0
  967. package/dist/test/unit/async/async-schedule.test.d.ts +7 -0
  968. package/dist/test/unit/async/async-schedule.test.d.ts.map +1 -0
  969. package/dist/test/unit/async/async-schedule.test.js +154 -0
  970. package/dist/test/unit/async/async-schedule.test.js.map +1 -0
  971. package/dist/test/unit/canonicalizer/canonicalizer.test.d.ts +2 -0
  972. package/dist/test/unit/canonicalizer/canonicalizer.test.d.ts.map +1 -0
  973. package/dist/test/unit/canonicalizer/canonicalizer.test.js +195 -0
  974. package/dist/test/unit/canonicalizer/canonicalizer.test.js.map +1 -0
  975. package/dist/test/unit/config/config-service.test.d.ts +2 -0
  976. package/dist/test/unit/config/config-service.test.d.ts.map +1 -0
  977. package/dist/test/unit/config/config-service.test.js +235 -0
  978. package/dist/test/unit/config/config-service.test.js.map +1 -0
  979. package/dist/test/unit/config/effect-config-cache.test.d.ts +2 -0
  980. package/dist/test/unit/config/effect-config-cache.test.d.ts.map +1 -0
  981. package/dist/test/unit/config/effect-config-cache.test.js +135 -0
  982. package/dist/test/unit/config/effect-config-cache.test.js.map +1 -0
  983. package/dist/test/unit/config/lexicons/i18n.test.d.ts +15 -0
  984. package/dist/test/unit/config/lexicons/i18n.test.d.ts.map +1 -0
  985. package/dist/test/unit/config/lexicons/i18n.test.js +318 -0
  986. package/dist/test/unit/config/lexicons/i18n.test.js.map +1 -0
  987. package/dist/test/unit/config/lexicons/identifiers/identifier-mapping.test.d.ts +7 -0
  988. package/dist/test/unit/config/lexicons/identifiers/identifier-mapping.test.d.ts.map +1 -0
  989. package/dist/test/unit/config/lexicons/identifiers/identifier-mapping.test.js +180 -0
  990. package/dist/test/unit/config/lexicons/identifiers/identifier-mapping.test.js.map +1 -0
  991. package/dist/test/unit/config/lexicons/zh-CN.test.d.ts +7 -0
  992. package/dist/test/unit/config/lexicons/zh-CN.test.d.ts.map +1 -0
  993. package/dist/test/unit/config/lexicons/zh-CN.test.js +922 -0
  994. package/dist/test/unit/config/lexicons/zh-CN.test.js.map +1 -0
  995. package/dist/test/unit/core_ir_json/core_ir_json.test.d.ts +2 -0
  996. package/dist/test/unit/core_ir_json/core_ir_json.test.d.ts.map +1 -0
  997. package/dist/test/unit/core_ir_json/core_ir_json.test.js +218 -0
  998. package/dist/test/unit/core_ir_json/core_ir_json.test.js.map +1 -0
  999. package/dist/test/unit/dependency-graph.test.d.ts +5 -0
  1000. package/dist/test/unit/dependency-graph.test.d.ts.map +1 -0
  1001. package/dist/test/unit/dependency-graph.test.js +105 -0
  1002. package/dist/test/unit/dependency-graph.test.js.map +1 -0
  1003. package/dist/test/unit/effect/effect-inference.test.d.ts +2 -0
  1004. package/dist/test/unit/effect/effect-inference.test.d.ts.map +1 -0
  1005. package/dist/test/unit/effect/effect-inference.test.js +480 -0
  1006. package/dist/test/unit/effect/effect-inference.test.js.map +1 -0
  1007. package/dist/test/unit/emitter/emitter.test.d.ts +2 -0
  1008. package/dist/test/unit/emitter/emitter.test.d.ts.map +1 -0
  1009. package/dist/test/unit/emitter/emitter.test.js +825 -0
  1010. package/dist/test/unit/emitter/emitter.test.js.map +1 -0
  1011. package/dist/test/unit/generator.test.d.ts +2 -0
  1012. package/dist/test/unit/generator.test.d.ts.map +1 -0
  1013. package/dist/test/unit/generator.test.js +322 -0
  1014. package/dist/test/unit/generator.test.js.map +1 -0
  1015. package/dist/test/unit/keyword-translator.test.d.ts +10 -0
  1016. package/dist/test/unit/keyword-translator.test.d.ts.map +1 -0
  1017. package/dist/test/unit/keyword-translator.test.js +251 -0
  1018. package/dist/test/unit/keyword-translator.test.js.map +1 -0
  1019. package/dist/test/unit/lexer/lexer.test.d.ts +2 -0
  1020. package/dist/test/unit/lexer/lexer.test.d.ts.map +1 -0
  1021. package/dist/test/unit/lexer/lexer.test.js +136 -0
  1022. package/dist/test/unit/lexer/lexer.test.js.map +1 -0
  1023. package/dist/test/unit/lexer/newline-handling.test.d.ts +12 -0
  1024. package/dist/test/unit/lexer/newline-handling.test.d.ts.map +1 -0
  1025. package/dist/test/unit/lexer/newline-handling.test.js +379 -0
  1026. package/dist/test/unit/lexer/newline-handling.test.js.map +1 -0
  1027. package/dist/test/unit/llm-providers.test.d.ts +2 -0
  1028. package/dist/test/unit/llm-providers.test.d.ts.map +1 -0
  1029. package/dist/test/unit/llm-providers.test.js +341 -0
  1030. package/dist/test/unit/llm-providers.test.js.map +1 -0
  1031. package/dist/test/unit/lockfile.test.d.ts +5 -0
  1032. package/dist/test/unit/lockfile.test.d.ts.map +1 -0
  1033. package/dist/test/unit/lockfile.test.js +116 -0
  1034. package/dist/test/unit/lockfile.test.js.map +1 -0
  1035. package/dist/test/unit/lowering/lowering.test.d.ts +2 -0
  1036. package/dist/test/unit/lowering/lowering.test.d.ts.map +1 -0
  1037. package/dist/test/unit/lowering/lowering.test.js +625 -0
  1038. package/dist/test/unit/lowering/lowering.test.js.map +1 -0
  1039. package/dist/test/unit/lsp/analysis.test.d.ts +2 -0
  1040. package/dist/test/unit/lsp/analysis.test.d.ts.map +1 -0
  1041. package/dist/test/unit/lsp/analysis.test.js +401 -0
  1042. package/dist/test/unit/lsp/analysis.test.js.map +1 -0
  1043. package/dist/test/unit/lsp/codeaction.test.d.ts +2 -0
  1044. package/dist/test/unit/lsp/codeaction.test.d.ts.map +1 -0
  1045. package/dist/test/unit/lsp/codeaction.test.js +542 -0
  1046. package/dist/test/unit/lsp/codeaction.test.js.map +1 -0
  1047. package/dist/test/unit/lsp/pii-diagnostics.test.d.ts +2 -0
  1048. package/dist/test/unit/lsp/pii-diagnostics.test.d.ts.map +1 -0
  1049. package/dist/test/unit/lsp/pii-diagnostics.test.js +222 -0
  1050. package/dist/test/unit/lsp/pii-diagnostics.test.js.map +1 -0
  1051. package/dist/test/unit/lsp/symbols.test.d.ts +2 -0
  1052. package/dist/test/unit/lsp/symbols.test.d.ts.map +1 -0
  1053. package/dist/test/unit/lsp/symbols.test.js +160 -0
  1054. package/dist/test/unit/lsp/symbols.test.js.map +1 -0
  1055. package/dist/test/unit/lsp/utils.test.d.ts +2 -0
  1056. package/dist/test/unit/lsp/utils.test.d.ts.map +1 -0
  1057. package/dist/test/unit/lsp/utils.test.js +182 -0
  1058. package/dist/test/unit/lsp/utils.test.js.map +1 -0
  1059. package/dist/test/unit/manifest-parser.test.d.ts +12 -0
  1060. package/dist/test/unit/manifest-parser.test.d.ts.map +1 -0
  1061. package/dist/test/unit/manifest-parser.test.js +285 -0
  1062. package/dist/test/unit/manifest-parser.test.js.map +1 -0
  1063. package/dist/test/unit/manifest-schema.test.d.ts +11 -0
  1064. package/dist/test/unit/manifest-schema.test.d.ts.map +1 -0
  1065. package/dist/test/unit/manifest-schema.test.js +171 -0
  1066. package/dist/test/unit/manifest-schema.test.js.map +1 -0
  1067. package/dist/test/unit/module-cache-packages.test.d.ts +2 -0
  1068. package/dist/test/unit/module-cache-packages.test.d.ts.map +1 -0
  1069. package/dist/test/unit/module-cache-packages.test.js +114 -0
  1070. package/dist/test/unit/module-cache-packages.test.js.map +1 -0
  1071. package/dist/test/unit/package-cache.test.d.ts +7 -0
  1072. package/dist/test/unit/package-cache.test.d.ts.map +1 -0
  1073. package/dist/test/unit/package-cache.test.js +192 -0
  1074. package/dist/test/unit/package-cache.test.js.map +1 -0
  1075. package/dist/test/unit/package-installer.test.d.ts +2 -0
  1076. package/dist/test/unit/package-installer.test.d.ts.map +1 -0
  1077. package/dist/test/unit/package-installer.test.js +263 -0
  1078. package/dist/test/unit/package-installer.test.js.map +1 -0
  1079. package/dist/test/unit/package-registry.test.d.ts +7 -0
  1080. package/dist/test/unit/package-registry.test.d.ts.map +1 -0
  1081. package/dist/test/unit/package-registry.test.js +198 -0
  1082. package/dist/test/unit/package-registry.test.js.map +1 -0
  1083. package/dist/test/unit/parser/parser.test.d.ts +2 -0
  1084. package/dist/test/unit/parser/parser.test.d.ts.map +1 -0
  1085. package/dist/test/unit/parser/parser.test.js +1117 -0
  1086. package/dist/test/unit/parser/parser.test.js.map +1 -0
  1087. package/dist/test/unit/parser/type-inference.test.d.ts +5 -0
  1088. package/dist/test/unit/parser/type-inference.test.d.ts.map +1 -0
  1089. package/dist/test/unit/parser/type-inference.test.js +262 -0
  1090. package/dist/test/unit/parser/type-inference.test.js.map +1 -0
  1091. package/dist/test/unit/prompt-manager.test.d.ts +2 -0
  1092. package/dist/test/unit/prompt-manager.test.d.ts.map +1 -0
  1093. package/dist/test/unit/prompt-manager.test.js +137 -0
  1094. package/dist/test/unit/prompt-manager.test.js.map +1 -0
  1095. package/dist/test/unit/provenance-integration.test.d.ts +2 -0
  1096. package/dist/test/unit/provenance-integration.test.d.ts.map +1 -0
  1097. package/dist/test/unit/provenance-integration.test.js +181 -0
  1098. package/dist/test/unit/provenance-integration.test.js.map +1 -0
  1099. package/dist/test/unit/provenance.test.d.ts +2 -0
  1100. package/dist/test/unit/provenance.test.d.ts.map +1 -0
  1101. package/dist/test/unit/provenance.test.js +170 -0
  1102. package/dist/test/unit/provenance.test.js.map +1 -0
  1103. package/dist/test/unit/resolver.test.d.ts +5 -0
  1104. package/dist/test/unit/resolver.test.d.ts.map +1 -0
  1105. package/dist/test/unit/resolver.test.js +48 -0
  1106. package/dist/test/unit/resolver.test.js.map +1 -0
  1107. package/dist/test/unit/typecheck/async-discipline-extended.test.d.ts +2 -0
  1108. package/dist/test/unit/typecheck/async-discipline-extended.test.d.ts.map +1 -0
  1109. package/dist/test/unit/typecheck/async-discipline-extended.test.js +69 -0
  1110. package/dist/test/unit/typecheck/async-discipline-extended.test.js.map +1 -0
  1111. package/dist/test/unit/typecheck/effects-and-capabilities.test.d.ts +2 -0
  1112. package/dist/test/unit/typecheck/effects-and-capabilities.test.d.ts.map +1 -0
  1113. package/dist/test/unit/typecheck/effects-and-capabilities.test.js +191 -0
  1114. package/dist/test/unit/typecheck/effects-and-capabilities.test.js.map +1 -0
  1115. package/dist/test/unit/typecheck/regression-fixes.test.d.ts +11 -0
  1116. package/dist/test/unit/typecheck/regression-fixes.test.d.ts.map +1 -0
  1117. package/dist/test/unit/typecheck/regression-fixes.test.js +456 -0
  1118. package/dist/test/unit/typecheck/regression-fixes.test.js.map +1 -0
  1119. package/dist/test/unit/typecheck/should-enforce-pii.test.d.ts +2 -0
  1120. package/dist/test/unit/typecheck/should-enforce-pii.test.d.ts.map +1 -0
  1121. package/dist/test/unit/typecheck/should-enforce-pii.test.js +167 -0
  1122. package/dist/test/unit/typecheck/should-enforce-pii.test.js.map +1 -0
  1123. package/dist/test/unit/typecheck/symbol-table.test.d.ts +7 -0
  1124. package/dist/test/unit/typecheck/symbol-table.test.d.ts.map +1 -0
  1125. package/dist/test/unit/typecheck/symbol-table.test.js +145 -0
  1126. package/dist/test/unit/typecheck/symbol-table.test.js.map +1 -0
  1127. package/dist/test/unit/typecheck/type-inference.test.d.ts +2 -0
  1128. package/dist/test/unit/typecheck/type-inference.test.d.ts.map +1 -0
  1129. package/dist/test/unit/typecheck/type-inference.test.js +122 -0
  1130. package/dist/test/unit/typecheck/type-inference.test.js.map +1 -0
  1131. package/dist/test/unit/typecheck/type-system-extended.test.d.ts +8 -0
  1132. package/dist/test/unit/typecheck/type-system-extended.test.d.ts.map +1 -0
  1133. package/dist/test/unit/typecheck/type-system-extended.test.js +131 -0
  1134. package/dist/test/unit/typecheck/type-system-extended.test.js.map +1 -0
  1135. package/dist/test/unit/typecheck/type-system.test.d.ts +9 -0
  1136. package/dist/test/unit/typecheck/type-system.test.d.ts.map +1 -0
  1137. package/dist/test/unit/typecheck/type-system.test.js +617 -0
  1138. package/dist/test/unit/typecheck/type-system.test.js.map +1 -0
  1139. package/dist/test/unit/typecheck/typecheck-advanced.test.d.ts +2 -0
  1140. package/dist/test/unit/typecheck/typecheck-advanced.test.d.ts.map +1 -0
  1141. package/dist/test/unit/typecheck/typecheck-advanced.test.js +125 -0
  1142. package/dist/test/unit/typecheck/typecheck-advanced.test.js.map +1 -0
  1143. package/dist/test/unit/validator.test.d.ts +2 -0
  1144. package/dist/test/unit/validator.test.d.ts.map +1 -0
  1145. package/dist/test/unit/validator.test.js +154 -0
  1146. package/dist/test/unit/validator.test.js.map +1 -0
  1147. package/dist/test/unit/version-utils.test.d.ts +12 -0
  1148. package/dist/test/unit/version-utils.test.d.ts.map +1 -0
  1149. package/dist/test/unit/version-utils.test.js +112 -0
  1150. package/dist/test/unit/version-utils.test.js.map +1 -0
  1151. package/package.json +153 -0
@@ -0,0 +1,825 @@
1
+ import { describe, it } from 'node:test';
2
+ import assert from 'node:assert/strict';
3
+ import fs from 'node:fs';
4
+ import os from 'node:os';
5
+ import path from 'node:path';
6
+ import { emitJava } from '../../../src/jvm/emitter.js';
7
+ import { Core } from '../../../src/core/core_ir.js';
8
+ function createTempDir() {
9
+ const base = fs.mkdtempSync(path.join(os.tmpdir(), 'aster-emitter-'));
10
+ return base;
11
+ }
12
+ function readFile(filePath) {
13
+ return fs.readFileSync(filePath, 'utf8');
14
+ }
15
+ async function emitToTemp(module) {
16
+ const outDir = createTempDir();
17
+ let cleaned = false;
18
+ return {
19
+ outDir,
20
+ cleanup: () => {
21
+ if (!cleaned) {
22
+ fs.rmSync(outDir, { recursive: true, force: true });
23
+ cleaned = true;
24
+ }
25
+ },
26
+ };
27
+ }
28
+ async function emitJavaClassContent(module, relativePath) {
29
+ const { outDir, cleanup } = await emitToTemp(module);
30
+ try {
31
+ await emitJava(module, outDir);
32
+ const filePath = path.join(outDir, ...relativePath);
33
+ return readFile(filePath);
34
+ }
35
+ finally {
36
+ cleanup();
37
+ }
38
+ }
39
+ describe('JVM 代码生成器', () => {
40
+ it('应生成数据类型对应的 Java 类', async () => {
41
+ const module = Core.Module('test.emitter.data', [
42
+ Core.Data('User', [
43
+ { name: 'id', type: Core.TypeName('Text'), annotations: [] },
44
+ { name: 'age', type: Core.TypeName('Int'), annotations: [] },
45
+ ]),
46
+ ]);
47
+ const { outDir, cleanup } = await emitToTemp(module);
48
+ try {
49
+ await emitJava(module, outDir);
50
+ const filePath = path.join(outDir, 'test', 'emitter', 'data', 'User.java');
51
+ assert.equal(fs.existsSync(filePath), true);
52
+ const content = readFile(filePath);
53
+ assert.equal(content.includes('public final class User'), true);
54
+ assert.equal(content.includes('public final String id;'), true);
55
+ }
56
+ finally {
57
+ cleanup();
58
+ }
59
+ });
60
+ it('应生成枚举声明', async () => {
61
+ const module = Core.Module('test.emitter.enum', [Core.Enum('Status', ['Pending', 'Success'])]);
62
+ const { outDir, cleanup } = await emitToTemp(module);
63
+ try {
64
+ await emitJava(module, outDir);
65
+ const filePath = path.join(outDir, 'test', 'emitter', 'enum', 'Status.java');
66
+ const content = readFile(filePath);
67
+ assert.equal(content.includes('public enum Status'), true);
68
+ assert.equal(content.includes('Pending'), true);
69
+ }
70
+ finally {
71
+ cleanup();
72
+ }
73
+ });
74
+ it('应生成函数包装类并渲染主体', async () => {
75
+ const funcBody = Core.Block([Core.Return(Core.String('pong'))]);
76
+ const funcDecl = Core.Func('ping', [], [{ name: 'input', type: Core.TypeName('Text'), annotations: [] }], Core.TypeName('Text'), [], funcBody);
77
+ const module = Core.Module('test.emitter.func', [funcDecl]);
78
+ const { outDir, cleanup } = await emitToTemp(module);
79
+ try {
80
+ await emitJava(module, outDir);
81
+ const filePath = path.join(outDir, 'test', 'emitter', 'func', 'ping_fn.java');
82
+ const content = readFile(filePath);
83
+ assert.equal(content.includes('public static String ping'), true);
84
+ assert.equal(content.includes('return "pong";'), true);
85
+ }
86
+ finally {
87
+ cleanup();
88
+ }
89
+ });
90
+ it('应为枚举匹配生成 switch 结构', async () => {
91
+ const enumDecl = Core.Enum('Status', ['Ok', 'Err']);
92
+ const matcher = Core.Func('classify', [], [{ name: 'status', type: Core.TypeName('Status'), annotations: [] }], Core.TypeName('int'), [], Core.Block([
93
+ Core.Match(Core.Name('status'), [
94
+ Core.Case(Core.PatName('Ok'), Core.Return(Core.Int(1))),
95
+ Core.Case(Core.PatName('Err'), Core.Return(Core.Int(0))),
96
+ ]),
97
+ ]));
98
+ const module = Core.Module('test.emitter.match', [enumDecl, matcher]);
99
+ const { outDir, cleanup } = await emitToTemp(module);
100
+ try {
101
+ await emitJava(module, outDir);
102
+ const filePath = path.join(outDir, 'test', 'emitter', 'match', 'classify_fn.java');
103
+ const content = readFile(filePath);
104
+ assert.equal(content.includes('switch((Status)__scrut)'), true);
105
+ assert.equal(content.includes('case Status.Ok'), true);
106
+ assert.equal(content.includes('return 1;'), true);
107
+ }
108
+ finally {
109
+ cleanup();
110
+ }
111
+ });
112
+ it('嵌套数据匹配应生成 instanceof 守卫与解构', async () => {
113
+ const pairData = Core.Data('Pair', [
114
+ { name: 'left', type: Core.TypeName('Object'), annotations: [] },
115
+ { name: 'right', type: Core.TypeName('Object'), annotations: [] },
116
+ ]);
117
+ const matcher = Core.Func('unwrap', [], [{ name: 'value', type: Core.TypeName('Pair'), annotations: [] }], Core.TypeName('Object'), [], Core.Block([
118
+ Core.Match(Core.Name('value'), [
119
+ Core.Case(Core.PatCtor('Pair', [], [
120
+ Core.PatName('a'),
121
+ Core.PatCtor('Pair', ['innerLeft']),
122
+ ]), Core.Return(Core.Name('innerLeft'))),
123
+ ]),
124
+ ]));
125
+ const module = Core.Module('test.emitter.nested_match', [pairData, matcher]);
126
+ const { outDir, cleanup } = await emitToTemp(module);
127
+ try {
128
+ await emitJava(module, outDir);
129
+ const filePath = path.join(outDir, 'test', 'emitter', 'nested_match', 'unwrap_fn.java');
130
+ const content = readFile(filePath);
131
+ assert.equal(content.includes('if (__scrut instanceof Pair)'), true);
132
+ assert.equal(content.includes('var __tmp = (Pair)__scrut;'), true);
133
+ assert.equal(content.includes('__tmp_1'), true);
134
+ }
135
+ finally {
136
+ cleanup();
137
+ }
138
+ });
139
+ it('数据类应对 List 与 Map 字段生成泛型类型', async () => {
140
+ const module = Core.Module('test.emitter.collections', [
141
+ Core.Data('Catalog', [
142
+ { name: 'items', type: Core.List(Core.TypeName('Int')), annotations: [] },
143
+ {
144
+ name: 'metadata',
145
+ type: Core.Map(Core.TypeName('Text'), Core.TypeName('Text')),
146
+ annotations: [],
147
+ },
148
+ ]),
149
+ ]);
150
+ const { outDir, cleanup } = await emitToTemp(module);
151
+ try {
152
+ await emitJava(module, outDir);
153
+ const filePath = path.join(outDir, 'test', 'emitter', 'collections', 'Catalog.java');
154
+ const content = readFile(filePath);
155
+ assert.equal(content.includes('java.util.List<int> items;'), true);
156
+ assert.equal(content.includes('java.util.Map<String, String> metadata;'), true);
157
+ }
158
+ finally {
159
+ cleanup();
160
+ }
161
+ });
162
+ it('Scope 语句应串联内部语句输出', async () => {
163
+ const scopedBody = Core.Block([
164
+ Core.Scope([
165
+ Core.Let('temp', Core.Int(1)),
166
+ Core.Set('result', Core.Int(2)),
167
+ ]),
168
+ Core.Return(Core.Name('result')),
169
+ ]);
170
+ const funcDecl = Core.Func('withScope', [], [{ name: 'result', type: Core.TypeName('int'), annotations: [] }], Core.TypeName('int'), [], scopedBody);
171
+ const module = Core.Module('test.emitter.scope', [funcDecl]);
172
+ const { outDir, cleanup } = await emitToTemp(module);
173
+ try {
174
+ await emitJava(module, outDir);
175
+ const filePath = path.join(outDir, 'test', 'emitter', 'scope', 'withScope_fn.java');
176
+ const content = readFile(filePath);
177
+ assert.equal(content.includes('var temp = 1;'), true);
178
+ assert.equal(content.includes('result = 2;'), true);
179
+ }
180
+ finally {
181
+ cleanup();
182
+ }
183
+ });
184
+ it('Start 与 Wait 语句暂未实现时应输出占位注释', async () => {
185
+ const funcDecl = Core.Func('asyncStub', [], [], Core.TypeName('void'), [], Core.Block([
186
+ Core.Start('task', Core.Name('producer')),
187
+ Core.Wait(['task']),
188
+ ]));
189
+ const module = Core.Module('test.emitter.async', [funcDecl]);
190
+ const { outDir, cleanup } = await emitToTemp(module);
191
+ try {
192
+ await emitJava(module, outDir);
193
+ const filePath = path.join(outDir, 'test', 'emitter', 'async', 'asyncStub_fn.java');
194
+ const content = readFile(filePath);
195
+ assert.equal(content.includes('// async not implemented in MVP'), true);
196
+ }
197
+ finally {
198
+ cleanup();
199
+ }
200
+ });
201
+ it('Await 表达式当前回退为 null 占位', async () => {
202
+ const funcDecl = Core.Func('awaitFallback', [], [], Core.TypeName('Object'), [], Core.Block([Core.Return(Core.Await(Core.Name('future')))]));
203
+ const module = Core.Module('test.emitter.await', [funcDecl]);
204
+ const { outDir, cleanup } = await emitToTemp(module);
205
+ try {
206
+ await emitJava(module, outDir);
207
+ const filePath = path.join(outDir, 'test', 'emitter', 'await', 'awaitFallback_fn.java');
208
+ const content = readFile(filePath);
209
+ assert.equal(content.includes('return null;'), true);
210
+ }
211
+ finally {
212
+ cleanup();
213
+ }
214
+ });
215
+ it('javaType 应将 Maybe<Text> 映射为可空字符串', async () => {
216
+ const module = Core.Module('test.emitter.java_type_maybe_text', [
217
+ Core.Data('MaybeSample', [
218
+ { name: 'value', type: Core.Maybe(Core.TypeName('Text')), annotations: [] },
219
+ ]),
220
+ ]);
221
+ const content = await emitJavaClassContent(module, [
222
+ 'test',
223
+ 'emitter',
224
+ 'java_type_maybe_text',
225
+ 'MaybeSample.java',
226
+ ]);
227
+ assert.equal(content.includes('public final String value;'), true);
228
+ });
229
+ it('javaType 应将 Maybe 自定义类型保持引用类型', async () => {
230
+ const module = Core.Module('test.emitter.java_type_maybe_custom', [
231
+ Core.Data('Profile', [
232
+ { name: 'name', type: Core.TypeName('Text'), annotations: [] },
233
+ ]),
234
+ Core.Data('Wrapper', [
235
+ { name: 'payload', type: Core.Maybe(Core.TypeName('Profile')), annotations: [] },
236
+ ]),
237
+ ]);
238
+ const content = await emitJavaClassContent(module, [
239
+ 'test',
240
+ 'emitter',
241
+ 'java_type_maybe_custom',
242
+ 'Wrapper.java',
243
+ ]);
244
+ assert.equal(content.includes('public final Profile payload;'), true);
245
+ });
246
+ it('javaType 应将 Option<Bool> 映射为布尔类型', async () => {
247
+ const module = Core.Module('test.emitter.java_type_option_bool', [
248
+ Core.Data('FlagHolder', [
249
+ { name: 'active', type: Core.Option(Core.TypeName('Bool')), annotations: [] },
250
+ ]),
251
+ ]);
252
+ const content = await emitJavaClassContent(module, [
253
+ 'test',
254
+ 'emitter',
255
+ 'java_type_option_bool',
256
+ 'FlagHolder.java',
257
+ ]);
258
+ assert.equal(content.includes('public final boolean active;'), true);
259
+ });
260
+ it('javaType 应将 Result<Text, Int> 映射为运行时包装', async () => {
261
+ const module = Core.Module('test.emitter.java_type_result', [
262
+ Core.Data('ActionResult', [
263
+ {
264
+ name: 'state',
265
+ type: Core.Result(Core.TypeName('Text'), Core.TypeName('Int')),
266
+ annotations: [],
267
+ },
268
+ ]),
269
+ ]);
270
+ const content = await emitJavaClassContent(module, [
271
+ 'test',
272
+ 'emitter',
273
+ 'java_type_result',
274
+ 'ActionResult.java',
275
+ ]);
276
+ assert.equal(content.includes('aster.runtime.Result<String, int> state;'), true);
277
+ });
278
+ it('Let 语句应生成局部变量声明', async () => {
279
+ const func = Core.Func('initCounter', [], [], Core.TypeName('int'), [], Core.Block([Core.Let('counter', Core.Int(0)), Core.Return(Core.Name('counter'))]));
280
+ const module = Core.Module('test.emitter.let_statement', [func]);
281
+ const content = await emitJavaClassContent(module, [
282
+ 'test',
283
+ 'emitter',
284
+ 'let_statement',
285
+ 'initCounter_fn.java',
286
+ ]);
287
+ assert.equal(content.includes('var counter = 0;'), true);
288
+ });
289
+ it('Set 语句应输出赋值语句', async () => {
290
+ const func = Core.Func('assignValue', [], [{ name: 'value', type: Core.TypeName('int'), annotations: [] }], Core.TypeName('int'), [], Core.Block([Core.Set('value', Core.Int(10)), Core.Return(Core.Name('value'))]));
291
+ const module = Core.Module('test.emitter.set_statement', [func]);
292
+ const content = await emitJavaClassContent(module, [
293
+ 'test',
294
+ 'emitter',
295
+ 'set_statement',
296
+ 'assignValue_fn.java',
297
+ ]);
298
+ assert.equal(content.includes('value = 10;'), true);
299
+ });
300
+ it('Set 语句应保留函数调用结果', async () => {
301
+ const func = Core.Func('updateValue', [], [], Core.TypeName('int'), [], Core.Block([
302
+ Core.Let('value', Core.Int(1)),
303
+ Core.Set('value', Core.Call(Core.Name('increment'), [Core.Name('value')])),
304
+ Core.Return(Core.Name('value')),
305
+ ]));
306
+ const module = Core.Module('test.emitter.set_call', [func]);
307
+ const content = await emitJavaClassContent(module, [
308
+ 'test',
309
+ 'emitter',
310
+ 'set_call',
311
+ 'updateValue_fn.java',
312
+ ]);
313
+ assert.equal(content.includes('value = increment(value);'), true);
314
+ });
315
+ it('If 语句应输出 else 分支结构', async () => {
316
+ const func = Core.Func('chooseValue', [], [{ name: 'flag', type: Core.TypeName('boolean'), annotations: [] }], Core.TypeName('int'), [], Core.Block([
317
+ Core.If(Core.Name('flag'), Core.Block([Core.Return(Core.Int(1))]), Core.Block([Core.Return(Core.Int(0))])),
318
+ ]));
319
+ const module = Core.Module('test.emitter.if_else', [func]);
320
+ const content = await emitJavaClassContent(module, [
321
+ 'test',
322
+ 'emitter',
323
+ 'if_else',
324
+ 'chooseValue_fn.java',
325
+ ]);
326
+ assert.equal(content.includes('if (flag) {'), true);
327
+ assert.equal(content.includes('} else {'), true);
328
+ });
329
+ it('If-else 语句应保持分支缩进', async () => {
330
+ const func = Core.Func('toggle', [], [], Core.TypeName('int'), [], Core.Block([
331
+ Core.Let('result', Core.Int(0)),
332
+ Core.If(Core.Bool(true), Core.Block([Core.Set('result', Core.Int(5))]), Core.Block([Core.Set('result', Core.Int(8))])),
333
+ Core.Return(Core.Name('result')),
334
+ ]));
335
+ const module = Core.Module('test.emitter.if_indent', [func]);
336
+ const content = await emitJavaClassContent(module, [
337
+ 'test',
338
+ 'emitter',
339
+ 'if_indent',
340
+ 'toggle_fn.java',
341
+ ]);
342
+ assert.equal(content.includes('if (true) {'), true);
343
+ assert.equal(content.includes('result = 5;'), true);
344
+ assert.equal(content.includes('result = 8;'), true);
345
+ });
346
+ it('枚举匹配无返回体时应生成 break 语句', async () => {
347
+ const enumDecl = Core.Enum('Status', ['Idle', 'Busy']);
348
+ const func = Core.Func('score', [], [{ name: 'status', type: Core.TypeName('Status'), annotations: [] }], Core.TypeName('int'), [], Core.Block([
349
+ Core.Let('result', Core.Int(0)),
350
+ Core.Match(Core.Name('status'), [
351
+ Core.Case(Core.PatName('Idle'), Core.Block([Core.Set('result', Core.Int(1))])),
352
+ Core.Case(Core.PatName('Busy'), Core.Block([Core.Set('result', Core.Int(2))])),
353
+ ]),
354
+ Core.Return(Core.Name('result')),
355
+ ]));
356
+ const module = Core.Module('test.emitter.enum_break', [enumDecl, func]);
357
+ const content = await emitJavaClassContent(module, [
358
+ 'test',
359
+ 'emitter',
360
+ 'enum_break',
361
+ 'score_fn.java',
362
+ ]);
363
+ assert.equal(content.includes('switch((Status)__scrut)'), true);
364
+ assert.equal(content.includes('break;'), true);
365
+ });
366
+ it('整数模式匹配应转换为 switch 结构', async () => {
367
+ const func = Core.Func('mapCode', [], [{ name: 'code', type: Core.TypeName('int'), annotations: [] }], Core.TypeName('int'), [], Core.Block([
368
+ Core.Let('result', Core.Int(0)),
369
+ Core.Match(Core.Name('code'), [
370
+ Core.Case(Core.PatInt(1), Core.Block([Core.Set('result', Core.Int(10))])),
371
+ Core.Case(Core.PatInt(2), Core.Block([Core.Set('result', Core.Int(20))])),
372
+ ]),
373
+ Core.Return(Core.Name('result')),
374
+ ]));
375
+ const module = Core.Module('test.emitter.int_switch', [func]);
376
+ const content = await emitJavaClassContent(module, [
377
+ 'test',
378
+ 'emitter',
379
+ 'int_switch',
380
+ 'mapCode_fn.java',
381
+ ]);
382
+ assert.equal(content.includes('switch (code)'), true);
383
+ assert.equal(content.includes('default: break;'), true);
384
+ });
385
+ it('PatNull 与 PatName fallback 应添加空检查', async () => {
386
+ const func = Core.Func('describe', [], [{ name: 'input', type: Core.TypeName('Object'), annotations: [] }], Core.TypeName('String'), [], Core.Block([
387
+ Core.Match(Core.Name('input'), [
388
+ Core.Case(Core.PatNull(), Core.Return(Core.String('missing'))),
389
+ Core.Case(Core.PatName('value'), Core.Return(Core.String('present'))),
390
+ ]),
391
+ Core.Return(Core.String('fallback')),
392
+ ]));
393
+ const module = Core.Module('test.emitter.pat_null_name', [func]);
394
+ const content = await emitJavaClassContent(module, [
395
+ 'test',
396
+ 'emitter',
397
+ 'pat_null_name',
398
+ 'describe_fn.java',
399
+ ]);
400
+ assert.equal(content.includes('if (__scrut == null)'), true);
401
+ assert.equal(content.includes('if (__scrut != null)'), true);
402
+ });
403
+ it('Ok 与 Err 构造应生成运行时包装', async () => {
404
+ const func = Core.Func('wrap', [], [], Core.TypeName('Object'), [], Core.Block([
405
+ Core.Let('okResult', Core.Ok(Core.Int(1))),
406
+ Core.Let('errResult', Core.Err(Core.String('fail'))),
407
+ Core.Return(Core.Name('okResult')),
408
+ ]));
409
+ const module = Core.Module('test.emitter.ok_err', [func]);
410
+ const content = await emitJavaClassContent(module, [
411
+ 'test',
412
+ 'emitter',
413
+ 'ok_err',
414
+ 'wrap_fn.java',
415
+ ]);
416
+ assert.equal(content.includes('new aster.runtime.Ok<>(1)'), true);
417
+ assert.equal(content.includes('new aster.runtime.Err<>("fail")'), true);
418
+ });
419
+ it('Some 与 None 应对应可空值表达', async () => {
420
+ const func = Core.Func('optionUsage', [], [], Core.TypeName('Object'), [], Core.Block([
421
+ Core.Let('someValue', Core.Some(Core.String('done'))),
422
+ Core.Let('noneValue', Core.None()),
423
+ Core.Return(Core.Name('someValue')),
424
+ ]));
425
+ const module = Core.Module('test.emitter.some_none', [func]);
426
+ const content = await emitJavaClassContent(module, [
427
+ 'test',
428
+ 'emitter',
429
+ 'some_none',
430
+ 'optionUsage_fn.java',
431
+ ]);
432
+ assert.equal(content.includes('var someValue = "done";'), true);
433
+ assert.equal(content.includes('var noneValue = null;'), true);
434
+ });
435
+ it('Text.concat 应拼接字符串', async () => {
436
+ const func = Core.Func('joinText', [], [], Core.TypeName('String'), [], Core.Block([
437
+ Core.Return(Core.Call(Core.Name('Text.concat'), [Core.String('A'), Core.String('B')])),
438
+ ]));
439
+ const module = Core.Module('test.emitter.text_concat', [func]);
440
+ const content = await emitJavaClassContent(module, [
441
+ 'test',
442
+ 'emitter',
443
+ 'text_concat',
444
+ 'joinText_fn.java',
445
+ ]);
446
+ assert.equal(content.includes('return ("A" + "B");'), true);
447
+ });
448
+ it('Text.replace 应映射为 Java replace', async () => {
449
+ const func = Core.Func('replace', [], [], Core.TypeName('String'), [], Core.Block([
450
+ Core.Return(Core.Call(Core.Name('Text.replace'), [
451
+ Core.Name('input'),
452
+ Core.String('X'),
453
+ Core.String('Y'),
454
+ ])),
455
+ ]));
456
+ const module = Core.Module('test.emitter.text_replace', [func]);
457
+ const content = await emitJavaClassContent(module, [
458
+ 'test',
459
+ 'emitter',
460
+ 'text_replace',
461
+ 'replace_fn.java',
462
+ ]);
463
+ assert.equal(content.includes('return input.replace("X", "Y");'), true);
464
+ });
465
+ it('Text.split 应转换为 Arrays.asList', async () => {
466
+ const func = Core.Func('split', [], [], Core.TypeName('Object'), [], Core.Block([
467
+ Core.Return(Core.Call(Core.Name('Text.split'), [Core.Name('path'), Core.String('/')])),
468
+ ]));
469
+ const module = Core.Module('test.emitter.text_split', [func]);
470
+ const content = await emitJavaClassContent(module, [
471
+ 'test',
472
+ 'emitter',
473
+ 'text_split',
474
+ 'split_fn.java',
475
+ ]);
476
+ assert.equal(content.includes('java.util.Arrays.asList(path.split("/"))'), true);
477
+ });
478
+ it('Text.length 应映射为 length 方法', async () => {
479
+ const func = Core.Func('length', [], [], Core.TypeName('int'), [], Core.Block([
480
+ Core.Return(Core.Call(Core.Name('Text.length'), [Core.Name('input')])),
481
+ ]));
482
+ const module = Core.Module('test.emitter.text_length', [func]);
483
+ const content = await emitJavaClassContent(module, [
484
+ 'test',
485
+ 'emitter',
486
+ 'text_length',
487
+ 'length_fn.java',
488
+ ]);
489
+ assert.equal(content.includes('return input.length();'), true);
490
+ });
491
+ it('Text.contains 应映射为 contains 调用', async () => {
492
+ const func = Core.Func('contains', [], [], Core.TypeName('boolean'), [], Core.Block([
493
+ Core.Return(Core.Call(Core.Name('Text.contains'), [Core.Name('source'), Core.String('needle')])),
494
+ ]));
495
+ const module = Core.Module('test.emitter.text_contains', [func]);
496
+ const content = await emitJavaClassContent(module, [
497
+ 'test',
498
+ 'emitter',
499
+ 'text_contains',
500
+ 'contains_fn.java',
501
+ ]);
502
+ assert.equal(content.includes('return source.contains("needle");'), true);
503
+ });
504
+ it('Text.trim 未特化时应保留直接调用', async () => {
505
+ const func = Core.Func('trim', [], [], Core.TypeName('String'), [], Core.Block([
506
+ Core.Return(Core.Call(Core.Name('Text.trim'), [Core.String(' value ')])),
507
+ ]));
508
+ const module = Core.Module('test.emitter.text_trim', [func]);
509
+ const content = await emitJavaClassContent(module, [
510
+ 'test',
511
+ 'emitter',
512
+ 'text_trim',
513
+ 'trim_fn.java',
514
+ ]);
515
+ assert.equal(content.includes('return Text.trim(" value ");'), true);
516
+ });
517
+ it('javaType 应将 TypeVar 映射为 Object', async () => {
518
+ const func = Core.Func('identity', ['T'], [{ name: 'value', type: Core.TypeVar('T'), annotations: [] }], Core.TypeVar('T'), [], Core.Block([Core.Return(Core.Name('value'))]));
519
+ const module = Core.Module('test.emitter.java_type_var', [func]);
520
+ const content = await emitJavaClassContent(module, [
521
+ 'test',
522
+ 'emitter',
523
+ 'java_type_var',
524
+ 'identity_fn.java',
525
+ ]);
526
+ assert.equal(content.includes('public static Object identity(Object value)'), true);
527
+ });
528
+ it('javaType 应将 TypeApp 映射为 Object', async () => {
529
+ const func = Core.Func('consume', [], [
530
+ {
531
+ name: 'future',
532
+ type: Core.TypeApp('Future', [Core.TypeName('Text')]),
533
+ annotations: [],
534
+ },
535
+ ], Core.TypeName('void'), [], Core.Block([Core.Return(Core.Null())]));
536
+ const module = Core.Module('test.emitter.java_type_app', [func]);
537
+ const content = await emitJavaClassContent(module, [
538
+ 'test',
539
+ 'emitter',
540
+ 'java_type_app',
541
+ 'consume_fn.java',
542
+ ]);
543
+ assert.equal(content.includes('Object future'), true);
544
+ });
545
+ it('javaType 应根据参数数量选择 Fn 接口', async () => {
546
+ const fnType = {
547
+ kind: 'FuncType',
548
+ params: [Core.TypeName('Text'), Core.TypeName('Int')],
549
+ ret: Core.TypeName('Bool'),
550
+ };
551
+ const func = Core.Func('apply', [], [{ name: 'fn', type: fnType, annotations: [] }], Core.TypeName('boolean'), [], Core.Block([Core.Return(Core.Bool(true))]));
552
+ const module = Core.Module('test.emitter.java_type_func', [func]);
553
+ const content = await emitJavaClassContent(module, [
554
+ 'test',
555
+ 'emitter',
556
+ 'java_type_func',
557
+ 'apply_fn.java',
558
+ ]);
559
+ assert.equal(content.includes('aster.runtime.Fn2 fn'), true);
560
+ });
561
+ it('List.length 应映射为 size 调用', async () => {
562
+ const func = Core.Func('size', [], [{ name: 'items', type: Core.List(Core.TypeName('Object')), annotations: [] }], Core.TypeName('int'), [], Core.Block([
563
+ Core.Return(Core.Call(Core.Name('List.length'), [Core.Name('items')])),
564
+ ]));
565
+ const module = Core.Module('test.emitter.list_length', [func]);
566
+ const content = await emitJavaClassContent(module, [
567
+ 'test',
568
+ 'emitter',
569
+ 'list_length',
570
+ 'size_fn.java',
571
+ ]);
572
+ assert.equal(content.includes('return items.size();'), true);
573
+ });
574
+ it('List.get 应映射为 get 调用', async () => {
575
+ const func = Core.Func('getItem', [], [{ name: 'items', type: Core.List(Core.TypeName('Object')), annotations: [] }], Core.TypeName('Object'), [], Core.Block([
576
+ Core.Return(Core.Call(Core.Name('List.get'), [Core.Name('items'), Core.Int(1)])),
577
+ ]));
578
+ const module = Core.Module('test.emitter.list_get', [func]);
579
+ const content = await emitJavaClassContent(module, [
580
+ 'test',
581
+ 'emitter',
582
+ 'list_get',
583
+ 'getItem_fn.java',
584
+ ]);
585
+ assert.equal(content.includes('return items.get(1);'), true);
586
+ });
587
+ it('List.head 应生成空检查逻辑', async () => {
588
+ const func = Core.Func('head', [], [{ name: 'items', type: Core.List(Core.TypeName('Object')), annotations: [] }], Core.TypeName('Object'), [], Core.Block([
589
+ Core.Return(Core.Call(Core.Name('List.head'), [Core.Name('items')])),
590
+ ]));
591
+ const module = Core.Module('test.emitter.list_head', [func]);
592
+ const content = await emitJavaClassContent(module, [
593
+ 'test',
594
+ 'emitter',
595
+ 'list_head',
596
+ 'head_fn.java',
597
+ ]);
598
+ assert.equal(content.includes('return (items.isEmpty() ? null : items.get(0));'), true);
599
+ });
600
+ it('Map.get 应映射为 get 调用', async () => {
601
+ const func = Core.Func('byKey', [], [
602
+ {
603
+ name: 'mapping',
604
+ type: Core.Map(Core.TypeName('String'), Core.TypeName('String')),
605
+ annotations: [],
606
+ },
607
+ ], Core.TypeName('String'), [], Core.Block([
608
+ Core.Return(Core.Call(Core.Name('Map.get'), [Core.Name('mapping'), Core.String('key')])),
609
+ ]));
610
+ const module = Core.Module('test.emitter.map_get', [func]);
611
+ const content = await emitJavaClassContent(module, [
612
+ 'test',
613
+ 'emitter',
614
+ 'map_get',
615
+ 'byKey_fn.java',
616
+ ]);
617
+ assert.equal(content.includes('return mapping.get("key");'), true);
618
+ });
619
+ it('Scope 语句应按序展开内部语句', async () => {
620
+ const func = Core.Func('useScope', [], [], Core.TypeName('int'), [], Core.Block([
621
+ Core.Scope([Core.Let('x', Core.Int(1)), Core.Set('x', Core.Int(3))]),
622
+ Core.Return(Core.Name('x')),
623
+ ]));
624
+ const module = Core.Module('test.emitter.scope_flat', [func]);
625
+ const content = await emitJavaClassContent(module, [
626
+ 'test',
627
+ 'emitter',
628
+ 'scope_flat',
629
+ 'useScope_fn.java',
630
+ ]);
631
+ assert.equal(content.includes('var x = 1;'), true);
632
+ assert.equal(content.includes('x = 3;'), true);
633
+ });
634
+ it('嵌套 Scope 应保持缩进', async () => {
635
+ const func = Core.Func('nestedScope', [], [], Core.TypeName('int'), [], Core.Block([
636
+ Core.Scope([
637
+ Core.Let('outer', Core.Int(1)),
638
+ Core.Scope([Core.Let('inner', Core.Int(2))]),
639
+ ]),
640
+ Core.Return(Core.Name('outer')),
641
+ ]));
642
+ const module = Core.Module('test.emitter.scope_nested', [func]);
643
+ const content = await emitJavaClassContent(module, [
644
+ 'test',
645
+ 'emitter',
646
+ 'scope_nested',
647
+ 'nestedScope_fn.java',
648
+ ]);
649
+ assert.equal(content.includes('var outer = 1;'), true);
650
+ assert.equal(content.includes(' var inner = 2;'), true);
651
+ });
652
+ it('Construct 表达式应生成类型实例化', async () => {
653
+ const module = Core.Module('test.emitter.construct', [
654
+ Core.Data('User', [
655
+ { name: 'name', type: Core.TypeName('String'), annotations: [] },
656
+ { name: 'age', type: Core.TypeName('int'), annotations: [] },
657
+ ]),
658
+ Core.Func('build', [], [], Core.TypeName('User'), [], Core.Block([
659
+ Core.Return(Core.Construct('User', [
660
+ { name: 'name', expr: Core.String('alice') },
661
+ { name: 'age', expr: Core.Int(30) },
662
+ ])),
663
+ ])),
664
+ ]);
665
+ const content = await emitJavaClassContent(module, [
666
+ 'test',
667
+ 'emitter',
668
+ 'construct',
669
+ 'build_fn.java',
670
+ ]);
671
+ assert.equal(content.includes('return new User("alice", 30);'), true);
672
+ });
673
+ it('Match 多分支应解构数据字段', async () => {
674
+ const pair = Core.Data('Pair', [
675
+ { name: 'left', type: Core.TypeName('Object'), annotations: [] },
676
+ { name: 'right', type: Core.TypeName('Object'), annotations: [] },
677
+ ]);
678
+ const func = Core.Func('describePair', [], [{ name: 'value', type: Core.TypeName('Pair'), annotations: [] }], Core.TypeName('Object'), [], Core.Block([
679
+ Core.Match(Core.Name('value'), [
680
+ Core.Case(Core.PatCtor('Pair', [], [Core.PatName('left'), Core.PatName('right')]), Core.Return(Core.Name('left'))),
681
+ Core.Case(Core.PatName('other'), Core.Return(Core.Name('other'))),
682
+ ]),
683
+ Core.Return(Core.Null()),
684
+ ]));
685
+ const module = Core.Module('test.emitter.match_fields', [pair, func]);
686
+ const content = await emitJavaClassContent(module, [
687
+ 'test',
688
+ 'emitter',
689
+ 'match_fields',
690
+ 'describePair_fn.java',
691
+ ]);
692
+ assert.equal(content.includes('var left = __tmp.left;'), true);
693
+ assert.equal(content.includes('var right = __tmp.right;'), true);
694
+ assert.equal(content.includes('if (__scrut != null)'), true);
695
+ });
696
+ it('Match 混合 Null 与构造体应按序生成守卫', async () => {
697
+ const wrapper = Core.Data('Wrapper', [
698
+ { name: 'payload', type: Core.TypeName('Object'), annotations: [] },
699
+ ]);
700
+ const func = Core.Func('analyze', [], [{ name: 'input', type: Core.TypeName('Wrapper'), annotations: [] }], Core.TypeName('String'), [], Core.Block([
701
+ Core.Match(Core.Name('input'), [
702
+ Core.Case(Core.PatNull(), Core.Return(Core.String('null'))),
703
+ Core.Case(Core.PatCtor('Wrapper', [], [Core.PatName('payload')]), Core.Return(Core.String('payload'))),
704
+ ]),
705
+ Core.Return(Core.String('none')),
706
+ ]));
707
+ const module = Core.Module('test.emitter.match_order', [wrapper, func]);
708
+ const content = await emitJavaClassContent(module, [
709
+ 'test',
710
+ 'emitter',
711
+ 'match_order',
712
+ 'analyze_fn.java',
713
+ ]);
714
+ assert.equal(content.includes('if (__scrut == null)'), true);
715
+ assert.equal(content.includes('if (__scrut instanceof Wrapper)'), true);
716
+ });
717
+ it('Return 语句应直接返回表达式', async () => {
718
+ const func = Core.Func('giveBack', [], [], Core.TypeName('boolean'), [], Core.Block([Core.Return(Core.Bool(true))]));
719
+ const module = Core.Module('test.emitter.return_stmt', [func]);
720
+ const content = await emitJavaClassContent(module, [
721
+ 'test',
722
+ 'emitter',
723
+ 'return_stmt',
724
+ 'giveBack_fn.java',
725
+ ]);
726
+ assert.equal(content.includes('return true;'), true);
727
+ });
728
+ it('链式调用应保持嵌套顺序', async () => {
729
+ const func = Core.Func('chain', [], [], Core.TypeName('Object'), [], Core.Block([
730
+ Core.Return(Core.Call(Core.Name('outer'), [
731
+ Core.Call(Core.Name('middle'), [Core.Call(Core.Name('inner'), [])]),
732
+ ])),
733
+ ]));
734
+ const module = Core.Module('test.emitter.call_chain', [func]);
735
+ const content = await emitJavaClassContent(module, [
736
+ 'test',
737
+ 'emitter',
738
+ 'call_chain',
739
+ 'chain_fn.java',
740
+ ]);
741
+ assert.equal(content.includes('return outer(middle(inner()));'), true);
742
+ });
743
+ it('not 内置函数应转换为逻辑非表达式', async () => {
744
+ const func = Core.Func('negate', [], [], Core.TypeName('boolean'), [], Core.Block([
745
+ Core.Return(Core.Call(Core.Name('not'), [
746
+ Core.Call(Core.Name('Text.contains'), [Core.Name('source'), Core.String('a')]),
747
+ ])),
748
+ ]));
749
+ const module = Core.Module('test.emitter.call_not', [func]);
750
+ const content = await emitJavaClassContent(module, [
751
+ 'test',
752
+ 'emitter',
753
+ 'call_not',
754
+ 'negate_fn.java',
755
+ ]);
756
+ assert.equal(content.includes('return !(source.contains("a"));'), true);
757
+ });
758
+ it('Start 语句应输出占位注释', async () => {
759
+ const func = Core.Func('launch', [], [], Core.TypeName('void'), [], Core.Block([Core.Start('job', Core.Name('producer'))]));
760
+ const module = Core.Module('test.emitter.start_stmt', [func]);
761
+ const content = await emitJavaClassContent(module, [
762
+ 'test',
763
+ 'emitter',
764
+ 'start_stmt',
765
+ 'launch_fn.java',
766
+ ]);
767
+ assert.equal(content.includes('// async not implemented in MVP'), true);
768
+ });
769
+ it('Wait 语句应输出占位注释', async () => {
770
+ const func = Core.Func('awaitAll', [], [], Core.TypeName('void'), [], Core.Block([Core.Wait(['first', 'second'])]));
771
+ const module = Core.Module('test.emitter.wait_stmt', [func]);
772
+ const content = await emitJavaClassContent(module, [
773
+ 'test',
774
+ 'emitter',
775
+ 'wait_stmt',
776
+ 'awaitAll_fn.java',
777
+ ]);
778
+ assert.equal(content.includes('// async not implemented in MVP'), true);
779
+ });
780
+ it('Within scope 语句应串联内部赋值', async () => {
781
+ const func = Core.Func('withinScope', [], [], Core.TypeName('int'), [], Core.Block([
782
+ Core.Scope([Core.Let('temp', Core.Int(5)), Core.Set('temp', Core.Int(9))]),
783
+ Core.Return(Core.Name('temp')),
784
+ ]));
785
+ const module = Core.Module('test.emitter.within_scope', [func]);
786
+ const content = await emitJavaClassContent(module, [
787
+ 'test',
788
+ 'emitter',
789
+ 'within_scope',
790
+ 'withinScope_fn.java',
791
+ ]);
792
+ assert.equal(content.includes('var temp = 5;'), true);
793
+ assert.equal(content.includes('temp = 9;'), true);
794
+ });
795
+ it('类型注解应传递到函数签名', async () => {
796
+ const func = Core.Func('withTypes', [], [
797
+ {
798
+ name: 'items',
799
+ type: Core.List(Core.TypeName('String')),
800
+ annotations: [],
801
+ },
802
+ ], Core.Map(Core.TypeName('String'), Core.TypeName('String')), [], Core.Block([Core.Return(Core.Null())]));
803
+ const module = Core.Module('test.emitter.type_annotations', [func]);
804
+ const content = await emitJavaClassContent(module, [
805
+ 'test',
806
+ 'emitter',
807
+ 'type_annotations',
808
+ 'withTypes_fn.java',
809
+ ]);
810
+ assert.equal(content.includes('java.util.List<String> items'), true);
811
+ assert.equal(content.includes('public static java.util.Map<String, String> withTypes'), true);
812
+ });
813
+ it('函数缺失 return 时应生成兜底返回', async () => {
814
+ const func = Core.Func('fallback', [], [], Core.TypeName('String'), [], Core.Block([]));
815
+ const module = Core.Module('test.emitter.fallback_return', [func]);
816
+ const content = await emitJavaClassContent(module, [
817
+ 'test',
818
+ 'emitter',
819
+ 'fallback_return',
820
+ 'fallback_fn.java',
821
+ ]);
822
+ assert.equal(content.includes('return null;'), true);
823
+ });
824
+ });
825
+ //# sourceMappingURL=emitter.test.js.map