@tsonic/emitter 0.0.62 → 0.0.64

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 (520) hide show
  1. package/dist/.tsbuildinfo +1 -1
  2. package/dist/adapter-generator.d.ts +5 -15
  3. package/dist/adapter-generator.d.ts.map +1 -1
  4. package/dist/adapter-generator.js +60 -53
  5. package/dist/adapter-generator.js.map +1 -1
  6. package/dist/contracts/backend-adapter.d.ts +36 -0
  7. package/dist/contracts/backend-adapter.d.ts.map +1 -0
  8. package/dist/contracts/backend-adapter.js +9 -0
  9. package/dist/contracts/backend-adapter.js.map +1 -0
  10. package/dist/contracts/emitter-contract.d.ts +54 -0
  11. package/dist/contracts/emitter-contract.d.ts.map +1 -0
  12. package/dist/contracts/emitter-contract.js +8 -0
  13. package/dist/contracts/emitter-contract.js.map +1 -0
  14. package/dist/contracts/import-classifier.d.ts +36 -0
  15. package/dist/contracts/import-classifier.d.ts.map +1 -0
  16. package/dist/contracts/import-classifier.js +9 -0
  17. package/dist/contracts/import-classifier.js.map +1 -0
  18. package/dist/core/{attributes.d.ts → format/attributes.d.ts} +9 -14
  19. package/dist/core/format/attributes.d.ts.map +1 -0
  20. package/dist/core/format/attributes.js +190 -0
  21. package/dist/core/format/attributes.js.map +1 -0
  22. package/dist/core/format/attributes.test.d.ts.map +1 -0
  23. package/dist/core/{attributes.test.js → format/attributes.test.js} +70 -32
  24. package/dist/core/format/attributes.test.js.map +1 -0
  25. package/dist/core/format/backend-ast/index.d.ts +7 -0
  26. package/dist/core/format/backend-ast/index.d.ts.map +1 -0
  27. package/dist/core/format/backend-ast/index.js +6 -0
  28. package/dist/core/format/backend-ast/index.js.map +1 -0
  29. package/dist/core/format/backend-ast/printer.d.ts +33 -0
  30. package/dist/core/format/backend-ast/printer.d.ts.map +1 -0
  31. package/dist/core/format/backend-ast/printer.js +1151 -0
  32. package/dist/core/format/backend-ast/printer.js.map +1 -0
  33. package/dist/core/format/backend-ast/types.d.ts +504 -0
  34. package/dist/core/format/backend-ast/types.d.ts.map +1 -0
  35. package/dist/core/format/backend-ast/types.js +13 -0
  36. package/dist/core/format/backend-ast/types.js.map +1 -0
  37. package/dist/core/format/backend-ast/utils.d.ts +26 -0
  38. package/dist/core/format/backend-ast/utils.d.ts.map +1 -0
  39. package/dist/core/format/backend-ast/utils.js +65 -0
  40. package/dist/core/format/backend-ast/utils.js.map +1 -0
  41. package/dist/core/{exports.d.ts → format/exports.d.ts} +2 -2
  42. package/dist/core/format/exports.d.ts.map +1 -0
  43. package/dist/core/format/exports.js +22 -0
  44. package/dist/core/format/exports.js.map +1 -0
  45. package/dist/core/format/index.d.ts +9 -0
  46. package/dist/core/format/index.d.ts.map +1 -0
  47. package/dist/core/format/index.js +9 -0
  48. package/dist/core/format/index.js.map +1 -0
  49. package/dist/core/{local-names.d.ts → format/local-names.d.ts} +1 -1
  50. package/dist/core/format/local-names.d.ts.map +1 -0
  51. package/dist/core/{local-names.js → format/local-names.js} +1 -1
  52. package/dist/core/format/local-names.js.map +1 -0
  53. package/dist/core/format/module-emitter/assembly.d.ts +27 -0
  54. package/dist/core/format/module-emitter/assembly.d.ts.map +1 -0
  55. package/dist/core/format/module-emitter/assembly.js +44 -0
  56. package/dist/core/format/module-emitter/assembly.js.map +1 -0
  57. package/dist/core/{module-emitter → format/module-emitter}/header.d.ts +1 -1
  58. package/dist/core/format/module-emitter/header.d.ts.map +1 -0
  59. package/dist/core/{module-emitter → format/module-emitter}/header.js +1 -1
  60. package/dist/core/format/module-emitter/header.js.map +1 -0
  61. package/dist/core/format/module-emitter/index.d.ts.map +1 -0
  62. package/dist/core/format/module-emitter/index.js.map +1 -0
  63. package/dist/core/format/module-emitter/namespace.d.ts +21 -0
  64. package/dist/core/format/module-emitter/namespace.d.ts.map +1 -0
  65. package/dist/core/format/module-emitter/namespace.js +58 -0
  66. package/dist/core/format/module-emitter/namespace.js.map +1 -0
  67. package/dist/core/{module-emitter → format/module-emitter}/orchestrator.d.ts +1 -1
  68. package/dist/core/format/module-emitter/orchestrator.d.ts.map +1 -0
  69. package/dist/core/{module-emitter → format/module-emitter}/orchestrator.js +19 -19
  70. package/dist/core/format/module-emitter/orchestrator.js.map +1 -0
  71. package/dist/core/format/module-emitter/separation.d.ts.map +1 -0
  72. package/dist/core/format/module-emitter/separation.js.map +1 -0
  73. package/dist/core/{module-emitter → format/module-emitter}/static-container.d.ts +8 -3
  74. package/dist/core/format/module-emitter/static-container.d.ts.map +1 -0
  75. package/dist/core/format/module-emitter/static-container.js +202 -0
  76. package/dist/core/format/module-emitter/static-container.js.map +1 -0
  77. package/dist/core/format/module-emitter.d.ts.map +1 -0
  78. package/dist/core/format/module-emitter.js.map +1 -0
  79. package/dist/core/{options.d.ts → format/options.d.ts} +1 -1
  80. package/dist/core/format/options.d.ts.map +1 -0
  81. package/dist/core/format/options.js.map +1 -0
  82. package/dist/core/index.d.ts +2 -7
  83. package/dist/core/index.d.ts.map +1 -1
  84. package/dist/core/index.js +2 -7
  85. package/dist/core/index.js.map +1 -1
  86. package/dist/core/semantic/boolean-context.d.ts +44 -0
  87. package/dist/core/semantic/boolean-context.d.ts.map +1 -0
  88. package/dist/core/semantic/boolean-context.js +717 -0
  89. package/dist/core/semantic/boolean-context.js.map +1 -0
  90. package/dist/core/semantic/boolean-context.test.d.ts.map +1 -0
  91. package/dist/core/{boolean-context.test.js → semantic/boolean-context.test.js} +86 -109
  92. package/dist/core/semantic/boolean-context.test.js.map +1 -0
  93. package/dist/core/{imports.d.ts → semantic/imports.d.ts} +1 -5
  94. package/dist/core/semantic/imports.d.ts.map +1 -0
  95. package/dist/core/{imports.js → semantic/imports.js} +56 -74
  96. package/dist/core/semantic/imports.js.map +1 -0
  97. package/dist/core/semantic/imports.test.d.ts.map +1 -0
  98. package/dist/core/semantic/imports.test.js +229 -0
  99. package/dist/core/semantic/imports.test.js.map +1 -0
  100. package/dist/core/semantic/index.d.ts +15 -0
  101. package/dist/core/semantic/index.d.ts.map +1 -0
  102. package/dist/core/semantic/index.js +15 -0
  103. package/dist/core/semantic/index.js.map +1 -0
  104. package/dist/core/{local-types.d.ts → semantic/local-types.d.ts} +1 -1
  105. package/dist/core/semantic/local-types.d.ts.map +1 -0
  106. package/dist/core/semantic/local-types.js.map +1 -0
  107. package/dist/core/{module-map.d.ts → semantic/module-map.d.ts} +1 -1
  108. package/dist/core/semantic/module-map.d.ts.map +1 -0
  109. package/dist/core/semantic/module-map.js.map +1 -0
  110. package/dist/core/semantic/module-map.test.d.ts.map +1 -0
  111. package/dist/core/semantic/module-map.test.js.map +1 -0
  112. package/dist/core/semantic/naming-collisions.d.ts.map +1 -0
  113. package/dist/core/{naming-collisions.js → semantic/naming-collisions.js} +1 -1
  114. package/dist/core/semantic/naming-collisions.js.map +1 -0
  115. package/dist/core/{type-alias-index.d.ts → semantic/type-alias-index.d.ts} +1 -1
  116. package/dist/core/semantic/type-alias-index.d.ts.map +1 -0
  117. package/dist/core/semantic/type-alias-index.js.map +1 -0
  118. package/dist/core/semantic/type-compatibility.d.ts.map +1 -0
  119. package/dist/core/semantic/type-compatibility.js.map +1 -0
  120. package/dist/core/{type-member-index.d.ts → semantic/type-member-index.d.ts} +1 -1
  121. package/dist/core/semantic/type-member-index.d.ts.map +1 -0
  122. package/dist/core/semantic/type-member-index.js.map +1 -0
  123. package/dist/core/semantic/type-params.d.ts.map +1 -0
  124. package/dist/core/semantic/type-params.js.map +1 -0
  125. package/dist/core/{type-resolution.d.ts → semantic/type-resolution.d.ts} +3 -6
  126. package/dist/core/semantic/type-resolution.d.ts.map +1 -0
  127. package/dist/core/{type-resolution.js → semantic/type-resolution.js} +15 -25
  128. package/dist/core/semantic/type-resolution.js.map +1 -0
  129. package/dist/core/semantic/type-resolution.test.d.ts.map +1 -0
  130. package/dist/core/{type-resolution.test.js → semantic/type-resolution.test.js} +11 -19
  131. package/dist/core/semantic/type-resolution.test.js.map +1 -0
  132. package/dist/core/semantic/unsafe.d.ts.map +1 -0
  133. package/dist/core/semantic/unsafe.js.map +1 -0
  134. package/dist/emitter-types/core.d.ts +6 -12
  135. package/dist/emitter-types/core.d.ts.map +1 -1
  136. package/dist/emitter-types/index.d.ts +1 -1
  137. package/dist/emitter-types/index.d.ts.map +1 -1
  138. package/dist/emitter-types/index.js.map +1 -1
  139. package/dist/emitter.d.ts +1 -1
  140. package/dist/emitter.d.ts.map +1 -1
  141. package/dist/emitter.js +9 -8
  142. package/dist/emitter.js.map +1 -1
  143. package/dist/expression-emitter.d.ts +10 -5
  144. package/dist/expression-emitter.d.ts.map +1 -1
  145. package/dist/expression-emitter.js +333 -117
  146. package/dist/expression-emitter.js.map +1 -1
  147. package/dist/expressions/access.d.ts +4 -3
  148. package/dist/expressions/access.d.ts.map +1 -1
  149. package/dist/expressions/access.js +252 -102
  150. package/dist/expressions/access.js.map +1 -1
  151. package/dist/expressions/calls/call-analysis.d.ts +86 -0
  152. package/dist/expressions/calls/call-analysis.d.ts.map +1 -0
  153. package/dist/expressions/calls/call-analysis.js +284 -0
  154. package/dist/expressions/calls/call-analysis.js.map +1 -0
  155. package/dist/expressions/calls/call-emitter.d.ts +13 -0
  156. package/dist/expressions/calls/call-emitter.d.ts.map +1 -0
  157. package/dist/expressions/calls/call-emitter.js +1048 -0
  158. package/dist/expressions/calls/call-emitter.js.map +1 -0
  159. package/dist/expressions/calls/new-emitter.d.ts +13 -0
  160. package/dist/expressions/calls/new-emitter.d.ts.map +1 -0
  161. package/dist/expressions/calls/new-emitter.js +641 -0
  162. package/dist/expressions/calls/new-emitter.js.map +1 -0
  163. package/dist/expressions/calls.d.ts +2 -14
  164. package/dist/expressions/calls.d.ts.map +1 -1
  165. package/dist/expressions/calls.js +2 -909
  166. package/dist/expressions/calls.js.map +1 -1
  167. package/dist/expressions/collections.d.ts +6 -16
  168. package/dist/expressions/collections.d.ts.map +1 -1
  169. package/dist/expressions/collections.js +318 -217
  170. package/dist/expressions/collections.js.map +1 -1
  171. package/dist/expressions/functions.d.ts +6 -5
  172. package/dist/expressions/functions.d.ts.map +1 -1
  173. package/dist/expressions/functions.js +57 -62
  174. package/dist/expressions/functions.js.map +1 -1
  175. package/dist/expressions/identifiers.d.ts +11 -6
  176. package/dist/expressions/identifiers.d.ts.map +1 -1
  177. package/dist/expressions/identifiers.js +76 -25
  178. package/dist/expressions/identifiers.js.map +1 -1
  179. package/dist/expressions/index.d.ts +1 -1
  180. package/dist/expressions/index.d.ts.map +1 -1
  181. package/dist/expressions/index.js +1 -1
  182. package/dist/expressions/index.js.map +1 -1
  183. package/dist/expressions/index.test.js +605 -0
  184. package/dist/expressions/index.test.js.map +1 -1
  185. package/dist/expressions/literals.d.ts +4 -3
  186. package/dist/expressions/literals.d.ts.map +1 -1
  187. package/dist/expressions/literals.js +25 -17
  188. package/dist/expressions/literals.js.map +1 -1
  189. package/dist/expressions/literals.test.js +18 -18
  190. package/dist/expressions/literals.test.js.map +1 -1
  191. package/dist/expressions/operators/assignment-emitter.d.ts +16 -0
  192. package/dist/expressions/operators/assignment-emitter.d.ts.map +1 -0
  193. package/dist/expressions/operators/assignment-emitter.js +118 -0
  194. package/dist/expressions/operators/assignment-emitter.js.map +1 -0
  195. package/dist/expressions/operators/binary-emitter.d.ts +33 -0
  196. package/dist/expressions/operators/binary-emitter.d.ts.map +1 -0
  197. package/dist/expressions/operators/binary-emitter.js +398 -0
  198. package/dist/expressions/operators/binary-emitter.js.map +1 -0
  199. package/dist/expressions/operators/conditional-emitter.d.ts +17 -0
  200. package/dist/expressions/operators/conditional-emitter.d.ts.map +1 -0
  201. package/dist/expressions/operators/conditional-emitter.js +306 -0
  202. package/dist/expressions/operators/conditional-emitter.js.map +1 -0
  203. package/dist/expressions/operators/helpers.d.ts +37 -0
  204. package/dist/expressions/operators/helpers.d.ts.map +1 -0
  205. package/dist/expressions/operators/helpers.js +136 -0
  206. package/dist/expressions/operators/helpers.js.map +1 -0
  207. package/dist/expressions/operators/logical-emitter.d.ts +23 -0
  208. package/dist/expressions/operators/logical-emitter.d.ts.map +1 -0
  209. package/dist/expressions/operators/logical-emitter.js +73 -0
  210. package/dist/expressions/operators/logical-emitter.js.map +1 -0
  211. package/dist/expressions/operators/unary-emitter.d.ts +30 -0
  212. package/dist/expressions/operators/unary-emitter.d.ts.map +1 -0
  213. package/dist/expressions/operators/unary-emitter.js +244 -0
  214. package/dist/expressions/operators/unary-emitter.js.map +1 -0
  215. package/dist/expressions/operators.d.ts +5 -81
  216. package/dist/expressions/operators.d.ts.map +1 -1
  217. package/dist/expressions/operators.js +5 -949
  218. package/dist/expressions/operators.js.map +1 -1
  219. package/dist/expressions/other.d.ts +15 -11
  220. package/dist/expressions/other.d.ts.map +1 -1
  221. package/dist/expressions/other.js +51 -36
  222. package/dist/expressions/other.js.map +1 -1
  223. package/dist/expressions/precedence.test.js +1 -1
  224. package/dist/expressions/precedence.test.js.map +1 -1
  225. package/dist/generator-exchange.d.ts +10 -3
  226. package/dist/generator-exchange.d.ts.map +1 -1
  227. package/dist/generator-exchange.js +57 -54
  228. package/dist/generator-exchange.js.map +1 -1
  229. package/dist/generator-wrapper.d.ts +17 -65
  230. package/dist/generator-wrapper.d.ts.map +1 -1
  231. package/dist/generator-wrapper.js +396 -220
  232. package/dist/generator-wrapper.js.map +1 -1
  233. package/dist/generator-wrapper.test.js +22 -14
  234. package/dist/generator-wrapper.test.js.map +1 -1
  235. package/dist/integration.test.js +169 -1
  236. package/dist/integration.test.js.map +1 -1
  237. package/dist/patterns.d.ts +18 -88
  238. package/dist/patterns.d.ts.map +1 -1
  239. package/dist/patterns.js +540 -304
  240. package/dist/patterns.js.map +1 -1
  241. package/dist/patterns.test.js +5 -4
  242. package/dist/patterns.test.js.map +1 -1
  243. package/dist/specialization/generation.d.ts +7 -3
  244. package/dist/specialization/generation.d.ts.map +1 -1
  245. package/dist/specialization/generation.js +31 -15
  246. package/dist/specialization/generation.js.map +1 -1
  247. package/dist/specialization/type-aliases.test.js +47 -2
  248. package/dist/specialization/type-aliases.test.js.map +1 -1
  249. package/dist/statement-emitter.d.ts +15 -4
  250. package/dist/statement-emitter.d.ts.map +1 -1
  251. package/dist/statement-emitter.js +54 -47
  252. package/dist/statement-emitter.js.map +1 -1
  253. package/dist/statements/blocks.d.ts +24 -16
  254. package/dist/statements/blocks.d.ts.map +1 -1
  255. package/dist/statements/blocks.js +242 -65
  256. package/dist/statements/blocks.js.map +1 -1
  257. package/dist/statements/classes/index.d.ts +1 -1
  258. package/dist/statements/classes/index.d.ts.map +1 -1
  259. package/dist/statements/classes/index.js +1 -1
  260. package/dist/statements/classes/index.js.map +1 -1
  261. package/dist/statements/classes/inline-types.d.ts +4 -3
  262. package/dist/statements/classes/inline-types.d.ts.map +1 -1
  263. package/dist/statements/classes/inline-types.js +21 -21
  264. package/dist/statements/classes/inline-types.js.map +1 -1
  265. package/dist/statements/classes/members/constructors.d.ts +4 -3
  266. package/dist/statements/classes/members/constructors.d.ts.map +1 -1
  267. package/dist/statements/classes/members/constructors.js +57 -58
  268. package/dist/statements/classes/members/constructors.js.map +1 -1
  269. package/dist/statements/classes/members/methods.d.ts +4 -3
  270. package/dist/statements/classes/members/methods.d.ts.map +1 -1
  271. package/dist/statements/classes/members/methods.js +106 -101
  272. package/dist/statements/classes/members/methods.js.map +1 -1
  273. package/dist/statements/classes/members/orchestrator.d.ts +4 -3
  274. package/dist/statements/classes/members/orchestrator.d.ts.map +1 -1
  275. package/dist/statements/classes/members/orchestrator.js +2 -2
  276. package/dist/statements/classes/members/orchestrator.js.map +1 -1
  277. package/dist/statements/classes/members/properties.d.ts +4 -3
  278. package/dist/statements/classes/members/properties.d.ts.map +1 -1
  279. package/dist/statements/classes/members/properties.js +105 -88
  280. package/dist/statements/classes/members/properties.js.map +1 -1
  281. package/dist/statements/classes/members/shadowing.test.js +7 -2
  282. package/dist/statements/classes/members/shadowing.test.js.map +1 -1
  283. package/dist/statements/classes/members/static-readonly-properties.test.js +4 -1
  284. package/dist/statements/classes/members/static-readonly-properties.test.js.map +1 -1
  285. package/dist/statements/classes/parameters.d.ts +8 -10
  286. package/dist/statements/classes/parameters.d.ts.map +1 -1
  287. package/dist/statements/classes/parameters.js +30 -26
  288. package/dist/statements/classes/parameters.js.map +1 -1
  289. package/dist/statements/classes/properties.d.ts +4 -3
  290. package/dist/statements/classes/properties.d.ts.map +1 -1
  291. package/dist/statements/classes/properties.js +76 -50
  292. package/dist/statements/classes/properties.js.map +1 -1
  293. package/dist/statements/classes.d.ts +1 -1
  294. package/dist/statements/classes.d.ts.map +1 -1
  295. package/dist/statements/classes.js +1 -1
  296. package/dist/statements/classes.js.map +1 -1
  297. package/dist/statements/control/conditionals/guard-analysis.d.ts +169 -0
  298. package/dist/statements/control/conditionals/guard-analysis.d.ts.map +1 -0
  299. package/dist/statements/control/conditionals/guard-analysis.js +591 -0
  300. package/dist/statements/control/conditionals/guard-analysis.js.map +1 -0
  301. package/dist/statements/control/conditionals/if-emitter.d.ts +14 -0
  302. package/dist/statements/control/conditionals/if-emitter.d.ts.map +1 -0
  303. package/dist/statements/control/conditionals/if-emitter.js +725 -0
  304. package/dist/statements/control/conditionals/if-emitter.js.map +1 -0
  305. package/dist/statements/control/conditionals/switch-emitter.d.ts +13 -0
  306. package/dist/statements/control/conditionals/switch-emitter.d.ts.map +1 -0
  307. package/dist/statements/control/conditionals/switch-emitter.js +60 -0
  308. package/dist/statements/control/conditionals/switch-emitter.js.map +1 -0
  309. package/dist/statements/control/conditionals.d.ts +3 -15
  310. package/dist/statements/control/conditionals.d.ts.map +1 -1
  311. package/dist/statements/control/conditionals.js +3 -1152
  312. package/dist/statements/control/conditionals.js.map +1 -1
  313. package/dist/statements/control/exceptions.d.ts +8 -6
  314. package/dist/statements/control/exceptions.d.ts.map +1 -1
  315. package/dist/statements/control/exceptions.js +35 -23
  316. package/dist/statements/control/exceptions.js.map +1 -1
  317. package/dist/statements/control/index.d.ts +3 -3
  318. package/dist/statements/control/index.d.ts.map +1 -1
  319. package/dist/statements/control/index.js +3 -3
  320. package/dist/statements/control/index.js.map +1 -1
  321. package/dist/statements/control/loops.d.ts +14 -12
  322. package/dist/statements/control/loops.d.ts.map +1 -1
  323. package/dist/statements/control/loops.js +147 -82
  324. package/dist/statements/control/loops.js.map +1 -1
  325. package/dist/statements/control.d.ts +1 -1
  326. package/dist/statements/control.d.ts.map +1 -1
  327. package/dist/statements/control.js +1 -1
  328. package/dist/statements/control.js.map +1 -1
  329. package/dist/statements/declarations/classes.d.ts +7 -3
  330. package/dist/statements/declarations/classes.d.ts.map +1 -1
  331. package/dist/statements/declarations/classes.js +107 -83
  332. package/dist/statements/declarations/classes.js.map +1 -1
  333. package/dist/statements/declarations/enums.d.ts +4 -3
  334. package/dist/statements/declarations/enums.d.ts.map +1 -1
  335. package/dist/statements/declarations/enums.js +16 -15
  336. package/dist/statements/declarations/enums.js.map +1 -1
  337. package/dist/statements/declarations/functions.d.ts +18 -2
  338. package/dist/statements/declarations/functions.d.ts.map +1 -1
  339. package/dist/statements/declarations/functions.js +633 -162
  340. package/dist/statements/declarations/functions.js.map +1 -1
  341. package/dist/statements/declarations/index.d.ts +2 -2
  342. package/dist/statements/declarations/index.d.ts.map +1 -1
  343. package/dist/statements/declarations/index.js +2 -2
  344. package/dist/statements/declarations/index.js.map +1 -1
  345. package/dist/statements/declarations/interfaces.d.ts +7 -3
  346. package/dist/statements/declarations/interfaces.d.ts.map +1 -1
  347. package/dist/statements/declarations/interfaces.js +138 -105
  348. package/dist/statements/declarations/interfaces.js.map +1 -1
  349. package/dist/statements/declarations/type-aliases.d.ts +7 -3
  350. package/dist/statements/declarations/type-aliases.d.ts.map +1 -1
  351. package/dist/statements/declarations/type-aliases.js +122 -82
  352. package/dist/statements/declarations/type-aliases.js.map +1 -1
  353. package/dist/statements/declarations/variables.d.ts +12 -2
  354. package/dist/statements/declarations/variables.d.ts.map +1 -1
  355. package/dist/statements/declarations/variables.js +541 -428
  356. package/dist/statements/declarations/variables.js.map +1 -1
  357. package/dist/statements/declarations.d.ts +1 -1
  358. package/dist/statements/declarations.d.ts.map +1 -1
  359. package/dist/statements/declarations.js +1 -1
  360. package/dist/statements/declarations.js.map +1 -1
  361. package/dist/statements/index.d.ts +3 -3
  362. package/dist/statements/index.d.ts.map +1 -1
  363. package/dist/statements/index.js +5 -5
  364. package/dist/statements/index.js.map +1 -1
  365. package/dist/statements/index.test.js +307 -0
  366. package/dist/statements/index.test.js.map +1 -1
  367. package/dist/type-emitter.d.ts +1 -1
  368. package/dist/type-emitter.d.ts.map +1 -1
  369. package/dist/type-emitter.js +1 -1
  370. package/dist/type-emitter.js.map +1 -1
  371. package/dist/types/arrays.d.ts +3 -2
  372. package/dist/types/arrays.d.ts.map +1 -1
  373. package/dist/types/arrays.js +7 -5
  374. package/dist/types/arrays.js.map +1 -1
  375. package/dist/types/dictionaries.d.ts +6 -3
  376. package/dist/types/dictionaries.d.ts.map +1 -1
  377. package/dist/types/dictionaries.js +22 -10
  378. package/dist/types/dictionaries.js.map +1 -1
  379. package/dist/types/emitter.d.ts +8 -2
  380. package/dist/types/emitter.d.ts.map +1 -1
  381. package/dist/types/emitter.js +20 -6
  382. package/dist/types/emitter.js.map +1 -1
  383. package/dist/types/functions.d.ts +3 -2
  384. package/dist/types/functions.d.ts.map +1 -1
  385. package/dist/types/functions.js +36 -13
  386. package/dist/types/functions.js.map +1 -1
  387. package/dist/types/index.d.ts +2 -2
  388. package/dist/types/index.d.ts.map +1 -1
  389. package/dist/types/index.js +2 -2
  390. package/dist/types/index.js.map +1 -1
  391. package/dist/types/index.test.js +137 -0
  392. package/dist/types/index.test.js.map +1 -1
  393. package/dist/types/intersections.d.ts +3 -2
  394. package/dist/types/intersections.d.ts.map +1 -1
  395. package/dist/types/intersections.js +2 -2
  396. package/dist/types/intersections.js.map +1 -1
  397. package/dist/types/literals.d.ts +9 -2
  398. package/dist/types/literals.d.ts.map +1 -1
  399. package/dist/types/literals.js +11 -5
  400. package/dist/types/literals.js.map +1 -1
  401. package/dist/types/objects.d.ts +3 -2
  402. package/dist/types/objects.d.ts.map +1 -1
  403. package/dist/types/objects.js +1 -1
  404. package/dist/types/objects.js.map +1 -1
  405. package/dist/types/parameters.d.ts +6 -5
  406. package/dist/types/parameters.d.ts.map +1 -1
  407. package/dist/types/parameters.js +88 -29
  408. package/dist/types/parameters.js.map +1 -1
  409. package/dist/types/parameters.test.js +9 -4
  410. package/dist/types/parameters.test.js.map +1 -1
  411. package/dist/types/primitives.d.ts +5 -4
  412. package/dist/types/primitives.d.ts.map +1 -1
  413. package/dist/types/primitives.js +14 -13
  414. package/dist/types/primitives.js.map +1 -1
  415. package/dist/types/references.d.ts +3 -2
  416. package/dist/types/references.d.ts.map +1 -1
  417. package/dist/types/references.js +135 -111
  418. package/dist/types/references.js.map +1 -1
  419. package/dist/types/tuples.d.ts +3 -2
  420. package/dist/types/tuples.d.ts.map +1 -1
  421. package/dist/types/tuples.js +25 -11
  422. package/dist/types/tuples.js.map +1 -1
  423. package/dist/types/unions.d.ts +3 -2
  424. package/dist/types/unions.d.ts.map +1 -1
  425. package/dist/types/unions.js +36 -21
  426. package/dist/types/unions.js.map +1 -1
  427. package/dist/types.d.ts +1 -1
  428. package/dist/types.d.ts.map +1 -1
  429. package/dist/types.js.map +1 -1
  430. package/package.json +2 -2
  431. package/dist/core/attributes.d.ts.map +0 -1
  432. package/dist/core/attributes.js +0 -141
  433. package/dist/core/attributes.js.map +0 -1
  434. package/dist/core/attributes.test.d.ts.map +0 -1
  435. package/dist/core/attributes.test.js.map +0 -1
  436. package/dist/core/boolean-context.d.ts +0 -42
  437. package/dist/core/boolean-context.d.ts.map +0 -1
  438. package/dist/core/boolean-context.js +0 -442
  439. package/dist/core/boolean-context.js.map +0 -1
  440. package/dist/core/boolean-context.test.d.ts.map +0 -1
  441. package/dist/core/boolean-context.test.js.map +0 -1
  442. package/dist/core/exports.d.ts.map +0 -1
  443. package/dist/core/exports.js +0 -28
  444. package/dist/core/exports.js.map +0 -1
  445. package/dist/core/imports.d.ts.map +0 -1
  446. package/dist/core/imports.js.map +0 -1
  447. package/dist/core/imports.test.d.ts.map +0 -1
  448. package/dist/core/imports.test.js +0 -79
  449. package/dist/core/imports.test.js.map +0 -1
  450. package/dist/core/local-names.d.ts.map +0 -1
  451. package/dist/core/local-names.js.map +0 -1
  452. package/dist/core/local-types.d.ts.map +0 -1
  453. package/dist/core/local-types.js.map +0 -1
  454. package/dist/core/module-emitter/assembly.d.ts +0 -24
  455. package/dist/core/module-emitter/assembly.d.ts.map +0 -1
  456. package/dist/core/module-emitter/assembly.js +0 -69
  457. package/dist/core/module-emitter/assembly.js.map +0 -1
  458. package/dist/core/module-emitter/header.d.ts.map +0 -1
  459. package/dist/core/module-emitter/header.js.map +0 -1
  460. package/dist/core/module-emitter/index.d.ts.map +0 -1
  461. package/dist/core/module-emitter/index.js.map +0 -1
  462. package/dist/core/module-emitter/namespace.d.ts +0 -14
  463. package/dist/core/module-emitter/namespace.d.ts.map +0 -1
  464. package/dist/core/module-emitter/namespace.js +0 -26
  465. package/dist/core/module-emitter/namespace.js.map +0 -1
  466. package/dist/core/module-emitter/orchestrator.d.ts.map +0 -1
  467. package/dist/core/module-emitter/orchestrator.js.map +0 -1
  468. package/dist/core/module-emitter/separation.d.ts.map +0 -1
  469. package/dist/core/module-emitter/separation.js.map +0 -1
  470. package/dist/core/module-emitter/static-container.d.ts.map +0 -1
  471. package/dist/core/module-emitter/static-container.js +0 -139
  472. package/dist/core/module-emitter/static-container.js.map +0 -1
  473. package/dist/core/module-emitter.d.ts.map +0 -1
  474. package/dist/core/module-emitter.js.map +0 -1
  475. package/dist/core/module-map.d.ts.map +0 -1
  476. package/dist/core/module-map.js.map +0 -1
  477. package/dist/core/module-map.test.d.ts.map +0 -1
  478. package/dist/core/module-map.test.js.map +0 -1
  479. package/dist/core/naming-collisions.d.ts.map +0 -1
  480. package/dist/core/naming-collisions.js.map +0 -1
  481. package/dist/core/options.d.ts.map +0 -1
  482. package/dist/core/options.js.map +0 -1
  483. package/dist/core/type-alias-index.d.ts.map +0 -1
  484. package/dist/core/type-alias-index.js.map +0 -1
  485. package/dist/core/type-compatibility.d.ts.map +0 -1
  486. package/dist/core/type-compatibility.js.map +0 -1
  487. package/dist/core/type-member-index.d.ts.map +0 -1
  488. package/dist/core/type-member-index.js.map +0 -1
  489. package/dist/core/type-params.d.ts.map +0 -1
  490. package/dist/core/type-params.js.map +0 -1
  491. package/dist/core/type-resolution.d.ts.map +0 -1
  492. package/dist/core/type-resolution.js.map +0 -1
  493. package/dist/core/type-resolution.test.d.ts.map +0 -1
  494. package/dist/core/type-resolution.test.js.map +0 -1
  495. package/dist/core/unsafe.d.ts.map +0 -1
  496. package/dist/core/unsafe.js.map +0 -1
  497. /package/dist/core/{attributes.test.d.ts → format/attributes.test.d.ts} +0 -0
  498. /package/dist/core/{module-emitter → format/module-emitter}/index.d.ts +0 -0
  499. /package/dist/core/{module-emitter → format/module-emitter}/index.js +0 -0
  500. /package/dist/core/{module-emitter → format/module-emitter}/separation.d.ts +0 -0
  501. /package/dist/core/{module-emitter → format/module-emitter}/separation.js +0 -0
  502. /package/dist/core/{module-emitter.d.ts → format/module-emitter.d.ts} +0 -0
  503. /package/dist/core/{module-emitter.js → format/module-emitter.js} +0 -0
  504. /package/dist/core/{options.js → format/options.js} +0 -0
  505. /package/dist/core/{boolean-context.test.d.ts → semantic/boolean-context.test.d.ts} +0 -0
  506. /package/dist/core/{imports.test.d.ts → semantic/imports.test.d.ts} +0 -0
  507. /package/dist/core/{local-types.js → semantic/local-types.js} +0 -0
  508. /package/dist/core/{module-map.js → semantic/module-map.js} +0 -0
  509. /package/dist/core/{module-map.test.d.ts → semantic/module-map.test.d.ts} +0 -0
  510. /package/dist/core/{module-map.test.js → semantic/module-map.test.js} +0 -0
  511. /package/dist/core/{naming-collisions.d.ts → semantic/naming-collisions.d.ts} +0 -0
  512. /package/dist/core/{type-alias-index.js → semantic/type-alias-index.js} +0 -0
  513. /package/dist/core/{type-compatibility.d.ts → semantic/type-compatibility.d.ts} +0 -0
  514. /package/dist/core/{type-compatibility.js → semantic/type-compatibility.js} +0 -0
  515. /package/dist/core/{type-member-index.js → semantic/type-member-index.js} +0 -0
  516. /package/dist/core/{type-params.d.ts → semantic/type-params.d.ts} +0 -0
  517. /package/dist/core/{type-params.js → semantic/type-params.js} +0 -0
  518. /package/dist/core/{type-resolution.test.d.ts → semantic/type-resolution.test.d.ts} +0 -0
  519. /package/dist/core/{unsafe.d.ts → semantic/unsafe.d.ts} +0 -0
  520. /package/dist/core/{unsafe.js → semantic/unsafe.js} +0 -0
