@shapeshift-labs/frontier-lang-compiler 0.2.149 → 0.2.151

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.
Files changed (280) hide show
  1. package/README.md +315 -9
  2. package/bench/real-repo-corpus-checkout-identity.mjs +134 -0
  3. package/bench/real-repo-corpus-checkout-proof.mjs +263 -0
  4. package/bench/real-repo-corpus-command-execution.mjs +314 -0
  5. package/bench/real-repo-corpus-evidence.mjs +165 -0
  6. package/bench/real-repo-corpus-suite.mjs +273 -0
  7. package/bench/smoke.mjs +109 -7
  8. package/dist/declarations/import-adapter-core.d.ts +4 -3
  9. package/dist/declarations/import-adapter-options-native.d.ts +21 -0
  10. package/dist/declarations/js-ts-project-merge-admission-routes.d.ts +35 -0
  11. package/dist/declarations/js-ts-project-merge-commonjs-interop.d.ts +29 -0
  12. package/dist/declarations/js-ts-project-merge-confidence.d.ts +64 -0
  13. package/dist/declarations/js-ts-project-merge-declaration-emit-parity.d.ts +37 -0
  14. package/dist/declarations/js-ts-project-merge-declarations.d.ts +65 -0
  15. package/dist/declarations/js-ts-project-merge-diagnostics.d.ts +97 -0
  16. package/dist/declarations/js-ts-project-merge-global-augmentation.d.ts +30 -0
  17. package/dist/declarations/js-ts-project-merge-jsx-render-branch.d.ts +48 -0
  18. package/dist/declarations/js-ts-project-merge-proof-levels.d.ts +109 -0
  19. package/dist/declarations/js-ts-project-merge-quality-gates.d.ts +38 -0
  20. package/dist/declarations/js-ts-project-merge-semantic-equivalence-proof.d.ts +45 -0
  21. package/dist/declarations/js-ts-project-merge-tsconfig.d.ts +43 -0
  22. package/dist/declarations/js-ts-safe-merge.d.ts +47 -0
  23. package/dist/declarations/js-ts-safe-project-merge.d.ts +120 -38
  24. package/dist/declarations/native-project-compiler-assignability-oracle.d.ts +41 -0
  25. package/dist/declarations/native-project-compiler-callable-signatures.d.ts +31 -0
  26. package/dist/declarations/native-project-compiler-class-member-runtime-proof.d.ts +87 -0
  27. package/dist/declarations/native-project-compiler-composite-types.d.ts +23 -0
  28. package/dist/declarations/native-project-compiler-enum-proof.d.ts +58 -0
  29. package/dist/declarations/native-project-compiler-index-signature.d.ts +7 -0
  30. package/dist/declarations/native-project-compiler-public-api-source-binding.d.ts +8 -0
  31. package/dist/declarations/native-project-compiler-scope.d.ts +37 -0
  32. package/dist/declarations/native-project-compiler-type-reference-targets.d.ts +38 -0
  33. package/dist/declarations/native-project-css-modules.d.ts +90 -0
  34. package/dist/declarations/native-project-decorator-metadata.d.ts +126 -0
  35. package/dist/declarations/native-project-jsx-graph.d.ts +313 -0
  36. package/dist/declarations/native-project-module-declarations.d.ts +52 -0
  37. package/dist/declarations/native-project-module-resolution.d.ts +76 -1
  38. package/dist/declarations/native-project-runtime-effect-target.d.ts +29 -0
  39. package/dist/declarations/native-project-runtime-executable-effect-evidence.d.ts +107 -0
  40. package/dist/declarations/native-project-runtime-mutation-target.d.ts +33 -0
  41. package/dist/declarations/native-project-runtime-promise-chain.d.ts +30 -0
  42. package/dist/declarations/native-project-runtime-promise-combinator.d.ts +22 -0
  43. package/dist/declarations/native-project-runtime-reachability.d.ts +30 -0
  44. package/dist/declarations/native-project-runtime-resource-management.d.ts +27 -0
  45. package/dist/declarations/native-project-runtime-yield-delegation.d.ts +10 -0
  46. package/dist/declarations/native-project-scope-template-reference.d.ts +13 -0
  47. package/dist/declarations/native-project-source-evidence.d.ts +8 -0
  48. package/dist/declarations/native-project.d.ts +40 -39
  49. package/dist/declarations/semantic-edit-script.d.ts +10 -8
  50. package/dist/declarations/semantic-graph-layers.d.ts +79 -0
  51. package/dist/declarations/semantic-patch-bundle-composition.d.ts +62 -0
  52. package/dist/declarations/semantic-sidecar.d.ts +3 -2
  53. package/dist/declarations/semantic-structural-diff.d.ts +94 -0
  54. package/dist/declarations/source-preservation.d.ts +32 -1
  55. package/dist/declarations/target-adapters.d.ts +22 -2
  56. package/dist/index.d.ts +32 -0
  57. package/dist/index.js +6 -0
  58. package/dist/internal/index-impl/compileNativeSource.js +53 -5
  59. package/dist/internal/index-impl/createLightweightNativeImport.js +58 -4
  60. package/dist/internal/index-impl/createNativeImportFromSyntaxAst.js +17 -1
  61. package/dist/internal/index-impl/createNativeImportFromTypeScriptAst.js +28 -4
  62. package/dist/internal/index-impl/createNativeProjectImportResult.js +31 -27
  63. package/dist/internal/index-impl/createNativeProjectModuleResolutionFromPackageManifests.js +145 -0
  64. package/dist/internal/index-impl/createNativeSourcePreservation.js +34 -7
  65. package/dist/internal/index-impl/createSemanticImportSidecar.js +27 -1
  66. package/dist/internal/index-impl/createTypeScriptCompilerNativeImporterAdapter.js +16 -5
  67. package/dist/internal/index-impl/dynamicImportExpressionMetadata.js +80 -0
  68. package/dist/internal/index-impl/importMetaUrlDependencyMetadata.js +176 -0
  69. package/dist/internal/index-impl/importNativeSource.js +2 -3
  70. package/dist/internal/index-impl/moduleImportAttributeMetadata.js +232 -0
  71. package/dist/internal/index-impl/projectSemanticEditScriptToSource.js +8 -1
  72. package/dist/internal/index-impl/projectSymbolGraphClassStaticBlocks.js +148 -0
  73. package/dist/internal/index-impl/projectSymbolGraphCompilerAdvancedTypeMetadata.js +45 -0
  74. package/dist/internal/index-impl/projectSymbolGraphCompilerCallableSignatureEquivalence.js +107 -0
  75. package/dist/internal/index-impl/projectSymbolGraphCompilerClassPrivateAccessorRuntimeProof.js +280 -0
  76. package/dist/internal/index-impl/projectSymbolGraphCompilerClassShapeEquivalence.js +103 -0
  77. package/dist/internal/index-impl/projectSymbolGraphCompilerConditionalTypeEquivalence.js +242 -0
  78. package/dist/internal/index-impl/projectSymbolGraphCompilerDecoratorRuntimeProof.js +197 -0
  79. package/dist/internal/index-impl/projectSymbolGraphCompilerEnumEquivalence.js +188 -0
  80. package/dist/internal/index-impl/projectSymbolGraphCompilerFacts.js +244 -0
  81. package/dist/internal/index-impl/projectSymbolGraphCompilerIndexSignatureEquivalence.js +58 -0
  82. package/dist/internal/index-impl/projectSymbolGraphCompilerMetadata.js +168 -0
  83. package/dist/internal/index-impl/projectSymbolGraphCompilerTypeEquivalence.js +199 -0
  84. package/dist/internal/index-impl/projectSymbolGraphCompilerTypeEquivalenceProof.js +204 -0
  85. package/dist/internal/index-impl/projectSymbolGraphCompilerTypeReferenceTargetEquivalence.js +99 -0
  86. package/dist/internal/index-impl/projectSymbolGraphCssModuleRecords.js +264 -0
  87. package/dist/internal/index-impl/projectSymbolGraphCssModuleScanners.js +242 -0
  88. package/dist/internal/index-impl/projectSymbolGraphCssModuleUtils.js +152 -0
  89. package/dist/internal/index-impl/projectSymbolGraphCssModules.js +82 -0
  90. package/dist/internal/index-impl/projectSymbolGraphJsxComponentImports.js +170 -0
  91. package/dist/internal/index-impl/projectSymbolGraphJsxComponentProviderLookup.js +167 -0
  92. package/dist/internal/index-impl/projectSymbolGraphJsxComponentWrappers.js +150 -0
  93. package/dist/internal/index-impl/projectSymbolGraphJsxContextTargets.js +71 -0
  94. package/dist/internal/index-impl/projectSymbolGraphJsxContextValues.js +212 -0
  95. package/dist/internal/index-impl/projectSymbolGraphJsxEventHandlers.js +172 -0
  96. package/dist/internal/index-impl/projectSymbolGraphJsxHookEffects.js +124 -0
  97. package/dist/internal/index-impl/projectSymbolGraphJsxHooks.js +281 -0
  98. package/dist/internal/index-impl/projectSymbolGraphJsxMemberComponents.js +139 -0
  99. package/dist/internal/index-impl/projectSymbolGraphJsxPropFlows.js +320 -0
  100. package/dist/internal/index-impl/projectSymbolGraphJsxPropValues.js +145 -0
  101. package/dist/internal/index-impl/projectSymbolGraphJsxProviderFlows.js +133 -0
  102. package/dist/internal/index-impl/projectSymbolGraphJsxRecords.js +315 -0
  103. package/dist/internal/index-impl/projectSymbolGraphJsxRenderCollections.js +155 -0
  104. package/dist/internal/index-impl/projectSymbolGraphJsxRenderReturns.js +291 -0
  105. package/dist/internal/index-impl/projectSymbolGraphJsxRenderRisk.js +279 -0
  106. package/dist/internal/index-impl/projectSymbolGraphModuleDeclarationShapes.js +138 -0
  107. package/dist/internal/index-impl/projectSymbolGraphModuleResolution.js +89 -87
  108. package/dist/internal/index-impl/projectSymbolGraphPackageConditions.js +314 -0
  109. package/dist/internal/index-impl/projectSymbolGraphReExportImportTargets.js +43 -0
  110. package/dist/internal/index-impl/projectSymbolGraphReExports.js +55 -1
  111. package/dist/internal/index-impl/projectSymbolGraphRuntimeRegions.js +108 -0
  112. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefAliases.js +307 -0
  113. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefLexical.js +320 -0
  114. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefOwners.js +50 -0
  115. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefRecordBuilders.js +112 -0
  116. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefRecords.js +238 -0
  117. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefStructural.js +104 -0
  118. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefStructuralNormalize.js +242 -0
  119. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefUseHashes.js +107 -0
  120. package/dist/internal/index-impl/projectSymbolGraphSourceMapGeneratedBoundary.js +111 -0
  121. package/dist/internal/index-impl/projectSymbolGraphSourceRecords.js +268 -0
  122. package/dist/internal/index-impl/projectSymbolGraphSourceRecordsOwnership.js +309 -0
  123. package/dist/internal/index-impl/replaySemanticEditProjection.js +53 -39
  124. package/dist/internal/index-impl/runtimeOrderEvidenceBinding.js +151 -0
  125. package/dist/internal/index-impl/runtimeOrderProofSurfaces.js +253 -0
  126. package/dist/internal/index-impl/semanticEditCallsiteArgumentMerge.js +319 -0
  127. package/dist/internal/index-impl/semanticEditExplicitSourceReplacement.js +7 -2
  128. package/dist/internal/index-impl/semanticEditProjectionRecord.js +8 -0
  129. package/dist/internal/index-impl/semanticEditReplayDiagnostics.js +7 -2
  130. package/dist/internal/index-impl/semanticEditReplayOutputBinding.js +61 -0
  131. package/dist/internal/index-impl/semanticEditReplayRerunRoute.js +27 -0
  132. package/dist/internal/index-impl/semanticEditReplaySourceReplacement.js +6 -1
  133. package/dist/internal/index-impl/semanticEditRuntimeOrderReasons.js +320 -0
  134. package/dist/internal/index-impl/semanticEditScriptClassification.js +90 -5
  135. package/dist/internal/index-impl/semanticEditScripts.js +42 -5
  136. package/dist/internal/index-impl/semanticEditTypeSyntaxReasons.js +134 -0
  137. package/dist/internal/index-impl/semanticIndexFromNativeDeclarations.js +11 -5
  138. package/dist/internal/index-impl/semanticPatchBundleComposition.js +166 -0
  139. package/dist/internal/index-impl/semanticStructuralDiffRecords.js +150 -0
  140. package/dist/internal/index-impl/sourceMapGeneratedBoundaryGate.js +185 -0
  141. package/dist/internal/index-impl/staticMemberLiteral.js +31 -0
  142. package/dist/internal/index-impl/staticOptionalMemberReference.js +22 -0
  143. package/dist/internal/index-impl/syntaxAstSourcePreservation.js +273 -0
  144. package/dist/internal/index-impl/syntaxCommonJsModuleDeclarationEntries.js +297 -0
  145. package/dist/internal/index-impl/syntaxModuleDeclarationEntries.js +56 -132
  146. package/dist/internal/index-impl/syntaxModuleEntryRecords.js +160 -0
  147. package/dist/internal/index-impl/typeScriptCompilerAdvancedTypeShapes.js +160 -0
  148. package/dist/internal/index-impl/typeScriptCompilerAssignabilityOracle.js +97 -0
  149. package/dist/internal/index-impl/typeScriptCompilerClassApi.js +238 -0
  150. package/dist/internal/index-impl/typeScriptCompilerDecoratorMetadata.js +290 -0
  151. package/dist/internal/index-impl/typeScriptCompilerEnumShape.js +279 -0
  152. package/dist/internal/index-impl/typeScriptCompilerFacts.js +294 -0
  153. package/dist/internal/index-impl/typeScriptCompilerInferenceSyntax.js +170 -0
  154. package/dist/internal/index-impl/typeScriptCompilerReferenceGraph.js +186 -0
  155. package/dist/internal/index-impl/typeScriptCompilerSymbolIdentity.js +294 -0
  156. package/dist/internal/index-impl/typeScriptCompilerTypeReferenceTargets.js +142 -0
  157. package/dist/internal/index-impl/typeScriptDeclaration.js +10 -38
  158. package/dist/internal/index-impl/typeScriptModuleDeclarationEntries.js +52 -15
  159. package/dist/internal/index-impl/typeScriptSourceFilePreservation.js +296 -0
  160. package/dist/js-ts-safe-member-class-invariants.js +247 -0
  161. package/dist/js-ts-safe-member-merge-result.js +23 -3
  162. package/dist/js-ts-safe-member-merge.js +28 -4
  163. package/dist/js-ts-safe-merge-binding-patterns.js +170 -0
  164. package/dist/js-ts-safe-merge-context.js +1 -0
  165. package/dist/js-ts-safe-merge-jsx-attribute-fallback.js +314 -0
  166. package/dist/js-ts-safe-merge-jsx-attribute-parser.js +277 -0
  167. package/dist/js-ts-safe-merge-jsx-child-expression-fallback.js +161 -0
  168. package/dist/js-ts-safe-merge-jsx-child-expression-merge.js +319 -0
  169. package/dist/js-ts-safe-merge-jsx-child-expression-parser.js +300 -0
  170. package/dist/js-ts-safe-merge-parse-declarations.js +46 -2
  171. package/dist/js-ts-safe-merge-parse-statements.js +8 -0
  172. package/dist/js-ts-safe-merge-plan.js +3 -1
  173. package/dist/js-ts-safe-merge-semantic-edit-fallback.js +49 -0
  174. package/dist/js-ts-safe-merge-source-shape-fallbacks.js +5 -1
  175. package/dist/js-ts-safe-merge-top-level-rename-fallback.js +31 -5
  176. package/dist/js-ts-safe-merge-top-level-rename-result.js +7 -2
  177. package/dist/js-ts-safe-merge-variable-declarator-fallback.js +124 -6
  178. package/dist/js-ts-safe-merge-variable-declarator-parser.js +34 -4
  179. package/dist/js-ts-safe-merge.js +136 -0
  180. package/dist/js-ts-safe-project-merge-admission-routes.js +216 -0
  181. package/dist/js-ts-safe-project-merge-admission.js +161 -0
  182. package/dist/js-ts-safe-project-merge-ambient.js +110 -0
  183. package/dist/js-ts-safe-project-merge-core.js +85 -0
  184. package/dist/js-ts-safe-project-merge-css-module-conflicts.js +60 -0
  185. package/dist/js-ts-safe-project-merge-declaration-emit-parity.js +186 -0
  186. package/dist/js-ts-safe-project-merge-declarations.js +227 -0
  187. package/dist/js-ts-safe-project-merge-diagnostics-metadata.js +42 -0
  188. package/dist/js-ts-safe-project-merge-diagnostics-ts.js +73 -0
  189. package/dist/js-ts-safe-project-merge-diagnostics.js +283 -0
  190. package/dist/js-ts-safe-project-merge-evidence-routing.js +38 -0
  191. package/dist/js-ts-safe-project-merge-files.js +70 -0
  192. package/dist/js-ts-safe-project-merge-global-augmentation-compatibility.js +99 -0
  193. package/dist/js-ts-safe-project-merge-graph-conflicts.js +90 -2
  194. package/dist/js-ts-safe-project-merge-graph-delta-commonjs-interop.js +108 -0
  195. package/dist/js-ts-safe-project-merge-graph-delta-compiler-conflicts.js +179 -0
  196. package/dist/js-ts-safe-project-merge-graph-delta-compiler-details.js +189 -0
  197. package/dist/js-ts-safe-project-merge-graph-delta-conflicts.js +51 -184
  198. package/dist/js-ts-safe-project-merge-graph-delta-identity-conflicts.js +202 -0
  199. package/dist/js-ts-safe-project-merge-graph-delta-inference-syntax.js +80 -0
  200. package/dist/js-ts-safe-project-merge-graph-delta-module-declarations.js +155 -0
  201. package/dist/js-ts-safe-project-merge-graph-limits.js +16 -1
  202. package/dist/js-ts-safe-project-merge-graph.js +37 -5
  203. package/dist/js-ts-safe-project-merge-import-removal.js +292 -0
  204. package/dist/js-ts-safe-project-merge-jsx-graph-conflict-details.js +235 -0
  205. package/dist/js-ts-safe-project-merge-jsx-graph-conflicts.js +173 -0
  206. package/dist/js-ts-safe-project-merge-jsx-prop-contracts.js +86 -0
  207. package/dist/js-ts-safe-project-merge-jsx-render-branch-proof.js +189 -0
  208. package/dist/js-ts-safe-project-merge-missing-evidence.js +310 -0
  209. package/dist/js-ts-safe-project-merge-move-rename.js +209 -0
  210. package/dist/js-ts-safe-project-merge-proof-conflicts.js +44 -0
  211. package/dist/js-ts-safe-project-merge-proof-levels.js +320 -0
  212. package/dist/js-ts-safe-project-merge-quality-gates.js +140 -0
  213. package/dist/js-ts-safe-project-merge-routing-calibration.js +125 -0
  214. package/dist/js-ts-safe-project-merge-runtime-region-conflicts.js +156 -0
  215. package/dist/js-ts-safe-project-merge-scope-use-def-conflicts.js +292 -0
  216. package/dist/js-ts-safe-project-merge-semantic-equivalence-proof.js +175 -0
  217. package/dist/js-ts-safe-project-merge-semantic-replay-proof.js +311 -0
  218. package/dist/js-ts-safe-project-merge-semantic-replay-routes.js +179 -0
  219. package/dist/js-ts-safe-project-merge-source-span-conflicts.js +310 -0
  220. package/dist/js-ts-safe-project-merge-source-span-roundtrip-proof.js +172 -0
  221. package/dist/js-ts-safe-project-merge-split-merge-admission.js +96 -0
  222. package/dist/js-ts-safe-project-merge-split-merge-records.js +320 -0
  223. package/dist/js-ts-safe-project-merge-split-merge-shapes.js +234 -0
  224. package/dist/js-ts-safe-project-merge-split-merge.js +218 -0
  225. package/dist/js-ts-safe-project-merge-summary.js +320 -0
  226. package/dist/js-ts-safe-project-merge-symbol-move-admission.js +63 -0
  227. package/dist/js-ts-safe-project-merge-symbol-move-default-admission.js +143 -0
  228. package/dist/js-ts-safe-project-merge-symbol-move-risks.js +213 -0
  229. package/dist/js-ts-safe-project-merge-symbol-move.js +316 -0
  230. package/dist/js-ts-safe-project-merge-symbol-rename-admission.js +59 -0
  231. package/dist/js-ts-safe-project-merge-symbol-rename-default-admission.js +111 -0
  232. package/dist/js-ts-safe-project-merge-symbol-rename.js +319 -0
  233. package/dist/js-ts-safe-project-merge-ts-options.js +205 -0
  234. package/dist/js-ts-safe-project-merge-ts-program.js +268 -0
  235. package/dist/js-ts-safe-project-merge-typed-property-rename-rebase-utils.js +69 -0
  236. package/dist/js-ts-safe-project-merge-typed-property-rename-rebase.js +317 -0
  237. package/dist/js-ts-safe-project-merge-unsupported-surfaces.js +319 -0
  238. package/dist/js-ts-safe-project-merge.js +171 -172
  239. package/dist/js-ts-semantic-scope-use-def-bindings.js +287 -0
  240. package/dist/js-ts-semantic-scope-use-def-scan.js +241 -0
  241. package/dist/js-ts-semantic-scope-use-def-utils.js +132 -0
  242. package/dist/js-ts-semantic-scope-use-def.js +217 -0
  243. package/dist/lightweight-dependency-effects.js +28 -4
  244. package/dist/lightweight-dependency-relations.js +13 -7
  245. package/dist/lightweight-dependency-top-level.js +63 -0
  246. package/dist/native-import-language-profiles.js +27 -1
  247. package/dist/native-js-ts-importers.js +9 -5
  248. package/dist/native-parser-ast-format-profiles.js +12 -0
  249. package/dist/native-parser-html-css-format-profiles.js +85 -0
  250. package/dist/native-region-scanner-core.js +5 -3
  251. package/dist/native-region-scanner-js-commonjs.js +155 -0
  252. package/dist/native-region-scanner-js-imports.js +51 -13
  253. package/dist/native-region-scanner-js-reexports.js +79 -0
  254. package/dist/native-region-scanner-js-ts-helpers.js +23 -0
  255. package/dist/native-source-ledger-helpers.js +1 -1
  256. package/dist/native-source-ledger.js +24 -10
  257. package/dist/native-source-maps-ecma426.js +316 -0
  258. package/dist/native-source-maps.js +36 -6
  259. package/dist/native-source-preservation-ownership.js +292 -0
  260. package/dist/native-source-preservation-scanner.js +63 -25
  261. package/dist/native-source-preservation-types.d.ts +3 -0
  262. package/dist/semantic-import-effect-occurrences.js +242 -0
  263. package/dist/semantic-import-effect-regions.js +95 -58
  264. package/dist/semantic-import-graph-layers.js +224 -0
  265. package/dist/semantic-import-runtime-conditional-evidence.js +135 -0
  266. package/dist/semantic-import-runtime-effect-target-evidence.js +145 -0
  267. package/dist/semantic-import-runtime-exit-evidence.js +32 -0
  268. package/dist/semantic-import-runtime-import-meta-evidence.js +33 -0
  269. package/dist/semantic-import-runtime-mutation-evidence.js +155 -0
  270. package/dist/semantic-import-runtime-order-evidence.js +318 -0
  271. package/dist/semantic-import-runtime-promise-chain-evidence.js +103 -0
  272. package/dist/semantic-import-runtime-promise-combinator-evidence.js +166 -0
  273. package/dist/semantic-import-runtime-reachability-evidence.js +269 -0
  274. package/dist/semantic-import-runtime-resource-management-evidence.js +293 -0
  275. package/dist/semantic-import-runtime-switch-evidence.js +304 -0
  276. package/dist/semantic-import-runtime-throw-evidence.js +44 -0
  277. package/dist/semantic-import-runtime-try-finally-evidence.js +172 -0
  278. package/dist/semantic-import-sidecar-entry.js +4 -0
  279. package/dist/semantic-import-source-preservation.js +6 -2
  280. package/package.json +1 -1
