@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,89 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Unsupported feature validation
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import * as ts from "typescript";
|
|
6
|
-
import { TsonicProgram } from "../program.js";
|
|
7
|
-
import {
|
|
8
|
-
DiagnosticsCollector,
|
|
9
|
-
addDiagnostic,
|
|
10
|
-
createDiagnostic,
|
|
11
|
-
} from "../types/diagnostic.js";
|
|
12
|
-
import { getNodeLocation } from "./helpers.js";
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* Validate that unsupported features are not used
|
|
16
|
-
*/
|
|
17
|
-
export const validateUnsupportedFeatures = (
|
|
18
|
-
sourceFile: ts.SourceFile,
|
|
19
|
-
_program: TsonicProgram,
|
|
20
|
-
collector: DiagnosticsCollector
|
|
21
|
-
): DiagnosticsCollector => {
|
|
22
|
-
const visitor = (node: ts.Node): void => {
|
|
23
|
-
// Check for features we don't support yet
|
|
24
|
-
if (ts.isWithStatement(node)) {
|
|
25
|
-
collector = addDiagnostic(
|
|
26
|
-
collector,
|
|
27
|
-
createDiagnostic(
|
|
28
|
-
"TSN2001",
|
|
29
|
-
"error",
|
|
30
|
-
"'with' statement not supported",
|
|
31
|
-
getNodeLocation(sourceFile, node)
|
|
32
|
-
)
|
|
33
|
-
);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
if (ts.isMetaProperty(node)) {
|
|
37
|
-
collector = addDiagnostic(
|
|
38
|
-
collector,
|
|
39
|
-
createDiagnostic(
|
|
40
|
-
"TSN2001",
|
|
41
|
-
"error",
|
|
42
|
-
"Meta properties (import.meta) not supported",
|
|
43
|
-
getNodeLocation(sourceFile, node)
|
|
44
|
-
)
|
|
45
|
-
);
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
if (
|
|
49
|
-
ts.isCallExpression(node) &&
|
|
50
|
-
node.expression.kind === ts.SyntaxKind.ImportKeyword
|
|
51
|
-
) {
|
|
52
|
-
collector = addDiagnostic(
|
|
53
|
-
collector,
|
|
54
|
-
createDiagnostic(
|
|
55
|
-
"TSN2001",
|
|
56
|
-
"error",
|
|
57
|
-
"Dynamic import() not supported",
|
|
58
|
-
getNodeLocation(sourceFile, node),
|
|
59
|
-
"Use static imports"
|
|
60
|
-
)
|
|
61
|
-
);
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
// Check for Promise.then/catch/finally chaining (not supported)
|
|
65
|
-
if (
|
|
66
|
-
ts.isCallExpression(node) &&
|
|
67
|
-
ts.isPropertyAccessExpression(node.expression)
|
|
68
|
-
) {
|
|
69
|
-
const methodName = node.expression.name.text;
|
|
70
|
-
if (["then", "catch", "finally"].includes(methodName)) {
|
|
71
|
-
collector = addDiagnostic(
|
|
72
|
-
collector,
|
|
73
|
-
createDiagnostic(
|
|
74
|
-
"TSN3011",
|
|
75
|
-
"error",
|
|
76
|
-
`Promise.${methodName}() is not supported`,
|
|
77
|
-
getNodeLocation(sourceFile, node),
|
|
78
|
-
"Use async/await instead of Promise chaining"
|
|
79
|
-
)
|
|
80
|
-
);
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
ts.forEachChild(node, visitor);
|
|
85
|
-
};
|
|
86
|
-
|
|
87
|
-
visitor(sourceFile);
|
|
88
|
-
return collector;
|
|
89
|
-
};
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generic type validation
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import * as ts from "typescript";
|
|
6
|
-
import { TsonicProgram } from "../program.js";
|
|
7
|
-
import { DiagnosticsCollector, addDiagnostic } from "../types/diagnostic.js";
|
|
8
|
-
import { checkForSymbolIndexSignature } from "../ir/generic-validator.js";
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* Validate generic types and constraints
|
|
12
|
-
*/
|
|
13
|
-
export const validateGenerics = (
|
|
14
|
-
sourceFile: ts.SourceFile,
|
|
15
|
-
_program: TsonicProgram,
|
|
16
|
-
collector: DiagnosticsCollector
|
|
17
|
-
): DiagnosticsCollector => {
|
|
18
|
-
const visitor = (node: ts.Node): void => {
|
|
19
|
-
// Only check for truly unsupported features (no static C# mapping)
|
|
20
|
-
// Symbol index signatures - TSN7203
|
|
21
|
-
if (ts.isIndexSignatureDeclaration(node)) {
|
|
22
|
-
const symbolDiag = checkForSymbolIndexSignature(node, sourceFile);
|
|
23
|
-
if (symbolDiag) {
|
|
24
|
-
collector = addDiagnostic(collector, symbolDiag);
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
// Explicitly visit interface and type literal members
|
|
29
|
-
if (ts.isInterfaceDeclaration(node) || ts.isTypeLiteralNode(node)) {
|
|
30
|
-
for (const member of node.members) {
|
|
31
|
-
visitor(member);
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
ts.forEachChild(node, visitor);
|
|
36
|
-
};
|
|
37
|
-
|
|
38
|
-
visitor(sourceFile);
|
|
39
|
-
return collector;
|
|
40
|
-
};
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Validation helper functions
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import * as ts from "typescript";
|
|
6
|
-
|
|
7
|
-
// Re-export hasExportModifier from graph helpers to avoid duplication
|
|
8
|
-
export { hasExportModifier } from "../graph/helpers.js";
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* Get location information for a node
|
|
12
|
-
*/
|
|
13
|
-
export const getNodeLocation = (
|
|
14
|
-
sourceFile: ts.SourceFile,
|
|
15
|
-
node: ts.Node
|
|
16
|
-
): {
|
|
17
|
-
readonly file: string;
|
|
18
|
-
readonly line: number;
|
|
19
|
-
readonly column: number;
|
|
20
|
-
readonly length: number;
|
|
21
|
-
} => {
|
|
22
|
-
const { line, character } = sourceFile.getLineAndCharacterOfPosition(
|
|
23
|
-
node.getStart()
|
|
24
|
-
);
|
|
25
|
-
return {
|
|
26
|
-
file: sourceFile.fileName,
|
|
27
|
-
line: line + 1,
|
|
28
|
-
column: character + 1,
|
|
29
|
-
length: node.getWidth(),
|
|
30
|
-
};
|
|
31
|
-
};
|
|
@@ -1,97 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Import validation
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import * as ts from "typescript";
|
|
6
|
-
import { TsonicProgram } from "../program.js";
|
|
7
|
-
import {
|
|
8
|
-
DiagnosticsCollector,
|
|
9
|
-
addDiagnostic,
|
|
10
|
-
createDiagnostic,
|
|
11
|
-
} from "../types/diagnostic.js";
|
|
12
|
-
import { resolveImport } from "../resolver.js";
|
|
13
|
-
import { getNodeLocation } from "./helpers.js";
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* Validate all imports in a source file
|
|
17
|
-
*/
|
|
18
|
-
export const validateImports = (
|
|
19
|
-
sourceFile: ts.SourceFile,
|
|
20
|
-
program: TsonicProgram,
|
|
21
|
-
collector: DiagnosticsCollector
|
|
22
|
-
): DiagnosticsCollector => {
|
|
23
|
-
const visitor = (node: ts.Node): DiagnosticsCollector => {
|
|
24
|
-
if (ts.isImportDeclaration(node)) {
|
|
25
|
-
return validateImportDeclaration(node, sourceFile, program, collector);
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
if (ts.isImportTypeNode(node)) {
|
|
29
|
-
return addDiagnostic(
|
|
30
|
-
collector,
|
|
31
|
-
createDiagnostic(
|
|
32
|
-
"TSN2001",
|
|
33
|
-
"error",
|
|
34
|
-
"Import type syntax not supported",
|
|
35
|
-
getNodeLocation(sourceFile, node),
|
|
36
|
-
"Use regular imports instead"
|
|
37
|
-
)
|
|
38
|
-
);
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
return ts.forEachChild(node, visitor) ?? collector;
|
|
42
|
-
};
|
|
43
|
-
|
|
44
|
-
return visitor(sourceFile);
|
|
45
|
-
};
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* Validate a specific import declaration
|
|
49
|
-
*/
|
|
50
|
-
export const validateImportDeclaration = (
|
|
51
|
-
node: ts.ImportDeclaration,
|
|
52
|
-
sourceFile: ts.SourceFile,
|
|
53
|
-
program: TsonicProgram,
|
|
54
|
-
collector: DiagnosticsCollector
|
|
55
|
-
): DiagnosticsCollector => {
|
|
56
|
-
if (!ts.isStringLiteral(node.moduleSpecifier)) {
|
|
57
|
-
return addDiagnostic(
|
|
58
|
-
collector,
|
|
59
|
-
createDiagnostic(
|
|
60
|
-
"TSN2001",
|
|
61
|
-
"error",
|
|
62
|
-
"Dynamic imports not supported",
|
|
63
|
-
getNodeLocation(sourceFile, node),
|
|
64
|
-
"Use static import statements"
|
|
65
|
-
)
|
|
66
|
-
);
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
const importPath = node.moduleSpecifier.text;
|
|
70
|
-
const result = resolveImport(
|
|
71
|
-
importPath,
|
|
72
|
-
sourceFile.fileName,
|
|
73
|
-
program.options.sourceRoot,
|
|
74
|
-
program.dotnetResolver
|
|
75
|
-
);
|
|
76
|
-
|
|
77
|
-
if (!result.ok) {
|
|
78
|
-
const location = getNodeLocation(sourceFile, node.moduleSpecifier);
|
|
79
|
-
return addDiagnostic(collector, { ...result.error, location });
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
// Check for default imports from local modules (we might want to restrict this)
|
|
83
|
-
if (result.value.isLocal && node.importClause?.name) {
|
|
84
|
-
return addDiagnostic(
|
|
85
|
-
collector,
|
|
86
|
-
createDiagnostic(
|
|
87
|
-
"TSN2001",
|
|
88
|
-
"warning",
|
|
89
|
-
"Default imports from local modules may not work as expected",
|
|
90
|
-
getNodeLocation(sourceFile, node.importClause),
|
|
91
|
-
"Consider using named imports"
|
|
92
|
-
)
|
|
93
|
-
);
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
return collector;
|
|
97
|
-
};
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Validation orchestrator - coordinates all validation functions
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import * as ts from "typescript";
|
|
6
|
-
import { TsonicProgram } from "../program.js";
|
|
7
|
-
import {
|
|
8
|
-
DiagnosticsCollector,
|
|
9
|
-
createDiagnosticsCollector,
|
|
10
|
-
} from "../types/diagnostic.js";
|
|
11
|
-
import { validateImports } from "./imports.js";
|
|
12
|
-
import { validateExports } from "./exports.js";
|
|
13
|
-
import { validateUnsupportedFeatures } from "./features.js";
|
|
14
|
-
import { validateGenerics } from "./generics.js";
|
|
15
|
-
import { validateStaticSafety } from "./static-safety.js";
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* Validate an entire Tsonic program
|
|
19
|
-
*/
|
|
20
|
-
export const validateProgram = (
|
|
21
|
-
program: TsonicProgram
|
|
22
|
-
): DiagnosticsCollector => {
|
|
23
|
-
const collector = createDiagnosticsCollector();
|
|
24
|
-
|
|
25
|
-
return program.sourceFiles.reduce(
|
|
26
|
-
(acc, sourceFile) => validateSourceFile(sourceFile, program, acc),
|
|
27
|
-
collector
|
|
28
|
-
);
|
|
29
|
-
};
|
|
30
|
-
|
|
31
|
-
/**
|
|
32
|
-
* Validate a single source file
|
|
33
|
-
*/
|
|
34
|
-
export const validateSourceFile = (
|
|
35
|
-
sourceFile: ts.SourceFile,
|
|
36
|
-
program: TsonicProgram,
|
|
37
|
-
collector: DiagnosticsCollector
|
|
38
|
-
): DiagnosticsCollector => {
|
|
39
|
-
const validationFns = [
|
|
40
|
-
validateImports,
|
|
41
|
-
validateExports,
|
|
42
|
-
validateUnsupportedFeatures,
|
|
43
|
-
validateGenerics,
|
|
44
|
-
validateStaticSafety,
|
|
45
|
-
];
|
|
46
|
-
|
|
47
|
-
return validationFns.reduce(
|
|
48
|
-
(acc, fn) => fn(sourceFile, program, acc),
|
|
49
|
-
collector
|
|
50
|
-
);
|
|
51
|
-
};
|
|
@@ -1,267 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Static Safety Validation
|
|
3
|
-
*
|
|
4
|
-
* Detects patterns that violate static typing requirements:
|
|
5
|
-
* - TSN7401: 'any' type usage
|
|
6
|
-
* - TSN7403: Object literal without contextual nominal type
|
|
7
|
-
* - TSN7405: Untyped function/arrow/lambda parameter
|
|
8
|
-
* - TSN7413: Dictionary key must be string type
|
|
9
|
-
*
|
|
10
|
-
* This ensures NativeAOT-compatible, predictable-performance output.
|
|
11
|
-
*
|
|
12
|
-
* Note: We intentionally do NOT validate JS built-in usage (arr.map, str.length)
|
|
13
|
-
* or dictionary dot-access patterns. These will fail naturally in C# if used
|
|
14
|
-
* incorrectly, which is an acceptable failure mode.
|
|
15
|
-
*/
|
|
16
|
-
|
|
17
|
-
import * as ts from "typescript";
|
|
18
|
-
import { TsonicProgram } from "../program.js";
|
|
19
|
-
import {
|
|
20
|
-
DiagnosticsCollector,
|
|
21
|
-
addDiagnostic,
|
|
22
|
-
createDiagnostic,
|
|
23
|
-
} from "../types/diagnostic.js";
|
|
24
|
-
import { getNodeLocation } from "./helpers.js";
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* Validate a source file for static safety violations.
|
|
28
|
-
*/
|
|
29
|
-
export const validateStaticSafety = (
|
|
30
|
-
sourceFile: ts.SourceFile,
|
|
31
|
-
program: TsonicProgram,
|
|
32
|
-
collector: DiagnosticsCollector
|
|
33
|
-
): DiagnosticsCollector => {
|
|
34
|
-
const checker = program.checker;
|
|
35
|
-
|
|
36
|
-
const visitor = (
|
|
37
|
-
node: ts.Node,
|
|
38
|
-
accCollector: DiagnosticsCollector
|
|
39
|
-
): DiagnosticsCollector => {
|
|
40
|
-
let currentCollector = accCollector;
|
|
41
|
-
|
|
42
|
-
// TSN7401: Check for explicit 'any' type annotations
|
|
43
|
-
if (node.kind === ts.SyntaxKind.AnyKeyword) {
|
|
44
|
-
currentCollector = addDiagnostic(
|
|
45
|
-
currentCollector,
|
|
46
|
-
createDiagnostic(
|
|
47
|
-
"TSN7401",
|
|
48
|
-
"error",
|
|
49
|
-
"'any' type is not supported. Provide a concrete type, use 'unknown', or define a nominal type.",
|
|
50
|
-
getNodeLocation(sourceFile, node),
|
|
51
|
-
"Replace 'any' with a specific type like 'unknown', 'object', or a custom interface."
|
|
52
|
-
)
|
|
53
|
-
);
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
// TSN7401: Check for 'as any' type assertions
|
|
57
|
-
if (
|
|
58
|
-
ts.isAsExpression(node) &&
|
|
59
|
-
node.type.kind === ts.SyntaxKind.AnyKeyword
|
|
60
|
-
) {
|
|
61
|
-
currentCollector = addDiagnostic(
|
|
62
|
-
currentCollector,
|
|
63
|
-
createDiagnostic(
|
|
64
|
-
"TSN7401",
|
|
65
|
-
"error",
|
|
66
|
-
"'as any' type assertion is not supported. Use a specific type assertion.",
|
|
67
|
-
getNodeLocation(sourceFile, node),
|
|
68
|
-
"Replace 'as any' with a specific type like 'as unknown' or 'as YourType'."
|
|
69
|
-
)
|
|
70
|
-
);
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
// TSN7405: Check for untyped function parameters
|
|
74
|
-
// Covers: function declarations, methods, constructors, arrow functions, function expressions
|
|
75
|
-
if (ts.isParameter(node) && !node.type) {
|
|
76
|
-
const parent = node.parent;
|
|
77
|
-
const isFunctionLike =
|
|
78
|
-
ts.isFunctionDeclaration(parent) ||
|
|
79
|
-
ts.isMethodDeclaration(parent) ||
|
|
80
|
-
ts.isConstructorDeclaration(parent) ||
|
|
81
|
-
ts.isArrowFunction(parent) ||
|
|
82
|
-
ts.isFunctionExpression(parent) ||
|
|
83
|
-
ts.isGetAccessorDeclaration(parent) ||
|
|
84
|
-
ts.isSetAccessorDeclaration(parent);
|
|
85
|
-
|
|
86
|
-
if (isFunctionLike) {
|
|
87
|
-
const paramName = ts.isIdentifier(node.name) ? node.name.text : "param";
|
|
88
|
-
currentCollector = addDiagnostic(
|
|
89
|
-
currentCollector,
|
|
90
|
-
createDiagnostic(
|
|
91
|
-
"TSN7405",
|
|
92
|
-
"error",
|
|
93
|
-
`Parameter '${paramName}' must have an explicit type annotation.`,
|
|
94
|
-
getNodeLocation(sourceFile, node),
|
|
95
|
-
"Add a type annotation to this parameter."
|
|
96
|
-
)
|
|
97
|
-
);
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
// TSN7403: Check for object literals without contextual nominal type
|
|
102
|
-
if (ts.isObjectLiteralExpression(node)) {
|
|
103
|
-
const contextualType = checker.getContextualType(node);
|
|
104
|
-
|
|
105
|
-
// Must have a contextual type that resolves to a nominal type or dictionary
|
|
106
|
-
if (
|
|
107
|
-
!contextualType ||
|
|
108
|
-
!isNominalOrDictionaryType(contextualType, checker)
|
|
109
|
-
) {
|
|
110
|
-
currentCollector = addDiagnostic(
|
|
111
|
-
currentCollector,
|
|
112
|
-
createDiagnostic(
|
|
113
|
-
"TSN7403",
|
|
114
|
-
"error",
|
|
115
|
-
"Object literal requires a contextual nominal type (interface, type alias, or class). Anonymous object types are not supported.",
|
|
116
|
-
getNodeLocation(sourceFile, node),
|
|
117
|
-
"Add a type annotation like 'const x: MyInterface = { ... }' or define an interface/type alias."
|
|
118
|
-
)
|
|
119
|
-
);
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
// TSN7413: Check for non-string dictionary keys
|
|
124
|
-
// Record<K, V> where K is not string
|
|
125
|
-
if (ts.isTypeReferenceNode(node)) {
|
|
126
|
-
const typeName = node.typeName;
|
|
127
|
-
if (ts.isIdentifier(typeName) && typeName.text === "Record") {
|
|
128
|
-
const typeArgs = node.typeArguments;
|
|
129
|
-
if (typeArgs && typeArgs.length >= 1) {
|
|
130
|
-
const keyTypeNode = typeArgs[0]!;
|
|
131
|
-
if (!isStringKeyType(keyTypeNode)) {
|
|
132
|
-
currentCollector = addDiagnostic(
|
|
133
|
-
currentCollector,
|
|
134
|
-
createDiagnostic(
|
|
135
|
-
"TSN7413",
|
|
136
|
-
"error",
|
|
137
|
-
"Dictionary key type must be 'string'. Non-string key types are not supported for NativeAOT compatibility.",
|
|
138
|
-
getNodeLocation(sourceFile, keyTypeNode),
|
|
139
|
-
"Use Record<string, V> instead of Record<number, V> or other key types."
|
|
140
|
-
)
|
|
141
|
-
);
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
// TSN7413: Check for non-string index signatures
|
|
148
|
-
// { [k: number]: V } is not allowed
|
|
149
|
-
if (ts.isIndexSignatureDeclaration(node)) {
|
|
150
|
-
const keyParam = node.parameters[0];
|
|
151
|
-
if (keyParam?.type && !isStringKeyType(keyParam.type)) {
|
|
152
|
-
currentCollector = addDiagnostic(
|
|
153
|
-
currentCollector,
|
|
154
|
-
createDiagnostic(
|
|
155
|
-
"TSN7413",
|
|
156
|
-
"error",
|
|
157
|
-
"Index signature key type must be 'string'. Non-string key types are not supported for NativeAOT compatibility.",
|
|
158
|
-
getNodeLocation(sourceFile, keyParam.type),
|
|
159
|
-
"Use { [key: string]: V } instead of { [key: number]: V }."
|
|
160
|
-
)
|
|
161
|
-
);
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
// Continue visiting children
|
|
166
|
-
ts.forEachChild(node, (child) => {
|
|
167
|
-
currentCollector = visitor(child, currentCollector);
|
|
168
|
-
});
|
|
169
|
-
|
|
170
|
-
return currentCollector;
|
|
171
|
-
};
|
|
172
|
-
|
|
173
|
-
return visitor(sourceFile, collector);
|
|
174
|
-
};
|
|
175
|
-
|
|
176
|
-
/**
|
|
177
|
-
* Check if a contextual type is a nominal type (interface, type alias, class)
|
|
178
|
-
* or a dictionary type that we can emit.
|
|
179
|
-
*
|
|
180
|
-
* Returns false for anonymous object types like `{ x: number }` without a name.
|
|
181
|
-
*/
|
|
182
|
-
const isNominalOrDictionaryType = (
|
|
183
|
-
type: ts.Type,
|
|
184
|
-
checker: ts.TypeChecker
|
|
185
|
-
): boolean => {
|
|
186
|
-
// Check if it's a dictionary type (Record<K,V> or index signature)
|
|
187
|
-
if (isTsDictionaryType(type)) {
|
|
188
|
-
return true;
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
// Check if the type has a symbol with a declaration (named type)
|
|
192
|
-
const symbol = type.getSymbol() ?? type.aliasSymbol;
|
|
193
|
-
if (symbol) {
|
|
194
|
-
const declarations = symbol.getDeclarations();
|
|
195
|
-
if (declarations && declarations.length > 0) {
|
|
196
|
-
const decl = declarations[0]!;
|
|
197
|
-
// Accept: interface, type alias, class
|
|
198
|
-
if (
|
|
199
|
-
ts.isInterfaceDeclaration(decl) ||
|
|
200
|
-
ts.isTypeAliasDeclaration(decl) ||
|
|
201
|
-
ts.isClassDeclaration(decl)
|
|
202
|
-
) {
|
|
203
|
-
return true;
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
// Check for primitive types (allowed)
|
|
209
|
-
if (
|
|
210
|
-
type.flags & ts.TypeFlags.String ||
|
|
211
|
-
type.flags & ts.TypeFlags.Number ||
|
|
212
|
-
type.flags & ts.TypeFlags.Boolean ||
|
|
213
|
-
type.flags & ts.TypeFlags.Null ||
|
|
214
|
-
type.flags & ts.TypeFlags.Undefined ||
|
|
215
|
-
type.flags & ts.TypeFlags.Void
|
|
216
|
-
) {
|
|
217
|
-
return true;
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
// Check for array types (allowed)
|
|
221
|
-
if (checker.isArrayType(type) || checker.isTupleType(type)) {
|
|
222
|
-
return true;
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
return false;
|
|
226
|
-
};
|
|
227
|
-
|
|
228
|
-
/**
|
|
229
|
-
* Check if a type is a TS dictionary type (Record<K,V> or index signature).
|
|
230
|
-
*
|
|
231
|
-
* TS dictionary types:
|
|
232
|
-
* - Record<string, T> → has aliasSymbol named "Record"
|
|
233
|
-
* - { [k: string]: T } → has string index signature
|
|
234
|
-
*/
|
|
235
|
-
const isTsDictionaryType = (type: ts.Type): boolean => {
|
|
236
|
-
// Check for Record<K,V> utility type
|
|
237
|
-
if (type.aliasSymbol?.name === "Record") {
|
|
238
|
-
return true;
|
|
239
|
-
}
|
|
240
|
-
|
|
241
|
-
// Check for index signature type like { [k: string]: T }
|
|
242
|
-
const stringIndexType = type.getStringIndexType();
|
|
243
|
-
const numberIndexType = type.getNumberIndexType();
|
|
244
|
-
|
|
245
|
-
return !!(stringIndexType || numberIndexType);
|
|
246
|
-
};
|
|
247
|
-
|
|
248
|
-
/**
|
|
249
|
-
* Check if a type node represents a string key type.
|
|
250
|
-
* Only `string` keyword is allowed for dictionary keys.
|
|
251
|
-
*/
|
|
252
|
-
const isStringKeyType = (typeNode: ts.TypeNode): boolean => {
|
|
253
|
-
// Direct string keyword
|
|
254
|
-
if (typeNode.kind === ts.SyntaxKind.StringKeyword) {
|
|
255
|
-
return true;
|
|
256
|
-
}
|
|
257
|
-
|
|
258
|
-
// Type reference to "string"
|
|
259
|
-
if (ts.isTypeReferenceNode(typeNode)) {
|
|
260
|
-
const typeName = typeNode.typeName;
|
|
261
|
-
if (ts.isIdentifier(typeName) && typeName.text === "string") {
|
|
262
|
-
return true;
|
|
263
|
-
}
|
|
264
|
-
}
|
|
265
|
-
|
|
266
|
-
return false;
|
|
267
|
-
};
|