@tsonic/emitter 0.0.74 → 0.0.75

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 (1497) hide show
  1. package/dist/.tsbuildinfo +1 -1
  2. package/dist/array.test.js +277 -6
  3. package/dist/array.test.js.map +1 -1
  4. package/dist/core/format/attributes.d.ts +3 -3
  5. package/dist/core/format/attributes.js +3 -3
  6. package/dist/core/format/backend-ast/builders.d.ts +1 -0
  7. package/dist/core/format/backend-ast/builders.d.ts.map +1 -1
  8. package/dist/core/format/backend-ast/builders.js +44 -22
  9. package/dist/core/format/backend-ast/builders.js.map +1 -1
  10. package/dist/core/format/backend-ast/invariants.test.js +15 -8
  11. package/dist/core/format/backend-ast/invariants.test.js.map +1 -1
  12. package/dist/core/format/backend-ast/printer-cases/basic-and-declarations.test.d.ts +2 -0
  13. package/dist/core/format/backend-ast/printer-cases/basic-and-declarations.test.d.ts.map +1 -0
  14. package/dist/core/format/backend-ast/printer-cases/basic-and-declarations.test.js +226 -0
  15. package/dist/core/format/backend-ast/printer-cases/basic-and-declarations.test.js.map +1 -0
  16. package/dist/core/format/backend-ast/printer-cases/control-flow-and-switch.test.d.ts +2 -0
  17. package/dist/core/format/backend-ast/printer-cases/control-flow-and-switch.test.d.ts.map +1 -0
  18. package/dist/core/format/backend-ast/printer-cases/control-flow-and-switch.test.js +289 -0
  19. package/dist/core/format/backend-ast/printer-cases/control-flow-and-switch.test.js.map +1 -0
  20. package/dist/core/format/backend-ast/printer-cases/helpers.d.ts +6 -0
  21. package/dist/core/format/backend-ast/printer-cases/helpers.d.ts.map +1 -0
  22. package/dist/core/format/backend-ast/printer-cases/helpers.js +5 -0
  23. package/dist/core/format/backend-ast/printer-cases/helpers.js.map +1 -0
  24. package/dist/core/format/backend-ast/printer-cases/identifiers-and-interpolation.test.d.ts +2 -0
  25. package/dist/core/format/backend-ast/printer-cases/identifiers-and-interpolation.test.d.ts.map +1 -0
  26. package/dist/core/format/backend-ast/printer-cases/identifiers-and-interpolation.test.js +211 -0
  27. package/dist/core/format/backend-ast/printer-cases/identifiers-and-interpolation.test.js.map +1 -0
  28. package/dist/core/format/backend-ast/printer-cases/remaining-nodes.test.d.ts +2 -0
  29. package/dist/core/format/backend-ast/printer-cases/remaining-nodes.test.d.ts.map +1 -0
  30. package/dist/core/format/backend-ast/printer-cases/remaining-nodes.test.js +186 -0
  31. package/dist/core/format/backend-ast/printer-cases/remaining-nodes.test.js.map +1 -0
  32. package/dist/core/format/backend-ast/printer-colon-detection.d.ts +14 -0
  33. package/dist/core/format/backend-ast/printer-colon-detection.d.ts.map +1 -0
  34. package/dist/core/format/backend-ast/printer-colon-detection.js +141 -0
  35. package/dist/core/format/backend-ast/printer-colon-detection.js.map +1 -0
  36. package/dist/core/format/backend-ast/printer-declarations.d.ts +12 -0
  37. package/dist/core/format/backend-ast/printer-declarations.d.ts.map +1 -0
  38. package/dist/core/format/backend-ast/printer-declarations.js +212 -0
  39. package/dist/core/format/backend-ast/printer-declarations.js.map +1 -0
  40. package/dist/core/format/backend-ast/printer-expressions.d.ts +12 -0
  41. package/dist/core/format/backend-ast/printer-expressions.d.ts.map +1 -0
  42. package/dist/core/format/backend-ast/printer-expressions.js +363 -0
  43. package/dist/core/format/backend-ast/printer-expressions.js.map +1 -0
  44. package/dist/core/format/backend-ast/printer-identifiers.d.ts +31 -0
  45. package/dist/core/format/backend-ast/printer-identifiers.d.ts.map +1 -0
  46. package/dist/core/format/backend-ast/printer-identifiers.js +194 -0
  47. package/dist/core/format/backend-ast/printer-identifiers.js.map +1 -0
  48. package/dist/core/format/backend-ast/printer-precedence.d.ts +23 -0
  49. package/dist/core/format/backend-ast/printer-precedence.d.ts.map +1 -0
  50. package/dist/core/format/backend-ast/printer-precedence.js +225 -0
  51. package/dist/core/format/backend-ast/printer-precedence.js.map +1 -0
  52. package/dist/core/format/backend-ast/printer-shared.d.ts +12 -0
  53. package/dist/core/format/backend-ast/printer-shared.d.ts.map +1 -0
  54. package/dist/core/format/backend-ast/printer-shared.js +12 -0
  55. package/dist/core/format/backend-ast/printer-shared.js.map +1 -0
  56. package/dist/core/format/backend-ast/printer-statements.d.ts +24 -0
  57. package/dist/core/format/backend-ast/printer-statements.d.ts.map +1 -0
  58. package/dist/core/format/backend-ast/printer-statements.js +336 -0
  59. package/dist/core/format/backend-ast/printer-statements.js.map +1 -0
  60. package/dist/core/format/backend-ast/printer.d.ts +10 -23
  61. package/dist/core/format/backend-ast/printer.d.ts.map +1 -1
  62. package/dist/core/format/backend-ast/printer.js +11 -1389
  63. package/dist/core/format/backend-ast/printer.js.map +1 -1
  64. package/dist/core/format/backend-ast/printer.test.d.ts +4 -1
  65. package/dist/core/format/backend-ast/printer.test.d.ts.map +1 -1
  66. package/dist/core/format/backend-ast/printer.test.js +4 -795
  67. package/dist/core/format/backend-ast/printer.test.js.map +1 -1
  68. package/dist/core/format/backend-ast/types/compilation-unit-ast.d.ts +26 -0
  69. package/dist/core/format/backend-ast/types/compilation-unit-ast.d.ts.map +1 -0
  70. package/dist/core/format/backend-ast/types/compilation-unit-ast.js +2 -0
  71. package/dist/core/format/backend-ast/types/compilation-unit-ast.js.map +1 -0
  72. package/dist/core/format/backend-ast/types/declaration-ast.d.ts +105 -0
  73. package/dist/core/format/backend-ast/types/declaration-ast.d.ts.map +1 -0
  74. package/dist/core/format/backend-ast/types/declaration-ast.js +2 -0
  75. package/dist/core/format/backend-ast/types/declaration-ast.js.map +1 -0
  76. package/dist/core/format/backend-ast/types/expression-ast.d.ts +219 -0
  77. package/dist/core/format/backend-ast/types/expression-ast.d.ts.map +1 -0
  78. package/dist/core/format/backend-ast/types/expression-ast.js +2 -0
  79. package/dist/core/format/backend-ast/types/expression-ast.js.map +1 -0
  80. package/dist/core/format/backend-ast/types/pattern-ast.d.ts +28 -0
  81. package/dist/core/format/backend-ast/types/pattern-ast.d.ts.map +1 -0
  82. package/dist/core/format/backend-ast/types/pattern-ast.js +2 -0
  83. package/dist/core/format/backend-ast/types/pattern-ast.js.map +1 -0
  84. package/dist/core/format/backend-ast/types/signature-ast.d.ts +34 -0
  85. package/dist/core/format/backend-ast/types/signature-ast.d.ts.map +1 -0
  86. package/dist/core/format/backend-ast/types/signature-ast.js +2 -0
  87. package/dist/core/format/backend-ast/types/signature-ast.js.map +1 -0
  88. package/dist/core/format/backend-ast/types/statement-ast.d.ts +118 -0
  89. package/dist/core/format/backend-ast/types/statement-ast.d.ts.map +1 -0
  90. package/dist/core/format/backend-ast/types/statement-ast.js +2 -0
  91. package/dist/core/format/backend-ast/types/statement-ast.js.map +1 -0
  92. package/dist/core/format/backend-ast/types/type-ast.d.ts +50 -0
  93. package/dist/core/format/backend-ast/types/type-ast.d.ts.map +1 -0
  94. package/dist/core/format/backend-ast/types/type-ast.js +2 -0
  95. package/dist/core/format/backend-ast/types/type-ast.js.map +1 -0
  96. package/dist/core/format/backend-ast/types.d.ts +7 -549
  97. package/dist/core/format/backend-ast/types.d.ts.map +1 -1
  98. package/dist/core/format/backend-ast/types.js +7 -1
  99. package/dist/core/format/backend-ast/types.js.map +1 -1
  100. package/dist/core/format/backend-ast/utils.d.ts +4 -0
  101. package/dist/core/format/backend-ast/utils.d.ts.map +1 -1
  102. package/dist/core/format/backend-ast/utils.js +87 -16
  103. package/dist/core/format/backend-ast/utils.js.map +1 -1
  104. package/dist/core/format/backend-ast/utils.test.js +67 -4
  105. package/dist/core/format/backend-ast/utils.test.js.map +1 -1
  106. package/dist/core/format/local-names.d.ts +26 -0
  107. package/dist/core/format/local-names.d.ts.map +1 -1
  108. package/dist/core/format/local-names.js +59 -0
  109. package/dist/core/format/local-names.js.map +1 -1
  110. package/dist/core/format/local-names.test.d.ts +12 -0
  111. package/dist/core/format/local-names.test.d.ts.map +1 -0
  112. package/dist/core/format/local-names.test.js +278 -0
  113. package/dist/core/format/local-names.test.js.map +1 -0
  114. package/dist/core/format/module-emitter/orchestrator.d.ts.map +1 -1
  115. package/dist/core/format/module-emitter/orchestrator.js +1 -152
  116. package/dist/core/format/module-emitter/orchestrator.js.map +1 -1
  117. package/dist/core/format/module-emitter/static-container.d.ts.map +1 -1
  118. package/dist/core/format/module-emitter/static-container.js +17 -1
  119. package/dist/core/format/module-emitter/static-container.js.map +1 -1
  120. package/dist/core/module-emitter-cases/class-and-recursion.test.d.ts +6 -0
  121. package/dist/core/module-emitter-cases/class-and-recursion.test.d.ts.map +1 -0
  122. package/dist/core/module-emitter-cases/class-and-recursion.test.js +263 -0
  123. package/dist/core/module-emitter-cases/class-and-recursion.test.js.map +1 -0
  124. package/dist/core/module-emitter-cases/static-containers.test.d.ts +6 -0
  125. package/dist/core/module-emitter-cases/static-containers.test.d.ts.map +1 -0
  126. package/dist/core/module-emitter-cases/static-containers.test.js +275 -0
  127. package/dist/core/module-emitter-cases/static-containers.test.js.map +1 -0
  128. package/dist/core/module-emitter.test.d.ts +2 -5
  129. package/dist/core/module-emitter.test.d.ts.map +1 -1
  130. package/dist/core/module-emitter.test.js +2 -403
  131. package/dist/core/module-emitter.test.js.map +1 -1
  132. package/dist/core/semantic/array-expected-types.d.ts +6 -0
  133. package/dist/core/semantic/array-expected-types.d.ts.map +1 -0
  134. package/dist/core/semantic/array-expected-types.js +84 -0
  135. package/dist/core/semantic/array-expected-types.js.map +1 -0
  136. package/dist/core/semantic/array-expected-types.test.d.ts +2 -0
  137. package/dist/core/semantic/array-expected-types.test.d.ts.map +1 -0
  138. package/dist/core/semantic/array-expected-types.test.js +66 -0
  139. package/dist/core/semantic/array-expected-types.test.js.map +1 -0
  140. package/dist/core/semantic/assignment-flow.d.ts +9 -0
  141. package/dist/core/semantic/assignment-flow.d.ts.map +1 -0
  142. package/dist/core/semantic/assignment-flow.js +161 -0
  143. package/dist/core/semantic/assignment-flow.js.map +1 -0
  144. package/dist/core/semantic/async-wrapper-types.d.ts +6 -0
  145. package/dist/core/semantic/async-wrapper-types.d.ts.map +1 -0
  146. package/dist/core/semantic/async-wrapper-types.js +65 -0
  147. package/dist/core/semantic/async-wrapper-types.js.map +1 -0
  148. package/dist/core/semantic/boolean-condition-emission.d.ts +9 -0
  149. package/dist/core/semantic/boolean-condition-emission.d.ts.map +1 -0
  150. package/dist/core/semantic/boolean-condition-emission.js +9 -0
  151. package/dist/core/semantic/boolean-condition-emission.js.map +1 -0
  152. package/dist/core/semantic/boolean-condition-main.d.ts +38 -0
  153. package/dist/core/semantic/boolean-condition-main.d.ts.map +1 -0
  154. package/dist/core/semantic/boolean-condition-main.js +235 -0
  155. package/dist/core/semantic/boolean-condition-main.js.map +1 -0
  156. package/dist/core/semantic/boolean-condition-union.d.ts +20 -0
  157. package/dist/core/semantic/boolean-condition-union.d.ts.map +1 -0
  158. package/dist/core/semantic/boolean-condition-union.js +238 -0
  159. package/dist/core/semantic/boolean-condition-union.js.map +1 -0
  160. package/dist/core/semantic/boolean-context.d.ts +6 -40
  161. package/dist/core/semantic/boolean-context.d.ts.map +1 -1
  162. package/dist/core/semantic/boolean-context.js +6 -709
  163. package/dist/core/semantic/boolean-context.js.map +1 -1
  164. package/dist/core/semantic/boolean-context.test.js +22 -2
  165. package/dist/core/semantic/boolean-context.test.js.map +1 -1
  166. package/dist/core/semantic/broad-array-storage.d.ts +11 -0
  167. package/dist/core/semantic/broad-array-storage.d.ts.map +1 -0
  168. package/dist/core/semantic/broad-array-storage.js +111 -0
  169. package/dist/core/semantic/broad-array-storage.js.map +1 -0
  170. package/dist/core/semantic/broad-object-types.d.ts +7 -0
  171. package/dist/core/semantic/broad-object-types.d.ts.map +1 -0
  172. package/dist/core/semantic/broad-object-types.js +60 -0
  173. package/dist/core/semantic/broad-object-types.js.map +1 -0
  174. package/dist/core/semantic/clr-type-identity.d.ts +21 -0
  175. package/dist/core/semantic/clr-type-identity.d.ts.map +1 -0
  176. package/dist/core/semantic/clr-type-identity.js +230 -0
  177. package/dist/core/semantic/clr-type-identity.js.map +1 -0
  178. package/dist/core/semantic/comparable-types.d.ts +5 -0
  179. package/dist/core/semantic/comparable-types.d.ts.map +1 -0
  180. package/dist/core/semantic/comparable-types.js +108 -0
  181. package/dist/core/semantic/comparable-types.js.map +1 -0
  182. package/dist/core/semantic/comparable-types.test.d.ts +2 -0
  183. package/dist/core/semantic/comparable-types.test.d.ts.map +1 -0
  184. package/dist/core/semantic/comparable-types.test.js +199 -0
  185. package/dist/core/semantic/comparable-types.test.js.map +1 -0
  186. package/dist/core/semantic/condition-branch-narrowing.d.ts +6 -0
  187. package/dist/core/semantic/condition-branch-narrowing.d.ts.map +1 -0
  188. package/dist/core/semantic/condition-branch-narrowing.js +50 -0
  189. package/dist/core/semantic/condition-branch-narrowing.js.map +1 -0
  190. package/dist/core/semantic/defaults.d.ts +7 -0
  191. package/dist/core/semantic/defaults.d.ts.map +1 -0
  192. package/dist/core/semantic/defaults.js +61 -0
  193. package/dist/core/semantic/defaults.js.map +1 -0
  194. package/dist/core/semantic/defaults.test.d.ts +2 -0
  195. package/dist/core/semantic/defaults.test.d.ts.map +1 -0
  196. package/dist/core/semantic/defaults.test.js +88 -0
  197. package/dist/core/semantic/defaults.test.js.map +1 -0
  198. package/dist/core/semantic/deterministic-type-keys.d.ts +8 -0
  199. package/dist/core/semantic/deterministic-type-keys.d.ts.map +1 -0
  200. package/dist/core/semantic/deterministic-type-keys.js +277 -0
  201. package/dist/core/semantic/deterministic-type-keys.js.map +1 -0
  202. package/dist/core/semantic/direct-storage-ir-types.d.ts +12 -0
  203. package/dist/core/semantic/direct-storage-ir-types.d.ts.map +1 -0
  204. package/dist/core/semantic/direct-storage-ir-types.js +189 -0
  205. package/dist/core/semantic/direct-storage-ir-types.js.map +1 -0
  206. package/dist/core/semantic/direct-value-surfaces.d.ts +9 -0
  207. package/dist/core/semantic/direct-value-surfaces.d.ts.map +1 -0
  208. package/dist/core/semantic/direct-value-surfaces.js +181 -0
  209. package/dist/core/semantic/direct-value-surfaces.js.map +1 -0
  210. package/dist/core/semantic/direct-value-surfaces.test.d.ts +2 -0
  211. package/dist/core/semantic/direct-value-surfaces.test.d.ts.map +1 -0
  212. package/dist/core/semantic/direct-value-surfaces.test.js +116 -0
  213. package/dist/core/semantic/direct-value-surfaces.test.js.map +1 -0
  214. package/dist/core/semantic/expected-type-matching.d.ts +7 -0
  215. package/dist/core/semantic/expected-type-matching.d.ts.map +1 -0
  216. package/dist/core/semantic/expected-type-matching.js +101 -0
  217. package/dist/core/semantic/expected-type-matching.js.map +1 -0
  218. package/dist/core/semantic/guard-primitives.d.ts +29 -0
  219. package/dist/core/semantic/guard-primitives.d.ts.map +1 -0
  220. package/dist/core/semantic/guard-primitives.js +80 -0
  221. package/dist/core/semantic/guard-primitives.js.map +1 -0
  222. package/dist/core/semantic/implicit-interfaces.d.ts +34 -0
  223. package/dist/core/semantic/implicit-interfaces.d.ts.map +1 -0
  224. package/dist/core/semantic/implicit-interfaces.js +276 -0
  225. package/dist/core/semantic/implicit-interfaces.js.map +1 -0
  226. package/dist/core/semantic/implicit-interfaces.test.d.ts +2 -0
  227. package/dist/core/semantic/implicit-interfaces.test.d.ts.map +1 -0
  228. package/dist/core/semantic/implicit-interfaces.test.js +280 -0
  229. package/dist/core/semantic/implicit-interfaces.test.js.map +1 -0
  230. package/dist/core/semantic/imports-cases/basic-and-local.test.d.ts +6 -0
  231. package/dist/core/semantic/imports-cases/basic-and-local.test.d.ts.map +1 -0
  232. package/dist/core/semantic/imports-cases/basic-and-local.test.js +504 -0
  233. package/dist/core/semantic/imports-cases/basic-and-local.test.js.map +1 -0
  234. package/dist/core/semantic/imports-cases/bindings-and-namespaces.test.d.ts +6 -0
  235. package/dist/core/semantic/imports-cases/bindings-and-namespaces.test.d.ts.map +1 -0
  236. package/dist/core/semantic/imports-cases/bindings-and-namespaces.test.js +932 -0
  237. package/dist/core/semantic/imports-cases/bindings-and-namespaces.test.js.map +1 -0
  238. package/dist/core/semantic/imports.d.ts.map +1 -1
  239. package/dist/core/semantic/imports.js +158 -22
  240. package/dist/core/semantic/imports.js.map +1 -1
  241. package/dist/core/semantic/imports.test.d.ts +2 -5
  242. package/dist/core/semantic/imports.test.d.ts.map +1 -1
  243. package/dist/core/semantic/imports.test.js +2 -551
  244. package/dist/core/semantic/imports.test.js.map +1 -1
  245. package/dist/core/semantic/instanceof-predicate-refinements.d.ts +10 -0
  246. package/dist/core/semantic/instanceof-predicate-refinements.d.ts.map +1 -0
  247. package/dist/core/semantic/instanceof-predicate-refinements.js +189 -0
  248. package/dist/core/semantic/instanceof-predicate-refinements.js.map +1 -0
  249. package/dist/core/semantic/instanceof-targets.d.ts +10 -0
  250. package/dist/core/semantic/instanceof-targets.d.ts.map +1 -0
  251. package/dist/core/semantic/instanceof-targets.js +20 -0
  252. package/dist/core/semantic/instanceof-targets.js.map +1 -0
  253. package/dist/core/semantic/iteration-types.d.ts +11 -0
  254. package/dist/core/semantic/iteration-types.d.ts.map +1 -0
  255. package/dist/core/semantic/iteration-types.js +116 -0
  256. package/dist/core/semantic/iteration-types.js.map +1 -0
  257. package/dist/core/semantic/js-value-types.d.ts +5 -0
  258. package/dist/core/semantic/js-value-types.d.ts.map +1 -0
  259. package/dist/core/semantic/js-value-types.js +42 -0
  260. package/dist/core/semantic/js-value-types.js.map +1 -0
  261. package/dist/core/semantic/local-type-lookup.d.ts +8 -0
  262. package/dist/core/semantic/local-type-lookup.d.ts.map +1 -0
  263. package/dist/core/semantic/local-type-lookup.js +36 -0
  264. package/dist/core/semantic/local-type-lookup.js.map +1 -0
  265. package/dist/core/semantic/local-types.d.ts +1 -0
  266. package/dist/core/semantic/local-types.d.ts.map +1 -1
  267. package/dist/core/semantic/local-types.js +269 -0
  268. package/dist/core/semantic/local-types.js.map +1 -1
  269. package/dist/core/semantic/materialized-narrowing.d.ts +5 -0
  270. package/dist/core/semantic/materialized-narrowing.d.ts.map +1 -0
  271. package/dist/core/semantic/materialized-narrowing.js +361 -0
  272. package/dist/core/semantic/materialized-narrowing.js.map +1 -0
  273. package/dist/core/semantic/materialized-narrowing.test.d.ts +2 -0
  274. package/dist/core/semantic/materialized-narrowing.test.d.ts.map +1 -0
  275. package/dist/core/semantic/materialized-narrowing.test.js +321 -0
  276. package/dist/core/semantic/materialized-narrowing.test.js.map +1 -0
  277. package/dist/core/semantic/member-surfaces.d.ts +10 -0
  278. package/dist/core/semantic/member-surfaces.d.ts.map +1 -0
  279. package/dist/core/semantic/member-surfaces.js +108 -0
  280. package/dist/core/semantic/member-surfaces.js.map +1 -0
  281. package/dist/core/semantic/member-surfaces.test.d.ts +2 -0
  282. package/dist/core/semantic/member-surfaces.test.d.ts.map +1 -0
  283. package/dist/core/semantic/member-surfaces.test.js +105 -0
  284. package/dist/core/semantic/member-surfaces.test.js.map +1 -0
  285. package/dist/core/semantic/module-map.d.ts.map +1 -1
  286. package/dist/core/semantic/module-map.js +92 -2
  287. package/dist/core/semantic/module-map.js.map +1 -1
  288. package/dist/core/semantic/module-map.test.js +264 -0
  289. package/dist/core/semantic/module-map.test.js.map +1 -1
  290. package/dist/core/semantic/mutable-storage-detection.d.ts +10 -0
  291. package/dist/core/semantic/mutable-storage-detection.d.ts.map +1 -0
  292. package/dist/core/semantic/mutable-storage-detection.js +10 -0
  293. package/dist/core/semantic/mutable-storage-detection.js.map +1 -0
  294. package/dist/core/semantic/mutable-storage-expression-visitor.d.ts +12 -0
  295. package/dist/core/semantic/mutable-storage-expression-visitor.d.ts.map +1 -0
  296. package/dist/core/semantic/mutable-storage-expression-visitor.js +126 -0
  297. package/dist/core/semantic/mutable-storage-expression-visitor.js.map +1 -0
  298. package/dist/core/semantic/mutable-storage-helpers.d.ts +26 -0
  299. package/dist/core/semantic/mutable-storage-helpers.d.ts.map +1 -0
  300. package/dist/core/semantic/mutable-storage-helpers.js +203 -0
  301. package/dist/core/semantic/mutable-storage-helpers.js.map +1 -0
  302. package/dist/core/semantic/mutable-storage-statement-visitor.d.ts +5 -0
  303. package/dist/core/semantic/mutable-storage-statement-visitor.d.ts.map +1 -0
  304. package/dist/core/semantic/mutable-storage-statement-visitor.js +158 -0
  305. package/dist/core/semantic/mutable-storage-statement-visitor.js.map +1 -0
  306. package/dist/core/semantic/mutable-storage-visitors.d.ts +5 -0
  307. package/dist/core/semantic/mutable-storage-visitors.d.ts.map +1 -0
  308. package/dist/core/semantic/mutable-storage-visitors.js +17 -0
  309. package/dist/core/semantic/mutable-storage-visitors.js.map +1 -0
  310. package/dist/core/semantic/mutable-storage.d.ts +2 -9
  311. package/dist/core/semantic/mutable-storage.d.ts.map +1 -1
  312. package/dist/core/semantic/mutable-storage.js +2 -478
  313. package/dist/core/semantic/mutable-storage.js.map +1 -1
  314. package/dist/core/semantic/narrowed-expression-types.d.ts +7 -0
  315. package/dist/core/semantic/narrowed-expression-types.d.ts.map +1 -0
  316. package/dist/core/semantic/narrowed-expression-types.js +287 -0
  317. package/dist/core/semantic/narrowed-expression-types.js.map +1 -0
  318. package/dist/core/semantic/narrowed-expression-types.test.d.ts +2 -0
  319. package/dist/core/semantic/narrowed-expression-types.test.d.ts.map +1 -0
  320. package/dist/core/semantic/narrowed-expression-types.test.js +296 -0
  321. package/dist/core/semantic/narrowed-expression-types.test.js.map +1 -0
  322. package/dist/core/semantic/narrowed-union-resolution.d.ts +42 -0
  323. package/dist/core/semantic/narrowed-union-resolution.d.ts.map +1 -0
  324. package/dist/core/semantic/narrowed-union-resolution.js +162 -0
  325. package/dist/core/semantic/narrowed-union-resolution.js.map +1 -0
  326. package/dist/core/semantic/narrowing-builder-core.d.ts +46 -0
  327. package/dist/core/semantic/narrowing-builder-core.d.ts.map +1 -0
  328. package/dist/core/semantic/narrowing-builder-core.js +332 -0
  329. package/dist/core/semantic/narrowing-builder-core.js.map +1 -0
  330. package/dist/core/semantic/narrowing-builder-core.test.d.ts +2 -0
  331. package/dist/core/semantic/narrowing-builder-core.test.d.ts.map +1 -0
  332. package/dist/core/semantic/narrowing-builder-core.test.js +49 -0
  333. package/dist/core/semantic/narrowing-builder-core.test.js.map +1 -0
  334. package/dist/core/semantic/narrowing-builder-unions.d.ts +18 -0
  335. package/dist/core/semantic/narrowing-builder-unions.d.ts.map +1 -0
  336. package/dist/core/semantic/narrowing-builder-unions.js +336 -0
  337. package/dist/core/semantic/narrowing-builder-unions.js.map +1 -0
  338. package/dist/core/semantic/narrowing-builders.d.ts +10 -0
  339. package/dist/core/semantic/narrowing-builders.d.ts.map +1 -0
  340. package/dist/core/semantic/narrowing-builders.js +10 -0
  341. package/dist/core/semantic/narrowing-builders.js.map +1 -0
  342. package/dist/core/semantic/narrowing-keys.d.ts +6 -0
  343. package/dist/core/semantic/narrowing-keys.d.ts.map +1 -0
  344. package/dist/core/semantic/narrowing-keys.js +27 -0
  345. package/dist/core/semantic/narrowing-keys.js.map +1 -0
  346. package/dist/core/semantic/narrowing-refinements.d.ts +10 -0
  347. package/dist/core/semantic/narrowing-refinements.d.ts.map +1 -0
  348. package/dist/core/semantic/narrowing-refinements.js +10 -0
  349. package/dist/core/semantic/narrowing-refinements.js.map +1 -0
  350. package/dist/core/semantic/nullable-typeof-refinements.d.ts +13 -0
  351. package/dist/core/semantic/nullable-typeof-refinements.d.ts.map +1 -0
  352. package/dist/core/semantic/nullable-typeof-refinements.js +408 -0
  353. package/dist/core/semantic/nullable-typeof-refinements.js.map +1 -0
  354. package/dist/core/semantic/nullish-value-helpers.d.ts +64 -0
  355. package/dist/core/semantic/nullish-value-helpers.d.ts.map +1 -0
  356. package/dist/core/semantic/nullish-value-helpers.js +346 -0
  357. package/dist/core/semantic/nullish-value-helpers.js.map +1 -0
  358. package/dist/core/semantic/parameter-modifier-types.d.ts +3 -0
  359. package/dist/core/semantic/parameter-modifier-types.d.ts.map +1 -0
  360. package/dist/core/semantic/parameter-modifier-types.js +17 -0
  361. package/dist/core/semantic/parameter-modifier-types.js.map +1 -0
  362. package/dist/core/semantic/pattern-types.d.ts +59 -0
  363. package/dist/core/semantic/pattern-types.d.ts.map +1 -0
  364. package/dist/core/semantic/pattern-types.js +92 -0
  365. package/dist/core/semantic/pattern-types.js.map +1 -0
  366. package/dist/core/semantic/property-lookup-membership.d.ts +30 -0
  367. package/dist/core/semantic/property-lookup-membership.d.ts.map +1 -0
  368. package/dist/core/semantic/property-lookup-membership.js +176 -0
  369. package/dist/core/semantic/property-lookup-membership.js.map +1 -0
  370. package/dist/core/semantic/property-lookup-resolution.d.ts +52 -0
  371. package/dist/core/semantic/property-lookup-resolution.d.ts.map +1 -0
  372. package/dist/core/semantic/property-lookup-resolution.js +275 -0
  373. package/dist/core/semantic/property-lookup-resolution.js.map +1 -0
  374. package/dist/core/semantic/property-member-lookup.d.ts +10 -0
  375. package/dist/core/semantic/property-member-lookup.d.ts.map +1 -0
  376. package/dist/core/semantic/property-member-lookup.js +10 -0
  377. package/dist/core/semantic/property-member-lookup.js.map +1 -0
  378. package/dist/core/semantic/reference-type-identity.d.ts +10 -0
  379. package/dist/core/semantic/reference-type-identity.d.ts.map +1 -0
  380. package/dist/core/semantic/reference-type-identity.js +28 -0
  381. package/dist/core/semantic/reference-type-identity.js.map +1 -0
  382. package/dist/core/semantic/runtime-call-arities.d.ts +4 -0
  383. package/dist/core/semantic/runtime-call-arities.d.ts.map +1 -0
  384. package/dist/core/semantic/runtime-call-arities.js +104 -0
  385. package/dist/core/semantic/runtime-call-arities.js.map +1 -0
  386. package/dist/core/semantic/runtime-materialization-targets.d.ts +4 -0
  387. package/dist/core/semantic/runtime-materialization-targets.d.ts.map +1 -0
  388. package/dist/core/semantic/runtime-materialization-targets.js +69 -0
  389. package/dist/core/semantic/runtime-materialization-targets.js.map +1 -0
  390. package/dist/core/semantic/runtime-reification-helpers.d.ts +9 -0
  391. package/dist/core/semantic/runtime-reification-helpers.d.ts.map +1 -0
  392. package/dist/core/semantic/runtime-reification-helpers.js +99 -0
  393. package/dist/core/semantic/runtime-reification-helpers.js.map +1 -0
  394. package/dist/core/semantic/runtime-reification.d.ts +16 -0
  395. package/dist/core/semantic/runtime-reification.d.ts.map +1 -0
  396. package/dist/core/semantic/runtime-reification.js +609 -0
  397. package/dist/core/semantic/runtime-reification.js.map +1 -0
  398. package/dist/core/semantic/runtime-union-alias-identity.d.ts +5 -0
  399. package/dist/core/semantic/runtime-union-alias-identity.d.ts.map +1 -0
  400. package/dist/core/semantic/runtime-union-alias-identity.js +27 -0
  401. package/dist/core/semantic/runtime-union-alias-identity.js.map +1 -0
  402. package/dist/core/semantic/runtime-union-expansion.d.ts +5 -0
  403. package/dist/core/semantic/runtime-union-expansion.d.ts.map +1 -0
  404. package/dist/core/semantic/runtime-union-expansion.js +190 -0
  405. package/dist/core/semantic/runtime-union-expansion.js.map +1 -0
  406. package/dist/core/semantic/runtime-union-family-preservation.d.ts +5 -0
  407. package/dist/core/semantic/runtime-union-family-preservation.d.ts.map +1 -0
  408. package/dist/core/semantic/runtime-union-family-preservation.js +34 -0
  409. package/dist/core/semantic/runtime-union-family-preservation.js.map +1 -0
  410. package/dist/core/semantic/runtime-union-matching.d.ts +9 -0
  411. package/dist/core/semantic/runtime-union-matching.d.ts.map +1 -0
  412. package/dist/core/semantic/runtime-union-matching.js +121 -0
  413. package/dist/core/semantic/runtime-union-matching.js.map +1 -0
  414. package/dist/core/semantic/runtime-union-member-mapping.d.ts +12 -0
  415. package/dist/core/semantic/runtime-union-member-mapping.d.ts.map +1 -0
  416. package/dist/core/semantic/runtime-union-member-mapping.js +25 -0
  417. package/dist/core/semantic/runtime-union-member-mapping.js.map +1 -0
  418. package/dist/core/semantic/runtime-union-member-mapping.test.d.ts +2 -0
  419. package/dist/core/semantic/runtime-union-member-mapping.test.d.ts.map +1 -0
  420. package/dist/core/semantic/runtime-union-member-mapping.test.js +54 -0
  421. package/dist/core/semantic/runtime-union-member-mapping.test.js.map +1 -0
  422. package/dist/core/semantic/runtime-union-ordering.d.ts +4 -0
  423. package/dist/core/semantic/runtime-union-ordering.d.ts.map +1 -0
  424. package/dist/core/semantic/runtime-union-ordering.js +114 -0
  425. package/dist/core/semantic/runtime-union-ordering.js.map +1 -0
  426. package/dist/core/semantic/runtime-union-projection.d.ts +40 -0
  427. package/dist/core/semantic/runtime-union-projection.d.ts.map +1 -0
  428. package/dist/core/semantic/runtime-union-projection.js +150 -0
  429. package/dist/core/semantic/runtime-union-projection.js.map +1 -0
  430. package/dist/core/semantic/runtime-union-projection.test.d.ts +2 -0
  431. package/dist/core/semantic/runtime-union-projection.test.d.ts.map +1 -0
  432. package/dist/core/semantic/runtime-union-projection.test.js +211 -0
  433. package/dist/core/semantic/runtime-union-projection.test.js.map +1 -0
  434. package/dist/core/semantic/runtime-union-registry.d.ts +28 -0
  435. package/dist/core/semantic/runtime-union-registry.d.ts.map +1 -0
  436. package/dist/core/semantic/runtime-union-registry.js +301 -0
  437. package/dist/core/semantic/runtime-union-registry.js.map +1 -0
  438. package/dist/core/semantic/runtime-union-shared.d.ts +23 -0
  439. package/dist/core/semantic/runtime-union-shared.d.ts.map +1 -0
  440. package/dist/core/semantic/runtime-union-shared.js +29 -0
  441. package/dist/core/semantic/runtime-union-shared.js.map +1 -0
  442. package/dist/core/semantic/runtime-unions.d.ts +14 -0
  443. package/dist/core/semantic/runtime-unions.d.ts.map +1 -0
  444. package/dist/core/semantic/runtime-unions.js +330 -0
  445. package/dist/core/semantic/runtime-unions.js.map +1 -0
  446. package/dist/core/semantic/runtime-unions.test.d.ts +2 -0
  447. package/dist/core/semantic/runtime-unions.test.d.ts.map +1 -0
  448. package/dist/core/semantic/runtime-unions.test.js +922 -0
  449. package/dist/core/semantic/runtime-unions.test.js.map +1 -0
  450. package/dist/core/semantic/semantic-union-members.d.ts +46 -0
  451. package/dist/core/semantic/semantic-union-members.d.ts.map +1 -0
  452. package/dist/core/semantic/semantic-union-members.js +144 -0
  453. package/dist/core/semantic/semantic-union-members.js.map +1 -0
  454. package/dist/core/semantic/storage-erased-adaptation.d.ts +14 -0
  455. package/dist/core/semantic/storage-erased-adaptation.d.ts.map +1 -0
  456. package/dist/core/semantic/storage-erased-adaptation.js +191 -0
  457. package/dist/core/semantic/storage-erased-adaptation.js.map +1 -0
  458. package/dist/core/semantic/storage-erased-adaptation.test.d.ts +2 -0
  459. package/dist/core/semantic/storage-erased-adaptation.test.d.ts.map +1 -0
  460. package/dist/core/semantic/storage-erased-adaptation.test.js +271 -0
  461. package/dist/core/semantic/storage-erased-adaptation.test.js.map +1 -0
  462. package/dist/core/semantic/storage-types.d.ts +8 -0
  463. package/dist/core/semantic/storage-types.d.ts.map +1 -0
  464. package/dist/core/semantic/storage-types.js +344 -0
  465. package/dist/core/semantic/storage-types.js.map +1 -0
  466. package/dist/core/semantic/storage-types.test.d.ts +2 -0
  467. package/dist/core/semantic/storage-types.test.d.ts.map +1 -0
  468. package/dist/core/semantic/storage-types.test.js +438 -0
  469. package/dist/core/semantic/storage-types.test.js.map +1 -0
  470. package/dist/core/semantic/structural-resolution.d.ts +11 -0
  471. package/dist/core/semantic/structural-resolution.d.ts.map +1 -0
  472. package/dist/core/semantic/structural-resolution.js +11 -0
  473. package/dist/core/semantic/structural-resolution.js.map +1 -0
  474. package/dist/core/semantic/structural-shape-matching.d.ts +22 -0
  475. package/dist/core/semantic/structural-shape-matching.d.ts.map +1 -0
  476. package/dist/core/semantic/structural-shape-matching.js +255 -0
  477. package/dist/core/semantic/structural-shape-matching.js.map +1 -0
  478. package/dist/core/semantic/structural-view-types.d.ts +10 -0
  479. package/dist/core/semantic/structural-view-types.d.ts.map +1 -0
  480. package/dist/core/semantic/structural-view-types.js +46 -0
  481. package/dist/core/semantic/structural-view-types.js.map +1 -0
  482. package/dist/core/semantic/symbol-types.d.ts +80 -0
  483. package/dist/core/semantic/symbol-types.d.ts.map +1 -0
  484. package/dist/core/semantic/symbol-types.js +102 -0
  485. package/dist/core/semantic/symbol-types.js.map +1 -0
  486. package/dist/core/semantic/ternary-guards.d.ts +43 -0
  487. package/dist/core/semantic/ternary-guards.d.ts.map +1 -0
  488. package/dist/core/semantic/ternary-guards.js +232 -0
  489. package/dist/core/semantic/ternary-guards.js.map +1 -0
  490. package/dist/core/semantic/transparent-expressions.d.ts +6 -0
  491. package/dist/core/semantic/transparent-expressions.d.ts.map +1 -0
  492. package/dist/core/semantic/transparent-expressions.js +18 -0
  493. package/dist/core/semantic/transparent-expressions.js.map +1 -0
  494. package/dist/core/semantic/truthiness-evaluation.d.ts +58 -0
  495. package/dist/core/semantic/truthiness-evaluation.d.ts.map +1 -0
  496. package/dist/core/semantic/truthiness-evaluation.js +295 -0
  497. package/dist/core/semantic/truthiness-evaluation.js.map +1 -0
  498. package/dist/core/semantic/type-alias-index.d.ts.map +1 -1
  499. package/dist/core/semantic/type-alias-index.js +1 -11
  500. package/dist/core/semantic/type-alias-index.js.map +1 -1
  501. package/dist/core/semantic/type-compatibility.d.ts +1 -1
  502. package/dist/core/semantic/type-compatibility.d.ts.map +1 -1
  503. package/dist/core/semantic/type-compatibility.js +75 -15
  504. package/dist/core/semantic/type-compatibility.js.map +1 -1
  505. package/dist/core/semantic/type-equivalence.d.ts +4 -0
  506. package/dist/core/semantic/type-equivalence.d.ts.map +1 -0
  507. package/dist/core/semantic/type-equivalence.js +255 -0
  508. package/dist/core/semantic/type-equivalence.js.map +1 -0
  509. package/dist/core/semantic/type-equivalence.test.d.ts +2 -0
  510. package/dist/core/semantic/type-equivalence.test.d.ts.map +1 -0
  511. package/dist/core/semantic/type-equivalence.test.js +380 -0
  512. package/dist/core/semantic/type-equivalence.test.js.map +1 -0
  513. package/dist/core/semantic/type-param-substitution.d.ts +19 -0
  514. package/dist/core/semantic/type-param-substitution.d.ts.map +1 -0
  515. package/dist/core/semantic/type-param-substitution.js +219 -0
  516. package/dist/core/semantic/type-param-substitution.js.map +1 -0
  517. package/dist/core/semantic/type-resolution-cases/array-like-element.test.d.ts +2 -0
  518. package/dist/core/semantic/type-resolution-cases/array-like-element.test.d.ts.map +1 -0
  519. package/dist/core/semantic/type-resolution-cases/array-like-element.test.js +82 -0
  520. package/dist/core/semantic/type-resolution-cases/array-like-element.test.js.map +1 -0
  521. package/dist/core/semantic/type-resolution-cases/contains-type-parameter.test.d.ts +2 -0
  522. package/dist/core/semantic/type-resolution-cases/contains-type-parameter.test.d.ts.map +1 -0
  523. package/dist/core/semantic/type-resolution-cases/contains-type-parameter.test.js +101 -0
  524. package/dist/core/semantic/type-resolution-cases/contains-type-parameter.test.js.map +1 -0
  525. package/dist/core/semantic/type-resolution-cases/helpers.d.ts +8 -0
  526. package/dist/core/semantic/type-resolution-cases/helpers.d.ts.map +1 -0
  527. package/dist/core/semantic/type-resolution-cases/helpers.js +5 -0
  528. package/dist/core/semantic/type-resolution-cases/helpers.js.map +1 -0
  529. package/dist/core/semantic/type-resolution-cases/narrow-typeof.test.d.ts +2 -0
  530. package/dist/core/semantic/type-resolution-cases/narrow-typeof.test.d.ts.map +1 -0
  531. package/dist/core/semantic/type-resolution-cases/narrow-typeof.test.js +98 -0
  532. package/dist/core/semantic/type-resolution-cases/narrow-typeof.test.js.map +1 -0
  533. package/dist/core/semantic/type-resolution-cases/nullish-and-value-type.test.d.ts +2 -0
  534. package/dist/core/semantic/type-resolution-cases/nullish-and-value-type.test.d.ts.map +1 -0
  535. package/dist/core/semantic/type-resolution-cases/nullish-and-value-type.test.js +378 -0
  536. package/dist/core/semantic/type-resolution-cases/nullish-and-value-type.test.js.map +1 -0
  537. package/dist/core/semantic/type-resolution-cases/object-literal-member-selection.test.d.ts +2 -0
  538. package/dist/core/semantic/type-resolution-cases/object-literal-member-selection.test.d.ts.map +1 -0
  539. package/dist/core/semantic/type-resolution-cases/object-literal-member-selection.test.js +137 -0
  540. package/dist/core/semantic/type-resolution-cases/object-literal-member-selection.test.js.map +1 -0
  541. package/dist/core/semantic/type-resolution-cases/property-type.test.d.ts +2 -0
  542. package/dist/core/semantic/type-resolution-cases/property-type.test.d.ts.map +1 -0
  543. package/dist/core/semantic/type-resolution-cases/property-type.test.js +298 -0
  544. package/dist/core/semantic/type-resolution-cases/property-type.test.js.map +1 -0
  545. package/dist/core/semantic/type-resolution-cases/structural-resolution.test.d.ts +2 -0
  546. package/dist/core/semantic/type-resolution-cases/structural-resolution.test.d.ts.map +1 -0
  547. package/dist/core/semantic/type-resolution-cases/structural-resolution.test.js +511 -0
  548. package/dist/core/semantic/type-resolution-cases/structural-resolution.test.js.map +1 -0
  549. package/dist/core/semantic/type-resolution-cases/structural-target.test.d.ts +2 -0
  550. package/dist/core/semantic/type-resolution-cases/structural-target.test.d.ts.map +1 -0
  551. package/dist/core/semantic/type-resolution-cases/structural-target.test.js +80 -0
  552. package/dist/core/semantic/type-resolution-cases/structural-target.test.js.map +1 -0
  553. package/dist/core/semantic/type-resolution-cases/substitute-type-args.test.d.ts +2 -0
  554. package/dist/core/semantic/type-resolution-cases/substitute-type-args.test.d.ts.map +1 -0
  555. package/dist/core/semantic/type-resolution-cases/substitute-type-args.test.js +80 -0
  556. package/dist/core/semantic/type-resolution-cases/substitute-type-args.test.js.map +1 -0
  557. package/dist/core/semantic/type-resolution-cases/union-member-index.test.d.ts +2 -0
  558. package/dist/core/semantic/type-resolution-cases/union-member-index.test.d.ts.map +1 -0
  559. package/dist/core/semantic/type-resolution-cases/union-member-index.test.js +142 -0
  560. package/dist/core/semantic/type-resolution-cases/union-member-index.test.js.map +1 -0
  561. package/dist/core/semantic/type-resolution.d.ts +19 -132
  562. package/dist/core/semantic/type-resolution.d.ts.map +1 -1
  563. package/dist/core/semantic/type-resolution.js +19 -785
  564. package/dist/core/semantic/type-resolution.js.map +1 -1
  565. package/dist/core/semantic/type-resolution.test.d.ts +10 -4
  566. package/dist/core/semantic/type-resolution.test.d.ts.map +1 -1
  567. package/dist/core/semantic/type-resolution.test.js +10 -552
  568. package/dist/core/semantic/type-resolution.test.js.map +1 -1
  569. package/dist/core/semantic/type-substitution.d.ts +10 -0
  570. package/dist/core/semantic/type-substitution.d.ts.map +1 -0
  571. package/dist/core/semantic/type-substitution.js +167 -0
  572. package/dist/core/semantic/type-substitution.js.map +1 -0
  573. package/dist/core/semantic/union-member-matching.d.ts +10 -0
  574. package/dist/core/semantic/union-member-matching.d.ts.map +1 -0
  575. package/dist/core/semantic/union-member-matching.js +10 -0
  576. package/dist/core/semantic/union-member-matching.js.map +1 -0
  577. package/dist/core/semantic/union-predicate-matching.d.ts +40 -0
  578. package/dist/core/semantic/union-predicate-matching.d.ts.map +1 -0
  579. package/dist/core/semantic/union-predicate-matching.js +313 -0
  580. package/dist/core/semantic/union-predicate-matching.js.map +1 -0
  581. package/dist/core/semantic/union-semantics.d.ts +39 -0
  582. package/dist/core/semantic/union-semantics.d.ts.map +1 -0
  583. package/dist/core/semantic/union-semantics.js +48 -0
  584. package/dist/core/semantic/union-semantics.js.map +1 -0
  585. package/dist/core/semantic/union-semantics.test.d.ts +2 -0
  586. package/dist/core/semantic/union-semantics.test.d.ts.map +1 -0
  587. package/dist/core/semantic/union-semantics.test.js +109 -0
  588. package/dist/core/semantic/union-semantics.test.js.map +1 -0
  589. package/dist/core/semantic/union-typeof-matching.d.ts +13 -0
  590. package/dist/core/semantic/union-typeof-matching.d.ts.map +1 -0
  591. package/dist/core/semantic/union-typeof-matching.js +124 -0
  592. package/dist/core/semantic/union-typeof-matching.js.map +1 -0
  593. package/dist/core/semantic/unsafe.d.ts.map +1 -1
  594. package/dist/core/semantic/unsafe.js +23 -15
  595. package/dist/core/semantic/unsafe.js.map +1 -1
  596. package/dist/core/semantic/value-slot-types.d.ts +3 -0
  597. package/dist/core/semantic/value-slot-types.d.ts.map +1 -0
  598. package/dist/core/semantic/value-slot-types.js +8 -0
  599. package/dist/core/semantic/value-slot-types.js.map +1 -0
  600. package/dist/core/semantic/variable-type-resolution.d.ts +68 -0
  601. package/dist/core/semantic/variable-type-resolution.d.ts.map +1 -0
  602. package/dist/core/semantic/variable-type-resolution.js +250 -0
  603. package/dist/core/semantic/variable-type-resolution.js.map +1 -0
  604. package/dist/duplicate-type-suppression.d.ts +18 -0
  605. package/dist/duplicate-type-suppression.d.ts.map +1 -0
  606. package/dist/duplicate-type-suppression.js +249 -0
  607. package/dist/duplicate-type-suppression.js.map +1 -0
  608. package/dist/duplicate-type-suppression.test.d.ts +2 -0
  609. package/dist/duplicate-type-suppression.test.d.ts.map +1 -0
  610. package/dist/duplicate-type-suppression.test.js +44 -0
  611. package/dist/duplicate-type-suppression.test.js.map +1 -0
  612. package/dist/emitter-types/context.d.ts +3 -2
  613. package/dist/emitter-types/context.d.ts.map +1 -1
  614. package/dist/emitter-types/context.js +8 -2
  615. package/dist/emitter-types/context.js.map +1 -1
  616. package/dist/emitter-types/core.d.ts +122 -7
  617. package/dist/emitter-types/core.d.ts.map +1 -1
  618. package/dist/emitter.d.ts +4 -0
  619. package/dist/emitter.d.ts.map +1 -1
  620. package/dist/emitter.js +31 -305
  621. package/dist/emitter.js.map +1 -1
  622. package/dist/expression-emitter.d.ts.map +1 -1
  623. package/dist/expression-emitter.js +55 -1411
  624. package/dist/expression-emitter.js.map +1 -1
  625. package/dist/expressions/access-binding.d.ts +19 -0
  626. package/dist/expressions/access-binding.d.ts.map +1 -0
  627. package/dist/expressions/access-binding.js +286 -0
  628. package/dist/expressions/access-binding.js.map +1 -0
  629. package/dist/expressions/access-computed.d.ts +22 -0
  630. package/dist/expressions/access-computed.d.ts.map +1 -0
  631. package/dist/expressions/access-computed.js +339 -0
  632. package/dist/expressions/access-computed.js.map +1 -0
  633. package/dist/expressions/access-length.d.ts +20 -0
  634. package/dist/expressions/access-length.d.ts.map +1 -0
  635. package/dist/expressions/access-length.js +419 -0
  636. package/dist/expressions/access-length.js.map +1 -0
  637. package/dist/expressions/access-length.test.d.ts +2 -0
  638. package/dist/expressions/access-length.test.d.ts.map +1 -0
  639. package/dist/expressions/access-length.test.js +39 -0
  640. package/dist/expressions/access-length.test.js.map +1 -0
  641. package/dist/expressions/access-property.d.ts +23 -0
  642. package/dist/expressions/access-property.d.ts.map +1 -0
  643. package/dist/expressions/access-property.js +267 -0
  644. package/dist/expressions/access-property.js.map +1 -0
  645. package/dist/expressions/access-resolution-receivers.d.ts +27 -0
  646. package/dist/expressions/access-resolution-receivers.d.ts.map +1 -0
  647. package/dist/expressions/access-resolution-receivers.js +358 -0
  648. package/dist/expressions/access-resolution-receivers.js.map +1 -0
  649. package/dist/expressions/access-resolution-types.d.ts +29 -0
  650. package/dist/expressions/access-resolution-types.d.ts.map +1 -0
  651. package/dist/expressions/access-resolution-types.js +192 -0
  652. package/dist/expressions/access-resolution-types.js.map +1 -0
  653. package/dist/expressions/access-resolution.d.ts +10 -0
  654. package/dist/expressions/access-resolution.d.ts.map +1 -0
  655. package/dist/expressions/access-resolution.js +10 -0
  656. package/dist/expressions/access-resolution.js.map +1 -0
  657. package/dist/expressions/access.d.ts +8 -3
  658. package/dist/expressions/access.d.ts.map +1 -1
  659. package/dist/expressions/access.js +169 -603
  660. package/dist/expressions/access.js.map +1 -1
  661. package/dist/expressions/architecture-invariants.test.d.ts +2 -0
  662. package/dist/expressions/architecture-invariants.test.d.ts.map +1 -0
  663. package/dist/expressions/architecture-invariants.test.js +73 -0
  664. package/dist/expressions/architecture-invariants.test.js.map +1 -0
  665. package/dist/expressions/array-interop.d.ts +3 -0
  666. package/dist/expressions/array-interop.d.ts.map +1 -0
  667. package/dist/expressions/array-interop.js +14 -0
  668. package/dist/expressions/array-interop.js.map +1 -0
  669. package/dist/expressions/array-literal.d.ts +13 -0
  670. package/dist/expressions/array-literal.d.ts.map +1 -0
  671. package/dist/expressions/array-literal.js +373 -0
  672. package/dist/expressions/array-literal.js.map +1 -0
  673. package/dist/expressions/await-normalization.d.ts +6 -0
  674. package/dist/expressions/await-normalization.d.ts.map +1 -0
  675. package/dist/expressions/await-normalization.js +358 -0
  676. package/dist/expressions/await-normalization.js.map +1 -0
  677. package/dist/expressions/calls/call-analysis.d.ts +8 -6
  678. package/dist/expressions/calls/call-analysis.d.ts.map +1 -1
  679. package/dist/expressions/calls/call-analysis.js +120 -31
  680. package/dist/expressions/calls/call-analysis.js.map +1 -1
  681. package/dist/expressions/calls/call-analysis.test.js +2 -2
  682. package/dist/expressions/calls/call-analysis.test.js.map +1 -1
  683. package/dist/expressions/calls/call-arguments-emit.d.ts +16 -0
  684. package/dist/expressions/calls/call-arguments-emit.d.ts.map +1 -0
  685. package/dist/expressions/calls/call-arguments-emit.js +1818 -0
  686. package/dist/expressions/calls/call-arguments-emit.js.map +1 -0
  687. package/dist/expressions/calls/call-arguments-helpers.d.ts +22 -0
  688. package/dist/expressions/calls/call-arguments-helpers.d.ts.map +1 -0
  689. package/dist/expressions/calls/call-arguments-helpers.js +333 -0
  690. package/dist/expressions/calls/call-arguments-helpers.js.map +1 -0
  691. package/dist/expressions/calls/call-arguments.d.ts +10 -0
  692. package/dist/expressions/calls/call-arguments.d.ts.map +1 -0
  693. package/dist/expressions/calls/call-arguments.js +10 -0
  694. package/dist/expressions/calls/call-arguments.js.map +1 -0
  695. package/dist/expressions/calls/call-array-interop.d.ts +10 -0
  696. package/dist/expressions/calls/call-array-interop.d.ts.map +1 -0
  697. package/dist/expressions/calls/call-array-interop.js +10 -0
  698. package/dist/expressions/calls/call-array-interop.js.map +1 -0
  699. package/dist/expressions/calls/call-array-mutation.d.ts +20 -0
  700. package/dist/expressions/calls/call-array-mutation.d.ts.map +1 -0
  701. package/dist/expressions/calls/call-array-mutation.js +260 -0
  702. package/dist/expressions/calls/call-array-mutation.js.map +1 -0
  703. package/dist/expressions/calls/call-array-wrapper.d.ts +14 -0
  704. package/dist/expressions/calls/call-array-wrapper.d.ts.map +1 -0
  705. package/dist/expressions/calls/call-array-wrapper.js +118 -0
  706. package/dist/expressions/calls/call-array-wrapper.js.map +1 -0
  707. package/dist/expressions/calls/call-binding-resolution.d.ts +8 -0
  708. package/dist/expressions/calls/call-binding-resolution.d.ts.map +1 -0
  709. package/dist/expressions/calls/call-binding-resolution.js +12 -0
  710. package/dist/expressions/calls/call-binding-resolution.js.map +1 -0
  711. package/dist/expressions/calls/call-dynamic-import.d.ts +11 -0
  712. package/dist/expressions/calls/call-dynamic-import.d.ts.map +1 -0
  713. package/dist/expressions/calls/call-dynamic-import.js +148 -0
  714. package/dist/expressions/calls/call-dynamic-import.js.map +1 -0
  715. package/dist/expressions/calls/call-emitter.d.ts +9 -3
  716. package/dist/expressions/calls/call-emitter.d.ts.map +1 -1
  717. package/dist/expressions/calls/call-emitter.js +231 -1918
  718. package/dist/expressions/calls/call-emitter.js.map +1 -1
  719. package/dist/expressions/calls/call-emitter.test.d.ts +2 -0
  720. package/dist/expressions/calls/call-emitter.test.d.ts.map +1 -0
  721. package/dist/expressions/calls/call-emitter.test.js +407 -0
  722. package/dist/expressions/calls/call-emitter.test.js.map +1 -0
  723. package/dist/expressions/calls/call-extension-methods.d.ts +17 -0
  724. package/dist/expressions/calls/call-extension-methods.d.ts.map +1 -0
  725. package/dist/expressions/calls/call-extension-methods.js +191 -0
  726. package/dist/expressions/calls/call-extension-methods.js.map +1 -0
  727. package/dist/expressions/calls/call-json.d.ts +15 -0
  728. package/dist/expressions/calls/call-json.d.ts.map +1 -0
  729. package/dist/expressions/calls/call-json.js +212 -0
  730. package/dist/expressions/calls/call-json.js.map +1 -0
  731. package/dist/expressions/calls/call-promise-chains.d.ts +7 -0
  732. package/dist/expressions/calls/call-promise-chains.d.ts.map +1 -0
  733. package/dist/expressions/calls/call-promise-chains.js +411 -0
  734. package/dist/expressions/calls/call-promise-chains.js.map +1 -0
  735. package/dist/expressions/calls/call-promise-ir-types.d.ts +11 -0
  736. package/dist/expressions/calls/call-promise-ir-types.d.ts.map +1 -0
  737. package/dist/expressions/calls/call-promise-ir-types.js +219 -0
  738. package/dist/expressions/calls/call-promise-ir-types.js.map +1 -0
  739. package/dist/expressions/calls/call-promise-normalization.d.ts +11 -0
  740. package/dist/expressions/calls/call-promise-normalization.d.ts.map +1 -0
  741. package/dist/expressions/calls/call-promise-normalization.js +179 -0
  742. package/dist/expressions/calls/call-promise-normalization.js.map +1 -0
  743. package/dist/expressions/calls/call-promise-static.d.ts +7 -0
  744. package/dist/expressions/calls/call-promise-static.d.ts.map +1 -0
  745. package/dist/expressions/calls/call-promise-static.js +188 -0
  746. package/dist/expressions/calls/call-promise-static.js.map +1 -0
  747. package/dist/expressions/calls/call-promise-task-types.d.ts +9 -0
  748. package/dist/expressions/calls/call-promise-task-types.d.ts.map +1 -0
  749. package/dist/expressions/calls/call-promise-task-types.js +88 -0
  750. package/dist/expressions/calls/call-promise-task-types.js.map +1 -0
  751. package/dist/expressions/calls/call-promise.d.ts +11 -0
  752. package/dist/expressions/calls/call-promise.d.ts.map +1 -0
  753. package/dist/expressions/calls/call-promise.js +11 -0
  754. package/dist/expressions/calls/call-promise.js.map +1 -0
  755. package/dist/expressions/calls/call-runtime-union-guards.d.ts +7 -0
  756. package/dist/expressions/calls/call-runtime-union-guards.d.ts.map +1 -0
  757. package/dist/expressions/calls/call-runtime-union-guards.js +131 -0
  758. package/dist/expressions/calls/call-runtime-union-guards.js.map +1 -0
  759. package/dist/expressions/calls/call-symbol.d.ts +7 -0
  760. package/dist/expressions/calls/call-symbol.d.ts.map +1 -0
  761. package/dist/expressions/calls/call-symbol.js +26 -0
  762. package/dist/expressions/calls/call-symbol.js.map +1 -0
  763. package/dist/expressions/calls/new-emitter-collections.d.ts +31 -0
  764. package/dist/expressions/calls/new-emitter-collections.d.ts.map +1 -0
  765. package/dist/expressions/calls/new-emitter-collections.js +310 -0
  766. package/dist/expressions/calls/new-emitter-collections.js.map +1 -0
  767. package/dist/expressions/calls/new-emitter-promise.d.ts +10 -0
  768. package/dist/expressions/calls/new-emitter-promise.d.ts.map +1 -0
  769. package/dist/expressions/calls/new-emitter-promise.js +437 -0
  770. package/dist/expressions/calls/new-emitter-promise.js.map +1 -0
  771. package/dist/expressions/calls/new-emitter.d.ts.map +1 -1
  772. package/dist/expressions/calls/new-emitter.js +28 -557
  773. package/dist/expressions/calls/new-emitter.js.map +1 -1
  774. package/dist/expressions/calls/runtime-expected-type-preference.d.ts +4 -0
  775. package/dist/expressions/calls/runtime-expected-type-preference.d.ts.map +1 -0
  776. package/dist/expressions/calls/runtime-expected-type-preference.js +61 -0
  777. package/dist/expressions/calls/runtime-expected-type-preference.js.map +1 -0
  778. package/dist/expressions/collections.d.ts +4 -21
  779. package/dist/expressions/collections.d.ts.map +1 -1
  780. package/dist/expressions/collections.js +3 -959
  781. package/dist/expressions/collections.js.map +1 -1
  782. package/dist/expressions/dictionary-literal.d.ts +20 -0
  783. package/dist/expressions/dictionary-literal.d.ts.map +1 -0
  784. package/dist/expressions/dictionary-literal.js +214 -0
  785. package/dist/expressions/dictionary-literal.js.map +1 -0
  786. package/dist/expressions/dictionary-safe-access.d.ts +4 -0
  787. package/dist/expressions/dictionary-safe-access.d.ts.map +1 -0
  788. package/dist/expressions/dictionary-safe-access.js +86 -0
  789. package/dist/expressions/dictionary-safe-access.js.map +1 -0
  790. package/dist/expressions/direct-storage-types.d.ts +10 -0
  791. package/dist/expressions/direct-storage-types.d.ts.map +1 -0
  792. package/dist/expressions/direct-storage-types.js +441 -0
  793. package/dist/expressions/direct-storage-types.js.map +1 -0
  794. package/dist/expressions/exact-comparison.d.ts +17 -0
  795. package/dist/expressions/exact-comparison.d.ts.map +1 -0
  796. package/dist/expressions/exact-comparison.js +240 -0
  797. package/dist/expressions/exact-comparison.js.map +1 -0
  798. package/dist/expressions/exact-global-bindings.d.ts +6 -0
  799. package/dist/expressions/exact-global-bindings.d.ts.map +1 -0
  800. package/dist/expressions/exact-global-bindings.js +15 -0
  801. package/dist/expressions/exact-global-bindings.js.map +1 -0
  802. package/dist/expressions/expected-type-adaptation.d.ts +55 -0
  803. package/dist/expressions/expected-type-adaptation.d.ts.map +1 -0
  804. package/dist/expressions/expected-type-adaptation.js +918 -0
  805. package/dist/expressions/expected-type-adaptation.js.map +1 -0
  806. package/dist/expressions/expected-type-adaptation.test.d.ts +2 -0
  807. package/dist/expressions/expected-type-adaptation.test.d.ts.map +1 -0
  808. package/dist/expressions/expected-type-adaptation.test.js +1363 -0
  809. package/dist/expressions/expected-type-adaptation.test.js.map +1 -0
  810. package/dist/expressions/functions.d.ts +6 -15
  811. package/dist/expressions/functions.d.ts.map +1 -1
  812. package/dist/expressions/functions.js +6 -213
  813. package/dist/expressions/functions.js.map +1 -1
  814. package/dist/expressions/identifier-storage.d.ts +43 -0
  815. package/dist/expressions/identifier-storage.d.ts.map +1 -0
  816. package/dist/expressions/identifier-storage.js +478 -0
  817. package/dist/expressions/identifier-storage.js.map +1 -0
  818. package/dist/expressions/identifiers.d.ts.map +1 -1
  819. package/dist/expressions/identifiers.js +126 -11
  820. package/dist/expressions/identifiers.js.map +1 -1
  821. package/dist/expressions/index-cases/alias-carrier-widening.test.d.ts +2 -0
  822. package/dist/expressions/index-cases/alias-carrier-widening.test.d.ts.map +1 -0
  823. package/dist/expressions/index-cases/alias-carrier-widening.test.js +347 -0
  824. package/dist/expressions/index-cases/alias-carrier-widening.test.js.map +1 -0
  825. package/dist/expressions/index-cases/array-wrapper-recursion-b.test.d.ts +2 -0
  826. package/dist/expressions/index-cases/array-wrapper-recursion-b.test.d.ts.map +1 -0
  827. package/dist/expressions/index-cases/array-wrapper-recursion-b.test.js +356 -0
  828. package/dist/expressions/index-cases/array-wrapper-recursion-b.test.js.map +1 -0
  829. package/dist/expressions/index-cases/array-wrapper-recursion-c.test.d.ts +2 -0
  830. package/dist/expressions/index-cases/array-wrapper-recursion-c.test.d.ts.map +1 -0
  831. package/dist/expressions/index-cases/array-wrapper-recursion-c.test.js +233 -0
  832. package/dist/expressions/index-cases/array-wrapper-recursion-c.test.js.map +1 -0
  833. package/dist/expressions/index-cases/basic-literals-and-calls.test.d.ts +2 -0
  834. package/dist/expressions/index-cases/basic-literals-and-calls.test.d.ts.map +1 -0
  835. package/dist/expressions/index-cases/basic-literals-and-calls.test.js +550 -0
  836. package/dist/expressions/index-cases/basic-literals-and-calls.test.js.map +1 -0
  837. package/dist/expressions/index-cases/defaults-and-char-context.test.d.ts +2 -0
  838. package/dist/expressions/index-cases/defaults-and-char-context.test.d.ts.map +1 -0
  839. package/dist/expressions/index-cases/defaults-and-char-context.test.js +951 -0
  840. package/dist/expressions/index-cases/defaults-and-char-context.test.js.map +1 -0
  841. package/dist/expressions/index-cases/dictionary-and-object-initializers-a.test.d.ts +2 -0
  842. package/dist/expressions/index-cases/dictionary-and-object-initializers-a.test.d.ts.map +1 -0
  843. package/dist/expressions/index-cases/dictionary-and-object-initializers-a.test.js +533 -0
  844. package/dist/expressions/index-cases/dictionary-and-object-initializers-a.test.js.map +1 -0
  845. package/dist/expressions/index-cases/dictionary-and-object-initializers-b.test.d.ts +2 -0
  846. package/dist/expressions/index-cases/dictionary-and-object-initializers-b.test.d.ts.map +1 -0
  847. package/dist/expressions/index-cases/dictionary-and-object-initializers-b.test.js +336 -0
  848. package/dist/expressions/index-cases/dictionary-and-object-initializers-b.test.js.map +1 -0
  849. package/dist/expressions/index-cases/fluent-and-ef-operators.test.d.ts +2 -0
  850. package/dist/expressions/index-cases/fluent-and-ef-operators.test.d.ts.map +1 -0
  851. package/dist/expressions/index-cases/fluent-and-ef-operators.test.js +352 -0
  852. package/dist/expressions/index-cases/fluent-and-ef-operators.test.js.map +1 -0
  853. package/dist/expressions/index-cases/helpers.d.ts +13 -0
  854. package/dist/expressions/index-cases/helpers.d.ts.map +1 -0
  855. package/dist/expressions/index-cases/helpers.js +27 -0
  856. package/dist/expressions/index-cases/helpers.js.map +1 -0
  857. package/dist/expressions/index-cases/member-access-and-array-wrappers-a.test.d.ts +2 -0
  858. package/dist/expressions/index-cases/member-access-and-array-wrappers-a.test.d.ts.map +1 -0
  859. package/dist/expressions/index-cases/member-access-and-array-wrappers-a.test.js +429 -0
  860. package/dist/expressions/index-cases/member-access-and-array-wrappers-a.test.js.map +1 -0
  861. package/dist/expressions/index-cases/nullable-and-comparisons.test.d.ts +2 -0
  862. package/dist/expressions/index-cases/nullable-and-comparisons.test.d.ts.map +1 -0
  863. package/dist/expressions/index-cases/nullable-and-comparisons.test.js +423 -0
  864. package/dist/expressions/index-cases/nullable-and-comparisons.test.js.map +1 -0
  865. package/dist/expressions/index-cases/runtime-subset-and-assertions.test.d.ts +2 -0
  866. package/dist/expressions/index-cases/runtime-subset-and-assertions.test.d.ts.map +1 -0
  867. package/dist/expressions/index-cases/runtime-subset-and-assertions.test.js +482 -0
  868. package/dist/expressions/index-cases/runtime-subset-and-assertions.test.js.map +1 -0
  869. package/dist/expressions/index-cases/runtime-union-reification-a.test.d.ts +2 -0
  870. package/dist/expressions/index-cases/runtime-union-reification-a.test.d.ts.map +1 -0
  871. package/dist/expressions/index-cases/runtime-union-reification-a.test.js +454 -0
  872. package/dist/expressions/index-cases/runtime-union-reification-a.test.js.map +1 -0
  873. package/dist/expressions/index-cases/runtime-union-reification-b.test.d.ts +2 -0
  874. package/dist/expressions/index-cases/runtime-union-reification-b.test.d.ts.map +1 -0
  875. package/dist/expressions/index-cases/runtime-union-reification-b.test.js +852 -0
  876. package/dist/expressions/index-cases/runtime-union-reification-b.test.js.map +1 -0
  877. package/dist/expressions/index-cases/spreads-and-member-bindings.test.d.ts +2 -0
  878. package/dist/expressions/index-cases/spreads-and-member-bindings.test.d.ts.map +1 -0
  879. package/dist/expressions/index-cases/spreads-and-member-bindings.test.js +616 -0
  880. package/dist/expressions/index-cases/spreads-and-member-bindings.test.js.map +1 -0
  881. package/dist/expressions/index-cases/string-and-array-fallbacks-a.test.d.ts +2 -0
  882. package/dist/expressions/index-cases/string-and-array-fallbacks-a.test.d.ts.map +1 -0
  883. package/dist/expressions/index-cases/string-and-array-fallbacks-a.test.js +304 -0
  884. package/dist/expressions/index-cases/string-and-array-fallbacks-a.test.js.map +1 -0
  885. package/dist/expressions/index-cases/string-and-array-fallbacks-b.test.d.ts +2 -0
  886. package/dist/expressions/index-cases/string-and-array-fallbacks-b.test.d.ts.map +1 -0
  887. package/dist/expressions/index-cases/string-and-array-fallbacks-b.test.js +369 -0
  888. package/dist/expressions/index-cases/string-and-array-fallbacks-b.test.js.map +1 -0
  889. package/dist/expressions/index-cases/tuple-rest-and-unions.test.d.ts +2 -0
  890. package/dist/expressions/index-cases/tuple-rest-and-unions.test.d.ts.map +1 -0
  891. package/dist/expressions/index-cases/tuple-rest-and-unions.test.js +392 -0
  892. package/dist/expressions/index-cases/tuple-rest-and-unions.test.js.map +1 -0
  893. package/dist/expressions/index.test.d.ts +17 -5
  894. package/dist/expressions/index.test.d.ts.map +1 -1
  895. package/dist/expressions/index.test.js +17 -2835
  896. package/dist/expressions/index.test.js.map +1 -1
  897. package/dist/expressions/invoked-lambda.d.ts +12 -0
  898. package/dist/expressions/invoked-lambda.d.ts.map +1 -0
  899. package/dist/expressions/invoked-lambda.js +69 -0
  900. package/dist/expressions/invoked-lambda.js.map +1 -0
  901. package/dist/expressions/lambda-body.d.ts +23 -0
  902. package/dist/expressions/lambda-body.d.ts.map +1 -0
  903. package/dist/expressions/lambda-body.js +421 -0
  904. package/dist/expressions/lambda-body.js.map +1 -0
  905. package/dist/expressions/lambda-parameters.d.ts +32 -0
  906. package/dist/expressions/lambda-parameters.d.ts.map +1 -0
  907. package/dist/expressions/lambda-parameters.js +279 -0
  908. package/dist/expressions/lambda-parameters.js.map +1 -0
  909. package/dist/expressions/literals.d.ts.map +1 -1
  910. package/dist/expressions/literals.js +18 -3
  911. package/dist/expressions/literals.js.map +1 -1
  912. package/dist/expressions/literals.test.js +48 -0
  913. package/dist/expressions/literals.test.js.map +1 -1
  914. package/dist/expressions/object-helpers.d.ts +22 -0
  915. package/dist/expressions/object-helpers.d.ts.map +1 -0
  916. package/dist/expressions/object-helpers.js +98 -0
  917. package/dist/expressions/object-helpers.js.map +1 -0
  918. package/dist/expressions/object-literal-spreads.d.ts +20 -0
  919. package/dist/expressions/object-literal-spreads.d.ts.map +1 -0
  920. package/dist/expressions/object-literal-spreads.js +188 -0
  921. package/dist/expressions/object-literal-spreads.js.map +1 -0
  922. package/dist/expressions/object-literal.d.ts +18 -0
  923. package/dist/expressions/object-literal.d.ts.map +1 -0
  924. package/dist/expressions/object-literal.js +178 -0
  925. package/dist/expressions/object-literal.js.map +1 -0
  926. package/dist/expressions/operators/assignment-emitter.d.ts.map +1 -1
  927. package/dist/expressions/operators/assignment-emitter.js +78 -27
  928. package/dist/expressions/operators/assignment-emitter.js.map +1 -1
  929. package/dist/expressions/operators/binary-dispatch.d.ts +37 -0
  930. package/dist/expressions/operators/binary-dispatch.d.ts.map +1 -0
  931. package/dist/expressions/operators/binary-dispatch.js +449 -0
  932. package/dist/expressions/operators/binary-dispatch.js.map +1 -0
  933. package/dist/expressions/operators/binary-emitter.d.ts +6 -29
  934. package/dist/expressions/operators/binary-emitter.d.ts.map +1 -1
  935. package/dist/expressions/operators/binary-emitter.js +6 -419
  936. package/dist/expressions/operators/binary-emitter.js.map +1 -1
  937. package/dist/expressions/operators/binary-helpers.d.ts +17 -0
  938. package/dist/expressions/operators/binary-helpers.d.ts.map +1 -0
  939. package/dist/expressions/operators/binary-helpers.js +119 -0
  940. package/dist/expressions/operators/binary-helpers.js.map +1 -0
  941. package/dist/expressions/operators/binary-runtime-union-comparison.d.ts +7 -0
  942. package/dist/expressions/operators/binary-runtime-union-comparison.d.ts.map +1 -0
  943. package/dist/expressions/operators/binary-runtime-union-comparison.js +150 -0
  944. package/dist/expressions/operators/binary-runtime-union-comparison.js.map +1 -0
  945. package/dist/expressions/operators/binary-special-ops.d.ts +29 -0
  946. package/dist/expressions/operators/binary-special-ops.d.ts.map +1 -0
  947. package/dist/expressions/operators/binary-special-ops.js +468 -0
  948. package/dist/expressions/operators/binary-special-ops.js.map +1 -0
  949. package/dist/expressions/operators/conditional-emitter.d.ts.map +1 -1
  950. package/dist/expressions/operators/conditional-emitter.js +221 -216
  951. package/dist/expressions/operators/conditional-emitter.js.map +1 -1
  952. package/dist/expressions/operators/helpers.d.ts +10 -0
  953. package/dist/expressions/operators/helpers.d.ts.map +1 -1
  954. package/dist/expressions/operators/helpers.js +30 -0
  955. package/dist/expressions/operators/helpers.js.map +1 -1
  956. package/dist/expressions/operators/logical-emitter.d.ts +2 -2
  957. package/dist/expressions/operators/logical-emitter.d.ts.map +1 -1
  958. package/dist/expressions/operators/logical-emitter.js +293 -10
  959. package/dist/expressions/operators/logical-emitter.js.map +1 -1
  960. package/dist/expressions/operators/unary-emitter.d.ts.map +1 -1
  961. package/dist/expressions/operators/unary-emitter.js +6 -21
  962. package/dist/expressions/operators/unary-emitter.js.map +1 -1
  963. package/dist/expressions/operators/write-targets.d.ts +5 -0
  964. package/dist/expressions/operators/write-targets.d.ts.map +1 -0
  965. package/dist/expressions/operators/write-targets.js +65 -0
  966. package/dist/expressions/operators/write-targets.js.map +1 -0
  967. package/dist/expressions/other.d.ts.map +1 -1
  968. package/dist/expressions/other.js +17 -50
  969. package/dist/expressions/other.js.map +1 -1
  970. package/dist/expressions/post-emission-adaptation.d.ts +19 -0
  971. package/dist/expressions/post-emission-adaptation.d.ts.map +1 -0
  972. package/dist/expressions/post-emission-adaptation.js +939 -0
  973. package/dist/expressions/post-emission-adaptation.js.map +1 -0
  974. package/dist/expressions/runtime-union-adaptation-projection.d.ts +12 -0
  975. package/dist/expressions/runtime-union-adaptation-projection.d.ts.map +1 -0
  976. package/dist/expressions/runtime-union-adaptation-projection.js +182 -0
  977. package/dist/expressions/runtime-union-adaptation-projection.js.map +1 -0
  978. package/dist/expressions/runtime-union-adaptation-upcast.d.ts +11 -0
  979. package/dist/expressions/runtime-union-adaptation-upcast.d.ts.map +1 -0
  980. package/dist/expressions/runtime-union-adaptation-upcast.js +722 -0
  981. package/dist/expressions/runtime-union-adaptation-upcast.js.map +1 -0
  982. package/dist/expressions/runtime-union-adaptation.d.ts +10 -0
  983. package/dist/expressions/runtime-union-adaptation.d.ts.map +1 -0
  984. package/dist/expressions/runtime-union-adaptation.js +10 -0
  985. package/dist/expressions/runtime-union-adaptation.js.map +1 -0
  986. package/dist/expressions/structural-adaptation-types.d.ts +12 -0
  987. package/dist/expressions/structural-adaptation-types.d.ts.map +1 -0
  988. package/dist/expressions/structural-adaptation-types.js +3 -0
  989. package/dist/expressions/structural-adaptation-types.js.map +1 -0
  990. package/dist/expressions/structural-adaptation.d.ts +16 -0
  991. package/dist/expressions/structural-adaptation.d.ts.map +1 -0
  992. package/dist/expressions/structural-adaptation.js +14 -0
  993. package/dist/expressions/structural-adaptation.js.map +1 -0
  994. package/dist/expressions/structural-anonymous-targets.d.ts +4 -0
  995. package/dist/expressions/structural-anonymous-targets.d.ts.map +1 -0
  996. package/dist/expressions/structural-anonymous-targets.js +156 -0
  997. package/dist/expressions/structural-anonymous-targets.js.map +1 -0
  998. package/dist/expressions/structural-collection-adaptation.d.ts +7 -0
  999. package/dist/expressions/structural-collection-adaptation.d.ts.map +1 -0
  1000. package/dist/expressions/structural-collection-adaptation.js +682 -0
  1001. package/dist/expressions/structural-collection-adaptation.js.map +1 -0
  1002. package/dist/expressions/structural-object-adaptation.d.ts +6 -0
  1003. package/dist/expressions/structural-object-adaptation.d.ts.map +1 -0
  1004. package/dist/expressions/structural-object-adaptation.js +213 -0
  1005. package/dist/expressions/structural-object-adaptation.js.map +1 -0
  1006. package/dist/expressions/structural-property-model.d.ts +6 -0
  1007. package/dist/expressions/structural-property-model.d.ts.map +1 -0
  1008. package/dist/expressions/structural-property-model.js +304 -0
  1009. package/dist/expressions/structural-property-model.js.map +1 -0
  1010. package/dist/expressions/structural-type-shapes.d.ts +19 -0
  1011. package/dist/expressions/structural-type-shapes.d.ts.map +1 -0
  1012. package/dist/expressions/structural-type-shapes.js +318 -0
  1013. package/dist/expressions/structural-type-shapes.js.map +1 -0
  1014. package/dist/expressions/structural-type-shapes.test.d.ts +2 -0
  1015. package/dist/expressions/structural-type-shapes.test.d.ts.map +1 -0
  1016. package/dist/expressions/structural-type-shapes.test.js +60 -0
  1017. package/dist/expressions/structural-type-shapes.test.js.map +1 -0
  1018. package/dist/expressions/type-assertion-emitters.d.ts +50 -0
  1019. package/dist/expressions/type-assertion-emitters.d.ts.map +1 -0
  1020. package/dist/expressions/type-assertion-emitters.js +675 -0
  1021. package/dist/expressions/type-assertion-emitters.js.map +1 -0
  1022. package/dist/fixture-regression-mirrors.test.d.ts +2 -0
  1023. package/dist/fixture-regression-mirrors.test.d.ts.map +1 -0
  1024. package/dist/fixture-regression-mirrors.test.js +580 -0
  1025. package/dist/fixture-regression-mirrors.test.js.map +1 -0
  1026. package/dist/generated-files.d.ts +19 -0
  1027. package/dist/generated-files.d.ts.map +1 -0
  1028. package/dist/generated-files.js +519 -0
  1029. package/dist/generated-files.js.map +1 -0
  1030. package/dist/generated-files.test.d.ts +2 -0
  1031. package/dist/generated-files.test.d.ts.map +1 -0
  1032. package/dist/generated-files.test.js +103 -0
  1033. package/dist/generated-files.test.js.map +1 -0
  1034. package/dist/generator-cases/bidirectional-core.test.d.ts +6 -0
  1035. package/dist/generator-cases/bidirectional-core.test.d.ts.map +1 -0
  1036. package/dist/generator-cases/bidirectional-core.test.js +272 -0
  1037. package/dist/generator-cases/bidirectional-core.test.js.map +1 -0
  1038. package/dist/generator-cases/bidirectional-features.test.d.ts +6 -0
  1039. package/dist/generator-cases/bidirectional-features.test.d.ts.map +1 -0
  1040. package/dist/generator-cases/bidirectional-features.test.js +360 -0
  1041. package/dist/generator-cases/bidirectional-features.test.js.map +1 -0
  1042. package/dist/generator-cases/simple-generators.test.d.ts +6 -0
  1043. package/dist/generator-cases/simple-generators.test.d.ts.map +1 -0
  1044. package/dist/generator-cases/simple-generators.test.js +227 -0
  1045. package/dist/generator-cases/simple-generators.test.js.map +1 -0
  1046. package/dist/generator-exchange.d.ts +3 -2
  1047. package/dist/generator-exchange.d.ts.map +1 -1
  1048. package/dist/generator-exchange.js +46 -15
  1049. package/dist/generator-exchange.js.map +1 -1
  1050. package/dist/generator-wrapper-builders.d.ts +10 -0
  1051. package/dist/generator-wrapper-builders.d.ts.map +1 -0
  1052. package/dist/generator-wrapper-builders.js +288 -0
  1053. package/dist/generator-wrapper-builders.js.map +1 -0
  1054. package/dist/generator-wrapper.d.ts +16 -5
  1055. package/dist/generator-wrapper.d.ts.map +1 -1
  1056. package/dist/generator-wrapper.js +47 -288
  1057. package/dist/generator-wrapper.js.map +1 -1
  1058. package/dist/generator.test.d.ts +3 -5
  1059. package/dist/generator.test.d.ts.map +1 -1
  1060. package/dist/generator.test.js +3 -766
  1061. package/dist/generator.test.js.map +1 -1
  1062. package/dist/golden-tests/config-parser.d.ts.map +1 -1
  1063. package/dist/golden-tests/config-parser.js +7 -0
  1064. package/dist/golden-tests/config-parser.js.map +1 -1
  1065. package/dist/golden-tests/discovery.js +1 -0
  1066. package/dist/golden-tests/discovery.js.map +1 -1
  1067. package/dist/golden-tests/runner.d.ts.map +1 -1
  1068. package/dist/golden-tests/runner.js +12 -40
  1069. package/dist/golden-tests/runner.js.map +1 -1
  1070. package/dist/golden-tests/types.d.ts +2 -0
  1071. package/dist/golden-tests/types.d.ts.map +1 -1
  1072. package/dist/hierarchical-bindings.test.js +6 -9
  1073. package/dist/hierarchical-bindings.test.js.map +1 -1
  1074. package/dist/integration-cases/arrow-and-generics-a.test.d.ts +2 -0
  1075. package/dist/integration-cases/arrow-and-generics-a.test.d.ts.map +1 -0
  1076. package/dist/integration-cases/arrow-and-generics-a.test.js +695 -0
  1077. package/dist/integration-cases/arrow-and-generics-a.test.js.map +1 -0
  1078. package/dist/integration-cases/arrow-and-generics-b.test.d.ts +2 -0
  1079. package/dist/integration-cases/arrow-and-generics-b.test.d.ts.map +1 -0
  1080. package/dist/integration-cases/arrow-and-generics-b.test.js +218 -0
  1081. package/dist/integration-cases/arrow-and-generics-b.test.js.map +1 -0
  1082. package/dist/integration-cases/await-and-intrinsics.test.d.ts +2 -0
  1083. package/dist/integration-cases/await-and-intrinsics.test.d.ts.map +1 -0
  1084. package/dist/integration-cases/await-and-intrinsics.test.js +237 -0
  1085. package/dist/integration-cases/await-and-intrinsics.test.js.map +1 -0
  1086. package/dist/integration-cases/clr-iterable-overloads.test.d.ts +2 -0
  1087. package/dist/integration-cases/clr-iterable-overloads.test.d.ts.map +1 -0
  1088. package/dist/integration-cases/clr-iterable-overloads.test.js +446 -0
  1089. package/dist/integration-cases/clr-iterable-overloads.test.js.map +1 -0
  1090. package/dist/integration-cases/full-module-and-promises.test.d.ts +2 -0
  1091. package/dist/integration-cases/full-module-and-promises.test.d.ts.map +1 -0
  1092. package/dist/integration-cases/full-module-and-promises.test.js +472 -0
  1093. package/dist/integration-cases/full-module-and-promises.test.js.map +1 -0
  1094. package/dist/integration-cases/helpers.d.ts +7 -0
  1095. package/dist/integration-cases/helpers.d.ts.map +1 -0
  1096. package/dist/integration-cases/helpers.js +348 -0
  1097. package/dist/integration-cases/helpers.js.map +1 -0
  1098. package/dist/integration-cases/object-literals-and-channels.test.d.ts +2 -0
  1099. package/dist/integration-cases/object-literals-and-channels.test.d.ts.map +1 -0
  1100. package/dist/integration-cases/object-literals-and-channels.test.js +72 -0
  1101. package/dist/integration-cases/object-literals-and-channels.test.js.map +1 -0
  1102. package/dist/integration-cases/regression-coverage-a.test.d.ts +2 -0
  1103. package/dist/integration-cases/regression-coverage-a.test.d.ts.map +1 -0
  1104. package/dist/integration-cases/regression-coverage-a.test.js +533 -0
  1105. package/dist/integration-cases/regression-coverage-a.test.js.map +1 -0
  1106. package/dist/integration-cases/regression-coverage-b.test.d.ts +2 -0
  1107. package/dist/integration-cases/regression-coverage-b.test.d.ts.map +1 -0
  1108. package/dist/integration-cases/regression-coverage-b.test.js +806 -0
  1109. package/dist/integration-cases/regression-coverage-b.test.js.map +1 -0
  1110. package/dist/integration-cases/regression-coverage-c.test.d.ts +2 -0
  1111. package/dist/integration-cases/regression-coverage-c.test.d.ts.map +1 -0
  1112. package/dist/integration-cases/regression-coverage-c.test.js +4139 -0
  1113. package/dist/integration-cases/regression-coverage-c.test.js.map +1 -0
  1114. package/dist/integration.test.d.ts +9 -5
  1115. package/dist/integration.test.d.ts.map +1 -1
  1116. package/dist/integration.test.js +9 -1223
  1117. package/dist/integration.test.js.map +1 -1
  1118. package/dist/invariants/numeric-proof-contract-cases/emitter-and-annotations.test.d.ts +5 -0
  1119. package/dist/invariants/numeric-proof-contract-cases/emitter-and-annotations.test.d.ts.map +1 -0
  1120. package/dist/invariants/numeric-proof-contract-cases/emitter-and-annotations.test.js +93 -0
  1121. package/dist/invariants/numeric-proof-contract-cases/emitter-and-annotations.test.js.map +1 -0
  1122. package/dist/invariants/numeric-proof-contract-cases/helpers.d.ts +14 -0
  1123. package/dist/invariants/numeric-proof-contract-cases/helpers.d.ts.map +1 -0
  1124. package/dist/invariants/numeric-proof-contract-cases/helpers.js +158 -0
  1125. package/dist/invariants/numeric-proof-contract-cases/helpers.js.map +1 -0
  1126. package/dist/invariants/numeric-proof-contract-cases/proof-and-diagnostics.test.d.ts +5 -0
  1127. package/dist/invariants/numeric-proof-contract-cases/proof-and-diagnostics.test.d.ts.map +1 -0
  1128. package/dist/invariants/numeric-proof-contract-cases/proof-and-diagnostics.test.js +242 -0
  1129. package/dist/invariants/numeric-proof-contract-cases/proof-and-diagnostics.test.js.map +1 -0
  1130. package/dist/invariants/numeric-proof-contract.test.d.ts +2 -18
  1131. package/dist/invariants/numeric-proof-contract.test.d.ts.map +1 -1
  1132. package/dist/invariants/numeric-proof-contract.test.js +2 -510
  1133. package/dist/invariants/numeric-proof-contract.test.js.map +1 -1
  1134. package/dist/json-aot-generic.test.js +320 -5
  1135. package/dist/json-aot-generic.test.js.map +1 -1
  1136. package/dist/naming-policy.d.ts.map +1 -1
  1137. package/dist/naming-policy.js +19 -0
  1138. package/dist/naming-policy.js.map +1 -1
  1139. package/dist/patterns/local-lowering.d.ts +27 -0
  1140. package/dist/patterns/local-lowering.d.ts.map +1 -0
  1141. package/dist/patterns/local-lowering.js +296 -0
  1142. package/dist/patterns/local-lowering.js.map +1 -0
  1143. package/dist/patterns/static-assignment-lowering.d.ts +11 -0
  1144. package/dist/patterns/static-assignment-lowering.d.ts.map +1 -0
  1145. package/dist/patterns/static-assignment-lowering.js +11 -0
  1146. package/dist/patterns/static-assignment-lowering.js.map +1 -0
  1147. package/dist/patterns/static-lowering-assignments.d.ts +16 -0
  1148. package/dist/patterns/static-lowering-assignments.d.ts.map +1 -0
  1149. package/dist/patterns/static-lowering-assignments.js +269 -0
  1150. package/dist/patterns/static-lowering-assignments.js.map +1 -0
  1151. package/dist/patterns/static-lowering-members.d.ts +15 -0
  1152. package/dist/patterns/static-lowering-members.d.ts.map +1 -0
  1153. package/dist/patterns/static-lowering-members.js +231 -0
  1154. package/dist/patterns/static-lowering-members.js.map +1 -0
  1155. package/dist/patterns-cases/array-and-object.test.d.ts +2 -0
  1156. package/dist/patterns-cases/array-and-object.test.d.ts.map +1 -0
  1157. package/dist/patterns-cases/array-and-object.test.js +370 -0
  1158. package/dist/patterns-cases/array-and-object.test.js.map +1 -0
  1159. package/dist/patterns-cases/assignments-and-complex.test.d.ts +2 -0
  1160. package/dist/patterns-cases/assignments-and-complex.test.d.ts.map +1 -0
  1161. package/dist/patterns-cases/assignments-and-complex.test.js +361 -0
  1162. package/dist/patterns-cases/assignments-and-complex.test.js.map +1 -0
  1163. package/dist/patterns-cases/edge-cases.test.d.ts +2 -0
  1164. package/dist/patterns-cases/edge-cases.test.d.ts.map +1 -0
  1165. package/dist/patterns-cases/edge-cases.test.js +133 -0
  1166. package/dist/patterns-cases/edge-cases.test.js.map +1 -0
  1167. package/dist/patterns-cases/helpers.d.ts +6 -0
  1168. package/dist/patterns-cases/helpers.d.ts.map +1 -0
  1169. package/dist/patterns-cases/helpers.js +33 -0
  1170. package/dist/patterns-cases/helpers.js.map +1 -0
  1171. package/dist/patterns-cases/loops-and-parameters.test.d.ts +2 -0
  1172. package/dist/patterns-cases/loops-and-parameters.test.d.ts.map +1 -0
  1173. package/dist/patterns-cases/loops-and-parameters.test.js +275 -0
  1174. package/dist/patterns-cases/loops-and-parameters.test.js.map +1 -0
  1175. package/dist/patterns-cases/methods-and-semantic-infra.test.d.ts +2 -0
  1176. package/dist/patterns-cases/methods-and-semantic-infra.test.d.ts.map +1 -0
  1177. package/dist/patterns-cases/methods-and-semantic-infra.test.js +438 -0
  1178. package/dist/patterns-cases/methods-and-semantic-infra.test.js.map +1 -0
  1179. package/dist/patterns.d.ts +5 -20
  1180. package/dist/patterns.d.ts.map +1 -1
  1181. package/dist/patterns.js +3 -809
  1182. package/dist/patterns.js.map +1 -1
  1183. package/dist/patterns.test.d.ts +5 -14
  1184. package/dist/patterns.test.d.ts.map +1 -1
  1185. package/dist/patterns.test.js +5 -1341
  1186. package/dist/patterns.test.js.map +1 -1
  1187. package/dist/runtime-union-cases/helpers.d.ts +7 -0
  1188. package/dist/runtime-union-cases/helpers.d.ts.map +1 -0
  1189. package/dist/runtime-union-cases/helpers.js +17 -0
  1190. package/dist/runtime-union-cases/helpers.js.map +1 -0
  1191. package/dist/specialization/generic-functions-cases/basics-and-structural.test.d.ts +6 -0
  1192. package/dist/specialization/generic-functions-cases/basics-and-structural.test.d.ts.map +1 -0
  1193. package/dist/specialization/generic-functions-cases/basics-and-structural.test.js +357 -0
  1194. package/dist/specialization/generic-functions-cases/basics-and-structural.test.js.map +1 -0
  1195. package/dist/specialization/generic-functions-cases/class-and-interface-constraints.test.d.ts +6 -0
  1196. package/dist/specialization/generic-functions-cases/class-and-interface-constraints.test.d.ts.map +1 -0
  1197. package/dist/specialization/generic-functions-cases/class-and-interface-constraints.test.js +304 -0
  1198. package/dist/specialization/generic-functions-cases/class-and-interface-constraints.test.js.map +1 -0
  1199. package/dist/specialization/generic-functions.test.d.ts +2 -5
  1200. package/dist/specialization/generic-functions.test.d.ts.map +1 -1
  1201. package/dist/specialization/generic-functions.test.js +2 -650
  1202. package/dist/specialization/generic-functions.test.js.map +1 -1
  1203. package/dist/specialization/helpers.d.ts.map +1 -1
  1204. package/dist/specialization/helpers.js +2 -16
  1205. package/dist/specialization/helpers.js.map +1 -1
  1206. package/dist/specialization/interfaces.test.js +58 -0
  1207. package/dist/specialization/interfaces.test.js.map +1 -1
  1208. package/dist/specialization/naming.d.ts.map +1 -1
  1209. package/dist/specialization/naming.js +9 -2
  1210. package/dist/specialization/naming.js.map +1 -1
  1211. package/dist/statements/block-emitters/block-and-return.d.ts +10 -0
  1212. package/dist/statements/block-emitters/block-and-return.d.ts.map +1 -0
  1213. package/dist/statements/block-emitters/block-and-return.js +132 -0
  1214. package/dist/statements/block-emitters/block-and-return.js.map +1 -0
  1215. package/dist/statements/block-emitters/expression-statements.d.ts +7 -0
  1216. package/dist/statements/block-emitters/expression-statements.d.ts.map +1 -0
  1217. package/dist/statements/block-emitters/expression-statements.js +72 -0
  1218. package/dist/statements/block-emitters/expression-statements.js.map +1 -0
  1219. package/dist/statements/block-emitters/yield-statements.d.ts +13 -0
  1220. package/dist/statements/block-emitters/yield-statements.d.ts.map +1 -0
  1221. package/dist/statements/block-emitters/yield-statements.js +217 -0
  1222. package/dist/statements/block-emitters/yield-statements.js.map +1 -0
  1223. package/dist/statements/blocks.d.ts +3 -86
  1224. package/dist/statements/blocks.d.ts.map +1 -1
  1225. package/dist/statements/blocks.js +3 -443
  1226. package/dist/statements/blocks.js.map +1 -1
  1227. package/dist/statements/classes/members/constructors.d.ts.map +1 -1
  1228. package/dist/statements/classes/members/constructors.js +105 -13
  1229. package/dist/statements/classes/members/constructors.js.map +1 -1
  1230. package/dist/statements/classes/members/methods.d.ts +1 -1
  1231. package/dist/statements/classes/members/methods.d.ts.map +1 -1
  1232. package/dist/statements/classes/members/methods.js +329 -76
  1233. package/dist/statements/classes/members/methods.js.map +1 -1
  1234. package/dist/statements/classes/members/orchestrator.d.ts +3 -3
  1235. package/dist/statements/classes/members/orchestrator.d.ts.map +1 -1
  1236. package/dist/statements/classes/members/orchestrator.js +10 -4
  1237. package/dist/statements/classes/members/orchestrator.js.map +1 -1
  1238. package/dist/statements/classes/members/properties.d.ts.map +1 -1
  1239. package/dist/statements/classes/members/properties.js +29 -5
  1240. package/dist/statements/classes/members/properties.js.map +1 -1
  1241. package/dist/statements/classes/members/shadowing.test.js +3 -2
  1242. package/dist/statements/classes/members/shadowing.test.js.map +1 -1
  1243. package/dist/statements/classes/parameters.d.ts +9 -1
  1244. package/dist/statements/classes/parameters.d.ts.map +1 -1
  1245. package/dist/statements/classes/parameters.js +86 -6
  1246. package/dist/statements/classes/parameters.js.map +1 -1
  1247. package/dist/statements/classes/properties.d.ts.map +1 -1
  1248. package/dist/statements/classes/properties.js +2 -1
  1249. package/dist/statements/classes/properties.js.map +1 -1
  1250. package/dist/statements/control/conditionals/branch-context.d.ts +58 -0
  1251. package/dist/statements/control/conditionals/branch-context.d.ts.map +1 -0
  1252. package/dist/statements/control/conditionals/branch-context.js +530 -0
  1253. package/dist/statements/control/conditionals/branch-context.js.map +1 -0
  1254. package/dist/statements/control/conditionals/branch-context.test.d.ts +2 -0
  1255. package/dist/statements/control/conditionals/branch-context.test.d.ts.map +1 -0
  1256. package/dist/statements/control/conditionals/branch-context.test.js +34 -0
  1257. package/dist/statements/control/conditionals/branch-context.test.js.map +1 -0
  1258. package/dist/statements/control/conditionals/guard-analysis.d.ts +8 -208
  1259. package/dist/statements/control/conditionals/guard-analysis.d.ts.map +1 -1
  1260. package/dist/statements/control/conditionals/guard-analysis.js +8 -763
  1261. package/dist/statements/control/conditionals/guard-analysis.js.map +1 -1
  1262. package/dist/statements/control/conditionals/guard-detectors-discriminant.d.ts +20 -0
  1263. package/dist/statements/control/conditionals/guard-detectors-discriminant.d.ts.map +1 -0
  1264. package/dist/statements/control/conditionals/guard-detectors-discriminant.js +214 -0
  1265. package/dist/statements/control/conditionals/guard-detectors-discriminant.js.map +1 -0
  1266. package/dist/statements/control/conditionals/guard-detectors-structural.d.ts +32 -0
  1267. package/dist/statements/control/conditionals/guard-detectors-structural.d.ts.map +1 -0
  1268. package/dist/statements/control/conditionals/guard-detectors-structural.js +302 -0
  1269. package/dist/statements/control/conditionals/guard-detectors-structural.js.map +1 -0
  1270. package/dist/statements/control/conditionals/guard-detectors.d.ts +11 -0
  1271. package/dist/statements/control/conditionals/guard-detectors.d.ts.map +1 -0
  1272. package/dist/statements/control/conditionals/guard-detectors.js +11 -0
  1273. package/dist/statements/control/conditionals/guard-detectors.js.map +1 -0
  1274. package/dist/statements/control/conditionals/guard-extraction.d.ts +30 -0
  1275. package/dist/statements/control/conditionals/guard-extraction.d.ts.map +1 -0
  1276. package/dist/statements/control/conditionals/guard-extraction.js +304 -0
  1277. package/dist/statements/control/conditionals/guard-extraction.js.map +1 -0
  1278. package/dist/statements/control/conditionals/guard-types.d.ts +214 -0
  1279. package/dist/statements/control/conditionals/guard-types.d.ts.map +1 -0
  1280. package/dist/statements/control/conditionals/guard-types.js +242 -0
  1281. package/dist/statements/control/conditionals/guard-types.js.map +1 -0
  1282. package/dist/statements/control/conditionals/if-emit-instanceof-guards.d.ts +28 -0
  1283. package/dist/statements/control/conditionals/if-emit-instanceof-guards.d.ts.map +1 -0
  1284. package/dist/statements/control/conditionals/if-emit-instanceof-guards.js +261 -0
  1285. package/dist/statements/control/conditionals/if-emit-instanceof-guards.js.map +1 -0
  1286. package/dist/statements/control/conditionals/if-emit-predicate-guards.d.ts +24 -0
  1287. package/dist/statements/control/conditionals/if-emit-predicate-guards.d.ts.map +1 -0
  1288. package/dist/statements/control/conditionals/if-emit-predicate-guards.js +165 -0
  1289. package/dist/statements/control/conditionals/if-emit-predicate-guards.js.map +1 -0
  1290. package/dist/statements/control/conditionals/if-emit-property-discriminant-guards.d.ts +24 -0
  1291. package/dist/statements/control/conditionals/if-emit-property-discriminant-guards.d.ts.map +1 -0
  1292. package/dist/statements/control/conditionals/if-emit-property-discriminant-guards.js +391 -0
  1293. package/dist/statements/control/conditionals/if-emit-property-discriminant-guards.js.map +1 -0
  1294. package/dist/statements/control/conditionals/if-emit-type-guards.d.ts +10 -0
  1295. package/dist/statements/control/conditionals/if-emit-type-guards.d.ts.map +1 -0
  1296. package/dist/statements/control/conditionals/if-emit-type-guards.js +10 -0
  1297. package/dist/statements/control/conditionals/if-emit-type-guards.js.map +1 -0
  1298. package/dist/statements/control/conditionals/if-emit-typeof-array-guards.d.ts +23 -0
  1299. package/dist/statements/control/conditionals/if-emit-typeof-array-guards.d.ts.map +1 -0
  1300. package/dist/statements/control/conditionals/if-emit-typeof-array-guards.js +264 -0
  1301. package/dist/statements/control/conditionals/if-emit-typeof-array-guards.js.map +1 -0
  1302. package/dist/statements/control/conditionals/if-emit-union-guards.d.ts +10 -0
  1303. package/dist/statements/control/conditionals/if-emit-union-guards.d.ts.map +1 -0
  1304. package/dist/statements/control/conditionals/if-emit-union-guards.js +10 -0
  1305. package/dist/statements/control/conditionals/if-emit-union-guards.js.map +1 -0
  1306. package/dist/statements/control/conditionals/if-emitter.d.ts +6 -3
  1307. package/dist/statements/control/conditionals/if-emitter.d.ts.map +1 -1
  1308. package/dist/statements/control/conditionals/if-emitter.js +99 -916
  1309. package/dist/statements/control/conditionals/if-emitter.js.map +1 -1
  1310. package/dist/statements/control/exceptions.d.ts.map +1 -1
  1311. package/dist/statements/control/exceptions.js +19 -2
  1312. package/dist/statements/control/exceptions.js.map +1 -1
  1313. package/dist/statements/control/loop-helpers.d.ts +13 -0
  1314. package/dist/statements/control/loop-helpers.d.ts.map +1 -0
  1315. package/dist/statements/control/loop-helpers.js +75 -0
  1316. package/dist/statements/control/loop-helpers.js.map +1 -0
  1317. package/dist/statements/control/loops.d.ts.map +1 -1
  1318. package/dist/statements/control/loops.js +85 -169
  1319. package/dist/statements/control/loops.js.map +1 -1
  1320. package/dist/statements/declarations/class-emitter-helpers.d.ts +17 -0
  1321. package/dist/statements/declarations/class-emitter-helpers.d.ts.map +1 -0
  1322. package/dist/statements/declarations/class-emitter-helpers.js +126 -0
  1323. package/dist/statements/declarations/class-emitter-helpers.js.map +1 -0
  1324. package/dist/statements/declarations/classes.d.ts.map +1 -1
  1325. package/dist/statements/declarations/classes.js +102 -27
  1326. package/dist/statements/declarations/classes.js.map +1 -1
  1327. package/dist/statements/declarations/function-local-emitter.d.ts +7 -0
  1328. package/dist/statements/declarations/function-local-emitter.d.ts.map +1 -0
  1329. package/dist/statements/declarations/function-local-emitter.js +363 -0
  1330. package/dist/statements/declarations/function-local-emitter.js.map +1 -0
  1331. package/dist/statements/declarations/function-module-emitter.d.ts +7 -0
  1332. package/dist/statements/declarations/function-module-emitter.d.ts.map +1 -0
  1333. package/dist/statements/declarations/function-module-emitter.js +372 -0
  1334. package/dist/statements/declarations/function-module-emitter.js.map +1 -0
  1335. package/dist/statements/declarations/function-shared.d.ts +43 -0
  1336. package/dist/statements/declarations/function-shared.d.ts.map +1 -0
  1337. package/dist/statements/declarations/function-shared.js +246 -0
  1338. package/dist/statements/declarations/function-shared.js.map +1 -0
  1339. package/dist/statements/declarations/functions.d.ts +2 -27
  1340. package/dist/statements/declarations/functions.d.ts.map +1 -1
  1341. package/dist/statements/declarations/functions.js +2 -709
  1342. package/dist/statements/declarations/functions.js.map +1 -1
  1343. package/dist/statements/declarations/interfaces.d.ts.map +1 -1
  1344. package/dist/statements/declarations/interfaces.js +25 -9
  1345. package/dist/statements/declarations/interfaces.js.map +1 -1
  1346. package/dist/statements/declarations/type-aliases.d.ts.map +1 -1
  1347. package/dist/statements/declarations/type-aliases.js +3 -4
  1348. package/dist/statements/declarations/type-aliases.js.map +1 -1
  1349. package/dist/statements/declarations/variable-local-type.d.ts +36 -0
  1350. package/dist/statements/declarations/variable-local-type.d.ts.map +1 -0
  1351. package/dist/statements/declarations/variable-local-type.js +122 -0
  1352. package/dist/statements/declarations/variable-local-type.js.map +1 -0
  1353. package/dist/statements/declarations/variable-static-arrow.d.ts +47 -0
  1354. package/dist/statements/declarations/variable-static-arrow.d.ts.map +1 -0
  1355. package/dist/statements/declarations/variable-static-arrow.js +363 -0
  1356. package/dist/statements/declarations/variable-static-arrow.js.map +1 -0
  1357. package/dist/statements/declarations/variable-type-helpers.d.ts +86 -0
  1358. package/dist/statements/declarations/variable-type-helpers.d.ts.map +1 -0
  1359. package/dist/statements/declarations/variable-type-helpers.js +242 -0
  1360. package/dist/statements/declarations/variable-type-helpers.js.map +1 -0
  1361. package/dist/statements/declarations/variable-type-resolution.d.ts +11 -0
  1362. package/dist/statements/declarations/variable-type-resolution.d.ts.map +1 -0
  1363. package/dist/statements/declarations/variable-type-resolution.js +11 -0
  1364. package/dist/statements/declarations/variable-type-resolution.js.map +1 -0
  1365. package/dist/statements/declarations/variables.d.ts +5 -1
  1366. package/dist/statements/declarations/variables.d.ts.map +1 -1
  1367. package/dist/statements/declarations/variables.js +116 -596
  1368. package/dist/statements/declarations/variables.js.map +1 -1
  1369. package/dist/statements/index.test.d.ts +10 -5
  1370. package/dist/statements/index.test.d.ts.map +1 -1
  1371. package/dist/statements/index.test.js +10 -1969
  1372. package/dist/statements/index.test.js.map +1 -1
  1373. package/dist/statements/parameter-defaults.d.ts +17 -0
  1374. package/dist/statements/parameter-defaults.d.ts.map +1 -0
  1375. package/dist/statements/parameter-defaults.js +122 -0
  1376. package/dist/statements/parameter-defaults.js.map +1 -0
  1377. package/dist/statements/statement-cases/async-returns.test.d.ts +2 -0
  1378. package/dist/statements/statement-cases/async-returns.test.d.ts.map +1 -0
  1379. package/dist/statements/statement-cases/async-returns.test.js +311 -0
  1380. package/dist/statements/statement-cases/async-returns.test.js.map +1 -0
  1381. package/dist/statements/statement-cases/flow-and-void.test.d.ts +2 -0
  1382. package/dist/statements/statement-cases/flow-and-void.test.d.ts.map +1 -0
  1383. package/dist/statements/statement-cases/flow-and-void.test.js +405 -0
  1384. package/dist/statements/statement-cases/flow-and-void.test.js.map +1 -0
  1385. package/dist/statements/statement-cases/helpers.d.ts +6 -0
  1386. package/dist/statements/statement-cases/helpers.d.ts.map +1 -0
  1387. package/dist/statements/statement-cases/helpers.js +4 -0
  1388. package/dist/statements/statement-cases/helpers.js.map +1 -0
  1389. package/dist/statements/statement-cases/if-and-instanceof-guards.test.d.ts +2 -0
  1390. package/dist/statements/statement-cases/if-and-instanceof-guards.test.d.ts.map +1 -0
  1391. package/dist/statements/statement-cases/if-and-instanceof-guards.test.js +826 -0
  1392. package/dist/statements/statement-cases/if-and-instanceof-guards.test.js.map +1 -0
  1393. package/dist/statements/statement-cases/loops.test.d.ts +2 -0
  1394. package/dist/statements/statement-cases/loops.test.d.ts.map +1 -0
  1395. package/dist/statements/statement-cases/loops.test.js +433 -0
  1396. package/dist/statements/statement-cases/loops.test.js.map +1 -0
  1397. package/dist/statements/statement-cases/scopes-and-storage.test.d.ts +2 -0
  1398. package/dist/statements/statement-cases/scopes-and-storage.test.d.ts.map +1 -0
  1399. package/dist/statements/statement-cases/scopes-and-storage.test.js +216 -0
  1400. package/dist/statements/statement-cases/scopes-and-storage.test.js.map +1 -0
  1401. package/dist/statements/statement-cases/union-guards-basic.test.d.ts +2 -0
  1402. package/dist/statements/statement-cases/union-guards-basic.test.d.ts.map +1 -0
  1403. package/dist/statements/statement-cases/union-guards-basic.test.js +235 -0
  1404. package/dist/statements/statement-cases/union-guards-basic.test.js.map +1 -0
  1405. package/dist/statements/statement-cases/union-guards-nullish-and-object.test.d.ts +2 -0
  1406. package/dist/statements/statement-cases/union-guards-nullish-and-object.test.d.ts.map +1 -0
  1407. package/dist/statements/statement-cases/union-guards-nullish-and-object.test.js +265 -0
  1408. package/dist/statements/statement-cases/union-guards-nullish-and-object.test.js.map +1 -0
  1409. package/dist/statements/statement-cases/union-guards-predicate-and-truthy.test.d.ts +2 -0
  1410. package/dist/statements/statement-cases/union-guards-predicate-and-truthy.test.d.ts.map +1 -0
  1411. package/dist/statements/statement-cases/union-guards-predicate-and-truthy.test.js +630 -0
  1412. package/dist/statements/statement-cases/union-guards-predicate-and-truthy.test.js.map +1 -0
  1413. package/dist/statements/statement-cases/union-guards-remapped-a.test.d.ts +2 -0
  1414. package/dist/statements/statement-cases/union-guards-remapped-a.test.d.ts.map +1 -0
  1415. package/dist/statements/statement-cases/union-guards-remapped-a.test.js +382 -0
  1416. package/dist/statements/statement-cases/union-guards-remapped-a.test.js.map +1 -0
  1417. package/dist/statements/statement-cases/union-guards-remapped-b.test.d.ts +2 -0
  1418. package/dist/statements/statement-cases/union-guards-remapped-b.test.d.ts.map +1 -0
  1419. package/dist/statements/statement-cases/union-guards-remapped-b.test.js +397 -0
  1420. package/dist/statements/statement-cases/union-guards-remapped-b.test.js.map +1 -0
  1421. package/dist/type-assertion.test.js +258 -10
  1422. package/dist/type-assertion.test.js.map +1 -1
  1423. package/dist/types/arrays.d.ts.map +1 -1
  1424. package/dist/types/arrays.js +10 -1
  1425. package/dist/types/arrays.js.map +1 -1
  1426. package/dist/types/emitter.d.ts.map +1 -1
  1427. package/dist/types/emitter.js +129 -24
  1428. package/dist/types/emitter.js.map +1 -1
  1429. package/dist/types/index.test.js +205 -1
  1430. package/dist/types/index.test.js.map +1 -1
  1431. package/dist/types/objects.d.ts +2 -2
  1432. package/dist/types/objects.d.ts.map +1 -1
  1433. package/dist/types/objects.js +2 -2
  1434. package/dist/types/objects.js.map +1 -1
  1435. package/dist/types/parameters.d.ts.map +1 -1
  1436. package/dist/types/parameters.js +88 -18
  1437. package/dist/types/parameters.js.map +1 -1
  1438. package/dist/types/reference-lookup.d.ts +16 -0
  1439. package/dist/types/reference-lookup.d.ts.map +1 -0
  1440. package/dist/types/reference-lookup.js +133 -0
  1441. package/dist/types/reference-lookup.js.map +1 -0
  1442. package/dist/types/reference-structural-signatures.d.ts +10 -0
  1443. package/dist/types/reference-structural-signatures.d.ts.map +1 -0
  1444. package/dist/types/reference-structural-signatures.js +310 -0
  1445. package/dist/types/reference-structural-signatures.js.map +1 -0
  1446. package/dist/types/references-cases/array-and-cross-module.test.d.ts +2 -0
  1447. package/dist/types/references-cases/array-and-cross-module.test.d.ts.map +1 -0
  1448. package/dist/types/references-cases/array-and-cross-module.test.js +150 -0
  1449. package/dist/types/references-cases/array-and-cross-module.test.js.map +1 -0
  1450. package/dist/types/references-cases/bindings-and-local.test.d.ts +2 -0
  1451. package/dist/types/references-cases/bindings-and-local.test.d.ts.map +1 -0
  1452. package/dist/types/references-cases/bindings-and-local.test.js +368 -0
  1453. package/dist/types/references-cases/bindings-and-local.test.js.map +1 -0
  1454. package/dist/types/references-cases/helpers.d.ts +14 -0
  1455. package/dist/types/references-cases/helpers.d.ts.map +1 -0
  1456. package/dist/types/references-cases/helpers.js +39 -0
  1457. package/dist/types/references-cases/helpers.js.map +1 -0
  1458. package/dist/types/references-cases/polymorphic-and-recursive.test.d.ts +2 -0
  1459. package/dist/types/references-cases/polymorphic-and-recursive.test.d.ts.map +1 -0
  1460. package/dist/types/references-cases/polymorphic-and-recursive.test.js +387 -0
  1461. package/dist/types/references-cases/polymorphic-and-recursive.test.js.map +1 -0
  1462. package/dist/types/references-cases/primitive-and-builtins.test.d.ts +2 -0
  1463. package/dist/types/references-cases/primitive-and-builtins.test.d.ts.map +1 -0
  1464. package/dist/types/references-cases/primitive-and-builtins.test.js +116 -0
  1465. package/dist/types/references-cases/primitive-and-builtins.test.js.map +1 -0
  1466. package/dist/types/references-cases/resolved-and-imported.test.d.ts +2 -0
  1467. package/dist/types/references-cases/resolved-and-imported.test.d.ts.map +1 -0
  1468. package/dist/types/references-cases/resolved-and-imported.test.js +669 -0
  1469. package/dist/types/references-cases/resolved-and-imported.test.js.map +1 -0
  1470. package/dist/types/references.d.ts.map +1 -1
  1471. package/dist/types/references.js +250 -154
  1472. package/dist/types/references.js.map +1 -1
  1473. package/dist/types/references.test.d.ts +5 -10
  1474. package/dist/types/references.test.d.ts.map +1 -1
  1475. package/dist/types/references.test.js +5 -730
  1476. package/dist/types/references.test.js.map +1 -1
  1477. package/dist/types/unions-cases/basic-and-ordering.test.d.ts +6 -0
  1478. package/dist/types/unions-cases/basic-and-ordering.test.d.ts.map +1 -0
  1479. package/dist/types/unions-cases/basic-and-ordering.test.js +322 -0
  1480. package/dist/types/unions-cases/basic-and-ordering.test.js.map +1 -0
  1481. package/dist/types/unions-cases/large-and-fallback.test.d.ts +6 -0
  1482. package/dist/types/unions-cases/large-and-fallback.test.d.ts.map +1 -0
  1483. package/dist/types/unions-cases/large-and-fallback.test.js +246 -0
  1484. package/dist/types/unions-cases/large-and-fallback.test.js.map +1 -0
  1485. package/dist/types/unions-cases/multi-surface.test.d.ts +6 -0
  1486. package/dist/types/unions-cases/multi-surface.test.d.ts.map +1 -0
  1487. package/dist/types/unions-cases/multi-surface.test.js +268 -0
  1488. package/dist/types/unions-cases/multi-surface.test.js.map +1 -0
  1489. package/dist/types/unions.d.ts +1 -1
  1490. package/dist/types/unions.d.ts.map +1 -1
  1491. package/dist/types/unions.js +60 -65
  1492. package/dist/types/unions.js.map +1 -1
  1493. package/dist/types/unions.test.d.ts +3 -5
  1494. package/dist/types/unions.test.d.ts.map +1 -1
  1495. package/dist/types/unions.test.js +3 -413
  1496. package/dist/types/unions.test.js.map +1 -1
  1497. package/package.json +4 -4
