@tsonic/emitter 0.0.62 → 0.0.64
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/.tsbuildinfo +1 -1
- package/dist/adapter-generator.d.ts +5 -15
- package/dist/adapter-generator.d.ts.map +1 -1
- package/dist/adapter-generator.js +60 -53
- package/dist/adapter-generator.js.map +1 -1
- package/dist/contracts/backend-adapter.d.ts +36 -0
- package/dist/contracts/backend-adapter.d.ts.map +1 -0
- package/dist/contracts/backend-adapter.js +9 -0
- package/dist/contracts/backend-adapter.js.map +1 -0
- package/dist/contracts/emitter-contract.d.ts +54 -0
- package/dist/contracts/emitter-contract.d.ts.map +1 -0
- package/dist/contracts/emitter-contract.js +8 -0
- package/dist/contracts/emitter-contract.js.map +1 -0
- package/dist/contracts/import-classifier.d.ts +36 -0
- package/dist/contracts/import-classifier.d.ts.map +1 -0
- package/dist/contracts/import-classifier.js +9 -0
- package/dist/contracts/import-classifier.js.map +1 -0
- package/dist/core/{attributes.d.ts → format/attributes.d.ts} +9 -14
- package/dist/core/format/attributes.d.ts.map +1 -0
- package/dist/core/format/attributes.js +190 -0
- package/dist/core/format/attributes.js.map +1 -0
- package/dist/core/format/attributes.test.d.ts.map +1 -0
- package/dist/core/{attributes.test.js → format/attributes.test.js} +70 -32
- package/dist/core/format/attributes.test.js.map +1 -0
- package/dist/core/format/backend-ast/index.d.ts +7 -0
- package/dist/core/format/backend-ast/index.d.ts.map +1 -0
- package/dist/core/format/backend-ast/index.js +6 -0
- package/dist/core/format/backend-ast/index.js.map +1 -0
- package/dist/core/format/backend-ast/printer.d.ts +33 -0
- package/dist/core/format/backend-ast/printer.d.ts.map +1 -0
- package/dist/core/format/backend-ast/printer.js +1151 -0
- package/dist/core/format/backend-ast/printer.js.map +1 -0
- package/dist/core/format/backend-ast/types.d.ts +504 -0
- package/dist/core/format/backend-ast/types.d.ts.map +1 -0
- package/dist/core/format/backend-ast/types.js +13 -0
- package/dist/core/format/backend-ast/types.js.map +1 -0
- package/dist/core/format/backend-ast/utils.d.ts +26 -0
- package/dist/core/format/backend-ast/utils.d.ts.map +1 -0
- package/dist/core/format/backend-ast/utils.js +65 -0
- package/dist/core/format/backend-ast/utils.js.map +1 -0
- package/dist/core/{exports.d.ts → format/exports.d.ts} +2 -2
- package/dist/core/format/exports.d.ts.map +1 -0
- package/dist/core/format/exports.js +22 -0
- package/dist/core/format/exports.js.map +1 -0
- package/dist/core/format/index.d.ts +9 -0
- package/dist/core/format/index.d.ts.map +1 -0
- package/dist/core/format/index.js +9 -0
- package/dist/core/format/index.js.map +1 -0
- package/dist/core/{local-names.d.ts → format/local-names.d.ts} +1 -1
- package/dist/core/format/local-names.d.ts.map +1 -0
- package/dist/core/{local-names.js → format/local-names.js} +1 -1
- package/dist/core/format/local-names.js.map +1 -0
- package/dist/core/format/module-emitter/assembly.d.ts +27 -0
- package/dist/core/format/module-emitter/assembly.d.ts.map +1 -0
- package/dist/core/format/module-emitter/assembly.js +44 -0
- package/dist/core/format/module-emitter/assembly.js.map +1 -0
- package/dist/core/{module-emitter → format/module-emitter}/header.d.ts +1 -1
- package/dist/core/format/module-emitter/header.d.ts.map +1 -0
- package/dist/core/{module-emitter → format/module-emitter}/header.js +1 -1
- package/dist/core/format/module-emitter/header.js.map +1 -0
- package/dist/core/format/module-emitter/index.d.ts.map +1 -0
- package/dist/core/format/module-emitter/index.js.map +1 -0
- package/dist/core/format/module-emitter/namespace.d.ts +21 -0
- package/dist/core/format/module-emitter/namespace.d.ts.map +1 -0
- package/dist/core/format/module-emitter/namespace.js +58 -0
- package/dist/core/format/module-emitter/namespace.js.map +1 -0
- package/dist/core/{module-emitter → format/module-emitter}/orchestrator.d.ts +1 -1
- package/dist/core/format/module-emitter/orchestrator.d.ts.map +1 -0
- package/dist/core/{module-emitter → format/module-emitter}/orchestrator.js +19 -19
- package/dist/core/format/module-emitter/orchestrator.js.map +1 -0
- package/dist/core/format/module-emitter/separation.d.ts.map +1 -0
- package/dist/core/format/module-emitter/separation.js.map +1 -0
- package/dist/core/{module-emitter → format/module-emitter}/static-container.d.ts +8 -3
- package/dist/core/format/module-emitter/static-container.d.ts.map +1 -0
- package/dist/core/format/module-emitter/static-container.js +202 -0
- package/dist/core/format/module-emitter/static-container.js.map +1 -0
- package/dist/core/format/module-emitter.d.ts.map +1 -0
- package/dist/core/format/module-emitter.js.map +1 -0
- package/dist/core/{options.d.ts → format/options.d.ts} +1 -1
- package/dist/core/format/options.d.ts.map +1 -0
- package/dist/core/format/options.js.map +1 -0
- package/dist/core/index.d.ts +2 -7
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/index.js +2 -7
- package/dist/core/index.js.map +1 -1
- package/dist/core/semantic/boolean-context.d.ts +44 -0
- package/dist/core/semantic/boolean-context.d.ts.map +1 -0
- package/dist/core/semantic/boolean-context.js +717 -0
- package/dist/core/semantic/boolean-context.js.map +1 -0
- package/dist/core/semantic/boolean-context.test.d.ts.map +1 -0
- package/dist/core/{boolean-context.test.js → semantic/boolean-context.test.js} +86 -109
- package/dist/core/semantic/boolean-context.test.js.map +1 -0
- package/dist/core/{imports.d.ts → semantic/imports.d.ts} +1 -5
- package/dist/core/semantic/imports.d.ts.map +1 -0
- package/dist/core/{imports.js → semantic/imports.js} +56 -74
- package/dist/core/semantic/imports.js.map +1 -0
- package/dist/core/semantic/imports.test.d.ts.map +1 -0
- package/dist/core/semantic/imports.test.js +229 -0
- package/dist/core/semantic/imports.test.js.map +1 -0
- package/dist/core/semantic/index.d.ts +15 -0
- package/dist/core/semantic/index.d.ts.map +1 -0
- package/dist/core/semantic/index.js +15 -0
- package/dist/core/semantic/index.js.map +1 -0
- package/dist/core/{local-types.d.ts → semantic/local-types.d.ts} +1 -1
- package/dist/core/semantic/local-types.d.ts.map +1 -0
- package/dist/core/semantic/local-types.js.map +1 -0
- package/dist/core/{module-map.d.ts → semantic/module-map.d.ts} +1 -1
- package/dist/core/semantic/module-map.d.ts.map +1 -0
- package/dist/core/semantic/module-map.js.map +1 -0
- package/dist/core/semantic/module-map.test.d.ts.map +1 -0
- package/dist/core/semantic/module-map.test.js.map +1 -0
- package/dist/core/semantic/naming-collisions.d.ts.map +1 -0
- package/dist/core/{naming-collisions.js → semantic/naming-collisions.js} +1 -1
- package/dist/core/semantic/naming-collisions.js.map +1 -0
- package/dist/core/{type-alias-index.d.ts → semantic/type-alias-index.d.ts} +1 -1
- package/dist/core/semantic/type-alias-index.d.ts.map +1 -0
- package/dist/core/semantic/type-alias-index.js.map +1 -0
- package/dist/core/semantic/type-compatibility.d.ts.map +1 -0
- package/dist/core/semantic/type-compatibility.js.map +1 -0
- package/dist/core/{type-member-index.d.ts → semantic/type-member-index.d.ts} +1 -1
- package/dist/core/semantic/type-member-index.d.ts.map +1 -0
- package/dist/core/semantic/type-member-index.js.map +1 -0
- package/dist/core/semantic/type-params.d.ts.map +1 -0
- package/dist/core/semantic/type-params.js.map +1 -0
- package/dist/core/{type-resolution.d.ts → semantic/type-resolution.d.ts} +3 -6
- package/dist/core/semantic/type-resolution.d.ts.map +1 -0
- package/dist/core/{type-resolution.js → semantic/type-resolution.js} +15 -25
- package/dist/core/semantic/type-resolution.js.map +1 -0
- package/dist/core/semantic/type-resolution.test.d.ts.map +1 -0
- package/dist/core/{type-resolution.test.js → semantic/type-resolution.test.js} +11 -19
- package/dist/core/semantic/type-resolution.test.js.map +1 -0
- package/dist/core/semantic/unsafe.d.ts.map +1 -0
- package/dist/core/semantic/unsafe.js.map +1 -0
- package/dist/emitter-types/core.d.ts +6 -12
- package/dist/emitter-types/core.d.ts.map +1 -1
- package/dist/emitter-types/index.d.ts +1 -1
- package/dist/emitter-types/index.d.ts.map +1 -1
- package/dist/emitter-types/index.js.map +1 -1
- package/dist/emitter.d.ts +1 -1
- package/dist/emitter.d.ts.map +1 -1
- package/dist/emitter.js +9 -8
- package/dist/emitter.js.map +1 -1
- package/dist/expression-emitter.d.ts +10 -5
- package/dist/expression-emitter.d.ts.map +1 -1
- package/dist/expression-emitter.js +333 -117
- package/dist/expression-emitter.js.map +1 -1
- package/dist/expressions/access.d.ts +4 -3
- package/dist/expressions/access.d.ts.map +1 -1
- package/dist/expressions/access.js +252 -102
- package/dist/expressions/access.js.map +1 -1
- package/dist/expressions/calls/call-analysis.d.ts +86 -0
- package/dist/expressions/calls/call-analysis.d.ts.map +1 -0
- package/dist/expressions/calls/call-analysis.js +284 -0
- package/dist/expressions/calls/call-analysis.js.map +1 -0
- package/dist/expressions/calls/call-emitter.d.ts +13 -0
- package/dist/expressions/calls/call-emitter.d.ts.map +1 -0
- package/dist/expressions/calls/call-emitter.js +1048 -0
- package/dist/expressions/calls/call-emitter.js.map +1 -0
- package/dist/expressions/calls/new-emitter.d.ts +13 -0
- package/dist/expressions/calls/new-emitter.d.ts.map +1 -0
- package/dist/expressions/calls/new-emitter.js +641 -0
- package/dist/expressions/calls/new-emitter.js.map +1 -0
- package/dist/expressions/calls.d.ts +2 -14
- package/dist/expressions/calls.d.ts.map +1 -1
- package/dist/expressions/calls.js +2 -909
- package/dist/expressions/calls.js.map +1 -1
- package/dist/expressions/collections.d.ts +6 -16
- package/dist/expressions/collections.d.ts.map +1 -1
- package/dist/expressions/collections.js +318 -217
- package/dist/expressions/collections.js.map +1 -1
- package/dist/expressions/functions.d.ts +6 -5
- package/dist/expressions/functions.d.ts.map +1 -1
- package/dist/expressions/functions.js +57 -62
- package/dist/expressions/functions.js.map +1 -1
- package/dist/expressions/identifiers.d.ts +11 -6
- package/dist/expressions/identifiers.d.ts.map +1 -1
- package/dist/expressions/identifiers.js +76 -25
- package/dist/expressions/identifiers.js.map +1 -1
- package/dist/expressions/index.d.ts +1 -1
- package/dist/expressions/index.d.ts.map +1 -1
- package/dist/expressions/index.js +1 -1
- package/dist/expressions/index.js.map +1 -1
- package/dist/expressions/index.test.js +605 -0
- package/dist/expressions/index.test.js.map +1 -1
- package/dist/expressions/literals.d.ts +4 -3
- package/dist/expressions/literals.d.ts.map +1 -1
- package/dist/expressions/literals.js +25 -17
- package/dist/expressions/literals.js.map +1 -1
- package/dist/expressions/literals.test.js +18 -18
- package/dist/expressions/literals.test.js.map +1 -1
- package/dist/expressions/operators/assignment-emitter.d.ts +16 -0
- package/dist/expressions/operators/assignment-emitter.d.ts.map +1 -0
- package/dist/expressions/operators/assignment-emitter.js +118 -0
- package/dist/expressions/operators/assignment-emitter.js.map +1 -0
- package/dist/expressions/operators/binary-emitter.d.ts +33 -0
- package/dist/expressions/operators/binary-emitter.d.ts.map +1 -0
- package/dist/expressions/operators/binary-emitter.js +398 -0
- package/dist/expressions/operators/binary-emitter.js.map +1 -0
- package/dist/expressions/operators/conditional-emitter.d.ts +17 -0
- package/dist/expressions/operators/conditional-emitter.d.ts.map +1 -0
- package/dist/expressions/operators/conditional-emitter.js +306 -0
- package/dist/expressions/operators/conditional-emitter.js.map +1 -0
- package/dist/expressions/operators/helpers.d.ts +37 -0
- package/dist/expressions/operators/helpers.d.ts.map +1 -0
- package/dist/expressions/operators/helpers.js +136 -0
- package/dist/expressions/operators/helpers.js.map +1 -0
- package/dist/expressions/operators/logical-emitter.d.ts +23 -0
- package/dist/expressions/operators/logical-emitter.d.ts.map +1 -0
- package/dist/expressions/operators/logical-emitter.js +73 -0
- package/dist/expressions/operators/logical-emitter.js.map +1 -0
- package/dist/expressions/operators/unary-emitter.d.ts +30 -0
- package/dist/expressions/operators/unary-emitter.d.ts.map +1 -0
- package/dist/expressions/operators/unary-emitter.js +244 -0
- package/dist/expressions/operators/unary-emitter.js.map +1 -0
- package/dist/expressions/operators.d.ts +5 -81
- package/dist/expressions/operators.d.ts.map +1 -1
- package/dist/expressions/operators.js +5 -949
- package/dist/expressions/operators.js.map +1 -1
- package/dist/expressions/other.d.ts +15 -11
- package/dist/expressions/other.d.ts.map +1 -1
- package/dist/expressions/other.js +51 -36
- package/dist/expressions/other.js.map +1 -1
- package/dist/expressions/precedence.test.js +1 -1
- package/dist/expressions/precedence.test.js.map +1 -1
- package/dist/generator-exchange.d.ts +10 -3
- package/dist/generator-exchange.d.ts.map +1 -1
- package/dist/generator-exchange.js +57 -54
- package/dist/generator-exchange.js.map +1 -1
- package/dist/generator-wrapper.d.ts +17 -65
- package/dist/generator-wrapper.d.ts.map +1 -1
- package/dist/generator-wrapper.js +396 -220
- package/dist/generator-wrapper.js.map +1 -1
- package/dist/generator-wrapper.test.js +22 -14
- package/dist/generator-wrapper.test.js.map +1 -1
- package/dist/integration.test.js +169 -1
- package/dist/integration.test.js.map +1 -1
- package/dist/patterns.d.ts +18 -88
- package/dist/patterns.d.ts.map +1 -1
- package/dist/patterns.js +540 -304
- package/dist/patterns.js.map +1 -1
- package/dist/patterns.test.js +5 -4
- package/dist/patterns.test.js.map +1 -1
- package/dist/specialization/generation.d.ts +7 -3
- package/dist/specialization/generation.d.ts.map +1 -1
- package/dist/specialization/generation.js +31 -15
- package/dist/specialization/generation.js.map +1 -1
- package/dist/specialization/type-aliases.test.js +47 -2
- package/dist/specialization/type-aliases.test.js.map +1 -1
- package/dist/statement-emitter.d.ts +15 -4
- package/dist/statement-emitter.d.ts.map +1 -1
- package/dist/statement-emitter.js +54 -47
- package/dist/statement-emitter.js.map +1 -1
- package/dist/statements/blocks.d.ts +24 -16
- package/dist/statements/blocks.d.ts.map +1 -1
- package/dist/statements/blocks.js +242 -65
- package/dist/statements/blocks.js.map +1 -1
- package/dist/statements/classes/index.d.ts +1 -1
- package/dist/statements/classes/index.d.ts.map +1 -1
- package/dist/statements/classes/index.js +1 -1
- package/dist/statements/classes/index.js.map +1 -1
- package/dist/statements/classes/inline-types.d.ts +4 -3
- package/dist/statements/classes/inline-types.d.ts.map +1 -1
- package/dist/statements/classes/inline-types.js +21 -21
- package/dist/statements/classes/inline-types.js.map +1 -1
- package/dist/statements/classes/members/constructors.d.ts +4 -3
- package/dist/statements/classes/members/constructors.d.ts.map +1 -1
- package/dist/statements/classes/members/constructors.js +57 -58
- package/dist/statements/classes/members/constructors.js.map +1 -1
- package/dist/statements/classes/members/methods.d.ts +4 -3
- package/dist/statements/classes/members/methods.d.ts.map +1 -1
- package/dist/statements/classes/members/methods.js +106 -101
- package/dist/statements/classes/members/methods.js.map +1 -1
- package/dist/statements/classes/members/orchestrator.d.ts +4 -3
- package/dist/statements/classes/members/orchestrator.d.ts.map +1 -1
- package/dist/statements/classes/members/orchestrator.js +2 -2
- package/dist/statements/classes/members/orchestrator.js.map +1 -1
- package/dist/statements/classes/members/properties.d.ts +4 -3
- package/dist/statements/classes/members/properties.d.ts.map +1 -1
- package/dist/statements/classes/members/properties.js +105 -88
- package/dist/statements/classes/members/properties.js.map +1 -1
- package/dist/statements/classes/members/shadowing.test.js +7 -2
- package/dist/statements/classes/members/shadowing.test.js.map +1 -1
- package/dist/statements/classes/members/static-readonly-properties.test.js +4 -1
- package/dist/statements/classes/members/static-readonly-properties.test.js.map +1 -1
- package/dist/statements/classes/parameters.d.ts +8 -10
- package/dist/statements/classes/parameters.d.ts.map +1 -1
- package/dist/statements/classes/parameters.js +30 -26
- package/dist/statements/classes/parameters.js.map +1 -1
- package/dist/statements/classes/properties.d.ts +4 -3
- package/dist/statements/classes/properties.d.ts.map +1 -1
- package/dist/statements/classes/properties.js +76 -50
- package/dist/statements/classes/properties.js.map +1 -1
- package/dist/statements/classes.d.ts +1 -1
- package/dist/statements/classes.d.ts.map +1 -1
- package/dist/statements/classes.js +1 -1
- package/dist/statements/classes.js.map +1 -1
- package/dist/statements/control/conditionals/guard-analysis.d.ts +169 -0
- package/dist/statements/control/conditionals/guard-analysis.d.ts.map +1 -0
- package/dist/statements/control/conditionals/guard-analysis.js +591 -0
- package/dist/statements/control/conditionals/guard-analysis.js.map +1 -0
- package/dist/statements/control/conditionals/if-emitter.d.ts +14 -0
- package/dist/statements/control/conditionals/if-emitter.d.ts.map +1 -0
- package/dist/statements/control/conditionals/if-emitter.js +725 -0
- package/dist/statements/control/conditionals/if-emitter.js.map +1 -0
- package/dist/statements/control/conditionals/switch-emitter.d.ts +13 -0
- package/dist/statements/control/conditionals/switch-emitter.d.ts.map +1 -0
- package/dist/statements/control/conditionals/switch-emitter.js +60 -0
- package/dist/statements/control/conditionals/switch-emitter.js.map +1 -0
- package/dist/statements/control/conditionals.d.ts +3 -15
- package/dist/statements/control/conditionals.d.ts.map +1 -1
- package/dist/statements/control/conditionals.js +3 -1152
- package/dist/statements/control/conditionals.js.map +1 -1
- package/dist/statements/control/exceptions.d.ts +8 -6
- package/dist/statements/control/exceptions.d.ts.map +1 -1
- package/dist/statements/control/exceptions.js +35 -23
- package/dist/statements/control/exceptions.js.map +1 -1
- package/dist/statements/control/index.d.ts +3 -3
- package/dist/statements/control/index.d.ts.map +1 -1
- package/dist/statements/control/index.js +3 -3
- package/dist/statements/control/index.js.map +1 -1
- package/dist/statements/control/loops.d.ts +14 -12
- package/dist/statements/control/loops.d.ts.map +1 -1
- package/dist/statements/control/loops.js +147 -82
- package/dist/statements/control/loops.js.map +1 -1
- package/dist/statements/control.d.ts +1 -1
- package/dist/statements/control.d.ts.map +1 -1
- package/dist/statements/control.js +1 -1
- package/dist/statements/control.js.map +1 -1
- package/dist/statements/declarations/classes.d.ts +7 -3
- package/dist/statements/declarations/classes.d.ts.map +1 -1
- package/dist/statements/declarations/classes.js +107 -83
- package/dist/statements/declarations/classes.js.map +1 -1
- package/dist/statements/declarations/enums.d.ts +4 -3
- package/dist/statements/declarations/enums.d.ts.map +1 -1
- package/dist/statements/declarations/enums.js +16 -15
- package/dist/statements/declarations/enums.js.map +1 -1
- package/dist/statements/declarations/functions.d.ts +18 -2
- package/dist/statements/declarations/functions.d.ts.map +1 -1
- package/dist/statements/declarations/functions.js +633 -162
- package/dist/statements/declarations/functions.js.map +1 -1
- package/dist/statements/declarations/index.d.ts +2 -2
- package/dist/statements/declarations/index.d.ts.map +1 -1
- package/dist/statements/declarations/index.js +2 -2
- package/dist/statements/declarations/index.js.map +1 -1
- package/dist/statements/declarations/interfaces.d.ts +7 -3
- package/dist/statements/declarations/interfaces.d.ts.map +1 -1
- package/dist/statements/declarations/interfaces.js +138 -105
- package/dist/statements/declarations/interfaces.js.map +1 -1
- package/dist/statements/declarations/type-aliases.d.ts +7 -3
- package/dist/statements/declarations/type-aliases.d.ts.map +1 -1
- package/dist/statements/declarations/type-aliases.js +122 -82
- package/dist/statements/declarations/type-aliases.js.map +1 -1
- package/dist/statements/declarations/variables.d.ts +12 -2
- package/dist/statements/declarations/variables.d.ts.map +1 -1
- package/dist/statements/declarations/variables.js +541 -428
- package/dist/statements/declarations/variables.js.map +1 -1
- package/dist/statements/declarations.d.ts +1 -1
- package/dist/statements/declarations.d.ts.map +1 -1
- package/dist/statements/declarations.js +1 -1
- package/dist/statements/declarations.js.map +1 -1
- package/dist/statements/index.d.ts +3 -3
- package/dist/statements/index.d.ts.map +1 -1
- package/dist/statements/index.js +5 -5
- package/dist/statements/index.js.map +1 -1
- package/dist/statements/index.test.js +307 -0
- package/dist/statements/index.test.js.map +1 -1
- package/dist/type-emitter.d.ts +1 -1
- package/dist/type-emitter.d.ts.map +1 -1
- package/dist/type-emitter.js +1 -1
- package/dist/type-emitter.js.map +1 -1
- package/dist/types/arrays.d.ts +3 -2
- package/dist/types/arrays.d.ts.map +1 -1
- package/dist/types/arrays.js +7 -5
- package/dist/types/arrays.js.map +1 -1
- package/dist/types/dictionaries.d.ts +6 -3
- package/dist/types/dictionaries.d.ts.map +1 -1
- package/dist/types/dictionaries.js +22 -10
- package/dist/types/dictionaries.js.map +1 -1
- package/dist/types/emitter.d.ts +8 -2
- package/dist/types/emitter.d.ts.map +1 -1
- package/dist/types/emitter.js +20 -6
- package/dist/types/emitter.js.map +1 -1
- package/dist/types/functions.d.ts +3 -2
- package/dist/types/functions.d.ts.map +1 -1
- package/dist/types/functions.js +36 -13
- package/dist/types/functions.js.map +1 -1
- package/dist/types/index.d.ts +2 -2
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +2 -2
- package/dist/types/index.js.map +1 -1
- package/dist/types/index.test.js +137 -0
- package/dist/types/index.test.js.map +1 -1
- package/dist/types/intersections.d.ts +3 -2
- package/dist/types/intersections.d.ts.map +1 -1
- package/dist/types/intersections.js +2 -2
- package/dist/types/intersections.js.map +1 -1
- package/dist/types/literals.d.ts +9 -2
- package/dist/types/literals.d.ts.map +1 -1
- package/dist/types/literals.js +11 -5
- package/dist/types/literals.js.map +1 -1
- package/dist/types/objects.d.ts +3 -2
- package/dist/types/objects.d.ts.map +1 -1
- package/dist/types/objects.js +1 -1
- package/dist/types/objects.js.map +1 -1
- package/dist/types/parameters.d.ts +6 -5
- package/dist/types/parameters.d.ts.map +1 -1
- package/dist/types/parameters.js +88 -29
- package/dist/types/parameters.js.map +1 -1
- package/dist/types/parameters.test.js +9 -4
- package/dist/types/parameters.test.js.map +1 -1
- package/dist/types/primitives.d.ts +5 -4
- package/dist/types/primitives.d.ts.map +1 -1
- package/dist/types/primitives.js +14 -13
- package/dist/types/primitives.js.map +1 -1
- package/dist/types/references.d.ts +3 -2
- package/dist/types/references.d.ts.map +1 -1
- package/dist/types/references.js +135 -111
- package/dist/types/references.js.map +1 -1
- package/dist/types/tuples.d.ts +3 -2
- package/dist/types/tuples.d.ts.map +1 -1
- package/dist/types/tuples.js +25 -11
- package/dist/types/tuples.js.map +1 -1
- package/dist/types/unions.d.ts +3 -2
- package/dist/types/unions.d.ts.map +1 -1
- package/dist/types/unions.js +36 -21
- package/dist/types/unions.js.map +1 -1
- package/dist/types.d.ts +1 -1
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js.map +1 -1
- package/package.json +2 -2
- package/dist/core/attributes.d.ts.map +0 -1
- package/dist/core/attributes.js +0 -141
- package/dist/core/attributes.js.map +0 -1
- package/dist/core/attributes.test.d.ts.map +0 -1
- package/dist/core/attributes.test.js.map +0 -1
- package/dist/core/boolean-context.d.ts +0 -42
- package/dist/core/boolean-context.d.ts.map +0 -1
- package/dist/core/boolean-context.js +0 -442
- package/dist/core/boolean-context.js.map +0 -1
- package/dist/core/boolean-context.test.d.ts.map +0 -1
- package/dist/core/boolean-context.test.js.map +0 -1
- package/dist/core/exports.d.ts.map +0 -1
- package/dist/core/exports.js +0 -28
- package/dist/core/exports.js.map +0 -1
- package/dist/core/imports.d.ts.map +0 -1
- package/dist/core/imports.js.map +0 -1
- package/dist/core/imports.test.d.ts.map +0 -1
- package/dist/core/imports.test.js +0 -79
- package/dist/core/imports.test.js.map +0 -1
- package/dist/core/local-names.d.ts.map +0 -1
- package/dist/core/local-names.js.map +0 -1
- package/dist/core/local-types.d.ts.map +0 -1
- package/dist/core/local-types.js.map +0 -1
- package/dist/core/module-emitter/assembly.d.ts +0 -24
- package/dist/core/module-emitter/assembly.d.ts.map +0 -1
- package/dist/core/module-emitter/assembly.js +0 -69
- package/dist/core/module-emitter/assembly.js.map +0 -1
- package/dist/core/module-emitter/header.d.ts.map +0 -1
- package/dist/core/module-emitter/header.js.map +0 -1
- package/dist/core/module-emitter/index.d.ts.map +0 -1
- package/dist/core/module-emitter/index.js.map +0 -1
- package/dist/core/module-emitter/namespace.d.ts +0 -14
- package/dist/core/module-emitter/namespace.d.ts.map +0 -1
- package/dist/core/module-emitter/namespace.js +0 -26
- package/dist/core/module-emitter/namespace.js.map +0 -1
- package/dist/core/module-emitter/orchestrator.d.ts.map +0 -1
- package/dist/core/module-emitter/orchestrator.js.map +0 -1
- package/dist/core/module-emitter/separation.d.ts.map +0 -1
- package/dist/core/module-emitter/separation.js.map +0 -1
- package/dist/core/module-emitter/static-container.d.ts.map +0 -1
- package/dist/core/module-emitter/static-container.js +0 -139
- package/dist/core/module-emitter/static-container.js.map +0 -1
- package/dist/core/module-emitter.d.ts.map +0 -1
- package/dist/core/module-emitter.js.map +0 -1
- package/dist/core/module-map.d.ts.map +0 -1
- package/dist/core/module-map.js.map +0 -1
- package/dist/core/module-map.test.d.ts.map +0 -1
- package/dist/core/module-map.test.js.map +0 -1
- package/dist/core/naming-collisions.d.ts.map +0 -1
- package/dist/core/naming-collisions.js.map +0 -1
- package/dist/core/options.d.ts.map +0 -1
- package/dist/core/options.js.map +0 -1
- package/dist/core/type-alias-index.d.ts.map +0 -1
- package/dist/core/type-alias-index.js.map +0 -1
- package/dist/core/type-compatibility.d.ts.map +0 -1
- package/dist/core/type-compatibility.js.map +0 -1
- package/dist/core/type-member-index.d.ts.map +0 -1
- package/dist/core/type-member-index.js.map +0 -1
- package/dist/core/type-params.d.ts.map +0 -1
- package/dist/core/type-params.js.map +0 -1
- package/dist/core/type-resolution.d.ts.map +0 -1
- package/dist/core/type-resolution.js.map +0 -1
- package/dist/core/type-resolution.test.d.ts.map +0 -1
- package/dist/core/type-resolution.test.js.map +0 -1
- package/dist/core/unsafe.d.ts.map +0 -1
- package/dist/core/unsafe.js.map +0 -1
- /package/dist/core/{attributes.test.d.ts → format/attributes.test.d.ts} +0 -0
- /package/dist/core/{module-emitter → format/module-emitter}/index.d.ts +0 -0
- /package/dist/core/{module-emitter → format/module-emitter}/index.js +0 -0
- /package/dist/core/{module-emitter → format/module-emitter}/separation.d.ts +0 -0
- /package/dist/core/{module-emitter → format/module-emitter}/separation.js +0 -0
- /package/dist/core/{module-emitter.d.ts → format/module-emitter.d.ts} +0 -0
- /package/dist/core/{module-emitter.js → format/module-emitter.js} +0 -0
- /package/dist/core/{options.js → format/options.js} +0 -0
- /package/dist/core/{boolean-context.test.d.ts → semantic/boolean-context.test.d.ts} +0 -0
- /package/dist/core/{imports.test.d.ts → semantic/imports.test.d.ts} +0 -0
- /package/dist/core/{local-types.js → semantic/local-types.js} +0 -0
- /package/dist/core/{module-map.js → semantic/module-map.js} +0 -0
- /package/dist/core/{module-map.test.d.ts → semantic/module-map.test.d.ts} +0 -0
- /package/dist/core/{module-map.test.js → semantic/module-map.test.js} +0 -0
- /package/dist/core/{naming-collisions.d.ts → semantic/naming-collisions.d.ts} +0 -0
- /package/dist/core/{type-alias-index.js → semantic/type-alias-index.js} +0 -0
- /package/dist/core/{type-compatibility.d.ts → semantic/type-compatibility.d.ts} +0 -0
- /package/dist/core/{type-compatibility.js → semantic/type-compatibility.js} +0 -0
- /package/dist/core/{type-member-index.js → semantic/type-member-index.js} +0 -0
- /package/dist/core/{type-params.d.ts → semantic/type-params.d.ts} +0 -0
- /package/dist/core/{type-params.js → semantic/type-params.js} +0 -0
- /package/dist/core/{type-resolution.test.d.ts → semantic/type-resolution.test.d.ts} +0 -0
- /package/dist/core/{unsafe.d.ts → semantic/unsafe.d.ts} +0 -0
- /package/dist/core/{unsafe.js → semantic/unsafe.js} +0 -0
|
@@ -0,0 +1,244 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Unary and update operator expression emitters
|
|
3
|
+
*
|
|
4
|
+
* NEW NUMERIC SPEC:
|
|
5
|
+
* - Literals use raw lexeme (no contextual widening)
|
|
6
|
+
* - Integer casts only from IrCastExpression (not inferred from expectedType)
|
|
7
|
+
*/
|
|
8
|
+
import { emitExpressionAst } from "../../expression-emitter.js";
|
|
9
|
+
import { emitTypeAst } from "../../type-emitter.js";
|
|
10
|
+
import { emitBooleanConditionAst } from "../../core/semantic/boolean-context.js";
|
|
11
|
+
import { extractCalleeNameFromAst } from "../../core/format/backend-ast/utils.js";
|
|
12
|
+
/**
|
|
13
|
+
* Emit a unary operator expression as CSharpExpressionAst (-, +, !, ~, typeof, void, delete)
|
|
14
|
+
*
|
|
15
|
+
* NEW NUMERIC SPEC: No contextual type propagation for numeric literals.
|
|
16
|
+
* Explicit casts come from IrCastExpression nodes.
|
|
17
|
+
*
|
|
18
|
+
* @param expr - The unary expression
|
|
19
|
+
* @param context - Emitter context
|
|
20
|
+
* @param expectedType - Used for void IIFE return type
|
|
21
|
+
*/
|
|
22
|
+
export const emitUnary = (expr, context, expectedType) => {
|
|
23
|
+
// In TypeScript, `!x` applies JS ToBoolean semantics to *any* operand.
|
|
24
|
+
// In C#, `!` only works on booleans, so we must coerce to a boolean condition.
|
|
25
|
+
if (expr.operator === "!") {
|
|
26
|
+
const [condAst, condCtx] = emitBooleanConditionAst(expr.expression, (e, ctx) => emitExpressionAst(e, ctx), context);
|
|
27
|
+
return [
|
|
28
|
+
{
|
|
29
|
+
kind: "prefixUnaryExpression",
|
|
30
|
+
operatorToken: "!",
|
|
31
|
+
operand: condAst,
|
|
32
|
+
},
|
|
33
|
+
condCtx,
|
|
34
|
+
];
|
|
35
|
+
}
|
|
36
|
+
if (expr.operator === "delete") {
|
|
37
|
+
// JavaScript `delete obj[key]` maps to dictionary key removal in CLR:
|
|
38
|
+
// delete dict[key] -> dict.Remove(key)
|
|
39
|
+
const target = expr.expression;
|
|
40
|
+
if (target.kind === "memberAccess" &&
|
|
41
|
+
target.isComputed &&
|
|
42
|
+
typeof target.property !== "string" &&
|
|
43
|
+
(target.accessKind === "dictionary" ||
|
|
44
|
+
target.object.inferredType?.kind === "dictionaryType")) {
|
|
45
|
+
const [objectAst, objectContext] = emitExpressionAst(target.object, context);
|
|
46
|
+
const [keyAst, keyContext] = emitExpressionAst(target.property, objectContext);
|
|
47
|
+
return [
|
|
48
|
+
{
|
|
49
|
+
kind: "invocationExpression",
|
|
50
|
+
expression: {
|
|
51
|
+
kind: "memberAccessExpression",
|
|
52
|
+
expression: objectAst,
|
|
53
|
+
memberName: "Remove",
|
|
54
|
+
},
|
|
55
|
+
arguments: [keyAst],
|
|
56
|
+
},
|
|
57
|
+
keyContext,
|
|
58
|
+
];
|
|
59
|
+
}
|
|
60
|
+
const [targetAst, newContext] = emitExpressionAst(target, context);
|
|
61
|
+
const targetText = extractCalleeNameFromAst(targetAst);
|
|
62
|
+
return [
|
|
63
|
+
{
|
|
64
|
+
kind: "identifierExpression",
|
|
65
|
+
identifier: `/* delete ${targetText} */`,
|
|
66
|
+
},
|
|
67
|
+
newContext,
|
|
68
|
+
];
|
|
69
|
+
}
|
|
70
|
+
const [operandAst, newContext] = emitExpressionAst(expr.expression, context);
|
|
71
|
+
if (expr.operator === "typeof") {
|
|
72
|
+
// typeof becomes global::Tsonic.Runtime.Operators.typeof()
|
|
73
|
+
return [
|
|
74
|
+
{
|
|
75
|
+
kind: "invocationExpression",
|
|
76
|
+
expression: {
|
|
77
|
+
kind: "identifierExpression",
|
|
78
|
+
identifier: "global::Tsonic.Runtime.Operators.@typeof",
|
|
79
|
+
},
|
|
80
|
+
arguments: [operandAst],
|
|
81
|
+
},
|
|
82
|
+
newContext,
|
|
83
|
+
];
|
|
84
|
+
}
|
|
85
|
+
if (expr.operator === "void") {
|
|
86
|
+
// `void expr` evaluates `expr` and yields `undefined`.
|
|
87
|
+
//
|
|
88
|
+
// In expression position we must produce a value, so use an IIFE:
|
|
89
|
+
// (() => { <eval expr>; return default(<T>); })()
|
|
90
|
+
//
|
|
91
|
+
// In statement position, emitExpressionStatement handles this separately.
|
|
92
|
+
const operand = expr.expression;
|
|
93
|
+
// If the operand is a literal null/undefined, evaluation is a no-op.
|
|
94
|
+
const isNoopOperand = (operand.kind === "literal" &&
|
|
95
|
+
(operand.value === undefined || operand.value === null)) ||
|
|
96
|
+
(operand.kind === "identifier" &&
|
|
97
|
+
(operand.name === "undefined" || operand.name === "null"));
|
|
98
|
+
let currentContext = newContext;
|
|
99
|
+
const effectiveExpectedType = expectedType &&
|
|
100
|
+
expectedType.kind !== "voidType" &&
|
|
101
|
+
expectedType.kind !== "neverType"
|
|
102
|
+
? expectedType
|
|
103
|
+
: undefined;
|
|
104
|
+
let returnTypeAst = {
|
|
105
|
+
kind: "nullableType",
|
|
106
|
+
underlyingType: { kind: "predefinedType", keyword: "object" },
|
|
107
|
+
};
|
|
108
|
+
if (effectiveExpectedType) {
|
|
109
|
+
try {
|
|
110
|
+
const [typeAst, next] = emitTypeAst(effectiveExpectedType, currentContext);
|
|
111
|
+
currentContext = next;
|
|
112
|
+
returnTypeAst = typeAst;
|
|
113
|
+
}
|
|
114
|
+
catch {
|
|
115
|
+
// Fall back to object? + default literal.
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
const defaultExpr = {
|
|
119
|
+
kind: "defaultExpression",
|
|
120
|
+
type: effectiveExpectedType ? returnTypeAst : undefined,
|
|
121
|
+
};
|
|
122
|
+
// Build the operand evaluation statement (if not a no-op).
|
|
123
|
+
const isStatementExpr = operand.kind === "call" ||
|
|
124
|
+
operand.kind === "new" ||
|
|
125
|
+
operand.kind === "assignment" ||
|
|
126
|
+
operand.kind === "update" ||
|
|
127
|
+
operand.kind === "await";
|
|
128
|
+
const operandStatements = isNoopOperand
|
|
129
|
+
? []
|
|
130
|
+
: [
|
|
131
|
+
{
|
|
132
|
+
kind: "expressionStatement",
|
|
133
|
+
expression: isStatementExpr
|
|
134
|
+
? operandAst
|
|
135
|
+
: {
|
|
136
|
+
kind: "assignmentExpression",
|
|
137
|
+
operatorToken: "=",
|
|
138
|
+
left: {
|
|
139
|
+
kind: "identifierExpression",
|
|
140
|
+
identifier: "_",
|
|
141
|
+
},
|
|
142
|
+
right: operandAst,
|
|
143
|
+
},
|
|
144
|
+
},
|
|
145
|
+
];
|
|
146
|
+
// Build IIFE: ((System.Func<T>)(() => { body }))()
|
|
147
|
+
const buildIife = (isAsync, funcReturnTypeAst) => {
|
|
148
|
+
const body = {
|
|
149
|
+
kind: "blockStatement",
|
|
150
|
+
statements: [
|
|
151
|
+
...operandStatements,
|
|
152
|
+
{ kind: "returnStatement", expression: defaultExpr },
|
|
153
|
+
],
|
|
154
|
+
};
|
|
155
|
+
const funcTypeAst = {
|
|
156
|
+
kind: "identifierType",
|
|
157
|
+
name: "global::System.Func",
|
|
158
|
+
typeArguments: [funcReturnTypeAst],
|
|
159
|
+
};
|
|
160
|
+
const lambdaAst = {
|
|
161
|
+
kind: "lambdaExpression",
|
|
162
|
+
isAsync,
|
|
163
|
+
parameters: [],
|
|
164
|
+
body,
|
|
165
|
+
};
|
|
166
|
+
const castAst = {
|
|
167
|
+
kind: "castExpression",
|
|
168
|
+
type: funcTypeAst,
|
|
169
|
+
expression: {
|
|
170
|
+
kind: "parenthesizedExpression",
|
|
171
|
+
expression: lambdaAst,
|
|
172
|
+
},
|
|
173
|
+
};
|
|
174
|
+
return {
|
|
175
|
+
kind: "invocationExpression",
|
|
176
|
+
expression: {
|
|
177
|
+
kind: "parenthesizedExpression",
|
|
178
|
+
expression: castAst,
|
|
179
|
+
},
|
|
180
|
+
arguments: [],
|
|
181
|
+
};
|
|
182
|
+
};
|
|
183
|
+
if (operand.kind === "await") {
|
|
184
|
+
if (!currentContext.isAsync) {
|
|
185
|
+
throw new Error("ICE: `void await <expr>` reached emitter in a non-async context.");
|
|
186
|
+
}
|
|
187
|
+
const taskTypeAst = {
|
|
188
|
+
kind: "identifierType",
|
|
189
|
+
name: "global::System.Threading.Tasks.Task",
|
|
190
|
+
typeArguments: [returnTypeAst],
|
|
191
|
+
};
|
|
192
|
+
const iifeAst = buildIife(true, taskTypeAst);
|
|
193
|
+
return [{ kind: "awaitExpression", expression: iifeAst }, currentContext];
|
|
194
|
+
}
|
|
195
|
+
return [buildIife(false, returnTypeAst), currentContext];
|
|
196
|
+
}
|
|
197
|
+
// Standard prefix operator: -, +, ~
|
|
198
|
+
return [
|
|
199
|
+
{
|
|
200
|
+
kind: "prefixUnaryExpression",
|
|
201
|
+
operatorToken: expr.operator,
|
|
202
|
+
operand: operandAst,
|
|
203
|
+
},
|
|
204
|
+
newContext,
|
|
205
|
+
];
|
|
206
|
+
};
|
|
207
|
+
/**
|
|
208
|
+
* Emit an update operator expression as CSharpExpressionAst (++, --)
|
|
209
|
+
*/
|
|
210
|
+
export const emitUpdate = (expr, context) => {
|
|
211
|
+
// Narrowing maps apply to *reads*, not writes.
|
|
212
|
+
// For update operators, suppress narrowed bindings for the target.
|
|
213
|
+
const operandCtx = expr.expression.kind === "identifier" &&
|
|
214
|
+
context.narrowedBindings?.has(expr.expression.name)
|
|
215
|
+
? (() => {
|
|
216
|
+
const next = new Map(context.narrowedBindings);
|
|
217
|
+
next.delete(expr.expression.name);
|
|
218
|
+
return { ...context, narrowedBindings: next };
|
|
219
|
+
})()
|
|
220
|
+
: context;
|
|
221
|
+
const [operandAst, ctx] = emitExpressionAst(expr.expression, operandCtx);
|
|
222
|
+
const newContext = operandCtx !== context
|
|
223
|
+
? { ...ctx, narrowedBindings: context.narrowedBindings }
|
|
224
|
+
: ctx;
|
|
225
|
+
if (expr.prefix) {
|
|
226
|
+
return [
|
|
227
|
+
{
|
|
228
|
+
kind: "prefixUnaryExpression",
|
|
229
|
+
operatorToken: expr.operator,
|
|
230
|
+
operand: operandAst,
|
|
231
|
+
},
|
|
232
|
+
newContext,
|
|
233
|
+
];
|
|
234
|
+
}
|
|
235
|
+
return [
|
|
236
|
+
{
|
|
237
|
+
kind: "postfixUnaryExpression",
|
|
238
|
+
operatorToken: expr.operator,
|
|
239
|
+
operand: operandAst,
|
|
240
|
+
},
|
|
241
|
+
newContext,
|
|
242
|
+
];
|
|
243
|
+
};
|
|
244
|
+
//# sourceMappingURL=unary-emitter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"unary-emitter.js","sourceRoot":"","sources":["../../../src/expressions/operators/unary-emitter.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,85 +6,9 @@
|
|
|
6
6
|
* - Integer casts only from IrCastExpression (not inferred from expectedType)
|
|
7
7
|
* - Binary ops: int op int = int, double op anything = double (C# semantics)
|
|
8
8
|
*/
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
* NEW NUMERIC SPEC: No contextual type propagation for numeric literals.
|
|
15
|
-
* Literals use their raw lexeme - C# will naturally handle int + int = int,
|
|
16
|
-
* int + double = double, etc.
|
|
17
|
-
*
|
|
18
|
-
* Explicit casts come from IrCastExpression nodes (generated by type-checker
|
|
19
|
-
* when user intent allows int → double coercion).
|
|
20
|
-
*
|
|
21
|
-
* STRING INDEXER FIX: In C#, string[int] returns char, not string.
|
|
22
|
-
* When comparing a string indexer result with a single-character string literal,
|
|
23
|
-
* we emit the string as a char literal to avoid CS0019 (char == string).
|
|
24
|
-
*
|
|
25
|
-
* @param expr - The binary expression
|
|
26
|
-
* @param context - Emitter context
|
|
27
|
-
* @param _expectedType - Unused under new spec (kept for API compatibility)
|
|
28
|
-
*/
|
|
29
|
-
export declare const emitBinary: (expr: Extract<IrExpression, {
|
|
30
|
-
kind: "binary";
|
|
31
|
-
}>, context: EmitterContext, _expectedType?: IrType) => [CSharpFragment, EmitterContext];
|
|
32
|
-
/**
|
|
33
|
-
* Emit a logical operator expression (&&, ||, ??)
|
|
34
|
-
*
|
|
35
|
-
* In TypeScript, || is used both for:
|
|
36
|
-
* 1. Boolean OR (when operands are booleans)
|
|
37
|
-
* 2. Nullish coalescing fallback (when left operand is nullable)
|
|
38
|
-
*
|
|
39
|
-
* In C#:
|
|
40
|
-
* - || only works with booleans
|
|
41
|
-
* - ?? is used for nullish coalescing
|
|
42
|
-
*
|
|
43
|
-
* We check if || is used with non-boolean operands and emit ?? instead.
|
|
44
|
-
*/
|
|
45
|
-
export declare const emitLogical: (expr: Extract<IrExpression, {
|
|
46
|
-
kind: "logical";
|
|
47
|
-
}>, context: EmitterContext) => [CSharpFragment, EmitterContext];
|
|
48
|
-
/**
|
|
49
|
-
* Emit a unary operator expression (-, +, !, ~, typeof, void, delete)
|
|
50
|
-
*
|
|
51
|
-
* NEW NUMERIC SPEC: No contextual type propagation for numeric literals.
|
|
52
|
-
* Explicit casts come from IrCastExpression nodes.
|
|
53
|
-
*
|
|
54
|
-
* @param expr - The unary expression
|
|
55
|
-
* @param context - Emitter context
|
|
56
|
-
* @param _expectedType - Unused under new spec (kept for API compatibility)
|
|
57
|
-
*/
|
|
58
|
-
export declare const emitUnary: (expr: Extract<IrExpression, {
|
|
59
|
-
kind: "unary";
|
|
60
|
-
}>, context: EmitterContext, expectedType?: IrType) => [CSharpFragment, EmitterContext];
|
|
61
|
-
/**
|
|
62
|
-
* Emit an update operator expression (++, --)
|
|
63
|
-
*/
|
|
64
|
-
export declare const emitUpdate: (expr: Extract<IrExpression, {
|
|
65
|
-
kind: "update";
|
|
66
|
-
}>, context: EmitterContext) => [CSharpFragment, EmitterContext];
|
|
67
|
-
/**
|
|
68
|
-
* Emit an assignment expression (=, +=, -=, etc.)
|
|
69
|
-
*
|
|
70
|
-
* Passes the LHS type as expected type to RHS, enabling proper integer
|
|
71
|
-
* literal emission for cases like `this.value = this.value + 1`.
|
|
72
|
-
*/
|
|
73
|
-
export declare const emitAssignment: (expr: Extract<IrExpression, {
|
|
74
|
-
kind: "assignment";
|
|
75
|
-
}>, context: EmitterContext) => [CSharpFragment, EmitterContext];
|
|
76
|
-
/**
|
|
77
|
-
* Emit a conditional (ternary) expression
|
|
78
|
-
*
|
|
79
|
-
* Supports type predicate narrowing:
|
|
80
|
-
* - `isUser(x) ? x.name : "anon"` → `x.Is1() ? (x.As1()).name : "anon"`
|
|
81
|
-
* - `!isUser(x) ? "anon" : x.name` → `!x.Is1() ? "anon" : (x.As1()).name`
|
|
82
|
-
*
|
|
83
|
-
* @param expr - The conditional expression
|
|
84
|
-
* @param context - Emitter context
|
|
85
|
-
* @param expectedType - Optional expected type (for null → default in generic contexts)
|
|
86
|
-
*/
|
|
87
|
-
export declare const emitConditional: (expr: Extract<IrExpression, {
|
|
88
|
-
kind: "conditional";
|
|
89
|
-
}>, context: EmitterContext, expectedType?: IrType) => [CSharpFragment, EmitterContext];
|
|
9
|
+
export { emitBinary } from "./operators/binary-emitter.js";
|
|
10
|
+
export { emitLogical } from "./operators/logical-emitter.js";
|
|
11
|
+
export { emitUnary, emitUpdate } from "./operators/unary-emitter.js";
|
|
12
|
+
export { emitAssignment } from "./operators/assignment-emitter.js";
|
|
13
|
+
export { emitConditional } from "./operators/conditional-emitter.js";
|
|
90
14
|
//# sourceMappingURL=operators.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"operators.d.ts","sourceRoot":"","sources":["../../src/expressions/operators.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"operators.d.ts","sourceRoot":"","sources":["../../src/expressions/operators.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC3D,OAAO,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AACrE,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC"}
|