@tsonic/frontend 0.0.1 → 0.0.4
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 -0
- package/{src/dependency-graph.ts → dist/dependency-graph.d.ts} +3 -11
- package/dist/dependency-graph.d.ts.map +1 -0
- package/dist/dependency-graph.js +9 -0
- package/dist/dependency-graph.js.map +1 -0
- package/dist/dotnet-metadata.d.ts +71 -0
- package/dist/dotnet-metadata.d.ts.map +1 -0
- package/dist/dotnet-metadata.js +78 -0
- package/dist/dotnet-metadata.js.map +1 -0
- package/dist/graph/builder.d.ts +10 -0
- package/dist/graph/builder.d.ts.map +1 -0
- package/dist/graph/builder.js +54 -0
- package/dist/graph/builder.js.map +1 -0
- package/dist/graph/circular.d.ts +10 -0
- package/dist/graph/circular.d.ts.map +1 -0
- package/dist/graph/circular.js +40 -0
- package/dist/graph/circular.js.map +1 -0
- package/dist/graph/extraction/exports.d.ts +10 -0
- package/dist/graph/extraction/exports.d.ts.map +1 -0
- package/dist/graph/extraction/exports.js +46 -0
- package/dist/graph/extraction/exports.js.map +1 -0
- package/dist/graph/extraction/imports.d.ts +11 -0
- package/dist/graph/extraction/imports.d.ts.map +1 -0
- package/dist/graph/extraction/imports.js +63 -0
- package/dist/graph/extraction/imports.js.map +1 -0
- package/dist/graph/extraction/index.d.ts +7 -0
- package/dist/graph/extraction/index.d.ts.map +1 -0
- package/{src/graph/extraction/index.ts → dist/graph/extraction/index.js} +1 -1
- package/dist/graph/extraction/index.js.map +1 -0
- package/dist/graph/extraction/orchestrator.d.ts +11 -0
- package/dist/graph/extraction/orchestrator.d.ts.map +1 -0
- package/dist/graph/extraction/orchestrator.js +78 -0
- package/dist/graph/extraction/orchestrator.js.map +1 -0
- package/dist/graph/extraction.d.ts +6 -0
- package/dist/graph/extraction.d.ts.map +1 -0
- package/{src/graph/extraction.ts → dist/graph/extraction.js} +2 -6
- package/dist/graph/extraction.js.map +1 -0
- package/dist/graph/helpers.d.ts +17 -0
- package/dist/graph/helpers.d.ts.map +1 -0
- package/dist/graph/helpers.js +40 -0
- package/dist/graph/helpers.js.map +1 -0
- package/{src/graph/index.ts → dist/graph/index.d.ts} +3 -11
- package/dist/graph/index.d.ts.map +1 -0
- package/dist/graph/index.js +8 -0
- package/dist/graph/index.js.map +1 -0
- package/{src/graph/types.ts → dist/graph/types.d.ts} +4 -5
- package/dist/graph/types.d.ts.map +1 -0
- package/dist/graph/types.js +5 -0
- package/dist/graph/types.js.map +1 -0
- package/dist/index.d.ts +26 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +43 -0
- package/dist/index.js.map +1 -0
- package/dist/ir/binding-resolution.test.d.ts +5 -0
- package/dist/ir/binding-resolution.test.d.ts.map +1 -0
- package/dist/ir/binding-resolution.test.js +518 -0
- package/dist/ir/binding-resolution.test.js.map +1 -0
- package/dist/ir/builder/exports.d.ts +10 -0
- package/dist/ir/builder/exports.d.ts.map +1 -0
- package/dist/ir/builder/exports.js +75 -0
- package/dist/ir/builder/exports.js.map +1 -0
- package/dist/ir/builder/helpers.d.ts +13 -0
- package/dist/ir/builder/helpers.d.ts.map +1 -0
- package/dist/ir/builder/helpers.js +23 -0
- package/dist/ir/builder/helpers.js.map +1 -0
- package/dist/ir/builder/imports.d.ts +18 -0
- package/dist/ir/builder/imports.d.ts.map +1 -0
- package/dist/ir/builder/imports.js +123 -0
- package/dist/ir/builder/imports.js.map +1 -0
- package/{src/ir/builder/index.ts → dist/ir/builder/index.d.ts} +1 -1
- package/dist/ir/builder/index.d.ts.map +1 -0
- package/dist/ir/builder/index.js +9 -0
- package/dist/ir/builder/index.js.map +1 -0
- package/dist/ir/builder/orchestrator.d.ts +18 -0
- package/dist/ir/builder/orchestrator.d.ts.map +1 -0
- package/dist/ir/builder/orchestrator.js +121 -0
- package/dist/ir/builder/orchestrator.js.map +1 -0
- package/dist/ir/builder/statements.d.ts +14 -0
- package/dist/ir/builder/statements.d.ts.map +1 -0
- package/dist/ir/builder/statements.js +43 -0
- package/dist/ir/builder/statements.js.map +1 -0
- package/dist/ir/builder/types.d.ts +8 -0
- package/dist/ir/builder/types.d.ts.map +1 -0
- package/dist/ir/builder/types.js +5 -0
- package/dist/ir/builder/types.js.map +1 -0
- package/dist/ir/builder/validation.d.ts +10 -0
- package/dist/ir/builder/validation.d.ts.map +1 -0
- package/dist/ir/builder/validation.js +86 -0
- package/dist/ir/builder/validation.js.map +1 -0
- package/{src/ir/builder.ts → dist/ir/builder.d.ts} +2 -5
- package/dist/ir/builder.d.ts.map +1 -0
- package/dist/ir/builder.js +10 -0
- package/dist/ir/builder.js.map +1 -0
- package/dist/ir/builder.test.d.ts +5 -0
- package/dist/ir/builder.test.d.ts.map +1 -0
- package/dist/ir/builder.test.js +498 -0
- package/dist/ir/builder.test.js.map +1 -0
- package/dist/ir/converters/expressions/access.d.ts +10 -0
- package/dist/ir/converters/expressions/access.d.ts.map +1 -0
- package/dist/ir/converters/expressions/access.js +132 -0
- package/dist/ir/converters/expressions/access.js.map +1 -0
- package/dist/ir/converters/expressions/calls.d.ts +14 -0
- package/dist/ir/converters/expressions/calls.d.ts.map +1 -0
- package/dist/ir/converters/expressions/calls.js +104 -0
- package/dist/ir/converters/expressions/calls.js.map +1 -0
- package/dist/ir/converters/expressions/collections.d.ts +14 -0
- package/dist/ir/converters/expressions/collections.d.ts.map +1 -0
- package/dist/ir/converters/expressions/collections.js +70 -0
- package/dist/ir/converters/expressions/collections.js.map +1 -0
- package/dist/ir/converters/expressions/functions.d.ts +14 -0
- package/dist/ir/converters/expressions/functions.d.ts.map +1 -0
- package/dist/ir/converters/expressions/functions.js +42 -0
- package/dist/ir/converters/expressions/functions.js.map +1 -0
- package/dist/ir/converters/expressions/helpers.d.ts +43 -0
- package/dist/ir/converters/expressions/helpers.d.ts.map +1 -0
- package/dist/ir/converters/expressions/helpers.js +217 -0
- package/dist/ir/converters/expressions/helpers.js.map +1 -0
- package/dist/ir/converters/expressions/index.d.ts +12 -0
- package/dist/ir/converters/expressions/index.d.ts.map +1 -0
- package/dist/ir/converters/expressions/index.js +20 -0
- package/dist/ir/converters/expressions/index.js.map +1 -0
- package/dist/ir/converters/expressions/literals.d.ts +10 -0
- package/dist/ir/converters/expressions/literals.d.ts.map +1 -0
- package/dist/ir/converters/expressions/literals.js +17 -0
- package/dist/ir/converters/expressions/literals.js.map +1 -0
- package/dist/ir/converters/expressions/operators.d.ts +18 -0
- package/dist/ir/converters/expressions/operators.d.ts.map +1 -0
- package/dist/ir/converters/expressions/operators.js +111 -0
- package/dist/ir/converters/expressions/operators.js.map +1 -0
- package/dist/ir/converters/expressions/other.d.ts +14 -0
- package/dist/ir/converters/expressions/other.d.ts.map +1 -0
- package/dist/ir/converters/expressions/other.js +44 -0
- package/dist/ir/converters/expressions/other.js.map +1 -0
- package/dist/ir/converters/statements/control/blocks.d.ts +10 -0
- package/dist/ir/converters/statements/control/blocks.d.ts.map +1 -0
- package/dist/ir/converters/statements/control/blocks.js +16 -0
- package/dist/ir/converters/statements/control/blocks.js.map +1 -0
- package/dist/ir/converters/statements/control/conditionals.d.ts +18 -0
- package/dist/ir/converters/statements/control/conditionals.d.ts.map +1 -0
- package/dist/ir/converters/statements/control/conditionals.js +46 -0
- package/dist/ir/converters/statements/control/conditionals.js.map +1 -0
- package/dist/ir/converters/statements/control/exceptions.d.ts +14 -0
- package/dist/ir/converters/statements/control/exceptions.d.ts.map +1 -0
- package/dist/ir/converters/statements/control/exceptions.js +33 -0
- package/dist/ir/converters/statements/control/exceptions.js.map +1 -0
- package/dist/ir/converters/statements/control/index.d.ts +8 -0
- package/dist/ir/converters/statements/control/index.d.ts.map +1 -0
- package/dist/ir/converters/statements/control/index.js +8 -0
- package/dist/ir/converters/statements/control/index.js.map +1 -0
- package/dist/ir/converters/statements/control/loops.d.ts +22 -0
- package/dist/ir/converters/statements/control/loops.d.ts.map +1 -0
- package/dist/ir/converters/statements/control/loops.js +75 -0
- package/dist/ir/converters/statements/control/loops.js.map +1 -0
- package/dist/ir/converters/statements/control.d.ts +6 -0
- package/dist/ir/converters/statements/control.d.ts.map +1 -0
- package/dist/ir/converters/statements/control.js +6 -0
- package/dist/ir/converters/statements/control.js.map +1 -0
- package/dist/ir/converters/statements/declarations/classes/constructors.d.ts +14 -0
- package/dist/ir/converters/statements/declarations/classes/constructors.d.ts.map +1 -0
- package/dist/ir/converters/statements/declarations/classes/constructors.js +91 -0
- package/dist/ir/converters/statements/declarations/classes/constructors.js.map +1 -0
- package/{src/ir/converters/statements/declarations/classes/index.ts → dist/ir/converters/statements/declarations/classes/index.d.ts} +2 -5
- package/dist/ir/converters/statements/declarations/classes/index.d.ts.map +1 -0
- package/dist/ir/converters/statements/declarations/classes/index.js +9 -0
- package/dist/ir/converters/statements/declarations/classes/index.js.map +1 -0
- package/dist/ir/converters/statements/declarations/classes/methods.d.ts +10 -0
- package/dist/ir/converters/statements/declarations/classes/methods.d.ts.map +1 -0
- package/dist/ir/converters/statements/declarations/classes/methods.js +39 -0
- package/dist/ir/converters/statements/declarations/classes/methods.js.map +1 -0
- package/dist/ir/converters/statements/declarations/classes/orchestrator.d.ts +10 -0
- package/dist/ir/converters/statements/declarations/classes/orchestrator.d.ts.map +1 -0
- package/dist/ir/converters/statements/declarations/classes/orchestrator.js +123 -0
- package/dist/ir/converters/statements/declarations/classes/orchestrator.js.map +1 -0
- package/dist/ir/converters/statements/declarations/classes/override-detection.d.ts +13 -0
- package/dist/ir/converters/statements/declarations/classes/override-detection.d.ts.map +1 -0
- package/dist/ir/converters/statements/declarations/classes/override-detection.js +79 -0
- package/dist/ir/converters/statements/declarations/classes/override-detection.js.map +1 -0
- package/dist/ir/converters/statements/declarations/classes/properties.d.ts +10 -0
- package/dist/ir/converters/statements/declarations/classes/properties.d.ts.map +1 -0
- package/dist/ir/converters/statements/declarations/classes/properties.js +42 -0
- package/dist/ir/converters/statements/declarations/classes/properties.js.map +1 -0
- package/dist/ir/converters/statements/declarations/classes.d.ts +6 -0
- package/dist/ir/converters/statements/declarations/classes.d.ts.map +1 -0
- package/{src/ir/converters/statements/declarations/classes.ts → dist/ir/converters/statements/declarations/classes.js} +1 -1
- package/dist/ir/converters/statements/declarations/classes.js.map +1 -0
- package/dist/ir/converters/statements/declarations/enums.d.ts +10 -0
- package/dist/ir/converters/statements/declarations/enums.d.ts.map +1 -0
- package/dist/ir/converters/statements/declarations/enums.js +24 -0
- package/dist/ir/converters/statements/declarations/enums.js.map +1 -0
- package/dist/ir/converters/statements/declarations/functions.d.ts +10 -0
- package/dist/ir/converters/statements/declarations/functions.d.ts.map +1 -0
- package/dist/ir/converters/statements/declarations/functions.js +28 -0
- package/dist/ir/converters/statements/declarations/functions.js.map +1 -0
- package/dist/ir/converters/statements/declarations/index.d.ts +11 -0
- package/dist/ir/converters/statements/declarations/index.d.ts.map +1 -0
- package/{src/ir/converters/statements/declarations/index.ts → dist/ir/converters/statements/declarations/index.js} +2 -5
- package/dist/ir/converters/statements/declarations/index.js.map +1 -0
- package/dist/ir/converters/statements/declarations/interfaces.d.ts +15 -0
- package/dist/ir/converters/statements/declarations/interfaces.d.ts.map +1 -0
- package/dist/ir/converters/statements/declarations/interfaces.js +96 -0
- package/dist/ir/converters/statements/declarations/interfaces.js.map +1 -0
- package/dist/ir/converters/statements/declarations/registry.d.ts +24 -0
- package/dist/ir/converters/statements/declarations/registry.d.ts.map +1 -0
- package/{src/ir/converters/statements/declarations/registry.ts → dist/ir/converters/statements/declarations/registry.js} +9 -16
- package/dist/ir/converters/statements/declarations/registry.js.map +1 -0
- package/dist/ir/converters/statements/declarations/type-aliases.d.ts +10 -0
- package/dist/ir/converters/statements/declarations/type-aliases.d.ts.map +1 -0
- package/dist/ir/converters/statements/declarations/type-aliases.js +19 -0
- package/dist/ir/converters/statements/declarations/type-aliases.js.map +1 -0
- package/dist/ir/converters/statements/declarations/variables.d.ts +10 -0
- package/dist/ir/converters/statements/declarations/variables.d.ts.map +1 -0
- package/dist/ir/converters/statements/declarations/variables.js +45 -0
- package/dist/ir/converters/statements/declarations/variables.js.map +1 -0
- package/dist/ir/converters/statements/declarations.d.ts +6 -0
- package/dist/ir/converters/statements/declarations.d.ts.map +1 -0
- package/dist/ir/converters/statements/declarations.js +6 -0
- package/dist/ir/converters/statements/declarations.js.map +1 -0
- package/dist/ir/converters/statements/helpers.d.ts +34 -0
- package/dist/ir/converters/statements/helpers.d.ts.map +1 -0
- package/dist/ir/converters/statements/helpers.js +137 -0
- package/dist/ir/converters/statements/helpers.js.map +1 -0
- package/dist/ir/converters/statements/index.d.ts +7 -0
- package/dist/ir/converters/statements/index.d.ts.map +1 -0
- package/dist/ir/converters/statements/index.js +10 -0
- package/dist/ir/converters/statements/index.js.map +1 -0
- package/dist/ir/expression-converter.d.ts +13 -0
- package/dist/ir/expression-converter.d.ts.map +1 -0
- package/dist/ir/expression-converter.js +167 -0
- package/dist/ir/expression-converter.js.map +1 -0
- package/dist/ir/generic-validator.d.ts +38 -0
- package/dist/ir/generic-validator.d.ts.map +1 -0
- package/dist/ir/generic-validator.js +69 -0
- package/dist/ir/generic-validator.js.map +1 -0
- package/dist/ir/hierarchical-bindings-e2e.test.d.ts +6 -0
- package/dist/ir/hierarchical-bindings-e2e.test.d.ts.map +1 -0
- package/dist/ir/hierarchical-bindings-e2e.test.js +129 -0
- package/dist/ir/hierarchical-bindings-e2e.test.js.map +1 -0
- package/{src/ir/index.ts → dist/ir/index.d.ts} +1 -1
- package/dist/ir/index.d.ts.map +1 -0
- package/dist/ir/index.js +6 -0
- package/dist/ir/index.js.map +1 -0
- package/dist/ir/statement-converter.d.ts +14 -0
- package/dist/ir/statement-converter.d.ts.map +1 -0
- package/dist/ir/statement-converter.js +100 -0
- package/dist/ir/statement-converter.js.map +1 -0
- package/dist/ir/type-converter/arrays.d.ts +10 -0
- package/dist/ir/type-converter/arrays.d.ts.map +1 -0
- package/dist/ir/type-converter/arrays.js +13 -0
- package/dist/ir/type-converter/arrays.js.map +1 -0
- package/dist/ir/type-converter/converter.d.ts +6 -0
- package/dist/ir/type-converter/converter.d.ts.map +1 -0
- package/dist/ir/type-converter/converter.js +6 -0
- package/dist/ir/type-converter/converter.js.map +1 -0
- package/dist/ir/type-converter/functions.d.ts +10 -0
- package/dist/ir/type-converter/functions.d.ts.map +1 -0
- package/dist/ir/type-converter/functions.js +15 -0
- package/dist/ir/type-converter/functions.js.map +1 -0
- package/dist/ir/type-converter/index.d.ts +7 -0
- package/dist/ir/type-converter/index.d.ts.map +1 -0
- package/{src/ir/type-converter/index.ts → dist/ir/type-converter/index.js} +2 -6
- package/dist/ir/type-converter/index.js.map +1 -0
- package/dist/ir/type-converter/inference.d.ts +20 -0
- package/dist/ir/type-converter/inference.d.ts.map +1 -0
- package/dist/ir/type-converter/inference.js +105 -0
- package/dist/ir/type-converter/inference.js.map +1 -0
- package/dist/ir/type-converter/literals.d.ts +10 -0
- package/dist/ir/type-converter/literals.d.ts.map +1 -0
- package/dist/ir/type-converter/literals.js +31 -0
- package/dist/ir/type-converter/literals.js.map +1 -0
- package/dist/ir/type-converter/objects.d.ts +16 -0
- package/dist/ir/type-converter/objects.d.ts.map +1 -0
- package/dist/ir/type-converter/objects.js +82 -0
- package/dist/ir/type-converter/objects.js.map +1 -0
- package/dist/ir/type-converter/orchestrator.d.ts +13 -0
- package/dist/ir/type-converter/orchestrator.d.ts.map +1 -0
- package/dist/ir/type-converter/orchestrator.js +59 -0
- package/dist/ir/type-converter/orchestrator.js.map +1 -0
- package/dist/ir/type-converter/patterns.d.ts +10 -0
- package/dist/ir/type-converter/patterns.d.ts.map +1 -0
- package/dist/ir/type-converter/patterns.js +66 -0
- package/dist/ir/type-converter/patterns.js.map +1 -0
- package/dist/ir/type-converter/primitives.d.ts +18 -0
- package/dist/ir/type-converter/primitives.d.ts.map +1 -0
- package/dist/ir/type-converter/primitives.js +47 -0
- package/dist/ir/type-converter/primitives.js.map +1 -0
- package/dist/ir/type-converter/references.d.ts +11 -0
- package/dist/ir/type-converter/references.d.ts.map +1 -0
- package/dist/ir/type-converter/references.js +62 -0
- package/dist/ir/type-converter/references.js.map +1 -0
- package/dist/ir/type-converter/unions-intersections.d.ts +14 -0
- package/dist/ir/type-converter/unions-intersections.d.ts.map +1 -0
- package/dist/ir/type-converter/unions-intersections.js +22 -0
- package/dist/ir/type-converter/unions-intersections.js.map +1 -0
- package/dist/ir/type-converter.d.ts +6 -0
- package/dist/ir/type-converter.d.ts.map +1 -0
- package/dist/ir/type-converter.js +6 -0
- package/dist/ir/type-converter.js.map +1 -0
- package/dist/ir/types/expressions.d.ts +164 -0
- package/dist/ir/types/expressions.d.ts.map +1 -0
- package/dist/ir/types/expressions.js +5 -0
- package/dist/ir/types/expressions.js.map +1 -0
- package/dist/ir/types/guards.d.ts +8 -0
- package/dist/ir/types/guards.d.ts.map +1 -0
- package/dist/ir/types/guards.js +31 -0
- package/dist/ir/types/guards.js.map +1 -0
- package/dist/ir/types/helpers.d.ts +65 -0
- package/dist/ir/types/helpers.d.ts.map +1 -0
- package/dist/ir/types/helpers.js +5 -0
- package/dist/ir/types/helpers.js.map +1 -0
- package/dist/ir/types/index.d.ts +11 -0
- package/dist/ir/types/index.d.ts.map +1 -0
- package/dist/ir/types/index.js +7 -0
- package/dist/ir/types/index.js.map +1 -0
- package/dist/ir/types/ir-types.d.ts +79 -0
- package/dist/ir/types/ir-types.d.ts.map +1 -0
- package/dist/ir/types/ir-types.js +5 -0
- package/dist/ir/types/ir-types.js.map +1 -0
- package/dist/ir/types/module.d.ts +56 -0
- package/dist/ir/types/module.d.ts.map +1 -0
- package/dist/ir/types/module.js +5 -0
- package/dist/ir/types/module.js.map +1 -0
- package/dist/ir/types/statements.d.ts +182 -0
- package/dist/ir/types/statements.d.ts.map +1 -0
- package/dist/ir/types/statements.js +5 -0
- package/dist/ir/types/statements.js.map +1 -0
- package/dist/ir/types.d.ts +7 -0
- package/dist/ir/types.d.ts.map +1 -0
- package/dist/ir/types.js +7 -0
- package/dist/ir/types.js.map +1 -0
- package/dist/metadata/bindings-loader.d.ts +41 -0
- package/dist/metadata/bindings-loader.d.ts.map +1 -0
- package/dist/metadata/bindings-loader.js +308 -0
- package/dist/metadata/bindings-loader.js.map +1 -0
- package/dist/metadata/bindings-loader.test.d.ts +5 -0
- package/dist/metadata/bindings-loader.test.d.ts.map +1 -0
- package/dist/metadata/bindings-loader.test.js +117 -0
- package/dist/metadata/bindings-loader.test.js.map +1 -0
- package/{src/metadata/index.ts → dist/metadata/index.d.ts} +2 -9
- package/dist/metadata/index.d.ts.map +1 -0
- package/dist/metadata/index.js +7 -0
- package/dist/metadata/index.js.map +1 -0
- package/dist/metadata/library-loader.d.ts +42 -0
- package/dist/metadata/library-loader.d.ts.map +1 -0
- package/dist/metadata/library-loader.js +126 -0
- package/dist/metadata/library-loader.js.map +1 -0
- package/dist/metadata/loader.d.ts +26 -0
- package/dist/metadata/loader.d.ts.map +1 -0
- package/dist/metadata/loader.js +333 -0
- package/dist/metadata/loader.js.map +1 -0
- package/dist/metadata/loader.test.d.ts +5 -0
- package/dist/metadata/loader.test.d.ts.map +1 -0
- package/dist/metadata/loader.test.js +119 -0
- package/dist/metadata/loader.test.js.map +1 -0
- package/dist/program/bindings.d.ts +159 -0
- package/dist/program/bindings.d.ts.map +1 -0
- package/dist/program/bindings.js +329 -0
- package/dist/program/bindings.js.map +1 -0
- package/dist/program/bindings.test.d.ts +5 -0
- package/dist/program/bindings.test.d.ts.map +1 -0
- package/dist/program/bindings.test.js +435 -0
- package/dist/program/bindings.test.js.map +1 -0
- package/dist/program/config.d.ts +9 -0
- package/dist/program/config.d.ts.map +1 -0
- package/dist/program/config.js +29 -0
- package/dist/program/config.js.map +1 -0
- package/dist/program/creation.d.ts +17 -0
- package/dist/program/creation.d.ts.map +1 -0
- package/dist/program/creation.js +182 -0
- package/dist/program/creation.js.map +1 -0
- package/dist/program/dependency-graph.d.ts +19 -0
- package/dist/program/dependency-graph.d.ts.map +1 -0
- package/dist/program/dependency-graph.js +230 -0
- package/dist/program/dependency-graph.js.map +1 -0
- package/dist/program/diagnostics.d.ts +23 -0
- package/dist/program/diagnostics.d.ts.map +1 -0
- package/dist/program/diagnostics.js +65 -0
- package/dist/program/diagnostics.js.map +1 -0
- package/{src/program/index.ts → dist/program/index.d.ts} +3 -10
- package/dist/program/index.d.ts.map +1 -0
- package/dist/program/index.js +11 -0
- package/dist/program/index.js.map +1 -0
- package/dist/program/metadata.d.ts +10 -0
- package/dist/program/metadata.d.ts.map +1 -0
- package/dist/program/metadata.js +56 -0
- package/dist/program/metadata.js.map +1 -0
- package/dist/program/queries.d.ts +10 -0
- package/dist/program/queries.d.ts.map +1 -0
- package/dist/program/queries.js +12 -0
- package/dist/program/queries.js.map +1 -0
- package/dist/program/types.d.ts +36 -0
- package/dist/program/types.d.ts.map +1 -0
- package/dist/program/types.js +5 -0
- package/dist/program/types.js.map +1 -0
- package/{src/program.ts → dist/program.d.ts} +2 -7
- package/dist/program.d.ts.map +1 -0
- package/dist/program.js +6 -0
- package/dist/program.js.map +1 -0
- package/dist/resolver/clr-bindings-resolver.d.ts +84 -0
- package/dist/resolver/clr-bindings-resolver.d.ts.map +1 -0
- package/dist/resolver/clr-bindings-resolver.js +224 -0
- package/dist/resolver/clr-bindings-resolver.js.map +1 -0
- package/dist/resolver/import-resolution.d.ts +20 -0
- package/dist/resolver/import-resolution.d.ts.map +1 -0
- package/dist/resolver/import-resolution.js +102 -0
- package/dist/resolver/import-resolution.js.map +1 -0
- package/{src/resolver/index.ts → dist/resolver/index.d.ts} +3 -11
- package/dist/resolver/index.d.ts.map +1 -0
- package/dist/resolver/index.js +9 -0
- package/dist/resolver/index.js.map +1 -0
- package/dist/resolver/namespace.d.ts +20 -0
- package/dist/resolver/namespace.d.ts.map +1 -0
- package/dist/resolver/namespace.js +35 -0
- package/dist/resolver/namespace.js.map +1 -0
- package/dist/resolver/namespace.test.d.ts +2 -0
- package/dist/resolver/namespace.test.d.ts.map +1 -0
- package/dist/resolver/namespace.test.js +42 -0
- package/dist/resolver/namespace.test.js.map +1 -0
- package/dist/resolver/naming.d.ts +12 -0
- package/dist/resolver/naming.d.ts.map +1 -0
- package/dist/resolver/naming.js +30 -0
- package/dist/resolver/naming.js.map +1 -0
- package/dist/resolver/path-resolution.d.ts +8 -0
- package/dist/resolver/path-resolution.d.ts.map +1 -0
- package/dist/resolver/path-resolution.js +16 -0
- package/dist/resolver/path-resolution.js.map +1 -0
- package/dist/resolver/types.d.ts +13 -0
- package/dist/resolver/types.d.ts.map +1 -0
- package/dist/resolver/types.js +5 -0
- package/dist/resolver/types.js.map +1 -0
- package/dist/resolver.d.ts +7 -0
- package/dist/resolver.d.ts.map +1 -0
- package/dist/resolver.js +6 -0
- package/dist/resolver.js.map +1 -0
- package/dist/resolver.test.d.ts +5 -0
- package/dist/resolver.test.d.ts.map +1 -0
- package/dist/resolver.test.js +93 -0
- package/dist/resolver.test.js.map +1 -0
- package/dist/symbol-table/builder.d.ts +10 -0
- package/dist/symbol-table/builder.d.ts.map +1 -0
- package/dist/symbol-table/builder.js +105 -0
- package/dist/symbol-table/builder.js.map +1 -0
- package/dist/symbol-table/creation.d.ts +13 -0
- package/dist/symbol-table/creation.d.ts.map +1 -0
- package/dist/symbol-table/creation.js +36 -0
- package/dist/symbol-table/creation.js.map +1 -0
- package/dist/symbol-table/helpers.d.ts +9 -0
- package/dist/symbol-table/helpers.d.ts.map +1 -0
- package/dist/symbol-table/helpers.js +15 -0
- package/dist/symbol-table/helpers.js.map +1 -0
- package/{src/symbol-table/index.ts → dist/symbol-table/index.d.ts} +2 -6
- package/dist/symbol-table/index.d.ts.map +1 -0
- package/dist/symbol-table/index.js +8 -0
- package/dist/symbol-table/index.js.map +1 -0
- package/dist/symbol-table/queries.d.ts +17 -0
- package/dist/symbol-table/queries.d.ts.map +1 -0
- package/dist/symbol-table/queries.js +27 -0
- package/dist/symbol-table/queries.js.map +1 -0
- package/dist/symbol-table/types.d.ts +18 -0
- package/dist/symbol-table/types.d.ts.map +1 -0
- package/dist/symbol-table/types.js +5 -0
- package/dist/symbol-table/types.js.map +1 -0
- package/{src/symbol-table.ts → dist/symbol-table.d.ts} +2 -9
- package/dist/symbol-table.d.ts.map +1 -0
- package/dist/symbol-table.js +6 -0
- package/dist/symbol-table.js.map +1 -0
- package/dist/types/bindings.d.ts +153 -0
- package/dist/types/bindings.d.ts.map +1 -0
- package/dist/types/bindings.js +14 -0
- package/dist/types/bindings.js.map +1 -0
- package/dist/types/diagnostic.d.ts +30 -0
- package/dist/types/diagnostic.d.ts.map +1 -0
- package/dist/types/diagnostic.js +37 -0
- package/dist/types/diagnostic.js.map +1 -0
- package/dist/types/diagnostic.test.d.ts +5 -0
- package/dist/types/diagnostic.test.d.ts.map +1 -0
- package/dist/types/diagnostic.test.js +94 -0
- package/dist/types/diagnostic.test.js.map +1 -0
- package/dist/types/explicit-views.d.ts +97 -0
- package/dist/types/explicit-views.d.ts.map +1 -0
- package/dist/types/explicit-views.js +163 -0
- package/dist/types/explicit-views.js.map +1 -0
- package/dist/types/explicit-views.test.d.ts +5 -0
- package/dist/types/explicit-views.test.d.ts.map +1 -0
- package/dist/types/explicit-views.test.js +67 -0
- package/dist/types/explicit-views.test.js.map +1 -0
- package/dist/types/metadata.d.ts +196 -0
- package/dist/types/metadata.d.ts.map +1 -0
- package/dist/types/metadata.js +10 -0
- package/dist/types/metadata.js.map +1 -0
- package/dist/types/module.d.ts +51 -0
- package/dist/types/module.d.ts.map +1 -0
- package/dist/types/module.js +28 -0
- package/dist/types/module.js.map +1 -0
- package/dist/types/nested-types.d.ts +111 -0
- package/dist/types/nested-types.d.ts.map +1 -0
- package/dist/types/nested-types.js +176 -0
- package/dist/types/nested-types.js.map +1 -0
- package/dist/types/nested-types.test.d.ts +5 -0
- package/dist/types/nested-types.test.d.ts.map +1 -0
- package/dist/types/nested-types.test.js +135 -0
- package/dist/types/nested-types.test.js.map +1 -0
- package/dist/types/parameter-modifiers.d.ts +55 -0
- package/dist/types/parameter-modifiers.d.ts.map +1 -0
- package/dist/types/parameter-modifiers.js +148 -0
- package/dist/types/parameter-modifiers.js.map +1 -0
- package/dist/types/ref-parameters.d.ts +123 -0
- package/dist/types/ref-parameters.d.ts.map +1 -0
- package/dist/types/ref-parameters.js +203 -0
- package/dist/types/ref-parameters.js.map +1 -0
- package/dist/types/ref-parameters.test.d.ts +5 -0
- package/dist/types/ref-parameters.test.d.ts.map +1 -0
- package/dist/types/ref-parameters.test.js +147 -0
- package/dist/types/ref-parameters.test.js.map +1 -0
- package/dist/types/result.d.ts +26 -0
- package/dist/types/result.d.ts.map +1 -0
- package/dist/types/result.js +19 -0
- package/dist/types/result.js.map +1 -0
- package/dist/types/result.test.d.ts +5 -0
- package/dist/types/result.test.d.ts.map +1 -0
- package/dist/types/result.test.js +121 -0
- package/dist/types/result.test.js.map +1 -0
- package/dist/types/support-types.d.ts +103 -0
- package/dist/types/support-types.d.ts.map +1 -0
- package/dist/types/support-types.js +220 -0
- package/dist/types/support-types.js.map +1 -0
- package/dist/types/support-types.test.d.ts +5 -0
- package/dist/types/support-types.test.d.ts.map +1 -0
- package/dist/types/support-types.test.js +53 -0
- package/dist/types/support-types.test.js.map +1 -0
- package/dist/types/test-harness.d.ts +34 -0
- package/dist/types/test-harness.d.ts.map +1 -0
- package/dist/types/test-harness.js +127 -0
- package/dist/types/test-harness.js.map +1 -0
- package/dist/validation/exports.d.ts +11 -0
- package/dist/validation/exports.d.ts.map +1 -0
- package/dist/validation/exports.js +56 -0
- package/dist/validation/exports.js.map +1 -0
- package/dist/validation/features.d.ts +11 -0
- package/dist/validation/features.d.ts.map +1 -0
- package/dist/validation/features.js +36 -0
- package/dist/validation/features.js.map +1 -0
- package/dist/validation/generics.d.ts +11 -0
- package/dist/validation/generics.d.ts.map +1 -0
- package/dist/validation/generics.js +31 -0
- package/dist/validation/generics.js.map +1 -0
- package/dist/validation/helpers.d.ts +15 -0
- package/dist/validation/helpers.d.ts.map +1 -0
- package/dist/validation/helpers.js +18 -0
- package/dist/validation/helpers.js.map +1 -0
- package/dist/validation/imports.d.ts +15 -0
- package/dist/validation/imports.d.ts.map +1 -0
- package/dist/validation/imports.js +42 -0
- package/dist/validation/imports.js.map +1 -0
- package/dist/validation/index.d.ts +11 -0
- package/dist/validation/index.d.ts.map +1 -0
- package/{src/validation/index.ts → dist/validation/index.js} +1 -1
- package/dist/validation/index.js.map +1 -0
- package/dist/validation/orchestrator.d.ts +15 -0
- package/dist/validation/orchestrator.d.ts.map +1 -0
- package/dist/validation/orchestrator.js +30 -0
- package/dist/validation/orchestrator.js.map +1 -0
- package/dist/validation/static-safety.d.ts +23 -0
- package/dist/validation/static-safety.d.ts.map +1 -0
- package/dist/validation/static-safety.js +165 -0
- package/dist/validation/static-safety.js.map +1 -0
- package/dist/validator.d.ts +6 -0
- package/dist/validator.d.ts.map +1 -0
- package/dist/validator.js +6 -0
- package/dist/validator.js.map +1 -0
- package/dist/validator.test.d.ts +11 -0
- package/dist/validator.test.d.ts.map +1 -0
- package/dist/validator.test.js +341 -0
- package/dist/validator.test.js.map +1 -0
- package/package.json +4 -1
- package/src/dotnet-metadata.ts +0 -121
- package/src/graph/builder.ts +0 -81
- package/src/graph/circular.ts +0 -58
- package/src/graph/extraction/exports.ts +0 -55
- package/src/graph/extraction/imports.ts +0 -81
- package/src/graph/extraction/orchestrator.ts +0 -99
- package/src/graph/helpers.ts +0 -51
- package/src/index.ts +0 -80
- package/src/ir/binding-resolution.test.ts +0 -585
- package/src/ir/builder/exports.ts +0 -78
- package/src/ir/builder/helpers.ts +0 -27
- package/src/ir/builder/imports.ts +0 -153
- package/src/ir/builder/orchestrator.ts +0 -178
- package/src/ir/builder/statements.ts +0 -55
- package/src/ir/builder/types.ts +0 -8
- package/src/ir/builder/validation.ts +0 -129
- package/src/ir/builder.test.ts +0 -581
- package/src/ir/converters/expressions/access.ts +0 -99
- package/src/ir/converters/expressions/calls.ts +0 -137
- package/src/ir/converters/expressions/collections.ts +0 -84
- package/src/ir/converters/expressions/functions.ts +0 -62
- package/src/ir/converters/expressions/helpers.ts +0 -264
- package/src/ir/converters/expressions/index.ts +0 -43
- package/src/ir/converters/expressions/literals.ts +0 -22
- package/src/ir/converters/expressions/operators.ts +0 -147
- package/src/ir/converters/expressions/other.ts +0 -60
- package/src/ir/converters/statements/control/blocks.ts +0 -22
- package/src/ir/converters/statements/control/conditionals.ts +0 -67
- package/src/ir/converters/statements/control/exceptions.ts +0 -43
- package/src/ir/converters/statements/control/index.ts +0 -17
- package/src/ir/converters/statements/control/loops.ts +0 -99
- package/src/ir/converters/statements/control.ts +0 -17
- package/src/ir/converters/statements/declarations/classes/constructors.ts +0 -120
- package/src/ir/converters/statements/declarations/classes/methods.ts +0 -61
- package/src/ir/converters/statements/declarations/classes/orchestrator.ts +0 -166
- package/src/ir/converters/statements/declarations/classes/override-detection.ts +0 -116
- package/src/ir/converters/statements/declarations/classes/properties.ts +0 -63
- package/src/ir/converters/statements/declarations/enums.ts +0 -29
- package/src/ir/converters/statements/declarations/functions.ts +0 -39
- package/src/ir/converters/statements/declarations/interfaces.ts +0 -131
- package/src/ir/converters/statements/declarations/type-aliases.ts +0 -25
- package/src/ir/converters/statements/declarations/variables.ts +0 -60
- package/src/ir/converters/statements/declarations.ts +0 -16
- package/src/ir/converters/statements/helpers.ts +0 -174
- package/src/ir/converters/statements/index.ts +0 -40
- package/src/ir/expression-converter.ts +0 -207
- package/src/ir/generic-validator.ts +0 -100
- package/src/ir/hierarchical-bindings-e2e.test.ts +0 -163
- package/src/ir/statement-converter.ts +0 -128
- package/src/ir/type-converter/arrays.ts +0 -20
- package/src/ir/type-converter/converter.ts +0 -10
- package/src/ir/type-converter/functions.ts +0 -22
- package/src/ir/type-converter/inference.ts +0 -122
- package/src/ir/type-converter/literals.ts +0 -40
- package/src/ir/type-converter/objects.ts +0 -107
- package/src/ir/type-converter/orchestrator.ts +0 -85
- package/src/ir/type-converter/patterns.ts +0 -73
- package/src/ir/type-converter/primitives.ts +0 -57
- package/src/ir/type-converter/references.ts +0 -64
- package/src/ir/type-converter/unions-intersections.ts +0 -34
- package/src/ir/type-converter.ts +0 -13
- package/src/ir/types/expressions.ts +0 -215
- package/src/ir/types/guards.ts +0 -39
- package/src/ir/types/helpers.ts +0 -135
- package/src/ir/types/index.ts +0 -108
- package/src/ir/types/ir-types.ts +0 -96
- package/src/ir/types/module.ts +0 -57
- package/src/ir/types/statements.ts +0 -238
- package/src/ir/types.ts +0 -97
- package/src/metadata/bindings-loader.test.ts +0 -144
- package/src/metadata/bindings-loader.ts +0 -357
- package/src/metadata/library-loader.ts +0 -153
- package/src/metadata/loader.test.ts +0 -156
- package/src/metadata/loader.ts +0 -382
- package/src/program/bindings.test.ts +0 -512
- package/src/program/bindings.ts +0 -253
- package/src/program/config.ts +0 -30
- package/src/program/creation.ts +0 -249
- package/src/program/dependency-graph.ts +0 -245
- package/src/program/diagnostics.ts +0 -103
- package/src/program/metadata.ts +0 -68
- package/src/program/queries.ts +0 -18
- package/src/program/types.ts +0 -38
- package/src/resolver/dotnet-import-resolver.ts +0 -226
- package/src/resolver/import-resolution.ts +0 -177
- package/src/resolver/namespace.test.ts +0 -86
- package/src/resolver/namespace.ts +0 -42
- package/src/resolver/naming.ts +0 -38
- package/src/resolver/path-resolution.ts +0 -22
- package/src/resolver/types.ts +0 -15
- package/src/resolver.test.ts +0 -155
- package/src/resolver.ts +0 -14
- package/src/symbol-table/builder.ts +0 -114
- package/src/symbol-table/creation.ts +0 -42
- package/src/symbol-table/helpers.ts +0 -18
- package/src/symbol-table/queries.ts +0 -42
- package/src/symbol-table/types.ts +0 -28
- package/src/types/bindings.ts +0 -172
- package/src/types/diagnostic.test.ts +0 -164
- package/src/types/diagnostic.ts +0 -153
- package/src/types/explicit-views.test.ts +0 -113
- package/src/types/explicit-views.ts +0 -218
- package/src/types/metadata.ts +0 -229
- package/src/types/module.ts +0 -99
- package/src/types/nested-types.test.ts +0 -194
- package/src/types/nested-types.ts +0 -215
- package/src/types/parameter-modifiers.ts +0 -173
- package/src/types/ref-parameters.test.ts +0 -192
- package/src/types/ref-parameters.ts +0 -268
- package/src/types/result.test.ts +0 -157
- package/src/types/result.ts +0 -48
- package/src/types/support-types.test.ts +0 -81
- package/src/types/support-types.ts +0 -288
- package/src/types/test-harness.ts +0 -180
- package/src/validation/exports.ts +0 -98
- package/src/validation/features.ts +0 -89
- package/src/validation/generics.ts +0 -40
- package/src/validation/helpers.ts +0 -31
- package/src/validation/imports.ts +0 -97
- package/src/validation/orchestrator.ts +0 -51
- package/src/validation/static-safety.ts +0 -267
- package/src/validator.test.ts +0 -468
- package/src/validator.ts +0 -15
- package/tsconfig.json +0 -13
|
@@ -1,147 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Operator expression converters (binary, unary, update, assignment)
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import * as ts from "typescript";
|
|
6
|
-
import {
|
|
7
|
-
IrExpression,
|
|
8
|
-
IrUnaryExpression,
|
|
9
|
-
IrUpdateExpression,
|
|
10
|
-
IrBinaryOperator,
|
|
11
|
-
IrAssignmentOperator,
|
|
12
|
-
} from "../../types.js";
|
|
13
|
-
import {
|
|
14
|
-
getInferredType,
|
|
15
|
-
convertBinaryOperator,
|
|
16
|
-
isAssignmentOperator,
|
|
17
|
-
} from "./helpers.js";
|
|
18
|
-
import { convertExpression } from "../../expression-converter.js";
|
|
19
|
-
|
|
20
|
-
/**
|
|
21
|
-
* Convert binary expression (including logical and assignment)
|
|
22
|
-
*/
|
|
23
|
-
export const convertBinaryExpression = (
|
|
24
|
-
node: ts.BinaryExpression,
|
|
25
|
-
checker: ts.TypeChecker
|
|
26
|
-
): IrExpression => {
|
|
27
|
-
const operator = convertBinaryOperator(node.operatorToken);
|
|
28
|
-
const inferredType = getInferredType(node, checker);
|
|
29
|
-
|
|
30
|
-
// Handle assignment separately
|
|
31
|
-
if (isAssignmentOperator(node.operatorToken)) {
|
|
32
|
-
return {
|
|
33
|
-
kind: "assignment",
|
|
34
|
-
operator: operator as IrAssignmentOperator,
|
|
35
|
-
left: ts.isIdentifier(node.left)
|
|
36
|
-
? { kind: "identifier", name: node.left.text }
|
|
37
|
-
: convertExpression(node.left, checker),
|
|
38
|
-
right: convertExpression(node.right, checker),
|
|
39
|
-
inferredType,
|
|
40
|
-
};
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
// Handle logical operators
|
|
44
|
-
if (operator === "&&" || operator === "||" || operator === "??") {
|
|
45
|
-
return {
|
|
46
|
-
kind: "logical",
|
|
47
|
-
operator,
|
|
48
|
-
left: convertExpression(node.left, checker),
|
|
49
|
-
right: convertExpression(node.right, checker),
|
|
50
|
-
inferredType,
|
|
51
|
-
};
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
// Regular binary expression
|
|
55
|
-
return {
|
|
56
|
-
kind: "binary",
|
|
57
|
-
operator: operator as IrBinaryOperator,
|
|
58
|
-
left: convertExpression(node.left, checker),
|
|
59
|
-
right: convertExpression(node.right, checker),
|
|
60
|
-
inferredType,
|
|
61
|
-
};
|
|
62
|
-
};
|
|
63
|
-
|
|
64
|
-
/**
|
|
65
|
-
* Convert prefix unary expression
|
|
66
|
-
*/
|
|
67
|
-
export const convertUnaryExpression = (
|
|
68
|
-
node: ts.PrefixUnaryExpression,
|
|
69
|
-
checker: ts.TypeChecker
|
|
70
|
-
): IrUnaryExpression | IrUpdateExpression => {
|
|
71
|
-
const inferredType = getInferredType(node, checker);
|
|
72
|
-
|
|
73
|
-
// Check if it's an increment/decrement (++ or --)
|
|
74
|
-
if (
|
|
75
|
-
node.operator === ts.SyntaxKind.PlusPlusToken ||
|
|
76
|
-
node.operator === ts.SyntaxKind.MinusMinusToken
|
|
77
|
-
) {
|
|
78
|
-
return {
|
|
79
|
-
kind: "update",
|
|
80
|
-
operator: node.operator === ts.SyntaxKind.PlusPlusToken ? "++" : "--",
|
|
81
|
-
prefix: true,
|
|
82
|
-
expression: convertExpression(node.operand, checker),
|
|
83
|
-
inferredType,
|
|
84
|
-
};
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
// Handle regular unary operators
|
|
88
|
-
let operator: IrUnaryExpression["operator"] = "+";
|
|
89
|
-
|
|
90
|
-
switch (node.operator) {
|
|
91
|
-
case ts.SyntaxKind.PlusToken:
|
|
92
|
-
operator = "+";
|
|
93
|
-
break;
|
|
94
|
-
case ts.SyntaxKind.MinusToken:
|
|
95
|
-
operator = "-";
|
|
96
|
-
break;
|
|
97
|
-
case ts.SyntaxKind.ExclamationToken:
|
|
98
|
-
operator = "!";
|
|
99
|
-
break;
|
|
100
|
-
case ts.SyntaxKind.TildeToken:
|
|
101
|
-
operator = "~";
|
|
102
|
-
break;
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
return {
|
|
106
|
-
kind: "unary",
|
|
107
|
-
operator,
|
|
108
|
-
expression: convertExpression(node.operand, checker),
|
|
109
|
-
inferredType,
|
|
110
|
-
};
|
|
111
|
-
};
|
|
112
|
-
|
|
113
|
-
/**
|
|
114
|
-
* Convert postfix unary expression (++ or --)
|
|
115
|
-
*/
|
|
116
|
-
export const convertUpdateExpression = (
|
|
117
|
-
node: ts.PostfixUnaryExpression | ts.PrefixUnaryExpression,
|
|
118
|
-
checker: ts.TypeChecker
|
|
119
|
-
): IrUpdateExpression => {
|
|
120
|
-
const inferredType = getInferredType(node, checker);
|
|
121
|
-
|
|
122
|
-
if (ts.isPrefixUnaryExpression(node)) {
|
|
123
|
-
// Check if it's an increment or decrement
|
|
124
|
-
if (
|
|
125
|
-
node.operator === ts.SyntaxKind.PlusPlusToken ||
|
|
126
|
-
node.operator === ts.SyntaxKind.MinusMinusToken
|
|
127
|
-
) {
|
|
128
|
-
return {
|
|
129
|
-
kind: "update",
|
|
130
|
-
operator: node.operator === ts.SyntaxKind.PlusPlusToken ? "++" : "--",
|
|
131
|
-
prefix: true,
|
|
132
|
-
expression: convertExpression(node.operand, checker),
|
|
133
|
-
inferredType,
|
|
134
|
-
};
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
// Handle postfix unary expression
|
|
139
|
-
const postfix = node as ts.PostfixUnaryExpression;
|
|
140
|
-
return {
|
|
141
|
-
kind: "update",
|
|
142
|
-
operator: postfix.operator === ts.SyntaxKind.PlusPlusToken ? "++" : "--",
|
|
143
|
-
prefix: false,
|
|
144
|
-
expression: convertExpression(postfix.operand, checker),
|
|
145
|
-
inferredType,
|
|
146
|
-
};
|
|
147
|
-
};
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Miscellaneous expression converters (conditional, template literals)
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import * as ts from "typescript";
|
|
6
|
-
import {
|
|
7
|
-
IrConditionalExpression,
|
|
8
|
-
IrTemplateLiteralExpression,
|
|
9
|
-
IrExpression,
|
|
10
|
-
} from "../../types.js";
|
|
11
|
-
import { getInferredType } from "./helpers.js";
|
|
12
|
-
import { convertExpression } from "../../expression-converter.js";
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* Convert conditional (ternary) expression
|
|
16
|
-
*/
|
|
17
|
-
export const convertConditionalExpression = (
|
|
18
|
-
node: ts.ConditionalExpression,
|
|
19
|
-
checker: ts.TypeChecker
|
|
20
|
-
): IrConditionalExpression => {
|
|
21
|
-
return {
|
|
22
|
-
kind: "conditional",
|
|
23
|
-
condition: convertExpression(node.condition, checker),
|
|
24
|
-
whenTrue: convertExpression(node.whenTrue, checker),
|
|
25
|
-
whenFalse: convertExpression(node.whenFalse, checker),
|
|
26
|
-
inferredType: getInferredType(node, checker),
|
|
27
|
-
};
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
/**
|
|
31
|
-
* Convert template literal expression
|
|
32
|
-
*/
|
|
33
|
-
export const convertTemplateLiteral = (
|
|
34
|
-
node: ts.TemplateExpression | ts.NoSubstitutionTemplateLiteral,
|
|
35
|
-
checker: ts.TypeChecker
|
|
36
|
-
): IrTemplateLiteralExpression => {
|
|
37
|
-
if (ts.isNoSubstitutionTemplateLiteral(node)) {
|
|
38
|
-
return {
|
|
39
|
-
kind: "templateLiteral",
|
|
40
|
-
quasis: [node.text],
|
|
41
|
-
expressions: [],
|
|
42
|
-
inferredType: getInferredType(node, checker),
|
|
43
|
-
};
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
const quasis: string[] = [node.head.text];
|
|
47
|
-
const expressions: IrExpression[] = [];
|
|
48
|
-
|
|
49
|
-
node.templateSpans.forEach((span) => {
|
|
50
|
-
expressions.push(convertExpression(span.expression, checker));
|
|
51
|
-
quasis.push(span.literal.text);
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
return {
|
|
55
|
-
kind: "templateLiteral",
|
|
56
|
-
quasis,
|
|
57
|
-
expressions,
|
|
58
|
-
inferredType: getInferredType(node, checker),
|
|
59
|
-
};
|
|
60
|
-
};
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Block statement converter
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import * as ts from "typescript";
|
|
6
|
-
import { IrStatement, IrBlockStatement } from "../../../types.js";
|
|
7
|
-
import { convertStatement } from "../../../statement-converter.js";
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* Convert block statement
|
|
11
|
-
*/
|
|
12
|
-
export const convertBlockStatement = (
|
|
13
|
-
node: ts.Block,
|
|
14
|
-
checker: ts.TypeChecker
|
|
15
|
-
): IrBlockStatement => {
|
|
16
|
-
return {
|
|
17
|
-
kind: "blockStatement",
|
|
18
|
-
statements: node.statements
|
|
19
|
-
.map((s) => convertStatement(s, checker))
|
|
20
|
-
.filter((s): s is IrStatement => s !== null),
|
|
21
|
-
};
|
|
22
|
-
};
|
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Conditional statement converters (if, switch)
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import * as ts from "typescript";
|
|
6
|
-
import {
|
|
7
|
-
IrStatement,
|
|
8
|
-
IrIfStatement,
|
|
9
|
-
IrSwitchStatement,
|
|
10
|
-
IrSwitchCase,
|
|
11
|
-
} from "../../../types.js";
|
|
12
|
-
import { convertExpression } from "../../../expression-converter.js";
|
|
13
|
-
import { convertStatement } from "../../../statement-converter.js";
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* Convert if statement
|
|
17
|
-
*/
|
|
18
|
-
export const convertIfStatement = (
|
|
19
|
-
node: ts.IfStatement,
|
|
20
|
-
checker: ts.TypeChecker
|
|
21
|
-
): IrIfStatement => {
|
|
22
|
-
const thenStmt = convertStatement(node.thenStatement, checker);
|
|
23
|
-
const elseStmt = node.elseStatement
|
|
24
|
-
? convertStatement(node.elseStatement, checker)
|
|
25
|
-
: undefined;
|
|
26
|
-
|
|
27
|
-
return {
|
|
28
|
-
kind: "ifStatement",
|
|
29
|
-
condition: convertExpression(node.expression, checker),
|
|
30
|
-
thenStatement: thenStmt ?? { kind: "emptyStatement" },
|
|
31
|
-
elseStatement: elseStmt ?? undefined,
|
|
32
|
-
};
|
|
33
|
-
};
|
|
34
|
-
|
|
35
|
-
/**
|
|
36
|
-
* Convert switch statement
|
|
37
|
-
*/
|
|
38
|
-
export const convertSwitchStatement = (
|
|
39
|
-
node: ts.SwitchStatement,
|
|
40
|
-
checker: ts.TypeChecker
|
|
41
|
-
): IrSwitchStatement => {
|
|
42
|
-
return {
|
|
43
|
-
kind: "switchStatement",
|
|
44
|
-
expression: convertExpression(node.expression, checker),
|
|
45
|
-
cases: node.caseBlock.clauses.map((clause) =>
|
|
46
|
-
convertSwitchCase(clause, checker)
|
|
47
|
-
),
|
|
48
|
-
};
|
|
49
|
-
};
|
|
50
|
-
|
|
51
|
-
/**
|
|
52
|
-
* Convert switch case
|
|
53
|
-
*/
|
|
54
|
-
export const convertSwitchCase = (
|
|
55
|
-
node: ts.CaseOrDefaultClause,
|
|
56
|
-
checker: ts.TypeChecker
|
|
57
|
-
): IrSwitchCase => {
|
|
58
|
-
return {
|
|
59
|
-
kind: "switchCase",
|
|
60
|
-
test: ts.isCaseClause(node)
|
|
61
|
-
? convertExpression(node.expression, checker)
|
|
62
|
-
: undefined,
|
|
63
|
-
statements: node.statements
|
|
64
|
-
.map((s) => convertStatement(s, checker))
|
|
65
|
-
.filter((s): s is IrStatement => s !== null),
|
|
66
|
-
};
|
|
67
|
-
};
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Exception handling converters (try, catch)
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import * as ts from "typescript";
|
|
6
|
-
import { IrTryStatement, IrCatchClause } from "../../../types.js";
|
|
7
|
-
import { convertBindingName } from "../../../type-converter.js";
|
|
8
|
-
import { convertBlockStatement } from "./blocks.js";
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* Convert try statement
|
|
12
|
-
*/
|
|
13
|
-
export const convertTryStatement = (
|
|
14
|
-
node: ts.TryStatement,
|
|
15
|
-
checker: ts.TypeChecker
|
|
16
|
-
): IrTryStatement => {
|
|
17
|
-
return {
|
|
18
|
-
kind: "tryStatement",
|
|
19
|
-
tryBlock: convertBlockStatement(node.tryBlock, checker),
|
|
20
|
-
catchClause: node.catchClause
|
|
21
|
-
? convertCatchClause(node.catchClause, checker)
|
|
22
|
-
: undefined,
|
|
23
|
-
finallyBlock: node.finallyBlock
|
|
24
|
-
? convertBlockStatement(node.finallyBlock, checker)
|
|
25
|
-
: undefined,
|
|
26
|
-
};
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
/**
|
|
30
|
-
* Convert catch clause
|
|
31
|
-
*/
|
|
32
|
-
export const convertCatchClause = (
|
|
33
|
-
node: ts.CatchClause,
|
|
34
|
-
checker: ts.TypeChecker
|
|
35
|
-
): IrCatchClause => {
|
|
36
|
-
return {
|
|
37
|
-
kind: "catchClause",
|
|
38
|
-
parameter: node.variableDeclaration
|
|
39
|
-
? convertBindingName(node.variableDeclaration.name)
|
|
40
|
-
: undefined,
|
|
41
|
-
body: convertBlockStatement(node.block, checker),
|
|
42
|
-
};
|
|
43
|
-
};
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Control flow statement converters - Public API
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
export {
|
|
6
|
-
convertIfStatement,
|
|
7
|
-
convertSwitchStatement,
|
|
8
|
-
convertSwitchCase,
|
|
9
|
-
} from "./conditionals.js";
|
|
10
|
-
export {
|
|
11
|
-
convertWhileStatement,
|
|
12
|
-
convertForStatement,
|
|
13
|
-
convertForOfStatement,
|
|
14
|
-
convertForInStatement,
|
|
15
|
-
} from "./loops.js";
|
|
16
|
-
export { convertTryStatement, convertCatchClause } from "./exceptions.js";
|
|
17
|
-
export { convertBlockStatement } from "./blocks.js";
|
|
@@ -1,99 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Loop statement converters (while, for, for-of, for-in)
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import * as ts from "typescript";
|
|
6
|
-
import {
|
|
7
|
-
IrWhileStatement,
|
|
8
|
-
IrForStatement,
|
|
9
|
-
IrForOfStatement,
|
|
10
|
-
} from "../../../types.js";
|
|
11
|
-
import { convertExpression } from "../../../expression-converter.js";
|
|
12
|
-
import { convertBindingName } from "../../../type-converter.js";
|
|
13
|
-
import { convertStatement } from "../../../statement-converter.js";
|
|
14
|
-
import { convertVariableDeclarationList } from "../helpers.js";
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* Convert while statement
|
|
18
|
-
*/
|
|
19
|
-
export const convertWhileStatement = (
|
|
20
|
-
node: ts.WhileStatement,
|
|
21
|
-
checker: ts.TypeChecker
|
|
22
|
-
): IrWhileStatement => {
|
|
23
|
-
const body = convertStatement(node.statement, checker);
|
|
24
|
-
return {
|
|
25
|
-
kind: "whileStatement",
|
|
26
|
-
condition: convertExpression(node.expression, checker),
|
|
27
|
-
body: body ?? { kind: "emptyStatement" },
|
|
28
|
-
};
|
|
29
|
-
};
|
|
30
|
-
|
|
31
|
-
/**
|
|
32
|
-
* Convert for statement
|
|
33
|
-
*/
|
|
34
|
-
export const convertForStatement = (
|
|
35
|
-
node: ts.ForStatement,
|
|
36
|
-
checker: ts.TypeChecker
|
|
37
|
-
): IrForStatement => {
|
|
38
|
-
const body = convertStatement(node.statement, checker);
|
|
39
|
-
return {
|
|
40
|
-
kind: "forStatement",
|
|
41
|
-
initializer: node.initializer
|
|
42
|
-
? ts.isVariableDeclarationList(node.initializer)
|
|
43
|
-
? convertVariableDeclarationList(node.initializer, checker)
|
|
44
|
-
: convertExpression(node.initializer, checker)
|
|
45
|
-
: undefined,
|
|
46
|
-
condition: node.condition
|
|
47
|
-
? convertExpression(node.condition, checker)
|
|
48
|
-
: undefined,
|
|
49
|
-
update: node.incrementor
|
|
50
|
-
? convertExpression(node.incrementor, checker)
|
|
51
|
-
: undefined,
|
|
52
|
-
body: body ?? { kind: "emptyStatement" },
|
|
53
|
-
};
|
|
54
|
-
};
|
|
55
|
-
|
|
56
|
-
/**
|
|
57
|
-
* Convert for-of statement
|
|
58
|
-
*/
|
|
59
|
-
export const convertForOfStatement = (
|
|
60
|
-
node: ts.ForOfStatement,
|
|
61
|
-
checker: ts.TypeChecker
|
|
62
|
-
): IrForOfStatement => {
|
|
63
|
-
const firstDecl = ts.isVariableDeclarationList(node.initializer)
|
|
64
|
-
? node.initializer.declarations[0]
|
|
65
|
-
: undefined;
|
|
66
|
-
|
|
67
|
-
const variable = ts.isVariableDeclarationList(node.initializer)
|
|
68
|
-
? convertBindingName(firstDecl?.name ?? ts.factory.createIdentifier("_"))
|
|
69
|
-
: convertBindingName(node.initializer as ts.BindingName);
|
|
70
|
-
|
|
71
|
-
const body = convertStatement(node.statement, checker);
|
|
72
|
-
return {
|
|
73
|
-
kind: "forOfStatement",
|
|
74
|
-
variable,
|
|
75
|
-
expression: convertExpression(node.expression, checker),
|
|
76
|
-
body: body ?? { kind: "emptyStatement" },
|
|
77
|
-
};
|
|
78
|
-
};
|
|
79
|
-
|
|
80
|
-
/**
|
|
81
|
-
* Convert for-in statement
|
|
82
|
-
*/
|
|
83
|
-
export const convertForInStatement = (
|
|
84
|
-
node: ts.ForInStatement,
|
|
85
|
-
checker: ts.TypeChecker
|
|
86
|
-
): IrForStatement => {
|
|
87
|
-
// Note: for...in needs special handling in C# - variable extraction will be handled in emitter
|
|
88
|
-
// We'll need to extract the variable info in the emitter phase
|
|
89
|
-
|
|
90
|
-
const body = convertStatement(node.statement, checker);
|
|
91
|
-
// Note: for...in needs special handling in C#
|
|
92
|
-
return {
|
|
93
|
-
kind: "forStatement",
|
|
94
|
-
initializer: undefined,
|
|
95
|
-
condition: undefined,
|
|
96
|
-
update: undefined,
|
|
97
|
-
body: body ?? { kind: "emptyStatement" },
|
|
98
|
-
};
|
|
99
|
-
};
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Control flow statement converters (if, while, for, switch, try, block)
|
|
3
|
-
* Main dispatcher - re-exports from control/ subdirectory
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
export {
|
|
7
|
-
convertIfStatement,
|
|
8
|
-
convertSwitchStatement,
|
|
9
|
-
convertSwitchCase,
|
|
10
|
-
convertWhileStatement,
|
|
11
|
-
convertForStatement,
|
|
12
|
-
convertForOfStatement,
|
|
13
|
-
convertForInStatement,
|
|
14
|
-
convertTryStatement,
|
|
15
|
-
convertCatchClause,
|
|
16
|
-
convertBlockStatement,
|
|
17
|
-
} from "./control/index.js";
|
|
@@ -1,120 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Constructor conversion with parameter properties
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import * as ts from "typescript";
|
|
6
|
-
import { IrClassMember, IrStatement } from "../../../../types.js";
|
|
7
|
-
import { convertType } from "../../../../type-converter.js";
|
|
8
|
-
import { convertBlockStatement } from "../../control.js";
|
|
9
|
-
import {
|
|
10
|
-
hasReadonlyModifier,
|
|
11
|
-
getAccessibility,
|
|
12
|
-
convertParameters,
|
|
13
|
-
} from "../../helpers.js";
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* Convert constructor declaration to IR
|
|
17
|
-
*/
|
|
18
|
-
export const convertConstructor = (
|
|
19
|
-
node: ts.ConstructorDeclaration,
|
|
20
|
-
checker: ts.TypeChecker,
|
|
21
|
-
constructorParams?: ts.NodeArray<ts.ParameterDeclaration>
|
|
22
|
-
): IrClassMember => {
|
|
23
|
-
// Build constructor body with parameter property assignments
|
|
24
|
-
const statements: IrStatement[] = [];
|
|
25
|
-
|
|
26
|
-
// Add assignments for parameter properties (parameters with explicit modifiers)
|
|
27
|
-
if (constructorParams) {
|
|
28
|
-
for (const param of constructorParams) {
|
|
29
|
-
// Check if parameter has an EXPLICIT accessibility modifier
|
|
30
|
-
const modifiers = ts.getModifiers(param);
|
|
31
|
-
const hasAccessibilityModifier = modifiers?.some(
|
|
32
|
-
(m) =>
|
|
33
|
-
m.kind === ts.SyntaxKind.PublicKeyword ||
|
|
34
|
-
m.kind === ts.SyntaxKind.PrivateKeyword ||
|
|
35
|
-
m.kind === ts.SyntaxKind.ProtectedKeyword
|
|
36
|
-
);
|
|
37
|
-
|
|
38
|
-
if (hasAccessibilityModifier && ts.isIdentifier(param.name)) {
|
|
39
|
-
// Create: this.name = name;
|
|
40
|
-
statements.push({
|
|
41
|
-
kind: "expressionStatement",
|
|
42
|
-
expression: {
|
|
43
|
-
kind: "assignment",
|
|
44
|
-
operator: "=",
|
|
45
|
-
left: {
|
|
46
|
-
kind: "memberAccess",
|
|
47
|
-
object: { kind: "this" },
|
|
48
|
-
property: param.name.text,
|
|
49
|
-
isComputed: false,
|
|
50
|
-
isOptional: false,
|
|
51
|
-
},
|
|
52
|
-
right: {
|
|
53
|
-
kind: "identifier",
|
|
54
|
-
name: param.name.text,
|
|
55
|
-
},
|
|
56
|
-
},
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
// Add existing constructor body statements
|
|
63
|
-
if (node.body) {
|
|
64
|
-
const existingBody = convertBlockStatement(node.body, checker);
|
|
65
|
-
statements.push(...existingBody.statements);
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
return {
|
|
69
|
-
kind: "constructorDeclaration",
|
|
70
|
-
parameters: convertParameters(node.parameters, checker),
|
|
71
|
-
body: { kind: "blockStatement", statements },
|
|
72
|
-
accessibility: getAccessibility(node),
|
|
73
|
-
};
|
|
74
|
-
};
|
|
75
|
-
|
|
76
|
-
/**
|
|
77
|
-
* Extract parameter properties from constructor
|
|
78
|
-
*/
|
|
79
|
-
export const extractParameterProperties = (
|
|
80
|
-
constructor: ts.ConstructorDeclaration | undefined,
|
|
81
|
-
checker: ts.TypeChecker
|
|
82
|
-
): IrClassMember[] => {
|
|
83
|
-
if (!constructor) {
|
|
84
|
-
return [];
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
const parameterProperties: IrClassMember[] = [];
|
|
88
|
-
|
|
89
|
-
for (const param of constructor.parameters) {
|
|
90
|
-
// Check if parameter has an EXPLICIT accessibility modifier
|
|
91
|
-
// (public/private/protected makes it a parameter property)
|
|
92
|
-
const modifiers = ts.getModifiers(param);
|
|
93
|
-
const hasAccessibilityModifier = modifiers?.some(
|
|
94
|
-
(m) =>
|
|
95
|
-
m.kind === ts.SyntaxKind.PublicKeyword ||
|
|
96
|
-
m.kind === ts.SyntaxKind.PrivateKeyword ||
|
|
97
|
-
m.kind === ts.SyntaxKind.ProtectedKeyword
|
|
98
|
-
);
|
|
99
|
-
|
|
100
|
-
if (!hasAccessibilityModifier) {
|
|
101
|
-
continue; // Not a parameter property
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
// Create a field declaration for this parameter property
|
|
105
|
-
if (ts.isIdentifier(param.name)) {
|
|
106
|
-
const accessibility = getAccessibility(param);
|
|
107
|
-
parameterProperties.push({
|
|
108
|
-
kind: "propertyDeclaration",
|
|
109
|
-
name: param.name.text,
|
|
110
|
-
type: param.type ? convertType(param.type, checker) : undefined,
|
|
111
|
-
initializer: undefined, // Will be assigned in constructor
|
|
112
|
-
isStatic: false,
|
|
113
|
-
isReadonly: hasReadonlyModifier(param),
|
|
114
|
-
accessibility,
|
|
115
|
-
});
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
return parameterProperties;
|
|
120
|
-
};
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Method member conversion
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import * as ts from "typescript";
|
|
6
|
-
import { IrClassMember } from "../../../../types.js";
|
|
7
|
-
import { convertType } from "../../../../type-converter.js";
|
|
8
|
-
import { convertBlockStatement } from "../../control.js";
|
|
9
|
-
import {
|
|
10
|
-
hasStaticModifier,
|
|
11
|
-
getAccessibility,
|
|
12
|
-
convertTypeParameters,
|
|
13
|
-
convertParameters,
|
|
14
|
-
} from "../../helpers.js";
|
|
15
|
-
import { detectOverride } from "./override-detection.js";
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* Convert method declaration to IR
|
|
19
|
-
*/
|
|
20
|
-
export const convertMethod = (
|
|
21
|
-
node: ts.MethodDeclaration,
|
|
22
|
-
checker: ts.TypeChecker,
|
|
23
|
-
superClass: ts.ExpressionWithTypeArguments | undefined
|
|
24
|
-
): IrClassMember => {
|
|
25
|
-
const memberName = ts.isIdentifier(node.name) ? node.name.text : "[computed]";
|
|
26
|
-
|
|
27
|
-
// Extract parameter types for method signature
|
|
28
|
-
const parameterTypes = node.parameters.map((param) => {
|
|
29
|
-
if (param.type) {
|
|
30
|
-
// Get type string representation
|
|
31
|
-
const type = checker.getTypeAtLocation(param.type);
|
|
32
|
-
return checker.typeToString(type);
|
|
33
|
-
}
|
|
34
|
-
return "any";
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
const overrideInfo = detectOverride(
|
|
38
|
-
memberName,
|
|
39
|
-
"method",
|
|
40
|
-
superClass,
|
|
41
|
-
checker,
|
|
42
|
-
parameterTypes
|
|
43
|
-
);
|
|
44
|
-
|
|
45
|
-
return {
|
|
46
|
-
kind: "methodDeclaration",
|
|
47
|
-
name: memberName,
|
|
48
|
-
typeParameters: convertTypeParameters(node.typeParameters, checker),
|
|
49
|
-
parameters: convertParameters(node.parameters, checker),
|
|
50
|
-
returnType: node.type ? convertType(node.type, checker) : undefined,
|
|
51
|
-
body: node.body ? convertBlockStatement(node.body, checker) : undefined,
|
|
52
|
-
isStatic: hasStaticModifier(node),
|
|
53
|
-
isAsync: !!node.modifiers?.some(
|
|
54
|
-
(m) => m.kind === ts.SyntaxKind.AsyncKeyword
|
|
55
|
-
),
|
|
56
|
-
isGenerator: !!node.asteriskToken,
|
|
57
|
-
accessibility: getAccessibility(node),
|
|
58
|
-
isOverride: overrideInfo.isOverride ? true : undefined,
|
|
59
|
-
isShadow: overrideInfo.isShadow ? true : undefined,
|
|
60
|
-
};
|
|
61
|
-
};
|