@@ -4,7 +4,7 @@
4
4
  // Literals
5
5
  export { emitLiteral } from "./literals.js";
6
6
  // Identifiers and type helpers
7
- export { emitIdentifier, emitTypeArguments, generateSpecializedName, } from "./identifiers.js";
7
+ export { emitIdentifier, generateSpecializedName } from "./identifiers.js";
8
8
  // Collections
9
9
  export { emitArray, emitObject } from "./collections.js";
10
10
  // Member access
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/expressions/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,WAAW;AACX,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,+BAA+B;AAC/B,OAAO,EACL,cAAc,EACd,iBAAiB,EACjB,uBAAuB,GACxB,MAAM,kBAAkB,CAAC;AAE1B,cAAc;AACd,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAEzD,gBAAgB;AAChB,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAE/C,QAAQ;AACR,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAE/C,YAAY;AACZ,OAAO,EACL,UAAU,EACV,WAAW,EACX,SAAS,EACT,UAAU,EACV,cAAc,EACd,eAAe,GAChB,MAAM,gBAAgB,CAAC;AAExB,YAAY;AACZ,OAAO,EAAE,sBAAsB,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAE3E,QAAQ;AACR,OAAO,EAAE,mBAAmB,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/expressions/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,WAAW;AACX,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,+BAA+B;AAC/B,OAAO,EAAE,cAAc,EAAE,uBAAuB,EAAE,MAAM,kBAAkB,CAAC;AAE3E,cAAc;AACd,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAEzD,gBAAgB;AAChB,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAE/C,QAAQ;AACR,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAE/C,YAAY;AACZ,OAAO,EACL,UAAU,EACV,WAAW,EACX,SAAS,EACT,UAAU,EACV,cAAc,EACd,eAAe,GAChB,MAAM,gBAAgB,CAAC;AAExB,YAAY;AACZ,OAAO,EAAE,sBAAsB,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAE3E,QAAQ;AACR,OAAO,EAAE,mBAAmB,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC"}
@@ -349,6 +349,126 @@ describe("Expression Emission", () => {
349
349
  expect(result).to.include('global::Tsonic.JSRuntime.String.split(path, "/")');
350
350
  expect(result).not.to.include("path.split");
351
351
  });
