@shapeshift-labs/frontier-lang-compiler 0.2.41 → 0.2.43
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/README.md +101 -1
- package/bench/compile-suite.mjs +31 -0
- package/bench/native-adapters.mjs +32 -0
- package/bench/native-import-suite.mjs +79 -0
- package/bench/native-matrix-suite.mjs +64 -0
- package/bench/native-transform-suite.mjs +125 -0
- package/bench/smoke.mjs +80 -375
- package/bench/source-change-suite.mjs +111 -0
- package/dist/coverage-matrix-profiles.js +19 -0
- package/dist/declarations/adapter-coverage.d.ts +181 -0
- package/dist/declarations/compile.d.ts +110 -0
- package/dist/declarations/import-adapter-core.d.ts +233 -0
- package/dist/declarations/import-adapter-options-native.d.ts +185 -0
- package/dist/declarations/import-adapter-options-platform.d.ts +204 -0
- package/dist/declarations/language-adapter-package-contracts.d.ts +190 -0
- package/dist/declarations/native-diff.d.ts +240 -0
- package/dist/declarations/native-import-contracts.d.ts +211 -0
- package/dist/declarations/native-import-coverage.d.ts +107 -0
- package/dist/declarations/native-import-losses.d.ts +199 -0
- package/dist/declarations/native-parser-features.d.ts +227 -0
- package/dist/declarations/native-parser-formats.d.ts +132 -0
- package/dist/declarations/native-project-admission.d.ts +160 -0
- package/dist/declarations/native-project.d.ts +209 -0
- package/dist/declarations/projection-coverage.d.ts +146 -0
- package/dist/declarations/projection-readiness.d.ts +115 -0
- package/dist/declarations/roundtrip.d.ts +200 -0
- package/dist/declarations/runtime.d.ts +135 -0
- package/dist/declarations/semantic-history.d.ts +188 -0
- package/dist/declarations/semantic-merge-conflicts.d.ts +82 -0
- package/dist/declarations/semantic-patch-bundle.d.ts +210 -0
- package/dist/declarations/semantic-sidecar-admission.d.ts +61 -0
- package/dist/declarations/semantic-sidecar.d.ts +317 -0
- package/dist/declarations/semantic-slice.d.ts +228 -0
- package/dist/declarations/source-preservation.d.ts +126 -0
- package/dist/declarations/target-adapters.d.ts +138 -0
- package/dist/declarations/universal-capability.d.ts +148 -0
- package/dist/declarations/universal-dialects.d.ts +242 -0
- package/dist/index.d.ts +28 -2570
- package/dist/index.js +76 -16575
- package/dist/internal/index-impl/ExternalSemanticIndexFormats.js +8 -0
- package/dist/internal/index-impl/FrontierCompileTargets.js +7 -0
- package/dist/internal/index-impl/NativeImportFeatureEvidencePolicies.js +111 -0
- package/dist/internal/index-impl/NativeImportLossKinds.js +24 -0
- package/dist/internal/index-impl/NativeImportReadinessBySeverity.js +6 -0
- package/dist/internal/index-impl/NativeImportRoundtripReadinessStatuses.js +7 -0
- package/dist/internal/index-impl/NativeImportTaxonomyKinds.js +19 -0
- package/dist/internal/index-impl/adapterCoverageCapabilityRow.js +13 -0
- package/dist/internal/index-impl/adapterCoverageSnapshotFromSummary.js +13 -0
- package/dist/internal/index-impl/adapterCoverageSourcePreservation.js +6 -0
- package/dist/internal/index-impl/adapterDiagnosticToLoss.js +23 -0
- package/dist/internal/index-impl/adapterDiagnosticsEvidence.js +27 -0
- package/dist/internal/index-impl/addLspSemanticTokens.js +32 -0
- package/dist/internal/index-impl/addLspSymbol.js +44 -0
- package/dist/internal/index-impl/addSet.js +5 -0
- package/dist/internal/index-impl/attachExternalOwnership.js +79 -0
- package/dist/internal/index-impl/attachNativeChangeRegionProjectionMetadata.js +13 -0
- package/dist/internal/index-impl/attachNativeImportLossSummary.js +11 -0
- package/dist/internal/index-impl/canonicalTargets.js +7 -0
- package/dist/internal/index-impl/clangAstChildEntries.js +9 -0
- package/dist/internal/index-impl/clangAstDeclaration.js +44 -0
- package/dist/internal/index-impl/clangAstKind.js +7 -0
- package/dist/internal/index-impl/clangAstNodeValue.js +7 -0
- package/dist/internal/index-impl/clangAstRoot.js +14 -0
- package/dist/internal/index-impl/clangDeclarationAction.js +7 -0
- package/dist/internal/index-impl/clangDeclarationName.js +10 -0
- package/dist/internal/index-impl/clangIncludePath.js +8 -0
- package/dist/internal/index-impl/clangLiteralValue.js +6 -0
- package/dist/internal/index-impl/clangLocPosition.js +12 -0
- package/dist/internal/index-impl/clangLocationKind.js +8 -0
- package/dist/internal/index-impl/clangPreprocessorKind.js +3 -0
- package/dist/internal/index-impl/clangPreprocessorRecords.js +8 -0
- package/dist/internal/index-impl/clangTypeName.js +9 -0
- package/dist/internal/index-impl/classifyNativeImportReadiness.js +9 -0
- package/dist/internal/index-impl/classifyNativeImportRoundtripReadiness.js +129 -0
- package/dist/internal/index-impl/compileFrontierDocument.js +28 -0
- package/dist/internal/index-impl/compileFrontierSource.js +8 -0
- package/dist/internal/index-impl/compileNativeSource.js +186 -0
- package/dist/internal/index-impl/compileTargetLanguage.js +5 -0
- package/dist/internal/index-impl/coverageMatrixContext.js +20 -0
- package/dist/internal/index-impl/createAstNormalizationContext.js +14 -0
- package/dist/internal/index-impl/createBabelNativeImporterAdapter.js +18 -0
- package/dist/internal/index-impl/createCSharpRoslynNativeImporterAdapter.js +68 -0
- package/dist/internal/index-impl/createClangAstNativeImporterAdapter.js +59 -0
- package/dist/internal/index-impl/createEstreeNativeImporterAdapter.js +12 -0
- package/dist/internal/index-impl/createGoAstNativeImporterAdapter.js +63 -0
- package/dist/internal/index-impl/createJavaAstNativeImporterAdapter.js +66 -0
- package/dist/internal/index-impl/createKotlinPsiNativeImporterAdapter.js +73 -0
- package/dist/internal/index-impl/createLightweightNativeImport.js +154 -0
- package/dist/internal/index-impl/createNativeImportCoverageMatrix.js +5 -0
- package/dist/internal/index-impl/createNativeImportFromCSharpRoslyn.js +39 -0
- package/dist/internal/index-impl/createNativeImportFromClangAst.js +36 -0
- package/dist/internal/index-impl/createNativeImportFromGoAst.js +35 -0
- package/dist/internal/index-impl/createNativeImportFromJavaAst.js +39 -0
- package/dist/internal/index-impl/createNativeImportFromKotlinPsi.js +47 -0
- package/dist/internal/index-impl/createNativeImportFromPythonAst.js +30 -0
- package/dist/internal/index-impl/createNativeImportFromRustSyn.js +30 -0
- package/dist/internal/index-impl/createNativeImportFromSwiftSyntax.js +37 -0
- package/dist/internal/index-impl/createNativeImportFromSyntaxAst.js +36 -0
- package/dist/internal/index-impl/createNativeImportFromTreeSitter.js +125 -0
- package/dist/internal/index-impl/createNativeImportFromTypeScriptAst.js +24 -0
- package/dist/internal/index-impl/createNativeImportResultContract.js +78 -0
- package/dist/internal/index-impl/createNativeParserAstFormatMatrix.js +5 -0
- package/dist/internal/index-impl/createNativeParserFeatureMatrix.js +5 -0
- package/dist/internal/index-impl/createNativeProjectImportResult.js +126 -0
- package/dist/internal/index-impl/createNativeRoundtripEvidence.js +117 -0
- package/dist/internal/index-impl/createNativeSourcePreservation.js +64 -0
- package/dist/internal/index-impl/createProjectImportAdmissionRecord.js +91 -0
- package/dist/internal/index-impl/createProjectionReadinessMatrix.js +5 -0
- package/dist/internal/index-impl/createProjectionTargetLossMatrix.js +5 -0
- package/dist/internal/index-impl/createPythonAstNativeImporterAdapter.js +52 -0
- package/dist/internal/index-impl/createRustSynNativeImporterAdapter.js +56 -0
- package/dist/internal/index-impl/createSemanticImportSidecar.js +105 -0
- package/dist/internal/index-impl/createSemanticImportSidecarAdmission.js +160 -0
- package/dist/internal/index-impl/createSemanticSlice.js +137 -0
- package/dist/internal/index-impl/createSwiftSyntaxNativeImporterAdapter.js +62 -0
- package/dist/internal/index-impl/createTreeSitterNativeImporterAdapter.js +58 -0
- package/dist/internal/index-impl/createTypeScriptCompilerNativeImporterAdapter.js +45 -0
- package/dist/internal/index-impl/createUniversalAstFromDocument.js +15 -0
- package/dist/internal/index-impl/createUniversalCapabilityMatrix.js +5 -0
- package/dist/internal/index-impl/csharpEvidenceSummary.js +18 -0
- package/dist/internal/index-impl/csharpGeneratedCodeLoss.js +20 -0
- package/dist/internal/index-impl/csharpGeneratedCodeMarker.js +16 -0
- package/dist/internal/index-impl/csharpGeneratedSourcePath.js +3 -0
- package/dist/internal/index-impl/csharpRoslynChildEntries.js +18 -0
- package/dist/internal/index-impl/csharpRoslynChildWithParent.js +6 -0
- package/dist/internal/index-impl/csharpRoslynDeclarationName.js +11 -0
- package/dist/internal/index-impl/csharpRoslynDeclarations.js +53 -0
- package/dist/internal/index-impl/csharpRoslynDirectiveKind.js +3 -0
- package/dist/internal/index-impl/csharpRoslynHasBody.js +3 -0
- package/dist/internal/index-impl/csharpRoslynKind.js +11 -0
- package/dist/internal/index-impl/csharpRoslynLiteralValue.js +5 -0
- package/dist/internal/index-impl/csharpRoslynMethodLikeKind.js +7 -0
- package/dist/internal/index-impl/csharpRoslynModifierNames.js +16 -0
- package/dist/internal/index-impl/csharpRoslynName.js +13 -0
- package/dist/internal/index-impl/csharpRoslynNodeValue.js +7 -0
- package/dist/internal/index-impl/csharpRoslynOperatorName.js +8 -0
- package/dist/internal/index-impl/csharpRoslynPosition.js +27 -0
- package/dist/internal/index-impl/csharpRoslynPositionKind.js +6 -0
- package/dist/internal/index-impl/csharpRoslynProblemNode.js +14 -0
- package/dist/internal/index-impl/csharpRoslynRecoveredKind.js +5 -0
- package/dist/internal/index-impl/csharpRoslynRoot.js +15 -0
- package/dist/internal/index-impl/csharpRoslynTypeDeclarationKind.js +8 -0
- package/dist/internal/index-impl/csharpRoslynTypeDeclarationSymbolKind.js +5 -0
- package/dist/internal/index-impl/csharpRoslynTypeName.js +19 -0
- package/dist/internal/index-impl/csharpRoslynUsingPath.js +5 -0
- package/dist/internal/index-impl/csharpRoslynVariableNames.js +10 -0
- package/dist/internal/index-impl/declarationRecord.js +11 -0
- package/dist/internal/index-impl/declarationSemanticCoverage.js +10 -0
- package/dist/internal/index-impl/diffNativeOwnershipRegions.js +19 -0
- package/dist/internal/index-impl/diffNativeSourceImports.js +166 -0
- package/dist/internal/index-impl/diffNativeSources.js +25 -0
- package/dist/internal/index-impl/diffNativeSymbols.js +41 -0
- package/dist/internal/index-impl/effectiveAdapterExactness.js +6 -0
- package/dist/internal/index-impl/effectiveNativeImporterAdapterCoverage.js +21 -0
- package/dist/internal/index-impl/emitForTarget.js +4 -0
- package/dist/internal/index-impl/emitForTargetWithSourceMap.js +11 -0
- package/dist/internal/index-impl/ensureTrailingNewline.js +4 -0
- package/dist/internal/index-impl/expandSemanticSliceSelection.js +51 -0
- package/dist/internal/index-impl/externalDiagnosticFact.js +22 -0
- package/dist/internal/index-impl/externalDiagnosticLoss.js +20 -0
- package/dist/internal/index-impl/externalDiagnosticSeverity.js +7 -0
- package/dist/internal/index-impl/externalDocument.js +12 -0
- package/dist/internal/index-impl/externalFact.js +10 -0
- package/dist/internal/index-impl/externalLanguageNameByNumber.js +23 -0
- package/dist/internal/index-impl/externalOccurrence.js +13 -0
- package/dist/internal/index-impl/externalRelation.js +10 -0
- package/dist/internal/index-impl/externalRelationPredicateForOccurrence.js +8 -0
- package/dist/internal/index-impl/externalSemanticBase.js +15 -0
- package/dist/internal/index-impl/externalSemanticCoverageLoss.js +17 -0
- package/dist/internal/index-impl/externalSemanticEvidence.js +16 -0
- package/dist/internal/index-impl/externalSemanticSourceMapMappings.js +26 -0
- package/dist/internal/index-impl/externalSymbol.js +14 -0
- package/dist/internal/index-impl/externalSymbolKindByNumber.js +32 -0
- package/dist/internal/index-impl/fileLevelNativeChangeRegion.js +23 -0
- package/dist/internal/index-impl/findSemanticImportRegion.js +6 -0
- package/dist/internal/index-impl/freezeNativeImporterAdapterCoverageSnapshot.js +13 -0
- package/dist/internal/index-impl/getNativeImportFeatureEvidencePolicy.js +5 -0
- package/dist/internal/index-impl/getNativeParserAstFormatProfile.js +4 -0
- package/dist/internal/index-impl/goAstChildEntries.js +23 -0
- package/dist/internal/index-impl/goAstDeclarationName.js +9 -0
- package/dist/internal/index-impl/goAstDeclarations.js +30 -0
- package/dist/internal/index-impl/goAstIdentName.js +5 -0
- package/dist/internal/index-impl/goAstImportPath.js +7 -0
- package/dist/internal/index-impl/goAstKind.js +15 -0
- package/dist/internal/index-impl/goAstLiteralValue.js +5 -0
- package/dist/internal/index-impl/goAstNodeValue.js +7 -0
- package/dist/internal/index-impl/goAstPackageName.js +5 -0
- package/dist/internal/index-impl/goAstPosition.js +30 -0
- package/dist/internal/index-impl/goAstPositionKind.js +6 -0
- package/dist/internal/index-impl/goAstReceiverName.js +8 -0
- package/dist/internal/index-impl/goAstRoot.js +12 -0
- package/dist/internal/index-impl/goAstTokenName.js +6 -0
- package/dist/internal/index-impl/goAstTypeName.js +27 -0
- package/dist/internal/index-impl/goAstTypeSpecSymbolKind.js +8 -0
- package/dist/internal/index-impl/goAstValueSpecName.js +4 -0
- package/dist/internal/index-impl/goAstValueSpecNames.js +7 -0
- package/dist/internal/index-impl/goBadAstKind.js +3 -0
- package/dist/internal/index-impl/goGeneratedCodeMarker.js +7 -0
- package/dist/internal/index-impl/goReceiverFieldCount.js +4 -0
- package/dist/internal/index-impl/goTypeEvidenceSummary.js +9 -0
- package/dist/internal/index-impl/hasNativeExactAstEvidence.js +13 -0
- package/dist/internal/index-impl/hashNativeSpanText.js +6 -0
- package/dist/internal/index-impl/identifierName.js +9 -0
- package/dist/internal/index-impl/ignoredCSharpRoslynField.js +31 -0
- package/dist/internal/index-impl/ignoredClangAstField.js +19 -0
- package/dist/internal/index-impl/ignoredGoAstField.js +23 -0
- package/dist/internal/index-impl/ignoredJavaAstField.js +29 -0
- package/dist/internal/index-impl/ignoredKotlinPsiField.js +26 -0
- package/dist/internal/index-impl/ignoredPythonAstField.js +17 -0
- package/dist/internal/index-impl/ignoredRustSynField.js +11 -0
- package/dist/internal/index-impl/ignoredSwiftSyntaxField.js +27 -0
- package/dist/internal/index-impl/ignoredSyntaxField.js +15 -0
- package/dist/internal/index-impl/importExternalSemanticIndex.js +141 -0
- package/dist/internal/index-impl/importNativeProject.js +26 -0
- package/dist/internal/index-impl/importNativeSource.js +317 -0
- package/dist/internal/index-impl/inferExternalSemanticIndexFormat.js +46 -0
- package/dist/internal/index-impl/inferredAdapterCoverageNotes.js +8 -0
- package/dist/internal/index-impl/inferredAdapterExactness.js +5 -0
- package/dist/internal/index-impl/inferredSemanticCoverageLevel.js +5 -0
- package/dist/internal/index-impl/isCSharpRoslynNode.js +4 -0
- package/dist/internal/index-impl/isClangAstNode.js +4 -0
- package/dist/internal/index-impl/isGoAstNode.js +4 -0
- package/dist/internal/index-impl/isJavaAstNode.js +4 -0
- package/dist/internal/index-impl/isKotlinPsiNode.js +4 -0
- package/dist/internal/index-impl/isNativeSourceImportResult.js +3 -0
- package/dist/internal/index-impl/isPythonAstNode.js +4 -0
- package/dist/internal/index-impl/isRustSynAstNode.js +4 -0
- package/dist/internal/index-impl/isSwiftSyntaxNode.js +4 -0
- package/dist/internal/index-impl/isSyntaxAstNode.js +3 -0
- package/dist/internal/index-impl/javaAnnotationProcessingSummary.js +13 -0
- package/dist/internal/index-impl/javaAstChildEntries.js +18 -0
- package/dist/internal/index-impl/javaAstChildWithParent.js +6 -0
- package/dist/internal/index-impl/javaAstDeclarationName.js +11 -0
- package/dist/internal/index-impl/javaAstDeclarations.js +35 -0
- package/dist/internal/index-impl/javaAstFieldNames.js +7 -0
- package/dist/internal/index-impl/javaAstHasBody.js +3 -0
- package/dist/internal/index-impl/javaAstImportPath.js +8 -0
- package/dist/internal/index-impl/javaAstKind.js +12 -0
- package/dist/internal/index-impl/javaAstLiteralValue.js +5 -0
- package/dist/internal/index-impl/javaAstModifierNames.js +16 -0
- package/dist/internal/index-impl/javaAstName.js +14 -0
- package/dist/internal/index-impl/javaAstNodeValue.js +8 -0
- package/dist/internal/index-impl/javaAstPackageName.js +5 -0
- package/dist/internal/index-impl/javaAstPosition.js +32 -0
- package/dist/internal/index-impl/javaAstPositionKind.js +7 -0
- package/dist/internal/index-impl/javaAstRoot.js +14 -0
- package/dist/internal/index-impl/javaAstTypeName.js +22 -0
- package/dist/internal/index-impl/javaBindingEvidenceSummary.js +10 -0
- package/dist/internal/index-impl/javaGeneratedCodeLoss.js +20 -0
- package/dist/internal/index-impl/javaGeneratedCodeMarker.js +16 -0
- package/dist/internal/index-impl/javaLombokAnnotationMarker.js +6 -0
- package/dist/internal/index-impl/javaPathEvidenceSummary.js +14 -0
- package/dist/internal/index-impl/javaProblemNode.js +3 -0
- package/dist/internal/index-impl/javaRecoveredAstKind.js +4 -0
- package/dist/internal/index-impl/javaTypeDeclarationKind.js +7 -0
- package/dist/internal/index-impl/javaTypeDeclarationSymbolKind.js +5 -0
- package/dist/internal/index-impl/kotlinCompilerPluginAnnotationNode.js +5 -0
- package/dist/internal/index-impl/kotlinContractNode.js +3 -0
- package/dist/internal/index-impl/kotlinCoroutineNode.js +8 -0
- package/dist/internal/index-impl/kotlinEvidenceSummary.js +21 -0
- package/dist/internal/index-impl/kotlinExpectActualNode.js +5 -0
- package/dist/internal/index-impl/kotlinGeneratedCodeLoss.js +22 -0
- package/dist/internal/index-impl/kotlinGeneratedCodeMarker.js +6 -0
- package/dist/internal/index-impl/kotlinGeneratedSourcePath.js +3 -0
- package/dist/internal/index-impl/kotlinPsiAnnotationNames.js +10 -0
- package/dist/internal/index-impl/kotlinPsiChildEntries.js +18 -0
- package/dist/internal/index-impl/kotlinPsiChildWithParent.js +6 -0
- package/dist/internal/index-impl/kotlinPsiDeclarationName.js +14 -0
- package/dist/internal/index-impl/kotlinPsiDeclarations.js +37 -0
- package/dist/internal/index-impl/kotlinPsiHasBody.js +3 -0
- package/dist/internal/index-impl/kotlinPsiImportPath.js +8 -0
- package/dist/internal/index-impl/kotlinPsiKind.js +13 -0
- package/dist/internal/index-impl/kotlinPsiModifiers.js +22 -0
- package/dist/internal/index-impl/kotlinPsiName.js +14 -0
- package/dist/internal/index-impl/kotlinPsiNodeValue.js +7 -0
- package/dist/internal/index-impl/kotlinPsiPackageName.js +8 -0
- package/dist/internal/index-impl/kotlinPsiPosition.js +27 -0
- package/dist/internal/index-impl/kotlinPsiPositionKind.js +6 -0
- package/dist/internal/index-impl/kotlinPsiProblemNode.js +10 -0
- package/dist/internal/index-impl/kotlinPsiRecoveredKind.js +5 -0
- package/dist/internal/index-impl/kotlinPsiRoot.js +15 -0
- package/dist/internal/index-impl/kotlinPsiTypeDeclarationKind.js +5 -0
- package/dist/internal/index-impl/kotlinPsiTypeDeclarationSymbolKind.js +8 -0
- package/dist/internal/index-impl/kotlinPsiTypeName.js +18 -0
- package/dist/internal/index-impl/kotlinPsiVariableNames.js +7 -0
- package/dist/internal/index-impl/kotlinScriptLoss.js +22 -0
- package/dist/internal/index-impl/kotlinUnsupportedSemanticLoss.js +23 -0
- package/dist/internal/index-impl/lineColumnForOffset.js +15 -0
- package/dist/internal/index-impl/literalSyntaxValue.js +4 -0
- package/dist/internal/index-impl/lossSeverityRank.js +6 -0
- package/dist/internal/index-impl/lspSymbolKindByNumber.js +19 -0
- package/dist/internal/index-impl/mapDiffSymbols.js +39 -0
- package/dist/internal/index-impl/matchingNativeTargetProjectionAdapter.js +4 -0
- package/dist/internal/index-impl/maxSemanticCoverageLevel.js +6 -0
- package/dist/internal/index-impl/mergeNativeLosses.js +12 -0
- package/dist/internal/index-impl/mergeSemanticIndexes.js +19 -0
- package/dist/internal/index-impl/mergeSemanticSliceSymbols.js +16 -0
- package/dist/internal/index-impl/missingInjectedParserResult.js +51 -0
- package/dist/internal/index-impl/nameFromExternalSymbol.js +10 -0
- package/dist/internal/index-impl/namedDeclaration.js +5 -0
- package/dist/internal/index-impl/nativeAstNodes.js +4 -0
- package/dist/internal/index-impl/nativeChangeMappingTouchesRegion.js +17 -0
- package/dist/internal/index-impl/nativeChangeProjectionEndpoint.js +28 -0
- package/dist/internal/index-impl/nativeChangeProjectionSourceMapLinks.js +33 -0
- package/dist/internal/index-impl/nativeChangeSpans.js +37 -0
- package/dist/internal/index-impl/nativeChangeSymbolTouchesRegion.js +10 -0
- package/dist/internal/index-impl/nativeChangeTouchedSymbol.js +21 -0
- package/dist/internal/index-impl/nativeChangedRegionProjectionAction.js +7 -0
- package/dist/internal/index-impl/nativeChangedRegionProjectionMetadata.js +49 -0
- package/dist/internal/index-impl/nativeChangedRegionProjectionSpanMetadata.js +12 -0
- package/dist/internal/index-impl/nativeCompileSourceLanguage.js +10 -0
- package/dist/internal/index-impl/nativeCompileTarget.js +10 -0
- package/dist/internal/index-impl/nativeDiffSymbolChanged.js +7 -0
- package/dist/internal/index-impl/nativeDiffSymbolKey.js +7 -0
- package/dist/internal/index-impl/nativeFeatureEvidenceRiskRank.js +6 -0
- package/dist/internal/index-impl/nativeImportCategoryForLossKind.js +16 -0
- package/dist/internal/index-impl/nativeImportEntries.js +4 -0
- package/dist/internal/index-impl/nativeImportFeatureEvidenceHasKey.js +5 -0
- package/dist/internal/index-impl/nativeImportFeatureEvidenceIds.js +10 -0
- package/dist/internal/index-impl/nativeImportFeatureEvidencePolicy.js +14 -0
- package/dist/internal/index-impl/nativeImportFeatureEvidenceReasons.js +8 -0
- package/dist/internal/index-impl/nativeImportFeatureEvidenceValue.js +11 -0
- package/dist/internal/index-impl/nativeImportFeatureEvidenceValuePresent.js +7 -0
- package/dist/internal/index-impl/nativeImportHasExactAstCoverage.js +5 -0
- package/dist/internal/index-impl/nativeImportProjectionContext.js +40 -0
- package/dist/internal/index-impl/nativeImportReadiness.js +6 -0
- package/dist/internal/index-impl/nativeImportReadinessReasons.js +16 -0
- package/dist/internal/index-impl/nativeImportRoundtripParser.js +10 -0
- package/dist/internal/index-impl/nativeImportRoundtripReasons.js +22 -0
- package/dist/internal/index-impl/nativeImportSourcePreservationRecord.js +6 -0
- package/dist/internal/index-impl/nativeImportSourceText.js +6 -0
- package/dist/internal/index-impl/nativeImporterAdapterCapabilityEvidence.js +59 -0
- package/dist/internal/index-impl/nativeImporterAdapterCoverage.js +12 -0
- package/dist/internal/index-impl/nativeJavaScriptImporterDeps.js +12 -0
- package/dist/internal/index-impl/nativeNodeId.js +8 -0
- package/dist/internal/index-impl/nativeProjectionDeclarationKind.js +12 -0
- package/dist/internal/index-impl/nativeProjectionDeclarations.js +48 -0
- package/dist/internal/index-impl/nativeProjectionImportOnlySymbol.js +5 -0
- package/dist/internal/index-impl/nativeProjectionKindForNode.js +12 -0
- package/dist/internal/index-impl/nativeProjectionLineComment.js +5 -0
- package/dist/internal/index-impl/nativeProjectionLoss.js +23 -0
- package/dist/internal/index-impl/nativeProjectionSourceCandidate.js +22 -0
- package/dist/internal/index-impl/nativeProjectionStubHeader.js +11 -0
- package/dist/internal/index-impl/nativeProjectionStubLosses.js +36 -0
- package/dist/internal/index-impl/nativeSourceChangeReasons.js +11 -0
- package/dist/internal/index-impl/nativeSourceChangeSummary.js +13 -0
- package/dist/internal/index-impl/nativeSourceCompileDeclarationGeneratedSpan.js +25 -0
- package/dist/internal/index-impl/nativeSourceCompileDeclarationMappings.js +31 -0
- package/dist/internal/index-impl/nativeSourceCompileEvidence.js +30 -0
- package/dist/internal/index-impl/nativeSourceCompileFileMapping.js +21 -0
- package/dist/internal/index-impl/nativeSourceCompileFullGeneratedSpan.js +16 -0
- package/dist/internal/index-impl/nativeSourceCompileGeneratedSpanForOffset.js +17 -0
- package/dist/internal/index-impl/nativeSourceCompileGeneratedSpanFromSource.js +13 -0
- package/dist/internal/index-impl/nativeSourceCompileMapTarget.js +6 -0
- package/dist/internal/index-impl/nativeSourceCompilePreservedMappings.js +51 -0
- package/dist/internal/index-impl/nativeSourceCompileSourceMaps.js +41 -0
- package/dist/internal/index-impl/nativeSourceCompileTargetCoverage.js +21 -0
- package/dist/internal/index-impl/nativeSourceCompileTargetExtension.js +10 -0
- package/dist/internal/index-impl/nativeSourceCompileTargetLoss.js +32 -0
- package/dist/internal/index-impl/nativeSourceCompileTargetLosses.js +43 -0
- package/dist/internal/index-impl/nativeSourceCompileTargetPath.js +9 -0
- package/dist/internal/index-impl/nativeTargetProjectionAdapterEvidence.js +26 -0
- package/dist/internal/index-impl/nativeTargetProjectionAdapterMatches.js +16 -0
- package/dist/internal/index-impl/nativeTargetProjectionDiagnosticToLoss.js +22 -0
- package/dist/internal/index-impl/normalizeAdapterDiagnostics.js +28 -0
- package/dist/internal/index-impl/normalizeArray.js +4 -0
- package/dist/internal/index-impl/normalizeCSharpRoslynKind.js +38 -0
- package/dist/internal/index-impl/normalizeCompileTarget.js +9 -0
- package/dist/internal/index-impl/normalizeDiagnosticSeverity.js +6 -0
- package/dist/internal/index-impl/normalizeExternalOccurrenceRole.js +9 -0
- package/dist/internal/index-impl/normalizeExternalSemanticIndexFormat.js +34 -0
- package/dist/internal/index-impl/normalizeExternalSemanticIndexPayload.js +10 -0
- package/dist/internal/index-impl/normalizeExternalSemanticLanguage.js +7 -0
- package/dist/internal/index-impl/normalizeExternalSpan.js +21 -0
- package/dist/internal/index-impl/normalizeExternalSymbolKind.js +6 -0
- package/dist/internal/index-impl/normalizeFrontierSemanticIndexPayload.js +14 -0
- package/dist/internal/index-impl/normalizeGenericExternalSemanticIndexPayload.js +15 -0
- package/dist/internal/index-impl/normalizeGleanPayload.js +210 -0
- package/dist/internal/index-impl/normalizeGoAstKind.js +14 -0
- package/dist/internal/index-impl/normalizeJavaAstKind.js +24 -0
- package/dist/internal/index-impl/normalizeKotlinPsiKind.js +54 -0
- package/dist/internal/index-impl/normalizeLossSeverity.js +6 -0
- package/dist/internal/index-impl/normalizeLsifPayload.js +91 -0
- package/dist/internal/index-impl/normalizeLspDocuments.js +15 -0
- package/dist/internal/index-impl/normalizeLspPayload.js +33 -0
- package/dist/internal/index-impl/normalizeLspSymbolKind.js +5 -0
- package/dist/internal/index-impl/normalizeNativeDiffImport.js +15 -0
- package/dist/internal/index-impl/normalizeNativeImporterAdapter.js +33 -0
- package/dist/internal/index-impl/normalizeNativeImporterAdapterCoverage.js +38 -0
- package/dist/internal/index-impl/normalizeNativeImporterAdapterObservedCoverage.js +43 -0
- package/dist/internal/index-impl/normalizeNativeImporterSemanticCoverage.js +18 -0
- package/dist/internal/index-impl/normalizeNativeLossKind.js +8 -0
- package/dist/internal/index-impl/normalizeNativeLossRecord.js +20 -0
- package/dist/internal/index-impl/normalizeNativeLossRecords.js +6 -0
- package/dist/internal/index-impl/normalizeNativeTargetProjectionAdapter.js +37 -0
- package/dist/internal/index-impl/normalizeNativeTargetProjectionAdapterCoverage.js +20 -0
- package/dist/internal/index-impl/normalizeParserErrors.js +18 -0
- package/dist/internal/index-impl/normalizeRustSynKind.js +32 -0
- package/dist/internal/index-impl/normalizeScipPayload.js +98 -0
- package/dist/internal/index-impl/normalizeSemanticDbPayload.js +57 -0
- package/dist/internal/index-impl/normalizeSemanticSliceRef.js +4 -0
- package/dist/internal/index-impl/normalizeSwiftSyntaxKind.js +45 -0
- package/dist/internal/index-impl/normalizeSyntaxAstRoot.js +5 -0
- package/dist/internal/index-impl/numberOrUndefined.js +3 -0
- package/dist/internal/index-impl/observeNativeImporterAdapterCoverage.js +24 -0
- package/dist/internal/index-impl/observeNativeImporterAdapterCoverageDetails.js +66 -0
- package/dist/internal/index-impl/observeNativeImporterSemanticEvidence.js +23 -0
- package/dist/internal/index-impl/observedAdapterExactness.js +6 -0
- package/dist/internal/index-impl/oneLine.js +3 -0
- package/dist/internal/index-impl/parseCSharpRoslynSource.js +15 -0
- package/dist/internal/index-impl/parseClangAstSource.js +16 -0
- package/dist/internal/index-impl/parseGoAstSource.js +15 -0
- package/dist/internal/index-impl/parseJavaAstSource.js +16 -0
- package/dist/internal/index-impl/parseKotlinPsiSource.js +16 -0
- package/dist/internal/index-impl/parsePythonAstSource.js +16 -0
- package/dist/internal/index-impl/parseRustSynSource.js +13 -0
- package/dist/internal/index-impl/parseSwiftSyntaxSource.js +15 -0
- package/dist/internal/index-impl/parseTreeSitterSource.js +6 -0
- package/dist/internal/index-impl/primitiveCSharpRoslynFields.js +23 -0
- package/dist/internal/index-impl/primitiveClangAstFields.js +31 -0
- package/dist/internal/index-impl/primitiveGoAstFields.js +22 -0
- package/dist/internal/index-impl/primitiveJavaAstFields.js +22 -0
- package/dist/internal/index-impl/primitiveKotlinPsiFields.js +24 -0
- package/dist/internal/index-impl/primitivePythonAstFields.js +18 -0
- package/dist/internal/index-impl/primitiveRustSynFields.js +16 -0
- package/dist/internal/index-impl/primitiveSwiftSyntaxFields.js +21 -0
- package/dist/internal/index-impl/primitiveSyntaxFields.js +13 -0
- package/dist/internal/index-impl/primitiveTypeScriptFields.js +9 -0
- package/dist/internal/index-impl/projectFrontierAst.js +6 -0
- package/dist/internal/index-impl/projectImportAdmissionDecision.js +27 -0
- package/dist/internal/index-impl/projectImportAdmissionMergeScore.js +316 -0
- package/dist/internal/index-impl/projectImportAdmissionSummaries.js +252 -0
- package/dist/internal/index-impl/projectNativeImportToSource.js +90 -0
- package/dist/internal/index-impl/projectors.js +8 -0
- package/dist/internal/index-impl/pythonAliasName.js +5 -0
- package/dist/internal/index-impl/pythonAssignmentName.js +9 -0
- package/dist/internal/index-impl/pythonAstChildEntries.js +11 -0
- package/dist/internal/index-impl/pythonAstDeclaration.js +18 -0
- package/dist/internal/index-impl/pythonAstKind.js +3 -0
- package/dist/internal/index-impl/pythonAstLiteralValue.js +6 -0
- package/dist/internal/index-impl/pythonAstNodeValue.js +4 -0
- package/dist/internal/index-impl/pythonAstRoot.js +9 -0
- package/dist/internal/index-impl/pythonTargetName.js +12 -0
- package/dist/internal/index-impl/queryNativeParserFeatureMatrix.js +5 -0
- package/dist/internal/index-impl/queryProjectionReadinessMatrix.js +5 -0
- package/dist/internal/index-impl/readSemanticSliceJson.js +7 -0
- package/dist/internal/index-impl/readStringArray.js +5 -0
- package/dist/internal/index-impl/readUniversalAstJson.js +9 -0
- package/dist/internal/index-impl/relationPredicateForDeclaration.js +5 -0
- package/dist/internal/index-impl/renderCProjectionStubs.js +11 -0
- package/dist/internal/index-impl/renderGenericProjectionStubs.js +5 -0
- package/dist/internal/index-impl/renderJavaScriptProjectionStubs.js +12 -0
- package/dist/internal/index-impl/renderNativeProjectionStubs.js +13 -0
- package/dist/internal/index-impl/renderPythonProjectionStubs.js +10 -0
- package/dist/internal/index-impl/renderRustProjectionStubs.js +11 -0
- package/dist/internal/index-impl/renderTargetAst.js +6 -0
- package/dist/internal/index-impl/renderTargetAstWithSourceMap.js +6 -0
- package/dist/internal/index-impl/renderTypeScriptProjectionStubs.js +14 -0
- package/dist/internal/index-impl/renderers.js +8 -0
- package/dist/internal/index-impl/resolveCapabilityAdapters.js +29 -0
- package/dist/internal/index-impl/resolveNativeProjectAdapter.js +11 -0
- package/dist/internal/index-impl/resolveNativeTargetProjectionAdapter.js +14 -0
- package/dist/internal/index-impl/runNativeImporterAdapter.js +130 -0
- package/dist/internal/index-impl/runNativeTargetProjectionAdapter.js +115 -0
- package/dist/internal/index-impl/rustSynAstRoot.js +11 -0
- package/dist/internal/index-impl/rustSynChildEntries.js +10 -0
- package/dist/internal/index-impl/rustSynColumnToOneBased.js +3 -0
- package/dist/internal/index-impl/rustSynDeclaration.js +40 -0
- package/dist/internal/index-impl/rustSynIdentName.js +12 -0
- package/dist/internal/index-impl/rustSynImplName.js +11 -0
- package/dist/internal/index-impl/rustSynKind.js +15 -0
- package/dist/internal/index-impl/rustSynLiteralValue.js +5 -0
- package/dist/internal/index-impl/rustSynMacroKind.js +3 -0
- package/dist/internal/index-impl/rustSynNodeValue.js +6 -0
- package/dist/internal/index-impl/rustSynPathName.js +21 -0
- package/dist/internal/index-impl/rustSynPayload.js +6 -0
- package/dist/internal/index-impl/rustSynSpanKind.js +5 -0
- package/dist/internal/index-impl/rustSynUseName.js +26 -0
- package/dist/internal/index-impl/rustSynVisibility.js +9 -0
- package/dist/internal/index-impl/rustSynWrapperKind.js +12 -0
- package/dist/internal/index-impl/safeNativeImporterAdapterSummary.js +8 -0
- package/dist/internal/index-impl/safeNativeTargetProjectionAdapterSummary.js +8 -0
- package/dist/internal/index-impl/safeProjectionIdentifier.js +5 -0
- package/dist/internal/index-impl/scipOccurrenceRole.js +8 -0
- package/dist/internal/index-impl/scipOccurrenceRoleSet.js +12 -0
- package/dist/internal/index-impl/scipRelationshipRelations.js +20 -0
- package/dist/internal/index-impl/scipSymbolFacts.js +31 -0
- package/dist/internal/index-impl/scipSymbolId.js +8 -0
- package/dist/internal/index-impl/scipSyntaxKind.js +8 -0
- package/dist/internal/index-impl/selectSemanticSliceRecords.js +70 -0
- package/dist/internal/index-impl/semanticDbOccurrenceRole.js +5 -0
- package/dist/internal/index-impl/semanticDbSymbolFacts.js +15 -0
- package/dist/internal/index-impl/semanticDbSymbolId.js +7 -0
- package/dist/internal/index-impl/semanticHistoryRecords.js +233 -0
- package/dist/internal/index-impl/semanticIndexFromNativeDeclarations.js +127 -0
- package/dist/internal/index-impl/semanticMergeAdmissionForSeverity.js +5 -0
- package/dist/internal/index-impl/semanticMergeConflicts.js +116 -0
- package/dist/internal/index-impl/semanticPatchBundleRecords.js +240 -0
- package/dist/internal/index-impl/semanticPredicateMatches.js +4 -0
- package/dist/internal/index-impl/semanticSliceAssertion.js +8 -0
- package/dist/internal/index-impl/semanticSliceContext.js +24 -0
- package/dist/internal/index-impl/semanticSliceCurrentSource.js +4 -0
- package/dist/internal/index-impl/semanticSliceExpectedAssertions.js +8 -0
- package/dist/internal/index-impl/semanticSliceImportResult.js +30 -0
- package/dist/internal/index-impl/semanticSliceMappingMatchesRef.js +15 -0
- package/dist/internal/index-impl/semanticSliceMappingTouchesSets.js +7 -0
- package/dist/internal/index-impl/semanticSliceNativeNodeMatchesRef.js +12 -0
- package/dist/internal/index-impl/semanticSliceNativeParentMap.js +7 -0
- package/dist/internal/index-impl/semanticSliceReadiness.js +14 -0
- package/dist/internal/index-impl/semanticSliceReasons.js +11 -0
- package/dist/internal/index-impl/semanticSliceRecords.js +62 -0
- package/dist/internal/index-impl/semanticSliceRegionFromMapping.js +16 -0
- package/dist/internal/index-impl/semanticSliceRegionFromSymbol.js +21 -0
- package/dist/internal/index-impl/semanticSliceRegionMatchesRef.js +12 -0
- package/dist/internal/index-impl/semanticSliceRegionTouchesSets.js +6 -0
- package/dist/internal/index-impl/semanticSliceSourceFiles.js +35 -0
- package/dist/internal/index-impl/semanticSliceSourceHashAssertions.js +27 -0
- package/dist/internal/index-impl/semanticSliceSourceHashMap.js +18 -0
- package/dist/internal/index-impl/semanticSliceSourceMapLinks.js +21 -0
- package/dist/internal/index-impl/semanticSliceSourceSpans.js +9 -0
- package/dist/internal/index-impl/semanticSliceSourceTextMap.js +19 -0
- package/dist/internal/index-impl/semanticSliceSpanTouchesSelection.js +6 -0
- package/dist/internal/index-impl/semanticSliceSpansOverlap.js +15 -0
- package/dist/internal/index-impl/semanticSliceSymbolMatchesRef.js +13 -0
- package/dist/internal/index-impl/semanticSliceSymbolSpan.js +3 -0
- package/dist/internal/index-impl/semanticSliceSymbolTouchesSets.js +7 -0
- package/dist/internal/index-impl/semanticSliceTouchedSymbol.js +16 -0
- package/dist/internal/index-impl/semanticSliceValueMatches.js +6 -0
- package/dist/internal/index-impl/semanticTokenModifiers.js +7 -0
- package/dist/internal/index-impl/serializableDiagnostic.js +13 -0
- package/dist/internal/index-impl/serializableIncludeGraphSummary.js +10 -0
- package/dist/internal/index-impl/shortNodeText.js +6 -0
- package/dist/internal/index-impl/sourceMapRenderers.js +8 -0
- package/dist/internal/index-impl/sourcePreservationFromProjectionContext.js +5 -0
- package/dist/internal/index-impl/sourceSpanPathMatches.js +4 -0
- package/dist/internal/index-impl/sourceTextForSpan.js +12 -0
- package/dist/internal/index-impl/spanFromCSharpLineFields.js +12 -0
- package/dist/internal/index-impl/spanFromCSharpLineSpan.js +18 -0
- package/dist/internal/index-impl/spanFromCSharpRoslynNode.js +19 -0
- package/dist/internal/index-impl/spanFromClangAstNode.js +17 -0
- package/dist/internal/index-impl/spanFromGoAstNode.js +14 -0
- package/dist/internal/index-impl/spanFromJavaAstNode.js +36 -0
- package/dist/internal/index-impl/spanFromJavaLineFields.js +12 -0
- package/dist/internal/index-impl/spanFromJavaRange.js +22 -0
- package/dist/internal/index-impl/spanFromKotlinLineFields.js +12 -0
- package/dist/internal/index-impl/spanFromKotlinPsiNode.js +19 -0
- package/dist/internal/index-impl/spanFromKotlinRange.js +18 -0
- package/dist/internal/index-impl/spanFromLoc.js +11 -0
- package/dist/internal/index-impl/spanFromLspRange.js +12 -0
- package/dist/internal/index-impl/spanFromPythonAstNode.js +15 -0
- package/dist/internal/index-impl/spanFromRustSynNode.js +20 -0
- package/dist/internal/index-impl/spanFromScipOccurrence.js +40 -0
- package/dist/internal/index-impl/spanFromSemanticDbRange.js +11 -0
- package/dist/internal/index-impl/spanFromSwiftLineFields.js +12 -0
- package/dist/internal/index-impl/spanFromSwiftRange.js +18 -0
- package/dist/internal/index-impl/spanFromSwiftSyntaxNode.js +19 -0
- package/dist/internal/index-impl/spanFromTreeSitterNode.js +13 -0
- package/dist/internal/index-impl/spanFromTypeScriptNode.js +15 -0
- package/dist/internal/index-impl/stringFromTsExpression.js +7 -0
- package/dist/internal/index-impl/summarizeNativeChangedRegionProjections.js +16 -0
- package/dist/internal/index-impl/summarizeNativeImportFeatureEvidence.js +60 -0
- package/dist/internal/index-impl/summarizeNativeImportLosses.js +65 -0
- package/dist/internal/index-impl/summarizeProjectSourcePreservation.js +15 -0
- package/dist/internal/index-impl/swiftEvidenceSummary.js +19 -0
- package/dist/internal/index-impl/swiftGeneratedCodeLoss.js +20 -0
- package/dist/internal/index-impl/swiftGeneratedCodeMarker.js +11 -0
- package/dist/internal/index-impl/swiftGeneratedSourcePath.js +3 -0
- package/dist/internal/index-impl/swiftSyntaxAttributeNames.js +10 -0
- package/dist/internal/index-impl/swiftSyntaxChildEntries.js +18 -0
- package/dist/internal/index-impl/swiftSyntaxChildWithParent.js +6 -0
- package/dist/internal/index-impl/swiftSyntaxConditionalCompilationKind.js +3 -0
- package/dist/internal/index-impl/swiftSyntaxDeclarationName.js +19 -0
- package/dist/internal/index-impl/swiftSyntaxDeclarations.js +38 -0
- package/dist/internal/index-impl/swiftSyntaxEnumCaseNames.js +7 -0
- package/dist/internal/index-impl/swiftSyntaxFunctionLikeKind.js +8 -0
- package/dist/internal/index-impl/swiftSyntaxHasBody.js +3 -0
- package/dist/internal/index-impl/swiftSyntaxImportPath.js +14 -0
- package/dist/internal/index-impl/swiftSyntaxKind.js +11 -0
- package/dist/internal/index-impl/swiftSyntaxLiteralValue.js +5 -0
- package/dist/internal/index-impl/swiftSyntaxMacroKind.js +3 -0
- package/dist/internal/index-impl/swiftSyntaxModifierNames.js +16 -0
- package/dist/internal/index-impl/swiftSyntaxName.js +14 -0
- package/dist/internal/index-impl/swiftSyntaxNodeValue.js +7 -0
- package/dist/internal/index-impl/swiftSyntaxOperatorName.js +6 -0
- package/dist/internal/index-impl/swiftSyntaxPatternName.js +6 -0
- package/dist/internal/index-impl/swiftSyntaxPosition.js +27 -0
- package/dist/internal/index-impl/swiftSyntaxPositionKind.js +6 -0
- package/dist/internal/index-impl/swiftSyntaxProblemNode.js +13 -0
- package/dist/internal/index-impl/swiftSyntaxRecoveredKind.js +7 -0
- package/dist/internal/index-impl/swiftSyntaxRoot.js +15 -0
- package/dist/internal/index-impl/swiftSyntaxTypeDeclarationKind.js +7 -0
- package/dist/internal/index-impl/swiftSyntaxTypeDeclarationSymbolKind.js +8 -0
- package/dist/internal/index-impl/swiftSyntaxTypeName.js +19 -0
- package/dist/internal/index-impl/swiftSyntaxVariableNames.js +7 -0
- package/dist/internal/index-impl/syntaxDeclaration.js +18 -0
- package/dist/internal/index-impl/testSemanticSlice.js +43 -0
- package/dist/internal/index-impl/treeSitterDeclaration.js +24 -0
- package/dist/internal/index-impl/treeSitterFieldText.js +5 -0
- package/dist/internal/index-impl/truncatedAstLoss.js +16 -0
- package/dist/internal/index-impl/typeScriptDeclaration.js +14 -0
- package/dist/internal/index-impl/typeScriptKindName.js +6 -0
- package/dist/internal/index-impl/typeScriptNodeValue.js +4 -0
- package/dist/internal/index-impl/uniqueNativeProjectionDeclarations.js +9 -0
- package/dist/internal/index-impl/uniqueSemanticSliceNativeNodes.js +11 -0
- package/dist/internal/index-impl/uniqueSemanticSliceRegions.js +15 -0
- package/dist/internal/index-impl/uniqueSemanticSliceSpans.js +21 -0
- package/dist/internal/index-impl/unverifiedNativeAstLosses.js +16 -0
- package/dist/internal/index-impl/uriToPath.js +11 -0
- package/dist/internal/index-impl/visitCSharpRoslynNode.js +87 -0
- package/dist/internal/index-impl/visitClangAstNode.js +62 -0
- package/dist/internal/index-impl/visitGoAstNode.js +99 -0
- package/dist/internal/index-impl/visitJavaAstNode.js +73 -0
- package/dist/internal/index-impl/visitKotlinPsiNode.js +108 -0
- package/dist/internal/index-impl/visitPythonAstNode.js +47 -0
- package/dist/internal/index-impl/visitRustSynNode.js +62 -0
- package/dist/internal/index-impl/visitSwiftSyntaxNode.js +103 -0
- package/dist/internal/index-impl/visitSyntaxAstNode.js +46 -0
- package/dist/internal/index-impl/visitTreeSitterNode.js +145 -0
- package/dist/internal/index-impl/visitTypeScriptAstNode.js +45 -0
- package/dist/internal/index-impl/withExternalEmptyLoss.js +32 -0
- package/dist/internal/index-impl/withNativeImportReadiness.js +53 -0
- package/dist/internal/index-impl/writeSemanticSliceJson.js +7 -0
- package/dist/internal/index-impl/writeUniversalAstJson.js +8 -0
- package/dist/language-adapter-package-contracts.js +302 -0
- package/dist/native-import-coverage-matrix.js +237 -0
- package/dist/native-import-language-profiles.js +169 -0
- package/dist/native-import-utils.js +143 -0
- package/dist/native-js-ts-importers.js +85 -0
- package/dist/native-parser-ast-format-matrix.js +147 -0
- package/dist/native-parser-ast-format-profiles.js +271 -0
- package/dist/native-parser-feature-assessment.js +118 -0
- package/dist/native-parser-feature-coverage.js +268 -0
- package/dist/native-parser-feature-matrix.js +92 -0
- package/dist/native-parser-feature-rows.js +219 -0
- package/dist/native-region-scanner-core.js +179 -0
- package/dist/native-region-scanner-dynamic.js +259 -0
- package/dist/native-region-scanner-functional.js +191 -0
- package/dist/native-region-scanner-js.js +310 -0
- package/dist/native-region-scanner-main.js +301 -0
- package/dist/native-region-scanner.js +62 -0
- package/dist/native-source-maps.js +260 -0
- package/dist/native-source-preservation-scanner.js +266 -0
- package/dist/native-source-preservation-types.d.ts +77 -0
- package/dist/projection-readiness-helpers.js +166 -0
- package/dist/projection-readiness-matrix.js +122 -0
- package/dist/projection-target-loss-matrix.js +318 -0
- package/dist/semantic-import-contract-summary.js +188 -0
- package/dist/semantic-import-layers.js +320 -0
- package/dist/semantic-import-regions.js +181 -0
- package/dist/semantic-import-sidecar-admission-types.d.ts +61 -0
- package/dist/semantic-import-sidecar-entry.js +78 -0
- package/dist/semantic-import-sidecar-types.d.ts +275 -0
- package/dist/semantic-import-source-preservation.js +198 -0
- package/dist/universal-capability-matrix.js +280 -0
- package/dist/universal-dialect-layer.js +74 -0
- package/dist/universal-dialect-registry.js +204 -0
- package/dist/universal-dialect-utils.js +110 -0
- package/package.json +1 -1
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import{maxSemanticMergeReadiness,uniqueStrings}from'../../native-import-utils.js';
|
|
2
|
+
import{getNativeImportFeatureEvidencePolicy}from'./getNativeImportFeatureEvidencePolicy.js';import{nativeFeatureEvidenceRiskRank}from'./nativeFeatureEvidenceRiskRank.js';import{nativeImportFeatureEvidenceHasKey}from'./nativeImportFeatureEvidenceHasKey.js';import{nativeImportFeatureEvidenceIds}from'./nativeImportFeatureEvidenceIds.js';import{nativeImportFeatureEvidenceReasons}from'./nativeImportFeatureEvidenceReasons.js';import{normalizeNativeLossRecords}from'./normalizeNativeLossRecords.js';
|
|
3
|
+
export function summarizeNativeImportFeatureEvidence(losses = [], options = {}) {
|
|
4
|
+
const normalizedLosses = normalizeNativeLossRecords(losses);
|
|
5
|
+
const evidence = options.evidence ?? [];
|
|
6
|
+
const issues = [];
|
|
7
|
+
const byKind = {};
|
|
8
|
+
const byRisk = {};
|
|
9
|
+
const policyKinds = [];
|
|
10
|
+
let highestRisk = 'low';
|
|
11
|
+
let semanticMergeReadiness = 'ready';
|
|
12
|
+
|
|
13
|
+
for (const loss of normalizedLosses) {
|
|
14
|
+
const policy = getNativeImportFeatureEvidencePolicy(loss.kind);
|
|
15
|
+
if (!policy) continue;
|
|
16
|
+
byKind[policy.kind] = (byKind[policy.kind] ?? 0) + 1;
|
|
17
|
+
byRisk[policy.risk] = (byRisk[policy.risk] ?? 0) + 1;
|
|
18
|
+
if ((nativeFeatureEvidenceRiskRank[policy.risk] ?? 0) > (nativeFeatureEvidenceRiskRank[highestRisk] ?? 0)) {
|
|
19
|
+
highestRisk = policy.risk;
|
|
20
|
+
}
|
|
21
|
+
policyKinds.push(policy.kind);
|
|
22
|
+
semanticMergeReadiness = maxSemanticMergeReadiness(semanticMergeReadiness, policy.minimumReadiness);
|
|
23
|
+
const missingRequiredEvidence = policy.requiredEvidenceKeys.filter((key) => !nativeImportFeatureEvidenceHasKey(loss, evidence, key));
|
|
24
|
+
const presentRequiredEvidence = policy.requiredEvidenceKeys.filter((key) => !missingRequiredEvidence.includes(key));
|
|
25
|
+
const presentRecommendedEvidence = policy.recommendedEvidenceKeys.filter((key) => nativeImportFeatureEvidenceHasKey(loss, evidence, key));
|
|
26
|
+
if (missingRequiredEvidence.length) {
|
|
27
|
+
semanticMergeReadiness = maxSemanticMergeReadiness(semanticMergeReadiness, policy.missingEvidenceReadiness);
|
|
28
|
+
}
|
|
29
|
+
issues.push({
|
|
30
|
+
lossId: loss.id,
|
|
31
|
+
kind: loss.kind,
|
|
32
|
+
policyKind: policy.kind,
|
|
33
|
+
risk: policy.risk,
|
|
34
|
+
category: policy.category,
|
|
35
|
+
readiness: missingRequiredEvidence.length ? policy.missingEvidenceReadiness : policy.minimumReadiness,
|
|
36
|
+
missingRequiredEvidence,
|
|
37
|
+
presentRequiredEvidence,
|
|
38
|
+
presentRecommendedEvidence,
|
|
39
|
+
evidenceIds: nativeImportFeatureEvidenceIds(loss, evidence, policy)
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
const missingRequiredEvidence = issues.flatMap((issue) => issue.missingRequiredEvidence.map((key) => ({
|
|
44
|
+
lossId: issue.lossId,
|
|
45
|
+
kind: issue.kind,
|
|
46
|
+
policyKind: issue.policyKind,
|
|
47
|
+
evidenceKey: key
|
|
48
|
+
})));
|
|
49
|
+
return {
|
|
50
|
+
total: issues.length,
|
|
51
|
+
policyKinds: uniqueStrings(policyKinds),
|
|
52
|
+
byKind,
|
|
53
|
+
byRisk,
|
|
54
|
+
highestRisk: issues.length ? highestRisk : 'low',
|
|
55
|
+
semanticMergeReadiness,
|
|
56
|
+
missingRequiredEvidence,
|
|
57
|
+
issues,
|
|
58
|
+
reasons: nativeImportFeatureEvidenceReasons(issues)
|
|
59
|
+
};
|
|
60
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import{uniqueStrings}from'../../native-import-utils.js';
|
|
2
|
+
import{lossSeverityRank}from'./lossSeverityRank.js';import{nativeImportCategoryForLossKind}from'./nativeImportCategoryForLossKind.js';import{NativeImportReadinessBySeverity}from'./NativeImportReadinessBySeverity.js';import{nativeImportReadinessReasons}from'./nativeImportReadinessReasons.js';import{normalizeNativeLossRecords}from'./normalizeNativeLossRecords.js';import{summarizeNativeImportFeatureEvidence}from'./summarizeNativeImportFeatureEvidence.js';
|
|
3
|
+
export function summarizeNativeImportLosses(losses = [], options = {}) {
|
|
4
|
+
const normalizedLosses = normalizeNativeLossRecords(losses);
|
|
5
|
+
const bySeverity = { info: 0, warning: 0, error: 0 };
|
|
6
|
+
const byKind = {};
|
|
7
|
+
const blockingLossIds = [];
|
|
8
|
+
const reviewLossIds = [];
|
|
9
|
+
const informationalLossIds = [];
|
|
10
|
+
let highestSeverity = 'none';
|
|
11
|
+
|
|
12
|
+
for (const loss of normalizedLosses) {
|
|
13
|
+
bySeverity[loss.severity] += 1;
|
|
14
|
+
byKind[loss.kind] = (byKind[loss.kind] ?? 0) + 1;
|
|
15
|
+
if (lossSeverityRank[loss.severity] > lossSeverityRank[highestSeverity]) {
|
|
16
|
+
highestSeverity = loss.severity;
|
|
17
|
+
}
|
|
18
|
+
if (loss.severity === 'error') blockingLossIds.push(loss.id);
|
|
19
|
+
else if (loss.severity === 'warning') reviewLossIds.push(loss.id);
|
|
20
|
+
else informationalLossIds.push(loss.id);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
const failedEvidenceIds = (options.evidence ?? [])
|
|
24
|
+
.filter((record) => record?.status === 'failed')
|
|
25
|
+
.map((record) => record.id)
|
|
26
|
+
.filter(Boolean);
|
|
27
|
+
const exactAst = Boolean(options.exactAst) && normalizedLosses.length === 0;
|
|
28
|
+
const categories = uniqueStrings([
|
|
29
|
+
...(exactAst ? ['exactAstImport'] : []),
|
|
30
|
+
...normalizedLosses.map((loss) => nativeImportCategoryForLossKind(loss.kind))
|
|
31
|
+
]);
|
|
32
|
+
const semanticMergeReadiness = failedEvidenceIds.length
|
|
33
|
+
? 'blocked'
|
|
34
|
+
: NativeImportReadinessBySeverity[highestSeverity];
|
|
35
|
+
const readinessReasons = nativeImportReadinessReasons({
|
|
36
|
+
exactAst,
|
|
37
|
+
failedEvidenceIds,
|
|
38
|
+
blockingLossIds,
|
|
39
|
+
reviewLossIds,
|
|
40
|
+
informationalLossIds
|
|
41
|
+
});
|
|
42
|
+
const featureEvidence = summarizeNativeImportFeatureEvidence(normalizedLosses, {
|
|
43
|
+
evidence: options.evidence
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
return {
|
|
47
|
+
total: normalizedLosses.length,
|
|
48
|
+
hasLosses: normalizedLosses.length > 0,
|
|
49
|
+
exactAst,
|
|
50
|
+
highestSeverity,
|
|
51
|
+
semanticMergeReadiness,
|
|
52
|
+
readinessReasons,
|
|
53
|
+
categories,
|
|
54
|
+
bySeverity,
|
|
55
|
+
byKind,
|
|
56
|
+
blockingLossIds,
|
|
57
|
+
reviewLossIds,
|
|
58
|
+
informationalLossIds,
|
|
59
|
+
failedEvidenceIds,
|
|
60
|
+
featureEvidence,
|
|
61
|
+
parser: options.parser,
|
|
62
|
+
scanKind: options.scanKind,
|
|
63
|
+
semanticStatus: options.semanticStatus
|
|
64
|
+
};
|
|
65
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export function summarizeProjectSourcePreservation(imports) {
|
|
2
|
+
const records = imports
|
|
3
|
+
.map((result) => result.metadata?.sourcePreservation ?? result.nativeSource?.metadata?.sourcePreservation ?? result.nativeAst?.metadata?.sourcePreservation)
|
|
4
|
+
.filter(Boolean);
|
|
5
|
+
return {
|
|
6
|
+
total: records.length,
|
|
7
|
+
exactSourceAvailable: records.filter((record) => record.summary?.exactSourceAvailable).length,
|
|
8
|
+
sourceBytes: records.reduce((sum, record) => sum + (record.sourceBytes ?? 0), 0),
|
|
9
|
+
tokens: records.reduce((sum, record) => sum + (record.summary?.tokens ?? record.tokens?.length ?? 0), 0),
|
|
10
|
+
trivia: records.reduce((sum, record) => sum + (record.summary?.trivia ?? record.trivia?.length ?? 0), 0),
|
|
11
|
+
directives: records.reduce((sum, record) => sum + (record.summary?.directives ?? record.directives?.length ?? 0), 0),
|
|
12
|
+
truncated: records.some((record) => record.summary?.truncated === true),
|
|
13
|
+
ids: records.map((record) => record.id).filter(Boolean)
|
|
14
|
+
};
|
|
15
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export function swiftEvidenceSummary(value) {
|
|
2
|
+
if (!value) return undefined;
|
|
3
|
+
if (Array.isArray(value)) return { entryCount: value.length };
|
|
4
|
+
if (typeof value === 'string') return { value };
|
|
5
|
+
if (typeof value === 'object') {
|
|
6
|
+
const summary = {};
|
|
7
|
+
if (typeof value.hash === 'string') summary.hash = value.hash;
|
|
8
|
+
if (typeof value.solver === 'string') summary.solver = value.solver;
|
|
9
|
+
if (Array.isArray(value.entries)) summary.entryCount = value.entries.length;
|
|
10
|
+
if (Array.isArray(value.symbols)) summary.symbolCount = value.symbols.length;
|
|
11
|
+
if (Array.isArray(value.references)) summary.referenceCount = value.references.length;
|
|
12
|
+
if (Array.isArray(value.types)) summary.typeCount = value.types.length;
|
|
13
|
+
if (Array.isArray(value.diagnostics)) summary.diagnosticCount = value.diagnostics.length;
|
|
14
|
+
if (Array.isArray(value.macros)) summary.macroCount = value.macros.length;
|
|
15
|
+
if (Array.isArray(value.packages)) summary.packageCount = value.packages.length;
|
|
16
|
+
return Object.keys(summary).length ? summary : { present: true };
|
|
17
|
+
}
|
|
18
|
+
return { present: true };
|
|
19
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import{idFragment}from'../../native-import-utils.js';
|
|
2
|
+
import{swiftEvidenceSummary}from'./swiftEvidenceSummary.js';
|
|
3
|
+
export function swiftGeneratedCodeLoss(input, nodeId, span, options = {}, metadata = {}) {
|
|
4
|
+
return {
|
|
5
|
+
id: `loss_${idFragment(nodeId ?? input.sourcePath ?? 'swift')}_swift_generated_code`,
|
|
6
|
+
severity: 'warning',
|
|
7
|
+
phase: 'parse',
|
|
8
|
+
sourceFormat: input.language,
|
|
9
|
+
kind: 'generatedCode',
|
|
10
|
+
message: 'Swift generated-source marker was imported; generated member provenance and source ownership require host evidence.',
|
|
11
|
+
span,
|
|
12
|
+
nodeId,
|
|
13
|
+
metadata: {
|
|
14
|
+
parser: options.parser,
|
|
15
|
+
astFormat: options.astFormat,
|
|
16
|
+
macroExpansionEvidence: swiftEvidenceSummary(options.macroExpansionEvidence),
|
|
17
|
+
...metadata
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import{swiftGeneratedSourcePath}from'./swiftGeneratedSourcePath.js';import{swiftSyntaxDeclarationName}from'./swiftSyntaxDeclarationName.js';
|
|
2
|
+
export function swiftGeneratedCodeMarker(node, kind) {
|
|
3
|
+
if (node.generated || node.isGenerated) return true;
|
|
4
|
+
const path = String(node.filePath ?? node.path ?? node.sourcePath ?? '');
|
|
5
|
+
if (swiftGeneratedSourcePath(path)) return true;
|
|
6
|
+
if (kind === 'Attribute') {
|
|
7
|
+
const name = swiftSyntaxDeclarationName(node);
|
|
8
|
+
if (name && /(^|\.)(Generated|CompilerGenerated|_spi)Attribute?$/.test(name)) return true;
|
|
9
|
+
}
|
|
10
|
+
return false;
|
|
11
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import{uniqueStrings}from'../../native-import-utils.js';
|
|
2
|
+
import{swiftSyntaxName}from'./swiftSyntaxName.js';
|
|
3
|
+
export function swiftSyntaxAttributeNames(node) {
|
|
4
|
+
const attributes = node.attributes ?? node.attributeList;
|
|
5
|
+
if (!attributes) return [];
|
|
6
|
+
if (Array.isArray(attributes)) {
|
|
7
|
+
return uniqueStrings(attributes.map((entry) => typeof entry === 'string' ? entry : swiftSyntaxName(entry.attributeName ?? entry.name ?? entry)).filter(Boolean));
|
|
8
|
+
}
|
|
9
|
+
return [];
|
|
10
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import{ignoredSwiftSyntaxField}from'./ignoredSwiftSyntaxField.js';import{isSwiftSyntaxNode}from'./isSwiftSyntaxNode.js';import{swiftSyntaxChildWithParent}from'./swiftSyntaxChildWithParent.js';import{swiftSyntaxKind}from'./swiftSyntaxKind.js';
|
|
2
|
+
export function swiftSyntaxChildEntries(node, kind = swiftSyntaxKind(node)) {
|
|
3
|
+
const fieldNames = Object.keys(node).filter((key) => !ignoredSwiftSyntaxField(key));
|
|
4
|
+
const entries = [];
|
|
5
|
+
for (const field of fieldNames) {
|
|
6
|
+
const value = node[field];
|
|
7
|
+
if (Array.isArray(value)) {
|
|
8
|
+
entries.push([field, value.map((entry) => swiftSyntaxChildWithParent(entry, kind, field))]);
|
|
9
|
+
continue;
|
|
10
|
+
}
|
|
11
|
+
if (value && typeof value === 'object') {
|
|
12
|
+
entries.push([field, swiftSyntaxChildWithParent(value, kind, field)]);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
return entries.filter(([, value]) => Array.isArray(value)
|
|
16
|
+
? value.some(isSwiftSyntaxNode)
|
|
17
|
+
: isSwiftSyntaxNode(value));
|
|
18
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import{isSwiftSyntaxNode}from'./isSwiftSyntaxNode.js';
|
|
2
|
+
export function swiftSyntaxChildWithParent(entry, parentKind, parentField) {
|
|
3
|
+
if (!entry || typeof entry !== 'object' || Array.isArray(entry)) return entry;
|
|
4
|
+
if (!isSwiftSyntaxNode(entry)) return entry;
|
|
5
|
+
return { parentKind, parentField, ...entry };
|
|
6
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import{swiftSyntaxKind}from'./swiftSyntaxKind.js';import{swiftSyntaxName}from'./swiftSyntaxName.js';import{swiftSyntaxOperatorName}from'./swiftSyntaxOperatorName.js';import{swiftSyntaxPatternName}from'./swiftSyntaxPatternName.js';import{swiftSyntaxTypeName}from'./swiftSyntaxTypeName.js';
|
|
2
|
+
export function swiftSyntaxDeclarationName(node, kind = swiftSyntaxKind(node)) {
|
|
3
|
+
if (!node || typeof node !== 'object') return undefined;
|
|
4
|
+
if (kind === 'InitializerDecl') return 'init';
|
|
5
|
+
if (kind === 'DeinitializerDecl') return 'deinit';
|
|
6
|
+
if (kind === 'SubscriptDecl') return 'subscript';
|
|
7
|
+
if (kind === 'ExtensionDecl') {
|
|
8
|
+
const extended = swiftSyntaxTypeName(node.extendedType ?? node.type ?? node.name);
|
|
9
|
+
return extended ? `extension ${extended}` : undefined;
|
|
10
|
+
}
|
|
11
|
+
if (kind === 'OperatorDecl') return swiftSyntaxOperatorName(node, kind);
|
|
12
|
+
for (const key of ['identifier', 'name', 'simpleName', 'typeName', 'id']) {
|
|
13
|
+
const name = swiftSyntaxName(node[key]);
|
|
14
|
+
if (name) return name;
|
|
15
|
+
}
|
|
16
|
+
const patternName = swiftSyntaxPatternName(node.pattern);
|
|
17
|
+
if (patternName) return patternName;
|
|
18
|
+
return undefined;
|
|
19
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import{declarationRecord}from'./declarationRecord.js';import{nativeNodeId}from'./nativeNodeId.js';import{swiftSyntaxDeclarationName}from'./swiftSyntaxDeclarationName.js';import{swiftSyntaxEnumCaseNames}from'./swiftSyntaxEnumCaseNames.js';import{swiftSyntaxFunctionLikeKind}from'./swiftSyntaxFunctionLikeKind.js';import{swiftSyntaxHasBody}from'./swiftSyntaxHasBody.js';import{swiftSyntaxImportPath}from'./swiftSyntaxImportPath.js';import{swiftSyntaxOperatorName}from'./swiftSyntaxOperatorName.js';import{swiftSyntaxTypeDeclarationKind}from'./swiftSyntaxTypeDeclarationKind.js';import{swiftSyntaxTypeDeclarationSymbolKind}from'./swiftSyntaxTypeDeclarationSymbolKind.js';import{swiftSyntaxVariableNames}from'./swiftSyntaxVariableNames.js';
|
|
2
|
+
export function swiftSyntaxDeclarations(node, kind, nativeNodeId, input) {
|
|
3
|
+
if (kind === 'ImportDecl') {
|
|
4
|
+
const name = swiftSyntaxImportPath(node);
|
|
5
|
+
return name ? [declarationRecord(input, nativeNodeId, name, 'module', 'import')] : [];
|
|
6
|
+
}
|
|
7
|
+
if (swiftSyntaxTypeDeclarationKind(kind)) {
|
|
8
|
+
const name = swiftSyntaxDeclarationName(node, kind);
|
|
9
|
+
return name ? [declarationRecord(input, nativeNodeId, name, swiftSyntaxTypeDeclarationSymbolKind(kind), 'definition')] : [];
|
|
10
|
+
}
|
|
11
|
+
if (kind === 'ExtensionDecl') {
|
|
12
|
+
const name = swiftSyntaxDeclarationName(node, kind);
|
|
13
|
+
return name ? [declarationRecord(input, nativeNodeId, name, 'type', 'definition')] : [];
|
|
14
|
+
}
|
|
15
|
+
if (kind === 'TypeAliasDecl' || kind === 'AssociatedTypeDecl') {
|
|
16
|
+
const name = swiftSyntaxDeclarationName(node, kind);
|
|
17
|
+
return name ? [declarationRecord(input, nativeNodeId, name, 'type', 'definition')] : [];
|
|
18
|
+
}
|
|
19
|
+
if (swiftSyntaxFunctionLikeKind(kind)) {
|
|
20
|
+
const name = swiftSyntaxDeclarationName(node, kind) ?? swiftSyntaxOperatorName(node, kind);
|
|
21
|
+
return name ? [declarationRecord(input, nativeNodeId, name, kind === 'FunctionDecl' ? 'function' : 'method', swiftSyntaxHasBody(node) ? 'definition' : 'declaration')] : [];
|
|
22
|
+
}
|
|
23
|
+
if (kind === 'VariableDecl') {
|
|
24
|
+
return swiftSyntaxVariableNames(node).map((name) => declarationRecord(input, nativeNodeId, name, 'property', 'definition'));
|
|
25
|
+
}
|
|
26
|
+
if (kind === 'PatternBinding' && node.parentKind === 'VariableDecl') {
|
|
27
|
+
const name = swiftSyntaxDeclarationName(node, kind);
|
|
28
|
+
return name ? [declarationRecord(input, nativeNodeId, name, 'property', 'definition')] : [];
|
|
29
|
+
}
|
|
30
|
+
if (kind === 'EnumCaseDecl') {
|
|
31
|
+
return swiftSyntaxEnumCaseNames(node).map((name) => declarationRecord(input, nativeNodeId, name, 'enumMember', 'definition'));
|
|
32
|
+
}
|
|
33
|
+
if (kind === 'EnumCaseElement') {
|
|
34
|
+
const name = swiftSyntaxDeclarationName(node, kind);
|
|
35
|
+
return name ? [declarationRecord(input, nativeNodeId, name, 'enumMember', 'definition')] : [];
|
|
36
|
+
}
|
|
37
|
+
return [];
|
|
38
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import{swiftSyntaxDeclarationName}from'./swiftSyntaxDeclarationName.js';
|
|
2
|
+
export function swiftSyntaxEnumCaseNames(node) {
|
|
3
|
+
const elements = node.elements ?? node.caseElements ?? node.cases;
|
|
4
|
+
if (Array.isArray(elements)) return elements.map((entry) => swiftSyntaxDeclarationName(entry, 'EnumCaseElement')).filter(Boolean);
|
|
5
|
+
const name = swiftSyntaxDeclarationName(node);
|
|
6
|
+
return name ? [name] : [];
|
|
7
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import{swiftSyntaxName}from'./swiftSyntaxName.js';
|
|
2
|
+
export function swiftSyntaxImportPath(node) {
|
|
3
|
+
if (!node || typeof node !== 'object') return undefined;
|
|
4
|
+
const path = node.importPath ?? node.path ?? node.modulePath ?? node.name;
|
|
5
|
+
if (typeof path === 'string') return path;
|
|
6
|
+
if (Array.isArray(path)) {
|
|
7
|
+
return path.map((entry) => swiftSyntaxName(entry.name ?? entry.identifier ?? entry)).filter(Boolean).join('.');
|
|
8
|
+
}
|
|
9
|
+
if (path && typeof path === 'object') {
|
|
10
|
+
if (Array.isArray(path.components)) return path.components.map((entry) => swiftSyntaxName(entry.name ?? entry.identifier ?? entry)).filter(Boolean).join('.');
|
|
11
|
+
return swiftSyntaxName(path);
|
|
12
|
+
}
|
|
13
|
+
return undefined;
|
|
14
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import{normalizeSwiftSyntaxKind}from'./normalizeSwiftSyntaxKind.js';
|
|
2
|
+
export function swiftSyntaxKind(node) {
|
|
3
|
+
if (!node || typeof node !== 'object') return undefined;
|
|
4
|
+
const declared = node.kind ?? node.syntaxKind ?? node.SyntaxKind ?? node._syntaxKind ?? node._type ?? node.type ?? node.nodeType;
|
|
5
|
+
if (typeof declared === 'string') return normalizeSwiftSyntaxKind(declared);
|
|
6
|
+
if (Array.isArray(node.statements) || Array.isArray(node.members) || Array.isArray(node.declarations)) return 'SourceFile';
|
|
7
|
+
if (node.identifier && (node.memberBlock || node.members || node.genericParameterClause || node.inheritanceClause)) return 'ClassDecl';
|
|
8
|
+
if (node.signature && node.body) return 'FunctionDecl';
|
|
9
|
+
if (node.importPath || node.path) return 'ImportDecl';
|
|
10
|
+
return undefined;
|
|
11
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import{uniqueStrings}from'../../native-import-utils.js';
|
|
2
|
+
import{swiftSyntaxName}from'./swiftSyntaxName.js';
|
|
3
|
+
export function swiftSyntaxModifierNames(node) {
|
|
4
|
+
const modifiers = node.modifiers ?? node.Modifiers;
|
|
5
|
+
if (!modifiers) return [];
|
|
6
|
+
if (Array.isArray(modifiers)) {
|
|
7
|
+
return uniqueStrings(modifiers.map((entry) => typeof entry === 'string' ? entry : swiftSyntaxName(entry.name ?? entry.modifier ?? entry)).filter(Boolean));
|
|
8
|
+
}
|
|
9
|
+
if (typeof modifiers === 'string') return uniqueStrings(modifiers.split(/\s+/).filter(Boolean));
|
|
10
|
+
if (typeof modifiers === 'object') {
|
|
11
|
+
return uniqueStrings(Object.entries(modifiers)
|
|
12
|
+
.filter(([, enabled]) => enabled === true)
|
|
13
|
+
.map(([key]) => key));
|
|
14
|
+
}
|
|
15
|
+
return [];
|
|
16
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export function swiftSyntaxName(value) {
|
|
2
|
+
if (!value) return undefined;
|
|
3
|
+
if (typeof value === 'string') return value;
|
|
4
|
+
if (typeof value.text === 'string') return value.text;
|
|
5
|
+
if (typeof value.trimmedDescription === 'string') return value.trimmedDescription;
|
|
6
|
+
if (typeof value.description === 'string' && !value.description.includes('[object Object]')) return value.description.trim();
|
|
7
|
+
if (typeof value.identifier === 'string') return value.identifier;
|
|
8
|
+
if (typeof value.name === 'string') return value.name;
|
|
9
|
+
if (typeof value.value === 'string') return value.value;
|
|
10
|
+
if (value.tokenKind && typeof value.tokenKind === 'object') return swiftSyntaxName(value.tokenKind);
|
|
11
|
+
if (value.identifier && value.identifier !== value) return swiftSyntaxName(value.identifier);
|
|
12
|
+
if (value.name && value.name !== value) return swiftSyntaxName(value.name);
|
|
13
|
+
return undefined;
|
|
14
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import{swiftSyntaxDeclarationName}from'./swiftSyntaxDeclarationName.js';import{swiftSyntaxImportPath}from'./swiftSyntaxImportPath.js';import{swiftSyntaxKind}from'./swiftSyntaxKind.js';import{swiftSyntaxLiteralValue}from'./swiftSyntaxLiteralValue.js';import{swiftSyntaxTypeName}from'./swiftSyntaxTypeName.js';
|
|
2
|
+
export function swiftSyntaxNodeValue(node) {
|
|
3
|
+
return swiftSyntaxDeclarationName(node, swiftSyntaxKind(node))
|
|
4
|
+
?? swiftSyntaxImportPath(node)
|
|
5
|
+
?? swiftSyntaxTypeName(node.type ?? node.returnClause?.type ?? node.extendedType)
|
|
6
|
+
?? swiftSyntaxLiteralValue(node);
|
|
7
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import{swiftSyntaxDeclarationName}from'./swiftSyntaxDeclarationName.js';import{swiftSyntaxName}from'./swiftSyntaxName.js';
|
|
2
|
+
export function swiftSyntaxOperatorName(node, kind) {
|
|
3
|
+
if (kind === 'PrecedenceGroupDecl') return swiftSyntaxDeclarationName(node) ?? 'precedencegroup';
|
|
4
|
+
const operatorToken = swiftSyntaxName(node.operatorIdentifier ?? node.operatorToken ?? node.name);
|
|
5
|
+
return operatorToken ? `operator ${operatorToken}` : undefined;
|
|
6
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import{swiftSyntaxName}from'./swiftSyntaxName.js';
|
|
2
|
+
export function swiftSyntaxPatternName(pattern) {
|
|
3
|
+
if (!pattern) return undefined;
|
|
4
|
+
if (typeof pattern === 'string') return pattern;
|
|
5
|
+
return swiftSyntaxName(pattern.identifier ?? pattern.name ?? pattern.boundName ?? pattern.pattern ?? pattern);
|
|
6
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export function swiftSyntaxPosition(value, options = {}) {
|
|
2
|
+
if (value === undefined || value === null) return undefined;
|
|
3
|
+
if (typeof value === 'object') {
|
|
4
|
+
const position = value.position ?? value.location ?? value;
|
|
5
|
+
const line = position.line ?? position.Line;
|
|
6
|
+
const column = position.column ?? position.character ?? position.utf8Column ?? position.Column;
|
|
7
|
+
if (typeof line === 'number') {
|
|
8
|
+
return {
|
|
9
|
+
path: position.path ?? position.filePath ?? position.file,
|
|
10
|
+
line,
|
|
11
|
+
column: typeof column === 'number' ? column : undefined
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
const resolver = typeof options.positionResolver === 'function'
|
|
16
|
+
? options.positionResolver
|
|
17
|
+
: typeof options.lineMap?.position === 'function'
|
|
18
|
+
? options.lineMap.position.bind(options.lineMap)
|
|
19
|
+
: typeof options.sourceLocationConverter?.location === 'function'
|
|
20
|
+
? options.sourceLocationConverter.location.bind(options.sourceLocationConverter)
|
|
21
|
+
: undefined;
|
|
22
|
+
if (resolver) {
|
|
23
|
+
const resolved = resolver(value);
|
|
24
|
+
if (resolved !== value) return swiftSyntaxPosition(resolved, options);
|
|
25
|
+
}
|
|
26
|
+
return undefined;
|
|
27
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export function swiftSyntaxPositionKind(node) {
|
|
2
|
+
if (node.sourceRange || node.range) return 'source-range';
|
|
3
|
+
if (node.position || node.absolutePosition) return 'absolute-position';
|
|
4
|
+
if (typeof node.startLine === 'number' || typeof node.line === 'number') return 'line-column-fields';
|
|
5
|
+
return undefined;
|
|
6
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export function swiftSyntaxProblemNode(node, kind) {
|
|
2
|
+
return Boolean(
|
|
3
|
+
node.isMissing
|
|
4
|
+
|| node.hasError
|
|
5
|
+
|| node.containsDiagnostics
|
|
6
|
+
|| node.containsSkippedText
|
|
7
|
+
|| node.presence === 'missing'
|
|
8
|
+
|| kind === 'UnexpectedNodes'
|
|
9
|
+
|| kind === 'MissingToken'
|
|
10
|
+
|| kind === 'SkippedToken'
|
|
11
|
+
|| kind === 'Error'
|
|
12
|
+
);
|
|
13
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import{isSwiftSyntaxNode}from'./isSwiftSyntaxNode.js';
|
|
2
|
+
export function swiftSyntaxRoot(value) {
|
|
3
|
+
if (!value || typeof value !== 'object') return undefined;
|
|
4
|
+
if (isSwiftSyntaxNode(value)) return value;
|
|
5
|
+
if (isSwiftSyntaxNode(value.ast)) return value.ast;
|
|
6
|
+
if (isSwiftSyntaxNode(value.root)) return value.root;
|
|
7
|
+
if (isSwiftSyntaxNode(value.rootNode)) return value.rootNode;
|
|
8
|
+
if (isSwiftSyntaxNode(value.sourceFile)) return value.sourceFile;
|
|
9
|
+
if (isSwiftSyntaxNode(value.sourceFileSyntax)) return value.sourceFileSyntax;
|
|
10
|
+
if (isSwiftSyntaxNode(value.tree)) return swiftSyntaxRoot(value.tree);
|
|
11
|
+
if (Array.isArray(value.statements) || Array.isArray(value.members) || Array.isArray(value.declarations)) {
|
|
12
|
+
return { kind: 'SourceFile', ...value };
|
|
13
|
+
}
|
|
14
|
+
return undefined;
|
|
15
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export function swiftSyntaxTypeDeclarationSymbolKind(kind) {
|
|
2
|
+
if (kind === 'ClassDecl') return 'class';
|
|
3
|
+
if (kind === 'StructDecl') return 'struct';
|
|
4
|
+
if (kind === 'EnumDecl') return 'enum';
|
|
5
|
+
if (kind === 'ProtocolDecl') return 'protocol';
|
|
6
|
+
if (kind === 'ActorDecl') return 'class';
|
|
7
|
+
return 'type';
|
|
8
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import{swiftSyntaxName}from'./swiftSyntaxName.js';
|
|
2
|
+
export function swiftSyntaxTypeName(value) {
|
|
3
|
+
if (!value) return undefined;
|
|
4
|
+
if (typeof value === 'string') return value;
|
|
5
|
+
if (typeof value.trimmedDescription === 'string') return value.trimmedDescription;
|
|
6
|
+
if (typeof value.description === 'string' && !value.description.includes('[object Object]')) return value.description.trim();
|
|
7
|
+
if (typeof value.name === 'string') return value.name;
|
|
8
|
+
if (typeof value.text === 'string') return value.text;
|
|
9
|
+
if (value.baseType) {
|
|
10
|
+
const base = swiftSyntaxTypeName(value.baseType);
|
|
11
|
+
return base && value.name ? `${base}.${swiftSyntaxName(value.name)}` : base;
|
|
12
|
+
}
|
|
13
|
+
if (value.argumentList && Array.isArray(value.argumentList)) {
|
|
14
|
+
const base = swiftSyntaxName(value.name) ?? swiftSyntaxTypeName(value.baseName);
|
|
15
|
+
const args = value.argumentList.map((entry) => swiftSyntaxTypeName(entry.type ?? entry)).filter(Boolean);
|
|
16
|
+
return base ? `${base}<${args.join(', ')}>` : undefined;
|
|
17
|
+
}
|
|
18
|
+
return swiftSyntaxName(value);
|
|
19
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import{swiftSyntaxDeclarationName}from'./swiftSyntaxDeclarationName.js';import{swiftSyntaxPatternName}from'./swiftSyntaxPatternName.js';
|
|
2
|
+
export function swiftSyntaxVariableNames(node) {
|
|
3
|
+
const bindings = node.bindings ?? node.bindingSpecifier?.bindings ?? node.patternBindings;
|
|
4
|
+
if (Array.isArray(bindings)) return bindings.map((binding) => swiftSyntaxPatternName(binding.pattern ?? binding)).filter(Boolean);
|
|
5
|
+
const name = swiftSyntaxPatternName(node.pattern) ?? swiftSyntaxDeclarationName(node);
|
|
6
|
+
return name ? [name] : [];
|
|
7
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import{declarationRecord}from'./declarationRecord.js';import{namedDeclaration}from'./namedDeclaration.js';import{nativeNodeId}from'./nativeNodeId.js';
|
|
2
|
+
export function syntaxDeclaration(node, nativeNodeId, input) {
|
|
3
|
+
const kind = String(node.type ?? node.kind ?? '');
|
|
4
|
+
if (kind === 'ImportDeclaration') {
|
|
5
|
+
const name = node.source?.value;
|
|
6
|
+
if (typeof name === 'string') return declarationRecord(input, nativeNodeId, name, 'module', 'import');
|
|
7
|
+
}
|
|
8
|
+
if (kind === 'ExportNamedDeclaration' || kind === 'ExportAllDeclaration') {
|
|
9
|
+
const name = node.source?.value;
|
|
10
|
+
if (typeof name === 'string') return declarationRecord(input, nativeNodeId, name, 'module', 'export');
|
|
11
|
+
}
|
|
12
|
+
if (kind === 'FunctionDeclaration') return namedDeclaration(input, nativeNodeId, node.id, 'function');
|
|
13
|
+
if (kind === 'ClassDeclaration') return namedDeclaration(input, nativeNodeId, node.id, 'class');
|
|
14
|
+
if (kind === 'TSInterfaceDeclaration' || kind === 'InterfaceDeclaration') return namedDeclaration(input, nativeNodeId, node.id, 'interface');
|
|
15
|
+
if (kind === 'TSTypeAliasDeclaration' || kind === 'TypeAliasDeclaration') return namedDeclaration(input, nativeNodeId, node.id, 'type');
|
|
16
|
+
if (kind === 'VariableDeclarator') return namedDeclaration(input, nativeNodeId, node.id, 'variable');
|
|
17
|
+
return undefined;
|
|
18
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import{idFragment,maxSemanticMergeReadiness}from'../../native-import-utils.js';
|
|
2
|
+
import{semanticSliceAssertion}from'./semanticSliceAssertion.js';import{semanticSliceSourceHashAssertions}from'./semanticSliceSourceHashAssertions.js';
|
|
3
|
+
export function testSemanticSlice(slice, options = {}) {
|
|
4
|
+
const assertions = [];
|
|
5
|
+
assertions.push(semanticSliceAssertion('kind', slice?.kind === 'frontier.lang.semanticSlice', 'Input is a Frontier semantic slice.'));
|
|
6
|
+
assertions.push(semanticSliceAssertion('entryRefsResolved', (slice?.unresolvedEntryRefs?.length ?? 0) === 0, 'All requested semantic entry refs resolved.', {
|
|
7
|
+
unresolvedEntryRefs: slice?.unresolvedEntryRefs ?? []
|
|
8
|
+
}));
|
|
9
|
+
assertions.push(semanticSliceAssertion('nonEmptySelection', (slice?.symbols?.length ?? 0) + (slice?.ownershipRegions?.length ?? 0) + (slice?.nativeNodes?.length ?? 0) > 0, 'Slice selected at least one symbol, ownership region, or native node.'));
|
|
10
|
+
assertions.push(semanticSliceAssertion('sourceMapLinks', options.requireSourceMapLinks === false || (slice?.sourceMapLinks?.length ?? 0) > 0, 'Slice has source-map links or the requirement was disabled.'));
|
|
11
|
+
assertions.push(semanticSliceAssertion('conflictKeys', (slice?.mergeAdmission?.conflictKeys?.length ?? 0) > 0, 'Slice exposes merge-admission conflict keys.'));
|
|
12
|
+
const sourceHashAssertions = semanticSliceSourceHashAssertions(slice, options.currentSources);
|
|
13
|
+
assertions.push(...sourceHashAssertions);
|
|
14
|
+
const failed = assertions.filter((assertion) => assertion.status === 'failed');
|
|
15
|
+
const warnings = assertions.filter((assertion) => assertion.status === 'warning');
|
|
16
|
+
const readiness = failed.length
|
|
17
|
+
? 'blocked'
|
|
18
|
+
: maxSemanticMergeReadiness(slice?.mergeAdmission?.readiness ?? slice?.summary?.readiness ?? 'ready', warnings.length ? 'needs-review' : 'ready');
|
|
19
|
+
return {
|
|
20
|
+
kind: 'frontier.lang.semanticSliceTestResult',
|
|
21
|
+
version: 1,
|
|
22
|
+
id: options.id ?? `semantic_slice_test_${idFragment(slice?.id ?? 'slice')}`,
|
|
23
|
+
generatedAt: options.generatedAt ?? Date.now(),
|
|
24
|
+
sliceId: slice?.id,
|
|
25
|
+
status: failed.length ? 'failed' : warnings.length ? 'needs-review' : 'passed',
|
|
26
|
+
readiness,
|
|
27
|
+
assertions,
|
|
28
|
+
summary: {
|
|
29
|
+
assertions: assertions.length,
|
|
30
|
+
passed: assertions.filter((assertion) => assertion.status === 'passed').length,
|
|
31
|
+
warnings: warnings.length,
|
|
32
|
+
failed: failed.length,
|
|
33
|
+
sourceHashChecks: sourceHashAssertions.length,
|
|
34
|
+
symbols: slice?.summary?.symbols ?? slice?.symbols?.length ?? 0,
|
|
35
|
+
ownershipRegions: slice?.summary?.ownershipRegions ?? slice?.ownershipRegions?.length ?? 0,
|
|
36
|
+
sourceMapLinks: slice?.summary?.sourceMapLinks ?? slice?.sourceMapLinks?.length ?? 0
|
|
37
|
+
},
|
|
38
|
+
metadata: {
|
|
39
|
+
sliceReadiness: slice?.mergeAdmission?.readiness ?? slice?.summary?.readiness,
|
|
40
|
+
...options.metadata
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
}
|