@@ -0,0 +1,283 @@
1
+ import { hashSemanticValue } from '@shapeshift-labs/frontier-lang-kernel';
2
+ import { compactRecord, uniqueStrings } from './js-ts-safe-merge-context.js';
3
+ import { diagnosticsGateMetadata } from './js-ts-safe-project-merge-diagnostics-metadata.js';
4
+ import { collectTypeScriptDiagnostics } from './js-ts-safe-project-merge-diagnostics-ts.js';
5
+ import {
6
+ collectJsxComponentPropContractsFromFileResults,
7
+ jsxComponentPropContractConflict,
8
+ jsxComponentPropContractEvidence,
9
+ jsxComponentPropContractSummary,
10
+ matchingJsxComponentPropContracts,
11
+ normalizeJsxComponentPropContracts
12
+ } from './js-ts-safe-project-merge-jsx-prop-contracts.js';
13
+ import {
14
+ describeJsTsProjectCompilerInputs,
15
+ normalizeSuppliedDiagnostics
16
+ } from './js-ts-safe-project-merge-ts-program.js';
17
+
18
+ const projectOutputDiagnosticCode = 'project-output-diagnostic';
19
+ const projectOutputSyntaxDiagnosticCode = 'project-output-syntax-diagnostic';
20
+ const projectOutputDiagnosticsUnavailableCode = 'project-output-diagnostics-unavailable';
21
+ const projectOutputSyntaxDiagnosticsUnavailableCode = 'project-output-syntax-diagnostics-unavailable';
22
+
23
+ function createJsTsProjectMergeDiagnosticsGate(input = {}, outputFiles = [], id = 'js_ts_project_safe_merge', context = {}) {
24
+ const jsxComponentPropContracts = normalizeJsxComponentPropContracts(
25
+ input.jsxComponentPropContracts
26
+ ?? input.jsxComponentPropContractCandidates
27
+ ?? context.jsxComponentPropContracts
28
+ ?? collectJsxComponentPropContractsFromFileResults(context.fileResults)
29
+ );
30
+ const suppliedDiagnostics = normalizeSuppliedOutputDiagnostics(input);
31
+ const diagnosticsResult = suppliedDiagnostics !== undefined
32
+ ? suppliedDiagnosticsResult(input, suppliedDiagnostics)
33
+ : collectTypeScriptDiagnostics(input, outputFiles);
34
+ const diagnostics = diagnosticsResult?.diagnostics;
35
+ const metadata = diagnosticsGateMetadata(input, diagnosticsResult);
36
+ const syntaxOnly = requiresOutputSyntaxDiagnostics(input) && input.requireOutputDiagnostics !== true && input.outputDiagnostics === undefined;
37
+ if (!diagnostics && input.requireOutputDiagnostics !== true && !requiresOutputSyntaxDiagnostics(input) && !jsxComponentPropContracts.length) return undefined;
38
+ if (!diagnostics) return unavailableGate(input, id, syntaxOnly, metadata, outputFiles, jsxComponentPropContracts);
39
+ const errorDiagnostics = diagnostics.filter((diagnostic) => (
40
+ diagnostic.severity === 'error' && (!syntaxOnly || isSyntaxDiagnostic(diagnostic))
41
+ ));
42
+ const conflicts = errorDiagnostics.map((diagnostic) => diagnosticConflict(input, diagnostic, jsxComponentPropContracts));
43
+ const status = conflicts.length ? 'blocked' : 'passed';
44
+ const core = {
45
+ kind: 'frontier.lang.jsTsProjectMergeDiagnosticsGate',
46
+ version: 1,
47
+ schema: 'frontier.lang.jsTsProjectMergeDiagnosticsGate.v1',
48
+ id: `${id}_output_diagnostics`,
49
+ status,
50
+ sourcePaths: outputFiles.map((file) => file.sourcePath).filter(Boolean),
51
+ diagnostics,
52
+ conflicts,
53
+ admission: {
54
+ status: status === 'passed' ? 'auto-merge-candidate' : 'blocked',
55
+ action: status === 'passed' ? 'accept-diagnostics' : 'human-review',
56
+ reviewRequired: status !== 'passed',
57
+ autoApplyCandidate: status === 'passed',
58
+ autoMergeClaim: false,
59
+ semanticEquivalenceClaim: false,
60
+ reasonCodes: uniqueStrings(conflicts.map((conflict) => conflict.code))
61
+ },
62
+ summary: diagnosticsSummary(diagnostics, conflicts, jsxComponentPropContracts),
63
+ metadata,
64
+ evidence: [{
65
+ id: `${id}_output_diagnostics_evidence`,
66
+ kind: 'js-ts-project-output-diagnostics',
67
+ status: status === 'passed' ? 'passed' : 'failed',
68
+ summary: status === 'passed'
69
+ ? `Validated ${outputFiles.length} JS/TS output file(s) with no blocking diagnostics.`
70
+ : `Blocked JS/TS project merge on ${conflicts.length} output diagnostic conflict(s).`,
71
+ metadata: {
72
+ diagnostics: diagnostics.length,
73
+ conflicts: conflicts.length,
74
+ diagnosticSource: metadata.diagnosticSource,
75
+ compilerOptions: metadata.compilerOptions,
76
+ compilerOptionSources: metadata.compilerOptionSources,
77
+ projectReferences: metadata.projectReferences,
78
+ projectReferenceCount: metadata.projectReferenceCount,
79
+ jsxComponentPropContractCandidates: jsxComponentPropContracts.length || undefined,
80
+ syntaxOnly,
81
+ autoMergeClaim: false,
82
+ semanticEquivalenceClaim: false
83
+ }
84
+ }, ...jsxComponentPropContractEvidence(id, status, diagnostics, conflicts, metadata.diagnosticSource, jsxComponentPropContracts)]
85
+ };
86
+ return { ...core, hash: hashSemanticValue(core) };
87
+ }
88
+
89
+ function suppliedDiagnosticsResult(input, diagnostics) {
90
+ return {
91
+ diagnostics,
92
+ metadata: {
93
+ ...describeJsTsProjectCompilerInputs(input),
94
+ diagnosticSource: diagnosticSource(input),
95
+ hasTypescriptCompilerApi: Boolean(input.typescript ?? input.ts ?? input.typescriptModule)
96
+ }
97
+ };
98
+ }
99
+
100
+ function unavailableGate(input, id, syntaxOnly = false, metadata = {}, outputFiles = [], jsxComponentPropContracts = []) {
101
+ const code = syntaxOnly ? projectOutputSyntaxDiagnosticsUnavailableCode : projectOutputDiagnosticsUnavailableCode;
102
+ const diagnosticConflict = {
103
+ code,
104
+ gateId: 'project-output-diagnostics',
105
+ message: syntaxOnly
106
+ ? 'Project output syntax diagnostics are required but no TypeScript compiler API or supplied syntax diagnostics were provided.'
107
+ : 'Project output diagnostics are required but no TypeScript compiler API or supplied diagnostics were provided.',
108
+ details: { required: input.requireOutputDiagnostics === true, syntaxRequired: requiresOutputSyntaxDiagnostics(input) }
109
+ };
110
+ const conflicts = [
111
+ ...(input.requireOutputDiagnostics === true || requiresOutputSyntaxDiagnostics(input) ? [diagnosticConflict] : []),
112
+ ...(jsxComponentPropContracts.length ? [jsxComponentPropContractConflict(jsxComponentPropContracts)] : [])
113
+ ];
114
+ const gateConflicts = conflicts.length ? conflicts : [diagnosticConflict];
115
+ const core = {
116
+ kind: 'frontier.lang.jsTsProjectMergeDiagnosticsGate',
117
+ version: 1,
118
+ schema: 'frontier.lang.jsTsProjectMergeDiagnosticsGate.v1',
119
+ id: `${id}_output_diagnostics`,
120
+ status: 'blocked',
121
+ sourcePaths: outputFiles.map((file) => file.sourcePath).filter(Boolean),
122
+ diagnostics: [],
123
+ conflicts: gateConflicts,
124
+ admission: {
125
+ status: 'blocked',
126
+ action: 'human-review',
127
+ reviewRequired: true,
128
+ autoApplyCandidate: false,
129
+ autoMergeClaim: false,
130
+ semanticEquivalenceClaim: false,
131
+ reasonCodes: uniqueStrings(gateConflicts.map((conflict) => conflict.code))
132
+ },
133
+ summary: diagnosticsSummary([], gateConflicts, jsxComponentPropContracts),
134
+ metadata,
135
+ evidence: [{
136
+ id: `${id}_output_diagnostics_evidence`,
137
+ kind: 'js-ts-project-output-diagnostics',
138
+ status: 'failed',
139
+ summary: gateConflicts.map((conflict) => conflict.message).join(' '),
140
+ metadata: {
141
+ diagnostics: 0,
142
+ conflicts: gateConflicts.length,
143
+ diagnosticSource: 'missing',
144
+ compilerOptions: metadata.compilerOptions,
145
+ compilerOptionSources: metadata.compilerOptionSources,
146
+ projectReferences: metadata.projectReferences,
147
+ projectReferenceCount: metadata.projectReferenceCount,
148
+ jsxComponentPropContractCandidates: jsxComponentPropContracts.length || undefined,
149
+ syntaxOnly
150
+ }
151
+ }, ...jsxComponentPropContractEvidence(id, 'blocked', [], gateConflicts, 'missing', jsxComponentPropContracts)]
152
+ };
153
+ return { ...core, hash: hashSemanticValue(core) };
154
+ }
155
+
156
+ function diagnosticConflict(input, diagnostic, jsxComponentPropContracts = []) {
157
+ const syntax = isSyntaxDiagnostic(diagnostic);
158
+ const matchingContracts = matchingJsxComponentPropContracts(diagnostic, jsxComponentPropContracts);
159
+ return compactRecord({
160
+ code: syntax ? projectOutputSyntaxDiagnosticCode : projectOutputDiagnosticCode,
161
+ gateId: 'project-output-diagnostics',
162
+ message: `${syntax ? 'Project output syntax diagnostic' : 'Project output diagnostic'} ${diagnostic.code}: ${diagnostic.message}`,
163
+ sourcePath: diagnostic.sourcePath,
164
+ details: {
165
+ diagnostic,
166
+ syntax,
167
+ projectRoot: input.projectRoot,
168
+ jsxComponentPropContracts: matchingContracts.length ? matchingContracts : undefined
169
+ }
170
+ });
171
+ }
172
+
173
+ function diagnosticsSummary(diagnostics, conflicts, jsxComponentPropContracts = []) {
174
+ const bySeverity = {};
175
+ const bySource = {};
176
+ const byPhase = {};
177
+ for (const diagnostic of diagnostics) {
178
+ bySeverity[diagnostic.severity] = (bySeverity[diagnostic.severity] ?? 0) + 1;
179
+ bySource[diagnostic.source ?? 'unknown'] = (bySource[diagnostic.source ?? 'unknown'] ?? 0) + 1;
180
+ byPhase[diagnostic.phase ?? 'unknown'] = (byPhase[diagnostic.phase ?? 'unknown'] ?? 0) + 1;
181
+ }
182
+ return {
183
+ diagnostics: diagnostics.length,
184
+ conflicts: conflicts.length,
185
+ errors: diagnostics.filter((diagnostic) => diagnostic.severity === 'error').length,
186
+ warnings: diagnostics.filter((diagnostic) => diagnostic.severity === 'warning').length,
187
+ syntaxErrors: diagnostics.filter((diagnostic) => diagnostic.severity === 'error' && isSyntaxDiagnostic(diagnostic)).length,
188
+ bySeverity,
189
+ bySource,
190
+ byPhase,
191
+ ...jsxComponentPropContractSummary(jsxComponentPropContracts)
192
+ };
193
+ }
194
+
195
+ function normalizeSuppliedOutputDiagnostics(input) {
196
+ const hasOutputDiagnostics = Object.hasOwn(input, 'outputDiagnostics');
197
+ const hasOutputSyntaxDiagnostics = Object.hasOwn(input, 'outputSyntaxDiagnostics')
198
+ || Object.hasOwn(input, 'mergedOutputSyntaxDiagnostics')
199
+ || input.syntaxDiagnostics?.output !== undefined
200
+ || input.syntaxDiagnostics?.merged !== undefined;
201
+ if (!hasOutputDiagnostics && !hasOutputSyntaxDiagnostics) return undefined;
202
+ return [
203
+ ...normalizeSuppliedDiagnosticsWithPhase(input.outputDiagnostics, undefined),
204
+ ...normalizeSuppliedDiagnosticsWithPhase(input.outputSyntaxDiagnostics, 'syntax'),
205
+ ...normalizeSuppliedDiagnosticsWithPhase(input.mergedOutputSyntaxDiagnostics, 'syntax'),
206
+ ...normalizeSuppliedDiagnosticsWithPhase(input.syntaxDiagnostics?.output, 'syntax'),
207
+ ...normalizeSuppliedDiagnosticsWithPhase(input.syntaxDiagnostics?.merged, 'syntax')
208
+ ];
209
+ }
210
+
211
+ function normalizeSuppliedDiagnosticsWithPhase(value, fallbackPhase) {
212
+ if (value === undefined) return [];
213
+ const rawDiagnostics = Array.isArray(value) ? value : [value].filter(Boolean);
214
+ const normalized = normalizeSuppliedDiagnostics(value);
215
+ return normalized.map((diagnostic, index) => withDiagnosticPhase(diagnostic, suppliedDiagnosticPhase(rawDiagnostics[index], fallbackPhase)));
216
+ }
217
+
218
+ function withDiagnosticPhase(diagnostic, phase) {
219
+ const normalizedPhase = normalizeDiagnosticPhase(phase);
220
+ const syntax = diagnostic.syntax === true || normalizedPhase === 'syntax' || isSyntaxDiagnostic(diagnostic);
221
+ return compactRecord({
222
+ ...diagnostic,
223
+ phase: normalizedPhase,
224
+ syntax: syntax ? true : undefined
225
+ });
226
+ }
227
+
228
+ function suppliedDiagnosticPhase(diagnostic, fallbackPhase) {
229
+ return diagnostic?.phase
230
+ ?? diagnostic?.diagnosticPhase
231
+ ?? diagnostic?.kind
232
+ ?? diagnostic?.type
233
+ ?? (diagnostic?.syntax === true ? 'syntax' : undefined)
234
+ ?? fallbackPhase;
235
+ }
236
+
237
+ function requiresOutputSyntaxDiagnostics(input) {
238
+ return input.requireOutputSyntaxDiagnostics === true
239
+ || input.requireOutputSyntaxGate === true
240
+ || input.requireMergedOutputSyntaxDiagnostics === true
241
+ || input.requireSyntaxGate === true;
242
+ }
243
+
244
+ function isSyntaxDiagnostic(diagnostic) {
245
+ if (diagnostic.syntax === true) return true;
246
+ const text = [
247
+ diagnostic.phase,
248
+ diagnostic.kind,
249
+ diagnostic.category,
250
+ diagnostic.type,
251
+ diagnostic.source,
252
+ diagnostic.ruleId,
253
+ diagnostic.name,
254
+ diagnostic.code
255
+ ].filter(Boolean).join(' ').toLowerCase();
256
+ return /\bsyntax\b|\bsyntactic\b|\bparse\b|\bparser\b/.test(text) || isTypeScriptSyntaxDiagnosticCode(diagnostic.code);
257
+ }
258
+
259
+ function isTypeScriptSyntaxDiagnosticCode(code) {
260
+ const match = /^TS(\d+)$/.exec(String(code ?? ''));
261
+ if (!match) return false;
262
+ const numeric = Number(match[1]);
263
+ return numeric >= 1000 && numeric < 2000;
264
+ }
265
+
266
+ function normalizeDiagnosticPhase(value) {
267
+ if (typeof value !== 'string') return undefined;
268
+ const lowered = value.toLowerCase();
269
+ if (lowered.includes('syntax') || lowered.includes('syntactic') || lowered.includes('parse')) return 'syntax';
270
+ if (lowered.includes('semantic') || lowered.includes('type')) return 'semantic';
271
+ return value;
272
+ }
273
+
274
+ function diagnosticSource(input) {
275
+ if (input.outputDiagnostics !== undefined && (input.outputSyntaxDiagnostics !== undefined || input.mergedOutputSyntaxDiagnostics !== undefined)) {
276
+ return 'supplied-mixed';
277
+ }
278
+ if (input.outputDiagnostics !== undefined) return 'supplied';
279
+ if (input.outputSyntaxDiagnostics !== undefined || input.mergedOutputSyntaxDiagnostics !== undefined || input.syntaxDiagnostics) return 'supplied-syntax';
280
+ return 'typescript-compiler-api';
281
+ }
282
+
283
+ export { createJsTsProjectMergeDiagnosticsGate };
@@ -0,0 +1,38 @@
1
+ function failedEvidenceMissingItems(evidence = []) {
2
+ return evidence
3
+ .filter((record) => record?.status === 'failed' && isPlainObject(record.metadata?.nextMissingEvidence))
4
+ .map((record) => {
5
+ const nextMissingEvidence = record.metadata.nextMissingEvidence;
6
+ const route = nextMissingEvidence.route;
7
+ return compactRecord({
8
+ ...nextMissingEvidence,
9
+ status: nextMissingEvidence.status ?? 'missing-or-failed',
10
+ evidenceId: record.id,
11
+ routeId: nextMissingEvidence.routeId ?? route?.id,
12
+ routeLane: nextMissingEvidence.routeLane ?? route?.lane,
13
+ routeNext: nextMissingEvidence.routeNext ?? route?.next,
14
+ autoMergeClaim: false,
15
+ semanticEquivalenceClaim: false
16
+ });
17
+ });
18
+ }
19
+
20
+ function fileAdmissionEvidenceRecords(files = []) {
21
+ return files.flatMap((file) => [
22
+ ...recordArraysWithSuffix(file.summary, 'AdmissionEvidence'),
23
+ ...recordArraysWithSuffix(file.metadata, 'Admissions')
24
+ ]);
25
+ }
26
+
27
+ function recordArraysWithSuffix(record, suffix) {
28
+ if (!isPlainObject(record)) return [];
29
+ return Object.entries(record)
30
+ .filter(([key, value]) => key.endsWith(suffix) && Array.isArray(value))
31
+ .flatMap(([, value]) => value)
32
+ .filter((value) => value?.kind && value?.id);
33
+ }
34
+
35
+ function isPlainObject(value) { return Boolean(value && typeof value === 'object' && !Array.isArray(value)); }
36
+ function compactRecord(record) { return Object.fromEntries(Object.entries(record).filter(([, value]) => value !== undefined)); }
37
+
38
+ export { failedEvidenceMissingItems, fileAdmissionEvidenceRecords };
@@ -0,0 +1,70 @@
1
+ export function normalizeProjectFiles(input) {
2
+ if (Array.isArray(input.files)) return input.files.map(normalizeFileRecord).sort(bySourcePath);
3
+ const base = normalizeFileMap(input.baseFiles);
4
+ const worker = normalizeFileMap(input.workerFiles);
5
+ const head = normalizeFileMap(input.headFiles);
6
+ const paths = [...new Set([...base.keys(), ...worker.keys(), ...head.keys()])].sort();
7
+ const field = (entry, name) => entry?.[name];
8
+ return paths.map((sourcePath) => normalizeFileRecord({
9
+ sourcePath,
10
+ baseSourceText: field(base.get(sourcePath), 'sourceText'),
11
+ workerSourceText: field(worker.get(sourcePath), 'sourceText'),
12
+ headSourceText: field(head.get(sourcePath), 'sourceText'),
13
+ baseParserTriviaEvidence: field(base.get(sourcePath), 'parserTriviaEvidence'),
14
+ workerParserTriviaEvidence: field(worker.get(sourcePath), 'parserTriviaEvidence'),
15
+ headParserTriviaEvidence: field(head.get(sourcePath), 'parserTriviaEvidence')
16
+ }));
17
+ }
18
+
19
+ function normalizeFileRecord(record = {}) {
20
+ return {
21
+ sourcePath: record.sourcePath ?? record.path,
22
+ language: record.language,
23
+ baseSourceText: stringOrUndefined(record.baseSourceText ?? record.baseText),
24
+ workerSourceText: stringOrUndefined(record.workerSourceText ?? record.workerText),
25
+ headSourceText: stringOrUndefined(record.headSourceText ?? record.headText),
26
+ workerDeleted: record.workerDeleted === true,
27
+ headDeleted: record.headDeleted === true,
28
+ policy: record.policy,
29
+ mergePolicy: record.mergePolicy,
30
+ parserTriviaEvidence: record.parserTriviaEvidence,
31
+ baseParserTriviaEvidence: record.baseParserTriviaEvidence,
32
+ workerParserTriviaEvidence: record.workerParserTriviaEvidence,
33
+ headParserTriviaEvidence: record.headParserTriviaEvidence,
34
+ outputParserTriviaEvidence: record.outputParserTriviaEvidence
35
+ };
36
+ }
37
+
38
+ function normalizeFileMap(value) {
39
+ const map = new Map();
40
+ if (!value) return map;
41
+ if (value instanceof Map) {
42
+ for (const [sourcePath, entry] of value) map.set(String(sourcePath), normalizeMapFileEntry(entry));
43
+ return map;
44
+ }
45
+ if (Array.isArray(value)) {
46
+ for (const entry of value) {
47
+ if (!entry?.sourcePath && !entry?.path) continue;
48
+ map.set(String(entry.sourcePath ?? entry.path), normalizeMapFileEntry(entry));
49
+ }
50
+ return map;
51
+ }
52
+ for (const [sourcePath, entry] of Object.entries(value)) map.set(sourcePath, normalizeMapFileEntry(entry));
53
+ return map;
54
+ }
55
+
56
+ function normalizeMapFileEntry(entry) {
57
+ if (entry && typeof entry === 'object') return {
58
+ sourceText: String(entry.sourceText ?? entry.text ?? ''),
59
+ parserTriviaEvidence: entry.parserTriviaEvidence
60
+ };
61
+ return { sourceText: String(entry ?? '') };
62
+ }
63
+
64
+ function stringOrUndefined(value) {
65
+ return typeof value === 'string' ? value : undefined;
66
+ }
67
+
68
+ function bySourcePath(left, right) {
69
+ return String(left.sourcePath ?? '').localeCompare(String(right.sourcePath ?? ''));
70
+ }
@@ -0,0 +1,99 @@
1
+ import { hashSemanticValue } from '@shapeshift-labs/frontier-lang-kernel';
2
+ import { compactRecord } from './js-ts-safe-merge-context.js';
3
+
4
+ const GlobalAugmentationCompatibilityRoute = Object.freeze({
5
+ routeId: 'prove-global-augmentation-compatibility',
6
+ routeLane: 'module-runtime-global-augmentation',
7
+ routeNext: 'supply-source-bound-global-augmentation-compatibility-proof'
8
+ });
9
+
10
+ function globalAugmentationCompatibilityAssessment(input = {}, options = {}) {
11
+ const proof = globalAugmentationCompatibilityProofFor(input, options);
12
+ const reasonCodes = [];
13
+ if (!proof) reasonCodes.push('global-augmentation-compatibility-proof-missing');
14
+ else {
15
+ if (proof.status !== 'passed') reasonCodes.push('global-augmentation-compatibility-proof-status-not-passed');
16
+ if (proof.kind !== undefined && proof.kind !== 'frontier.lang.globalAugmentationCompatibilityProof') reasonCodes.push('global-augmentation-compatibility-proof-schema-mismatch');
17
+ if (proof.schema !== undefined && proof.schema !== 'frontier.lang.globalAugmentationCompatibilityProof.v1') reasonCodes.push('global-augmentation-compatibility-proof-schema-mismatch');
18
+ if (proof.surfaceKind !== 'global-augmentation') reasonCodes.push('global-augmentation-compatibility-proof-surface-mismatch');
19
+ if (input.sourcePath && proof.sourcePath !== input.sourcePath) reasonCodes.push('global-augmentation-compatibility-proof-source-path-mismatch');
20
+ if (!sourceHashesMatch(input, proof)) reasonCodes.push('global-augmentation-compatibility-proof-stale-source');
21
+ if (input.moduleName && proof.moduleName !== input.moduleName) reasonCodes.push('global-augmentation-compatibility-proof-surface-mismatch');
22
+ if (input.moduleDeclarationRecordId && proof.moduleDeclarationRecordId !== input.moduleDeclarationRecordId) reasonCodes.push('global-augmentation-compatibility-shape-hash-mismatch');
23
+ if (input.moduleDeclarationShapeHash && proof.moduleDeclarationShapeHash !== input.moduleDeclarationShapeHash) reasonCodes.push('global-augmentation-compatibility-shape-hash-mismatch');
24
+ if (input.moduleDeclarationSignatureHash && proof.moduleDeclarationSignatureHash !== input.moduleDeclarationSignatureHash) reasonCodes.push('global-augmentation-compatibility-shape-hash-mismatch');
25
+ if (input.sourceSpanHash && proof.sourceSpanHash !== input.sourceSpanHash) reasonCodes.push('global-augmentation-compatibility-source-span-mismatch');
26
+ if (input.declarationOutputHash && proof.declarationOutputHash !== input.declarationOutputHash) reasonCodes.push('global-augmentation-compatibility-declaration-output-mismatch');
27
+ if (!proof.declarationOutputGateId || !proof.declarationOutputHash) reasonCodes.push('global-augmentation-compatibility-declaration-output-missing');
28
+ if (!proof.consumerDiagnosticsGateId || !proof.consumerDiagnosticsHash) reasonCodes.push('global-augmentation-compatibility-consumer-diagnostics-missing');
29
+ if (proof.consumerDiagnosticsPassed !== true || input.consumerDiagnosticsPassed === false) reasonCodes.push('global-augmentation-compatibility-consumer-diagnostics-failed');
30
+ if (!Array.isArray(proof.consumerEntrypoints) || proof.consumerEntrypoints.length === 0) reasonCodes.push('global-augmentation-compatibility-consumer-diagnostics-missing');
31
+ if (proof.globalCompatibilityClaim !== 'declaration-boundary-consumer-diagnostics-only'
32
+ || proof.hostRuntimeInteractionClaim !== false
33
+ || proof.runtimeEquivalenceClaim !== false
34
+ || proof.semanticEquivalenceClaim !== false
35
+ || proof.autoMergeClaim !== false) reasonCodes.push('global-augmentation-compatibility-proof-claim-bearing');
36
+ }
37
+ const status = proof && reasonCodes.length === 0 ? 'passed' : proof ? 'failed' : 'missing';
38
+ return {
39
+ status,
40
+ ...GlobalAugmentationCompatibilityRoute,
41
+ reasonCodes: uniqueStrings(reasonCodes),
42
+ record: compactRecord({
43
+ schema: 'frontier.lang.globalAugmentationCompatibilityProofAssessment.v1',
44
+ status,
45
+ proofStatus: proof?.status,
46
+ proofId: proof?.id,
47
+ proofHash: proof?.proofHash,
48
+ ...GlobalAugmentationCompatibilityRoute,
49
+ reasonCodes: uniqueStrings(reasonCodes),
50
+ expected: compactRecord(input),
51
+ globalCompatibilityClaim: 'declaration-boundary-consumer-diagnostics-only',
52
+ autoMergeClaim: false,
53
+ semanticEquivalenceClaim: false,
54
+ runtimeEquivalenceClaim: false,
55
+ hostRuntimeInteractionClaim: false
56
+ })
57
+ };
58
+ }
59
+
60
+ function globalAugmentationCompatibilityProofFor(input = {}, options = {}) {
61
+ const proofs = [
62
+ options.globalAugmentationCompatibilityProof,
63
+ ...(Array.isArray(options.globalAugmentationCompatibilityProofs) ? options.globalAugmentationCompatibilityProofs : [])
64
+ ].filter(Boolean);
65
+ return proofs.find((proof) => (
66
+ proof.moduleDeclarationRecordId === input.moduleDeclarationRecordId
67
+ || proof.sourcePath === input.sourcePath
68
+ && proof.moduleName === (input.moduleName ?? 'global')
69
+ && proof.surfaceKind === 'global-augmentation'
70
+ ));
71
+ }
72
+
73
+ function sourceHashesMatch(input, proof) {
74
+ const expectedHashes = uniqueStrings([input.sourceHash, ...(input.sourceHashes ?? [])]);
75
+ if (!expectedHashes.length) return true;
76
+ const proofHashes = uniqueStrings([proof.sourceHash, ...(proof.sourceHashes ?? [])]);
77
+ return expectedHashes.every((hash) => proofHashes.includes(hash));
78
+ }
79
+
80
+ function sourceSpanHash(sourceSpan) {
81
+ return sourceSpan ? hashSemanticValue({
82
+ start: sourceSpan.start,
83
+ end: sourceSpan.end,
84
+ startLine: sourceSpan.startLine,
85
+ startColumn: sourceSpan.startColumn,
86
+ endLine: sourceSpan.endLine,
87
+ endColumn: sourceSpan.endColumn
88
+ }) : undefined;
89
+ }
90
+
91
+ function uniqueStrings(values) {
92
+ return [...new Set(values.filter((value) => typeof value === 'string' && value.length > 0))];
93
+ }
94
+
95
+ export {
96
+ GlobalAugmentationCompatibilityRoute,
97
+ globalAugmentationCompatibilityAssessment,
98
+ sourceSpanHash
99
+ };
@@ -1,5 +1,6 @@
1
1
  import { hashSemanticValue } from '@shapeshift-labs/frontier-lang-kernel';
