@tsonic/emitter 0.0.73 → 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.
- package/dist/.tsbuildinfo +1 -1
- package/dist/adapter-generator.d.ts.map +1 -1
- package/dist/adapter-generator.js +2 -1
- package/dist/adapter-generator.js.map +1 -1
- package/dist/array.test.js +277 -6
- package/dist/array.test.js.map +1 -1
- package/dist/constants.d.ts +3 -2
- package/dist/constants.d.ts.map +1 -1
- package/dist/constants.js +15 -6
- package/dist/constants.js.map +1 -1
- package/dist/core/format/attributes.d.ts +3 -3
- package/dist/core/format/attributes.d.ts.map +1 -1
- package/dist/core/format/attributes.js +8 -59
- package/dist/core/format/attributes.js.map +1 -1
- package/dist/core/format/attributes.test.js +1 -1
- package/dist/core/format/attributes.test.js.map +1 -1
- package/dist/core/format/backend-ast/builders.d.ts +14 -0
- package/dist/core/format/backend-ast/builders.d.ts.map +1 -0
- package/dist/core/format/backend-ast/builders.js +191 -0
- package/dist/core/format/backend-ast/builders.js.map +1 -0
- package/dist/core/format/backend-ast/builders.test.d.ts +2 -0
- package/dist/core/format/backend-ast/builders.test.d.ts.map +1 -0
- package/dist/core/format/backend-ast/builders.test.js +258 -0
- package/dist/core/format/backend-ast/builders.test.js.map +1 -0
- package/dist/core/format/backend-ast/index.d.ts +3 -2
- package/dist/core/format/backend-ast/index.d.ts.map +1 -1
- package/dist/core/format/backend-ast/index.js +2 -1
- package/dist/core/format/backend-ast/index.js.map +1 -1
- package/dist/core/format/backend-ast/invariants.test.d.ts +2 -0
- package/dist/core/format/backend-ast/invariants.test.d.ts.map +1 -0
- package/dist/core/format/backend-ast/invariants.test.js +79 -0
- package/dist/core/format/backend-ast/invariants.test.js.map +1 -0
- package/dist/core/format/backend-ast/printer-cases/basic-and-declarations.test.d.ts +2 -0
- package/dist/core/format/backend-ast/printer-cases/basic-and-declarations.test.d.ts.map +1 -0
- package/dist/core/format/backend-ast/printer-cases/basic-and-declarations.test.js +226 -0
- package/dist/core/format/backend-ast/printer-cases/basic-and-declarations.test.js.map +1 -0
- package/dist/core/format/backend-ast/printer-cases/control-flow-and-switch.test.d.ts +2 -0
- package/dist/core/format/backend-ast/printer-cases/control-flow-and-switch.test.d.ts.map +1 -0
- package/dist/core/format/backend-ast/printer-cases/control-flow-and-switch.test.js +289 -0
- package/dist/core/format/backend-ast/printer-cases/control-flow-and-switch.test.js.map +1 -0
- package/dist/core/format/backend-ast/printer-cases/helpers.d.ts +6 -0
- package/dist/core/format/backend-ast/printer-cases/helpers.d.ts.map +1 -0
- package/dist/core/format/backend-ast/printer-cases/helpers.js +5 -0
- package/dist/core/format/backend-ast/printer-cases/helpers.js.map +1 -0
- package/dist/core/format/backend-ast/printer-cases/identifiers-and-interpolation.test.d.ts +2 -0
- package/dist/core/format/backend-ast/printer-cases/identifiers-and-interpolation.test.d.ts.map +1 -0
- package/dist/core/format/backend-ast/printer-cases/identifiers-and-interpolation.test.js +211 -0
- package/dist/core/format/backend-ast/printer-cases/identifiers-and-interpolation.test.js.map +1 -0
- package/dist/core/format/backend-ast/printer-cases/remaining-nodes.test.d.ts +2 -0
- package/dist/core/format/backend-ast/printer-cases/remaining-nodes.test.d.ts.map +1 -0
- package/dist/core/format/backend-ast/printer-cases/remaining-nodes.test.js +186 -0
- package/dist/core/format/backend-ast/printer-cases/remaining-nodes.test.js.map +1 -0
- package/dist/core/format/backend-ast/printer-colon-detection.d.ts +14 -0
- package/dist/core/format/backend-ast/printer-colon-detection.d.ts.map +1 -0
- package/dist/core/format/backend-ast/printer-colon-detection.js +141 -0
- package/dist/core/format/backend-ast/printer-colon-detection.js.map +1 -0
- package/dist/core/format/backend-ast/printer-declarations.d.ts +12 -0
- package/dist/core/format/backend-ast/printer-declarations.d.ts.map +1 -0
- package/dist/core/format/backend-ast/printer-declarations.js +212 -0
- package/dist/core/format/backend-ast/printer-declarations.js.map +1 -0
- package/dist/core/format/backend-ast/printer-expressions.d.ts +12 -0
- package/dist/core/format/backend-ast/printer-expressions.d.ts.map +1 -0
- package/dist/core/format/backend-ast/printer-expressions.js +363 -0
- package/dist/core/format/backend-ast/printer-expressions.js.map +1 -0
- package/dist/core/format/backend-ast/printer-identifiers.d.ts +31 -0
- package/dist/core/format/backend-ast/printer-identifiers.d.ts.map +1 -0
- package/dist/core/format/backend-ast/printer-identifiers.js +194 -0
- package/dist/core/format/backend-ast/printer-identifiers.js.map +1 -0
- package/dist/core/format/backend-ast/printer-precedence.d.ts +23 -0
- package/dist/core/format/backend-ast/printer-precedence.d.ts.map +1 -0
- package/dist/core/format/backend-ast/printer-precedence.js +225 -0
- package/dist/core/format/backend-ast/printer-precedence.js.map +1 -0
- package/dist/core/format/backend-ast/printer-shared.d.ts +12 -0
- package/dist/core/format/backend-ast/printer-shared.d.ts.map +1 -0
- package/dist/core/format/backend-ast/printer-shared.js +12 -0
- package/dist/core/format/backend-ast/printer-shared.js.map +1 -0
- package/dist/core/format/backend-ast/printer-statements.d.ts +24 -0
- package/dist/core/format/backend-ast/printer-statements.d.ts.map +1 -0
- package/dist/core/format/backend-ast/printer-statements.js +336 -0
- package/dist/core/format/backend-ast/printer-statements.js.map +1 -0
- package/dist/core/format/backend-ast/printer.d.ts +10 -23
- package/dist/core/format/backend-ast/printer.d.ts.map +1 -1
- package/dist/core/format/backend-ast/printer.js +11 -1146
- package/dist/core/format/backend-ast/printer.js.map +1 -1
- package/dist/core/format/backend-ast/printer.test.d.ts +5 -0
- package/dist/core/format/backend-ast/printer.test.d.ts.map +1 -0
- package/dist/core/format/backend-ast/printer.test.js +5 -0
- package/dist/core/format/backend-ast/printer.test.js.map +1 -0
- package/dist/core/format/backend-ast/types/compilation-unit-ast.d.ts +26 -0
- package/dist/core/format/backend-ast/types/compilation-unit-ast.d.ts.map +1 -0
- package/dist/core/format/backend-ast/types/compilation-unit-ast.js +2 -0
- package/dist/core/format/backend-ast/types/compilation-unit-ast.js.map +1 -0
- package/dist/core/format/backend-ast/types/declaration-ast.d.ts +105 -0
- package/dist/core/format/backend-ast/types/declaration-ast.d.ts.map +1 -0
- package/dist/core/format/backend-ast/types/declaration-ast.js +2 -0
- package/dist/core/format/backend-ast/types/declaration-ast.js.map +1 -0
- package/dist/core/format/backend-ast/types/expression-ast.d.ts +219 -0
- package/dist/core/format/backend-ast/types/expression-ast.d.ts.map +1 -0
- package/dist/core/format/backend-ast/types/expression-ast.js +2 -0
- package/dist/core/format/backend-ast/types/expression-ast.js.map +1 -0
- package/dist/core/format/backend-ast/types/pattern-ast.d.ts +28 -0
- package/dist/core/format/backend-ast/types/pattern-ast.d.ts.map +1 -0
- package/dist/core/format/backend-ast/types/pattern-ast.js +2 -0
- package/dist/core/format/backend-ast/types/pattern-ast.js.map +1 -0
- package/dist/core/format/backend-ast/types/signature-ast.d.ts +34 -0
- package/dist/core/format/backend-ast/types/signature-ast.d.ts.map +1 -0
- package/dist/core/format/backend-ast/types/signature-ast.js +2 -0
- package/dist/core/format/backend-ast/types/signature-ast.js.map +1 -0
- package/dist/core/format/backend-ast/types/statement-ast.d.ts +118 -0
- package/dist/core/format/backend-ast/types/statement-ast.d.ts.map +1 -0
- package/dist/core/format/backend-ast/types/statement-ast.js +2 -0
- package/dist/core/format/backend-ast/types/statement-ast.js.map +1 -0
- package/dist/core/format/backend-ast/types/type-ast.d.ts +50 -0
- package/dist/core/format/backend-ast/types/type-ast.d.ts.map +1 -0
- package/dist/core/format/backend-ast/types/type-ast.js +2 -0
- package/dist/core/format/backend-ast/types/type-ast.js.map +1 -0
- package/dist/core/format/backend-ast/types.d.ts +7 -497
- package/dist/core/format/backend-ast/types.d.ts.map +1 -1
- package/dist/core/format/backend-ast/types.js +7 -1
- package/dist/core/format/backend-ast/types.js.map +1 -1
- package/dist/core/format/backend-ast/utils.d.ts +16 -8
- package/dist/core/format/backend-ast/utils.d.ts.map +1 -1
- package/dist/core/format/backend-ast/utils.js +295 -21
- package/dist/core/format/backend-ast/utils.js.map +1 -1
- package/dist/core/format/backend-ast/utils.test.d.ts +2 -0
- package/dist/core/format/backend-ast/utils.test.d.ts.map +1 -0
- package/dist/core/format/backend-ast/utils.test.js +205 -0
- package/dist/core/format/backend-ast/utils.test.js.map +1 -0
- package/dist/core/format/local-names.d.ts +26 -0
- package/dist/core/format/local-names.d.ts.map +1 -1
- package/dist/core/format/local-names.js +59 -0
- package/dist/core/format/local-names.js.map +1 -1
- package/dist/core/format/local-names.test.d.ts +12 -0
- package/dist/core/format/local-names.test.d.ts.map +1 -0
- package/dist/core/format/local-names.test.js +278 -0
- package/dist/core/format/local-names.test.js.map +1 -0
- package/dist/core/format/module-emitter/assembly.d.ts +2 -2
- package/dist/core/format/module-emitter/assembly.d.ts.map +1 -1
- package/dist/core/format/module-emitter/assembly.js +7 -3
- package/dist/core/format/module-emitter/assembly.js.map +1 -1
- package/dist/core/format/module-emitter/header.d.ts +2 -1
- package/dist/core/format/module-emitter/header.d.ts.map +1 -1
- package/dist/core/format/module-emitter/header.js +2 -2
- package/dist/core/format/module-emitter/header.js.map +1 -1
- package/dist/core/format/module-emitter/orchestrator.d.ts.map +1 -1
- package/dist/core/format/module-emitter/orchestrator.js +2 -153
- package/dist/core/format/module-emitter/orchestrator.js.map +1 -1
- package/dist/core/format/module-emitter/static-container.d.ts.map +1 -1
- package/dist/core/format/module-emitter/static-container.js +20 -6
- package/dist/core/format/module-emitter/static-container.js.map +1 -1
- package/dist/core/module-emitter-cases/class-and-recursion.test.d.ts +6 -0
- package/dist/core/module-emitter-cases/class-and-recursion.test.d.ts.map +1 -0
- package/dist/core/module-emitter-cases/class-and-recursion.test.js +263 -0
- package/dist/core/module-emitter-cases/class-and-recursion.test.js.map +1 -0
- package/dist/core/module-emitter-cases/static-containers.test.d.ts +6 -0
- package/dist/core/module-emitter-cases/static-containers.test.d.ts.map +1 -0
- package/dist/core/module-emitter-cases/static-containers.test.js +275 -0
- package/dist/core/module-emitter-cases/static-containers.test.js.map +1 -0
- package/dist/core/module-emitter.test.d.ts +2 -5
- package/dist/core/module-emitter.test.d.ts.map +1 -1
- package/dist/core/module-emitter.test.js +2 -402
- package/dist/core/module-emitter.test.js.map +1 -1
- package/dist/core/semantic/array-expected-types.d.ts +6 -0
- package/dist/core/semantic/array-expected-types.d.ts.map +1 -0
- package/dist/core/semantic/array-expected-types.js +84 -0
- package/dist/core/semantic/array-expected-types.js.map +1 -0
- package/dist/core/semantic/array-expected-types.test.d.ts +2 -0
- package/dist/core/semantic/array-expected-types.test.d.ts.map +1 -0
- package/dist/core/semantic/array-expected-types.test.js +66 -0
- package/dist/core/semantic/array-expected-types.test.js.map +1 -0
- package/dist/core/semantic/assignment-flow.d.ts +9 -0
- package/dist/core/semantic/assignment-flow.d.ts.map +1 -0
- package/dist/core/semantic/assignment-flow.js +161 -0
- package/dist/core/semantic/assignment-flow.js.map +1 -0
- package/dist/core/semantic/async-wrapper-types.d.ts +6 -0
- package/dist/core/semantic/async-wrapper-types.d.ts.map +1 -0
- package/dist/core/semantic/async-wrapper-types.js +65 -0
- package/dist/core/semantic/async-wrapper-types.js.map +1 -0
- package/dist/core/semantic/boolean-condition-emission.d.ts +9 -0
- package/dist/core/semantic/boolean-condition-emission.d.ts.map +1 -0
- package/dist/core/semantic/boolean-condition-emission.js +9 -0
- package/dist/core/semantic/boolean-condition-emission.js.map +1 -0
- package/dist/core/semantic/boolean-condition-main.d.ts +38 -0
- package/dist/core/semantic/boolean-condition-main.d.ts.map +1 -0
- package/dist/core/semantic/boolean-condition-main.js +235 -0
- package/dist/core/semantic/boolean-condition-main.js.map +1 -0
- package/dist/core/semantic/boolean-condition-union.d.ts +20 -0
- package/dist/core/semantic/boolean-condition-union.d.ts.map +1 -0
- package/dist/core/semantic/boolean-condition-union.js +238 -0
- package/dist/core/semantic/boolean-condition-union.js.map +1 -0
- package/dist/core/semantic/boolean-context.d.ts +6 -40
- package/dist/core/semantic/boolean-context.d.ts.map +1 -1
- package/dist/core/semantic/boolean-context.js +6 -713
- package/dist/core/semantic/boolean-context.js.map +1 -1
- package/dist/core/semantic/boolean-context.test.js +22 -2
- package/dist/core/semantic/boolean-context.test.js.map +1 -1
- package/dist/core/semantic/broad-array-storage.d.ts +11 -0
- package/dist/core/semantic/broad-array-storage.d.ts.map +1 -0
- package/dist/core/semantic/broad-array-storage.js +111 -0
- package/dist/core/semantic/broad-array-storage.js.map +1 -0
- package/dist/core/semantic/broad-object-types.d.ts +7 -0
- package/dist/core/semantic/broad-object-types.d.ts.map +1 -0
- package/dist/core/semantic/broad-object-types.js +60 -0
- package/dist/core/semantic/broad-object-types.js.map +1 -0
- package/dist/core/semantic/clr-type-identity.d.ts +21 -0
- package/dist/core/semantic/clr-type-identity.d.ts.map +1 -0
- package/dist/core/semantic/clr-type-identity.js +230 -0
- package/dist/core/semantic/clr-type-identity.js.map +1 -0
- package/dist/core/semantic/comparable-types.d.ts +5 -0
- package/dist/core/semantic/comparable-types.d.ts.map +1 -0
- package/dist/core/semantic/comparable-types.js +108 -0
- package/dist/core/semantic/comparable-types.js.map +1 -0
- package/dist/core/semantic/comparable-types.test.d.ts +2 -0
- package/dist/core/semantic/comparable-types.test.d.ts.map +1 -0
- package/dist/core/semantic/comparable-types.test.js +199 -0
- package/dist/core/semantic/comparable-types.test.js.map +1 -0
- package/dist/core/semantic/condition-branch-narrowing.d.ts +6 -0
- package/dist/core/semantic/condition-branch-narrowing.d.ts.map +1 -0
- package/dist/core/semantic/condition-branch-narrowing.js +50 -0
- package/dist/core/semantic/condition-branch-narrowing.js.map +1 -0
- package/dist/core/semantic/defaults.d.ts +7 -0
- package/dist/core/semantic/defaults.d.ts.map +1 -0
- package/dist/core/semantic/defaults.js +61 -0
- package/dist/core/semantic/defaults.js.map +1 -0
- package/dist/core/semantic/defaults.test.d.ts +2 -0
- package/dist/core/semantic/defaults.test.d.ts.map +1 -0
- package/dist/core/semantic/defaults.test.js +88 -0
- package/dist/core/semantic/defaults.test.js.map +1 -0
- package/dist/core/semantic/deterministic-type-keys.d.ts +8 -0
- package/dist/core/semantic/deterministic-type-keys.d.ts.map +1 -0
- package/dist/core/semantic/deterministic-type-keys.js +277 -0
- package/dist/core/semantic/deterministic-type-keys.js.map +1 -0
- package/dist/core/semantic/direct-storage-ir-types.d.ts +12 -0
- package/dist/core/semantic/direct-storage-ir-types.d.ts.map +1 -0
- package/dist/core/semantic/direct-storage-ir-types.js +189 -0
- package/dist/core/semantic/direct-storage-ir-types.js.map +1 -0
- package/dist/core/semantic/direct-value-surfaces.d.ts +9 -0
- package/dist/core/semantic/direct-value-surfaces.d.ts.map +1 -0
- package/dist/core/semantic/direct-value-surfaces.js +181 -0
- package/dist/core/semantic/direct-value-surfaces.js.map +1 -0
- package/dist/core/semantic/direct-value-surfaces.test.d.ts +2 -0
- package/dist/core/semantic/direct-value-surfaces.test.d.ts.map +1 -0
- package/dist/core/semantic/direct-value-surfaces.test.js +116 -0
- package/dist/core/semantic/direct-value-surfaces.test.js.map +1 -0
- package/dist/core/semantic/expected-type-matching.d.ts +7 -0
- package/dist/core/semantic/expected-type-matching.d.ts.map +1 -0
- package/dist/core/semantic/expected-type-matching.js +101 -0
- package/dist/core/semantic/expected-type-matching.js.map +1 -0
- package/dist/core/semantic/guard-primitives.d.ts +29 -0
- package/dist/core/semantic/guard-primitives.d.ts.map +1 -0
- package/dist/core/semantic/guard-primitives.js +80 -0
- package/dist/core/semantic/guard-primitives.js.map +1 -0
- package/dist/core/semantic/implicit-interfaces.d.ts +34 -0
- package/dist/core/semantic/implicit-interfaces.d.ts.map +1 -0
- package/dist/core/semantic/implicit-interfaces.js +276 -0
- package/dist/core/semantic/implicit-interfaces.js.map +1 -0
- package/dist/core/semantic/implicit-interfaces.test.d.ts +2 -0
- package/dist/core/semantic/implicit-interfaces.test.d.ts.map +1 -0
- package/dist/core/semantic/implicit-interfaces.test.js +280 -0
- package/dist/core/semantic/implicit-interfaces.test.js.map +1 -0
- package/dist/core/semantic/imports-cases/basic-and-local.test.d.ts +6 -0
- package/dist/core/semantic/imports-cases/basic-and-local.test.d.ts.map +1 -0
- package/dist/core/semantic/imports-cases/basic-and-local.test.js +504 -0
- package/dist/core/semantic/imports-cases/basic-and-local.test.js.map +1 -0
- package/dist/core/semantic/imports-cases/bindings-and-namespaces.test.d.ts +6 -0
- package/dist/core/semantic/imports-cases/bindings-and-namespaces.test.d.ts.map +1 -0
- package/dist/core/semantic/imports-cases/bindings-and-namespaces.test.js +932 -0
- package/dist/core/semantic/imports-cases/bindings-and-namespaces.test.js.map +1 -0
- package/dist/core/semantic/imports.d.ts.map +1 -1
- package/dist/core/semantic/imports.js +174 -37
- package/dist/core/semantic/imports.js.map +1 -1
- package/dist/core/semantic/imports.test.d.ts +2 -5
- package/dist/core/semantic/imports.test.d.ts.map +1 -1
- package/dist/core/semantic/imports.test.js +2 -551
- package/dist/core/semantic/imports.test.js.map +1 -1
- package/dist/core/semantic/instanceof-predicate-refinements.d.ts +10 -0
- package/dist/core/semantic/instanceof-predicate-refinements.d.ts.map +1 -0
- package/dist/core/semantic/instanceof-predicate-refinements.js +189 -0
- package/dist/core/semantic/instanceof-predicate-refinements.js.map +1 -0
- package/dist/core/semantic/instanceof-targets.d.ts +10 -0
- package/dist/core/semantic/instanceof-targets.d.ts.map +1 -0
- package/dist/core/semantic/instanceof-targets.js +20 -0
- package/dist/core/semantic/instanceof-targets.js.map +1 -0
- package/dist/core/semantic/iteration-types.d.ts +11 -0
- package/dist/core/semantic/iteration-types.d.ts.map +1 -0
- package/dist/core/semantic/iteration-types.js +116 -0
- package/dist/core/semantic/iteration-types.js.map +1 -0
- package/dist/core/semantic/js-value-types.d.ts +5 -0
- package/dist/core/semantic/js-value-types.d.ts.map +1 -0
- package/dist/core/semantic/js-value-types.js +42 -0
- package/dist/core/semantic/js-value-types.js.map +1 -0
- package/dist/core/semantic/local-type-lookup.d.ts +8 -0
- package/dist/core/semantic/local-type-lookup.d.ts.map +1 -0
- package/dist/core/semantic/local-type-lookup.js +36 -0
- package/dist/core/semantic/local-type-lookup.js.map +1 -0
- package/dist/core/semantic/local-types.d.ts +1 -0
- package/dist/core/semantic/local-types.d.ts.map +1 -1
- package/dist/core/semantic/local-types.js +269 -0
- package/dist/core/semantic/local-types.js.map +1 -1
- package/dist/core/semantic/materialized-narrowing.d.ts +5 -0
- package/dist/core/semantic/materialized-narrowing.d.ts.map +1 -0
- package/dist/core/semantic/materialized-narrowing.js +361 -0
- package/dist/core/semantic/materialized-narrowing.js.map +1 -0
- package/dist/core/semantic/materialized-narrowing.test.d.ts +2 -0
- package/dist/core/semantic/materialized-narrowing.test.d.ts.map +1 -0
- package/dist/core/semantic/materialized-narrowing.test.js +321 -0
- package/dist/core/semantic/materialized-narrowing.test.js.map +1 -0
- package/dist/core/semantic/member-surfaces.d.ts +10 -0
- package/dist/core/semantic/member-surfaces.d.ts.map +1 -0
- package/dist/core/semantic/member-surfaces.js +108 -0
- package/dist/core/semantic/member-surfaces.js.map +1 -0
- package/dist/core/semantic/member-surfaces.test.d.ts +2 -0
- package/dist/core/semantic/member-surfaces.test.d.ts.map +1 -0
- package/dist/core/semantic/member-surfaces.test.js +105 -0
- package/dist/core/semantic/member-surfaces.test.js.map +1 -0
- package/dist/core/semantic/module-map.d.ts.map +1 -1
- package/dist/core/semantic/module-map.js +92 -2
- package/dist/core/semantic/module-map.js.map +1 -1
- package/dist/core/semantic/module-map.test.js +264 -0
- package/dist/core/semantic/module-map.test.js.map +1 -1
- package/dist/core/semantic/mutable-storage-detection.d.ts +10 -0
- package/dist/core/semantic/mutable-storage-detection.d.ts.map +1 -0
- package/dist/core/semantic/mutable-storage-detection.js +10 -0
- package/dist/core/semantic/mutable-storage-detection.js.map +1 -0
- package/dist/core/semantic/mutable-storage-expression-visitor.d.ts +12 -0
- package/dist/core/semantic/mutable-storage-expression-visitor.d.ts.map +1 -0
- package/dist/core/semantic/mutable-storage-expression-visitor.js +126 -0
- package/dist/core/semantic/mutable-storage-expression-visitor.js.map +1 -0
- package/dist/core/semantic/mutable-storage-helpers.d.ts +26 -0
- package/dist/core/semantic/mutable-storage-helpers.d.ts.map +1 -0
- package/dist/core/semantic/mutable-storage-helpers.js +203 -0
- package/dist/core/semantic/mutable-storage-helpers.js.map +1 -0
- package/dist/core/semantic/mutable-storage-statement-visitor.d.ts +5 -0
- package/dist/core/semantic/mutable-storage-statement-visitor.d.ts.map +1 -0
- package/dist/core/semantic/mutable-storage-statement-visitor.js +158 -0
- package/dist/core/semantic/mutable-storage-statement-visitor.js.map +1 -0
- package/dist/core/semantic/mutable-storage-visitors.d.ts +5 -0
- package/dist/core/semantic/mutable-storage-visitors.d.ts.map +1 -0
- package/dist/core/semantic/mutable-storage-visitors.js +17 -0
- package/dist/core/semantic/mutable-storage-visitors.js.map +1 -0
- package/dist/core/semantic/mutable-storage.d.ts +2 -9
- package/dist/core/semantic/mutable-storage.d.ts.map +1 -1
- package/dist/core/semantic/mutable-storage.js +2 -478
- package/dist/core/semantic/mutable-storage.js.map +1 -1
- package/dist/core/semantic/narrowed-expression-types.d.ts +7 -0
- package/dist/core/semantic/narrowed-expression-types.d.ts.map +1 -0
- package/dist/core/semantic/narrowed-expression-types.js +287 -0
- package/dist/core/semantic/narrowed-expression-types.js.map +1 -0
- package/dist/core/semantic/narrowed-expression-types.test.d.ts +2 -0
- package/dist/core/semantic/narrowed-expression-types.test.d.ts.map +1 -0
- package/dist/core/semantic/narrowed-expression-types.test.js +296 -0
- package/dist/core/semantic/narrowed-expression-types.test.js.map +1 -0
- package/dist/core/semantic/narrowed-union-resolution.d.ts +42 -0
- package/dist/core/semantic/narrowed-union-resolution.d.ts.map +1 -0
- package/dist/core/semantic/narrowed-union-resolution.js +162 -0
- package/dist/core/semantic/narrowed-union-resolution.js.map +1 -0
- package/dist/core/semantic/narrowing-builder-core.d.ts +46 -0
- package/dist/core/semantic/narrowing-builder-core.d.ts.map +1 -0
- package/dist/core/semantic/narrowing-builder-core.js +332 -0
- package/dist/core/semantic/narrowing-builder-core.js.map +1 -0
- package/dist/core/semantic/narrowing-builder-core.test.d.ts +2 -0
- package/dist/core/semantic/narrowing-builder-core.test.d.ts.map +1 -0
- package/dist/core/semantic/narrowing-builder-core.test.js +49 -0
- package/dist/core/semantic/narrowing-builder-core.test.js.map +1 -0
- package/dist/core/semantic/narrowing-builder-unions.d.ts +18 -0
- package/dist/core/semantic/narrowing-builder-unions.d.ts.map +1 -0
- package/dist/core/semantic/narrowing-builder-unions.js +336 -0
- package/dist/core/semantic/narrowing-builder-unions.js.map +1 -0
- package/dist/core/semantic/narrowing-builders.d.ts +10 -0
- package/dist/core/semantic/narrowing-builders.d.ts.map +1 -0
- package/dist/core/semantic/narrowing-builders.js +10 -0
- package/dist/core/semantic/narrowing-builders.js.map +1 -0
- package/dist/core/semantic/narrowing-keys.d.ts +6 -0
- package/dist/core/semantic/narrowing-keys.d.ts.map +1 -0
- package/dist/core/semantic/narrowing-keys.js +27 -0
- package/dist/core/semantic/narrowing-keys.js.map +1 -0
- package/dist/core/semantic/narrowing-refinements.d.ts +10 -0
- package/dist/core/semantic/narrowing-refinements.d.ts.map +1 -0
- package/dist/core/semantic/narrowing-refinements.js +10 -0
- package/dist/core/semantic/narrowing-refinements.js.map +1 -0
- package/dist/core/semantic/nullable-typeof-refinements.d.ts +13 -0
- package/dist/core/semantic/nullable-typeof-refinements.d.ts.map +1 -0
- package/dist/core/semantic/nullable-typeof-refinements.js +408 -0
- package/dist/core/semantic/nullable-typeof-refinements.js.map +1 -0
- package/dist/core/semantic/nullish-value-helpers.d.ts +64 -0
- package/dist/core/semantic/nullish-value-helpers.d.ts.map +1 -0
- package/dist/core/semantic/nullish-value-helpers.js +346 -0
- package/dist/core/semantic/nullish-value-helpers.js.map +1 -0
- package/dist/core/semantic/parameter-modifier-types.d.ts +3 -0
- package/dist/core/semantic/parameter-modifier-types.d.ts.map +1 -0
- package/dist/core/semantic/parameter-modifier-types.js +17 -0
- package/dist/core/semantic/parameter-modifier-types.js.map +1 -0
- package/dist/core/semantic/pattern-types.d.ts +59 -0
- package/dist/core/semantic/pattern-types.d.ts.map +1 -0
- package/dist/core/semantic/pattern-types.js +92 -0
- package/dist/core/semantic/pattern-types.js.map +1 -0
- package/dist/core/semantic/property-lookup-membership.d.ts +30 -0
- package/dist/core/semantic/property-lookup-membership.d.ts.map +1 -0
- package/dist/core/semantic/property-lookup-membership.js +176 -0
- package/dist/core/semantic/property-lookup-membership.js.map +1 -0
- package/dist/core/semantic/property-lookup-resolution.d.ts +52 -0
- package/dist/core/semantic/property-lookup-resolution.d.ts.map +1 -0
- package/dist/core/semantic/property-lookup-resolution.js +275 -0
- package/dist/core/semantic/property-lookup-resolution.js.map +1 -0
- package/dist/core/semantic/property-member-lookup.d.ts +10 -0
- package/dist/core/semantic/property-member-lookup.d.ts.map +1 -0
- package/dist/core/semantic/property-member-lookup.js +10 -0
- package/dist/core/semantic/property-member-lookup.js.map +1 -0
- package/dist/core/semantic/reference-type-identity.d.ts +10 -0
- package/dist/core/semantic/reference-type-identity.d.ts.map +1 -0
- package/dist/core/semantic/reference-type-identity.js +28 -0
- package/dist/core/semantic/reference-type-identity.js.map +1 -0
- package/dist/core/semantic/runtime-call-arities.d.ts +4 -0
- package/dist/core/semantic/runtime-call-arities.d.ts.map +1 -0
- package/dist/core/semantic/runtime-call-arities.js +104 -0
- package/dist/core/semantic/runtime-call-arities.js.map +1 -0
- package/dist/core/semantic/runtime-materialization-targets.d.ts +4 -0
- package/dist/core/semantic/runtime-materialization-targets.d.ts.map +1 -0
- package/dist/core/semantic/runtime-materialization-targets.js +69 -0
- package/dist/core/semantic/runtime-materialization-targets.js.map +1 -0
- package/dist/core/semantic/runtime-reification-helpers.d.ts +9 -0
- package/dist/core/semantic/runtime-reification-helpers.d.ts.map +1 -0
- package/dist/core/semantic/runtime-reification-helpers.js +99 -0
- package/dist/core/semantic/runtime-reification-helpers.js.map +1 -0
- package/dist/core/semantic/runtime-reification.d.ts +16 -0
- package/dist/core/semantic/runtime-reification.d.ts.map +1 -0
- package/dist/core/semantic/runtime-reification.js +609 -0
- package/dist/core/semantic/runtime-reification.js.map +1 -0
- package/dist/core/semantic/runtime-union-alias-identity.d.ts +5 -0
- package/dist/core/semantic/runtime-union-alias-identity.d.ts.map +1 -0
- package/dist/core/semantic/runtime-union-alias-identity.js +27 -0
- package/dist/core/semantic/runtime-union-alias-identity.js.map +1 -0
- package/dist/core/semantic/runtime-union-expansion.d.ts +5 -0
- package/dist/core/semantic/runtime-union-expansion.d.ts.map +1 -0
- package/dist/core/semantic/runtime-union-expansion.js +190 -0
- package/dist/core/semantic/runtime-union-expansion.js.map +1 -0
- package/dist/core/semantic/runtime-union-family-preservation.d.ts +5 -0
- package/dist/core/semantic/runtime-union-family-preservation.d.ts.map +1 -0
- package/dist/core/semantic/runtime-union-family-preservation.js +34 -0
- package/dist/core/semantic/runtime-union-family-preservation.js.map +1 -0
- package/dist/core/semantic/runtime-union-matching.d.ts +9 -0
- package/dist/core/semantic/runtime-union-matching.d.ts.map +1 -0
- package/dist/core/semantic/runtime-union-matching.js +121 -0
- package/dist/core/semantic/runtime-union-matching.js.map +1 -0
- package/dist/core/semantic/runtime-union-member-mapping.d.ts +12 -0
- package/dist/core/semantic/runtime-union-member-mapping.d.ts.map +1 -0
- package/dist/core/semantic/runtime-union-member-mapping.js +25 -0
- package/dist/core/semantic/runtime-union-member-mapping.js.map +1 -0
- package/dist/core/semantic/runtime-union-member-mapping.test.d.ts +2 -0
- package/dist/core/semantic/runtime-union-member-mapping.test.d.ts.map +1 -0
- package/dist/core/semantic/runtime-union-member-mapping.test.js +54 -0
- package/dist/core/semantic/runtime-union-member-mapping.test.js.map +1 -0
- package/dist/core/semantic/runtime-union-ordering.d.ts +4 -0
- package/dist/core/semantic/runtime-union-ordering.d.ts.map +1 -0
- package/dist/core/semantic/runtime-union-ordering.js +114 -0
- package/dist/core/semantic/runtime-union-ordering.js.map +1 -0
- package/dist/core/semantic/runtime-union-projection.d.ts +40 -0
- package/dist/core/semantic/runtime-union-projection.d.ts.map +1 -0
- package/dist/core/semantic/runtime-union-projection.js +150 -0
- package/dist/core/semantic/runtime-union-projection.js.map +1 -0
- package/dist/core/semantic/runtime-union-projection.test.d.ts +2 -0
- package/dist/core/semantic/runtime-union-projection.test.d.ts.map +1 -0
- package/dist/core/semantic/runtime-union-projection.test.js +211 -0
- package/dist/core/semantic/runtime-union-projection.test.js.map +1 -0
- package/dist/core/semantic/runtime-union-registry.d.ts +28 -0
- package/dist/core/semantic/runtime-union-registry.d.ts.map +1 -0
- package/dist/core/semantic/runtime-union-registry.js +301 -0
- package/dist/core/semantic/runtime-union-registry.js.map +1 -0
- package/dist/core/semantic/runtime-union-shared.d.ts +23 -0
- package/dist/core/semantic/runtime-union-shared.d.ts.map +1 -0
- package/dist/core/semantic/runtime-union-shared.js +29 -0
- package/dist/core/semantic/runtime-union-shared.js.map +1 -0
- package/dist/core/semantic/runtime-unions.d.ts +14 -0
- package/dist/core/semantic/runtime-unions.d.ts.map +1 -0
- package/dist/core/semantic/runtime-unions.js +330 -0
- package/dist/core/semantic/runtime-unions.js.map +1 -0
- package/dist/core/semantic/runtime-unions.test.d.ts +2 -0
- package/dist/core/semantic/runtime-unions.test.d.ts.map +1 -0
- package/dist/core/semantic/runtime-unions.test.js +922 -0
- package/dist/core/semantic/runtime-unions.test.js.map +1 -0
- package/dist/core/semantic/semantic-union-members.d.ts +46 -0
- package/dist/core/semantic/semantic-union-members.d.ts.map +1 -0
- package/dist/core/semantic/semantic-union-members.js +144 -0
- package/dist/core/semantic/semantic-union-members.js.map +1 -0
- package/dist/core/semantic/storage-erased-adaptation.d.ts +14 -0
- package/dist/core/semantic/storage-erased-adaptation.d.ts.map +1 -0
- package/dist/core/semantic/storage-erased-adaptation.js +191 -0
- package/dist/core/semantic/storage-erased-adaptation.js.map +1 -0
- package/dist/core/semantic/storage-erased-adaptation.test.d.ts +2 -0
- package/dist/core/semantic/storage-erased-adaptation.test.d.ts.map +1 -0
- package/dist/core/semantic/storage-erased-adaptation.test.js +271 -0
- package/dist/core/semantic/storage-erased-adaptation.test.js.map +1 -0
- package/dist/core/semantic/storage-types.d.ts +8 -0
- package/dist/core/semantic/storage-types.d.ts.map +1 -0
- package/dist/core/semantic/storage-types.js +344 -0
- package/dist/core/semantic/storage-types.js.map +1 -0
- package/dist/core/semantic/storage-types.test.d.ts +2 -0
- package/dist/core/semantic/storage-types.test.d.ts.map +1 -0
- package/dist/core/semantic/storage-types.test.js +438 -0
- package/dist/core/semantic/storage-types.test.js.map +1 -0
- package/dist/core/semantic/structural-resolution.d.ts +11 -0
- package/dist/core/semantic/structural-resolution.d.ts.map +1 -0
- package/dist/core/semantic/structural-resolution.js +11 -0
- package/dist/core/semantic/structural-resolution.js.map +1 -0
- package/dist/core/semantic/structural-shape-matching.d.ts +22 -0
- package/dist/core/semantic/structural-shape-matching.d.ts.map +1 -0
- package/dist/core/semantic/structural-shape-matching.js +255 -0
- package/dist/core/semantic/structural-shape-matching.js.map +1 -0
- package/dist/core/semantic/structural-view-types.d.ts +10 -0
- package/dist/core/semantic/structural-view-types.d.ts.map +1 -0
- package/dist/core/semantic/structural-view-types.js +46 -0
- package/dist/core/semantic/structural-view-types.js.map +1 -0
- package/dist/core/semantic/symbol-types.d.ts +80 -0
- package/dist/core/semantic/symbol-types.d.ts.map +1 -0
- package/dist/core/semantic/symbol-types.js +102 -0
- package/dist/core/semantic/symbol-types.js.map +1 -0
- package/dist/core/semantic/ternary-guards.d.ts +43 -0
- package/dist/core/semantic/ternary-guards.d.ts.map +1 -0
- package/dist/core/semantic/ternary-guards.js +232 -0
- package/dist/core/semantic/ternary-guards.js.map +1 -0
- package/dist/core/semantic/transparent-expressions.d.ts +6 -0
- package/dist/core/semantic/transparent-expressions.d.ts.map +1 -0
- package/dist/core/semantic/transparent-expressions.js +18 -0
- package/dist/core/semantic/transparent-expressions.js.map +1 -0
- package/dist/core/semantic/truthiness-evaluation.d.ts +58 -0
- package/dist/core/semantic/truthiness-evaluation.d.ts.map +1 -0
- package/dist/core/semantic/truthiness-evaluation.js +295 -0
- package/dist/core/semantic/truthiness-evaluation.js.map +1 -0
- package/dist/core/semantic/type-alias-index.d.ts.map +1 -1
- package/dist/core/semantic/type-alias-index.js +1 -11
- package/dist/core/semantic/type-alias-index.js.map +1 -1
- package/dist/core/semantic/type-compatibility.d.ts +1 -1
- package/dist/core/semantic/type-compatibility.d.ts.map +1 -1
- package/dist/core/semantic/type-compatibility.js +75 -15
- package/dist/core/semantic/type-compatibility.js.map +1 -1
- package/dist/core/semantic/type-equivalence.d.ts +4 -0
- package/dist/core/semantic/type-equivalence.d.ts.map +1 -0
- package/dist/core/semantic/type-equivalence.js +255 -0
- package/dist/core/semantic/type-equivalence.js.map +1 -0
- package/dist/core/semantic/type-equivalence.test.d.ts +2 -0
- package/dist/core/semantic/type-equivalence.test.d.ts.map +1 -0
- package/dist/core/semantic/type-equivalence.test.js +380 -0
- package/dist/core/semantic/type-equivalence.test.js.map +1 -0
- package/dist/core/semantic/type-param-substitution.d.ts +19 -0
- package/dist/core/semantic/type-param-substitution.d.ts.map +1 -0
- package/dist/core/semantic/type-param-substitution.js +219 -0
- package/dist/core/semantic/type-param-substitution.js.map +1 -0
- package/dist/core/semantic/type-resolution-cases/array-like-element.test.d.ts +2 -0
- package/dist/core/semantic/type-resolution-cases/array-like-element.test.d.ts.map +1 -0
- package/dist/core/semantic/type-resolution-cases/array-like-element.test.js +82 -0
- package/dist/core/semantic/type-resolution-cases/array-like-element.test.js.map +1 -0
- package/dist/core/semantic/type-resolution-cases/contains-type-parameter.test.d.ts +2 -0
- package/dist/core/semantic/type-resolution-cases/contains-type-parameter.test.d.ts.map +1 -0
- package/dist/core/semantic/type-resolution-cases/contains-type-parameter.test.js +101 -0
- package/dist/core/semantic/type-resolution-cases/contains-type-parameter.test.js.map +1 -0
- package/dist/core/semantic/type-resolution-cases/helpers.d.ts +8 -0
- package/dist/core/semantic/type-resolution-cases/helpers.d.ts.map +1 -0
- package/dist/core/semantic/type-resolution-cases/helpers.js +5 -0
- package/dist/core/semantic/type-resolution-cases/helpers.js.map +1 -0
- package/dist/core/semantic/type-resolution-cases/narrow-typeof.test.d.ts +2 -0
- package/dist/core/semantic/type-resolution-cases/narrow-typeof.test.d.ts.map +1 -0
- package/dist/core/semantic/type-resolution-cases/narrow-typeof.test.js +98 -0
- package/dist/core/semantic/type-resolution-cases/narrow-typeof.test.js.map +1 -0
- package/dist/core/semantic/type-resolution-cases/nullish-and-value-type.test.d.ts +2 -0
- package/dist/core/semantic/type-resolution-cases/nullish-and-value-type.test.d.ts.map +1 -0
- package/dist/core/semantic/type-resolution-cases/nullish-and-value-type.test.js +378 -0
- package/dist/core/semantic/type-resolution-cases/nullish-and-value-type.test.js.map +1 -0
- package/dist/core/semantic/type-resolution-cases/object-literal-member-selection.test.d.ts +2 -0
- package/dist/core/semantic/type-resolution-cases/object-literal-member-selection.test.d.ts.map +1 -0
- package/dist/core/semantic/type-resolution-cases/object-literal-member-selection.test.js +137 -0
- package/dist/core/semantic/type-resolution-cases/object-literal-member-selection.test.js.map +1 -0
- package/dist/core/semantic/type-resolution-cases/property-type.test.d.ts +2 -0
- package/dist/core/semantic/type-resolution-cases/property-type.test.d.ts.map +1 -0
- package/dist/core/semantic/type-resolution-cases/property-type.test.js +298 -0
- package/dist/core/semantic/type-resolution-cases/property-type.test.js.map +1 -0
- package/dist/core/semantic/type-resolution-cases/structural-resolution.test.d.ts +2 -0
- package/dist/core/semantic/type-resolution-cases/structural-resolution.test.d.ts.map +1 -0
- package/dist/core/semantic/type-resolution-cases/structural-resolution.test.js +511 -0
- package/dist/core/semantic/type-resolution-cases/structural-resolution.test.js.map +1 -0
- package/dist/core/semantic/type-resolution-cases/structural-target.test.d.ts +2 -0
- package/dist/core/semantic/type-resolution-cases/structural-target.test.d.ts.map +1 -0
- package/dist/core/semantic/type-resolution-cases/structural-target.test.js +80 -0
- package/dist/core/semantic/type-resolution-cases/structural-target.test.js.map +1 -0
- package/dist/core/semantic/type-resolution-cases/substitute-type-args.test.d.ts +2 -0
- package/dist/core/semantic/type-resolution-cases/substitute-type-args.test.d.ts.map +1 -0
- package/dist/core/semantic/type-resolution-cases/substitute-type-args.test.js +80 -0
- package/dist/core/semantic/type-resolution-cases/substitute-type-args.test.js.map +1 -0
- package/dist/core/semantic/type-resolution-cases/union-member-index.test.d.ts +2 -0
- package/dist/core/semantic/type-resolution-cases/union-member-index.test.d.ts.map +1 -0
- package/dist/core/semantic/type-resolution-cases/union-member-index.test.js +142 -0
- package/dist/core/semantic/type-resolution-cases/union-member-index.test.js.map +1 -0
- package/dist/core/semantic/type-resolution.d.ts +19 -132
- package/dist/core/semantic/type-resolution.d.ts.map +1 -1
- package/dist/core/semantic/type-resolution.js +19 -786
- package/dist/core/semantic/type-resolution.js.map +1 -1
- package/dist/core/semantic/type-resolution.test.d.ts +10 -4
- package/dist/core/semantic/type-resolution.test.d.ts.map +1 -1
- package/dist/core/semantic/type-resolution.test.js +10 -552
- package/dist/core/semantic/type-resolution.test.js.map +1 -1
- package/dist/core/semantic/type-substitution.d.ts +10 -0
- package/dist/core/semantic/type-substitution.d.ts.map +1 -0
- package/dist/core/semantic/type-substitution.js +167 -0
- package/dist/core/semantic/type-substitution.js.map +1 -0
- package/dist/core/semantic/union-member-matching.d.ts +10 -0
- package/dist/core/semantic/union-member-matching.d.ts.map +1 -0
- package/dist/core/semantic/union-member-matching.js +10 -0
- package/dist/core/semantic/union-member-matching.js.map +1 -0
- package/dist/core/semantic/union-predicate-matching.d.ts +40 -0
- package/dist/core/semantic/union-predicate-matching.d.ts.map +1 -0
- package/dist/core/semantic/union-predicate-matching.js +313 -0
- package/dist/core/semantic/union-predicate-matching.js.map +1 -0
- package/dist/core/semantic/union-semantics.d.ts +39 -0
- package/dist/core/semantic/union-semantics.d.ts.map +1 -0
- package/dist/core/semantic/union-semantics.js +48 -0
- package/dist/core/semantic/union-semantics.js.map +1 -0
- package/dist/core/semantic/union-semantics.test.d.ts +2 -0
- package/dist/core/semantic/union-semantics.test.d.ts.map +1 -0
- package/dist/core/semantic/union-semantics.test.js +109 -0
- package/dist/core/semantic/union-semantics.test.js.map +1 -0
- package/dist/core/semantic/union-typeof-matching.d.ts +13 -0
- package/dist/core/semantic/union-typeof-matching.d.ts.map +1 -0
- package/dist/core/semantic/union-typeof-matching.js +124 -0
- package/dist/core/semantic/union-typeof-matching.js.map +1 -0
- package/dist/core/semantic/unsafe.d.ts.map +1 -1
- package/dist/core/semantic/unsafe.js +23 -15
- package/dist/core/semantic/unsafe.js.map +1 -1
- package/dist/core/semantic/value-slot-types.d.ts +3 -0
- package/dist/core/semantic/value-slot-types.d.ts.map +1 -0
- package/dist/core/semantic/value-slot-types.js +8 -0
- package/dist/core/semantic/value-slot-types.js.map +1 -0
- package/dist/core/semantic/variable-type-resolution.d.ts +68 -0
- package/dist/core/semantic/variable-type-resolution.d.ts.map +1 -0
- package/dist/core/semantic/variable-type-resolution.js +250 -0
- package/dist/core/semantic/variable-type-resolution.js.map +1 -0
- package/dist/duplicate-type-suppression.d.ts +18 -0
- package/dist/duplicate-type-suppression.d.ts.map +1 -0
- package/dist/duplicate-type-suppression.js +249 -0
- package/dist/duplicate-type-suppression.js.map +1 -0
- package/dist/duplicate-type-suppression.test.d.ts +2 -0
- package/dist/duplicate-type-suppression.test.d.ts.map +1 -0
- package/dist/duplicate-type-suppression.test.js +44 -0
- package/dist/duplicate-type-suppression.test.js.map +1 -0
- package/dist/emitter-types/context.d.ts +3 -2
- package/dist/emitter-types/context.d.ts.map +1 -1
- package/dist/emitter-types/context.js +8 -2
- package/dist/emitter-types/context.js.map +1 -1
- package/dist/emitter-types/core.d.ts +141 -17
- package/dist/emitter-types/core.d.ts.map +1 -1
- package/dist/emitter.d.ts +4 -0
- package/dist/emitter.d.ts.map +1 -1
- package/dist/emitter.js +31 -225
- package/dist/emitter.js.map +1 -1
- package/dist/expression-emitter.d.ts.map +1 -1
- package/dist/expression-emitter.js +55 -1430
- package/dist/expression-emitter.js.map +1 -1
- package/dist/expressions/access-binding.d.ts +19 -0
- package/dist/expressions/access-binding.d.ts.map +1 -0
- package/dist/expressions/access-binding.js +286 -0
- package/dist/expressions/access-binding.js.map +1 -0
- package/dist/expressions/access-computed.d.ts +22 -0
- package/dist/expressions/access-computed.d.ts.map +1 -0
- package/dist/expressions/access-computed.js +339 -0
- package/dist/expressions/access-computed.js.map +1 -0
- package/dist/expressions/access-length.d.ts +20 -0
- package/dist/expressions/access-length.d.ts.map +1 -0
- package/dist/expressions/access-length.js +419 -0
- package/dist/expressions/access-length.js.map +1 -0
- package/dist/expressions/access-length.test.d.ts +2 -0
- package/dist/expressions/access-length.test.d.ts.map +1 -0
- package/dist/expressions/access-length.test.js +39 -0
- package/dist/expressions/access-length.test.js.map +1 -0
- package/dist/expressions/access-property.d.ts +23 -0
- package/dist/expressions/access-property.d.ts.map +1 -0
- package/dist/expressions/access-property.js +267 -0
- package/dist/expressions/access-property.js.map +1 -0
- package/dist/expressions/access-resolution-receivers.d.ts +27 -0
- package/dist/expressions/access-resolution-receivers.d.ts.map +1 -0
- package/dist/expressions/access-resolution-receivers.js +358 -0
- package/dist/expressions/access-resolution-receivers.js.map +1 -0
- package/dist/expressions/access-resolution-types.d.ts +29 -0
- package/dist/expressions/access-resolution-types.d.ts.map +1 -0
- package/dist/expressions/access-resolution-types.js +192 -0
- package/dist/expressions/access-resolution-types.js.map +1 -0
- package/dist/expressions/access-resolution.d.ts +10 -0
- package/dist/expressions/access-resolution.d.ts.map +1 -0
- package/dist/expressions/access-resolution.js +10 -0
- package/dist/expressions/access-resolution.js.map +1 -0
- package/dist/expressions/access.d.ts +8 -3
- package/dist/expressions/access.d.ts.map +1 -1
- package/dist/expressions/access.js +170 -621
- package/dist/expressions/access.js.map +1 -1
- package/dist/expressions/architecture-invariants.test.d.ts +2 -0
- package/dist/expressions/architecture-invariants.test.d.ts.map +1 -0
- package/dist/expressions/architecture-invariants.test.js +73 -0
- package/dist/expressions/architecture-invariants.test.js.map +1 -0
- package/dist/expressions/array-interop.d.ts +3 -0
- package/dist/expressions/array-interop.d.ts.map +1 -0
- package/dist/expressions/array-interop.js +14 -0
- package/dist/expressions/array-interop.js.map +1 -0
- package/dist/expressions/array-literal.d.ts +13 -0
- package/dist/expressions/array-literal.d.ts.map +1 -0
- package/dist/expressions/array-literal.js +373 -0
- package/dist/expressions/array-literal.js.map +1 -0
- package/dist/expressions/await-normalization.d.ts +6 -0
- package/dist/expressions/await-normalization.d.ts.map +1 -0
- package/dist/expressions/await-normalization.js +358 -0
- package/dist/expressions/await-normalization.js.map +1 -0
- package/dist/expressions/calls/call-analysis.d.ts +8 -16
- package/dist/expressions/calls/call-analysis.d.ts.map +1 -1
- package/dist/expressions/calls/call-analysis.js +123 -93
- package/dist/expressions/calls/call-analysis.js.map +1 -1
- package/dist/expressions/calls/call-analysis.test.js +2 -2
- package/dist/expressions/calls/call-analysis.test.js.map +1 -1
- package/dist/expressions/calls/call-arguments-emit.d.ts +16 -0
- package/dist/expressions/calls/call-arguments-emit.d.ts.map +1 -0
- package/dist/expressions/calls/call-arguments-emit.js +1818 -0
- package/dist/expressions/calls/call-arguments-emit.js.map +1 -0
- package/dist/expressions/calls/call-arguments-helpers.d.ts +22 -0
- package/dist/expressions/calls/call-arguments-helpers.d.ts.map +1 -0
- package/dist/expressions/calls/call-arguments-helpers.js +333 -0
- package/dist/expressions/calls/call-arguments-helpers.js.map +1 -0
- package/dist/expressions/calls/call-arguments.d.ts +10 -0
- package/dist/expressions/calls/call-arguments.d.ts.map +1 -0
- package/dist/expressions/calls/call-arguments.js +10 -0
- package/dist/expressions/calls/call-arguments.js.map +1 -0
- package/dist/expressions/calls/call-array-interop.d.ts +10 -0
- package/dist/expressions/calls/call-array-interop.d.ts.map +1 -0
- package/dist/expressions/calls/call-array-interop.js +10 -0
- package/dist/expressions/calls/call-array-interop.js.map +1 -0
- package/dist/expressions/calls/call-array-mutation.d.ts +20 -0
- package/dist/expressions/calls/call-array-mutation.d.ts.map +1 -0
- package/dist/expressions/calls/call-array-mutation.js +260 -0
- package/dist/expressions/calls/call-array-mutation.js.map +1 -0
- package/dist/expressions/calls/call-array-wrapper.d.ts +14 -0
- package/dist/expressions/calls/call-array-wrapper.d.ts.map +1 -0
- package/dist/expressions/calls/call-array-wrapper.js +118 -0
- package/dist/expressions/calls/call-array-wrapper.js.map +1 -0
- package/dist/expressions/calls/call-binding-resolution.d.ts +8 -0
- package/dist/expressions/calls/call-binding-resolution.d.ts.map +1 -0
- package/dist/expressions/calls/call-binding-resolution.js +12 -0
- package/dist/expressions/calls/call-binding-resolution.js.map +1 -0
- package/dist/expressions/calls/call-dynamic-import.d.ts +11 -0
- package/dist/expressions/calls/call-dynamic-import.d.ts.map +1 -0
- package/dist/expressions/calls/call-dynamic-import.js +148 -0
- package/dist/expressions/calls/call-dynamic-import.js.map +1 -0
- package/dist/expressions/calls/call-emitter.d.ts +9 -3
- package/dist/expressions/calls/call-emitter.d.ts.map +1 -1
- package/dist/expressions/calls/call-emitter.js +227 -1976
- package/dist/expressions/calls/call-emitter.js.map +1 -1
- package/dist/expressions/calls/call-emitter.test.d.ts +2 -0
- package/dist/expressions/calls/call-emitter.test.d.ts.map +1 -0
- package/dist/expressions/calls/call-emitter.test.js +407 -0
- package/dist/expressions/calls/call-emitter.test.js.map +1 -0
- package/dist/expressions/calls/call-extension-methods.d.ts +17 -0
- package/dist/expressions/calls/call-extension-methods.d.ts.map +1 -0
- package/dist/expressions/calls/call-extension-methods.js +191 -0
- package/dist/expressions/calls/call-extension-methods.js.map +1 -0
- package/dist/expressions/calls/call-json.d.ts +15 -0
- package/dist/expressions/calls/call-json.d.ts.map +1 -0
- package/dist/expressions/calls/call-json.js +212 -0
- package/dist/expressions/calls/call-json.js.map +1 -0
- package/dist/expressions/calls/call-promise-chains.d.ts +7 -0
- package/dist/expressions/calls/call-promise-chains.d.ts.map +1 -0
- package/dist/expressions/calls/call-promise-chains.js +411 -0
- package/dist/expressions/calls/call-promise-chains.js.map +1 -0
- package/dist/expressions/calls/call-promise-ir-types.d.ts +11 -0
- package/dist/expressions/calls/call-promise-ir-types.d.ts.map +1 -0
- package/dist/expressions/calls/call-promise-ir-types.js +219 -0
- package/dist/expressions/calls/call-promise-ir-types.js.map +1 -0
- package/dist/expressions/calls/call-promise-normalization.d.ts +11 -0
- package/dist/expressions/calls/call-promise-normalization.d.ts.map +1 -0
- package/dist/expressions/calls/call-promise-normalization.js +179 -0
- package/dist/expressions/calls/call-promise-normalization.js.map +1 -0
- package/dist/expressions/calls/call-promise-static.d.ts +7 -0
- package/dist/expressions/calls/call-promise-static.d.ts.map +1 -0
- package/dist/expressions/calls/call-promise-static.js +188 -0
- package/dist/expressions/calls/call-promise-static.js.map +1 -0
- package/dist/expressions/calls/call-promise-task-types.d.ts +9 -0
- package/dist/expressions/calls/call-promise-task-types.d.ts.map +1 -0
- package/dist/expressions/calls/call-promise-task-types.js +88 -0
- package/dist/expressions/calls/call-promise-task-types.js.map +1 -0
- package/dist/expressions/calls/call-promise.d.ts +11 -0
- package/dist/expressions/calls/call-promise.d.ts.map +1 -0
- package/dist/expressions/calls/call-promise.js +11 -0
- package/dist/expressions/calls/call-promise.js.map +1 -0
- package/dist/expressions/calls/call-runtime-union-guards.d.ts +7 -0
- package/dist/expressions/calls/call-runtime-union-guards.d.ts.map +1 -0
- package/dist/expressions/calls/call-runtime-union-guards.js +131 -0
- package/dist/expressions/calls/call-runtime-union-guards.js.map +1 -0
- package/dist/expressions/calls/call-symbol.d.ts +7 -0
- package/dist/expressions/calls/call-symbol.d.ts.map +1 -0
- package/dist/expressions/calls/call-symbol.js +26 -0
- package/dist/expressions/calls/call-symbol.js.map +1 -0
- package/dist/expressions/calls/new-emitter-collections.d.ts +31 -0
- package/dist/expressions/calls/new-emitter-collections.d.ts.map +1 -0
- package/dist/expressions/calls/new-emitter-collections.js +310 -0
- package/dist/expressions/calls/new-emitter-collections.js.map +1 -0
- package/dist/expressions/calls/new-emitter-promise.d.ts +10 -0
- package/dist/expressions/calls/new-emitter-promise.d.ts.map +1 -0
- package/dist/expressions/calls/new-emitter-promise.js +437 -0
- package/dist/expressions/calls/new-emitter-promise.js.map +1 -0
- package/dist/expressions/calls/new-emitter.d.ts.map +1 -1
- package/dist/expressions/calls/new-emitter.js +34 -596
- package/dist/expressions/calls/new-emitter.js.map +1 -1
- package/dist/expressions/calls/runtime-expected-type-preference.d.ts +4 -0
- package/dist/expressions/calls/runtime-expected-type-preference.d.ts.map +1 -0
- package/dist/expressions/calls/runtime-expected-type-preference.js +61 -0
- package/dist/expressions/calls/runtime-expected-type-preference.js.map +1 -0
- package/dist/expressions/collections.d.ts +4 -18
- package/dist/expressions/collections.d.ts.map +1 -1
- package/dist/expressions/collections.js +3 -986
- package/dist/expressions/collections.js.map +1 -1
- package/dist/expressions/dictionary-literal.d.ts +20 -0
- package/dist/expressions/dictionary-literal.d.ts.map +1 -0
- package/dist/expressions/dictionary-literal.js +214 -0
- package/dist/expressions/dictionary-literal.js.map +1 -0
- package/dist/expressions/dictionary-safe-access.d.ts +4 -0
- package/dist/expressions/dictionary-safe-access.d.ts.map +1 -0
- package/dist/expressions/dictionary-safe-access.js +86 -0
- package/dist/expressions/dictionary-safe-access.js.map +1 -0
- package/dist/expressions/direct-storage-types.d.ts +10 -0
- package/dist/expressions/direct-storage-types.d.ts.map +1 -0
- package/dist/expressions/direct-storage-types.js +441 -0
- package/dist/expressions/direct-storage-types.js.map +1 -0
- package/dist/expressions/exact-comparison.d.ts +17 -0
- package/dist/expressions/exact-comparison.d.ts.map +1 -0
- package/dist/expressions/exact-comparison.js +240 -0
- package/dist/expressions/exact-comparison.js.map +1 -0
- package/dist/expressions/exact-global-bindings.d.ts +6 -0
- package/dist/expressions/exact-global-bindings.d.ts.map +1 -0
- package/dist/expressions/exact-global-bindings.js +15 -0
- package/dist/expressions/exact-global-bindings.js.map +1 -0
- package/dist/expressions/expected-type-adaptation.d.ts +55 -0
- package/dist/expressions/expected-type-adaptation.d.ts.map +1 -0
- package/dist/expressions/expected-type-adaptation.js +918 -0
- package/dist/expressions/expected-type-adaptation.js.map +1 -0
- package/dist/expressions/expected-type-adaptation.test.d.ts +2 -0
- package/dist/expressions/expected-type-adaptation.test.d.ts.map +1 -0
- package/dist/expressions/expected-type-adaptation.test.js +1363 -0
- package/dist/expressions/expected-type-adaptation.test.js.map +1 -0
- package/dist/expressions/functions.d.ts +6 -15
- package/dist/expressions/functions.d.ts.map +1 -1
- package/dist/expressions/functions.js +6 -219
- package/dist/expressions/functions.js.map +1 -1
- package/dist/expressions/identifier-storage.d.ts +43 -0
- package/dist/expressions/identifier-storage.d.ts.map +1 -0
- package/dist/expressions/identifier-storage.js +478 -0
- package/dist/expressions/identifier-storage.js.map +1 -0
- package/dist/expressions/identifiers.d.ts.map +1 -1
- package/dist/expressions/identifiers.js +145 -51
- package/dist/expressions/identifiers.js.map +1 -1
- package/dist/expressions/index-cases/alias-carrier-widening.test.d.ts +2 -0
- package/dist/expressions/index-cases/alias-carrier-widening.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/alias-carrier-widening.test.js +347 -0
- package/dist/expressions/index-cases/alias-carrier-widening.test.js.map +1 -0
- package/dist/expressions/index-cases/array-wrapper-recursion-b.test.d.ts +2 -0
- package/dist/expressions/index-cases/array-wrapper-recursion-b.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/array-wrapper-recursion-b.test.js +356 -0
- package/dist/expressions/index-cases/array-wrapper-recursion-b.test.js.map +1 -0
- package/dist/expressions/index-cases/array-wrapper-recursion-c.test.d.ts +2 -0
- package/dist/expressions/index-cases/array-wrapper-recursion-c.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/array-wrapper-recursion-c.test.js +233 -0
- package/dist/expressions/index-cases/array-wrapper-recursion-c.test.js.map +1 -0
- package/dist/expressions/index-cases/basic-literals-and-calls.test.d.ts +2 -0
- package/dist/expressions/index-cases/basic-literals-and-calls.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/basic-literals-and-calls.test.js +550 -0
- package/dist/expressions/index-cases/basic-literals-and-calls.test.js.map +1 -0
- package/dist/expressions/index-cases/defaults-and-char-context.test.d.ts +2 -0
- package/dist/expressions/index-cases/defaults-and-char-context.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/defaults-and-char-context.test.js +951 -0
- package/dist/expressions/index-cases/defaults-and-char-context.test.js.map +1 -0
- package/dist/expressions/index-cases/dictionary-and-object-initializers-a.test.d.ts +2 -0
- package/dist/expressions/index-cases/dictionary-and-object-initializers-a.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/dictionary-and-object-initializers-a.test.js +533 -0
- package/dist/expressions/index-cases/dictionary-and-object-initializers-a.test.js.map +1 -0
- package/dist/expressions/index-cases/dictionary-and-object-initializers-b.test.d.ts +2 -0
- package/dist/expressions/index-cases/dictionary-and-object-initializers-b.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/dictionary-and-object-initializers-b.test.js +336 -0
- package/dist/expressions/index-cases/dictionary-and-object-initializers-b.test.js.map +1 -0
- package/dist/expressions/index-cases/fluent-and-ef-operators.test.d.ts +2 -0
- package/dist/expressions/index-cases/fluent-and-ef-operators.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/fluent-and-ef-operators.test.js +352 -0
- package/dist/expressions/index-cases/fluent-and-ef-operators.test.js.map +1 -0
- package/dist/expressions/index-cases/helpers.d.ts +13 -0
- package/dist/expressions/index-cases/helpers.d.ts.map +1 -0
- package/dist/expressions/index-cases/helpers.js +27 -0
- package/dist/expressions/index-cases/helpers.js.map +1 -0
- package/dist/expressions/index-cases/member-access-and-array-wrappers-a.test.d.ts +2 -0
- package/dist/expressions/index-cases/member-access-and-array-wrappers-a.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/member-access-and-array-wrappers-a.test.js +429 -0
- package/dist/expressions/index-cases/member-access-and-array-wrappers-a.test.js.map +1 -0
- package/dist/expressions/index-cases/nullable-and-comparisons.test.d.ts +2 -0
- package/dist/expressions/index-cases/nullable-and-comparisons.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/nullable-and-comparisons.test.js +423 -0
- package/dist/expressions/index-cases/nullable-and-comparisons.test.js.map +1 -0
- package/dist/expressions/index-cases/runtime-subset-and-assertions.test.d.ts +2 -0
- package/dist/expressions/index-cases/runtime-subset-and-assertions.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/runtime-subset-and-assertions.test.js +482 -0
- package/dist/expressions/index-cases/runtime-subset-and-assertions.test.js.map +1 -0
- package/dist/expressions/index-cases/runtime-union-reification-a.test.d.ts +2 -0
- package/dist/expressions/index-cases/runtime-union-reification-a.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/runtime-union-reification-a.test.js +454 -0
- package/dist/expressions/index-cases/runtime-union-reification-a.test.js.map +1 -0
- package/dist/expressions/index-cases/runtime-union-reification-b.test.d.ts +2 -0
- package/dist/expressions/index-cases/runtime-union-reification-b.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/runtime-union-reification-b.test.js +852 -0
- package/dist/expressions/index-cases/runtime-union-reification-b.test.js.map +1 -0
- package/dist/expressions/index-cases/spreads-and-member-bindings.test.d.ts +2 -0
- package/dist/expressions/index-cases/spreads-and-member-bindings.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/spreads-and-member-bindings.test.js +616 -0
- package/dist/expressions/index-cases/spreads-and-member-bindings.test.js.map +1 -0
- package/dist/expressions/index-cases/string-and-array-fallbacks-a.test.d.ts +2 -0
- package/dist/expressions/index-cases/string-and-array-fallbacks-a.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/string-and-array-fallbacks-a.test.js +304 -0
- package/dist/expressions/index-cases/string-and-array-fallbacks-a.test.js.map +1 -0
- package/dist/expressions/index-cases/string-and-array-fallbacks-b.test.d.ts +2 -0
- package/dist/expressions/index-cases/string-and-array-fallbacks-b.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/string-and-array-fallbacks-b.test.js +369 -0
- package/dist/expressions/index-cases/string-and-array-fallbacks-b.test.js.map +1 -0
- package/dist/expressions/index-cases/tuple-rest-and-unions.test.d.ts +2 -0
- package/dist/expressions/index-cases/tuple-rest-and-unions.test.d.ts.map +1 -0
- package/dist/expressions/index-cases/tuple-rest-and-unions.test.js +392 -0
- package/dist/expressions/index-cases/tuple-rest-and-unions.test.js.map +1 -0
- package/dist/expressions/index.test.d.ts +17 -5
- package/dist/expressions/index.test.d.ts.map +1 -1
- package/dist/expressions/index.test.js +17 -2707
- package/dist/expressions/index.test.js.map +1 -1
- package/dist/expressions/invoked-lambda.d.ts +12 -0
- package/dist/expressions/invoked-lambda.d.ts.map +1 -0
- package/dist/expressions/invoked-lambda.js +69 -0
- package/dist/expressions/invoked-lambda.js.map +1 -0
- package/dist/expressions/lambda-body.d.ts +23 -0
- package/dist/expressions/lambda-body.d.ts.map +1 -0
- package/dist/expressions/lambda-body.js +421 -0
- package/dist/expressions/lambda-body.js.map +1 -0
- package/dist/expressions/lambda-parameters.d.ts +32 -0
- package/dist/expressions/lambda-parameters.d.ts.map +1 -0
- package/dist/expressions/lambda-parameters.js +279 -0
- package/dist/expressions/lambda-parameters.js.map +1 -0
- package/dist/expressions/literals.d.ts.map +1 -1
- package/dist/expressions/literals.js +25 -42
- package/dist/expressions/literals.js.map +1 -1
- package/dist/expressions/literals.test.js +48 -0
- package/dist/expressions/literals.test.js.map +1 -1
- package/dist/expressions/object-helpers.d.ts +22 -0
- package/dist/expressions/object-helpers.d.ts.map +1 -0
- package/dist/expressions/object-helpers.js +98 -0
- package/dist/expressions/object-helpers.js.map +1 -0
- package/dist/expressions/object-literal-spreads.d.ts +20 -0
- package/dist/expressions/object-literal-spreads.d.ts.map +1 -0
- package/dist/expressions/object-literal-spreads.js +188 -0
- package/dist/expressions/object-literal-spreads.js.map +1 -0
- package/dist/expressions/object-literal.d.ts +18 -0
- package/dist/expressions/object-literal.d.ts.map +1 -0
- package/dist/expressions/object-literal.js +178 -0
- package/dist/expressions/object-literal.js.map +1 -0
- package/dist/expressions/operators/assignment-emitter.d.ts.map +1 -1
- package/dist/expressions/operators/assignment-emitter.js +80 -33
- package/dist/expressions/operators/assignment-emitter.js.map +1 -1
- package/dist/expressions/operators/binary-dispatch.d.ts +37 -0
- package/dist/expressions/operators/binary-dispatch.d.ts.map +1 -0
- package/dist/expressions/operators/binary-dispatch.js +449 -0
- package/dist/expressions/operators/binary-dispatch.js.map +1 -0
- package/dist/expressions/operators/binary-emitter.d.ts +6 -29
- package/dist/expressions/operators/binary-emitter.d.ts.map +1 -1
- package/dist/expressions/operators/binary-emitter.js +6 -435
- package/dist/expressions/operators/binary-emitter.js.map +1 -1
- package/dist/expressions/operators/binary-helpers.d.ts +17 -0
- package/dist/expressions/operators/binary-helpers.d.ts.map +1 -0
- package/dist/expressions/operators/binary-helpers.js +119 -0
- package/dist/expressions/operators/binary-helpers.js.map +1 -0
- package/dist/expressions/operators/binary-runtime-union-comparison.d.ts +7 -0
- package/dist/expressions/operators/binary-runtime-union-comparison.d.ts.map +1 -0
- package/dist/expressions/operators/binary-runtime-union-comparison.js +150 -0
- package/dist/expressions/operators/binary-runtime-union-comparison.js.map +1 -0
- package/dist/expressions/operators/binary-special-ops.d.ts +29 -0
- package/dist/expressions/operators/binary-special-ops.d.ts.map +1 -0
- package/dist/expressions/operators/binary-special-ops.js +468 -0
- package/dist/expressions/operators/binary-special-ops.js.map +1 -0
- package/dist/expressions/operators/conditional-emitter.d.ts.map +1 -1
- package/dist/expressions/operators/conditional-emitter.js +221 -216
- package/dist/expressions/operators/conditional-emitter.js.map +1 -1
- package/dist/expressions/operators/helpers.d.ts +10 -0
- package/dist/expressions/operators/helpers.d.ts.map +1 -1
- package/dist/expressions/operators/helpers.js +30 -0
- package/dist/expressions/operators/helpers.js.map +1 -1
- package/dist/expressions/operators/logical-emitter.d.ts +2 -2
- package/dist/expressions/operators/logical-emitter.d.ts.map +1 -1
- package/dist/expressions/operators/logical-emitter.js +293 -12
- package/dist/expressions/operators/logical-emitter.js.map +1 -1
- package/dist/expressions/operators/unary-emitter.d.ts.map +1 -1
- package/dist/expressions/operators/unary-emitter.js +14 -40
- package/dist/expressions/operators/unary-emitter.js.map +1 -1
- package/dist/expressions/operators/write-targets.d.ts +5 -0
- package/dist/expressions/operators/write-targets.d.ts.map +1 -0
- package/dist/expressions/operators/write-targets.js +65 -0
- package/dist/expressions/operators/write-targets.js.map +1 -0
- package/dist/expressions/other.d.ts.map +1 -1
- package/dist/expressions/other.js +20 -58
- package/dist/expressions/other.js.map +1 -1
- package/dist/expressions/post-emission-adaptation.d.ts +19 -0
- package/dist/expressions/post-emission-adaptation.d.ts.map +1 -0
- package/dist/expressions/post-emission-adaptation.js +939 -0
- package/dist/expressions/post-emission-adaptation.js.map +1 -0
- package/dist/expressions/runtime-union-adaptation-projection.d.ts +12 -0
- package/dist/expressions/runtime-union-adaptation-projection.d.ts.map +1 -0
- package/dist/expressions/runtime-union-adaptation-projection.js +182 -0
- package/dist/expressions/runtime-union-adaptation-projection.js.map +1 -0
- package/dist/expressions/runtime-union-adaptation-upcast.d.ts +11 -0
- package/dist/expressions/runtime-union-adaptation-upcast.d.ts.map +1 -0
- package/dist/expressions/runtime-union-adaptation-upcast.js +722 -0
- package/dist/expressions/runtime-union-adaptation-upcast.js.map +1 -0
- package/dist/expressions/runtime-union-adaptation.d.ts +10 -0
- package/dist/expressions/runtime-union-adaptation.d.ts.map +1 -0
- package/dist/expressions/runtime-union-adaptation.js +10 -0
- package/dist/expressions/runtime-union-adaptation.js.map +1 -0
- package/dist/expressions/structural-adaptation-types.d.ts +12 -0
- package/dist/expressions/structural-adaptation-types.d.ts.map +1 -0
- package/dist/expressions/structural-adaptation-types.js +3 -0
- package/dist/expressions/structural-adaptation-types.js.map +1 -0
- package/dist/expressions/structural-adaptation.d.ts +16 -0
- package/dist/expressions/structural-adaptation.d.ts.map +1 -0
- package/dist/expressions/structural-adaptation.js +14 -0
- package/dist/expressions/structural-adaptation.js.map +1 -0
- package/dist/expressions/structural-anonymous-targets.d.ts +4 -0
- package/dist/expressions/structural-anonymous-targets.d.ts.map +1 -0
- package/dist/expressions/structural-anonymous-targets.js +156 -0
- package/dist/expressions/structural-anonymous-targets.js.map +1 -0
- package/dist/expressions/structural-collection-adaptation.d.ts +7 -0
- package/dist/expressions/structural-collection-adaptation.d.ts.map +1 -0
- package/dist/expressions/structural-collection-adaptation.js +682 -0
- package/dist/expressions/structural-collection-adaptation.js.map +1 -0
- package/dist/expressions/structural-object-adaptation.d.ts +6 -0
- package/dist/expressions/structural-object-adaptation.d.ts.map +1 -0
- package/dist/expressions/structural-object-adaptation.js +213 -0
- package/dist/expressions/structural-object-adaptation.js.map +1 -0
- package/dist/expressions/structural-property-model.d.ts +6 -0
- package/dist/expressions/structural-property-model.d.ts.map +1 -0
- package/dist/expressions/structural-property-model.js +304 -0
- package/dist/expressions/structural-property-model.js.map +1 -0
- package/dist/expressions/structural-type-shapes.d.ts +19 -0
- package/dist/expressions/structural-type-shapes.d.ts.map +1 -0
- package/dist/expressions/structural-type-shapes.js +318 -0
- package/dist/expressions/structural-type-shapes.js.map +1 -0
- package/dist/expressions/structural-type-shapes.test.d.ts +2 -0
- package/dist/expressions/structural-type-shapes.test.d.ts.map +1 -0
- package/dist/expressions/structural-type-shapes.test.js +60 -0
- package/dist/expressions/structural-type-shapes.test.js.map +1 -0
- package/dist/expressions/type-assertion-emitters.d.ts +50 -0
- package/dist/expressions/type-assertion-emitters.d.ts.map +1 -0
- package/dist/expressions/type-assertion-emitters.js +675 -0
- package/dist/expressions/type-assertion-emitters.js.map +1 -0
- package/dist/fixture-regression-mirrors.test.d.ts +2 -0
- package/dist/fixture-regression-mirrors.test.d.ts.map +1 -0
- package/dist/fixture-regression-mirrors.test.js +580 -0
- package/dist/fixture-regression-mirrors.test.js.map +1 -0
- package/dist/generated-files.d.ts +19 -0
- package/dist/generated-files.d.ts.map +1 -0
- package/dist/generated-files.js +519 -0
- package/dist/generated-files.js.map +1 -0
- package/dist/generated-files.test.d.ts +2 -0
- package/dist/generated-files.test.d.ts.map +1 -0
- package/dist/generated-files.test.js +103 -0
- package/dist/generated-files.test.js.map +1 -0
- package/dist/generator-cases/bidirectional-core.test.d.ts +6 -0
- package/dist/generator-cases/bidirectional-core.test.d.ts.map +1 -0
- package/dist/generator-cases/bidirectional-core.test.js +272 -0
- package/dist/generator-cases/bidirectional-core.test.js.map +1 -0
- package/dist/generator-cases/bidirectional-features.test.d.ts +6 -0
- package/dist/generator-cases/bidirectional-features.test.d.ts.map +1 -0
- package/dist/generator-cases/bidirectional-features.test.js +360 -0
- package/dist/generator-cases/bidirectional-features.test.js.map +1 -0
- package/dist/generator-cases/simple-generators.test.d.ts +6 -0
- package/dist/generator-cases/simple-generators.test.d.ts.map +1 -0
- package/dist/generator-cases/simple-generators.test.js +227 -0
- package/dist/generator-cases/simple-generators.test.js.map +1 -0
- package/dist/generator-exchange.d.ts +3 -2
- package/dist/generator-exchange.d.ts.map +1 -1
- package/dist/generator-exchange.js +49 -17
- package/dist/generator-exchange.js.map +1 -1
- package/dist/generator-wrapper-builders.d.ts +10 -0
- package/dist/generator-wrapper-builders.d.ts.map +1 -0
- package/dist/generator-wrapper-builders.js +288 -0
- package/dist/generator-wrapper-builders.js.map +1 -0
- package/dist/generator-wrapper.d.ts +16 -5
- package/dist/generator-wrapper.d.ts.map +1 -1
- package/dist/generator-wrapper.js +55 -325
- package/dist/generator-wrapper.js.map +1 -1
- package/dist/generator.test.d.ts +3 -5
- package/dist/generator.test.d.ts.map +1 -1
- package/dist/generator.test.js +3 -766
- package/dist/generator.test.js.map +1 -1
- package/dist/golden-tests/config-parser.d.ts.map +1 -1
- package/dist/golden-tests/config-parser.js +7 -0
- package/dist/golden-tests/config-parser.js.map +1 -1
- package/dist/golden-tests/discovery.js +1 -0
- package/dist/golden-tests/discovery.js.map +1 -1
- package/dist/golden-tests/runner.d.ts.map +1 -1
- package/dist/golden-tests/runner.js +12 -40
- package/dist/golden-tests/runner.js.map +1 -1
- package/dist/golden-tests/types.d.ts +2 -0
- package/dist/golden-tests/types.d.ts.map +1 -1
- package/dist/hierarchical-bindings.test.js +6 -9
- package/dist/hierarchical-bindings.test.js.map +1 -1
- package/dist/integration-cases/arrow-and-generics-a.test.d.ts +2 -0
- package/dist/integration-cases/arrow-and-generics-a.test.d.ts.map +1 -0
- package/dist/integration-cases/arrow-and-generics-a.test.js +695 -0
- package/dist/integration-cases/arrow-and-generics-a.test.js.map +1 -0
- package/dist/integration-cases/arrow-and-generics-b.test.d.ts +2 -0
- package/dist/integration-cases/arrow-and-generics-b.test.d.ts.map +1 -0
- package/dist/integration-cases/arrow-and-generics-b.test.js +218 -0
- package/dist/integration-cases/arrow-and-generics-b.test.js.map +1 -0
- package/dist/integration-cases/await-and-intrinsics.test.d.ts +2 -0
- package/dist/integration-cases/await-and-intrinsics.test.d.ts.map +1 -0
- package/dist/integration-cases/await-and-intrinsics.test.js +237 -0
- package/dist/integration-cases/await-and-intrinsics.test.js.map +1 -0
- package/dist/integration-cases/clr-iterable-overloads.test.d.ts +2 -0
- package/dist/integration-cases/clr-iterable-overloads.test.d.ts.map +1 -0
- package/dist/integration-cases/clr-iterable-overloads.test.js +446 -0
- package/dist/integration-cases/clr-iterable-overloads.test.js.map +1 -0
- package/dist/integration-cases/full-module-and-promises.test.d.ts +2 -0
- package/dist/integration-cases/full-module-and-promises.test.d.ts.map +1 -0
- package/dist/integration-cases/full-module-and-promises.test.js +472 -0
- package/dist/integration-cases/full-module-and-promises.test.js.map +1 -0
- package/dist/integration-cases/helpers.d.ts +7 -0
- package/dist/integration-cases/helpers.d.ts.map +1 -0
- package/dist/integration-cases/helpers.js +348 -0
- package/dist/integration-cases/helpers.js.map +1 -0
- package/dist/integration-cases/object-literals-and-channels.test.d.ts +2 -0
- package/dist/integration-cases/object-literals-and-channels.test.d.ts.map +1 -0
- package/dist/integration-cases/object-literals-and-channels.test.js +72 -0
- package/dist/integration-cases/object-literals-and-channels.test.js.map +1 -0
- package/dist/integration-cases/regression-coverage-a.test.d.ts +2 -0
- package/dist/integration-cases/regression-coverage-a.test.d.ts.map +1 -0
- package/dist/integration-cases/regression-coverage-a.test.js +533 -0
- package/dist/integration-cases/regression-coverage-a.test.js.map +1 -0
- package/dist/integration-cases/regression-coverage-b.test.d.ts +2 -0
- package/dist/integration-cases/regression-coverage-b.test.d.ts.map +1 -0
- package/dist/integration-cases/regression-coverage-b.test.js +806 -0
- package/dist/integration-cases/regression-coverage-b.test.js.map +1 -0
- package/dist/integration-cases/regression-coverage-c.test.d.ts +2 -0
- package/dist/integration-cases/regression-coverage-c.test.d.ts.map +1 -0
- package/dist/integration-cases/regression-coverage-c.test.js +4139 -0
- package/dist/integration-cases/regression-coverage-c.test.js.map +1 -0
- package/dist/integration.test.d.ts +9 -5
- package/dist/integration.test.d.ts.map +1 -1
- package/dist/integration.test.js +9 -1223
- package/dist/integration.test.js.map +1 -1
- package/dist/invariants/numeric-proof-contract-cases/emitter-and-annotations.test.d.ts +5 -0
- package/dist/invariants/numeric-proof-contract-cases/emitter-and-annotations.test.d.ts.map +1 -0
- package/dist/invariants/numeric-proof-contract-cases/emitter-and-annotations.test.js +93 -0
- package/dist/invariants/numeric-proof-contract-cases/emitter-and-annotations.test.js.map +1 -0
- package/dist/invariants/numeric-proof-contract-cases/helpers.d.ts +14 -0
- package/dist/invariants/numeric-proof-contract-cases/helpers.d.ts.map +1 -0
- package/dist/invariants/numeric-proof-contract-cases/helpers.js +158 -0
- package/dist/invariants/numeric-proof-contract-cases/helpers.js.map +1 -0
- package/dist/invariants/numeric-proof-contract-cases/proof-and-diagnostics.test.d.ts +5 -0
- package/dist/invariants/numeric-proof-contract-cases/proof-and-diagnostics.test.d.ts.map +1 -0
- package/dist/invariants/numeric-proof-contract-cases/proof-and-diagnostics.test.js +242 -0
- package/dist/invariants/numeric-proof-contract-cases/proof-and-diagnostics.test.js.map +1 -0
- package/dist/invariants/numeric-proof-contract.test.d.ts +2 -18
- package/dist/invariants/numeric-proof-contract.test.d.ts.map +1 -1
- package/dist/invariants/numeric-proof-contract.test.js +2 -510
- package/dist/invariants/numeric-proof-contract.test.js.map +1 -1
- package/dist/json-aot-generic.test.js +323 -5
- package/dist/json-aot-generic.test.js.map +1 -1
- package/dist/naming-policy.d.ts.map +1 -1
- package/dist/naming-policy.js +19 -0
- package/dist/naming-policy.js.map +1 -1
- package/dist/patterns/local-lowering.d.ts +27 -0
- package/dist/patterns/local-lowering.d.ts.map +1 -0
- package/dist/patterns/local-lowering.js +296 -0
- package/dist/patterns/local-lowering.js.map +1 -0
- package/dist/patterns/static-assignment-lowering.d.ts +11 -0
- package/dist/patterns/static-assignment-lowering.d.ts.map +1 -0
- package/dist/patterns/static-assignment-lowering.js +11 -0
- package/dist/patterns/static-assignment-lowering.js.map +1 -0
- package/dist/patterns/static-lowering-assignments.d.ts +16 -0
- package/dist/patterns/static-lowering-assignments.d.ts.map +1 -0
- package/dist/patterns/static-lowering-assignments.js +269 -0
- package/dist/patterns/static-lowering-assignments.js.map +1 -0
- package/dist/patterns/static-lowering-members.d.ts +15 -0
- package/dist/patterns/static-lowering-members.d.ts.map +1 -0
- package/dist/patterns/static-lowering-members.js +231 -0
- package/dist/patterns/static-lowering-members.js.map +1 -0
- package/dist/patterns-cases/array-and-object.test.d.ts +2 -0
- package/dist/patterns-cases/array-and-object.test.d.ts.map +1 -0
- package/dist/patterns-cases/array-and-object.test.js +370 -0
- package/dist/patterns-cases/array-and-object.test.js.map +1 -0
- package/dist/patterns-cases/assignments-and-complex.test.d.ts +2 -0
- package/dist/patterns-cases/assignments-and-complex.test.d.ts.map +1 -0
- package/dist/patterns-cases/assignments-and-complex.test.js +361 -0
- package/dist/patterns-cases/assignments-and-complex.test.js.map +1 -0
- package/dist/patterns-cases/edge-cases.test.d.ts +2 -0
- package/dist/patterns-cases/edge-cases.test.d.ts.map +1 -0
- package/dist/patterns-cases/edge-cases.test.js +133 -0
- package/dist/patterns-cases/edge-cases.test.js.map +1 -0
- package/dist/patterns-cases/helpers.d.ts +6 -0
- package/dist/patterns-cases/helpers.d.ts.map +1 -0
- package/dist/patterns-cases/helpers.js +33 -0
- package/dist/patterns-cases/helpers.js.map +1 -0
- package/dist/patterns-cases/loops-and-parameters.test.d.ts +2 -0
- package/dist/patterns-cases/loops-and-parameters.test.d.ts.map +1 -0
- package/dist/patterns-cases/loops-and-parameters.test.js +275 -0
- package/dist/patterns-cases/loops-and-parameters.test.js.map +1 -0
- package/dist/patterns-cases/methods-and-semantic-infra.test.d.ts +2 -0
- package/dist/patterns-cases/methods-and-semantic-infra.test.d.ts.map +1 -0
- package/dist/patterns-cases/methods-and-semantic-infra.test.js +438 -0
- package/dist/patterns-cases/methods-and-semantic-infra.test.js.map +1 -0
- package/dist/patterns.d.ts +5 -20
- package/dist/patterns.d.ts.map +1 -1
- package/dist/patterns.js +3 -830
- package/dist/patterns.js.map +1 -1
- package/dist/patterns.test.d.ts +5 -14
- package/dist/patterns.test.d.ts.map +1 -1
- package/dist/patterns.test.js +5 -1341
- package/dist/patterns.test.js.map +1 -1
- package/dist/runtime-union-cases/helpers.d.ts +7 -0
- package/dist/runtime-union-cases/helpers.d.ts.map +1 -0
- package/dist/runtime-union-cases/helpers.js +17 -0
- package/dist/runtime-union-cases/helpers.js.map +1 -0
- package/dist/specialization/generic-functions-cases/basics-and-structural.test.d.ts +6 -0
- package/dist/specialization/generic-functions-cases/basics-and-structural.test.d.ts.map +1 -0
- package/dist/specialization/generic-functions-cases/basics-and-structural.test.js +357 -0
- package/dist/specialization/generic-functions-cases/basics-and-structural.test.js.map +1 -0
- package/dist/specialization/generic-functions-cases/class-and-interface-constraints.test.d.ts +6 -0
- package/dist/specialization/generic-functions-cases/class-and-interface-constraints.test.d.ts.map +1 -0
- package/dist/specialization/generic-functions-cases/class-and-interface-constraints.test.js +304 -0
- package/dist/specialization/generic-functions-cases/class-and-interface-constraints.test.js.map +1 -0
- package/dist/specialization/generic-functions.test.d.ts +2 -5
- package/dist/specialization/generic-functions.test.d.ts.map +1 -1
- package/dist/specialization/generic-functions.test.js +2 -650
- package/dist/specialization/generic-functions.test.js.map +1 -1
- package/dist/specialization/helpers.d.ts.map +1 -1
- package/dist/specialization/helpers.js +2 -16
- package/dist/specialization/helpers.js.map +1 -1
- package/dist/specialization/interfaces.test.js +58 -0
- package/dist/specialization/interfaces.test.js.map +1 -1
- package/dist/specialization/naming.d.ts.map +1 -1
- package/dist/specialization/naming.js +9 -2
- package/dist/specialization/naming.js.map +1 -1
- package/dist/statements/block-emitters/block-and-return.d.ts +10 -0
- package/dist/statements/block-emitters/block-and-return.d.ts.map +1 -0
- package/dist/statements/block-emitters/block-and-return.js +132 -0
- package/dist/statements/block-emitters/block-and-return.js.map +1 -0
- package/dist/statements/block-emitters/expression-statements.d.ts +7 -0
- package/dist/statements/block-emitters/expression-statements.d.ts.map +1 -0
- package/dist/statements/block-emitters/expression-statements.js +72 -0
- package/dist/statements/block-emitters/expression-statements.js.map +1 -0
- package/dist/statements/block-emitters/yield-statements.d.ts +13 -0
- package/dist/statements/block-emitters/yield-statements.d.ts.map +1 -0
- package/dist/statements/block-emitters/yield-statements.js +217 -0
- package/dist/statements/block-emitters/yield-statements.js.map +1 -0
- package/dist/statements/blocks.d.ts +3 -86
- package/dist/statements/blocks.d.ts.map +1 -1
- package/dist/statements/blocks.js +3 -443
- package/dist/statements/blocks.js.map +1 -1
- package/dist/statements/classes/members/constructors.d.ts.map +1 -1
- package/dist/statements/classes/members/constructors.js +105 -13
- package/dist/statements/classes/members/constructors.js.map +1 -1
- package/dist/statements/classes/members/methods.d.ts +1 -1
- package/dist/statements/classes/members/methods.d.ts.map +1 -1
- package/dist/statements/classes/members/methods.js +330 -83
- package/dist/statements/classes/members/methods.js.map +1 -1
- package/dist/statements/classes/members/orchestrator.d.ts +3 -3
- package/dist/statements/classes/members/orchestrator.d.ts.map +1 -1
- package/dist/statements/classes/members/orchestrator.js +10 -4
- package/dist/statements/classes/members/orchestrator.js.map +1 -1
- package/dist/statements/classes/members/properties.d.ts.map +1 -1
- package/dist/statements/classes/members/properties.js +29 -5
- package/dist/statements/classes/members/properties.js.map +1 -1
- package/dist/statements/classes/members/shadowing.test.js +3 -2
- package/dist/statements/classes/members/shadowing.test.js.map +1 -1
- package/dist/statements/classes/parameters.d.ts +9 -1
- package/dist/statements/classes/parameters.d.ts.map +1 -1
- package/dist/statements/classes/parameters.js +88 -7
- package/dist/statements/classes/parameters.js.map +1 -1
- package/dist/statements/classes/properties.d.ts.map +1 -1
- package/dist/statements/classes/properties.js +7 -17
- package/dist/statements/classes/properties.js.map +1 -1
- package/dist/statements/control/conditionals/branch-context.d.ts +58 -0
- package/dist/statements/control/conditionals/branch-context.d.ts.map +1 -0
- package/dist/statements/control/conditionals/branch-context.js +530 -0
- package/dist/statements/control/conditionals/branch-context.js.map +1 -0
- package/dist/statements/control/conditionals/branch-context.test.d.ts +2 -0
- package/dist/statements/control/conditionals/branch-context.test.d.ts.map +1 -0
- package/dist/statements/control/conditionals/branch-context.test.js +34 -0
- package/dist/statements/control/conditionals/branch-context.test.js.map +1 -0
- package/dist/statements/control/conditionals/guard-analysis.d.ts +8 -207
- package/dist/statements/control/conditionals/guard-analysis.d.ts.map +1 -1
- package/dist/statements/control/conditionals/guard-analysis.js +8 -750
- package/dist/statements/control/conditionals/guard-analysis.js.map +1 -1
- package/dist/statements/control/conditionals/guard-detectors-discriminant.d.ts +20 -0
- package/dist/statements/control/conditionals/guard-detectors-discriminant.d.ts.map +1 -0
- package/dist/statements/control/conditionals/guard-detectors-discriminant.js +214 -0
- package/dist/statements/control/conditionals/guard-detectors-discriminant.js.map +1 -0
- package/dist/statements/control/conditionals/guard-detectors-structural.d.ts +32 -0
- package/dist/statements/control/conditionals/guard-detectors-structural.d.ts.map +1 -0
- package/dist/statements/control/conditionals/guard-detectors-structural.js +302 -0
- package/dist/statements/control/conditionals/guard-detectors-structural.js.map +1 -0
- package/dist/statements/control/conditionals/guard-detectors.d.ts +11 -0
- package/dist/statements/control/conditionals/guard-detectors.d.ts.map +1 -0
- package/dist/statements/control/conditionals/guard-detectors.js +11 -0
- package/dist/statements/control/conditionals/guard-detectors.js.map +1 -0
- package/dist/statements/control/conditionals/guard-extraction.d.ts +30 -0
- package/dist/statements/control/conditionals/guard-extraction.d.ts.map +1 -0
- package/dist/statements/control/conditionals/guard-extraction.js +304 -0
- package/dist/statements/control/conditionals/guard-extraction.js.map +1 -0
- package/dist/statements/control/conditionals/guard-types.d.ts +214 -0
- package/dist/statements/control/conditionals/guard-types.d.ts.map +1 -0
- package/dist/statements/control/conditionals/guard-types.js +242 -0
- package/dist/statements/control/conditionals/guard-types.js.map +1 -0
- package/dist/statements/control/conditionals/if-emit-instanceof-guards.d.ts +28 -0
- package/dist/statements/control/conditionals/if-emit-instanceof-guards.d.ts.map +1 -0
- package/dist/statements/control/conditionals/if-emit-instanceof-guards.js +261 -0
- package/dist/statements/control/conditionals/if-emit-instanceof-guards.js.map +1 -0
- package/dist/statements/control/conditionals/if-emit-predicate-guards.d.ts +24 -0
- package/dist/statements/control/conditionals/if-emit-predicate-guards.d.ts.map +1 -0
- package/dist/statements/control/conditionals/if-emit-predicate-guards.js +165 -0
- package/dist/statements/control/conditionals/if-emit-predicate-guards.js.map +1 -0
- package/dist/statements/control/conditionals/if-emit-property-discriminant-guards.d.ts +24 -0
- package/dist/statements/control/conditionals/if-emit-property-discriminant-guards.d.ts.map +1 -0
- package/dist/statements/control/conditionals/if-emit-property-discriminant-guards.js +391 -0
- package/dist/statements/control/conditionals/if-emit-property-discriminant-guards.js.map +1 -0
- package/dist/statements/control/conditionals/if-emit-type-guards.d.ts +10 -0
- package/dist/statements/control/conditionals/if-emit-type-guards.d.ts.map +1 -0
- package/dist/statements/control/conditionals/if-emit-type-guards.js +10 -0
- package/dist/statements/control/conditionals/if-emit-type-guards.js.map +1 -0
- package/dist/statements/control/conditionals/if-emit-typeof-array-guards.d.ts +23 -0
- package/dist/statements/control/conditionals/if-emit-typeof-array-guards.d.ts.map +1 -0
- package/dist/statements/control/conditionals/if-emit-typeof-array-guards.js +264 -0
- package/dist/statements/control/conditionals/if-emit-typeof-array-guards.js.map +1 -0
- package/dist/statements/control/conditionals/if-emit-union-guards.d.ts +10 -0
- package/dist/statements/control/conditionals/if-emit-union-guards.d.ts.map +1 -0
- package/dist/statements/control/conditionals/if-emit-union-guards.js +10 -0
- package/dist/statements/control/conditionals/if-emit-union-guards.js.map +1 -0
- package/dist/statements/control/conditionals/if-emitter.d.ts +6 -3
- package/dist/statements/control/conditionals/if-emitter.d.ts.map +1 -1
- package/dist/statements/control/conditionals/if-emitter.js +99 -911
- package/dist/statements/control/conditionals/if-emitter.js.map +1 -1
- package/dist/statements/control/exceptions.d.ts.map +1 -1
- package/dist/statements/control/exceptions.js +21 -6
- package/dist/statements/control/exceptions.js.map +1 -1
- package/dist/statements/control/loop-helpers.d.ts +13 -0
- package/dist/statements/control/loop-helpers.d.ts.map +1 -0
- package/dist/statements/control/loop-helpers.js +75 -0
- package/dist/statements/control/loop-helpers.js.map +1 -0
- package/dist/statements/control/loops.d.ts.map +1 -1
- package/dist/statements/control/loops.js +88 -174
- package/dist/statements/control/loops.js.map +1 -1
- package/dist/statements/declarations/class-emitter-helpers.d.ts +17 -0
- package/dist/statements/declarations/class-emitter-helpers.d.ts.map +1 -0
- package/dist/statements/declarations/class-emitter-helpers.js +126 -0
- package/dist/statements/declarations/class-emitter-helpers.js.map +1 -0
- package/dist/statements/declarations/classes.d.ts.map +1 -1
- package/dist/statements/declarations/classes.js +104 -31
- package/dist/statements/declarations/classes.js.map +1 -1
- package/dist/statements/declarations/function-local-emitter.d.ts +7 -0
- package/dist/statements/declarations/function-local-emitter.d.ts.map +1 -0
- package/dist/statements/declarations/function-local-emitter.js +363 -0
- package/dist/statements/declarations/function-local-emitter.js.map +1 -0
- package/dist/statements/declarations/function-module-emitter.d.ts +7 -0
- package/dist/statements/declarations/function-module-emitter.d.ts.map +1 -0
- package/dist/statements/declarations/function-module-emitter.js +372 -0
- package/dist/statements/declarations/function-module-emitter.js.map +1 -0
- package/dist/statements/declarations/function-shared.d.ts +43 -0
- package/dist/statements/declarations/function-shared.d.ts.map +1 -0
- package/dist/statements/declarations/function-shared.js +246 -0
- package/dist/statements/declarations/function-shared.js.map +1 -0
- package/dist/statements/declarations/functions.d.ts +2 -27
- package/dist/statements/declarations/functions.d.ts.map +1 -1
- package/dist/statements/declarations/functions.js +2 -739
- package/dist/statements/declarations/functions.js.map +1 -1
- package/dist/statements/declarations/interfaces-mutable-storage.test.js +10 -2
- package/dist/statements/declarations/interfaces-mutable-storage.test.js.map +1 -1
- package/dist/statements/declarations/interfaces.d.ts.map +1 -1
- package/dist/statements/declarations/interfaces.js +29 -21
- package/dist/statements/declarations/interfaces.js.map +1 -1
- package/dist/statements/declarations/type-aliases.d.ts.map +1 -1
- package/dist/statements/declarations/type-aliases.js +6 -12
- package/dist/statements/declarations/type-aliases.js.map +1 -1
- package/dist/statements/declarations/variable-local-type.d.ts +36 -0
- package/dist/statements/declarations/variable-local-type.d.ts.map +1 -0
- package/dist/statements/declarations/variable-local-type.js +122 -0
- package/dist/statements/declarations/variable-local-type.js.map +1 -0
- package/dist/statements/declarations/variable-static-arrow.d.ts +47 -0
- package/dist/statements/declarations/variable-static-arrow.d.ts.map +1 -0
- package/dist/statements/declarations/variable-static-arrow.js +363 -0
- package/dist/statements/declarations/variable-static-arrow.js.map +1 -0
- package/dist/statements/declarations/variable-type-helpers.d.ts +86 -0
- package/dist/statements/declarations/variable-type-helpers.d.ts.map +1 -0
- package/dist/statements/declarations/variable-type-helpers.js +242 -0
- package/dist/statements/declarations/variable-type-helpers.js.map +1 -0
- package/dist/statements/declarations/variable-type-resolution.d.ts +11 -0
- package/dist/statements/declarations/variable-type-resolution.d.ts.map +1 -0
- package/dist/statements/declarations/variable-type-resolution.js +11 -0
- package/dist/statements/declarations/variable-type-resolution.js.map +1 -0
- package/dist/statements/declarations/variables.d.ts +5 -1
- package/dist/statements/declarations/variables.d.ts.map +1 -1
- package/dist/statements/declarations/variables.js +116 -594
- package/dist/statements/declarations/variables.js.map +1 -1
- package/dist/statements/index.test.d.ts +10 -5
- package/dist/statements/index.test.d.ts.map +1 -1
- package/dist/statements/index.test.js +10 -1883
- package/dist/statements/index.test.js.map +1 -1
- package/dist/statements/parameter-defaults.d.ts +17 -0
- package/dist/statements/parameter-defaults.d.ts.map +1 -0
- package/dist/statements/parameter-defaults.js +122 -0
- package/dist/statements/parameter-defaults.js.map +1 -0
- package/dist/statements/statement-cases/async-returns.test.d.ts +2 -0
- package/dist/statements/statement-cases/async-returns.test.d.ts.map +1 -0
- package/dist/statements/statement-cases/async-returns.test.js +311 -0
- package/dist/statements/statement-cases/async-returns.test.js.map +1 -0
- package/dist/statements/statement-cases/flow-and-void.test.d.ts +2 -0
- package/dist/statements/statement-cases/flow-and-void.test.d.ts.map +1 -0
- package/dist/statements/statement-cases/flow-and-void.test.js +405 -0
- package/dist/statements/statement-cases/flow-and-void.test.js.map +1 -0
- package/dist/statements/statement-cases/helpers.d.ts +6 -0
- package/dist/statements/statement-cases/helpers.d.ts.map +1 -0
- package/dist/statements/statement-cases/helpers.js +4 -0
- package/dist/statements/statement-cases/helpers.js.map +1 -0
- package/dist/statements/statement-cases/if-and-instanceof-guards.test.d.ts +2 -0
- package/dist/statements/statement-cases/if-and-instanceof-guards.test.d.ts.map +1 -0
- package/dist/statements/statement-cases/if-and-instanceof-guards.test.js +826 -0
- package/dist/statements/statement-cases/if-and-instanceof-guards.test.js.map +1 -0
- package/dist/statements/statement-cases/loops.test.d.ts +2 -0
- package/dist/statements/statement-cases/loops.test.d.ts.map +1 -0
- package/dist/statements/statement-cases/loops.test.js +433 -0
- package/dist/statements/statement-cases/loops.test.js.map +1 -0
- package/dist/statements/statement-cases/scopes-and-storage.test.d.ts +2 -0
- package/dist/statements/statement-cases/scopes-and-storage.test.d.ts.map +1 -0
- package/dist/statements/statement-cases/scopes-and-storage.test.js +216 -0
- package/dist/statements/statement-cases/scopes-and-storage.test.js.map +1 -0
- package/dist/statements/statement-cases/union-guards-basic.test.d.ts +2 -0
- package/dist/statements/statement-cases/union-guards-basic.test.d.ts.map +1 -0
- package/dist/statements/statement-cases/union-guards-basic.test.js +235 -0
- package/dist/statements/statement-cases/union-guards-basic.test.js.map +1 -0
- package/dist/statements/statement-cases/union-guards-nullish-and-object.test.d.ts +2 -0
- package/dist/statements/statement-cases/union-guards-nullish-and-object.test.d.ts.map +1 -0
- package/dist/statements/statement-cases/union-guards-nullish-and-object.test.js +265 -0
- package/dist/statements/statement-cases/union-guards-nullish-and-object.test.js.map +1 -0
- package/dist/statements/statement-cases/union-guards-predicate-and-truthy.test.d.ts +2 -0
- package/dist/statements/statement-cases/union-guards-predicate-and-truthy.test.d.ts.map +1 -0
- package/dist/statements/statement-cases/union-guards-predicate-and-truthy.test.js +630 -0
- package/dist/statements/statement-cases/union-guards-predicate-and-truthy.test.js.map +1 -0
- package/dist/statements/statement-cases/union-guards-remapped-a.test.d.ts +2 -0
- package/dist/statements/statement-cases/union-guards-remapped-a.test.d.ts.map +1 -0
- package/dist/statements/statement-cases/union-guards-remapped-a.test.js +382 -0
- package/dist/statements/statement-cases/union-guards-remapped-a.test.js.map +1 -0
- package/dist/statements/statement-cases/union-guards-remapped-b.test.d.ts +2 -0
- package/dist/statements/statement-cases/union-guards-remapped-b.test.d.ts.map +1 -0
- package/dist/statements/statement-cases/union-guards-remapped-b.test.js +397 -0
- package/dist/statements/statement-cases/union-guards-remapped-b.test.js.map +1 -0
- package/dist/type-assertion.test.js +258 -10
- package/dist/type-assertion.test.js.map +1 -1
- package/dist/types/arrays.d.ts.map +1 -1
- package/dist/types/arrays.js +10 -1
- package/dist/types/arrays.js.map +1 -1
- package/dist/types/dictionaries.d.ts.map +1 -1
- package/dist/types/dictionaries.js +5 -5
- package/dist/types/dictionaries.js.map +1 -1
- package/dist/types/emitter.d.ts.map +1 -1
- package/dist/types/emitter.js +129 -24
- package/dist/types/emitter.js.map +1 -1
- package/dist/types/functions.d.ts.map +1 -1
- package/dist/types/functions.js +5 -25
- package/dist/types/functions.js.map +1 -1
- package/dist/types/index.test.js +205 -1
- package/dist/types/index.test.js.map +1 -1
- package/dist/types/objects.d.ts +2 -2
- package/dist/types/objects.d.ts.map +1 -1
- package/dist/types/objects.js +2 -2
- package/dist/types/objects.js.map +1 -1
- package/dist/types/parameters.d.ts.map +1 -1
- package/dist/types/parameters.js +88 -18
- package/dist/types/parameters.js.map +1 -1
- package/dist/types/primitives.d.ts.map +1 -1
- package/dist/types/primitives.js.map +1 -1
- package/dist/types/reference-lookup.d.ts +16 -0
- package/dist/types/reference-lookup.d.ts.map +1 -0
- package/dist/types/reference-lookup.js +133 -0
- package/dist/types/reference-lookup.js.map +1 -0
- package/dist/types/reference-structural-signatures.d.ts +10 -0
- package/dist/types/reference-structural-signatures.d.ts.map +1 -0
- package/dist/types/reference-structural-signatures.js +310 -0
- package/dist/types/reference-structural-signatures.js.map +1 -0
- package/dist/types/references-cases/array-and-cross-module.test.d.ts +2 -0
- package/dist/types/references-cases/array-and-cross-module.test.d.ts.map +1 -0
- package/dist/types/references-cases/array-and-cross-module.test.js +150 -0
- package/dist/types/references-cases/array-and-cross-module.test.js.map +1 -0
- package/dist/types/references-cases/bindings-and-local.test.d.ts +2 -0
- package/dist/types/references-cases/bindings-and-local.test.d.ts.map +1 -0
- package/dist/types/references-cases/bindings-and-local.test.js +368 -0
- package/dist/types/references-cases/bindings-and-local.test.js.map +1 -0
- package/dist/types/references-cases/helpers.d.ts +14 -0
- package/dist/types/references-cases/helpers.d.ts.map +1 -0
- package/dist/types/references-cases/helpers.js +39 -0
- package/dist/types/references-cases/helpers.js.map +1 -0
- package/dist/types/references-cases/polymorphic-and-recursive.test.d.ts +2 -0
- package/dist/types/references-cases/polymorphic-and-recursive.test.d.ts.map +1 -0
- package/dist/types/references-cases/polymorphic-and-recursive.test.js +387 -0
- package/dist/types/references-cases/polymorphic-and-recursive.test.js.map +1 -0
- package/dist/types/references-cases/primitive-and-builtins.test.d.ts +2 -0
- package/dist/types/references-cases/primitive-and-builtins.test.d.ts.map +1 -0
- package/dist/types/references-cases/primitive-and-builtins.test.js +116 -0
- package/dist/types/references-cases/primitive-and-builtins.test.js.map +1 -0
- package/dist/types/references-cases/resolved-and-imported.test.d.ts +2 -0
- package/dist/types/references-cases/resolved-and-imported.test.d.ts.map +1 -0
- package/dist/types/references-cases/resolved-and-imported.test.js +669 -0
- package/dist/types/references-cases/resolved-and-imported.test.js.map +1 -0
- package/dist/types/references.d.ts.map +1 -1
- package/dist/types/references.js +279 -250
- package/dist/types/references.js.map +1 -1
- package/dist/types/references.test.d.ts +5 -10
- package/dist/types/references.test.d.ts.map +1 -1
- package/dist/types/references.test.js +5 -718
- package/dist/types/references.test.js.map +1 -1
- package/dist/types/tuples.d.ts.map +1 -1
- package/dist/types/tuples.js +7 -17
- package/dist/types/tuples.js.map +1 -1
- package/dist/types/unions-cases/basic-and-ordering.test.d.ts +6 -0
- package/dist/types/unions-cases/basic-and-ordering.test.d.ts.map +1 -0
- package/dist/types/unions-cases/basic-and-ordering.test.js +322 -0
- package/dist/types/unions-cases/basic-and-ordering.test.js.map +1 -0
- package/dist/types/unions-cases/large-and-fallback.test.d.ts +6 -0
- package/dist/types/unions-cases/large-and-fallback.test.d.ts.map +1 -0
- package/dist/types/unions-cases/large-and-fallback.test.js +246 -0
- package/dist/types/unions-cases/large-and-fallback.test.js.map +1 -0
- package/dist/types/unions-cases/multi-surface.test.d.ts +6 -0
- package/dist/types/unions-cases/multi-surface.test.d.ts.map +1 -0
- package/dist/types/unions-cases/multi-surface.test.js +268 -0
- package/dist/types/unions-cases/multi-surface.test.js.map +1 -0
- package/dist/types/unions.d.ts +1 -1
- package/dist/types/unions.d.ts.map +1 -1
- package/dist/types/unions.js +60 -68
- package/dist/types/unions.js.map +1 -1
- package/dist/types/unions.test.d.ts +3 -5
- package/dist/types/unions.test.d.ts.map +1 -1
- package/dist/types/unions.test.js +3 -413
- package/dist/types/unions.test.js.map +1 -1
- package/package.json +4 -4
- package/dist/expressions/parentheses.d.ts +0 -4
- package/dist/expressions/parentheses.d.ts.map +0 -1
- package/dist/expressions/parentheses.js +0 -91
- package/dist/expressions/parentheses.js.map +0 -1
|
@@ -0,0 +1,255 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Structural shape matching and structural-to-nominal type resolution.
|
|
3
|
+
*
|
|
4
|
+
* Extracted from structural-resolution.ts — contains structural shape
|
|
5
|
+
* comparison logic and the normalizeStructuralEmissionType deep walker.
|
|
6
|
+
*/
|
|
7
|
+
import { resolveTypeAlias, stripNullish } from "./nullish-value-helpers.js";
|
|
8
|
+
import { rebuildUnionTypePreservingCarrierFamily } from "./runtime-union-family-preservation.js";
|
|
9
|
+
const isCompilerGeneratedStructuralName = (name) => !!name && (name.startsWith("__Anon_") || name.startsWith("__Rest_"));
|
|
10
|
+
export const isCompilerGeneratedStructuralReferenceType = (type) => {
|
|
11
|
+
const simpleName = type.name.split(".").pop() ?? type.name;
|
|
12
|
+
const clrSimpleName = type.resolvedClrType?.split(".").pop();
|
|
13
|
+
return (isCompilerGeneratedStructuralName(simpleName) ||
|
|
14
|
+
isCompilerGeneratedStructuralName(clrSimpleName));
|
|
15
|
+
};
|
|
16
|
+
const buildReferenceType = (name, resolvedClrType, typeArguments) => ({
|
|
17
|
+
kind: "referenceType",
|
|
18
|
+
name,
|
|
19
|
+
...(resolvedClrType ? { resolvedClrType } : {}),
|
|
20
|
+
...(typeArguments ? { typeArguments: [...typeArguments] } : {}),
|
|
21
|
+
});
|
|
22
|
+
const tryResolveIteratorResultVariant = (type, context) => {
|
|
23
|
+
const resolved = resolveTypeAlias(stripNullish(type), context);
|
|
24
|
+
const members = resolved.kind === "objectType"
|
|
25
|
+
? resolved.members
|
|
26
|
+
: resolved.kind === "referenceType"
|
|
27
|
+
? resolved.structuralMembers
|
|
28
|
+
: undefined;
|
|
29
|
+
if (!members || members.length !== 2) {
|
|
30
|
+
return undefined;
|
|
31
|
+
}
|
|
32
|
+
const properties = members.filter((member) => member.kind === "propertySignature");
|
|
33
|
+
if (properties.length !== 2) {
|
|
34
|
+
return undefined;
|
|
35
|
+
}
|
|
36
|
+
const doneProperty = properties.find((member) => member.name === "done");
|
|
37
|
+
const valueProperty = properties.find((member) => member.name === "value");
|
|
38
|
+
if (!doneProperty ||
|
|
39
|
+
!valueProperty ||
|
|
40
|
+
doneProperty.isOptional ||
|
|
41
|
+
valueProperty.isOptional) {
|
|
42
|
+
return undefined;
|
|
43
|
+
}
|
|
44
|
+
if (doneProperty.type.kind !== "literalType" ||
|
|
45
|
+
typeof doneProperty.type.value !== "boolean") {
|
|
46
|
+
return undefined;
|
|
47
|
+
}
|
|
48
|
+
return {
|
|
49
|
+
done: doneProperty.type.value,
|
|
50
|
+
valueType: valueProperty.type,
|
|
51
|
+
};
|
|
52
|
+
};
|
|
53
|
+
export const resolveIteratorResultReferenceType = (type, context) => {
|
|
54
|
+
const resolved = resolveTypeAlias(stripNullish(type), context);
|
|
55
|
+
if (resolved.kind !== "unionType" || resolved.types.length !== 2) {
|
|
56
|
+
return undefined;
|
|
57
|
+
}
|
|
58
|
+
const variants = resolved.types
|
|
59
|
+
.map((member) => tryResolveIteratorResultVariant(member, context))
|
|
60
|
+
.filter((variant) => variant !== undefined);
|
|
61
|
+
if (variants.length !== 2) {
|
|
62
|
+
return undefined;
|
|
63
|
+
}
|
|
64
|
+
const doneFalseVariant = variants.find((variant) => variant.done === false);
|
|
65
|
+
const doneTrueVariant = variants.find((variant) => variant.done === true);
|
|
66
|
+
if (!doneFalseVariant || !doneTrueVariant) {
|
|
67
|
+
return undefined;
|
|
68
|
+
}
|
|
69
|
+
return buildReferenceType("IteratorResult", "global::Tsonic.Runtime.IteratorResult", [doneFalseVariant.valueType]);
|
|
70
|
+
};
|
|
71
|
+
/**
|
|
72
|
+
* Resolve structural emission-only helpers that already have an explicit reference
|
|
73
|
+
* representation. Inline structural object types intentionally stay compiler-owned
|
|
74
|
+
* and must not be rebound to authored aliases or classes here.
|
|
75
|
+
*/
|
|
76
|
+
export const resolveStructuralReferenceType = (type, context) => {
|
|
77
|
+
const stripped = stripNullish(type);
|
|
78
|
+
const iteratorResultReference = resolveIteratorResultReferenceType(stripped, context);
|
|
79
|
+
if (iteratorResultReference) {
|
|
80
|
+
return iteratorResultReference;
|
|
81
|
+
}
|
|
82
|
+
if (stripped.kind === "referenceType") {
|
|
83
|
+
return stripped;
|
|
84
|
+
}
|
|
85
|
+
return undefined;
|
|
86
|
+
};
|
|
87
|
+
export const normalizeStructuralEmissionType = (type, context) => {
|
|
88
|
+
const cache = new Map();
|
|
89
|
+
const active = new Set();
|
|
90
|
+
const normalize = (current) => {
|
|
91
|
+
const rebound = resolveStructuralReferenceType(current, context);
|
|
92
|
+
if (rebound) {
|
|
93
|
+
return rebound;
|
|
94
|
+
}
|
|
95
|
+
if (active.has(current)) {
|
|
96
|
+
return current;
|
|
97
|
+
}
|
|
98
|
+
const cached = cache.get(current);
|
|
99
|
+
if (cached) {
|
|
100
|
+
return cached;
|
|
101
|
+
}
|
|
102
|
+
active.add(current);
|
|
103
|
+
const normalized = (() => {
|
|
104
|
+
switch (current.kind) {
|
|
105
|
+
case "referenceType": {
|
|
106
|
+
const typeArguments = current.typeArguments?.map(normalize);
|
|
107
|
+
const hasChanged = !!typeArguments &&
|
|
108
|
+
typeArguments.some((argument, index) => argument !== current.typeArguments?.[index]);
|
|
109
|
+
return hasChanged
|
|
110
|
+
? {
|
|
111
|
+
...current,
|
|
112
|
+
typeArguments,
|
|
113
|
+
}
|
|
114
|
+
: current;
|
|
115
|
+
}
|
|
116
|
+
case "arrayType": {
|
|
117
|
+
const elementType = normalize(current.elementType);
|
|
118
|
+
const tuplePrefixElementTypes = current.tuplePrefixElementTypes?.map(normalize);
|
|
119
|
+
const tupleRestElementType = current.tupleRestElementType
|
|
120
|
+
? normalize(current.tupleRestElementType)
|
|
121
|
+
: undefined;
|
|
122
|
+
const hasChanged = elementType !== current.elementType ||
|
|
123
|
+
(!!tuplePrefixElementTypes &&
|
|
124
|
+
tuplePrefixElementTypes.some((element, index) => element !== current.tuplePrefixElementTypes?.[index])) ||
|
|
125
|
+
tupleRestElementType !== current.tupleRestElementType;
|
|
126
|
+
return hasChanged
|
|
127
|
+
? {
|
|
128
|
+
...current,
|
|
129
|
+
elementType,
|
|
130
|
+
...(tuplePrefixElementTypes ? { tuplePrefixElementTypes } : {}),
|
|
131
|
+
...(tupleRestElementType ? { tupleRestElementType } : {}),
|
|
132
|
+
}
|
|
133
|
+
: current;
|
|
134
|
+
}
|
|
135
|
+
case "tupleType": {
|
|
136
|
+
const elementTypes = current.elementTypes.map(normalize);
|
|
137
|
+
return elementTypes.some((element, index) => element !== current.elementTypes[index])
|
|
138
|
+
? { ...current, elementTypes }
|
|
139
|
+
: current;
|
|
140
|
+
}
|
|
141
|
+
case "functionType": {
|
|
142
|
+
const parameters = current.parameters.map((parameter) => parameter.type
|
|
143
|
+
? {
|
|
144
|
+
...parameter,
|
|
145
|
+
type: normalize(parameter.type),
|
|
146
|
+
}
|
|
147
|
+
: parameter);
|
|
148
|
+
const returnType = normalize(current.returnType);
|
|
149
|
+
const hasChanged = returnType !== current.returnType ||
|
|
150
|
+
parameters.some((parameter, index) => parameter !== current.parameters[index]);
|
|
151
|
+
return hasChanged
|
|
152
|
+
? {
|
|
153
|
+
...current,
|
|
154
|
+
parameters,
|
|
155
|
+
returnType,
|
|
156
|
+
}
|
|
157
|
+
: current;
|
|
158
|
+
}
|
|
159
|
+
case "objectType": {
|
|
160
|
+
const members = current.members.map((member) => {
|
|
161
|
+
switch (member.kind) {
|
|
162
|
+
case "propertySignature": {
|
|
163
|
+
const memberType = normalize(member.type);
|
|
164
|
+
return memberType !== member.type
|
|
165
|
+
? {
|
|
166
|
+
...member,
|
|
167
|
+
type: memberType,
|
|
168
|
+
}
|
|
169
|
+
: member;
|
|
170
|
+
}
|
|
171
|
+
case "methodSignature": {
|
|
172
|
+
const parameters = member.parameters.map((parameter) => parameter.type
|
|
173
|
+
? {
|
|
174
|
+
...parameter,
|
|
175
|
+
type: normalize(parameter.type),
|
|
176
|
+
}
|
|
177
|
+
: parameter);
|
|
178
|
+
const returnType = member.returnType
|
|
179
|
+
? normalize(member.returnType)
|
|
180
|
+
: undefined;
|
|
181
|
+
const typeParameters = member.typeParameters?.map((typeParameter) => typeParameter.constraint || typeParameter.default
|
|
182
|
+
? {
|
|
183
|
+
...typeParameter,
|
|
184
|
+
...(typeParameter.constraint
|
|
185
|
+
? {
|
|
186
|
+
constraint: normalize(typeParameter.constraint),
|
|
187
|
+
}
|
|
188
|
+
: {}),
|
|
189
|
+
...(typeParameter.default
|
|
190
|
+
? {
|
|
191
|
+
default: normalize(typeParameter.default),
|
|
192
|
+
}
|
|
193
|
+
: {}),
|
|
194
|
+
}
|
|
195
|
+
: typeParameter);
|
|
196
|
+
const hasChanged = parameters.some((parameter, index) => parameter !== member.parameters[index]) ||
|
|
197
|
+
returnType !== member.returnType ||
|
|
198
|
+
(!!typeParameters &&
|
|
199
|
+
typeParameters.some((typeParameter, index) => typeParameter !== member.typeParameters?.[index]));
|
|
200
|
+
return hasChanged
|
|
201
|
+
? {
|
|
202
|
+
...member,
|
|
203
|
+
parameters,
|
|
204
|
+
...(returnType ? { returnType } : {}),
|
|
205
|
+
...(typeParameters ? { typeParameters } : {}),
|
|
206
|
+
}
|
|
207
|
+
: member;
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
});
|
|
211
|
+
return members.some((member, index) => member !== current.members[index])
|
|
212
|
+
? { ...current, members }
|
|
213
|
+
: current;
|
|
214
|
+
}
|
|
215
|
+
case "dictionaryType": {
|
|
216
|
+
const keyType = normalize(current.keyType);
|
|
217
|
+
const valueType = normalize(current.valueType);
|
|
218
|
+
return keyType !== current.keyType || valueType !== current.valueType
|
|
219
|
+
? {
|
|
220
|
+
...current,
|
|
221
|
+
keyType,
|
|
222
|
+
valueType,
|
|
223
|
+
}
|
|
224
|
+
: current;
|
|
225
|
+
}
|
|
226
|
+
case "unionType":
|
|
227
|
+
case "intersectionType": {
|
|
228
|
+
const types = current.types.map(normalize);
|
|
229
|
+
if (!types.some((member, index) => member !== current.types[index])) {
|
|
230
|
+
return current;
|
|
231
|
+
}
|
|
232
|
+
return current.kind === "unionType"
|
|
233
|
+
? rebuildUnionTypePreservingCarrierFamily(current, types)
|
|
234
|
+
: {
|
|
235
|
+
...current,
|
|
236
|
+
types,
|
|
237
|
+
};
|
|
238
|
+
}
|
|
239
|
+
case "primitiveType":
|
|
240
|
+
case "typeParameterType":
|
|
241
|
+
case "literalType":
|
|
242
|
+
case "anyType":
|
|
243
|
+
case "unknownType":
|
|
244
|
+
case "voidType":
|
|
245
|
+
case "neverType":
|
|
246
|
+
return current;
|
|
247
|
+
}
|
|
248
|
+
})();
|
|
249
|
+
cache.set(current, normalized);
|
|
250
|
+
active.delete(current);
|
|
251
|
+
return normalized;
|
|
252
|
+
};
|
|
253
|
+
return normalize(type);
|
|
254
|
+
};
|
|
255
|
+
//# sourceMappingURL=structural-shape-matching.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"structural-shape-matching.js","sourceRoot":"","sources":["../../../src/core/semantic/structural-shape-matching.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { IrExpression, IrType } from "@tsonic/frontend";
|
|
2
|
+
import type { EmitterContext } from "../../types.js";
|
|
3
|
+
export type StructuralViewMethodSurface = {
|
|
4
|
+
readonly parameterTypes: readonly (IrType | undefined)[];
|
|
5
|
+
readonly returnType?: IrType;
|
|
6
|
+
};
|
|
7
|
+
export declare const resolveStructuralViewMethodSurface: (callee: IrExpression, context: EmitterContext, options?: {
|
|
8
|
+
readonly includeErasedAsInterface?: boolean;
|
|
9
|
+
}) => StructuralViewMethodSurface | undefined;
|
|
10
|
+
//# sourceMappingURL=structural-view-types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"structural-view-types.d.ts","sourceRoot":"","sources":["../../../src/core/semantic/structural-view-types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAqBrD,MAAM,MAAM,2BAA2B,GAAG;IACxC,QAAQ,CAAC,cAAc,EAAE,SAAS,CAAC,MAAM,GAAG,SAAS,CAAC,EAAE,CAAC;IACzD,QAAQ,CAAC,UAAU,CAAC,EAAE,MAAM,CAAC;CAC9B,CAAC;AA+CF,eAAO,MAAM,kCAAkC,GAC7C,QAAQ,YAAY,EACpB,SAAS,cAAc,EACvB,UAAS;IAAE,QAAQ,CAAC,wBAAwB,CAAC,EAAE,OAAO,CAAA;CAAO,KAC5D,2BAA2B,GAAG,SAkDhC,CAAC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { resolveLocalTypeInfo, resolveTypeAlias, stripNullish, substituteTypeArgs, } from "./type-resolution.js";
|
|
2
|
+
const isStructuralViewExpression = (expression, includeErasedAsInterface) => (includeErasedAsInterface && expression.kind === "asinterface") ||
|
|
3
|
+
expression.kind === "typeAssertion" ||
|
|
4
|
+
expression.kind === "trycast";
|
|
5
|
+
const substituteMemberType = (type, typeParameterNames, typeArguments) => type && typeParameterNames && typeArguments
|
|
6
|
+
? substituteTypeArgs(type, typeParameterNames, typeArguments)
|
|
7
|
+
: type;
|
|
8
|
+
const findMethodSurface = (members, memberName, typeParameterNames, typeArguments) => {
|
|
9
|
+
const method = members?.find((member) => (member.kind === "methodSignature" ||
|
|
10
|
+
member.kind === "methodDeclaration") &&
|
|
11
|
+
member.name === memberName);
|
|
12
|
+
if (!method?.parameters) {
|
|
13
|
+
return undefined;
|
|
14
|
+
}
|
|
15
|
+
return {
|
|
16
|
+
parameterTypes: method.parameters.map((parameter) => substituteMemberType(parameter.type, typeParameterNames, typeArguments)),
|
|
17
|
+
returnType: substituteMemberType(method.returnType, typeParameterNames, typeArguments),
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
export const resolveStructuralViewMethodSurface = (callee, context, options = {}) => {
|
|
21
|
+
if (callee.kind !== "memberAccess" ||
|
|
22
|
+
callee.isComputed ||
|
|
23
|
+
typeof callee.property !== "string" ||
|
|
24
|
+
!isStructuralViewExpression(callee.object, options.includeErasedAsInterface === true)) {
|
|
25
|
+
return undefined;
|
|
26
|
+
}
|
|
27
|
+
const targetType = callee.object.targetType;
|
|
28
|
+
const memberName = callee.property;
|
|
29
|
+
const resolvedTarget = resolveTypeAlias(stripNullish(targetType), context);
|
|
30
|
+
if (resolvedTarget.kind === "objectType") {
|
|
31
|
+
return findMethodSurface(resolvedTarget.members, memberName, undefined, undefined);
|
|
32
|
+
}
|
|
33
|
+
if (resolvedTarget.kind !== "referenceType") {
|
|
34
|
+
return undefined;
|
|
35
|
+
}
|
|
36
|
+
const structuralSurface = findMethodSurface(resolvedTarget.structuralMembers, memberName, undefined, undefined);
|
|
37
|
+
if (structuralSurface) {
|
|
38
|
+
return structuralSurface;
|
|
39
|
+
}
|
|
40
|
+
const localType = resolveLocalTypeInfo(resolvedTarget, context)?.info;
|
|
41
|
+
if (localType?.kind !== "class" && localType?.kind !== "interface") {
|
|
42
|
+
return undefined;
|
|
43
|
+
}
|
|
44
|
+
return findMethodSurface(localType.members, memberName, localType.typeParameters, resolvedTarget.typeArguments);
|
|
45
|
+
};
|
|
46
|
+
//# sourceMappingURL=structural-view-types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"structural-view-types.js","sourceRoot":"","sources":["../../../src/core/semantic/structural-view-types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Canonical symbol type registration — the single authority for deciding
|
|
3
|
+
* what goes into localSemanticTypes vs localValueTypes.
|
|
4
|
+
*
|
|
5
|
+
* Construct emitters (functions, variables, loops, patterns, catch) call
|
|
6
|
+
* these helpers instead of computing semantic/storage splits ad hoc.
|
|
7
|
+
* Each function encapsulates the derivation strategy for its construct kind
|
|
8
|
+
* and delegates to registerLocalSymbolTypes for the actual map update.
|
|
9
|
+
*
|
|
10
|
+
* ## Materialization boundary
|
|
11
|
+
*
|
|
12
|
+
* The emitter maintains two type channels:
|
|
13
|
+
*
|
|
14
|
+
* - **Semantic types** (localSemanticTypes): Authored frontend IR types
|
|
15
|
+
* preserving alias identity, union structure, and type-parameter shapes.
|
|
16
|
+
* These flow into analysis functions (narrowing, guard analysis, layout
|
|
17
|
+
* building, `buildRuntimeUnionLayout`, `tryBuildRuntimeMaterializationAst`).
|
|
18
|
+
*
|
|
19
|
+
* - **Storage types** (localValueTypes): CLR-normalized carriers produced
|
|
20
|
+
* by `normalizeRuntimeStorageType`. These are used for C# declarations
|
|
21
|
+
* and runtime dispatch.
|
|
22
|
+
*
|
|
23
|
+
* The lowering boundary is enforced at emission points:
|
|
24
|
+
*
|
|
25
|
+
* - `emitTypeAst()` is where semantic → C# AST conversion happens.
|
|
26
|
+
* - `normalizeRuntimeStorageType` is called only at symbol registration
|
|
27
|
+
* time (here) or at final emission boundaries (e.g., `access.ts`).
|
|
28
|
+
* - Analysis functions must receive semantic types, never pre-lowered
|
|
29
|
+
* storage types. Parameter modifier wrappers (ref/out/In) may be
|
|
30
|
+
* stripped for emission-time comparisons but must not be stripped
|
|
31
|
+
* before passing types to materialization functions.
|
|
32
|
+
*/
|
|
33
|
+
import type { IrExpression, IrType } from "@tsonic/frontend";
|
|
34
|
+
import type { EmitterContext } from "../../types.js";
|
|
35
|
+
import { type VariableDeclaratorLike } from "./variable-type-resolution.js";
|
|
36
|
+
/**
|
|
37
|
+
* Register a local symbol from its semantic (frontend IR) type.
|
|
38
|
+
*
|
|
39
|
+
* Storage type is derived automatically via normalizeRuntimeStorageType.
|
|
40
|
+
* Falls back to the semantic type itself when normalization returns undefined.
|
|
41
|
+
*
|
|
42
|
+
* Use for: parameters, pattern bindings — where the authored type is the
|
|
43
|
+
* single source of truth and storage is purely derived.
|
|
44
|
+
*/
|
|
45
|
+
export declare const registerParameterTypes: (originalName: string, semanticType: IrType | undefined, acceptsExplicitUndefined: boolean, context: EmitterContext) => EmitterContext;
|
|
46
|
+
/**
|
|
47
|
+
* Register for-of element semantic and storage types for a loop variable.
|
|
48
|
+
*
|
|
49
|
+
* Semantic: element type derived from the collection's frontend IR type.
|
|
50
|
+
* Storage: element type derived from the collection's CLR-normalized type,
|
|
51
|
+
* falling back to semantic when normalization produces no change.
|
|
52
|
+
*
|
|
53
|
+
* The two-step derivation (normalize collection → extract element) is
|
|
54
|
+
* intentionally different from normalizing the element type directly,
|
|
55
|
+
* because collection-level normalization can change the element extraction.
|
|
56
|
+
*/
|
|
57
|
+
export declare const registerForOfElementSymbolTypes: (originalName: string, collectionType: IrExpression["inferredType"], context: EmitterContext) => EmitterContext;
|
|
58
|
+
/**
|
|
59
|
+
* Register both semantic and storage types for a variable declaration.
|
|
60
|
+
*
|
|
61
|
+
* Semantic: decl.type (explicit annotation) or the un-normalized
|
|
62
|
+
* initializer type (preserving alias identity and union structure).
|
|
63
|
+
* Storage: the CLR-normalized carrier via resolveLocalStorageType.
|
|
64
|
+
*/
|
|
65
|
+
export declare const registerVariableSymbolTypes: (originalName: string, decl: VariableDeclaratorLike, context: EmitterContext, storageTypeOverride?: IrType, semanticTypeOverride?: IrType) => EmitterContext;
|
|
66
|
+
/**
|
|
67
|
+
* Register catch variable types.
|
|
68
|
+
*
|
|
69
|
+
* Semantic: JsValue (broad JS-visible thrown value channel).
|
|
70
|
+
* Storage: System.Exception (the CLR catch carrier).
|
|
71
|
+
*/
|
|
72
|
+
export declare const registerCatchVariableTypes: (originalName: string, context: EmitterContext) => EmitterContext;
|
|
73
|
+
/**
|
|
74
|
+
* Register for-in key variable types.
|
|
75
|
+
*
|
|
76
|
+
* Both semantic and storage are string — for-in keys are always strings
|
|
77
|
+
* in both channels.
|
|
78
|
+
*/
|
|
79
|
+
export declare const registerForInKeyTypes: (originalName: string, context: EmitterContext) => EmitterContext;
|
|
80
|
+
//# sourceMappingURL=symbol-types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"symbol-types.d.ts","sourceRoot":"","sources":["../../../src/core/semantic/symbol-types.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+BG;AAEH,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAIrD,OAAO,EAGL,KAAK,sBAAsB,EAC5B,MAAM,+BAA+B,CAAC;AAGvC;;;;;;;;GAQG;AACH,eAAO,MAAM,sBAAsB,GACjC,cAAc,MAAM,EACpB,cAAc,MAAM,GAAG,SAAS,EAChC,0BAA0B,OAAO,EACjC,SAAS,cAAc,KACtB,cAgBF,CAAC;AAEF;;;;;;;;;;GAUG;AACH,eAAO,MAAM,+BAA+B,GAC1C,cAAc,MAAM,EACpB,gBAAgB,YAAY,CAAC,cAAc,CAAC,EAC5C,SAAS,cAAc,KACtB,cAYF,CAAC;AAEF;;;;;;GAMG;AACH,eAAO,MAAM,2BAA2B,GACtC,cAAc,MAAM,EACpB,MAAM,sBAAsB,EAC5B,SAAS,cAAc,EACvB,sBAAsB,MAAM,EAC5B,uBAAuB,MAAM,KAC5B,cAQA,CAAC;AAEJ;;;;;GAKG;AACH,eAAO,MAAM,0BAA0B,GACrC,cAAc,MAAM,EACpB,SAAS,cAAc,KACtB,cAcA,CAAC;AAEJ;;;;;GAKG;AACH,eAAO,MAAM,qBAAqB,GAChC,cAAc,MAAM,EACpB,SAAS,cAAc,KACtB,cAMA,CAAC"}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Canonical symbol type registration — the single authority for deciding
|
|
3
|
+
* what goes into localSemanticTypes vs localValueTypes.
|
|
4
|
+
*
|
|
5
|
+
* Construct emitters (functions, variables, loops, patterns, catch) call
|
|
6
|
+
* these helpers instead of computing semantic/storage splits ad hoc.
|
|
7
|
+
* Each function encapsulates the derivation strategy for its construct kind
|
|
8
|
+
* and delegates to registerLocalSymbolTypes for the actual map update.
|
|
9
|
+
*
|
|
10
|
+
* ## Materialization boundary
|
|
11
|
+
*
|
|
12
|
+
* The emitter maintains two type channels:
|
|
13
|
+
*
|
|
14
|
+
* - **Semantic types** (localSemanticTypes): Authored frontend IR types
|
|
15
|
+
* preserving alias identity, union structure, and type-parameter shapes.
|
|
16
|
+
* These flow into analysis functions (narrowing, guard analysis, layout
|
|
17
|
+
* building, `buildRuntimeUnionLayout`, `tryBuildRuntimeMaterializationAst`).
|
|
18
|
+
*
|
|
19
|
+
* - **Storage types** (localValueTypes): CLR-normalized carriers produced
|
|
20
|
+
* by `normalizeRuntimeStorageType`. These are used for C# declarations
|
|
21
|
+
* and runtime dispatch.
|
|
22
|
+
*
|
|
23
|
+
* The lowering boundary is enforced at emission points:
|
|
24
|
+
*
|
|
25
|
+
* - `emitTypeAst()` is where semantic → C# AST conversion happens.
|
|
26
|
+
* - `normalizeRuntimeStorageType` is called only at symbol registration
|
|
27
|
+
* time (here) or at final emission boundaries (e.g., `access.ts`).
|
|
28
|
+
* - Analysis functions must receive semantic types, never pre-lowered
|
|
29
|
+
* storage types. Parameter modifier wrappers (ref/out/In) may be
|
|
30
|
+
* stripped for emission-time comparisons but must not be stripped
|
|
31
|
+
* before passing types to materialization functions.
|
|
32
|
+
*/
|
|
33
|
+
import { normalizeRuntimeStorageType } from "./storage-types.js";
|
|
34
|
+
import { registerLocalSymbolTypes } from "../format/local-names.js";
|
|
35
|
+
import { deriveForOfElementType } from "./iteration-types.js";
|
|
36
|
+
import { resolveSemanticVariableInitializerType, resolveLocalStorageType, } from "./variable-type-resolution.js";
|
|
37
|
+
import { getAcceptedParameterType } from "./defaults.js";
|
|
38
|
+
/**
|
|
39
|
+
* Register a local symbol from its semantic (frontend IR) type.
|
|
40
|
+
*
|
|
41
|
+
* Storage type is derived automatically via normalizeRuntimeStorageType.
|
|
42
|
+
* Falls back to the semantic type itself when normalization returns undefined.
|
|
43
|
+
*
|
|
44
|
+
* Use for: parameters, pattern bindings — where the authored type is the
|
|
45
|
+
* single source of truth and storage is purely derived.
|
|
46
|
+
*/
|
|
47
|
+
export const registerParameterTypes = (originalName, semanticType, acceptsExplicitUndefined, context) => {
|
|
48
|
+
const acceptedType = getAcceptedParameterType(semanticType, acceptsExplicitUndefined);
|
|
49
|
+
const storageType = normalizeRuntimeStorageType(acceptedType, context) ??
|
|
50
|
+
acceptedType ??
|
|
51
|
+
semanticType;
|
|
52
|
+
return registerLocalSymbolTypes(originalName, acceptedType ?? semanticType, storageType, context);
|
|
53
|
+
};
|
|
54
|
+
/**
|
|
55
|
+
* Register for-of element semantic and storage types for a loop variable.
|
|
56
|
+
*
|
|
57
|
+
* Semantic: element type derived from the collection's frontend IR type.
|
|
58
|
+
* Storage: element type derived from the collection's CLR-normalized type,
|
|
59
|
+
* falling back to semantic when normalization produces no change.
|
|
60
|
+
*
|
|
61
|
+
* The two-step derivation (normalize collection → extract element) is
|
|
62
|
+
* intentionally different from normalizing the element type directly,
|
|
63
|
+
* because collection-level normalization can change the element extraction.
|
|
64
|
+
*/
|
|
65
|
+
export const registerForOfElementSymbolTypes = (originalName, collectionType, context) => {
|
|
66
|
+
const semanticElementType = deriveForOfElementType(collectionType, context);
|
|
67
|
+
const storageElementType = deriveForOfElementType(normalizeRuntimeStorageType(collectionType, context), context);
|
|
68
|
+
return registerLocalSymbolTypes(originalName, semanticElementType, storageElementType ?? semanticElementType, context);
|
|
69
|
+
};
|
|
70
|
+
/**
|
|
71
|
+
* Register both semantic and storage types for a variable declaration.
|
|
72
|
+
*
|
|
73
|
+
* Semantic: decl.type (explicit annotation) or the un-normalized
|
|
74
|
+
* initializer type (preserving alias identity and union structure).
|
|
75
|
+
* Storage: the CLR-normalized carrier via resolveLocalStorageType.
|
|
76
|
+
*/
|
|
77
|
+
export const registerVariableSymbolTypes = (originalName, decl, context, storageTypeOverride, semanticTypeOverride) => registerLocalSymbolTypes(originalName, semanticTypeOverride ??
|
|
78
|
+
decl.type ??
|
|
79
|
+
resolveSemanticVariableInitializerType(decl.initializer, context), storageTypeOverride ?? resolveLocalStorageType(decl, context), context);
|
|
80
|
+
/**
|
|
81
|
+
* Register catch variable types.
|
|
82
|
+
*
|
|
83
|
+
* Semantic: JsValue (broad JS-visible thrown value channel).
|
|
84
|
+
* Storage: System.Exception (the CLR catch carrier).
|
|
85
|
+
*/
|
|
86
|
+
export const registerCatchVariableTypes = (originalName, context) => registerLocalSymbolTypes(originalName, {
|
|
87
|
+
kind: "referenceType",
|
|
88
|
+
name: "JsValue",
|
|
89
|
+
resolvedClrType: "Tsonic.Runtime.JsValue",
|
|
90
|
+
}, {
|
|
91
|
+
kind: "referenceType",
|
|
92
|
+
name: "System.Exception",
|
|
93
|
+
resolvedClrType: "global::System.Exception",
|
|
94
|
+
}, context);
|
|
95
|
+
/**
|
|
96
|
+
* Register for-in key variable types.
|
|
97
|
+
*
|
|
98
|
+
* Both semantic and storage are string — for-in keys are always strings
|
|
99
|
+
* in both channels.
|
|
100
|
+
*/
|
|
101
|
+
export const registerForInKeyTypes = (originalName, context) => registerLocalSymbolTypes(originalName, { kind: "primitiveType", name: "string" }, { kind: "primitiveType", name: "string" }, context);
|
|
102
|
+
//# sourceMappingURL=symbol-types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"symbol-types.js","sourceRoot":"","sources":["../../../src/core/semantic/symbol-types.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+BG;AAIH,OAAO,EAAE,2BAA2B,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,EAAE,wBAAwB,EAAE,MAAM,0BAA0B,CAAC;AACpE,OAAO,EAAE,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AAC9D,OAAO,EACL,sCAAsC,EACtC,uBAAuB,GAExB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,wBAAwB,EAAE,MAAM,eAAe,CAAC;AAEzD;;;;;;;;GAQG;AACH,MAAM,CAAC,MAAM,sBAAsB,GAAG,CACpC,YAAoB,EACpB,YAAgC,EAChC,wBAAiC,EACjC,OAAuB,EACP,EAAE;IAClB,MAAM,YAAY,GAAG,wBAAwB,CAC3C,YAAY,EACZ,wBAAwB,CACzB,CAAC;IACF,MAAM,WAAW,GACf,2BAA2B,CAAC,YAAY,EAAE,OAAO,CAAC;QAClD,YAAY;QACZ,YAAY,CAAC;IAEf,OAAO,wBAAwB,CAC7B,YAAY,EACZ,YAAY,IAAI,YAAY,EAC5B,WAAW,EACX,OAAO,CACR,CAAC;AACJ,CAAC,CAAC;AAEF;;;;;;;;;;GAUG;AACH,MAAM,CAAC,MAAM,+BAA+B,GAAG,CAC7C,YAAoB,EACpB,cAA4C,EAC5C,OAAuB,EACP,EAAE;IAClB,MAAM,mBAAmB,GAAG,sBAAsB,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;IAC5E,MAAM,kBAAkB,GAAG,sBAAsB,CAC/C,2BAA2B,CAAC,cAAc,EAAE,OAAO,CAAC,EACpD,OAAO,CACR,CAAC;IACF,OAAO,wBAAwB,CAC7B,YAAY,EACZ,mBAAmB,EACnB,kBAAkB,IAAI,mBAAmB,EACzC,OAAO,CACR,CAAC;AACJ,CAAC,CAAC;AAEF;;;;;;GAMG;AACH,MAAM,CAAC,MAAM,2BAA2B,GAAG,CACzC,YAAoB,EACpB,IAA4B,EAC5B,OAAuB,EACvB,mBAA4B,EAC5B,oBAA6B,EACb,EAAE,CAClB,wBAAwB,CACtB,YAAY,EACZ,oBAAoB;IAClB,IAAI,CAAC,IAAI;IACT,sCAAsC,CAAC,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,EACnE,mBAAmB,IAAI,uBAAuB,CAAC,IAAI,EAAE,OAAO,CAAC,EAC7D,OAAO,CACR,CAAC;AAEJ;;;;;GAKG;AACH,MAAM,CAAC,MAAM,0BAA0B,GAAG,CACxC,YAAoB,EACpB,OAAuB,EACP,EAAE,CAClB,wBAAwB,CACtB,YAAY,EACZ;IACE,IAAI,EAAE,eAAe;IACrB,IAAI,EAAE,SAAS;IACf,eAAe,EAAE,wBAAwB;CAC1C,EACD;IACE,IAAI,EAAE,eAAe;IACrB,IAAI,EAAE,kBAAkB;IACxB,eAAe,EAAE,0BAA0B;CAC5C,EACD,OAAO,CACR,CAAC;AAEJ;;;;;GAKG;AACH,MAAM,CAAC,MAAM,qBAAqB,GAAG,CACnC,YAAoB,EACpB,OAAuB,EACP,EAAE,CAClB,wBAAwB,CACtB,YAAY,EACZ,EAAE,IAAI,EAAE,eAAe,EAAE,IAAI,EAAE,QAAQ,EAAE,EACzC,EAAE,IAAI,EAAE,eAAe,EAAE,IAAI,EAAE,QAAQ,EAAE,EACzC,OAAO,CACR,CAAC"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Ternary (conditional expression) guard detection helpers.
|
|
3
|
+
*
|
|
4
|
+
* Pure detection module — extracts TernaryGuardInfo from condition expressions
|
|
5
|
+
* for use by the conditional-emitter. Lives in core/semantic to avoid a module
|
|
6
|
+
* cycle between expressions/ and statements/control/.
|
|
7
|
+
*
|
|
8
|
+
* The ternary guard path differs from the if-statement guard path in two ways:
|
|
9
|
+
* - Uses `findRuntimeUnionMemberIndices` (semantic matching) instead of
|
|
10
|
+
* `findExactRuntimeUnionMemberIndices` (strict key matching).
|
|
11
|
+
* - Uses `buildRuntimeUnionLayout` (not `resolveRuntimeUnionFrame`) for
|
|
12
|
+
* discriminant equality detection.
|
|
13
|
+
*/
|
|
14
|
+
import { IrExpression, IrType } from "@tsonic/frontend";
|
|
15
|
+
import { EmitterContext } from "../../types.js";
|
|
16
|
+
import { type EmitTypeAstLike } from "./runtime-unions.js";
|
|
17
|
+
/**
|
|
18
|
+
* Information extracted from a ternary condition guard.
|
|
19
|
+
* Used to generate inline Union.IsN()/AsN() narrowing in conditional expressions.
|
|
20
|
+
*
|
|
21
|
+
* Unlike statement-level GuardInfo (which produces `var __narrowed = x.AsN()`),
|
|
22
|
+
* TernaryGuardInfo uses inline narrowedBindings (`x → (x.AsN())`).
|
|
23
|
+
*/
|
|
24
|
+
export type TernaryGuardInfo = {
|
|
25
|
+
readonly originalName: string;
|
|
26
|
+
readonly memberN: number;
|
|
27
|
+
readonly narrowedType: IrType;
|
|
28
|
+
readonly sourceType: IrType;
|
|
29
|
+
readonly escapedOrig: string;
|
|
30
|
+
readonly polarity: "positive" | "negative";
|
|
31
|
+
};
|
|
32
|
+
/**
|
|
33
|
+
* Try to extract ternary guard info from a condition expression.
|
|
34
|
+
* Handles type predicate calls (`isUser(x)`), negated calls (`!isUser(x)`),
|
|
35
|
+
* and discriminant literal equality (`x.kind === "circle"`).
|
|
36
|
+
* Returns guard info with polarity indicating which branch to narrow.
|
|
37
|
+
*
|
|
38
|
+
* Accepts `emitTypeAst` as a callback (threaded to discriminant equality
|
|
39
|
+
* detection via `buildRuntimeUnionLayout`) to keep this module free of
|
|
40
|
+
* upward imports into the root emitter layer.
|
|
41
|
+
*/
|
|
42
|
+
export declare const tryResolveTernaryGuard: (condition: IrExpression, context: EmitterContext, emitTypeAst: EmitTypeAstLike) => TernaryGuardInfo | undefined;
|
|
43
|
+
//# sourceMappingURL=ternary-guards.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ternary-guards.d.ts","sourceRoot":"","sources":["../../../src/core/semantic/ternary-guards.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AACxD,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAIhD,OAAO,EAGL,KAAK,eAAe,EACrB,MAAM,qBAAqB,CAAC;AAW7B;;;;;;GAMG;AACH,MAAM,MAAM,gBAAgB,GAAG;IAC7B,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC;IAC9B,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC;IAC9B,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAC7B,QAAQ,CAAC,QAAQ,EAAE,UAAU,GAAG,UAAU,CAAC;CAC5C,CAAC;AAwOF;;;;;;;;;GASG;AACH,eAAO,MAAM,sBAAsB,GACjC,WAAW,YAAY,EACvB,SAAS,cAAc,EACvB,aAAa,eAAe,KAC3B,gBAAgB,GAAG,SA8BrB,CAAC"}
|