352
+ it("should rewrite js-surface array functional calls via LINQ", () => {
353
+ const module = {
354
+ kind: "module",
355
+ filePath: "/src/test.ts",
356
+ namespace: "MyApp",
357
+ className: "test",
358
+ isStaticContainer: true,
359
+ imports: [],
360
+ body: [
361
+ {
362
+ kind: "expressionStatement",
363
+ expression: {
364
+ kind: "call",
365
+ callee: {
366
+ kind: "memberAccess",
367
+ object: {
368
+ kind: "identifier",
369
+ name: "nums",
370
+ inferredType: {
371
+ kind: "arrayType",
372
+ elementType: { kind: "primitiveType", name: "int" },
373
+ },
374
+ },
375
+ property: "map",
376
+ isComputed: false,
377
+ isOptional: false,
378
+ },
379
+ arguments: [{ kind: "identifier", name: "doubleIt" }],
380
+ isOptional: false,
381
+ inferredType: {
382
+ kind: "arrayType",
383
+ elementType: { kind: "primitiveType", name: "int" },
384
+ },
385
+ },
386
+ },
387
+ ],
388
+ exports: [],
389
+ };
390
+ const result = emitModule(module, { surface: "js" });
391
+ expect(result).to.include("global::System.Linq.Enumerable.Select(nums, doubleIt)");
392
+ expect(result).to.include("global::System.Linq.Enumerable.ToArray(");
393
+ expect(result).not.to.include("new global::Tsonic.JSRuntime.JSArray");
394
+ });
395
+ it("should rewrite js-surface reduce/reduceRight/join via deterministic CLR calls", () => {
396
+ const numsExpr = {
397
+ kind: "identifier",
398
+ name: "nums",
399
+ inferredType: {
400
+ kind: "arrayType",
401
+ elementType: { kind: "primitiveType", name: "int" },
402
+ },
403
+ };
404
+ const module = {
405
+ kind: "module",
406
+ filePath: "/src/test.ts",
407
+ namespace: "MyApp",
408
+ className: "test",
409
+ isStaticContainer: true,
410
+ imports: [],
411
+ body: [
412
+ {
413
+ kind: "expressionStatement",
414
+ expression: {
415
+ kind: "call",
416
+ callee: {
417
+ kind: "memberAccess",
418
+ object: numsExpr,
419
+ property: "reduce",
420
+ isComputed: false,
421
+ isOptional: false,
422
+ },
423
+ arguments: [
424
+ { kind: "identifier", name: "sum" },
425
+ { kind: "literal", value: 0 },
426
+ ],
427
+ isOptional: false,
428
+ },
429
+ },
430
+ {
431
+ kind: "expressionStatement",
432
+ expression: {
433
+ kind: "call",
434
+ callee: {
435
+ kind: "memberAccess",
436
+ object: numsExpr,
437
+ property: "reduceRight",
438
+ isComputed: false,
439
+ isOptional: false,
440
+ },
441
+ arguments: [
442
+ { kind: "identifier", name: "sum" },
443
+ { kind: "literal", value: 0 },
444
+ ],
445
+ isOptional: false,
446
+ },
447
+ },
448
+ {
449
+ kind: "expressionStatement",
450
+ expression: {
451
+ kind: "call",
452
+ callee: {
453
+ kind: "memberAccess",
454
+ object: numsExpr,
455
+ property: "join",
456
+ isComputed: false,
457
+ isOptional: false,
458
+ },
459
+ arguments: [],
460
+ isOptional: false,
461
+ },
462
+ },
463
+ ],
464
+ exports: [],
465
+ };
466
+ const result = emitModule(module, { surface: "js" });
467
+ expect(result).to.include("global::System.Linq.Enumerable.Aggregate(nums, 0, sum)");
468
+ expect(result).to.include("global::System.Linq.Enumerable.Aggregate(global::System.Linq.Enumerable.Reverse(nums), 0, sum)");
469
+ expect(result).to.include('global::System.String.Join(",", nums)');
470
+ expect(result).not.to.include("new global::Tsonic.JSRuntime.JSArray");
471
+ });
352
472
  it("should emit fluent LINQ extension method calls (required for EF query precompilation)", () => {
353
473
  const module = {
354
474
  kind: "module",
@@ -965,6 +1085,162 @@ describe("Expression Emission", () => {
965
1085
  // Should emit regular property access
966
1086
  expect(result).to.include("obj.property");
967
1087
  });
1088
+ it("should emit array Length for js/node surfaces when binding provides lowercase length", () => {
1089
+ const module = {
1090
+ kind: "module",
1091
+ filePath: "/src/test.ts",
1092
+ namespace: "MyApp",
1093
+ className: "test",
1094
+ isStaticContainer: true,
1095
+ imports: [],
1096
+ body: [
1097
+ {
1098
+ kind: "expressionStatement",
1099
+ expression: {
1100
+ kind: "memberAccess",
1101
+ object: {
1102
+ kind: "identifier",
1103
+ name: "nums",
1104
+ inferredType: {
1105
+ kind: "arrayType",
1106
+ elementType: { kind: "primitiveType", name: "int" },
1107
+ },
1108
+ },
1109
+ property: "length",
1110
+ isComputed: false,
1111
+ isOptional: false,
1112
+ memberBinding: {
1113
+ assembly: "Tsonic.JSRuntime",
1114
+ type: "Tsonic.JSRuntime.JSArray",
1115
+ member: "length",
1116
+ },
1117
+ },
1118
+ },
1119
+ ],
1120
+ exports: [],
1121
+ };
1122
+ const jsResult = emitModule(module, { surface: "js" });
1123
+ expect(jsResult).to.include("nums.Length");
1124
+ expect(jsResult).not.to.include("nums.length");
1125
+ const nodeResult = emitModule(module, { surface: "nodejs" });
1126
+ expect(nodeResult).to.include("nums.Length");
1127
+ expect(nodeResult).not.to.include("nums.length");
1128
+ });
1129
+ it("should emit array Length for js/node surfaces without member binding", () => {
1130
+ const module = {
1131
+ kind: "module",
1132
+ filePath: "/src/test.ts",
1133
+ namespace: "MyApp",
1134
+ className: "test",
1135
+ isStaticContainer: true,
1136
+ imports: [],
1137
+ body: [
1138
+ {
1139
+ kind: "expressionStatement",
1140
+ expression: {
1141
+ kind: "memberAccess",
1142
+ object: {
1143
+ kind: "identifier",
1144
+ name: "nums",
1145
+ inferredType: {
1146
+ kind: "arrayType",
1147
+ elementType: { kind: "primitiveType", name: "int" },
1148
+ },
1149
+ },
1150
+ property: "length",
1151
+ isComputed: false,
1152
+ isOptional: false,
1153
+ },
1154
+ },
1155
+ ],
1156
+ exports: [],
1157
+ };
1158
+ const jsResult = emitModule(module, { surface: "js" });
1159
+ expect(jsResult).to.include("nums.Length");
1160
+ expect(jsResult).not.to.include("nums.length");
1161
+ const nodeResult = emitModule(module, { surface: "nodejs" });
1162
+ expect(nodeResult).to.include("nums.Length");
1163
+ expect(nodeResult).not.to.include("nums.length");
1164
+ });
1165
+ it("should emit array Length for js/node surfaces when array type is referenceType", () => {
1166
+ const module = {
1167
+ kind: "module",
1168
+ filePath: "/src/test.ts",
1169
+ namespace: "MyApp",
1170
+ className: "test",
1171
+ isStaticContainer: true,
1172
+ imports: [],
1173
+ body: [
1174
+ {
1175
+ kind: "expressionStatement",
1176
+ expression: {
1177
+ kind: "memberAccess",
1178
+ object: {
1179
+ kind: "identifier",
1180
+ name: "nums",
1181
+ inferredType: {
1182
+ kind: "referenceType",
1183
+ name: "Array",
1184
+ typeArguments: [{ kind: "primitiveType", name: "int" }],
1185
+ },
1186
+ },
1187
+ property: "length",
1188
+ isComputed: false,
1189
+ isOptional: false,
1190
+ },
1191
+ },
1192
+ ],
1193
+ exports: [],
1194
+ };
1195
+ const jsResult = emitModule(module, { surface: "js" });
1196
+ expect(jsResult).to.include("nums.Length");
1197
+ expect(jsResult).not.to.include("nums.length");
1198
+ const nodeResult = emitModule(module, { surface: "nodejs" });
1199
+ expect(nodeResult).to.include("nums.Length");
1200
+ expect(nodeResult).not.to.include("nums.length");
1201
+ });
1202
+ it("should emit array Length for js/node surfaces with member binding and ReadonlyArray referenceType", () => {
1203
+ const module = {
1204
+ kind: "module",
1205
+ filePath: "/src/test.ts",
1206
+ namespace: "MyApp",
1207
+ className: "test",
1208
+ isStaticContainer: true,
1209
+ imports: [],
1210
+ body: [
1211
+ {
1212
+ kind: "expressionStatement",
1213
+ expression: {
1214
+ kind: "memberAccess",
1215
+ object: {
1216
+ kind: "identifier",
1217
+ name: "nums",
1218
+ inferredType: {
1219
+ kind: "referenceType",
1220
+ name: "ReadonlyArray",
1221
+ typeArguments: [{ kind: "primitiveType", name: "int" }],
1222
+ },
1223
+ },
1224
+ property: "length",
1225
+ isComputed: false,
1226
+ isOptional: false,
1227
+ memberBinding: {
1228
+ assembly: "Tsonic.JSRuntime",
1229
+ type: "Tsonic.JSRuntime.JSArray",
1230
+ member: "length",
1231
+ },
1232
+ },
1233
+ },
1234
+ ],
1235
+ exports: [],
1236
+ };
1237
+ const jsResult = emitModule(module, { surface: "js" });
1238
+ expect(jsResult).to.include("nums.Length");
1239
+ expect(jsResult).not.to.include("nums.length");
1240
+ const nodeResult = emitModule(module, { surface: "nodejs" });
1241
+ expect(nodeResult).to.include("nums.Length");
1242
+ expect(nodeResult).not.to.include("nums.length");
1243
+ });
968
1244
  it("should project CLR Union_n member access deterministically", () => {
969
1245
  const unionReference = {
970
1246
  kind: "referenceType",
@@ -1165,6 +1441,64 @@ describe("Expression Emission", () => {
1165
1441
  // Should be a Dictionary with global:: prefix
1166
1442
  expect(result).to.include("new global::System.Collections.Generic.Dictionary<string, double>");
1167
1443
  });
1444
+ it("should emit computed string-literal keys for nominal object initializers", () => {
1445
+ const module = {
1446
+ kind: "module",
1447
+ filePath: "/src/test.ts",
1448
+ namespace: "MyApp",
1449
+ className: "test",
1450
+ isStaticContainer: true,
1451
+ imports: [],
1452
+ body: [
1453
+ {
1454
+ kind: "interfaceDeclaration",
1455
+ name: "Box",
1456
+ typeParameters: [],
1457
+ extends: [],
1458
+ members: [
1459
+ {
1460
+ kind: "propertySignature",
1461
+ name: "foo",
1462
+ type: { kind: "primitiveType", name: "number" },
1463
+ isOptional: false,
1464
+ isReadonly: false,
1465
+ },
1466
+ ],
1467
+ isExported: false,
1468
+ isStruct: false,
1469
+ },
1470
+ {
1471
+ kind: "variableDeclaration",
1472
+ declarationKind: "const",
1473
+ isExported: false,
1474
+ declarations: [
1475
+ {
1476
+ kind: "variableDeclarator",
1477
+ name: { kind: "identifierPattern", name: "box" },
1478
+ type: { kind: "referenceType", name: "Box" },
1479
+ initializer: {
1480
+ kind: "object",
1481
+ properties: [
1482
+ {
1483
+ kind: "property",
1484
+ key: { kind: "literal", value: "foo" },
1485
+ value: { kind: "literal", value: 1 },
1486
+ shorthand: false,
1487
+ },
1488
+ ],
1489
+ contextualType: { kind: "referenceType", name: "Box" },
1490
+ inferredType: { kind: "referenceType", name: "Box" },
1491
+ },
1492
+ },
1493
+ ],
1494
+ },
1495
+ ],
1496
+ exports: [],
1497
+ };
1498
+ const result = emitModule(module);
1499
+ expect(result).not.to.include("/* computed */");
1500
+ expect(result).to.include("foo = 1");
1501
+ });
1168
1502
  it("should lower dictionary[key] !== undefined to ContainsKey", () => {
1169
1503
  const dictType = {
1170
1504
  kind: "dictionaryType",
@@ -1211,6 +1545,277 @@ describe("Expression Emission", () => {
1211
1545
  expect(result).to.include('(dict).ContainsKey("x")');
1212
1546
  expect(result).to.not.include('dict["x"] != null');
1213
1547
  });
1548
+ it("should lower dictionary.Keys to a materialized key array", () => {
1549
+ const dictType = {
1550
+ kind: "dictionaryType",
1551
+ keyType: { kind: "primitiveType", name: "string" },
1552
+ valueType: { kind: "primitiveType", name: "number" },
1553
+ };
1554
+ const module = {
1555
+ kind: "module",
1556
+ filePath: "/src/test.ts",
1557
+ namespace: "MyApp",
1558
+ className: "test",
1559
+ isStaticContainer: true,
1560
+ imports: [],
1561
+ body: [
1562
+ {
1563
+ kind: "variableDeclaration",
1564
+ declarationKind: "const",
1565
+ isExported: false,
1566
+ declarations: [
1567
+ {
1568
+ kind: "variableDeclarator",
1569
+ name: { kind: "identifierPattern", name: "keys" },
1570
+ initializer: {
1571
+ kind: "memberAccess",
1572
+ object: {
1573
+ kind: "identifier",
1574
+ name: "dict",
1575
+ inferredType: dictType,
1576
+ },
1577
+ property: "Keys",
1578
+ isComputed: false,
1579
+ isOptional: false,
1580
+ inferredType: {
1581
+ kind: "arrayType",
1582
+ elementType: { kind: "primitiveType", name: "string" },
1583
+ },
1584
+ },
1585
+ },
1586
+ ],
1587
+ },
1588
+ ],
1589
+ exports: [],
1590
+ };
1591
+ const result = emitModule(module);
1592
+ expect(result).to.include("new global::System.Collections.Generic.List<string>(dict.Keys).ToArray()");
1593
+ });
1594
+ it("should lower dictionary.Values to a materialized value array", () => {
1595
+ const dictType = {
1596
+ kind: "dictionaryType",
1597
+ keyType: { kind: "primitiveType", name: "string" },
1598
+ valueType: { kind: "referenceType", name: "long" },
1599
+ };
1600
+ const module = {
1601
+ kind: "module",
1602
+ filePath: "/src/test.ts",
1603
+ namespace: "MyApp",
1604
+ className: "test",
1605
+ isStaticContainer: true,
1606
+ imports: [],
1607
+ body: [
1608
+ {
1609
+ kind: "variableDeclaration",
1610
+ declarationKind: "const",
1611
+ isExported: false,
1612
+ declarations: [
1613
+ {
1614
+ kind: "variableDeclarator",
1615
+ name: { kind: "identifierPattern", name: "values" },
1616
+ initializer: {
1617
+ kind: "memberAccess",
1618
+ object: {
1619
+ kind: "identifier",
1620
+ name: "dict",
1621
+ inferredType: dictType,
1622
+ },
1623
+ property: "Values",
1624
+ isComputed: false,
1625
+ isOptional: false,
1626
+ inferredType: {
1627
+ kind: "arrayType",
1628
+ elementType: { kind: "referenceType", name: "long" },
1629
+ },
1630
+ },
1631
+ },
1632
+ ],
1633
+ },
1634
+ ],
1635
+ exports: [],
1636
+ };
1637
+ const result = emitModule(module);
1638
+ expect(result).to.include("new global::System.Collections.Generic.List<long>(dict.Values).ToArray()");
1639
+ });
1640
+ it("should upcast dictionary values into union wrappers for expected dictionary union types", () => {
1641
+ const module = {
1642
+ kind: "module",
1643
+ filePath: "/src/test.ts",
1644
+ namespace: "MyApp",
1645
+ className: "test",
1646
+ isStaticContainer: true,
1647
+ imports: [],
1648
+ body: [
1649
+ {
1650
+ kind: "variableDeclaration",
1651
+ declarationKind: "const",
1652
+ isExported: false,
1653
+ declarations: [
1654
+ {
1655
+ kind: "variableDeclarator",
1656
+ name: { kind: "identifierPattern", name: "widened" },
1657
+ type: {
1658
+ kind: "dictionaryType",
1659
+ keyType: { kind: "primitiveType", name: "string" },
1660
+ valueType: {
1661
+ kind: "unionType",
1662
+ types: [
1663
+ { kind: "referenceType", name: "int" },
1664
+ { kind: "primitiveType", name: "string" },
1665
+ ],
1666
+ },
1667
+ },
1668
+ initializer: {
1669
+ kind: "identifier",
1670
+ name: "raw",
1671
+ inferredType: {
1672
+ kind: "dictionaryType",
1673
+ keyType: { kind: "primitiveType", name: "string" },
1674
+ valueType: { kind: "referenceType", name: "int" },
1675
+ },
1676
+ },
1677
+ },
1678
+ ],
1679
+ },
1680
+ ],
1681
+ exports: [],
1682
+ };
1683
+ const result = emitModule(module);
1684
+ expect(result).to.include("global::System.Linq.Enumerable.ToDictionary");
1685
+ expect(result).to.include("global::Tsonic.Runtime.Union<int, string>.From1");
1686
+ });
1687
+ it("should not upcast when dictionary value type already matches union runtime type", () => {
1688
+ const unionType = {
1689
+ kind: "unionType",
1690
+ types: [
1691
+ { kind: "referenceType", name: "int" },
1692
+ { kind: "primitiveType", name: "string" },
1693
+ ],
1694
+ };
1695
+ const module = {
1696
+ kind: "module",
1697
+ filePath: "/src/test.ts",
1698
+ namespace: "MyApp",
1699
+ className: "test",
1700
+ isStaticContainer: true,
1701
+ imports: [],
1702
+ body: [
1703
+ {
1704
+ kind: "variableDeclaration",
1705
+ declarationKind: "const",
1706
+ isExported: false,
1707
+ declarations: [
1708
+ {
1709
+ kind: "variableDeclarator",
1710
+ name: { kind: "identifierPattern", name: "alreadyWide" },
1711
+ type: {
1712
+ kind: "dictionaryType",
1713
+ keyType: { kind: "primitiveType", name: "string" },
1714
+ valueType: unionType,
1715
+ },
1716
+ initializer: {
1717
+ kind: "identifier",
1718
+ name: "input",
1719
+ inferredType: {
1720
+ kind: "dictionaryType",
1721
+ keyType: { kind: "primitiveType", name: "string" },
1722
+ valueType: unionType,
1723
+ },
1724
+ },
1725
+ },
1726
+ ],
1727
+ },
1728
+ ],
1729
+ exports: [],
1730
+ };
1731
+ const result = emitModule(module);
1732
+ expect(result).not.to.include("global::System.Linq.Enumerable.ToDictionary");
1733
+ });
1734
+ it("should lower symbol-key dictionary undefined checks to ContainsKey", () => {
1735
+ const dictType = {
1736
+ kind: "dictionaryType",
1737
+ keyType: { kind: "referenceType", name: "object" },
1738
+ valueType: { kind: "primitiveType", name: "number" },
1739
+ };
1740
+ const module = {
1741
+ kind: "module",
1742
+ filePath: "/src/test.ts",
1743
+ namespace: "MyApp",
1744
+ className: "test",
1745
+ isStaticContainer: true,
1746
+ imports: [],
1747
+ body: [
1748
+ {
1749
+ kind: "ifStatement",
1750
+ condition: {
1751
+ kind: "binary",
1752
+ operator: "===",
1753
+ left: {
1754
+ kind: "memberAccess",
1755
+ object: {
1756
+ kind: "identifier",
1757
+ name: "dict",
1758
+ inferredType: dictType,
1759
+ },
1760
+ property: { kind: "identifier", name: "key" },
1761
+ isComputed: true,
1762
+ isOptional: false,
1763
+ accessKind: "dictionary",
1764
+ inferredType: { kind: "primitiveType", name: "number" },
1765
+ },
1766
+ right: { kind: "identifier", name: "undefined" },
1767
+ },
1768
+ thenStatement: {
1769
+ kind: "blockStatement",
1770
+ statements: [],
1771
+ },
1772
+ },
1773
+ ],
1774
+ exports: [],
1775
+ };
1776
+ const result = emitModule(module);
1777
+ expect(result).to.include("!(dict).ContainsKey(key)");
1778
+ expect(result).to.not.include("dict[key] == null");
1779
+ });
1780
+ it("should lower delete on symbol-key dictionary access to Remove", () => {
1781
+ const dictType = {
1782
+ kind: "dictionaryType",
1783
+ keyType: { kind: "referenceType", name: "object" },
1784
+ valueType: { kind: "primitiveType", name: "number" },
1785
+ };
1786
+ const module = {
1787
+ kind: "module",
1788
+ filePath: "/src/test.ts",
1789
+ namespace: "MyApp",
1790
+ className: "test",
1791
+ isStaticContainer: true,
1792
+ imports: [],
1793
+ body: [
1794
+ {
1795
+ kind: "expressionStatement",
1796
+ expression: {
1797
+ kind: "unary",
1798
+ operator: "delete",
1799
+ expression: {
1800
+ kind: "memberAccess",
1801
+ object: {
1802
+ kind: "identifier",
1803
+ name: "dict",
1804
+ inferredType: dictType,
1805
+ },
1806
+ property: { kind: "identifier", name: "key" },
1807
+ isComputed: true,
1808
+ isOptional: false,
1809
+ accessKind: "dictionary",
1810
+ },
1811
+ },
1812
+ },
1813
+ ],
1814
+ exports: [],
1815
+ };
1816
+ const result = emitModule(module);
1817
+ expect(result).to.include("dict.Remove(key);");
1818
+ });
1214
1819
  it("should infer arrow function return type from inferredType", () => {
1215
1820
  const module = {
1216
1821
  kind: "module",