@shapeshift-labs/frontier-lang-compiler 0.2.150 → 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 (276) 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-sidecar.d.ts +3 -2
  52. package/dist/declarations/semantic-structural-diff.d.ts +94 -0
  53. package/dist/declarations/source-preservation.d.ts +32 -1
  54. package/dist/declarations/target-adapters.d.ts +22 -2
  55. package/dist/index.d.ts +31 -0
  56. package/dist/index.js +5 -0
  57. package/dist/internal/index-impl/compileNativeSource.js +53 -5
  58. package/dist/internal/index-impl/createLightweightNativeImport.js +58 -4
  59. package/dist/internal/index-impl/createNativeImportFromSyntaxAst.js +17 -1
  60. package/dist/internal/index-impl/createNativeImportFromTypeScriptAst.js +28 -4
  61. package/dist/internal/index-impl/createNativeProjectImportResult.js +31 -27
  62. package/dist/internal/index-impl/createNativeProjectModuleResolutionFromPackageManifests.js +145 -0
  63. package/dist/internal/index-impl/createNativeSourcePreservation.js +34 -7
  64. package/dist/internal/index-impl/createSemanticImportSidecar.js +27 -1
  65. package/dist/internal/index-impl/createTypeScriptCompilerNativeImporterAdapter.js +16 -5
  66. package/dist/internal/index-impl/dynamicImportExpressionMetadata.js +80 -0
  67. package/dist/internal/index-impl/importMetaUrlDependencyMetadata.js +176 -0
  68. package/dist/internal/index-impl/importNativeSource.js +2 -3
  69. package/dist/internal/index-impl/moduleImportAttributeMetadata.js +232 -0
  70. package/dist/internal/index-impl/projectSemanticEditScriptToSource.js +8 -1
  71. package/dist/internal/index-impl/projectSymbolGraphClassStaticBlocks.js +148 -0
  72. package/dist/internal/index-impl/projectSymbolGraphCompilerAdvancedTypeMetadata.js +45 -0
  73. package/dist/internal/index-impl/projectSymbolGraphCompilerCallableSignatureEquivalence.js +107 -0
  74. package/dist/internal/index-impl/projectSymbolGraphCompilerClassPrivateAccessorRuntimeProof.js +280 -0
  75. package/dist/internal/index-impl/projectSymbolGraphCompilerClassShapeEquivalence.js +103 -0
  76. package/dist/internal/index-impl/projectSymbolGraphCompilerConditionalTypeEquivalence.js +242 -0
  77. package/dist/internal/index-impl/projectSymbolGraphCompilerDecoratorRuntimeProof.js +197 -0
  78. package/dist/internal/index-impl/projectSymbolGraphCompilerEnumEquivalence.js +188 -0
  79. package/dist/internal/index-impl/projectSymbolGraphCompilerFacts.js +244 -0
  80. package/dist/internal/index-impl/projectSymbolGraphCompilerIndexSignatureEquivalence.js +58 -0
  81. package/dist/internal/index-impl/projectSymbolGraphCompilerMetadata.js +168 -0
  82. package/dist/internal/index-impl/projectSymbolGraphCompilerTypeEquivalence.js +199 -0
  83. package/dist/internal/index-impl/projectSymbolGraphCompilerTypeEquivalenceProof.js +204 -0
  84. package/dist/internal/index-impl/projectSymbolGraphCompilerTypeReferenceTargetEquivalence.js +99 -0
  85. package/dist/internal/index-impl/projectSymbolGraphCssModuleRecords.js +264 -0
  86. package/dist/internal/index-impl/projectSymbolGraphCssModuleScanners.js +242 -0
  87. package/dist/internal/index-impl/projectSymbolGraphCssModuleUtils.js +152 -0
  88. package/dist/internal/index-impl/projectSymbolGraphCssModules.js +82 -0
  89. package/dist/internal/index-impl/projectSymbolGraphJsxComponentImports.js +170 -0
  90. package/dist/internal/index-impl/projectSymbolGraphJsxComponentProviderLookup.js +167 -0
  91. package/dist/internal/index-impl/projectSymbolGraphJsxComponentWrappers.js +150 -0
  92. package/dist/internal/index-impl/projectSymbolGraphJsxContextTargets.js +71 -0
  93. package/dist/internal/index-impl/projectSymbolGraphJsxContextValues.js +212 -0
  94. package/dist/internal/index-impl/projectSymbolGraphJsxEventHandlers.js +172 -0
  95. package/dist/internal/index-impl/projectSymbolGraphJsxHookEffects.js +124 -0
  96. package/dist/internal/index-impl/projectSymbolGraphJsxHooks.js +281 -0
  97. package/dist/internal/index-impl/projectSymbolGraphJsxMemberComponents.js +139 -0
  98. package/dist/internal/index-impl/projectSymbolGraphJsxPropFlows.js +320 -0
  99. package/dist/internal/index-impl/projectSymbolGraphJsxPropValues.js +145 -0
  100. package/dist/internal/index-impl/projectSymbolGraphJsxProviderFlows.js +133 -0
  101. package/dist/internal/index-impl/projectSymbolGraphJsxRecords.js +315 -0
  102. package/dist/internal/index-impl/projectSymbolGraphJsxRenderCollections.js +155 -0
  103. package/dist/internal/index-impl/projectSymbolGraphJsxRenderReturns.js +291 -0
  104. package/dist/internal/index-impl/projectSymbolGraphJsxRenderRisk.js +279 -0
  105. package/dist/internal/index-impl/projectSymbolGraphModuleDeclarationShapes.js +138 -0
  106. package/dist/internal/index-impl/projectSymbolGraphModuleResolution.js +89 -87
  107. package/dist/internal/index-impl/projectSymbolGraphPackageConditions.js +314 -0
  108. package/dist/internal/index-impl/projectSymbolGraphReExportImportTargets.js +43 -0
  109. package/dist/internal/index-impl/projectSymbolGraphReExports.js +55 -1
  110. package/dist/internal/index-impl/projectSymbolGraphRuntimeRegions.js +108 -0
  111. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefAliases.js +307 -0
  112. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefLexical.js +320 -0
  113. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefOwners.js +50 -0
  114. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefRecordBuilders.js +112 -0
  115. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefRecords.js +238 -0
  116. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefStructural.js +104 -0
  117. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefStructuralNormalize.js +242 -0
  118. package/dist/internal/index-impl/projectSymbolGraphScopeUseDefUseHashes.js +107 -0
  119. package/dist/internal/index-impl/projectSymbolGraphSourceMapGeneratedBoundary.js +111 -0
  120. package/dist/internal/index-impl/projectSymbolGraphSourceRecords.js +268 -0
  121. package/dist/internal/index-impl/projectSymbolGraphSourceRecordsOwnership.js +309 -0
  122. package/dist/internal/index-impl/replaySemanticEditProjection.js +53 -39
  123. package/dist/internal/index-impl/runtimeOrderEvidenceBinding.js +151 -0
  124. package/dist/internal/index-impl/runtimeOrderProofSurfaces.js +253 -0
  125. package/dist/internal/index-impl/semanticEditCallsiteArgumentMerge.js +319 -0
  126. package/dist/internal/index-impl/semanticEditExplicitSourceReplacement.js +7 -2
  127. package/dist/internal/index-impl/semanticEditProjectionRecord.js +8 -0
  128. package/dist/internal/index-impl/semanticEditReplayDiagnostics.js +7 -2
  129. package/dist/internal/index-impl/semanticEditReplayOutputBinding.js +61 -0
  130. package/dist/internal/index-impl/semanticEditReplayRerunRoute.js +27 -0
  131. package/dist/internal/index-impl/semanticEditReplaySourceReplacement.js +6 -1
  132. package/dist/internal/index-impl/semanticEditRuntimeOrderReasons.js +320 -0
  133. package/dist/internal/index-impl/semanticEditScriptClassification.js +90 -5
  134. package/dist/internal/index-impl/semanticEditScripts.js +42 -5
  135. package/dist/internal/index-impl/semanticEditTypeSyntaxReasons.js +134 -0
  136. package/dist/internal/index-impl/semanticIndexFromNativeDeclarations.js +11 -5
  137. package/dist/internal/index-impl/semanticStructuralDiffRecords.js +150 -0
  138. package/dist/internal/index-impl/sourceMapGeneratedBoundaryGate.js +185 -0
  139. package/dist/internal/index-impl/staticMemberLiteral.js +31 -0
  140. package/dist/internal/index-impl/staticOptionalMemberReference.js +22 -0
  141. package/dist/internal/index-impl/syntaxAstSourcePreservation.js +273 -0
  142. package/dist/internal/index-impl/syntaxCommonJsModuleDeclarationEntries.js +297 -0
  143. package/dist/internal/index-impl/syntaxModuleDeclarationEntries.js +56 -132
  144. package/dist/internal/index-impl/syntaxModuleEntryRecords.js +160 -0
  145. package/dist/internal/index-impl/typeScriptCompilerAdvancedTypeShapes.js +160 -0
  146. package/dist/internal/index-impl/typeScriptCompilerAssignabilityOracle.js +97 -0
  147. package/dist/internal/index-impl/typeScriptCompilerClassApi.js +238 -0
  148. package/dist/internal/index-impl/typeScriptCompilerDecoratorMetadata.js +290 -0
  149. package/dist/internal/index-impl/typeScriptCompilerEnumShape.js +279 -0
  150. package/dist/internal/index-impl/typeScriptCompilerFacts.js +294 -0
  151. package/dist/internal/index-impl/typeScriptCompilerInferenceSyntax.js +170 -0
  152. package/dist/internal/index-impl/typeScriptCompilerReferenceGraph.js +186 -0
  153. package/dist/internal/index-impl/typeScriptCompilerSymbolIdentity.js +294 -0
  154. package/dist/internal/index-impl/typeScriptCompilerTypeReferenceTargets.js +142 -0
  155. package/dist/internal/index-impl/typeScriptDeclaration.js +10 -38
  156. package/dist/internal/index-impl/typeScriptModuleDeclarationEntries.js +52 -15
  157. package/dist/internal/index-impl/typeScriptSourceFilePreservation.js +296 -0
  158. package/dist/js-ts-safe-member-class-invariants.js +247 -0
  159. package/dist/js-ts-safe-member-merge-result.js +23 -3
  160. package/dist/js-ts-safe-member-merge.js +28 -4
  161. package/dist/js-ts-safe-merge-binding-patterns.js +170 -0
  162. package/dist/js-ts-safe-merge-jsx-attribute-fallback.js +151 -157
  163. package/dist/js-ts-safe-merge-jsx-attribute-parser.js +277 -0
  164. package/dist/js-ts-safe-merge-jsx-child-expression-fallback.js +161 -0
  165. package/dist/js-ts-safe-merge-jsx-child-expression-merge.js +319 -0
  166. package/dist/js-ts-safe-merge-jsx-child-expression-parser.js +300 -0
  167. package/dist/js-ts-safe-merge-parse-declarations.js +46 -2
  168. package/dist/js-ts-safe-merge-parse-statements.js +8 -0
  169. package/dist/js-ts-safe-merge-semantic-edit-fallback.js +13 -5
  170. package/dist/js-ts-safe-merge-source-shape-fallbacks.js +3 -1
  171. package/dist/js-ts-safe-merge-top-level-rename-fallback.js +31 -5
  172. package/dist/js-ts-safe-merge-top-level-rename-result.js +7 -2
  173. package/dist/js-ts-safe-merge-variable-declarator-fallback.js +124 -6
  174. package/dist/js-ts-safe-merge-variable-declarator-parser.js +34 -4
  175. package/dist/js-ts-safe-merge.js +136 -0
  176. package/dist/js-ts-safe-project-merge-admission-routes.js +216 -0
  177. package/dist/js-ts-safe-project-merge-admission.js +161 -0
  178. package/dist/js-ts-safe-project-merge-ambient.js +110 -0
  179. package/dist/js-ts-safe-project-merge-core.js +85 -0
  180. package/dist/js-ts-safe-project-merge-css-module-conflicts.js +60 -0
  181. package/dist/js-ts-safe-project-merge-declaration-emit-parity.js +186 -0
  182. package/dist/js-ts-safe-project-merge-declarations.js +227 -0
  183. package/dist/js-ts-safe-project-merge-diagnostics-metadata.js +42 -0
  184. package/dist/js-ts-safe-project-merge-diagnostics-ts.js +73 -0
  185. package/dist/js-ts-safe-project-merge-diagnostics.js +283 -0
  186. package/dist/js-ts-safe-project-merge-evidence-routing.js +38 -0
  187. package/dist/js-ts-safe-project-merge-files.js +70 -0
  188. package/dist/js-ts-safe-project-merge-global-augmentation-compatibility.js +99 -0
  189. package/dist/js-ts-safe-project-merge-graph-conflicts.js +90 -2
  190. package/dist/js-ts-safe-project-merge-graph-delta-commonjs-interop.js +108 -0
  191. package/dist/js-ts-safe-project-merge-graph-delta-compiler-conflicts.js +179 -0
  192. package/dist/js-ts-safe-project-merge-graph-delta-compiler-details.js +189 -0
  193. package/dist/js-ts-safe-project-merge-graph-delta-conflicts.js +51 -184
  194. package/dist/js-ts-safe-project-merge-graph-delta-identity-conflicts.js +202 -0
  195. package/dist/js-ts-safe-project-merge-graph-delta-inference-syntax.js +80 -0
  196. package/dist/js-ts-safe-project-merge-graph-delta-module-declarations.js +155 -0
  197. package/dist/js-ts-safe-project-merge-graph-limits.js +16 -1
  198. package/dist/js-ts-safe-project-merge-graph.js +37 -5
  199. package/dist/js-ts-safe-project-merge-import-removal.js +292 -0
  200. package/dist/js-ts-safe-project-merge-jsx-graph-conflict-details.js +235 -0
  201. package/dist/js-ts-safe-project-merge-jsx-graph-conflicts.js +173 -0
  202. package/dist/js-ts-safe-project-merge-jsx-prop-contracts.js +86 -0
  203. package/dist/js-ts-safe-project-merge-jsx-render-branch-proof.js +189 -0
  204. package/dist/js-ts-safe-project-merge-missing-evidence.js +310 -0
  205. package/dist/js-ts-safe-project-merge-move-rename.js +209 -0
  206. package/dist/js-ts-safe-project-merge-proof-conflicts.js +44 -0
  207. package/dist/js-ts-safe-project-merge-proof-levels.js +320 -0
  208. package/dist/js-ts-safe-project-merge-quality-gates.js +140 -0
  209. package/dist/js-ts-safe-project-merge-routing-calibration.js +125 -0
  210. package/dist/js-ts-safe-project-merge-runtime-region-conflicts.js +156 -0
  211. package/dist/js-ts-safe-project-merge-scope-use-def-conflicts.js +292 -0
  212. package/dist/js-ts-safe-project-merge-semantic-equivalence-proof.js +175 -0
  213. package/dist/js-ts-safe-project-merge-semantic-replay-proof.js +311 -0
  214. package/dist/js-ts-safe-project-merge-semantic-replay-routes.js +179 -0
  215. package/dist/js-ts-safe-project-merge-source-span-conflicts.js +310 -0
  216. package/dist/js-ts-safe-project-merge-source-span-roundtrip-proof.js +172 -0
  217. package/dist/js-ts-safe-project-merge-split-merge-admission.js +96 -0
  218. package/dist/js-ts-safe-project-merge-split-merge-records.js +320 -0
  219. package/dist/js-ts-safe-project-merge-split-merge-shapes.js +234 -0
  220. package/dist/js-ts-safe-project-merge-split-merge.js +218 -0
  221. package/dist/js-ts-safe-project-merge-summary.js +320 -0
  222. package/dist/js-ts-safe-project-merge-symbol-move-admission.js +63 -0
  223. package/dist/js-ts-safe-project-merge-symbol-move-default-admission.js +143 -0
  224. package/dist/js-ts-safe-project-merge-symbol-move-risks.js +213 -0
  225. package/dist/js-ts-safe-project-merge-symbol-move.js +316 -0
  226. package/dist/js-ts-safe-project-merge-symbol-rename-admission.js +59 -0
  227. package/dist/js-ts-safe-project-merge-symbol-rename-default-admission.js +111 -0
  228. package/dist/js-ts-safe-project-merge-symbol-rename.js +319 -0
  229. package/dist/js-ts-safe-project-merge-ts-options.js +205 -0
  230. package/dist/js-ts-safe-project-merge-ts-program.js +268 -0
  231. package/dist/js-ts-safe-project-merge-typed-property-rename-rebase-utils.js +69 -0
  232. package/dist/js-ts-safe-project-merge-typed-property-rename-rebase.js +317 -0
  233. package/dist/js-ts-safe-project-merge-unsupported-surfaces.js +319 -0
  234. package/dist/js-ts-safe-project-merge.js +170 -171
  235. package/dist/js-ts-semantic-scope-use-def-bindings.js +287 -0
  236. package/dist/js-ts-semantic-scope-use-def-scan.js +241 -0
  237. package/dist/js-ts-semantic-scope-use-def-utils.js +132 -0
  238. package/dist/js-ts-semantic-scope-use-def.js +217 -0
  239. package/dist/lightweight-dependency-effects.js +28 -4
  240. package/dist/lightweight-dependency-relations.js +13 -7
  241. package/dist/lightweight-dependency-top-level.js +63 -0
  242. package/dist/native-import-language-profiles.js +27 -1
  243. package/dist/native-js-ts-importers.js +9 -5
  244. package/dist/native-parser-ast-format-profiles.js +12 -0
  245. package/dist/native-parser-html-css-format-profiles.js +85 -0
  246. package/dist/native-region-scanner-core.js +5 -3
  247. package/dist/native-region-scanner-js-commonjs.js +155 -0
  248. package/dist/native-region-scanner-js-imports.js +51 -13
  249. package/dist/native-region-scanner-js-reexports.js +79 -0
  250. package/dist/native-region-scanner-js-ts-helpers.js +23 -0
  251. package/dist/native-source-ledger-helpers.js +1 -1
  252. package/dist/native-source-ledger.js +24 -10
  253. package/dist/native-source-maps-ecma426.js +316 -0
  254. package/dist/native-source-maps.js +36 -6
  255. package/dist/native-source-preservation-ownership.js +292 -0
  256. package/dist/native-source-preservation-scanner.js +63 -25
  257. package/dist/native-source-preservation-types.d.ts +3 -0
  258. package/dist/semantic-import-effect-occurrences.js +242 -0
  259. package/dist/semantic-import-effect-regions.js +95 -58
  260. package/dist/semantic-import-graph-layers.js +224 -0
  261. package/dist/semantic-import-runtime-conditional-evidence.js +135 -0
  262. package/dist/semantic-import-runtime-effect-target-evidence.js +145 -0
  263. package/dist/semantic-import-runtime-exit-evidence.js +32 -0
  264. package/dist/semantic-import-runtime-import-meta-evidence.js +33 -0
  265. package/dist/semantic-import-runtime-mutation-evidence.js +155 -0
  266. package/dist/semantic-import-runtime-order-evidence.js +318 -0
  267. package/dist/semantic-import-runtime-promise-chain-evidence.js +103 -0
  268. package/dist/semantic-import-runtime-promise-combinator-evidence.js +166 -0
  269. package/dist/semantic-import-runtime-reachability-evidence.js +269 -0
  270. package/dist/semantic-import-runtime-resource-management-evidence.js +293 -0
  271. package/dist/semantic-import-runtime-switch-evidence.js +304 -0
  272. package/dist/semantic-import-runtime-throw-evidence.js +44 -0
  273. package/dist/semantic-import-runtime-try-finally-evidence.js +172 -0
  274. package/dist/semantic-import-sidecar-entry.js +4 -0
  275. package/dist/semantic-import-source-preservation.js +6 -2
  276. package/package.json +1 -1