2
2
  import { compactRecord } from './js-ts-safe-merge-context.js';
3
+ import { cssModuleUseSiteBlockerConflicts, isResolvedCssModuleImportEdge } from './js-ts-safe-project-merge-css-module-conflicts.js';
3
4
  import { projectGraphDeltaConflicts } from './js-ts-safe-project-merge-graph-delta-conflicts.js';
4
5
 
5
6
  function outputProjectGraphConflicts(projectSymbolGraph) {
@@ -7,6 +8,7 @@ function outputProjectGraphConflicts(projectSymbolGraph) {
7
8
  projectSymbolGraph = projectSymbolGraph?.projectSymbolGraph ?? projectSymbolGraph;
8
9
  const importEdges = Array.isArray(projectSymbolGraph?.importEdges) ? projectSymbolGraph.importEdges : [];
9
10
  const exportEdges = Array.isArray(projectSymbolGraph?.exportEdges) ? projectSymbolGraph.exportEdges : [];
11
+ const cssModuleBlockers = Array.isArray(projectSymbolGraph?.cssModuleUseSiteBlockers) ? projectSymbolGraph.cssModuleUseSiteBlockers : [];
10
12
  const missingModuleGroups = new Map();
11
13
  const missingSymbolGroups = new Map();
12
14
  for (const edge of importEdges) {
@@ -26,6 +28,7 @@ function outputProjectGraphConflicts(projectSymbolGraph) {
26
28
  }
27
29
  return [
28
30
  ...limitConflicts,
31
+ ...cssModuleUseSiteBlockerConflicts(cssModuleBlockers),
29
32
  ...[...missingModuleGroups.values()].map(projectGraphMissingImportConflict),
30
33
  ...[...missingSymbolGroups.values()].map(projectGraphMissingTargetConflict),
31
34
  ...duplicateReExportIdentityConflicts(projectSymbolGraph?.reExportIdentities)
@@ -48,7 +51,9 @@ function projectGraphMissingImportConflict(group) {
48
51
  resolvedModulePath: edge.resolvedModulePath,
49
52
  edgeIds: uniqueStrings(group.map((record) => record.id)),
50
53
  importKinds: uniqueStrings(group.map((record) => record.importKind)),
51
- importedNames: uniqueStrings(group.map((record) => record.importedName))
54
+ importedNames: uniqueStrings(group.map((record) => record.importedName)),
55
+ moduleEdgeFailureReasonCodes: uniqueStrings(group.flatMap(moduleEdgeFailureReasonCodes)),
56
+ moduleEdgeEvidence: group.map(moduleEdgeEvidence)
52
57
  })
53
58
  };
54
59
  }
@@ -73,7 +78,9 @@ function projectGraphMissingTargetConflict(group) {
73
78
  edgeIds: uniqueStrings(group.map((record) => record.id)),
74
79
  importKinds: uniqueStrings(group.map((record) => record.importKind)),
75
80
  importedNames: uniqueStrings(group.map((record) => record.importedName)),
76
- localNames: uniqueStrings(group.map((record) => record.localName))
81
+ localNames: uniqueStrings(group.map((record) => record.localName)),
82
+ moduleEdgeFailureReasonCodes: uniqueStrings(['project-output-symbol-unresolved', ...group.flatMap(moduleEdgeFailureReasonCodes)]),
83
+ moduleEdgeEvidence: group.map(moduleEdgeEvidence)
77
84
  })