@@ -0,0 +1,1818 @@
1
+ /**
2
+ * Call argument emission.
3
+ * Handles the main emitCallArguments function and function-value call argument emission.
4
+ */
5
+ import { emitExpressionAst } from "../../expression-emitter.js";
6
+ import { emitTypeAst } from "../../type-emitter.js";
7
+ import { escapeCSharpIdentifier } from "../../emitter-types/index.js";
8
+ import { emitCSharpName } from "../../naming-policy.js";
9
+ import { identifierExpression } from "../../core/format/backend-ast/builders.js";
10
+ import { extractCalleeNameFromAst } from "../../core/format/backend-ast/utils.js";
11
+ import { resolveEffectiveExpressionType, resolveRuntimeSubsetMemberNs, } from "../../core/semantic/narrowed-expression-types.js";
12
+ import { containsTypeParameter, getArrayLikeElementType, } from "../../core/semantic/type-resolution.js";
13
+ import { matchesExpectedEmissionType } from "../../core/semantic/expected-type-matching.js";
14
+ import { getAcceptedParameterType } from "../../core/semantic/defaults.js";
15
+ import { unwrapParameterModifierType } from "../../core/semantic/parameter-modifier-types.js";
16
+ import { resolveTypeAlias, splitRuntimeNullishUnionMembers, stripNullish, } from "../../core/semantic/type-resolution.js";
17
+ import { resolveComparableType } from "../../core/semantic/comparable-types.js";
18
+ import { resolveArrayLiteralContextType, resolveEmptyArrayLiteralContextType, } from "../../core/semantic/array-expected-types.js";
19
+ import { resolveRuntimeMaterializationTargetType } from "../../core/semantic/runtime-materialization-targets.js";
20
+ import { isBroadObjectSlotType } from "../../core/semantic/js-value-types.js";
21
+ import { referenceTypeHasClrIdentity } from "../../core/semantic/clr-type-identity.js";
22
+ import { runtimeUnionMemberCanAcceptValue } from "../../core/semantic/runtime-union-matching.js";
23
+ import { willCarryAsRuntimeUnion } from "../../core/semantic/union-semantics.js";
24
+ import { getContextualTypeVisitKey, tryContextualTypeIdentityKey, } from "../../core/semantic/deterministic-type-keys.js";
25
+ import { unwrapTransparentExpression } from "../../core/semantic/transparent-expressions.js";
26
+ import { buildRuntimeUnionLayout } from "../../core/semantic/runtime-unions.js";
27
+ import { runtimeUnionAliasReferencesMatch } from "../../core/semantic/runtime-union-alias-identity.js";
28
+ import { getPassingModifierFromCast, isLValue } from "./call-analysis.js";
29
+ import { adaptValueToExpectedTypeAst, resolveDirectStorageCompatibleExpressionType, resolveDirectStorageCompatibleIrType, resolveCarrierPreservingRawExpectedType, resolveCarrierPreservingSourceType, resolveRuntimeCarrierCompatibleExpressionAst, resolveRuntimeCarrierCompatibleIrType, tryEmitCarrierPreservingExpressionAst, hasMismatchedCollectionElementCarrier, } from "../expected-type-adaptation.js";
30
+ import { isExactArrayCreationToType, isExactExpressionToType, tryEmitExactComparisonTargetAst, } from "../exact-comparison.js";
31
+ import { getDirectIterableElementType } from "../structural-type-shapes.js";
32
+ import { normalizeCallArgumentExpectedType, expandTupleLikeSpreadArguments, getTransparentRestSpreadPassthroughExpression, wrapArgModifier, emitFlattenedRestArguments, } from "./call-arguments-helpers.js";
33
+ import { shouldPreferRuntimeExpectedType } from "./runtime-expected-type-preference.js";
34
+ import { collectStructuralProperties } from "../structural-property-model.js";
35
+ import { isSameNominalType } from "../structural-type-shapes.js";
36
+ import { areIrTypesEquivalent } from "../../core/semantic/type-equivalence.js";
37
+ import { isExpectedJsNumberIrType, isExpectedIntegralIrType, isNumericSourceIrType, maybeCastNumericToExpectedIntegralAst, maybeCastNumericToExpectedJsNumberAst, } from "../post-emission-adaptation.js";
38
+ const NUMERIC_BINDING_CLR_NAMES = new Set([
39
+ "System.SByte",
40
+ "global::System.SByte",
41
+ "System.Byte",
42
+ "global::System.Byte",
43
+ "System.Int16",
44
+ "global::System.Int16",
45
+ "System.UInt16",
46
+ "global::System.UInt16",
47
+ "System.Int32",
48
+ "global::System.Int32",
49
+ "System.UInt32",
50
+ "global::System.UInt32",
51
+ "System.Int64",
52
+ "global::System.Int64",
53
+ "System.UInt64",
54
+ "global::System.UInt64",
55
+ "System.Single",
56
+ "global::System.Single",
57
+ "System.Double",
58
+ "global::System.Double",
59
+ "System.Decimal",
60
+ "global::System.Decimal",
61
+ "System.Half",
62
+ "global::System.Half",
63
+ ]);
64
+ const getFunctionValueSignature = (expr, context) => {
65
+ if (expr.callee.kind === "identifier") {
66
+ const localType = context.localSemanticTypes?.get(expr.callee.name) ??
67
+ context.localValueTypes?.get(expr.callee.name);
68
+ const resolvedLocalType = resolveFunctionType(localType, context);
69
+ if (resolvedLocalType) {
70
+ return resolvedLocalType;
71
+ }
72
+ const symbolType = context.valueSymbols?.get(expr.callee.name)?.type;
73
+ const resolvedSymbolType = resolveFunctionType(symbolType, context);
74
+ if (resolvedSymbolType) {
75
+ return resolvedSymbolType;
76
+ }
77
+ }
78
+ const calleeType = expr.callee.inferredType;
79
+ if (!calleeType || calleeType.kind !== "functionType")
80
+ return undefined;
81
+ if (expr.callee.kind === "identifier" && expr.callee.resolvedClrType) {
82
+ return undefined;
83
+ }
84
+ if (expr.callee.kind === "memberAccess" && expr.callee.memberBinding) {
85
+ return undefined;
86
+ }
87
+ return calleeType;
88
+ };
89
+ const emitOutDiscardArgument = (context) => {
90
+ const nextId = (context.tempVarId ?? 0) + 1;
91
+ return [
92
+ wrapArgModifier("out", {
93
+ kind: "declarationExpression",
94
+ designation: `__tsonic_out_discard_${nextId}`,
95
+ }),
96
+ {
97
+ ...context,
98
+ tempVarId: nextId,
99
+ },
100
+ ];
101
+ };
102
+ const resolveFunctionType = (type, context) => {
103
+ if (!type) {
104
+ return undefined;
105
+ }
106
+ const unwrapped = unwrapParameterModifierType(type) ?? type;
107
+ const resolved = resolveTypeAlias(stripNullish(unwrapped), context);
108
+ return resolved.kind === "functionType" ? resolved : undefined;
109
+ };
110
+ const getRuntimeSurfaceParameterTypes = (expr, fallback) => {
111
+ if (expr.sourceBackedSurfaceParameterTypes &&
112
+ expr.sourceBackedSurfaceParameterTypes.length > 0) {
113
+ return expr.sourceBackedSurfaceParameterTypes;
114
+ }
115
+ if (expr.surfaceParameterTypes && expr.surfaceParameterTypes.length > 0) {
116
+ return expr.surfaceParameterTypes;
117
+ }
118
+ return fallback;
119
+ };
120
+ const getRuntimeRestParameter = (expr) => expr.sourceBackedRestParameter ??
121
+ expr.surfaceRestParameter ??
122
+ expr.restParameter;
123
+ const matchesDirectCarrierAst = (left, right) => {
124
+ if (left.kind !== right.kind) {
125
+ return false;
126
+ }
127
+ switch (left.kind) {
128
+ case "identifierExpression":
129
+ return (right.kind === "identifierExpression" &&
130
+ left.identifier === right.identifier);
131
+ case "parenthesizedExpression":
132
+ return (right.kind === "parenthesizedExpression" &&
133
+ matchesDirectCarrierAst(left.expression, right.expression));
134
+ case "castExpression":
135
+ return (right.kind === "castExpression" &&
136
+ left.type.kind === right.type.kind &&
137
+ matchesDirectCarrierAst(left.expression, right.expression));
138
+ case "memberAccessExpression":
139
+ return (right.kind === "memberAccessExpression" &&
140
+ left.memberName === right.memberName &&
141
+ matchesDirectCarrierAst(left.expression, right.expression));
142
+ default:
143
+ return false;
144
+ }
145
+ };
146
+ const resolveCarrierPassThroughArgumentType = (arg, valueAst, expectedType, context) => {
147
+ if (!expectedType) {
148
+ return undefined;
149
+ }
150
+ const effectiveExpressionType = resolveEffectiveExpressionType(arg, context) ?? arg.inferredType;
151
+ if (effectiveExpressionType &&
152
+ hasMismatchedCollectionElementCarrier(effectiveExpressionType, expectedType, context)) {
153
+ return undefined;
154
+ }
155
+ if (isBroadObjectSlotType(expectedType, context) &&
156
+ effectiveExpressionType &&
157
+ willCarryAsRuntimeUnion(stripNullish(effectiveExpressionType), context)) {
158
+ return undefined;
159
+ }
160
+ if (arg.kind === "identifier") {
161
+ const storageType = context.localValueTypes?.get(arg.name);
162
+ const storageIdentifier = context.localNameMap?.get(arg.name) ?? escapeCSharpIdentifier(arg.name);
163
+ const carrierSourceType = resolveCarrierPreservingSourceType(storageType, expectedType, context);
164
+ if (carrierSourceType &&
165
+ matchesDirectCarrierAst(valueAst, identifierExpression(storageIdentifier)) &&
166
+ matchesExpectedEmissionType(storageType, expectedType, context)) {
167
+ return carrierSourceType;
168
+ }
169
+ }
170
+ if (!isBroadObjectSlotType(expectedType, context) &&
171
+ !willCarryAsRuntimeUnion(expectedType, context)) {
172
+ return undefined;
173
+ }
174
+ const carrierAst = resolveRuntimeCarrierCompatibleExpressionAst({
175
+ expr: arg,
176
+ context,
177
+ });
178
+ const carrierType = resolveRuntimeCarrierCompatibleIrType({
179
+ expr: arg,
180
+ context,
181
+ });
182
+ if (!carrierAst || !carrierType) {
183
+ return undefined;
184
+ }
185
+ if (!matchesDirectCarrierAst(valueAst, carrierAst)) {
186
+ return undefined;
187
+ }
188
+ return resolveCarrierPreservingSourceType(carrierType, expectedType, context);
189
+ };
190
+ const resolveContextualAdaptedArgumentType = (valueAst, contextualExpectedType, context) => {
191
+ if (!contextualExpectedType) {
192
+ return undefined;
193
+ }
194
+ const exactContextualTarget = tryEmitExactComparisonTargetAst(contextualExpectedType, context);
195
+ if (exactContextualTarget &&
196
+ (isExactExpressionToType(valueAst, exactContextualTarget[0]) ||
197
+ isExactArrayCreationToType(valueAst, exactContextualTarget[0]))) {
198
+ return contextualExpectedType;
199
+ }
200
+ const directIterableElementType = getDirectIterableElementType(contextualExpectedType, context);
201
+ if (!directIterableElementType) {
202
+ return undefined;
203
+ }
204
+ const iteratorMethodName = emitCSharpName("[symbol:iterator]", "methods", context);
205
+ const iteratorPropertyName = emitCSharpName("[symbol:iterator]", "properties", context);
206
+ const calleeName = valueAst.kind === "invocationExpression"
207
+ ? extractCalleeNameFromAst(valueAst.expression)
208
+ : undefined;
209
+ if (calleeName === "global::System.Linq.Enumerable.Select" ||
210
+ (valueAst.kind === "memberAccessExpression" &&
211
+ (valueAst.memberName === iteratorMethodName ||
212
+ valueAst.memberName === iteratorPropertyName)) ||
213
+ (valueAst.kind === "invocationExpression" &&
214
+ valueAst.expression.kind === "memberAccessExpression" &&
215
+ valueAst.expression.memberName === iteratorMethodName)) {
216
+ return contextualExpectedType;
217
+ }
218
+ return undefined;
219
+ };
220
+ const resolveExactRawEmittedExpectedType = (opts) => {
221
+ const { arg, rawArgAst, rawEmitExpectedType, adaptationExpectedType, context, } = opts;
222
+ if (!adaptationExpectedType ||
223
+ !rawEmitExpectedType ||
224
+ (arg.kind !== "call" && arg.kind !== "new") ||
225
+ !areIrTypesEquivalent(rawEmitExpectedType, adaptationExpectedType, context)) {
226
+ return undefined;
227
+ }
228
+ const rawActualType = (arg.kind === "call" || arg.kind === "new"
229
+ ? arg.sourceBackedReturnType
230
+ : undefined) ??
231
+ resolveEffectiveExpressionType(arg, context) ??
232
+ arg.inferredType;
233
+ if (rawActualType &&
234
+ hasMismatchedCollectionElementCarrier(rawActualType, adaptationExpectedType, context)) {
235
+ return undefined;
236
+ }
237
+ const exactTarget = tryEmitExactComparisonTargetAst(adaptationExpectedType, context);
238
+ if (exactTarget &&
239
+ (isExactExpressionToType(rawArgAst, exactTarget[0]) ||
240
+ isExactArrayCreationToType(rawArgAst, exactTarget[0]))) {
241
+ return adaptationExpectedType;
242
+ }
243
+ const carrierAst = resolveRuntimeCarrierCompatibleExpressionAst({
244
+ expr: arg,
245
+ context,
246
+ });
247
+ const carrierType = resolveRuntimeCarrierCompatibleIrType({
248
+ expr: arg,
249
+ context,
250
+ });
251
+ if (carrierAst &&
252
+ carrierType &&
253
+ matchesDirectCarrierAst(rawArgAst, carrierAst) &&
254
+ resolveCarrierPreservingSourceType(carrierType, adaptationExpectedType, context)) {
255
+ return adaptationExpectedType;
256
+ }
257
+ return undefined;
258
+ };
259
+ const isBroadOrStructuralObjectExpectedType = (type) => {
260
+ const stripped = stripNullish(type);
261
+ return (stripped.kind === "unknownType" ||
262
+ stripped.kind === "anyType" ||
263
+ stripped.kind === "objectType" ||
264
+ (stripped.kind === "referenceType" && stripped.name === "object"));
265
+ };
266
+ const getStructuralSurfaceKey = (type, context) => {
267
+ const stripped = type ? stripNullish(type) : undefined;
268
+ if (!stripped) {
269
+ return undefined;
270
+ }
271
+ if (stripped.kind === "objectType") {
272
+ return tryContextualTypeIdentityKey(stripped, context);
273
+ }
274
+ if (stripped.kind === "referenceType" &&
275
+ stripped.structuralMembers &&
276
+ stripped.structuralMembers.length > 0) {
277
+ return tryContextualTypeIdentityKey({
278
+ kind: "objectType",
279
+ members: stripped.structuralMembers,
280
+ }, context);
281
+ }
282
+ return undefined;
283
+ };
284
+ const hasEquivalentStructuralSurface = (left, right, context) => {
285
+ const leftKey = getStructuralSurfaceKey(left, context);
286
+ const rightKey = getStructuralSurfaceKey(right, context);
287
+ return leftKey !== undefined && leftKey === rightKey;
288
+ };
289
+ const surfaceUnionMemberContainsSelectedType = (member, selected, context, seen = new Set()) => {
290
+ if (!member || !selected) {
291
+ return false;
292
+ }
293
+ const resolvedMember = resolveTypeAlias(stripNullish(member), context);
294
+ const resolvedSelected = resolveTypeAlias(stripNullish(selected), context);
295
+ const visitKey = `${getContextualTypeVisitKey(resolvedMember, context)}=>${getContextualTypeVisitKey(resolvedSelected, context)}`;
296
+ if (seen.has(visitKey)) {
297
+ return false;
298
+ }
299
+ const selectedComparable = resolveComparableType(resolvedSelected, context);
300
+ const matchesMember = (candidate) => {
301
+ const candidateComparable = resolveComparableType(candidate, context);
302
+ if (areIrTypesEquivalent(candidateComparable, selectedComparable, context)) {
303
+ return true;
304
+ }
305
+ return (hasEquivalentStructuralSurface(candidate, resolvedSelected, context) ||
306
+ runtimeUnionMemberCanAcceptValue(candidate, resolvedSelected, context) ||
307
+ (matchesExpectedEmissionType(candidate, resolvedSelected, context) &&
308
+ matchesExpectedEmissionType(resolvedSelected, candidate, context)));
309
+ };
310
+ if (matchesMember(resolvedMember)) {
311
+ return true;
312
+ }
313
+ if (resolvedMember.kind !== "unionType") {
314
+ return false;
315
+ }
316
+ const nextSeen = new Set(seen);
317
+ nextSeen.add(visitKey);
318
+ return resolvedMember.types.some((candidate) => matchesMember(candidate) ||
319
+ surfaceUnionMemberContainsSelectedType(candidate, resolvedSelected, context, nextSeen));
320
+ };
321
+ const shouldPreferNamedStructuralTarget = (selectedExpectedType, surfaceExpectedType, context) => {
322
+ void selectedExpectedType;
323
+ void surfaceExpectedType;
324
+ void context;
325
+ return false;
326
+ };
327
+ const unionMemberAcceptsArrayLiteral = (member, context, seen = new Set()) => {
328
+ const resolvedMember = resolveTypeAlias(stripNullish(member), context);
329
+ const visitKey = getContextualTypeVisitKey(resolvedMember, context);
330
+ if (seen.has(visitKey)) {
331
+ return false;
332
+ }
333
+ if (getArrayLikeElementType(resolvedMember, context) ||
334
+ getDirectIterableElementType(resolvedMember, context)) {
335
+ return true;
336
+ }
337
+ if (resolvedMember.kind !== "unionType") {
338
+ return false;
339
+ }
340
+ const nextSeen = new Set(seen);
341
+ nextSeen.add(visitKey);
342
+ return resolvedMember.types.some((candidate) => unionMemberAcceptsArrayLiteral(candidate, context, nextSeen));
343
+ };
344
+ const resolveConcreteArrayLiteralContextType = (type, context, preferEmptyArrayMember = false) => {
345
+ if (!type) {
346
+ return undefined;
347
+ }
348
+ const contextualType = (preferEmptyArrayMember
349
+ ? resolveEmptyArrayLiteralContextType(type, context)
350
+ : undefined) ?? resolveArrayLiteralContextType(type, context);
351
+ if (!contextualType) {
352
+ return undefined;
353
+ }
354
+ const resolvedContextualType = resolveTypeAlias(stripNullish(contextualType), context);
355
+ if (resolvedContextualType.kind === "arrayType" ||
356
+ resolvedContextualType.kind === "tupleType") {
357
+ return contextualType;
358
+ }
359
+ if (resolvedContextualType.kind === "referenceType" &&
360
+ (resolvedContextualType.name === "Array" ||
361
+ resolvedContextualType.name === "ReadonlyArray" ||
362
+ resolvedContextualType.name === "ArrayLike")) {
363
+ return contextualType;
364
+ }
365
+ return undefined;
366
+ };
367
+ const resolveDeterministicSurfaceUnionMemberNs = (selectedExpectedType, surfaceExpectedType, context) => {
368
+ if (!selectedExpectedType || !surfaceExpectedType) {
369
+ return undefined;
370
+ }
371
+ const resolvedSurface = resolveTypeAlias(stripNullish(surfaceExpectedType), context);
372
+ if (resolvedSurface.kind !== "unionType") {
373
+ return undefined;
374
+ }
375
+ const [runtimeLayout] = buildRuntimeUnionLayout(resolvedSurface, context, emitTypeAst);
376
+ if (!runtimeLayout) {
377
+ return undefined;
378
+ }
379
+ const resolvedSelected = resolveTypeAlias(stripNullish(selectedExpectedType), context);
380
+ const matchingMemberNs = runtimeLayout.members.flatMap((member, index) => {
381
+ return surfaceUnionMemberContainsSelectedType(member, resolvedSelected, context)
382
+ ? [index + 1]
383
+ : [];
384
+ });
385
+ return matchingMemberNs.length === 1 ? new Set(matchingMemberNs) : undefined;
386
+ };
387
+ const finalExpectedMatchesSurfaceCarrier = (finalExpectedType, surfaceExpectedType, context) => {
388
+ if (!finalExpectedType || !surfaceExpectedType) {
389
+ return false;
390
+ }
391
+ return (areIrTypesEquivalent(finalExpectedType, surfaceExpectedType, context) ||
392
+ runtimeUnionAliasReferencesMatch(finalExpectedType, surfaceExpectedType, context) ||
393
+ resolveCarrierPreservingSourceType(finalExpectedType, surfaceExpectedType, context) !== undefined ||
394
+ resolveCarrierPreservingSourceType(surfaceExpectedType, finalExpectedType, context) !== undefined);
395
+ };
396
+ const resolveSurfaceSelectedSourceMemberNs = (selectedExpectedType, finalExpectedType, surfaceExpectedType, context) => {
397
+ if (!surfaceExpectedType) {
398
+ return undefined;
399
+ }
400
+ return (resolveDeterministicSurfaceUnionMemberNs(selectedExpectedType, surfaceExpectedType, context) ??
401
+ resolveDeterministicSurfaceUnionMemberNs(finalExpectedType, surfaceExpectedType, context));
402
+ };
403
+ const intersectSelectedSourceMemberNs = (left, right) => {
404
+ if (!left) {
405
+ return right;
406
+ }
407
+ if (!right) {
408
+ return left;
409
+ }
410
+ const intersection = new Set(Array.from(left).filter((memberN) => right.has(memberN)));
411
+ return intersection.size > 0 ? intersection : undefined;
412
+ };
413
+ const resolveSelectedSourceMemberNs = (arg, selectedExpectedType, finalExpectedType, surfaceExpectedType, context) => intersectSelectedSourceMemberNs(resolveRuntimeSubsetMemberNs(arg, context), resolveSurfaceSelectedSourceMemberNs(selectedExpectedType, finalExpectedType, surfaceExpectedType, context));
414
+ const resolveAdaptationExpectedType = (selectedExpectedType, finalExpectedType, surfaceExpectedType, context) => {
415
+ if (!finalExpectedType) {
416
+ return surfaceExpectedType;
417
+ }
418
+ if (!surfaceExpectedType) {
419
+ return finalExpectedType;
420
+ }
421
+ if (resolveSurfaceSelectedSourceMemberNs(selectedExpectedType, finalExpectedType, surfaceExpectedType, context)) {
422
+ return surfaceExpectedType;
423
+ }
424
+ return finalExpectedMatchesSurfaceCarrier(finalExpectedType, surfaceExpectedType, context)
425
+ ? surfaceExpectedType
426
+ : finalExpectedType;
427
+ };
428
+ const resolveFinalCallArgumentExpectedType = (selectedExpectedType, surfaceExpectedType, actualArgumentType, context) => {
429
+ if (!surfaceExpectedType) {
430
+ return selectedExpectedType;
431
+ }
432
+ if (!selectedExpectedType) {
433
+ return surfaceExpectedType;
434
+ }
435
+ if (shouldPreferNamedStructuralTarget(selectedExpectedType, surfaceExpectedType, context)) {
436
+ return selectedExpectedType;
437
+ }
438
+ if (resolveDeterministicSurfaceUnionMemberNs(selectedExpectedType, surfaceExpectedType, context)) {
439
+ return surfaceExpectedType;
440
+ }
441
+ if (preservesSurfaceRuntimeMaterialization(surfaceExpectedType, selectedExpectedType, context)) {
442
+ return selectedExpectedType;
443
+ }
444
+ if (isBroadOrStructuralObjectExpectedType(surfaceExpectedType) &&
445
+ !preservesSurfaceRuntimeMaterialization(surfaceExpectedType, selectedExpectedType, context) &&
446
+ (!actualArgumentType ||
447
+ matchesExpectedEmissionType(actualArgumentType, selectedExpectedType, context))) {
448
+ return selectedExpectedType;
449
+ }
450
+ return surfaceExpectedType;
451
+ };
452
+ const shouldPreserveSurfaceRuntimeExpectedType = (opts) => {
453
+ const { selectedExpectedType, surfaceExpectedType, context } = opts;
454
+ if (!selectedExpectedType || !surfaceExpectedType) {
455
+ return false;
456
+ }
457
+ return (willCarryAsRuntimeUnion(surfaceExpectedType, context) &&
458
+ !preservesSurfaceRuntimeMaterialization(surfaceExpectedType, selectedExpectedType, context));
459
+ };
460
+ const resolvePreEmitStorageAwareArgumentType = (arg, semanticArgumentType, context) => resolveDirectStorageCompatibleIrType({
461
+ expr: arg,
462
+ context,
463
+ }) ?? semanticArgumentType;
464
+ const shouldPreserveOptionalSurfaceCarrierPassThrough = (opts) => {
465
+ const { arg, selectedExpectedType, surfaceExpectedType, context } = opts;
466
+ if (!selectedExpectedType || !surfaceExpectedType) {
467
+ return false;
468
+ }
469
+ const surfaceNullishSplit = splitRuntimeNullishUnionMembers(surfaceExpectedType);
470
+ const selectedNullishSplit = splitRuntimeNullishUnionMembers(selectedExpectedType);
471
+ if (!surfaceNullishSplit?.hasRuntimeNullish) {
472
+ return false;
473
+ }
474
+ if (selectedNullishSplit?.hasRuntimeNullish) {
475
+ return false;
476
+ }
477
+ return !!tryEmitCarrierPreservingExpressionAst({
478
+ expr: arg,
479
+ expectedType: surfaceExpectedType,
480
+ context,
481
+ });
482
+ };
483
+ const isExplicitRuntimeNullishArgument = (arg) => (arg.kind === "identifier" &&
484
+ (arg.name === "undefined" || arg.name === "null")) ||
485
+ (arg.kind === "literal" && (arg.value === undefined || arg.value === null));
486
+ const resolveExplicitNullishSurfaceExpectedType = (opts) => {
487
+ const { arg, surfaceExpectedType } = opts;
488
+ if (!surfaceExpectedType || !isExplicitRuntimeNullishArgument(arg)) {
489
+ return undefined;
490
+ }
491
+ return splitRuntimeNullishUnionMembers(surfaceExpectedType)?.hasRuntimeNullish
492
+ ? surfaceExpectedType
493
+ : undefined;
494
+ };
495
+ const shouldPreserveOptionalSurfaceRawEmission = (opts) => {
496
+ const { arg, selectedExpectedType, surfaceExpectedType, context } = opts;
497
+ if (!selectedExpectedType || !surfaceExpectedType) {
498
+ return false;
499
+ }
500
+ const surfaceNullishSplit = splitRuntimeNullishUnionMembers(surfaceExpectedType);
501
+ const selectedNullishSplit = splitRuntimeNullishUnionMembers(selectedExpectedType);
502
+ if (!surfaceNullishSplit?.hasRuntimeNullish ||
503
+ selectedNullishSplit?.hasRuntimeNullish) {
504
+ return false;
505
+ }
506
+ const transparentArg = unwrapTransparentExpression(arg);
507
+ if (transparentArg.kind !== "identifier" &&
508
+ transparentArg.kind !== "memberAccess") {
509
+ return false;
510
+ }
511
+ const actualType = resolveEffectiveExpressionType(arg, context) ??
512
+ resolveEffectiveExpressionType(transparentArg, context) ??
513
+ arg.inferredType ??
514
+ transparentArg.inferredType;
515
+ const directStorageType = resolveDirectStorageCompatibleIrType({
516
+ expr: arg,
517
+ context,
518
+ }) ??
519
+ resolveDirectStorageCompatibleIrType({
520
+ expr: transparentArg,
521
+ context,
522
+ });
523
+ const candidateSourceType = directStorageType ?? actualType;
524
+ if (!candidateSourceType) {
525
+ return false;
526
+ }
527
+ return (resolveCarrierPreservingSourceType(candidateSourceType, surfaceExpectedType, context) !== undefined);
528
+ };
529
+ const shouldUseSurfaceCarrierForRawEmission = (opts) => {
530
+ const { arg, adaptationExpectedType, surfaceExpectedType, context } = opts;
531
+ if (!adaptationExpectedType || !surfaceExpectedType) {
532
+ return false;
533
+ }
534
+ if (surfaceExpectedType.kind !== "referenceType") {
535
+ return false;
536
+ }
537
+ if (!willCarryAsRuntimeUnion(surfaceExpectedType, context)) {
538
+ return false;
539
+ }
540
+ const rawCarrierSourceType = resolveRuntimeCarrierCompatibleIrType({ expr: arg, context }) ??
541
+ resolveDirectStorageCompatibleIrType({ expr: arg, context });
542
+ if (!resolveCarrierPreservingSourceType(rawCarrierSourceType, surfaceExpectedType, context)) {
543
+ return false;
544
+ }
545
+ return finalExpectedMatchesSurfaceCarrier(adaptationExpectedType, surfaceExpectedType, context);
546
+ };
547
+ const shouldDeferStructuralObjectArgumentMaterialization = (opts) => {
548
+ const { arg, rawExpectedType, context } = opts;
549
+ if (!rawExpectedType) {
550
+ return false;
551
+ }
552
+ if (arg.kind !== "identifier" && arg.kind !== "memberAccess") {
553
+ return false;
554
+ }
555
+ const actualType = resolveDirectStorageCompatibleIrType({ expr: arg, context }) ??
556
+ resolveEffectiveExpressionType(arg, context) ??
557
+ arg.inferredType;
558
+ if (!actualType) {
559
+ return false;
560
+ }
561
+ if (isSameNominalType(actualType, rawExpectedType, context)) {
562
+ return false;
563
+ }
564
+ const actualProps = collectStructuralProperties(actualType, context);
565
+ const expectedProps = collectStructuralProperties(rawExpectedType, context);
566
+ return (actualProps !== undefined &&
567
+ actualProps.length > 0 &&
568
+ expectedProps !== undefined &&
569
+ expectedProps.length > 0);
570
+ };
571
+ const selectAdaptationActualArgumentType = (opts) => {
572
+ const { carrierPassThroughType, exactFinalExpectedArgumentType, directStorageArgumentType, contextualAdaptedActualType, resolvedFunctionArgumentType, effectiveArgumentType, inferredArgumentType, selectedSourceMemberNs, context, } = opts;
573
+ if (carrierPassThroughType) {
574
+ return carrierPassThroughType;
575
+ }
576
+ if (exactFinalExpectedArgumentType) {
577
+ return exactFinalExpectedArgumentType;
578
+ }
579
+ if (selectedSourceMemberNs &&
580
+ selectedSourceMemberNs.size > 0 &&
581
+ effectiveArgumentType &&
582
+ directStorageArgumentType &&
583
+ willCarryAsRuntimeUnion(stripNullish(directStorageArgumentType), context) &&
584
+ matchesExpectedEmissionType(effectiveArgumentType, directStorageArgumentType, context) &&
585
+ !matchesExpectedEmissionType(directStorageArgumentType, effectiveArgumentType, context)) {
586
+ return directStorageArgumentType;
587
+ }
588
+ const shouldPreferEffectiveArgumentType = !!effectiveArgumentType &&
589
+ !!directStorageArgumentType &&
590
+ !areIrTypesEquivalent(effectiveArgumentType, directStorageArgumentType, context) &&
591
+ !(willCarryAsRuntimeUnion(stripNullish(effectiveArgumentType), context) &&
592
+ !willCarryAsRuntimeUnion(stripNullish(directStorageArgumentType), context)) &&
593
+ matchesExpectedEmissionType(effectiveArgumentType, directStorageArgumentType, context) &&
594
+ !matchesExpectedEmissionType(directStorageArgumentType, effectiveArgumentType, context);
595
+ if (shouldPreferEffectiveArgumentType) {
596
+ return effectiveArgumentType;
597
+ }
598
+ if (isBroadObjectSlotType(directStorageArgumentType, context)) {
599
+ return directStorageArgumentType;
600
+ }
601
+ return (directStorageArgumentType ??
602
+ contextualAdaptedActualType ??
603
+ resolvedFunctionArgumentType ??
604
+ effectiveArgumentType ??
605
+ inferredArgumentType);
606
+ };
607
+ const selectCollectionMaterializationActualArgumentType = (opts) => {
608
+ const { arg, preferredSourceType, selectedActualType, expectedType, context, } = opts;
609
+ if (!expectedType) {
610
+ return selectedActualType;
611
+ }
612
+ const sourceBackedReturnType = arg.kind === "call" || arg.kind === "new"
613
+ ? arg.sourceBackedReturnType
614
+ : undefined;
615
+ const sourceType = sourceBackedReturnType ?? preferredSourceType;
616
+ return sourceType &&
617
+ hasMismatchedCollectionElementCarrier(sourceType, expectedType, context)
618
+ ? sourceType
619
+ : selectedActualType;
620
+ };
621
+ const selectNumericCastArgumentType = (candidates, context) => candidates.find((candidate) => isNumericSourceIrType(candidate, context));
622
+ const hasRuntimeNullishSurface = (type) => type !== undefined &&
623
+ (splitRuntimeNullishUnionMembers(type)?.hasRuntimeNullish ?? false);
624
+ const numericCoreTypesMatch = (left, right, context) => {
625
+ if (!left || !right) {
626
+ return false;
627
+ }
628
+ const strippedLeft = stripNullish(left);
629
+ const strippedRight = stripNullish(right);
630
+ return (areIrTypesEquivalent(strippedLeft, strippedRight, context) ||
631
+ (matchesExpectedEmissionType(strippedLeft, strippedRight, context) &&
632
+ matchesExpectedEmissionType(strippedRight, strippedLeft, context)));
633
+ };
634
+ const selectPostMaterializationNumericCastArgumentType = (opts) => {
635
+ if (opts.exactFinalExpectedArgumentType &&
636
+ opts.adaptationExpectedType &&
637
+ hasRuntimeNullishSurface(opts.adaptationExpectedType) &&
638
+ numericCoreTypesMatch(opts.exactFinalExpectedArgumentType, opts.adaptationExpectedType, opts.context)) {
639
+ return opts.adaptationExpectedType;
640
+ }
641
+ const postMaterializationType = opts.carrierPassThroughArgumentType ??
642
+ opts.carrierPassThroughType ??
643
+ opts.exactFinalExpectedArgumentType ??
644
+ (opts.materializedArgAst === opts.rawArgAst
645
+ ? undefined
646
+ : opts.adaptationExpectedType);
647
+ if (postMaterializationType) {
648
+ return isNumericSourceIrType(postMaterializationType, opts.context)
649
+ ? postMaterializationType
650
+ : undefined;
651
+ }
652
+ return selectNumericCastArgumentType(opts.fallbackCandidates, opts.context);
653
+ };
654
+ const selectNumericCastExpectedType = (candidates, context, actualType) => {
655
+ const numericCandidates = candidates.filter((candidate) => isExpectedIntegralIrType(candidate, context) ||
656
+ isExpectedJsNumberIrType(candidate, context));
657
+ if (actualType && hasRuntimeNullishSurface(actualType)) {
658
+ const nullishCandidate = numericCandidates.find((candidate) => hasRuntimeNullishSurface(candidate) &&
659
+ numericCoreTypesMatch(candidate, actualType, context));
660
+ if (nullishCandidate) {
661
+ return nullishCandidate;
662
+ }
663
+ }
664
+ return numericCandidates[0];
665
+ };
666
+ const resolveContextualCallArgumentExpectedType = (arg, selectedExpectedType, runtimeExpectedType, actualArgumentType, context) => {
667
+ if (!runtimeExpectedType) {
668
+ return selectedExpectedType;
669
+ }
670
+ if (!selectedExpectedType) {
671
+ return runtimeExpectedType;
672
+ }
673
+ if (shouldPreferNamedStructuralTarget(selectedExpectedType, runtimeExpectedType, context)) {
674
+ return selectedExpectedType;
675
+ }
676
+ if (arg.kind === "identifier") {
677
+ const storageType = context.localValueTypes?.get(arg.name);
678
+ if (storageType &&
679
+ matchesExpectedEmissionType(storageType, runtimeExpectedType, context) &&
680
+ matchesExpectedEmissionType(selectedExpectedType, runtimeExpectedType, context)) {
681
+ return runtimeExpectedType;
682
+ }
683
+ }
684
+ if (actualArgumentType &&
685
+ matchesExpectedEmissionType(actualArgumentType, runtimeExpectedType, context)) {
686
+ return runtimeExpectedType;
687
+ }
688
+ if (shouldPreferRuntimeExpectedType(arg, actualArgumentType, runtimeExpectedType, context)) {
689
+ return runtimeExpectedType;
690
+ }
691
+ if (runtimeExpectedType.kind === "unknownType" ||
692
+ runtimeExpectedType.kind === "anyType" ||
693
+ (runtimeExpectedType.kind === "referenceType" &&
694
+ runtimeExpectedType.name === "object")) {
695
+ return runtimeExpectedType;
696
+ }
697
+ return selectedExpectedType;
698
+ };
699
+ const countRequiredParameters = (parameters) => {
700
+ let required = 0;
701
+ for (const parameter of parameters) {
702
+ if (!parameter)
703
+ continue;
704
+ if (parameter.isRest ||
705
+ parameter.isOptional ||
706
+ parameter.initializer !== undefined) {
707
+ break;
708
+ }
709
+ required += 1;
710
+ }
711
+ return required;
712
+ };
713
+ const isNumericBindingParameterType = (type, context) => {
714
+ const resolved = resolveTypeAlias(stripNullish(type), context);
715
+ if (resolved.kind === "primitiveType") {
716
+ return resolved.name === "number" || resolved.name === "int";
717
+ }
718
+ if (resolved.kind === "literalType") {
719
+ return typeof resolved.value === "number";
720
+ }
721
+ if (resolved.kind !== "referenceType") {
722
+ return false;
723
+ }
724
+ return (resolved.name === "sbyte" ||
725
+ resolved.name === "byte" ||
726
+ resolved.name === "short" ||
727
+ resolved.name === "ushort" ||
728
+ resolved.name === "int" ||
729
+ resolved.name === "uint" ||
730
+ resolved.name === "long" ||
731
+ resolved.name === "ulong" ||
732
+ resolved.name === "float" ||
733
+ resolved.name === "double" ||
734
+ resolved.name === "decimal" ||
735
+ resolved.name === "Half" ||
736
+ resolved.name === "SByte" ||
737
+ resolved.name === "Byte" ||
738
+ resolved.name === "Int16" ||
739
+ resolved.name === "UInt16" ||
740
+ resolved.name === "Int32" ||
741
+ resolved.name === "UInt32" ||
742
+ resolved.name === "Int64" ||
743
+ resolved.name === "UInt64" ||
744
+ resolved.name === "Single" ||
745
+ resolved.name === "Double" ||
746
+ resolved.name === "Decimal" ||
747
+ referenceTypeHasClrIdentity(resolved, NUMERIC_BINDING_CLR_NAMES));
748
+ };
749
+ const requiresDelegateArityAdaptation = (actualType, expectedType) => {
750
+ const actualHasRest = actualType.parameters.some((parameter) => parameter?.isRest);
751
+ const expectedHasRest = expectedType.parameters.some((parameter) => parameter?.isRest);
752
+ if (actualHasRest || expectedHasRest) {
753
+ return false;
754
+ }
755
+ if (actualType.parameters.length === expectedType.parameters.length) {
756
+ return false;
757
+ }
758
+ const actualRequired = countRequiredParameters(actualType.parameters);
759
+ return actualRequired <= expectedType.parameters.length;
760
+ };
761
+ const getExpectedParameterBaseName = (parameter, index) => {
762
+ if (parameter?.pattern.kind === "identifierPattern") {
763
+ return escapeCSharpIdentifier(parameter.pattern.name);
764
+ }
765
+ return `arg${index}`;
766
+ };
767
+ const buildDelegateAdapterParameterName = (parameter, index, preserveExisting) => preserveExisting
768
+ ? getExpectedParameterBaseName(parameter, index)
769
+ : `__unused_${getExpectedParameterBaseName(parameter, index)}`;
770
+ const shouldEmitExplicitDelegateAdapterTypes = (expectedType) => expectedType.parameters.every((parameter) => parameter?.type !== undefined &&
771
+ parameter.type.kind !== "unknownType" &&
772
+ parameter.type.kind !== "anyType" &&
773
+ !containsTypeParameter(parameter.type));
774
+ const wrapOptionalDelegateParameterTypeAst = (typeAst, parameter) => parameter?.isOptional && typeAst.kind !== "nullableType"
775
+ ? { kind: "nullableType", underlyingType: typeAst }
776
+ : typeAst;
777
+ const emitDelegateAdapterParameters = (expectedType, parameterNames, context) => {
778
+ let currentContext = context;
779
+ const emitExplicitTypes = shouldEmitExplicitDelegateAdapterTypes(expectedType);
780
+ const emitted = [];
781
+ for (let index = 0; index < expectedType.parameters.length; index += 1) {
782
+ const parameter = expectedType.parameters[index];
783
+ if (!parameter)
784
+ continue;
785
+ const modifier = parameter.passing !== "value" ? parameter.passing : undefined;
786
+ if (emitExplicitTypes && parameter.type) {
787
+ const [typeAst, nextContext] = emitTypeAst(parameter.type, currentContext);
788
+ currentContext = nextContext;
789
+ emitted.push(modifier
790
+ ? {
791
+ name: parameterNames[index] ?? `__arg${index}`,
792
+ modifier,
793
+ type: wrapOptionalDelegateParameterTypeAst(typeAst, parameter),
794
+ }
795
+ : {
796
+ name: parameterNames[index] ?? `__arg${index}`,
797
+ type: wrapOptionalDelegateParameterTypeAst(typeAst, parameter),
798
+ });
799
+ continue;
800
+ }
801
+ emitted.push(modifier
802
+ ? { name: parameterNames[index] ?? `__arg${index}`, modifier }
803
+ : { name: parameterNames[index] ?? `__arg${index}` });
804
+ }
805
+ return [emitted, currentContext];
806
+ };
807
+ const adaptLambdaArgumentAst = (lambdaAst, expectedType, context) => {
808
+ const parameterNames = expectedType.parameters.map((parameter, index) => index < lambdaAst.parameters.length
809
+ ? (lambdaAst.parameters[index]?.name ?? `__arg${index}`)
810
+ : buildDelegateAdapterParameterName(parameter, index, false));
811
+ const [parameters, nextContext] = emitDelegateAdapterParameters(expectedType, parameterNames, context);
812
+ return [
813
+ {
814
+ ...lambdaAst,
815
+ parameters,
816
+ },
817
+ nextContext,
818
+ ];
819
+ };
820
+ const wrapFunctionValueArgumentAst = (originalAst, actualType, expectedType, context) => {
821
+ const parameterNames = expectedType.parameters.map((parameter, index) => buildDelegateAdapterParameterName(parameter, index, index < actualType.parameters.length));
822
+ const [parameters, nextContext] = emitDelegateAdapterParameters(expectedType, parameterNames, context);
823
+ return [
824
+ {
825
+ kind: "lambdaExpression",
826
+ isAsync: false,
827
+ parameters,
828
+ body: {
829
+ kind: "invocationExpression",
830
+ expression: originalAst,
831
+ arguments: parameterNames
832
+ .slice(0, actualType.parameters.length)
833
+ .map((name) => ({
834
+ kind: "identifierExpression",
835
+ identifier: name,
836
+ })),
837
+ },
838
+ },
839
+ nextContext,
840
+ ];
841
+ };
842
+ const findMemberBindingExpectedType = (expr, argIndex, context) => {
843
+ if (expr.callee.kind !== "memberAccess" || !expr.callee.memberBinding) {
844
+ return undefined;
845
+ }
846
+ const calleeBinding = expr.callee.memberBinding;
847
+ const preferredOwner = calleeBinding.type;
848
+ const overloads = context.bindingRegistry?.getMemberOverloads(preferredOwner, calleeBinding.member, preferredOwner);
849
+ if (!overloads || overloads.length === 0) {
850
+ return undefined;
851
+ }
852
+ const actualArgumentTypes = expr.arguments.map((argument) => argument.kind === "spread"
853
+ ? undefined
854
+ : (resolveEffectiveExpressionType(argument, context) ??
855
+ argument.inferredType));
856
+ const matchingParameterTypes = overloads
857
+ .filter((overload) => {
858
+ if (overload.binding.assembly !== calleeBinding.assembly ||
859
+ overload.binding.type !== calleeBinding.type ||
860
+ overload.binding.member !== calleeBinding.member) {
861
+ return false;
862
+ }
863
+ const parameters = overload.semanticSignature?.parameters;
864
+ if (!parameters) {
865
+ return false;
866
+ }
867
+ const parameterOffset = overload.isExtensionMethod ? 1 : 0;
868
+ const required = countRequiredParameters(parameters);
869
+ const visibleRequired = Math.max(0, required - parameterOffset);
870
+ if (expr.arguments.length < visibleRequired) {
871
+ return false;
872
+ }
873
+ const hasRest = parameters.some((parameter) => parameter?.isRest);
874
+ const visibleParameterCount = Math.max(0, parameters.length - parameterOffset);
875
+ if (!hasRest && expr.arguments.length > visibleParameterCount) {
876
+ return false;
877
+ }
878
+ for (let visibleIndex = 0; visibleIndex < expr.arguments.length; visibleIndex++) {
879
+ const actualArgumentType = actualArgumentTypes[visibleIndex];
880
+ const parameter = parameters[visibleIndex + parameterOffset];
881
+ const parameterType = parameter?.type;
882
+ if (!actualArgumentType || !parameterType) {
883
+ continue;
884
+ }
885
+ if (!matchesExpectedEmissionType(actualArgumentType, parameterType, context)) {
886
+ return false;
887
+ }
888
+ }
889
+ return parameters[argIndex + parameterOffset]?.type !== undefined;
890
+ })
891
+ .map((overload) => {
892
+ const parameters = overload.semanticSignature?.parameters;
893
+ const parameterOffset = overload.isExtensionMethod ? 1 : 0;
894
+ return parameters?.[argIndex + parameterOffset]?.type;
895
+ })
896
+ .filter((parameterType) => parameterType !== undefined);
897
+ if (matchingParameterTypes.length === 0) {
898
+ return undefined;
899
+ }
900
+ const uniqueParameterTypes = new Map();
901
+ for (const parameterType of matchingParameterTypes) {
902
+ const key = tryContextualTypeIdentityKey(stripNullish(parameterType), context);
903
+ if (!key) {
904
+ return undefined;
905
+ }
906
+ uniqueParameterTypes.set(key, parameterType);
907
+ }
908
+ if (uniqueParameterTypes.size === 1) {
909
+ return [...uniqueParameterTypes.values()][0];
910
+ }
911
+ const uniqueNonBroadParameterTypes = new Map();
912
+ for (const parameterType of uniqueParameterTypes.values()) {
913
+ const stripped = stripNullish(parameterType);
914
+ const isBroadFallback = stripped.kind === "anyType" ||
915
+ stripped.kind === "unknownType" ||
916
+ (stripped.kind === "referenceType" && stripped.name === "object");
917
+ if (isBroadFallback) {
918
+ continue;
919
+ }
920
+ const key = tryContextualTypeIdentityKey(stripped, context);
921
+ if (!key) {
922
+ return undefined;
923
+ }
924
+ uniqueNonBroadParameterTypes.set(key, parameterType);
925
+ }
926
+ if (uniqueNonBroadParameterTypes.size === 1) {
927
+ return [...uniqueNonBroadParameterTypes.values()][0];
928
+ }
929
+ const uniqueNumericParameterTypes = new Map();
930
+ for (const parameterType of uniqueNonBroadParameterTypes.values()) {
931
+ if (!isNumericBindingParameterType(parameterType, context)) {
932
+ continue;
933
+ }
934
+ const key = tryContextualTypeIdentityKey(stripNullish(parameterType), context);
935
+ if (!key) {
936
+ return undefined;
937
+ }
938
+ uniqueNumericParameterTypes.set(key, parameterType);
939
+ }
940
+ return uniqueNumericParameterTypes.size === 1
941
+ ? [...uniqueNumericParameterTypes.values()][0]
942
+ : undefined;
943
+ };
944
+ const resolveExpectedFunctionTypeForArgument = (expr, argIndex, expectedType, context) => resolveFunctionType(expectedType, context) ??
945
+ resolveFunctionType(findMemberBindingExpectedType(expr, argIndex, context), context);
946
+ const resolveActualFunctionTypeForArgument = (arg, context) => {
947
+ const trimToDeclaredArity = (functionType) => {
948
+ if (!functionType ||
949
+ (arg.kind !== "arrowFunction" && arg.kind !== "functionExpression")) {
950
+ return functionType;
951
+ }
952
+ const declaredArity = arg.parameters.length;
953
+ if (declaredArity >= functionType.parameters.length) {
954
+ return functionType;
955
+ }
956
+ return {
957
+ ...functionType,
958
+ parameters: functionType.parameters.slice(0, declaredArity),
959
+ };
960
+ };
961
+ if (arg.kind === "identifier") {
962
+ return trimToDeclaredArity(resolveFunctionType(context.localSemanticTypes?.get(arg.name) ??
963
+ context.localValueTypes?.get(arg.name) ??
964
+ context.valueSymbols?.get(arg.name)?.type ??
965
+ arg.inferredType, context));
966
+ }
967
+ return trimToDeclaredArity(resolveFunctionType(resolveEffectiveExpressionType(arg, context) ?? arg.inferredType, context));
968
+ };
969
+ const broadObjectIrType = {
970
+ kind: "referenceType",
971
+ name: "object",
972
+ resolvedClrType: "System.Object",
973
+ };
974
+ const resolveGenericBroadObjectFallbackExpectedType = (expr, args, argIndex, context) => {
975
+ const calleeType = expr.callee.inferredType;
976
+ if (!calleeType || calleeType.kind !== "intersectionType") {
977
+ return undefined;
978
+ }
979
+ const argument = args[argIndex];
980
+ if (!argument) {
981
+ return undefined;
982
+ }
983
+ const actualType = resolveActualFunctionTypeForArgument(argument, context) ??
984
+ resolveEffectiveExpressionType(argument, context) ??
985
+ argument.inferredType;
986
+ if (!actualType || !isNumericBindingParameterType(actualType, context)) {
987
+ return undefined;
988
+ }
989
+ const actualArgumentTypes = args.map((arg) => arg
990
+ ? (resolveActualFunctionTypeForArgument(arg, context) ??
991
+ resolveEffectiveExpressionType(arg, context) ??
992
+ arg.inferredType)
993
+ : undefined);
994
+ for (const candidate of calleeType.types) {
995
+ if (candidate.kind !== "functionType" ||
996
+ !candidate.typeParameters ||
997
+ candidate.typeParameters.length === 0) {
998
+ continue;
999
+ }
1000
+ if (candidate.parameters.length !== args.length) {
1001
+ continue;
1002
+ }
1003
+ if (candidate.parameters.some((parameter) => !parameter ||
1004
+ parameter.isRest ||
1005
+ parameter.isOptional ||
1006
+ parameter.initializer !== undefined)) {
1007
+ continue;
1008
+ }
1009
+ const groupedIndices = new Map();
1010
+ for (let index = 0; index < candidate.parameters.length; index += 1) {
1011
+ const parameterType = candidate.parameters[index]?.type;
1012
+ if (parameterType?.kind !== "typeParameterType") {
1013
+ continue;
1014
+ }
1015
+ const existing = groupedIndices.get(parameterType.name) ?? [];
1016
+ existing.push(index);
1017
+ groupedIndices.set(parameterType.name, existing);
1018
+ }
1019
+ for (const indices of groupedIndices.values()) {
1020
+ if (!indices.includes(argIndex) || indices.length < 2) {
1021
+ continue;
1022
+ }
1023
+ const hasBroadObjectPeer = indices.some((index) => index !== argIndex &&
1024
+ isBroadObjectSlotType(actualArgumentTypes[index], context));
1025
+ if (hasBroadObjectPeer) {
1026
+ return broadObjectIrType;
1027
+ }
1028
+ }
1029
+ }
1030
+ return undefined;
1031
+ };
1032
+ const adaptFunctionArgumentAst = (expr, arg, argIndex, argAst, expectedType, context) => {
1033
+ const expectedFunctionType = resolveExpectedFunctionTypeForArgument(expr, argIndex, expectedType, context);
1034
+ const actualFunctionType = resolveActualFunctionTypeForArgument(arg, context);
1035
+ if (!expectedFunctionType ||
1036
+ !actualFunctionType ||
1037
+ !requiresDelegateArityAdaptation(actualFunctionType, expectedFunctionType)) {
1038
+ return [argAst, context];
1039
+ }
1040
+ if (argAst.kind === "lambdaExpression") {
1041
+ return adaptLambdaArgumentAst(argAst, expectedFunctionType, context);
1042
+ }
1043
+ return wrapFunctionValueArgumentAst(argAst, actualFunctionType, expectedFunctionType, context);
1044
+ };
1045
+ const emitFunctionValueCallArguments = (args, signature, expr, context) => {
1046
+ let currentContext = context;
1047
+ const argAsts = [];
1048
+ const parameters = signature.parameters;
1049
+ const runtimeOmittableCallArities = (() => {
1050
+ if (expr.callee.kind === "identifier") {
1051
+ const importBinding = context.importBindings?.get(expr.callee.name);
1052
+ if (importBinding?.kind === "value") {
1053
+ return new Set(importBinding.runtimeOmittableCallArities ?? []);
1054
+ }
1055
+ return undefined;
1056
+ }
1057
+ if (expr.callee.kind === "memberAccess" &&
1058
+ expr.callee.object.kind === "identifier" &&
1059
+ !expr.callee.isComputed &&
1060
+ typeof expr.callee.property === "string") {
1061
+ const importBinding = context.importBindings?.get(expr.callee.object.name);
1062
+ if (importBinding?.kind === "namespace") {
1063
+ return new Set(importBinding.memberCallArities?.get(expr.callee.property) ?? []);
1064
+ }
1065
+ }
1066
+ return undefined;
1067
+ })();
1068
+ const providedArgumentCount = args.length;
1069
+ const runtimeSurfaceParameterTypes = getRuntimeSurfaceParameterTypes(expr, signature.parameters.map((parameter) => parameter?.type));
1070
+ for (let i = 0; i < parameters.length; i++) {
1071
+ const parameter = parameters[i];
1072
+ if (!parameter)
1073
+ continue;
1074
+ if (parameter.isRest) {
1075
+ const tupleRestResult = tryEmitTupleRestArguments(args, i, parameter.type, currentContext);
1076
+ if (tupleRestResult) {
1077
+ const [tupleArgs, tupleContext] = tupleRestResult;
1078
+ argAsts.push(...tupleArgs);
1079
+ currentContext = tupleContext;
1080
+ break;
1081
+ }
1082
+ const spreadArg = args[i];
1083
+ if (args.length === i + 1 && spreadArg && spreadArg.kind === "spread") {
1084
+ const transparentPassthrough = getTransparentRestSpreadPassthroughExpression(spreadArg, parameter.type, currentContext);
1085
+ const passthroughContext = {
1086
+ ...currentContext,
1087
+ localSemanticTypes: undefined,
1088
+ localValueTypes: undefined,
1089
+ };
1090
+ const [spreadAst, spreadCtx] = emitExpressionAst(transparentPassthrough ?? spreadArg.expression, transparentPassthrough ? passthroughContext : currentContext, transparentPassthrough ? undefined : parameter.type);
1091
+ argAsts.push(spreadAst);
1092
+ currentContext = spreadCtx;
1093
+ break;
1094
+ }
1095
+ const restElementType = getArrayLikeElementType(parameter.type, currentContext) ??
1096
+ parameter.type;
1097
+ if (!restElementType) {
1098
+ throw new Error("Internal Compiler Error: function-value rest parameter reached emission without an element type.");
1099
+ }
1100
+ let elementTypeAst = {
1101
+ kind: "predefinedType",
1102
+ keyword: "object",
1103
+ };
1104
+ const [emittedType, typeCtx] = emitTypeAst(restElementType, currentContext);
1105
+ elementTypeAst = emittedType;
1106
+ currentContext = typeCtx;
1107
+ const restArgs = args
1108
+ .slice(i)
1109
+ .filter((arg) => !!arg);
1110
+ if (restArgs.some((arg) => arg.kind === "spread")) {
1111
+ const restArrayType = parameter.type;
1112
+ if (!restArrayType) {
1113
+ throw new Error("Internal Compiler Error: function-value rest parameter reached emission without an array type.");
1114
+ }
1115
+ const [flattenedRestArgs, flattenedContext] = emitFlattenedRestArguments(restArgs, restArrayType, restElementType, currentContext);
1116
+ argAsts.push(...flattenedRestArgs);
1117
+ currentContext = flattenedContext;
1118
+ break;
1119
+ }
1120
+ const restItems = [];
1121
+ for (const arg of restArgs) {
1122
+ const [argAst, argCtx] = emitExpressionAst(arg, currentContext, restElementType);
1123
+ restItems.push(argAst);
1124
+ currentContext = argCtx;
1125
+ }
1126
+ argAsts.push({
1127
+ kind: "arrayCreationExpression",
1128
+ elementType: elementTypeAst,
1129
+ initializer: restItems,
1130
+ });
1131
+ break;
1132
+ }
1133
+ const arg = args[i];
1134
+ if (arg) {
1135
+ const passingMode = expr.argumentPassing?.[i];
1136
+ if (passingMode === "out" && !isLValue(arg)) {
1137
+ const [discardAst, discardCtx] = emitOutDiscardArgument(currentContext);
1138
+ argAsts.push(discardAst);
1139
+ currentContext = discardCtx;
1140
+ continue;
1141
+ }
1142
+ const surfaceParameterType = runtimeSurfaceParameterTypes[i];
1143
+ const selectedParameterType = expr.parameterTypes?.[i] ?? surfaceParameterType ?? parameter?.type;
1144
+ const runtimeParameterType = getAcceptedParameterType(selectedParameterType, !!parameter?.isOptional);
1145
+ const selectedExpectedType = selectedParameterType === undefined
1146
+ ? undefined
1147
+ : resolveCallArgumentExpectedType(expr, arg, i, selectedParameterType, currentContext);
1148
+ const runtimeExpectedType = runtimeParameterType === undefined
1149
+ ? undefined
1150
+ : normalizeCallArgumentExpectedType(runtimeParameterType, arg, currentContext);
1151
+ const preEmitActualArgumentType = resolveActualFunctionTypeForArgument(arg, currentContext) ??
1152
+ resolveEffectiveExpressionType(arg, currentContext) ??
1153
+ arg.inferredType;
1154
+ const preEmitStorageAwareArgumentType = resolvePreEmitStorageAwareArgumentType(arg, preEmitActualArgumentType, currentContext);
1155
+ const contextualExpectedType = resolveContextualCallArgumentExpectedType(arg, selectedExpectedType, runtimeExpectedType, preEmitStorageAwareArgumentType, currentContext);
1156
+ const preserveOptionalSurfaceCarrierPassThrough = shouldPreserveOptionalSurfaceCarrierPassThrough({
1157
+ arg,
1158
+ selectedExpectedType,
1159
+ surfaceExpectedType: surfaceParameterType,
1160
+ context: currentContext,
1161
+ });
1162
+ const explicitNullishSurfaceExpectedType = resolveExplicitNullishSurfaceExpectedType({
1163
+ arg,
1164
+ surfaceExpectedType: surfaceParameterType,
1165
+ });
1166
+ const preservedSurfaceRuntimeType = preserveOptionalSurfaceCarrierPassThrough
1167
+ ? surfaceParameterType
1168
+ : shouldPreserveSurfaceRuntimeExpectedType({
1169
+ selectedExpectedType,
1170
+ surfaceExpectedType: surfaceParameterType,
1171
+ context: currentContext,
1172
+ })
1173
+ ? surfaceParameterType
1174
+ : undefined;
1175
+ const finalExpectedType = explicitNullishSurfaceExpectedType ??
1176
+ preservedSurfaceRuntimeType ??
1177
+ resolveFinalCallArgumentExpectedType(selectedExpectedType, runtimeExpectedType, preEmitStorageAwareArgumentType, currentContext) ??
1178
+ runtimeExpectedType ??
1179
+ contextualExpectedType;
1180
+ const adaptationExpectedType = resolveAdaptationExpectedType(selectedExpectedType, finalExpectedType, surfaceParameterType, currentContext);
1181
+ const selectedSourceMemberNs = resolveSelectedSourceMemberNs(arg, selectedExpectedType, finalExpectedType, surfaceParameterType, currentContext);
1182
+ const rawEmitExpectedTypeCandidate = explicitNullishSurfaceExpectedType ??
1183
+ (shouldPreserveOptionalSurfaceRawEmission({
1184
+ arg,
1185
+ selectedExpectedType,
1186
+ surfaceExpectedType: surfaceParameterType,
1187
+ context: currentContext,
1188
+ })
1189
+ ? surfaceParameterType
1190
+ : shouldUseSurfaceCarrierForRawEmission({
1191
+ arg,
1192
+ adaptationExpectedType,
1193
+ surfaceExpectedType: surfaceParameterType,
1194
+ context: currentContext,
1195
+ })
1196
+ ? surfaceParameterType
1197
+ : resolveCarrierPreservingRawExpectedType({
1198
+ expr: arg,
1199
+ selectedExpectedType,
1200
+ contextualExpectedType,
1201
+ surfaceExpectedType: surfaceParameterType,
1202
+ finalExpectedType: adaptationExpectedType,
1203
+ context: currentContext,
1204
+ }));
1205
+ const rawEmitExpectedType = shouldDeferStructuralObjectArgumentMaterialization({
1206
+ arg,
1207
+ rawExpectedType: rawEmitExpectedTypeCandidate,
1208
+ context: currentContext,
1209
+ })
1210
+ ? undefined
1211
+ : rawEmitExpectedTypeCandidate;
1212
+ const carrierPassThroughArgument = tryEmitCarrierPreservingExpressionAst({
1213
+ expr: arg,
1214
+ expectedType: adaptationExpectedType,
1215
+ context: currentContext,
1216
+ });
1217
+ const concreteArrayLiteralRawExpectedType = arg.kind === "array"
1218
+ ? resolveConcreteArrayLiteralContextType(rawEmitExpectedType ??
1219
+ adaptationExpectedType ??
1220
+ finalExpectedType ??
1221
+ contextualExpectedType ??
1222
+ selectedExpectedType ??
1223
+ surfaceParameterType, currentContext, arg.elements.length === 0)
1224
+ : undefined;
1225
+ const [rawArgAst, rawArgCtx] = carrierPassThroughArgument
1226
+ ? [carrierPassThroughArgument.ast, carrierPassThroughArgument.context]
1227
+ : emitExpressionAst(arg, currentContext, concreteArrayLiteralRawExpectedType ?? rawEmitExpectedType);
1228
+ const carrierPassThroughType = resolveCarrierPassThroughArgumentType(arg, rawArgAst, adaptationExpectedType, rawArgCtx);
1229
+ const directStorageArgumentType = resolveDirectStorageCompatibleExpressionType({
1230
+ expr: arg,
1231
+ valueAst: rawArgAst,
1232
+ context: rawArgCtx,
1233
+ });
1234
+ const exactFinalExpectedArgumentType = resolveExactRawEmittedExpectedType({
1235
+ arg,
1236
+ rawArgAst,
1237
+ rawEmitExpectedType,
1238
+ adaptationExpectedType,
1239
+ context: rawArgCtx,
1240
+ }) ??
1241
+ resolveContextualAdaptedArgumentType(rawArgAst, adaptationExpectedType, rawArgCtx);
1242
+ const contextualAdaptedActualType = resolveContextualAdaptedArgumentType(rawArgAst, contextualExpectedType, rawArgCtx);
1243
+ const postEmitEffectiveArgumentType = resolveEffectiveExpressionType(arg, rawArgCtx);
1244
+ const effectiveArgumentType = postEmitEffectiveArgumentType ?? preEmitActualArgumentType;
1245
+ const actualArgumentType = carrierPassThroughArgument?.actualType ??
1246
+ selectAdaptationActualArgumentType({
1247
+ carrierPassThroughType,
1248
+ exactFinalExpectedArgumentType,
1249
+ directStorageArgumentType,
1250
+ contextualAdaptedActualType,
1251
+ resolvedFunctionArgumentType: resolveActualFunctionTypeForArgument(arg, rawArgCtx),
1252
+ effectiveArgumentType,
1253
+ inferredArgumentType: arg.inferredType,
1254
+ selectedSourceMemberNs,
1255
+ context: rawArgCtx,
1256
+ });
1257
+ const materializationActualArgumentType = selectCollectionMaterializationActualArgumentType({
1258
+ arg,
1259
+ preferredSourceType: preEmitActualArgumentType,
1260
+ selectedActualType: actualArgumentType,
1261
+ expectedType: adaptationExpectedType,
1262
+ context: rawArgCtx,
1263
+ });
1264
+ const [materializedArgAst, materializedArgCtx] = carrierPassThroughArgument ||
1265
+ carrierPassThroughType ||
1266
+ exactFinalExpectedArgumentType
1267
+ ? [rawArgAst, rawArgCtx]
1268
+ : (adaptValueToExpectedTypeAst({
1269
+ valueAst: rawArgAst,
1270
+ actualType: materializationActualArgumentType,
1271
+ context: rawArgCtx,
1272
+ expectedType: adaptationExpectedType,
1273
+ selectedSourceMemberNs,
1274
+ }) ?? [rawArgAst, rawArgCtx]);
1275
+ const numericActualArgumentType = selectPostMaterializationNumericCastArgumentType({
1276
+ rawArgAst,
1277
+ materializedArgAst,
1278
+ carrierPassThroughArgumentType: carrierPassThroughArgument?.actualType,
1279
+ carrierPassThroughType,
1280
+ exactFinalExpectedArgumentType,
1281
+ adaptationExpectedType,
1282
+ fallbackCandidates: [
1283
+ actualArgumentType,
1284
+ materializationActualArgumentType,
1285
+ preEmitStorageAwareArgumentType,
1286
+ effectiveArgumentType,
1287
+ preEmitActualArgumentType,
1288
+ arg.inferredType,
1289
+ ],
1290
+ context: materializedArgCtx,
1291
+ });
1292
+ const numericExpectedArgumentType = selectNumericCastExpectedType([
1293
+ finalExpectedType,
1294
+ adaptationExpectedType,
1295
+ contextualExpectedType,
1296
+ selectedExpectedType,
1297
+ ], materializedArgCtx, numericActualArgumentType);
1298
+ const [numericMaterializedArgAst, numericMaterializedArgCtx] = maybeCastNumericToExpectedIntegralAst(materializedArgAst, numericActualArgumentType, materializedArgCtx, numericExpectedArgumentType);
1299
+ const [jsNumberMaterializedArgAst, jsNumberMaterializedArgCtx] = maybeCastNumericToExpectedJsNumberAst(numericMaterializedArgAst, numericActualArgumentType, numericMaterializedArgCtx, numericExpectedArgumentType);
1300
+ const [argAst, argCtx] = adaptFunctionArgumentAst(expr, arg, i, jsNumberMaterializedArgAst, finalExpectedType, jsNumberMaterializedArgCtx);
1301
+ const modifier = passingMode && passingMode !== "value" && isLValue(arg)
1302
+ ? passingMode
1303
+ : undefined;
1304
+ argAsts.push(wrapArgModifier(modifier, argAst));
1305
+ currentContext = argCtx;
1306
+ continue;
1307
+ }
1308
+ if (runtimeOmittableCallArities?.has(providedArgumentCount)) {
1309
+ return [argAsts, currentContext];
1310
+ }
1311
+ if (parameter.initializer) {
1312
+ const [defaultAst, defaultCtx] = emitExpressionAst(parameter.initializer, currentContext, parameter.type);
1313
+ argAsts.push(defaultAst);
1314
+ currentContext = defaultCtx;
1315
+ continue;
1316
+ }
1317
+ if (parameter.isOptional) {
1318
+ let defaultType;
1319
+ if (parameter.type) {
1320
+ const [emittedType, typeCtx] = emitTypeAst(parameter.type, currentContext);
1321
+ currentContext = typeCtx;
1322
+ defaultType = parameter.isOptional
1323
+ ? emittedType.kind === "nullableType"
1324
+ ? emittedType
1325
+ : { kind: "nullableType", underlyingType: emittedType }
1326
+ : emittedType;
1327
+ }
1328
+ argAsts.push({ kind: "defaultExpression", type: defaultType });
1329
+ }
1330
+ }
1331
+ return [argAsts, currentContext];
1332
+ };
1333
+ const extractTupleRestCandidates = (type) => {
1334
+ if (!type)
1335
+ return undefined;
1336
+ if (type.kind === "tupleType") {
1337
+ return [type.elementTypes];
1338
+ }
1339
+ if (type.kind !== "unionType") {
1340
+ return undefined;
1341
+ }
1342
+ const candidates = [];
1343
+ for (const member of type.types) {
1344
+ if (!member || member.kind !== "tupleType") {
1345
+ return undefined;
1346
+ }
1347
+ candidates.push(member.elementTypes);
1348
+ }
1349
+ return candidates;
1350
+ };
1351
+ const tryEmitTupleRestArguments = (args, startIndex, parameterType, context) => {
1352
+ const remainingArgs = args.slice(startIndex);
1353
+ if (remainingArgs.some((arg) => arg?.kind === "spread")) {
1354
+ return undefined;
1355
+ }
1356
+ const tupleCandidates = extractTupleRestCandidates(parameterType);
1357
+ if (!tupleCandidates || tupleCandidates.length === 0) {
1358
+ return undefined;
1359
+ }
1360
+ const matchingCandidates = tupleCandidates.filter((candidate) => candidate.length === remainingArgs.length);
1361
+ if (matchingCandidates.length !== 1) {
1362
+ return undefined;
1363
+ }
1364
+ const tupleElements = matchingCandidates[0] ?? [];
1365
+ const emittedArgs = [];
1366
+ let tupleContext = context;
1367
+ for (let index = 0; index < remainingArgs.length; index++) {
1368
+ const arg = remainingArgs[index];
1369
+ const expectedType = tupleElements[index];
1370
+ if (!arg || arg.kind === "spread")
1371
+ continue;
1372
+ const [argAst, argContext] = emitExpressionAst(arg, tupleContext, expectedType);
1373
+ emittedArgs.push(argAst);
1374
+ tupleContext = argContext;
1375
+ }
1376
+ return [emittedArgs, tupleContext];
1377
+ };
1378
+ const selectDeterministicUnionParameterMember = (expectedType, arg, context) => {
1379
+ if (!expectedType) {
1380
+ return expectedType;
1381
+ }
1382
+ const resolvedExpected = resolveTypeAlias(stripNullish(expectedType), context);
1383
+ if (resolvedExpected.kind !== "unionType") {
1384
+ return expectedType;
1385
+ }
1386
+ const actualType = (arg.kind === "identifier"
1387
+ ? context.localValueTypes?.get(arg.name)
1388
+ : undefined) ??
1389
+ resolveEffectiveExpressionType(arg, context) ??
1390
+ arg.inferredType;
1391
+ if (!actualType) {
1392
+ return expectedType;
1393
+ }
1394
+ const expectedNullishSplit = splitRuntimeNullishUnionMembers(expectedType);
1395
+ const actualIsExplicitRuntimeNullish = actualType.kind === "primitiveType" &&
1396
+ (actualType.name === "undefined" || actualType.name === "null");
1397
+ if (expectedNullishSplit?.hasRuntimeNullish &&
1398
+ actualIsExplicitRuntimeNullish &&
1399
+ expectedNullishSplit.nonNullishMembers.length > 0) {
1400
+ return expectedType;
1401
+ }
1402
+ const resolvedComparableActual = resolveComparableType(actualType, context);
1403
+ if (arg.kind === "array") {
1404
+ if (arg.elements.length === 0) {
1405
+ const emptyArrayMember = resolveConcreteArrayLiteralContextType(expectedType, context, true);
1406
+ if (emptyArrayMember) {
1407
+ return emptyArrayMember;
1408
+ }
1409
+ }
1410
+ const arrayLiteralMembers = resolvedExpected.types.filter((member) => unionMemberAcceptsArrayLiteral(member, context));
1411
+ const concreteArrayLiteralMembers = arrayLiteralMembers.filter((member) => !!resolveConcreteArrayLiteralContextType(member, context));
1412
+ if (concreteArrayLiteralMembers.length === 1) {
1413
+ return concreteArrayLiteralMembers[0];
1414
+ }
1415
+ if (arrayLiteralMembers.length === 1) {
1416
+ return arrayLiteralMembers[0];
1417
+ }
1418
+ }
1419
+ if (resolvedComparableActual.kind === "unionType") {
1420
+ return expectedType;
1421
+ }
1422
+ const matchingMembers = resolvedExpected.types.filter((member) => {
1423
+ return areIrTypesEquivalent(resolvedComparableActual, resolveComparableType(member, context), context);
1424
+ });
1425
+ if (matchingMembers.length === 1) {
1426
+ return matchingMembers[0];
1427
+ }
1428
+ const emissionMatchingMembers = resolvedExpected.types.filter((member) => matchesExpectedEmissionType(actualType, member, context));
1429
+ if (emissionMatchingMembers.length === 1) {
1430
+ return emissionMatchingMembers[0];
1431
+ }
1432
+ return expectedType;
1433
+ };
1434
+ const resolveCallArgumentExpectedType = (expr, arg, argIndex, parameterType, context) => {
1435
+ const expectedType = normalizeCallArgumentExpectedType(parameterType, arg, context);
1436
+ const bindingExpectedType = (() => {
1437
+ const candidate = findMemberBindingExpectedType(expr, argIndex, context);
1438
+ return candidate
1439
+ ? normalizeCallArgumentExpectedType(candidate, arg, context)
1440
+ : undefined;
1441
+ })();
1442
+ const prefersBindingNumericType = (() => {
1443
+ if (!expectedType || !bindingExpectedType) {
1444
+ return false;
1445
+ }
1446
+ const resolvedExpected = resolveTypeAlias(stripNullish(expectedType), context);
1447
+ const resolvedBinding = resolveTypeAlias(stripNullish(bindingExpectedType), context);
1448
+ const isBroadNumber = resolvedExpected.kind === "primitiveType" &&
1449
+ resolvedExpected.name === "number";
1450
+ if (!isBroadNumber) {
1451
+ return false;
1452
+ }
1453
+ if (resolvedBinding.kind === "primitiveType") {
1454
+ return resolvedBinding.name === "int";
1455
+ }
1456
+ if (resolvedBinding.kind !== "referenceType") {
1457
+ return false;
1458
+ }
1459
+ return (resolvedBinding.name === "sbyte" ||
1460
+ resolvedBinding.name === "byte" ||
1461
+ resolvedBinding.name === "short" ||
1462
+ resolvedBinding.name === "ushort" ||
1463
+ resolvedBinding.name === "int" ||
1464
+ resolvedBinding.name === "uint" ||
1465
+ resolvedBinding.name === "long" ||
1466
+ resolvedBinding.name === "ulong" ||
1467
+ resolvedBinding.name === "SByte" ||
1468
+ resolvedBinding.name === "Byte" ||
1469
+ resolvedBinding.name === "Int16" ||
1470
+ resolvedBinding.name === "UInt16" ||
1471
+ resolvedBinding.name === "Int32" ||
1472
+ resolvedBinding.name === "UInt32" ||
1473
+ resolvedBinding.name === "Int64" ||
1474
+ resolvedBinding.name === "UInt64");
1475
+ })();
1476
+ const narrowedExpectedType = !expectedType || prefersBindingNumericType
1477
+ ? (bindingExpectedType ?? expectedType)
1478
+ : expectedType;
1479
+ return selectDeterministicUnionParameterMember(narrowedExpectedType, arg, context);
1480
+ };
1481
+ const preservesSurfaceRuntimeMaterialization = (surfaceExpectedType, runtimeExpectedType, context) => {
1482
+ if (!surfaceExpectedType || !runtimeExpectedType) {
1483
+ return true;
1484
+ }
1485
+ const surfaceHasRuntimeNullish = splitRuntimeNullishUnionMembers(surfaceExpectedType)?.hasRuntimeNullish ??
1486
+ false;
1487
+ const runtimeHasRuntimeNullish = splitRuntimeNullishUnionMembers(runtimeExpectedType)?.hasRuntimeNullish ??
1488
+ false;
1489
+ if ((surfaceHasRuntimeNullish ||
1490
+ willCarryAsRuntimeUnion(surfaceExpectedType, context)) &&
1491
+ !areIrTypesEquivalent(surfaceExpectedType, runtimeExpectedType, context)) {
1492
+ return false;
1493
+ }
1494
+ if (runtimeHasRuntimeNullish && !surfaceHasRuntimeNullish) {
1495
+ return false;
1496
+ }
1497
+ return areIrTypesEquivalent(resolveRuntimeMaterializationTargetType(surfaceExpectedType, context), resolveRuntimeMaterializationTargetType(runtimeExpectedType, context), context);
1498
+ };
1499
+ /**
1500
+ * Emit call arguments as typed AST array.
1501
+ * Handles spread arrays, castModifier (ref/out from cast), and argumentPassing modes.
1502
+ */
1503
+ const emitCallArguments = (args, expr, context, parameterTypeOverrides) => {
1504
+ const functionValueSignature = getFunctionValueSignature(expr, context);
1505
+ const identifierImportBinding = expr.callee.kind === "identifier"
1506
+ ? context.importBindings?.get(expr.callee.name)
1507
+ : undefined;
1508
+ const memberObjectImportBinding = expr.callee.kind === "memberAccess" &&
1509
+ expr.callee.object.kind === "identifier"
1510
+ ? context.importBindings?.get(expr.callee.object.name)
1511
+ : undefined;
1512
+ const importedFunctionValueTarget = functionValueSignature &&
1513
+ ((expr.callee.kind === "identifier" &&
1514
+ identifierImportBinding?.kind === "value" &&
1515
+ (identifierImportBinding.valueKind === "variable" ||
1516
+ identifierImportBinding.moduleObject === true)) ||
1517
+ (expr.callee.kind === "memberAccess" &&
1518
+ !expr.callee.isComputed &&
1519
+ typeof expr.callee.property === "string" &&
1520
+ ((memberObjectImportBinding?.kind === "namespace" &&
1521
+ (memberObjectImportBinding.memberKinds?.get(expr.callee.property) ===
1522
+ "variable" ||
1523
+ memberObjectImportBinding.moduleObject === true)) ||
1524
+ (memberObjectImportBinding?.kind === "value" &&
1525
+ (memberObjectImportBinding.valueKind === "variable" ||
1526
+ memberObjectImportBinding.moduleObject === true)))));
1527
+ const directCallableTarget = (expr.callee.kind === "identifier" &&
1528
+ (context.importBindings?.get(expr.callee.name)?.kind === "value" ||
1529
+ context.valueSymbols?.get(expr.callee.name)?.kind === "function")) ||
1530
+ (expr.callee.kind === "memberAccess" &&
1531
+ !expr.callee.isComputed &&
1532
+ typeof expr.callee.property === "string");
1533
+ const localFunctionValueTarget = expr.callee.kind === "identifier" &&
1534
+ ((context.localSemanticTypes?.has(expr.callee.name) ?? false) ||
1535
+ (context.localValueTypes?.has(expr.callee.name) ?? false));
1536
+ const functionValueHasAuthoredCallSemantics = functionValueSignature?.parameters.some((parameter) => parameter?.isRest ||
1537
+ parameter?.isOptional ||
1538
+ parameter?.initializer !== undefined) ?? false;
1539
+ const valueSymbolSignature = expr.callee.kind === "identifier"
1540
+ ? context.valueSymbols?.get(expr.callee.name)?.type
1541
+ : undefined;
1542
+ if (functionValueSignature &&
1543
+ functionValueHasAuthoredCallSemantics &&
1544
+ (localFunctionValueTarget ||
1545
+ !directCallableTarget ||
1546
+ importedFunctionValueTarget)) {
1547
+ return emitFunctionValueCallArguments(args, functionValueSignature, expr, context);
1548
+ }
1549
+ const selectedParameterTypes = parameterTypeOverrides && parameterTypeOverrides.length > 0
1550
+ ? parameterTypeOverrides
1551
+ : expr.parameterTypes && expr.parameterTypes.length > 0
1552
+ ? expr.parameterTypes
1553
+ : expr.surfaceParameterTypes && expr.surfaceParameterTypes.length > 0
1554
+ ? expr.surfaceParameterTypes
1555
+ : ((functionValueSignature?.parameters ??
1556
+ valueSymbolSignature?.parameters)?.map((parameter) => parameter?.type) ?? []);
1557
+ const runtimeSurfaceParameterTypes = parameterTypeOverrides && parameterTypeOverrides.length > 0
1558
+ ? parameterTypeOverrides
1559
+ : getRuntimeSurfaceParameterTypes(expr, selectedParameterTypes);
1560
+ const runtimeParameterTypes = parameterTypeOverrides && parameterTypeOverrides.length > 0
1561
+ ? parameterTypeOverrides
1562
+ : selectedParameterTypes.map((parameterType, index) => runtimeSurfaceParameterTypes[index] ?? parameterType);
1563
+ const selectedRestParameter = expr.surfaceRestParameter ?? expr.restParameter;
1564
+ const runtimeRestParameter = getRuntimeRestParameter(expr);
1565
+ const transparentRestPassthroughExpression = runtimeRestParameter?.arrayType &&
1566
+ args.length === (runtimeRestParameter.index ?? 0) + 1
1567
+ ? getTransparentRestSpreadPassthroughExpression(args[runtimeRestParameter.index], runtimeRestParameter.arrayType, context)
1568
+ : undefined;
1569
+ const normalizedArgs = transparentRestPassthroughExpression
1570
+ ? args.map((arg, index) => index === runtimeRestParameter?.index && arg?.kind === "spread"
1571
+ ? {
1572
+ kind: "spread",
1573
+ expression: transparentRestPassthroughExpression,
1574
+ inferredType: transparentRestPassthroughExpression.inferredType,
1575
+ }
1576
+ : arg)
1577
+ : expandTupleLikeSpreadArguments(args);
1578
+ const restInfo = runtimeRestParameter?.arrayType &&
1579
+ runtimeRestParameter.elementType &&
1580
+ normalizedArgs
1581
+ .slice(runtimeRestParameter.index)
1582
+ .some((candidate) => candidate?.kind === "spread")
1583
+ ? {
1584
+ index: runtimeRestParameter.index,
1585
+ arrayType: runtimeRestParameter.arrayType,
1586
+ elementType: runtimeRestParameter.elementType,
1587
+ }
1588
+ : undefined;
1589
+ let currentContext = context;
1590
+ const argAsts = [];
1591
+ if (runtimeRestParameter) {
1592
+ const tupleRestResult = tryEmitTupleRestArguments(normalizedArgs, runtimeRestParameter.index, runtimeRestParameter.arrayType, currentContext);
1593
+ if (tupleRestResult) {
1594
+ const [tupleArgs, tupleContext] = tupleRestResult;
1595
+ argAsts.push(...tupleArgs);
1596
+ return [argAsts, tupleContext];
1597
+ }
1598
+ }
1599
+ for (let i = 0; i < normalizedArgs.length; i++) {
1600
+ const arg = normalizedArgs[i];
1601
+ if (!arg)
1602
+ continue;
1603
+ if (restInfo &&
1604
+ i === restInfo.index &&
1605
+ normalizedArgs
1606
+ .slice(restInfo.index)
1607
+ .some((candidate) => candidate?.kind === "spread")) {
1608
+ const [flattenedRestArgs, flattenedContext] = emitFlattenedRestArguments(normalizedArgs.slice(restInfo.index), restInfo.arrayType, restInfo.elementType, currentContext);
1609
+ argAsts.push(...flattenedRestArgs);
1610
+ currentContext = flattenedContext;
1611
+ break;
1612
+ }
1613
+ const selectedRestElementType = selectedRestParameter && i >= selectedRestParameter.index
1614
+ ? selectedRestParameter.elementType
1615
+ : undefined;
1616
+ const expectedType = selectedRestElementType ??
1617
+ (restInfo && i >= restInfo.index
1618
+ ? restInfo.elementType
1619
+ : resolveCallArgumentExpectedType(expr, arg, i, selectedParameterTypes[i], currentContext));
1620
+ const runtimeRestElementType = runtimeRestParameter && i >= runtimeRestParameter.index
1621
+ ? runtimeRestParameter.elementType
1622
+ : undefined;
1623
+ const runtimeParameterType = runtimeRestElementType ?? runtimeParameterTypes[i];
1624
+ const genericBroadObjectFallbackType = resolveGenericBroadObjectFallbackExpectedType(expr, normalizedArgs, i, currentContext);
1625
+ const normalizedRuntime = runtimeParameterType === undefined
1626
+ ? undefined
1627
+ : normalizeCallArgumentExpectedType(runtimeParameterType, arg, currentContext);
1628
+ const preEmitActualArgumentType = resolveActualFunctionTypeForArgument(arg, currentContext) ??
1629
+ resolveEffectiveExpressionType(arg, currentContext) ??
1630
+ arg.inferredType;
1631
+ const preEmitStorageAwareArgumentType = resolvePreEmitStorageAwareArgumentType(arg, preEmitActualArgumentType, currentContext);
1632
+ const surfaceParameterType = runtimeSurfaceParameterTypes[i];
1633
+ const contextualExpectedType = genericBroadObjectFallbackType ??
1634
+ resolveContextualCallArgumentExpectedType(arg, expectedType, normalizedRuntime, preEmitStorageAwareArgumentType, currentContext);
1635
+ const preserveOptionalSurfaceCarrierPassThrough = shouldPreserveOptionalSurfaceCarrierPassThrough({
1636
+ arg,
1637
+ selectedExpectedType: expectedType,
1638
+ surfaceExpectedType: surfaceParameterType,
1639
+ context: currentContext,
1640
+ });
1641
+ const explicitNullishSurfaceExpectedType = resolveExplicitNullishSurfaceExpectedType({
1642
+ arg,
1643
+ surfaceExpectedType: surfaceParameterType,
1644
+ });
1645
+ const preservedSurfaceRuntimeType = preserveOptionalSurfaceCarrierPassThrough
1646
+ ? surfaceParameterType
1647
+ : shouldPreserveSurfaceRuntimeExpectedType({
1648
+ selectedExpectedType: expectedType,
1649
+ surfaceExpectedType: surfaceParameterType,
1650
+ context: currentContext,
1651
+ })
1652
+ ? surfaceParameterType
1653
+ : undefined;
1654
+ const finalExpectedType = explicitNullishSurfaceExpectedType ??
1655
+ genericBroadObjectFallbackType ??
1656
+ preservedSurfaceRuntimeType ??
1657
+ resolveFinalCallArgumentExpectedType(expectedType, normalizedRuntime, preEmitStorageAwareArgumentType, currentContext) ??
1658
+ contextualExpectedType;
1659
+ const adaptationExpectedType = resolveAdaptationExpectedType(expectedType, finalExpectedType, surfaceParameterType, currentContext);
1660
+ const selectedSourceMemberNs = resolveSurfaceSelectedSourceMemberNs(expectedType, finalExpectedType, surfaceParameterType, currentContext);
1661
+ const rawEmitExpectedTypeCandidate = explicitNullishSurfaceExpectedType ??
1662
+ (shouldPreserveOptionalSurfaceRawEmission({
1663
+ arg,
1664
+ selectedExpectedType: expectedType,
1665
+ surfaceExpectedType: surfaceParameterType,
1666
+ context: currentContext,
1667
+ })
1668
+ ? surfaceParameterType
1669
+ : shouldUseSurfaceCarrierForRawEmission({
1670
+ arg,
1671
+ adaptationExpectedType,
1672
+ surfaceExpectedType: surfaceParameterType,
1673
+ context: currentContext,
1674
+ })
1675
+ ? surfaceParameterType
1676
+ : resolveCarrierPreservingRawExpectedType({
1677
+ expr: arg,
1678
+ selectedExpectedType: expectedType,
1679
+ contextualExpectedType,
1680
+ surfaceExpectedType: surfaceParameterType,
1681
+ finalExpectedType: adaptationExpectedType,
1682
+ context: currentContext,
1683
+ }));
1684
+ const rawEmitExpectedType = shouldDeferStructuralObjectArgumentMaterialization({
1685
+ arg,
1686
+ rawExpectedType: rawEmitExpectedTypeCandidate,
1687
+ context: currentContext,
1688
+ })
1689
+ ? undefined
1690
+ : rawEmitExpectedTypeCandidate;
1691
+ if (arg.kind === "spread") {
1692
+ const [spreadAst, ctx] = emitExpressionAst(arg.expression, currentContext);
1693
+ argAsts.push(spreadAst);
1694
+ currentContext = ctx;
1695
+ }
1696
+ else {
1697
+ const castModifier = getPassingModifierFromCast(arg);
1698
+ if (castModifier === "out" && !isLValue(arg)) {
1699
+ const [discardAst, discardCtx] = emitOutDiscardArgument(currentContext);
1700
+ argAsts.push(discardAst);
1701
+ currentContext = discardCtx;
1702
+ continue;
1703
+ }
1704
+ if (castModifier && isLValue(arg)) {
1705
+ const [argAst, ctx] = emitExpressionAst(arg, currentContext);
1706
+ argAsts.push(wrapArgModifier(castModifier, argAst));
1707
+ currentContext = ctx;
1708
+ }
1709
+ else {
1710
+ const passingMode = expr.argumentPassing?.[i];
1711
+ if (passingMode === "out" && !isLValue(arg)) {
1712
+ const [discardAst, discardCtx] = emitOutDiscardArgument(currentContext);
1713
+ argAsts.push(discardAst);
1714
+ currentContext = discardCtx;
1715
+ continue;
1716
+ }
1717
+ const preEmitEffectiveArgumentType = resolveEffectiveExpressionType(arg, currentContext) ??
1718
+ arg.inferredType;
1719
+ const carrierPassThroughArgument = tryEmitCarrierPreservingExpressionAst({
1720
+ expr: arg,
1721
+ expectedType: adaptationExpectedType,
1722
+ context: currentContext,
1723
+ });
1724
+ const concreteArrayLiteralRawExpectedType = arg.kind === "array"
1725
+ ? resolveConcreteArrayLiteralContextType(rawEmitExpectedType ??
1726
+ adaptationExpectedType ??
1727
+ finalExpectedType ??
1728
+ contextualExpectedType ??
1729
+ expectedType ??
1730
+ surfaceParameterType, currentContext, arg.elements.length === 0)
1731
+ : undefined;
1732
+ const [rawArgAst, emittedContext] = carrierPassThroughArgument
1733
+ ? [carrierPassThroughArgument.ast, carrierPassThroughArgument.context]
1734
+ : emitExpressionAst(arg, currentContext, concreteArrayLiteralRawExpectedType ?? rawEmitExpectedType);
1735
+ const carrierPassThroughType = resolveCarrierPassThroughArgumentType(arg, rawArgAst, adaptationExpectedType, emittedContext);
1736
+ const directStorageArgumentType = resolveDirectStorageCompatibleExpressionType({
1737
+ expr: arg,
1738
+ valueAst: rawArgAst,
1739
+ context: emittedContext,
1740
+ });
1741
+ const exactFinalExpectedArgumentType = resolveExactRawEmittedExpectedType({
1742
+ arg,
1743
+ rawArgAst,
1744
+ rawEmitExpectedType,
1745
+ adaptationExpectedType,
1746
+ context: emittedContext,
1747
+ }) ??
1748
+ resolveContextualAdaptedArgumentType(rawArgAst, adaptationExpectedType, emittedContext);
1749
+ const contextualAdaptedActualType = resolveContextualAdaptedArgumentType(rawArgAst, contextualExpectedType, emittedContext);
1750
+ const postEmitEffectiveArgumentType = resolveEffectiveExpressionType(arg, emittedContext);
1751
+ const effectiveArgumentType = postEmitEffectiveArgumentType ?? preEmitEffectiveArgumentType;
1752
+ const actualArgumentType = carrierPassThroughArgument?.actualType ??
1753
+ selectAdaptationActualArgumentType({
1754
+ carrierPassThroughType,
1755
+ exactFinalExpectedArgumentType,
1756
+ directStorageArgumentType,
1757
+ contextualAdaptedActualType,
1758
+ resolvedFunctionArgumentType: resolveActualFunctionTypeForArgument(arg, emittedContext),
1759
+ effectiveArgumentType,
1760
+ inferredArgumentType: arg.inferredType,
1761
+ context: emittedContext,
1762
+ });
1763
+ const materializationActualArgumentType = selectCollectionMaterializationActualArgumentType({
1764
+ arg,
1765
+ preferredSourceType: preEmitEffectiveArgumentType,
1766
+ selectedActualType: actualArgumentType,
1767
+ expectedType: adaptationExpectedType,
1768
+ context: emittedContext,
1769
+ });
1770
+ const [materializedArgAst, materializedContext] = carrierPassThroughArgument ||
1771
+ carrierPassThroughType ||
1772
+ exactFinalExpectedArgumentType
1773
+ ? [rawArgAst, emittedContext]
1774
+ : (adaptValueToExpectedTypeAst({
1775
+ valueAst: rawArgAst,
1776
+ actualType: materializationActualArgumentType,
1777
+ context: emittedContext,
1778
+ expectedType: adaptationExpectedType,
1779
+ selectedSourceMemberNs,
1780
+ }) ?? [rawArgAst, emittedContext]);
1781
+ const numericActualArgumentType = selectPostMaterializationNumericCastArgumentType({
1782
+ rawArgAst,
1783
+ materializedArgAst,
1784
+ carrierPassThroughArgumentType: carrierPassThroughArgument?.actualType,
1785
+ carrierPassThroughType,
1786
+ exactFinalExpectedArgumentType,
1787
+ adaptationExpectedType,
1788
+ fallbackCandidates: [
1789
+ actualArgumentType,
1790
+ materializationActualArgumentType,
1791
+ preEmitStorageAwareArgumentType,
1792
+ effectiveArgumentType,
1793
+ preEmitEffectiveArgumentType,
1794
+ arg.inferredType,
1795
+ ],
1796
+ context: materializedContext,
1797
+ });
1798
+ const numericExpectedArgumentType = selectNumericCastExpectedType([
1799
+ finalExpectedType,
1800
+ adaptationExpectedType,
1801
+ contextualExpectedType,
1802
+ expectedType,
1803
+ ], materializedContext, numericActualArgumentType);
1804
+ const [numericMaterializedArgAst, numericMaterializedContext] = maybeCastNumericToExpectedIntegralAst(materializedArgAst, numericActualArgumentType, materializedContext, numericExpectedArgumentType);
1805
+ const [jsNumberMaterializedArgAst, jsNumberMaterializedContext] = maybeCastNumericToExpectedJsNumberAst(numericMaterializedArgAst, numericActualArgumentType, numericMaterializedContext, numericExpectedArgumentType);
1806
+ const [adaptedArgAst, ctx] = adaptFunctionArgumentAst(expr, arg, i, jsNumberMaterializedArgAst, finalExpectedType, jsNumberMaterializedContext);
1807
+ const modifier = passingMode && passingMode !== "value" && isLValue(arg)
1808
+ ? passingMode
1809
+ : undefined;
1810
+ argAsts.push(wrapArgModifier(modifier, adaptedArgAst));
1811
+ currentContext = ctx;
1812
+ }
1813
+ }
1814
+ }
1815
+ return [argAsts, currentContext];
1816
+ };
1817
+ export { emitCallArguments };
1818
+ //# sourceMappingURL=call-arguments-emit.js.map