@@ -0,0 +1,292 @@
1
+ import { hashSemanticValue } from '@shapeshift-labs/frontier-lang-kernel';
2
+ import { JsTsSafeMergeConflictCodes, JsTsSafeMergeStatuses, jsTsSafeMergeGateOrder } from './js-ts-safe-merge-constants.js';
3
+ import { compactRecord, createMergeContext, sameStatementText, uniqueStrings } from './js-ts-safe-merge-context.js';
4
+ import { scanJsTsTopLevelLedger } from './js-ts-safe-merge-ledger.js';
5
+ import { analyzeImportRemovalUseDefEvidence, LexicalUseDefReasonCodes } from './js-ts-semantic-scope-use-def.js';
6
+
7
+ const ImportRemovalUsageProofConflictCode = 'project-import-removal-usage-proof-unavailable';
8
+ const ImportRemovalUsageProofGateId = 'project-import-removal-usage-proof';
9
+ const ImportRemovalUsageProofOperation = 'merged-import-removal-usage-proof';
10
+ const ImportRemovalLexicalUseDefConflictCode = 'project-import-removal-lexical-use-def-blocked';
11
+ const ImportRemovalLexicalUseDefGateId = 'project-import-removal-lexical-use-def';
12
+
13
+ function maybeMergeImportSpecifierRemovalFile(file, context, result, input) {
14
+ const usageProof = analyzeNarrowImportSpecifierRemoval(file, context, result);
15
+ if (!usageProof) return undefined;
16
+ if (usageProof.lexicalUseDefEvidence?.status === 'blocked') {
17
+ return blockedImportRemovalLexicalUseDefFile(file, context, result, usageProof);
18
+ }
19
+ if (!hasImportRemovalUsageProofInput(input)) return blockedImportRemovalUsageProofFile(file, context, result, usageProof);
20
+ const admission = admittedImportRemovalUsageProofAdmission();
21
+ const mergeResult = importRemovalUsageProofMergeResult(context, result, usageProof, input, admission);
22
+ return compactRecord({
23
+ kind: 'frontier.lang.jsTsProjectSafeMergeFile',
24
+ version: 1,
25
+ sourcePath: file.sourcePath,
26
+ language: context.language,
27
+ status: 'merged',
28
+ operation: ImportRemovalUsageProofOperation,
29
+ outputSourceText: usageProof.outputSourceText,
30
+ outputHash: hashText(usageProof.outputSourceText),
31
+ baseHash: hashText(file.baseSourceText),
32
+ workerHash: hashText(usageProof.outputSourceText),
33
+ headHash: hashText(file.headSourceText ?? file.baseSourceText),
34
+ result: mergeResult,
35
+ conflicts: [],
36
+ admission,
37
+ summary: mergeResult.summary,
38
+ conflictKeys: [`source#${file.sourcePath}`],
39
+ metadata: mergeResult.metadata
40
+ });
41
+ }
42
+
43
+ function analyzeNarrowImportSpecifierRemoval(file, context, result) {
44
+ const conflicts = result.conflicts ?? [];
45
+ const removalConflicts = conflicts.filter((conflict) => conflict.code === JsTsSafeMergeConflictCodes.importSpecifierRemoved);
46
+ if (result.status !== JsTsSafeMergeStatuses.blocked || conflicts.length !== 1 || removalConflicts.length !== 1) return undefined;
47
+ const conflict = removalConflicts[0];
48
+ const missing = Array.isArray(conflict.details?.missing) ? conflict.details.missing : [];
49
+ if (conflict.side !== 'worker' || missing.length !== 1) return undefined;
50
+ const baseSourceText = file.baseSourceText;
51
+ const workerSourceText = file.workerDeleted ? undefined : file.workerSourceText ?? baseSourceText;
52
+ const headSourceText = file.headDeleted ? undefined : file.headSourceText ?? baseSourceText;
53
+ if (typeof baseSourceText !== 'string' || typeof workerSourceText !== 'string' || typeof headSourceText !== 'string') return undefined;
54
+ if (headSourceText !== baseSourceText) return undefined;
55
+ return analyzeLedgers(file, context, result, baseSourceText, workerSourceText, headSourceText, conflict, missing[0]);
56
+ }
57
+
58
+ function analyzeLedgers(file, context, result, baseSourceText, workerSourceText, headSourceText, conflict, removedSpecifier) {
59
+ const scanContext = createMergeContext({
60
+ id: `${result.id}_import_removal_usage_probe`,
61
+ sourcePath: context.sourcePath,
62
+ language: context.language
63
+ });
64
+ const baseLedger = scanJsTsTopLevelLedger(baseSourceText, 'base', scanContext);
65
+ const workerLedger = scanJsTsTopLevelLedger(workerSourceText, 'worker', scanContext);
66
+ const headLedger = scanJsTsTopLevelLedger(headSourceText, 'head', scanContext);
67
+ if (scanContext.conflicts.length) return undefined;
68
+ if (baseLedger.entries.length !== workerLedger.entries.length || baseLedger.entries.length !== headLedger.entries.length) return undefined;
69
+ const importKey = conflict.details?.key;
70
+ let removal;
71
+ for (let index = 0; index < baseLedger.entries.length; index += 1) {
72
+ const baseEntry = baseLedger.entries[index];
73
+ const workerEntry = workerLedger.entries[index];
74
+ const headEntry = headLedger.entries[index];
75
+ if (!headEntryMatchesBase(baseEntry, headEntry) || baseEntry.kind !== workerEntry.kind || baseEntry.key !== workerEntry.key) return undefined;
76
+ if (baseEntry.kind === 'import' && baseEntry.key === importKey) {
77
+ removal = importSpecifierRemovalUsageProof(baseEntry, workerEntry, removedSpecifier);
78
+ if (!removal) return undefined;
79
+ } else if (!sameStatementText(baseEntry.text, workerEntry.text)) return undefined;
80
+ }
81
+ if (!removal) return undefined;
82
+ const lexicalUseDefEvidence = analyzeImportRemovalUseDefEvidence({
83
+ sourcePath: file.sourcePath,
84
+ sourceText: workerSourceText,
85
+ moduleSpecifier: removal.moduleSpecifier,
86
+ removedSpecifier: removal.removedSpecifier,
87
+ importedName: removal.importedName,
88
+ localName: removal.localName,
89
+ typeOnly: removal.typeOnly
90
+ });
91
+ return { ...removal, importKey, sourcePath: file.sourcePath, outputSourceText: workerSourceText, lexicalUseDefEvidence };
92
+ }
93
+
94
+ function importSpecifierRemovalUsageProof(baseEntry, workerEntry, removedSpecifier) {
95
+ const baseImport = baseEntry.importInfo;
96
+ const workerImport = workerEntry.importInfo;
97
+ if (!baseImport || !workerImport || baseImport.sideEffectOnly || workerImport.sideEffectOnly) return undefined;
98
+ if (baseImport.moduleSpecifier !== workerImport.moduleSpecifier
99
+ || baseImport.typeOnly !== workerImport.typeOnly
100
+ || baseImport.defaultLocalName !== workerImport.defaultLocalName
101
+ || baseImport.namespaceLocalName !== workerImport.namespaceLocalName) {
102
+ return undefined;
103
+ }
104
+ const baseSpecifiers = baseImport.specifiers.map((specifier) => specifier.canonical);
105
+ const workerSpecifiers = workerImport.specifiers.map((specifier) => specifier.canonical);
106
+ const expectedWorkerSpecifiers = baseSpecifiers.filter((specifier) => specifier !== removedSpecifier);
107
+ if (expectedWorkerSpecifiers.length !== baseSpecifiers.length - 1) return undefined;
108
+ if (!arraysEqual(workerSpecifiers, expectedWorkerSpecifiers)) return undefined;
109
+ const removed = baseImport.specifiers.find((specifier) => specifier.canonical === removedSpecifier);
110
+ if (!removed) return undefined;
111
+ return {
112
+ removedSpecifier,
113
+ importedName: removed.importedName,
114
+ localName: removed.localName,
115
+ moduleSpecifier: baseImport.moduleSpecifier,
116
+ typeOnly: baseImport.typeOnly || removed.typeOnly,
117
+ remainingSpecifiers: workerSpecifiers
118
+ };
119
+ }
120
+
121
+ function blockedImportRemovalLexicalUseDefFile(file, context, result, usageProof) {
122
+ const reasonCodes = usageProof.lexicalUseDefEvidence.reasonCodes
123
+ .filter((code) => code !== LexicalUseDefReasonCodes.noLiveReferences);
124
+ const conflict = {
125
+ code: ImportRemovalLexicalUseDefConflictCode,
126
+ gateId: ImportRemovalLexicalUseDefGateId,
127
+ message: 'Project import specifier removal has live lexical references or namespace conflicts.',
128
+ sourcePath: file.sourcePath,
129
+ details: compactRecord({
130
+ sourcePath: file.sourcePath,
131
+ importKey: usageProof.importKey,
132
+ moduleSpecifier: usageProof.moduleSpecifier,
133
+ removedSpecifier: usageProof.removedSpecifier,
134
+ localName: usageProof.localName,
135
+ reasonCodes,
136
+ lexicalUseDefEvidence: usageProof.lexicalUseDefEvidence,
137
+ originalReasonCodes: result.admission?.reasonCodes
138
+ })
139
+ };
140
+ const conflicts = [...(result.conflicts ?? []), conflict];
141
+ return compactRecord({
142
+ kind: 'frontier.lang.jsTsProjectSafeMergeFile',
143
+ version: 1,
144
+ sourcePath: file.sourcePath,
145
+ language: context.language,
146
+ status: 'blocked',
147
+ operation: 'blocked-import-removal-lexical-use-def',
148
+ result,
149
+ conflicts,
150
+ admission: {
151
+ status: 'blocked',
152
+ action: 'human-review',
153
+ reviewRequired: true,
154
+ autoApplyCandidate: false,
155
+ autoMergeClaim: false,
156
+ semanticEquivalenceClaim: false,
157
+ reasonCodes: uniqueStrings([...conflicts.map((item) => item.code), ...reasonCodes])
158
+ },
159
+ summary: importRemovalUsageProofSummary(usageProof, conflicts.length),
160
+ conflictKeys: [`source#${file.sourcePath}`],
161
+ metadata: importRemovalUsageProofMetadata({}, usageProof, 'blocked-lexical-use-def')
162
+ });
163
+ }
164
+
165
+ function blockedImportRemovalUsageProofFile(file, context, result, usageProof) {
166
+ const conflict = {
167
+ code: ImportRemovalUsageProofConflictCode,
168
+ gateId: ImportRemovalUsageProofGateId,
169
+ message: 'Project import specifier removal requires caller-supplied TypeScript output diagnostics before automatic merge.',
170
+ sourcePath: file.sourcePath,
171
+ details: compactRecord({
172
+ sourcePath: file.sourcePath,
173
+ importKey: usageProof.importKey,
174
+ moduleSpecifier: usageProof.moduleSpecifier,
175
+ removedSpecifier: usageProof.removedSpecifier,
176
+ requiredEvidence: 'project-output-diagnostics',
177
+ originalReasonCodes: result.admission?.reasonCodes
178
+ })
179
+ };
180
+ const conflicts = [...(result.conflicts ?? []), conflict];
181
+ return compactRecord({
182
+ kind: 'frontier.lang.jsTsProjectSafeMergeFile',
183
+ version: 1,
184
+ sourcePath: file.sourcePath,
185
+ language: context.language,
186
+ status: 'blocked',
187
+ operation: 'blocked-import-removal-usage-proof',
188
+ result,
189
+ conflicts,
190
+ admission: {
191
+ status: 'blocked',
192
+ action: 'human-review',
193
+ reviewRequired: true,
194
+ autoApplyCandidate: false,
195
+ autoMergeClaim: false,
196
+ semanticEquivalenceClaim: false,
197
+ reasonCodes: uniqueStrings(conflicts.map((item) => item.code))
198
+ },
199
+ summary: importRemovalUsageProofSummary(usageProof, conflicts.length),
200
+ conflictKeys: [`source#${file.sourcePath}`],
201
+ metadata: importRemovalUsageProofMetadata({}, usageProof, 'unavailable')
202
+ });
203
+ }
204
+
205
+ function importRemovalUsageProofMergeResult(context, result, usageProof, input, admission) {
206
+ return {
207
+ kind: 'frontier.lang.jsTsSafeMerge',
208
+ version: 1,
209
+ schema: 'frontier.lang.jsTsSafeMerge.v1',
210
+ id: result.id,
211
+ status: JsTsSafeMergeStatuses.merged,
212
+ sourcePath: context.sourcePath,
213
+ language: context.language,
214
+ mergedSourceText: usageProof.outputSourceText,
215
+ outputSourceText: usageProof.outputSourceText,
216
+ conflicts: [],
217
+ gates: jsTsSafeMergeGateOrder.map((id) => ({ id, status: 'passed', reasonCodes: [] })),
218
+ admission,
219
+ summary: importRemovalUsageProofSummary(usageProof, 0),
220
+ metadata: importRemovalUsageProofMetadata(input, usageProof, 'pending-project-output-diagnostics')
221
+ };
222
+ }
223
+
224
+ function hasImportRemovalUsageProofInput(input) {
225
+ if (input.outputDiagnostics !== undefined && input.outputDiagnostics !== null) return true;
226
+ const diagnosticOptions = input.diagnosticOptions ?? input.typescriptDiagnosticOptions ?? {};
227
+ if (diagnosticOptions.semantic === false) return false;
228
+ const ts = input.typescript ?? input.ts ?? input.typescriptModule;
229
+ return Boolean(ts?.createProgram && ts?.createSourceFile);
230
+ }
231
+
232
+ function admittedImportRemovalUsageProofAdmission() {
233
+ return {
234
+ status: 'auto-merge-candidate',
235
+ action: 'apply',
236
+ reviewRequired: false,
237
+ autoApplyCandidate: true,
238
+ autoMergeClaim: false,
239
+ semanticEquivalenceClaim: false,
240
+ reasonCodes: []
241
+ };
242
+ }
243
+
244
+ function importRemovalUsageProofSummary(usageProof, conflicts) {
245
+ return {
246
+ importSpecifierAdditions: 0,
247
+ importSpecifierRemovals: 1,
248
+ importDeclarationAdditions: 0,
249
+ topLevelDeclarationAdditions: 0,
250
+ changedExistingDeclarations: 0,
251
+ conflicts,
252
+ gatesPassed: conflicts ? 0 : jsTsSafeMergeGateOrder.length,
253
+ removedImportSpecifiers: [usageProof.removedSpecifier]
254
+ };
255
+ }
256
+
257
+ function importRemovalUsageProofMetadata(input, usageProof, status) {
258
+ return {
259
+ importRemovalUsageProof: compactRecord({
260
+ status,
261
+ proof: 'project-output-diagnostics',
262
+ diagnosticSource: diagnosticProofSource(input),
263
+ sourcePath: usageProof.sourcePath,
264
+ importKey: usageProof.importKey,
265
+ moduleSpecifier: usageProof.moduleSpecifier,
266
+ removedSpecifier: usageProof.removedSpecifier,
267
+ localName: usageProof.localName,
268
+ typeOnly: usageProof.typeOnly || undefined,
269
+ lexicalUseDefEvidence: usageProof.lexicalUseDefEvidence,
270
+ autoMergeClaim: false,
271
+ semanticEquivalenceClaim: false
272
+ })
273
+ };
274
+ }
275
+
276
+ function diagnosticProofSource(input) {
277
+ if (input.outputDiagnostics !== undefined && input.outputDiagnostics !== null) return 'supplied';
278
+ if (input.typescript || input.ts || input.typescriptModule) return 'typescript-compiler-api';
279
+ return undefined;
280
+ }
281
+
282
+ function headEntryMatchesBase(baseEntry, headEntry) {
283
+ return baseEntry.kind === headEntry.kind && baseEntry.key === headEntry.key && sameStatementText(baseEntry.text, headEntry.text);
284
+ }
285
+
286
+ function arraysEqual(left, right) {
287
+ return left.length === right.length && left.every((value, index) => value === right[index]);
288
+ }
289
+
290
+ function hashText(text) { return typeof text === 'string' ? hashSemanticValue(text) : undefined; }
291
+
292
+ export { ImportRemovalUsageProofOperation, maybeMergeImportSpecifierRemovalFile };
@@ -0,0 +1,235 @@
1
+ import { compactRecord } from './js-ts-safe-merge-context.js';
2
+
3
+ function jsxPropIdentityKey(record) {
4
+ return stableKey(['jsx-prop', record?.sourcePath, record?.publicOwnerName, record?.tagKey, record?.tagName, record?.propName]);
5
+ }
6
+
7
+ function jsxChildOrderIdentityKey(record) {
8
+ return stableKey(['jsx-child-order', record?.sourcePath, record?.publicOwnerName, record?.keyPropValue]);
9
+ }
10
+
11
+ function jsxRenderRiskIdentityKey(record) {
12
+ return stableKey(['jsx-render-risk', record?.sourcePath, record?.publicOwnerName, record?.tagKey, record?.tagName]);
13
+ }
14
+
15
+ function jsxPropFingerprint(record) { return record ? stableKey([record.signatureHash]) : undefined; }
16
+
17
+ function jsxChildOrderFingerprint(record) {
18
+ return record ? stableKey([
19
+ record.tagName,
20
+ record.keyPropValue,
21
+ record.ordinal,
22
+ record.tagKey,
23
+ record.fragmentKind,
24
+ record.childOrderSignatureHash
25
+ ]) : undefined;
26
+ }
27
+
28
+ function jsxRenderRiskFingerprint(record) {
29
+ return record ? stableKey([
30
+ record.renderRiskSignatureHash,
31
+ ...(record.renderRiskKinds ?? []),
32
+ ...(record.renderRiskReasonCodes ?? []),
33
+ record.contextBoundaryKind,
34
+ record.contextName,
35
+ record.contextValuePropName,
36
+ record.contextValueExpressionHash,
37
+ record.contextValueSignatureHash,
38
+ ...jsxContextValueFingerprintParts(record.contextValueRecord),
39
+ ...(record.contextProviderPath ?? []),
40
+ ...(record.contextProviderAncestorTags ?? []),
41
+ record.contextProviderAncestorCount,
42
+ record.contextProviderNestingSignatureHash,
43
+ ...(record.hookNames ?? []),
44
+ ...(record.hookCallOrder ?? []),
45
+ record.hookCallCount,
46
+ record.hookCallOrderSignatureHash,
47
+ record.hookDependencyCount,
48
+ record.hookDependencySignatureHash,
49
+ ...jsxHookDependencyFingerprintParts(record.hookDependencyRecords),
50
+ record.hookEffectCount,
51
+ record.hookEffectSignatureHash,
52
+ JSON.stringify(record.hookEffectRecords ?? []),
53
+ ...(record.contextConsumerNames ?? []),
54
+ record.contextConsumerCount,
55
+ record.contextConsumerSignatureHash,
56
+ JSON.stringify(record.contextConsumerRecords ?? []),
57
+ record.renderReturnCount,
58
+ record.renderReturnBranchCount,
59
+ record.renderReturnSignatureHash,
60
+ JSON.stringify(record.renderReturnRecords ?? []),
61
+ ...(record.componentWrapperNames ?? []),
62
+ ...(record.componentWrapperCalleeTexts ?? []),
63
+ record.componentWrapperCount,
64
+ record.componentWrapperRenderEquivalenceClaim,
65
+ record.componentWrapperSignatureHash,
66
+ JSON.stringify(record.componentWrapperRecords ?? []),
67
+ ...(record.eventHandlerPropNames ?? []),
68
+ record.eventHandlerPropCount,
69
+ record.eventHandlerSignatureHash,
70
+ ...jsxEventHandlerFingerprintParts(record.eventHandlerPropRecords)
71
+ ]) : undefined;
72
+ }
73
+
74
+ function jsxChildOrderDetails(record) {
75
+ if (!record) return undefined;
76
+ return compactRecord({
77
+ sourcePath: record.sourcePath,
78
+ publicOwnerName: record.publicOwnerName,
79
+ tagName: record.tagName,
80
+ tagKey: record.tagKey,
81
+ keyPropValue: record.keyPropValue,
82
+ keyPropHash: record.keyPropHash,
83
+ ordinal: record.ordinal,
84
+ fragmentKind: record.fragmentKind,
85
+ childOrderSignatureHash: record.childOrderSignatureHash,
86
+ sourceHash: record.sourceHash
87
+ });
88
+ }
89
+
90
+ function jsxPropDetails(record) {
91
+ if (!record) return undefined;
92
+ return compactRecord({
93
+ sourcePath: record.sourcePath, publicOwnerName: record.publicOwnerName,
94
+ tagName: record.tagName, tagKey: record.tagKey, propName: record.propName, propKind: record.propKind,
95
+ spreadOrdinal: record.spreadOrdinal, spreadExpressionHash: record.spreadExpressionHash,
96
+ propValueProofStatus: record.propValueProofStatus, propValueReasonCode: record.propValueReasonCode,
97
+ propValueKind: record.propValueKind, propValueText: record.propValueText, propValueExpressionText: record.propValueExpressionText,
98
+ propValueReferenceRoot: record.propValueReferenceRoot, propValueReferencePath: record.propValueReferencePath,
99
+ propValueOptionalReference: record.propValueOptionalReference, propValueOptionalReferenceSegments: record.propValueOptionalReferenceSegments,
100
+ propValueOptionalReferenceSegmentIndexes: record.propValueOptionalReferenceSegmentIndexes, propValueOptionalNullishBoundaryCount: record.propValueOptionalNullishBoundaryCount,
101
+ propValueDynamicText: record.propValueDynamicText, propValueDynamicBlockerReasonCode: record.propValueDynamicBlockerReasonCode,
102
+ propValueExpressionHash: record.propValueExpressionHash, propValueSignatureHash: record.propValueSignatureHash,
103
+ componentPropRenderFlowStatus: record.componentPropRenderFlowStatus, componentPropRenderFlowReasonCode: record.componentPropRenderFlowReasonCode,
104
+ componentPropRenderFlowClaim: record.componentPropRenderFlowClaim, componentPropRenderFlowClaimScope: record.componentPropRenderFlowClaimScope,
105
+ componentPropRenderFlowRenderEquivalenceClaim: record.componentPropRenderFlowRenderEquivalenceClaim,
106
+ componentPropRenderFlowScope: record.componentPropRenderFlowScope,
107
+ componentPropRenderFlowTargetName: record.componentPropRenderFlowTargetName,
108
+ componentPropRenderFlowTargetKind: record.componentPropRenderFlowTargetKind,
109
+ componentPropRenderFlowTargetOwnerName: record.componentPropRenderFlowTargetOwnerName,
110
+ componentPropRenderFlowTargetOwnerCount: record.componentPropRenderFlowTargetOwnerCount,
111
+ componentPropRenderFlowTargetSourcePath: record.componentPropRenderFlowTargetSourcePath,
112
+ componentPropRenderFlowComponentPropName: record.componentPropRenderFlowComponentPropName,
113
+ componentPropRenderFlowRenderedTagName: record.componentPropRenderFlowRenderedTagName,
114
+ componentPropRenderFlowRenderedPropName: record.componentPropRenderFlowRenderedPropName,
115
+ componentPropRenderFlowPassthroughExpressionText: record.componentPropRenderFlowPassthroughExpressionText,
116
+ componentPropRenderFlowBindingKind: record.componentPropRenderFlowBindingKind,
117
+ componentPropRenderFlowReturnOrdinal: record.componentPropRenderFlowReturnOrdinal,
118
+ componentPropRenderFlowDynamicBlockerReasonCode: record.componentPropRenderFlowDynamicBlockerReasonCode,
119
+ componentPropRenderFlowTargetSignatureHash: record.componentPropRenderFlowTargetSignatureHash,
120
+ componentPropRenderFlowSignatureHash: record.componentPropRenderFlowSignatureHash,
121
+ ordinal: record.ordinal, signatureHash: record.signatureHash, sourceHash: record.sourceHash
122
+ });
123
+ }
124
+
125
+ function jsxRenderRiskDetails(record) {
126
+ if (!record) return undefined;
127
+ return compactRecord({
128
+ sourcePath: record.sourcePath,
129
+ publicOwnerName: record.publicOwnerName,
130
+ tagName: record.tagName,
131
+ tagKey: record.tagKey,
132
+ renderRiskKinds: record.renderRiskKinds,
133
+ renderRiskReasonCodes: record.renderRiskReasonCodes,
134
+ contextBoundaryKind: record.contextBoundaryKind,
135
+ contextName: record.contextName,
136
+ contextValuePropName: record.contextValuePropName,
137
+ contextValueExpressionHash: record.contextValueExpressionHash,
138
+ contextValueSignatureHash: record.contextValueSignatureHash,
139
+ contextValueRecord: record.contextValueRecord,
140
+ contextProviderPath: record.contextProviderPath,
141
+ contextProviderAncestorTags: record.contextProviderAncestorTags,
142
+ contextProviderAncestorCount: record.contextProviderAncestorCount,
143
+ contextProviderNestingSignatureHash: record.contextProviderNestingSignatureHash,
144
+ hookNames: record.hookNames,
145
+ hookCallOrder: record.hookCallOrder,
146
+ hookCallCount: record.hookCallCount,
147
+ hookCallOrderSignatureHash: record.hookCallOrderSignatureHash,
148
+ hookDependencyRecords: record.hookDependencyRecords,
149
+ hookDependencyCount: record.hookDependencyCount,
150
+ hookDependencySignatureHash: record.hookDependencySignatureHash,
151
+ hookEffectRecords: record.hookEffectRecords,
152
+ hookEffectCount: record.hookEffectCount,
153
+ hookEffectSignatureHash: record.hookEffectSignatureHash,
154
+ contextConsumerNames: record.contextConsumerNames,
155
+ contextConsumerRecords: record.contextConsumerRecords,
156
+ contextConsumerCount: record.contextConsumerCount,
157
+ contextConsumerSignatureHash: record.contextConsumerSignatureHash,
158
+ renderReturnRecords: record.renderReturnRecords, renderReturnCount: record.renderReturnCount, renderReturnBranchCount: record.renderReturnBranchCount, renderReturnSignatureHash: record.renderReturnSignatureHash,
159
+ componentWrapperNames: record.componentWrapperNames,
160
+ componentWrapperCalleeTexts: record.componentWrapperCalleeTexts,
161
+ componentWrapperRecords: record.componentWrapperRecords,
162
+ componentWrapperCount: record.componentWrapperCount,
163
+ componentWrapperRenderEquivalenceClaim: record.componentWrapperRenderEquivalenceClaim,
164
+ componentWrapperSignatureHash: record.componentWrapperSignatureHash,
165
+ eventHandlerPropNames: record.eventHandlerPropNames,
166
+ eventHandlerPropRecords: record.eventHandlerPropRecords,
167
+ eventHandlerPropCount: record.eventHandlerPropCount,
168
+ eventHandlerSignatureHash: record.eventHandlerSignatureHash,
169
+ renderRiskSignatureHash: record.renderRiskSignatureHash,
170
+ sourceHash: record.sourceHash
171
+ });
172
+ }
173
+
174
+ function stableKey(parts) {
175
+ const values = parts.map((part) => part === undefined || part === null ? '' : String(part));
176
+ return values.some(Boolean) ? values.join('#') : undefined;
177
+ }
178
+
179
+ function jsxRenderRiskReasonCodes(...records) {
180
+ return uniqueStrings(records.flatMap((record) => record?.renderRiskReasonCodes ?? []));
181
+ }
182
+
183
+ function jsxPropLabel(record) { return record?.propKind === 'spread' || record?.spread ? 'spread attribute' : 'prop'; }
184
+ function hasRenderRisk(record) { return Array.isArray(record?.renderRiskKinds) && record.renderRiskKinds.length > 0; }
185
+
186
+ function jsxHookDependencyFingerprintParts(records = []) {
187
+ return records.flatMap((record) => [
188
+ record?.hookName,
189
+ record?.ordinal,
190
+ record?.dependencyCount,
191
+ ...(record?.dependencyTexts ?? []),
192
+ JSON.stringify(record?.dependencyRecords ?? []),
193
+ ...(record?.dynamicDependencyReasonCodes ?? []),
194
+ record?.dependencyArrayHash,
195
+ record?.dependencySignatureHash
196
+ ]);
197
+ }
198
+
199
+ function jsxContextValueFingerprintParts(record) {
200
+ return record ? [
201
+ record.propName, record.propKind, record.proofStatus, record.reasonCode, record.literalValueKind, record.literalValueText, record.staticValueKind, record.staticValueText, record.staticReferenceRoot,
202
+ ...(record.staticReferencePath ?? []), ...(record.staticReferenceMemberPath ?? []), record.referenceBindingStatus,
203
+ record.referenceBindingScope, record.referenceBindingHash, record.dynamicValueKind, record.dynamicValueText, record.dynamicBlockerReasonCode, record.expressionHash, record.signatureHash
204
+ ] : [];
205
+ }
206
+
207
+ function jsxEventHandlerFingerprintParts(records = []) {
208
+ return records.flatMap((record) => [
209
+ record?.propName, record?.ordinal, record?.propKind,
210
+ record?.proofStatus, record?.reasonCode, record?.handlerReferenceText, record?.handlerReferenceRoot,
211
+ ...(record?.handlerReferencePath ?? []), record?.optionalReference,
212
+ ...(record?.optionalReferenceSegments ?? []), ...(record?.optionalReferenceSegmentIndexes ?? []),
213
+ record?.optionalNullishBoundaryCount, record?.dynamicExpressionText, record?.dynamicExpressionKind,
214
+ record?.dynamicBlockerReasonCode,
215
+ record?.expressionHash,
216
+ record?.signatureHash
217
+ ]);
218
+ }
219
+
220
+ function uniqueStrings(values) { return [...new Set(values.filter((value) => typeof value === 'string' && value.length > 0))]; }
221
+
222
+ export {
223
+ hasRenderRisk,
224
+ jsxChildOrderDetails,
225
+ jsxChildOrderFingerprint,
226
+ jsxChildOrderIdentityKey,
227
+ jsxPropDetails,
228
+ jsxPropFingerprint,
229
+ jsxPropIdentityKey,
230
+ jsxPropLabel,
231
+ jsxRenderRiskDetails,
232
+ jsxRenderRiskFingerprint,
233
+ jsxRenderRiskIdentityKey,
234
+ jsxRenderRiskReasonCodes
235
+ };