78
85
  };
79
86
  }
@@ -86,6 +93,7 @@ function isMissingProjectImportTargetEdge(edge, exportEdges = []) {
86
93
  return hasResolvedProjectModule(edge)
87
94
  && Boolean(projectImportTargetName(edge))
88
95
  && !edge.resolvedTargetSymbolId
96
+ && !isResolvedCssModuleImportEdge(edge)
89
97
  && !commonJsRequireResolvedByExportAssignment(edge, exportEdges);
90
98
  }
91
99
 
@@ -160,6 +168,11 @@ function reExportIdentityKey(record) {
160
168
  function reExportIdentityFingerprint(record) {
161
169
  return hashSemanticValue({
162
170
  moduleSpecifier: record.moduleSpecifier,
171
+ hasImportAttributes: record.hasImportAttributes,
172
+ importAttributeCount: record.importAttributeCount,
173
+ importAttributeKeys: record.importAttributeKeys,
174
+ importAttributeHash: record.importAttributeHash,
175
+ importAttributes: record.importAttributes,
163
176
  exportedName: record.exportedName,
164
177
  importedName: record.importedName,
165
178
  localName: record.localName,
@@ -176,6 +189,11 @@ function reExportIdentityFingerprint(record) {
176
189
  function reExportIdentityDetails(record) {
177
190
  return compactRecord({
178
191
  moduleSpecifier: record.moduleSpecifier,
192
+ hasImportAttributes: record.hasImportAttributes,
193
+ importAttributeCount: record.importAttributeCount,
194
+ importAttributeKeys: record.importAttributeKeys,
195
+ importAttributeHash: record.importAttributeHash,
196
+ importAttributes: record.importAttributes,
179
197
  exportedName: record.exportedName,
180
198
  importedName: record.importedName,
181
199
  localName: record.localName,
@@ -189,6 +207,76 @@ function reExportIdentityDetails(record) {
189
207
  });
190
208
  }
191
209
 
210
+ function moduleEdgeFailureReasonCodes(edge) {
211
+ return [
212
+ edge?.packageRuntimeConditionReasonCode,
213
+ edge?.packageEnvironmentConditionReasonCode,
214
+ edge?.packageResolutionReasonCode,
215
+ typeof edge?.resolutionKind === 'string' && edge.resolutionKind.endsWith('-missing') ? edge.resolutionKind : undefined
216
+ ];
217
+ }
218
+
219
+ function moduleEdgeEvidence(edge) {
220
+ return compactRecord(Object.fromEntries(moduleEdgeEvidenceFields.map((field) => [field, edge?.[field]])));
221
+ }
222
+
223
+ const moduleEdgeEvidenceFields = [
224
+ 'id',
225
+ 'sourcePath',
226
+ 'moduleSpecifier',
227
+ 'resolutionKind',
228
+ 'resolvedModulePath',
229
+ 'targetDocumentId',
230
+ 'resolvedTargetSymbolId',
231
+ 'edgeKind',
232
+ 'importKind',
233
+ 'exportKind',
234
+ 'importedName',
235
+ 'exportedName',
236
+ 'localName',
237
+ 'isTypeOnly',
238
+ 'resolutionPathVariant',
239
+ 'packageName',
240
+ 'packageSubpath',
241
+ 'packageExportKey',
242
+ 'packageExportCondition',
243
+ 'packageExportTarget',
244
+ 'packageImportKey',
245
+ 'packageImportCondition',
246
+ 'packageImportTarget',
247
+ 'packageType',
248
+ 'packageRuntimeCondition',
249
+ 'packageRuntimeConditionEvidenceSource',
250
+ 'packageRuntimeConditionEdgeKind',
251
+ 'packageRuntimeConditionCandidates',
252
+ 'packageRuntimeConditionReasonCode',
253
+ 'packageEnvironmentCondition',
254
+ 'packageEnvironmentConditionEvidenceSource',
255
+ 'packageEnvironmentConditionCandidates',
256
+ 'packageEnvironmentConditionReasonCode',
257
+ 'packageWorkspaceRootAmbiguous',
258
+ 'packageWorkspaceRoots',
259
+ 'packageResolutionReasonCode',
260
+ 'hostDependencyKind',
261
+ 'hostDependencyBase',
262
+ 'hostDependencyExpressionHash',
263
+ 'hostDependencyStaticSpecifierEvidence',
264
+ 'hostDependencyRuntimeResolutionClaim',
265
+ 'hostDependencyResolutionProofRequired',
266
+ 'dynamicImport',
267
+ 'dynamicImportSpecifierKind',
268
+ 'dynamicImportExpressionText',
269
+ 'dynamicImportExpressionHash',
270
+ 'dynamicImportStaticSpecifierEvidence',
271
+ 'dynamicImportRuntimeResolutionClaim',
272
+ 'dynamicImportResolutionProofRequired',
273
+ 'hasImportAttributes',
274
+ 'importAttributeCount',
275
+ 'importAttributeKeys',
276
+ 'importAttributeHash',
277
+ 'importAttributes'
278
+ ];
279
+
192
280
  function stableKey(parts) {
193
281
  const values = parts.map((part) => part === undefined || part === null ? '' : String(part));
194
282
  return values.some(Boolean) ? values.join('#') : undefined;