@shapeshift-labs/frontier-lang-compiler 0.2.40 → 0.2.42
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 +100 -0
- 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 +289 -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 +9 -9
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import{nativeImportFeatureEvidencePolicy}from'./nativeImportFeatureEvidencePolicy.js';
|
|
2
|
+
export const NativeImportFeatureEvidencePolicies = Object.freeze({
|
|
3
|
+
macroExpansion: nativeImportFeatureEvidencePolicy('macroExpansion', {
|
|
4
|
+
category: 'macroExpansion',
|
|
5
|
+
risk: 'high',
|
|
6
|
+
minimumReadiness: 'needs-review',
|
|
7
|
+
requiredEvidenceKeys: ['macroDefinitionsHash', 'expandedSourceHash'],
|
|
8
|
+
recommendedEvidenceKeys: ['expansionMapId', 'sourceMapId', 'macroCallSites'],
|
|
9
|
+
notes: ['Macro-expanded code must retain a link from generated output back to macro call sites before semantic merges can be trusted.']
|
|
10
|
+
}),
|
|
11
|
+
macroHygiene: nativeImportFeatureEvidencePolicy('macroHygiene', {
|
|
12
|
+
category: 'macroExpansion',
|
|
13
|
+
risk: 'critical',
|
|
14
|
+
minimumReadiness: 'needs-review',
|
|
15
|
+
missingEvidenceReadiness: 'blocked',
|
|
16
|
+
requiredEvidenceKeys: ['hygieneContextHash', 'bindingMapId'],
|
|
17
|
+
recommendedEvidenceKeys: ['expansionMapId', 'captureSetHash'],
|
|
18
|
+
notes: ['Hygiene-sensitive macros can change binding identity even when emitted text looks equivalent.']
|
|
19
|
+
}),
|
|
20
|
+
preprocessor: nativeImportFeatureEvidencePolicy('preprocessor', {
|
|
21
|
+
category: 'preprocessor',
|
|
22
|
+
risk: 'high',
|
|
23
|
+
minimumReadiness: 'needs-review',
|
|
24
|
+
requiredEvidenceKeys: ['preprocessedOutputHash', 'definesHash'],
|
|
25
|
+
recommendedEvidenceKeys: ['includeGraphHash', 'conditionalBranches', 'sourceMapId'],
|
|
26
|
+
notes: ['Preprocessor imports need the active defines/includes and preprocessed output hash to make replayable claims.']
|
|
27
|
+
}),
|
|
28
|
+
conditionalCompilation: nativeImportFeatureEvidencePolicy('conditionalCompilation', {
|
|
29
|
+
category: 'conditionalCompilation',
|
|
30
|
+
risk: 'high',
|
|
31
|
+
minimumReadiness: 'needs-review',
|
|
32
|
+
requiredEvidenceKeys: ['activeBranches', 'inactiveBranchesHash'],
|
|
33
|
+
recommendedEvidenceKeys: ['compileTarget', 'featureFlags', 'preprocessedOutputHash'],
|
|
34
|
+
notes: ['Conditional branches that were not active still affect portability and conflict review.']
|
|
35
|
+
}),
|
|
36
|
+
metaprogramming: nativeImportFeatureEvidencePolicy('metaprogramming', {
|
|
37
|
+
category: 'metaprogramming',
|
|
38
|
+
risk: 'critical',
|
|
39
|
+
minimumReadiness: 'needs-review',
|
|
40
|
+
missingEvidenceReadiness: 'blocked',
|
|
41
|
+
requiredEvidenceKeys: ['generatedArtifactHash', 'generatorIdentity'],
|
|
42
|
+
recommendedEvidenceKeys: ['generatorInputsHash', 'generatedRanges', 'replayCommand'],
|
|
43
|
+
notes: ['Generated or metaprogrammed declarations need replayable generator identity and input evidence.']
|
|
44
|
+
}),
|
|
45
|
+
reflection: nativeImportFeatureEvidencePolicy('reflection', {
|
|
46
|
+
category: 'reflection',
|
|
47
|
+
risk: 'high',
|
|
48
|
+
minimumReadiness: 'needs-review',
|
|
49
|
+
requiredEvidenceKeys: ['reflectionSurface', 'runtimeContract'],
|
|
50
|
+
recommendedEvidenceKeys: ['observedMembers', 'fixtureIds', 'runtimeVersion'],
|
|
51
|
+
notes: ['Reflection-heavy code needs a declared runtime contract because static AST evidence is incomplete.']
|
|
52
|
+
}),
|
|
53
|
+
dynamicRuntime: nativeImportFeatureEvidencePolicy('dynamicRuntime', {
|
|
54
|
+
category: 'reflection',
|
|
55
|
+
risk: 'high',
|
|
56
|
+
minimumReadiness: 'needs-review',
|
|
57
|
+
requiredEvidenceKeys: ['runtimeContract'],
|
|
58
|
+
recommendedEvidenceKeys: ['fixtureIds', 'observedEffects', 'runtimeVersion'],
|
|
59
|
+
notes: ['Dynamic runtime behavior should stay review-required until fixtures or traces describe the observed contract.']
|
|
60
|
+
}),
|
|
61
|
+
dynamicDispatch: nativeImportFeatureEvidencePolicy('dynamicDispatch', {
|
|
62
|
+
category: 'overloadTypeInference',
|
|
63
|
+
risk: 'medium',
|
|
64
|
+
minimumReadiness: 'needs-review',
|
|
65
|
+
requiredEvidenceKeys: ['dispatchTargets'],
|
|
66
|
+
recommendedEvidenceKeys: ['callGraphId', 'typeEvidenceId', 'fixtureIds'],
|
|
67
|
+
notes: ['Dynamic dispatch needs candidate target evidence before call graph or porting claims are merge-ready.']
|
|
68
|
+
}),
|
|
69
|
+
generatedCode: nativeImportFeatureEvidencePolicy('generatedCode', {
|
|
70
|
+
category: 'generatedCode',
|
|
71
|
+
risk: 'high',
|
|
72
|
+
minimumReadiness: 'needs-review',
|
|
73
|
+
requiredEvidenceKeys: ['generatedArtifactHash', 'generatedRanges'],
|
|
74
|
+
recommendedEvidenceKeys: ['generatorIdentity', 'generatorInputsHash', 'sourceMapId'],
|
|
75
|
+
notes: ['Generated code must preserve generated ranges and artifact hashes so workers can avoid editing derived output blindly.']
|
|
76
|
+
}),
|
|
77
|
+
overloadResolution: nativeImportFeatureEvidencePolicy('overloadResolution', {
|
|
78
|
+
category: 'overloadTypeInference',
|
|
79
|
+
risk: 'medium',
|
|
80
|
+
minimumReadiness: 'needs-review',
|
|
81
|
+
requiredEvidenceKeys: ['resolvedOverloads'],
|
|
82
|
+
recommendedEvidenceKeys: ['typeEvidenceId', 'compilerVersion', 'callSiteSpans'],
|
|
83
|
+
notes: ['Overload-sensitive imports should record compiler/type evidence for each call site.']
|
|
84
|
+
}),
|
|
85
|
+
typeInference: nativeImportFeatureEvidencePolicy('typeInference', {
|
|
86
|
+
category: 'overloadTypeInference',
|
|
87
|
+
risk: 'medium',
|
|
88
|
+
minimumReadiness: 'needs-review',
|
|
89
|
+
requiredEvidenceKeys: ['inferredTypesHash'],
|
|
90
|
+
recommendedEvidenceKeys: ['typeEvidenceId', 'compilerVersion', 'symbolTableHash'],
|
|
91
|
+
notes: ['Inferred types need a stable type-evidence hash before cross-language projection can claim fidelity.']
|
|
92
|
+
}),
|
|
93
|
+
unsupportedSyntax: nativeImportFeatureEvidencePolicy('unsupportedSyntax', {
|
|
94
|
+
category: 'unsupportedSyntax',
|
|
95
|
+
risk: 'high',
|
|
96
|
+
minimumReadiness: 'needs-review',
|
|
97
|
+
missingEvidenceReadiness: 'blocked',
|
|
98
|
+
requiredEvidenceKeys: ['unsupportedSyntaxKind', 'sourceSpan'],
|
|
99
|
+
recommendedEvidenceKeys: ['parserDiagnosticId', 'nativeAstNodeId', 'sourceSnippetHash'],
|
|
100
|
+
notes: ['Unsupported syntax must remain anchored to source spans and parser diagnostics for later adapter work.']
|
|
101
|
+
}),
|
|
102
|
+
unsupportedSemantic: nativeImportFeatureEvidencePolicy('unsupportedSemantic', {
|
|
103
|
+
category: 'unsupportedSyntax',
|
|
104
|
+
risk: 'high',
|
|
105
|
+
minimumReadiness: 'needs-review',
|
|
106
|
+
missingEvidenceReadiness: 'blocked',
|
|
107
|
+
requiredEvidenceKeys: ['unsupportedSemanticKind', 'semanticSymbolId'],
|
|
108
|
+
recommendedEvidenceKeys: ['semanticIndexId', 'sourceMapId', 'reason'],
|
|
109
|
+
notes: ['Unsupported semantics should name the affected symbol so merge tools can isolate the unsafe region.']
|
|
110
|
+
})
|
|
111
|
+
});
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export const NativeImportLossKinds = Object.freeze([
|
|
2
|
+
'declarationOnlyCoverage',
|
|
3
|
+
'opaqueNative',
|
|
4
|
+
'macroExpansion',
|
|
5
|
+
'macroHygiene',
|
|
6
|
+
'preprocessor',
|
|
7
|
+
'conditionalCompilation',
|
|
8
|
+
'metaprogramming',
|
|
9
|
+
'reflection',
|
|
10
|
+
'dynamicRuntime',
|
|
11
|
+
'dynamicDispatch',
|
|
12
|
+
'generatedCode',
|
|
13
|
+
'overloadResolution',
|
|
14
|
+
'typeInference',
|
|
15
|
+
'sourcePreservation',
|
|
16
|
+
'commentsTrivia',
|
|
17
|
+
'parserDiagnostic',
|
|
18
|
+
'unsupportedSyntax',
|
|
19
|
+
'unsupportedSemantic',
|
|
20
|
+
'unverifiedNativeAst',
|
|
21
|
+
'partialSemanticIndex',
|
|
22
|
+
'sourceMapApproximation',
|
|
23
|
+
'targetProjectionLoss'
|
|
24
|
+
]);
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export const NativeImportTaxonomyKinds = Object.freeze([
|
|
2
|
+
'exactAstImport',
|
|
3
|
+
'declarationsOnly',
|
|
4
|
+
'opaqueBodies',
|
|
5
|
+
'macroExpansion',
|
|
6
|
+
'preprocessor',
|
|
7
|
+
'conditionalCompilation',
|
|
8
|
+
'metaprogramming',
|
|
9
|
+
'reflection',
|
|
10
|
+
'generatedCode',
|
|
11
|
+
'overloadTypeInference',
|
|
12
|
+
'sourcePreservation',
|
|
13
|
+
'commentsTrivia',
|
|
14
|
+
'parserDiagnostics',
|
|
15
|
+
'unsupportedSyntax',
|
|
16
|
+
'partialSemanticIndex',
|
|
17
|
+
'sourceMapApproximation',
|
|
18
|
+
'targetProjectionLoss'
|
|
19
|
+
]);
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export function adapterCoverageCapabilityRow(capability, declared, observed, effective, count = 0) {
|
|
2
|
+
const status = declared && observed
|
|
3
|
+
? 'declared-and-observed'
|
|
4
|
+
: declared ? 'declared-unobserved' : observed ? 'observed-undeclared' : 'absent';
|
|
5
|
+
return Object.freeze({
|
|
6
|
+
capability,
|
|
7
|
+
declared: Boolean(declared),
|
|
8
|
+
observed: Boolean(observed),
|
|
9
|
+
effective: Boolean(effective),
|
|
10
|
+
count: Number(count ?? 0) || 0,
|
|
11
|
+
status
|
|
12
|
+
});
|
|
13
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import{freezeNativeImporterAdapterCoverageSnapshot}from'./freezeNativeImporterAdapterCoverageSnapshot.js';
|
|
2
|
+
export function adapterCoverageSnapshotFromSummary(coverage = {}) {
|
|
3
|
+
return freezeNativeImporterAdapterCoverageSnapshot({
|
|
4
|
+
exactness: coverage.exactness ?? 'unknown',
|
|
5
|
+
exactAst: coverage.exactAst,
|
|
6
|
+
tokens: coverage.tokens,
|
|
7
|
+
trivia: coverage.trivia,
|
|
8
|
+
diagnostics: coverage.diagnostics,
|
|
9
|
+
sourceRanges: coverage.sourceRanges,
|
|
10
|
+
generatedRanges: coverage.generatedRanges,
|
|
11
|
+
semanticCoverage: coverage.semanticCoverage
|
|
12
|
+
});
|
|
13
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export function adapterCoverageSourcePreservation(parseResult = {}) {
|
|
2
|
+
return parseResult.sourcePreservation
|
|
3
|
+
?? parseResult.nativeAst?.metadata?.sourcePreservation
|
|
4
|
+
?? parseResult.nativeAstMetadata?.sourcePreservation
|
|
5
|
+
?? parseResult.metadata?.sourcePreservation;
|
|
6
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import{idFragment}from'../../native-import-utils.js';
|
|
2
|
+
export function adapterDiagnosticToLoss(diagnostic, index, adapter, input) {
|
|
3
|
+
const code = diagnostic.code ?? diagnostic.kind ?? diagnostic.severity;
|
|
4
|
+
return {
|
|
5
|
+
id: `loss_${idFragment(diagnostic.id ?? `${adapter.id}_${index}_${code}`)}`,
|
|
6
|
+
severity: diagnostic.severity,
|
|
7
|
+
phase: diagnostic.phase,
|
|
8
|
+
sourceFormat: input.language,
|
|
9
|
+
kind: diagnostic.kind ?? (diagnostic.severity === 'error' ? 'unsupportedSyntax' : 'opaqueNative'),
|
|
10
|
+
message: diagnostic.message,
|
|
11
|
+
span: diagnostic.span,
|
|
12
|
+
metadata: {
|
|
13
|
+
adapterId: adapter.id,
|
|
14
|
+
adapterVersion: adapter.version,
|
|
15
|
+
diagnosticId: diagnostic.id,
|
|
16
|
+
diagnosticCode: diagnostic.code,
|
|
17
|
+
parser: input.parser,
|
|
18
|
+
parserVersion: input.parserVersion,
|
|
19
|
+
path: diagnostic.path,
|
|
20
|
+
...diagnostic.metadata
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import{idFragment}from'../../native-import-utils.js';
|
|
2
|
+
import{serializableDiagnostic}from'./serializableDiagnostic.js';
|
|
3
|
+
export function adapterDiagnosticsEvidence(adapter, diagnostics, input) {
|
|
4
|
+
const errors = diagnostics.filter((diagnostic) => diagnostic.severity === 'error').length;
|
|
5
|
+
const warnings = diagnostics.filter((diagnostic) => diagnostic.severity === 'warning').length;
|
|
6
|
+
return {
|
|
7
|
+
id: `evidence_${idFragment(adapter.id)}_native_importer_adapter`,
|
|
8
|
+
kind: 'import',
|
|
9
|
+
status: errors ? 'failed' : 'passed',
|
|
10
|
+
path: input.sourcePath,
|
|
11
|
+
summary: `Ran ${adapter.id} native importer for ${input.language} with ${diagnostics.length} diagnostic(s).`,
|
|
12
|
+
metadata: {
|
|
13
|
+
adapterId: adapter.id,
|
|
14
|
+
adapterVersion: adapter.version,
|
|
15
|
+
language: input.language,
|
|
16
|
+
parser: input.parser,
|
|
17
|
+
parserVersion: input.parserVersion,
|
|
18
|
+
sourceHash: input.sourceHash,
|
|
19
|
+
capabilities: adapter.capabilities,
|
|
20
|
+
coverage: adapter.coverage,
|
|
21
|
+
supportedExtensions: adapter.supportedExtensions,
|
|
22
|
+
diagnostics: diagnostics.map(serializableDiagnostic),
|
|
23
|
+
errors,
|
|
24
|
+
warnings
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import{idFragment}from'../../native-import-utils.js';
|
|
2
|
+
import{normalizeArray}from'./normalizeArray.js';import{semanticTokenModifiers}from'./semanticTokenModifiers.js';
|
|
3
|
+
export function addLspSemanticTokens(result, semanticTokens, input) {
|
|
4
|
+
const data = normalizeArray(semanticTokens.data);
|
|
5
|
+
const legend = semanticTokens.legend ?? {};
|
|
6
|
+
let line = 0;
|
|
7
|
+
let character = 0;
|
|
8
|
+
for (let index = 0; index + 4 < data.length; index += 5) {
|
|
9
|
+
line += Number(data[index] ?? 0);
|
|
10
|
+
character = Number(data[index] ?? 0) === 0 ? character + Number(data[index + 1] ?? 0) : Number(data[index + 1] ?? 0);
|
|
11
|
+
const length = Number(data[index + 2] ?? 0);
|
|
12
|
+
const tokenType = legend.tokenTypes?.[Number(data[index + 3] ?? 0)] ?? `tokenType${data[index + 3] ?? 0}`;
|
|
13
|
+
const span = {
|
|
14
|
+
path: input.sourcePath,
|
|
15
|
+
startLine: line + 1,
|
|
16
|
+
startColumn: character + 1,
|
|
17
|
+
endLine: line + 1,
|
|
18
|
+
endColumn: character + length + 1
|
|
19
|
+
};
|
|
20
|
+
result.facts.push({
|
|
21
|
+
id: `fact_${idFragment(input.documentId)}_semantic_token_${index / 5 + 1}`,
|
|
22
|
+
predicate: 'semanticToken',
|
|
23
|
+
subjectId: input.documentId,
|
|
24
|
+
value: {
|
|
25
|
+
tokenType,
|
|
26
|
+
tokenModifiers: semanticTokenModifiers(Number(data[index + 4] ?? 0), legend.tokenModifiers),
|
|
27
|
+
span
|
|
28
|
+
},
|
|
29
|
+
metadata: { format: 'lsp' }
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import{idFragment}from'../../native-import-utils.js';import{hashSemanticValue}from'@shapeshift-labs/frontier-lang-kernel';
|
|
2
|
+
import{normalizeArray}from'./normalizeArray.js';import{normalizeLspSymbolKind}from'./normalizeLspSymbolKind.js';import{spanFromLspRange}from'./spanFromLspRange.js';import{uriToPath}from'./uriToPath.js';
|
|
3
|
+
export function addLspSymbol(result, symbol, input) {
|
|
4
|
+
const location = symbol.location ?? {};
|
|
5
|
+
const range = symbol.range ?? location.range ?? symbol.selectionRange;
|
|
6
|
+
const sourcePath = uriToPath(location.uri ?? symbol.uri) ?? input.sourcePath;
|
|
7
|
+
const symbolName = symbol.name ?? symbol.containerName ?? `symbol_${result.symbols.length + 1}`;
|
|
8
|
+
const symbolId = symbol.id ?? `symbol:lsp:${idFragment(input.language ?? 'unknown')}:${idFragment([input.parentName, symbolName].filter(Boolean).join('.'))}`;
|
|
9
|
+
const ownershipSpan = spanFromLspRange(range, sourcePath, input.context.sourceHash, 0);
|
|
10
|
+
const selectionSpan = spanFromLspRange(symbol.selectionRange ?? range, sourcePath, input.context.sourceHash, 0);
|
|
11
|
+
if (!result.symbols.some((entry) => entry.id === symbolId)) {
|
|
12
|
+
result.symbols.push({
|
|
13
|
+
id: symbolId,
|
|
14
|
+
scheme: 'lsp',
|
|
15
|
+
name: symbolName,
|
|
16
|
+
kind: normalizeLspSymbolKind(symbol.kind),
|
|
17
|
+
language: input.language,
|
|
18
|
+
definitionSpan: ownershipSpan,
|
|
19
|
+
signatureHash: hashSemanticValue([symbolName, symbol.kind, symbol.detail]),
|
|
20
|
+
metadata: {
|
|
21
|
+
format: 'lsp',
|
|
22
|
+
detail: symbol.detail,
|
|
23
|
+
tags: symbol.tags,
|
|
24
|
+
deprecated: symbol.deprecated,
|
|
25
|
+
containerName: symbol.containerName,
|
|
26
|
+
parentName: input.parentName
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
result.occurrences.push({
|
|
31
|
+
id: `occ_${idFragment(symbolId)}_${result.occurrences.length + 1}`,
|
|
32
|
+
documentId: input.documentId,
|
|
33
|
+
symbolId,
|
|
34
|
+
role: 'definition',
|
|
35
|
+
span: selectionSpan,
|
|
36
|
+
metadata: { format: 'lsp', range, selectionRange: symbol.selectionRange }
|
|
37
|
+
});
|
|
38
|
+
for (const child of normalizeArray(symbol.children)) {
|
|
39
|
+
addLspSymbol(result, child, {
|
|
40
|
+
...input,
|
|
41
|
+
parentName: [input.parentName, symbolName].filter(Boolean).join('.')
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import{idFragment}from'../../native-import-utils.js';import{semanticRegionKindForSymbol,semanticRegionMergePolicy}from'../../semantic-import-regions.js';
|
|
2
|
+
import{externalRelationPredicateForOccurrence}from'./externalRelationPredicateForOccurrence.js';
|
|
3
|
+
export function attachExternalOwnership(result, context) {
|
|
4
|
+
const occurrencesBySymbol = new Map();
|
|
5
|
+
for (const occurrence of result.occurrences) {
|
|
6
|
+
if (!occurrencesBySymbol.has(occurrence.symbolId)) occurrencesBySymbol.set(occurrence.symbolId, []);
|
|
7
|
+
occurrencesBySymbol.get(occurrence.symbolId).push(occurrence);
|
|
8
|
+
result.relations.push({
|
|
9
|
+
id: `rel_${idFragment(occurrence.documentId)}_${idFragment(occurrence.id)}_${idFragment(occurrence.role)}`,
|
|
10
|
+
sourceId: occurrence.documentId,
|
|
11
|
+
predicate: externalRelationPredicateForOccurrence(occurrence),
|
|
12
|
+
targetId: occurrence.symbolId,
|
|
13
|
+
metadata: {
|
|
14
|
+
format: context.format,
|
|
15
|
+
source: 'external-semantic-index',
|
|
16
|
+
occurrenceId: occurrence.id,
|
|
17
|
+
role: occurrence.role
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
result.symbols = result.symbols.map((symbol) => {
|
|
22
|
+
const occurrences = occurrencesBySymbol.get(symbol.id) ?? [];
|
|
23
|
+
const definition = occurrences.find((occurrence) => occurrence.role === 'definition') ?? occurrences[0];
|
|
24
|
+
const sourceSpan = symbol.definitionSpan ?? definition?.span;
|
|
25
|
+
const regionKind = semanticRegionKindForSymbol(symbol, undefined, undefined);
|
|
26
|
+
const key = [
|
|
27
|
+
'external',
|
|
28
|
+
symbol.language ?? context.language ?? 'unknown',
|
|
29
|
+
sourceSpan?.path ?? context.sourcePath ?? 'memory',
|
|
30
|
+
regionKind,
|
|
31
|
+
symbol.name ?? symbol.id
|
|
32
|
+
].join('#');
|
|
33
|
+
const region = {
|
|
34
|
+
id: `region_${idFragment(key)}`,
|
|
35
|
+
key,
|
|
36
|
+
regionKind,
|
|
37
|
+
granularity: 'symbol',
|
|
38
|
+
language: symbol.language ?? context.language,
|
|
39
|
+
documentId: definition?.documentId,
|
|
40
|
+
sourcePath: sourceSpan?.path ?? context.sourcePath,
|
|
41
|
+
sourceHash: context.sourceHash,
|
|
42
|
+
symbolId: symbol.id,
|
|
43
|
+
symbolName: symbol.name,
|
|
44
|
+
symbolKind: symbol.kind,
|
|
45
|
+
sourceSpan,
|
|
46
|
+
precision: sourceSpan ? 'declaration' : 'unknown',
|
|
47
|
+
mergePolicy: semanticRegionMergePolicy(regionKind),
|
|
48
|
+
metadata: {
|
|
49
|
+
format: context.format,
|
|
50
|
+
source: 'external-semantic-index'
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
result.facts.push({
|
|
54
|
+
id: `fact_${idFragment(symbol.id)}_ownership_region`,
|
|
55
|
+
predicate: 'semanticOwnershipRegion',
|
|
56
|
+
subjectId: symbol.id,
|
|
57
|
+
value: region
|
|
58
|
+
}, {
|
|
59
|
+
id: `fact_${idFragment(symbol.id)}_ownership_region_taxonomy`,
|
|
60
|
+
predicate: 'semanticOwnershipRegionTaxonomy',
|
|
61
|
+
subjectId: symbol.id,
|
|
62
|
+
value: {
|
|
63
|
+
regionKind: region.regionKind,
|
|
64
|
+
granularity: region.granularity,
|
|
65
|
+
key: region.key
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
return {
|
|
69
|
+
...symbol,
|
|
70
|
+
definitionSpan: symbol.definitionSpan ?? definition?.span,
|
|
71
|
+
metadata: {
|
|
72
|
+
...symbol.metadata,
|
|
73
|
+
ownershipRegionId: symbol.metadata?.ownershipRegionId ?? region.id,
|
|
74
|
+
ownershipRegionKey: symbol.metadata?.ownershipRegionKey ?? region.key,
|
|
75
|
+
ownershipRegionKind: symbol.metadata?.ownershipRegionKind ?? region.regionKind
|
|
76
|
+
}
|
|
77
|
+
};
|
|
78
|
+
});
|
|
79
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import{nativeChangedRegionProjectionMetadata}from'./nativeChangedRegionProjectionMetadata.js';
|
|
2
|
+
export function attachNativeChangeRegionProjectionMetadata(regions, context) {
|
|
3
|
+
return (regions ?? []).map((region) => {
|
|
4
|
+
const projection = nativeChangedRegionProjectionMetadata(region, context);
|
|
5
|
+
return {
|
|
6
|
+
...region,
|
|
7
|
+
metadata: {
|
|
8
|
+
...(region.metadata ?? {}),
|
|
9
|
+
changedRegionProjection: projection
|
|
10
|
+
}
|
|
11
|
+
};
|
|
12
|
+
});
|
|
13
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export function attachNativeImportLossSummary(evidence, lossSummary) {
|
|
2
|
+
return (evidence ?? []).map((record) => ({
|
|
3
|
+
...record,
|
|
4
|
+
metadata: {
|
|
5
|
+
...record.metadata,
|
|
6
|
+
nativeImportLossSummary: lossSummary,
|
|
7
|
+
semanticMergeReadiness: lossSummary.semanticMergeReadiness,
|
|
8
|
+
lossCategories: lossSummary.categories
|
|
9
|
+
}
|
|
10
|
+
}));
|
|
11
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import{ignoredClangAstField}from'./ignoredClangAstField.js';import{isClangAstNode}from'./isClangAstNode.js';
|
|
2
|
+
export function clangAstChildEntries(node) {
|
|
3
|
+
const fieldNames = Object.keys(node).filter((key) => !ignoredClangAstField(key));
|
|
4
|
+
return fieldNames
|
|
5
|
+
.map((field) => [field, node[field]])
|
|
6
|
+
.filter(([, value]) => Array.isArray(value)
|
|
7
|
+
? value.some(isClangAstNode)
|
|
8
|
+
: isClangAstNode(value));
|
|
9
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import{clangDeclarationAction}from'./clangDeclarationAction.js';import{clangDeclarationName}from'./clangDeclarationName.js';import{clangIncludePath}from'./clangIncludePath.js';import{declarationRecord}from'./declarationRecord.js';import{nativeNodeId}from'./nativeNodeId.js';
|
|
2
|
+
export function clangAstDeclaration(node, kind, nativeNodeId, input) {
|
|
3
|
+
if (kind === 'FunctionDecl' || kind === 'CXXMethodDecl' || kind === 'FunctionTemplateDecl') {
|
|
4
|
+
const name = clangDeclarationName(node);
|
|
5
|
+
if (name) return declarationRecord(input, nativeNodeId, name, kind === 'CXXMethodDecl' ? 'method' : 'function', clangDeclarationAction(node));
|
|
6
|
+
}
|
|
7
|
+
if (kind === 'ParmVarDecl') {
|
|
8
|
+
const name = clangDeclarationName(node);
|
|
9
|
+
if (name) return declarationRecord(input, nativeNodeId, name, 'parameter', 'definition');
|
|
10
|
+
}
|
|
11
|
+
if (kind === 'RecordDecl' || kind === 'CXXRecordDecl' || kind === 'ClassTemplateDecl') {
|
|
12
|
+
const name = clangDeclarationName(node);
|
|
13
|
+
if (name) return declarationRecord(input, nativeNodeId, name, kind === 'CXXRecordDecl' ? 'class' : 'type', clangDeclarationAction(node));
|
|
14
|
+
}
|
|
15
|
+
if (kind === 'FieldDecl') {
|
|
16
|
+
const name = clangDeclarationName(node);
|
|
17
|
+
if (name) return declarationRecord(input, nativeNodeId, name, 'property', 'definition');
|
|
18
|
+
}
|
|
19
|
+
if (kind === 'TypedefDecl' || kind === 'TypeAliasDecl' || kind === 'TypeAliasTemplateDecl') {
|
|
20
|
+
const name = clangDeclarationName(node);
|
|
21
|
+
if (name) return declarationRecord(input, nativeNodeId, name, 'type', 'definition');
|
|
22
|
+
}
|
|
23
|
+
if (kind === 'EnumDecl') {
|
|
24
|
+
const name = clangDeclarationName(node);
|
|
25
|
+
if (name) return declarationRecord(input, nativeNodeId, name, 'type', clangDeclarationAction(node));
|
|
26
|
+
}
|
|
27
|
+
if (kind === 'EnumConstantDecl') {
|
|
28
|
+
const name = clangDeclarationName(node);
|
|
29
|
+
if (name) return declarationRecord(input, nativeNodeId, name, 'enumMember', 'definition');
|
|
30
|
+
}
|
|
31
|
+
if (kind === 'VarDecl') {
|
|
32
|
+
const name = clangDeclarationName(node);
|
|
33
|
+
if (name) return declarationRecord(input, nativeNodeId, name, 'variable', clangDeclarationAction(node));
|
|
34
|
+
}
|
|
35
|
+
if (/IncludeDirective|InclusionDirective/.test(kind)) {
|
|
36
|
+
const name = clangIncludePath(node);
|
|
37
|
+
if (name) return declarationRecord(input, nativeNodeId, name, 'module', 'import');
|
|
38
|
+
}
|
|
39
|
+
if (/MacroDefinition|MacroExpansion|MacroInstantiation/.test(kind)) {
|
|
40
|
+
const name = clangDeclarationName(node) ?? clangIncludePath(node);
|
|
41
|
+
if (name) return declarationRecord(input, nativeNodeId, name, 'macro', 'definition');
|
|
42
|
+
}
|
|
43
|
+
return undefined;
|
|
44
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export function clangAstKind(node) {
|
|
2
|
+
if (!node || typeof node !== 'object') return undefined;
|
|
3
|
+
const declared = node.kind ?? node._type ?? node.type ?? node.nodeType ?? node.declKind ?? node.stmtKind;
|
|
4
|
+
if (typeof declared === 'string') return declared;
|
|
5
|
+
if (Array.isArray(node.inner) || Array.isArray(node.children) || Array.isArray(node.decls)) return 'TranslationUnitDecl';
|
|
6
|
+
return undefined;
|
|
7
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import{clangDeclarationName}from'./clangDeclarationName.js';import{clangIncludePath}from'./clangIncludePath.js';import{clangLiteralValue}from'./clangLiteralValue.js';import{clangTypeName}from'./clangTypeName.js';
|
|
2
|
+
export function clangAstNodeValue(node) {
|
|
3
|
+
return clangDeclarationName(node)
|
|
4
|
+
?? clangIncludePath(node)
|
|
5
|
+
?? clangTypeName(node.type ?? node.qualType)
|
|
6
|
+
?? clangLiteralValue(node);
|
|
7
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import{isClangAstNode}from'./isClangAstNode.js';
|
|
2
|
+
export function clangAstRoot(value) {
|
|
3
|
+
if (!value || typeof value !== 'object') return undefined;
|
|
4
|
+
if (Array.isArray(value)) return { kind: 'TranslationUnitDecl', inner: value };
|
|
5
|
+
if (isClangAstNode(value)) return value;
|
|
6
|
+
if (Array.isArray(value.ast)) return { kind: 'TranslationUnitDecl', inner: value.ast };
|
|
7
|
+
if (isClangAstNode(value.ast)) return value.ast;
|
|
8
|
+
if (isClangAstNode(value.root)) return value.root;
|
|
9
|
+
if (isClangAstNode(value.translationUnit)) return value.translationUnit;
|
|
10
|
+
if (isClangAstNode(value.tu)) return value.tu;
|
|
11
|
+
if (isClangAstNode(value.file)) return value.file;
|
|
12
|
+
if (isClangAstNode(value.sourceFile)) return value.sourceFile;
|
|
13
|
+
return undefined;
|
|
14
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import{clangAstKind}from'./clangAstKind.js';
|
|
2
|
+
export function clangDeclarationAction(node) {
|
|
3
|
+
if (node.isThisDeclarationADefinition === false) return 'declaration';
|
|
4
|
+
if (node.isThisDeclarationADefinition === true) return 'definition';
|
|
5
|
+
if (Array.isArray(node.inner) && node.inner.some((entry) => ['CompoundStmt', 'FieldDecl', 'EnumConstantDecl'].includes(clangAstKind(entry)))) return 'definition';
|
|
6
|
+
return 'declaration';
|
|
7
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export function clangDeclarationName(node) {
|
|
2
|
+
if (!node || typeof node !== 'object') return undefined;
|
|
3
|
+
for (const key of ['qualifiedName', 'displayName', 'name', 'mangledName']) {
|
|
4
|
+
if (typeof node[key] === 'string' && node[key]) return node[key];
|
|
5
|
+
}
|
|
6
|
+
if (node.name && typeof node.name === 'object') return clangDeclarationName(node.name);
|
|
7
|
+
if (node.referencedDecl && typeof node.referencedDecl === 'object') return clangDeclarationName(node.referencedDecl);
|
|
8
|
+
if (node.decl && typeof node.decl === 'object') return clangDeclarationName(node.decl);
|
|
9
|
+
return undefined;
|
|
10
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export function clangIncludePath(node) {
|
|
2
|
+
if (!node || typeof node !== 'object') return undefined;
|
|
3
|
+
for (const key of ['file', 'filename', 'path', 'spelling', 'source']) {
|
|
4
|
+
if (typeof node[key] === 'string' && node[key]) return node[key];
|
|
5
|
+
}
|
|
6
|
+
if (node.include && typeof node.include === 'object') return clangIncludePath(node.include);
|
|
7
|
+
return undefined;
|
|
8
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export function clangLiteralValue(node) {
|
|
2
|
+
const value = node.value ?? node.val ?? node.literal;
|
|
3
|
+
if (value === null || typeof value === 'string' || typeof value === 'number' || typeof value === 'boolean') return value;
|
|
4
|
+
if (typeof node.valueAsString === 'string') return node.valueAsString;
|
|
5
|
+
return undefined;
|
|
6
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export function clangLocPosition(loc) {
|
|
2
|
+
if (!loc || typeof loc !== 'object') return undefined;
|
|
3
|
+
const expanded = loc.expansionLoc ?? loc.spellingLoc ?? loc;
|
|
4
|
+
const line = expanded.line ?? expanded.startLine ?? expanded.begin?.line;
|
|
5
|
+
const column = expanded.col ?? expanded.column ?? expanded.startColumn ?? expanded.begin?.col ?? expanded.begin?.column;
|
|
6
|
+
if (typeof line !== 'number') return undefined;
|
|
7
|
+
return {
|
|
8
|
+
path: expanded.file ?? expanded.filename ?? expanded.path,
|
|
9
|
+
line,
|
|
10
|
+
column: typeof column === 'number' ? column : undefined
|
|
11
|
+
};
|
|
12
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export function clangLocationKind(node) {
|
|
2
|
+
const loc = node.loc ?? node.range?.begin;
|
|
3
|
+
if (!loc || typeof loc !== 'object') return undefined;
|
|
4
|
+
if (loc.expansionLoc) return 'expansionLoc';
|
|
5
|
+
if (loc.spellingLoc) return 'spellingLoc';
|
|
6
|
+
if (loc.includedFrom) return 'includedFrom';
|
|
7
|
+
return 'clang-loc';
|
|
8
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import{isClangAstNode}from'./isClangAstNode.js';
|
|
2
|
+
export function clangPreprocessorRecords(value) {
|
|
3
|
+
if (!value) return [];
|
|
4
|
+
if (Array.isArray(value)) return value.filter(isClangAstNode);
|
|
5
|
+
if (typeof value === 'object' && Array.isArray(value.records)) return value.records.filter(isClangAstNode);
|
|
6
|
+
if (isClangAstNode(value)) return [value];
|
|
7
|
+
return [];
|
|
8
|
+
}
|