projscan 4.3.1 → 4.4.0

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 (677) hide show
  1. package/CONTRIBUTING.md +5 -1
  2. package/PRIVACY.md +1 -0
  3. package/README.md +253 -229
  4. package/THIRD-PARTY-NOTICES.md +31 -31
  5. package/dist/analyzers/architectureCheck.js.map +1 -1
  6. package/dist/analyzers/crossPackageImportCheck.js +3 -2
  7. package/dist/analyzers/crossPackageImportCheck.js.map +1 -1
  8. package/dist/analyzers/deadCodeCheck.js +10 -2
  9. package/dist/analyzers/deadCodeCheck.js.map +1 -1
  10. package/dist/analyzers/dependencyRiskCheck.js +1 -5
  11. package/dist/analyzers/dependencyRiskCheck.js.map +1 -1
  12. package/dist/analyzers/eslintCheck.js +3 -1
  13. package/dist/analyzers/eslintCheck.js.map +1 -1
  14. package/dist/analyzers/prettierCheck.js +16 -3
  15. package/dist/analyzers/prettierCheck.js.map +1 -1
  16. package/dist/analyzers/pythonDependencyRiskCheck.js +4 -17
  17. package/dist/analyzers/pythonDependencyRiskCheck.js.map +1 -1
  18. package/dist/analyzers/pythonLinterCheck.js +2 -12
  19. package/dist/analyzers/pythonLinterCheck.js.map +1 -1
  20. package/dist/analyzers/securityCheck.js +26 -9
  21. package/dist/analyzers/securityCheck.js.map +1 -1
  22. package/dist/analyzers/supplyChainCheck.js +6 -2
  23. package/dist/analyzers/supplyChainCheck.js.map +1 -1
  24. package/dist/analyzers/testCheck.js +10 -1
  25. package/dist/analyzers/testCheck.js.map +1 -1
  26. package/dist/analyzers/unusedDependencyCheck.js +8 -8
  27. package/dist/analyzers/unusedDependencyCheck.js.map +1 -1
  28. package/dist/cli/_shared.d.ts +2 -1
  29. package/dist/cli/_shared.js +14 -2
  30. package/dist/cli/_shared.js.map +1 -1
  31. package/dist/cli/commands/agentBrief.js +7 -1
  32. package/dist/cli/commands/agentBrief.js.map +1 -1
  33. package/dist/cli/commands/analyze.js.map +1 -1
  34. package/dist/cli/commands/applyFix.js +1 -1
  35. package/dist/cli/commands/applyFix.js.map +1 -1
  36. package/dist/cli/commands/audit.js +4 -2
  37. package/dist/cli/commands/audit.js.map +1 -1
  38. package/dist/cli/commands/badge.js.map +1 -1
  39. package/dist/cli/commands/bugHunt.js +2 -2
  40. package/dist/cli/commands/bugHunt.js.map +1 -1
  41. package/dist/cli/commands/ci.js.map +1 -1
  42. package/dist/cli/commands/claim.js +3 -3
  43. package/dist/cli/commands/claim.js.map +1 -1
  44. package/dist/cli/commands/collision.js +4 -2
  45. package/dist/cli/commands/collision.js.map +1 -1
  46. package/dist/cli/commands/coordinate.js +4 -2
  47. package/dist/cli/commands/coordinate.js.map +1 -1
  48. package/dist/cli/commands/coupling.js.map +1 -1
  49. package/dist/cli/commands/coverage.js.map +1 -1
  50. package/dist/cli/commands/dataflow.js.map +1 -1
  51. package/dist/cli/commands/dependencies.js +1 -1
  52. package/dist/cli/commands/dependencies.js.map +1 -1
  53. package/dist/cli/commands/diff.js.map +1 -1
  54. package/dist/cli/commands/doctor.js.map +1 -1
  55. package/dist/cli/commands/dogfood.js +30 -5
  56. package/dist/cli/commands/dogfood.js.map +1 -1
  57. package/dist/cli/commands/evidencePack.js.map +1 -1
  58. package/dist/cli/commands/explainIssue.js +1 -1
  59. package/dist/cli/commands/explainIssue.js.map +1 -1
  60. package/dist/cli/commands/feedback.js +19 -5
  61. package/dist/cli/commands/feedback.js.map +1 -1
  62. package/dist/cli/commands/file.js +1 -1
  63. package/dist/cli/commands/file.js.map +1 -1
  64. package/dist/cli/commands/fix.js.map +1 -1
  65. package/dist/cli/commands/fixSuggest.js +12 -4
  66. package/dist/cli/commands/fixSuggest.js.map +1 -1
  67. package/dist/cli/commands/hotspots.js.map +1 -1
  68. package/dist/cli/commands/impact.js +1 -1
  69. package/dist/cli/commands/impact.js.map +1 -1
  70. package/dist/cli/commands/init.js +13 -5
  71. package/dist/cli/commands/init.js.map +1 -1
  72. package/dist/cli/commands/installHook.js +2 -2
  73. package/dist/cli/commands/installHook.js.map +1 -1
  74. package/dist/cli/commands/mcp.js.map +1 -1
  75. package/dist/cli/commands/memory.js +5 -2
  76. package/dist/cli/commands/memory.js.map +1 -1
  77. package/dist/cli/commands/mergeRisk.js +1 -1
  78. package/dist/cli/commands/mergeRisk.js.map +1 -1
  79. package/dist/cli/commands/missionProof.js +13 -12
  80. package/dist/cli/commands/missionProof.js.map +1 -1
  81. package/dist/cli/commands/outdated.js +1 -1
  82. package/dist/cli/commands/outdated.js.map +1 -1
  83. package/dist/cli/commands/plugin.js +10 -6
  84. package/dist/cli/commands/plugin.js.map +1 -1
  85. package/dist/cli/commands/prDiff.js +1 -1
  86. package/dist/cli/commands/prDiff.js.map +1 -1
  87. package/dist/cli/commands/preflight.js +1 -5
  88. package/dist/cli/commands/preflight.js.map +1 -1
  89. package/dist/cli/commands/privacyCheck.js +3 -1
  90. package/dist/cli/commands/privacyCheck.js.map +1 -1
  91. package/dist/cli/commands/qualityScorecard.js.map +1 -1
  92. package/dist/cli/commands/recipes.js.map +1 -1
  93. package/dist/cli/commands/regressionPlan.js.map +1 -1
  94. package/dist/cli/commands/releaseTrain.js.map +1 -1
  95. package/dist/cli/commands/review.js +1 -1
  96. package/dist/cli/commands/review.js.map +1 -1
  97. package/dist/cli/commands/route.js.map +1 -1
  98. package/dist/cli/commands/search.js +5 -2
  99. package/dist/cli/commands/search.js.map +1 -1
  100. package/dist/cli/commands/semanticGraph.js.map +1 -1
  101. package/dist/cli/commands/session.js +2 -2
  102. package/dist/cli/commands/session.js.map +1 -1
  103. package/dist/cli/commands/start.js +3 -1177
  104. package/dist/cli/commands/start.js.map +1 -1
  105. package/dist/cli/commands/startAction.d.ts +36 -0
  106. package/dist/cli/commands/startAction.js +70 -0
  107. package/dist/cli/commands/startAction.js.map +1 -0
  108. package/dist/cli/commands/startConsole.d.ts +7 -0
  109. package/dist/cli/commands/startConsole.js +309 -0
  110. package/dist/cli/commands/startConsole.js.map +1 -0
  111. package/dist/cli/commands/startMissionBundle.d.ts +41 -0
  112. package/dist/cli/commands/startMissionBundle.js +645 -0
  113. package/dist/cli/commands/startMissionBundle.js.map +1 -0
  114. package/dist/cli/commands/startOutput.d.ts +31 -0
  115. package/dist/cli/commands/startOutput.js +232 -0
  116. package/dist/cli/commands/startOutput.js.map +1 -0
  117. package/dist/cli/commands/startShortcuts.d.ts +26 -0
  118. package/dist/cli/commands/startShortcuts.js +117 -0
  119. package/dist/cli/commands/startShortcuts.js.map +1 -0
  120. package/dist/cli/commands/telemetry.js +2 -1
  121. package/dist/cli/commands/telemetry.js.map +1 -1
  122. package/dist/cli/commands/trial.js +19 -4
  123. package/dist/cli/commands/trial.js.map +1 -1
  124. package/dist/cli/commands/understand.js +3 -1
  125. package/dist/cli/commands/understand.js.map +1 -1
  126. package/dist/cli/commands/upgrade.js.map +1 -1
  127. package/dist/cli/commands/watch.js +1 -1
  128. package/dist/cli/commands/watch.js.map +1 -1
  129. package/dist/cli/commands/workplan.js.map +1 -1
  130. package/dist/cli/commands/workspace.js +1 -1
  131. package/dist/cli/commands/workspace.js.map +1 -1
  132. package/dist/cli/commands/workspaces.js +1 -1
  133. package/dist/cli/commands/workspaces.js.map +1 -1
  134. package/dist/cli/index.js +2 -117
  135. package/dist/cli/index.js.map +1 -1
  136. package/dist/cli/registerCommands.d.ts +4 -0
  137. package/dist/cli/registerCommands.js +125 -0
  138. package/dist/cli/registerCommands.js.map +1 -0
  139. package/dist/core/adoption.d.ts +2 -1
  140. package/dist/core/adoption.js +40 -13
  141. package/dist/core/adoption.js.map +1 -1
  142. package/dist/core/agentBrief.js +19 -6
  143. package/dist/core/agentBrief.js.map +1 -1
  144. package/dist/core/applyFix.js.map +1 -1
  145. package/dist/core/ast.js +30 -19
  146. package/dist/core/ast.js.map +1 -1
  147. package/dist/core/auditRunner.js.map +1 -1
  148. package/dist/core/bugHunt.js +119 -17
  149. package/dist/core/bugHunt.js.map +1 -1
  150. package/dist/core/claims.js +5 -2
  151. package/dist/core/claims.js.map +1 -1
  152. package/dist/core/codeGraph.js +10 -0
  153. package/dist/core/codeGraph.js.map +1 -1
  154. package/dist/core/codeGraphReexports.d.ts +9 -0
  155. package/dist/core/codeGraphReexports.js +59 -0
  156. package/dist/core/codeGraphReexports.js.map +1 -0
  157. package/dist/core/collisionDetector.js +14 -4
  158. package/dist/core/collisionDetector.js.map +1 -1
  159. package/dist/core/coordination.js +4 -6
  160. package/dist/core/coordination.js.map +1 -1
  161. package/dist/core/couplingAnalyzer.d.ts +2 -1
  162. package/dist/core/couplingAnalyzer.js.map +1 -1
  163. package/dist/core/coverageParser.js.map +1 -1
  164. package/dist/core/dataflow.js +11 -2
  165. package/dist/core/dataflow.js.map +1 -1
  166. package/dist/core/dataflowFilters.js +8 -3
  167. package/dist/core/dataflowFilters.js.map +1 -1
  168. package/dist/core/dependencyAnalyzer.js +4 -1
  169. package/dist/core/dependencyAnalyzer.js.map +1 -1
  170. package/dist/core/dogfood.d.ts +1 -1
  171. package/dist/core/dogfood.js +39 -5
  172. package/dist/core/dogfood.js.map +1 -1
  173. package/dist/core/embeddings.js.map +1 -1
  174. package/dist/core/evidenceComment.js +34 -12
  175. package/dist/core/evidenceComment.js.map +1 -1
  176. package/dist/core/explainIssue.js +1 -2
  177. package/dist/core/explainIssue.js.map +1 -1
  178. package/dist/core/feedback.d.ts +1 -1
  179. package/dist/core/feedback.js +15 -4
  180. package/dist/core/feedback.js.map +1 -1
  181. package/dist/core/fileInspector.js +8 -2
  182. package/dist/core/fileInspector.js.map +1 -1
  183. package/dist/core/fixFirst.d.ts +3 -1
  184. package/dist/core/fixFirst.js +17 -4
  185. package/dist/core/fixFirst.js.map +1 -1
  186. package/dist/core/fixSuggest.js +20 -12
  187. package/dist/core/fixSuggest.js.map +1 -1
  188. package/dist/core/frameworkDetector.js +5 -3
  189. package/dist/core/frameworkDetector.js.map +1 -1
  190. package/dist/core/frameworkSources.js +22 -2
  191. package/dist/core/frameworkSources.js.map +1 -1
  192. package/dist/core/graphCorpus.d.ts +1 -1
  193. package/dist/core/graphCorpus.js +9 -1
  194. package/dist/core/graphCorpus.js.map +1 -1
  195. package/dist/core/graphQuery.js.map +1 -1
  196. package/dist/core/hotspotAnalyzer.js +26 -6
  197. package/dist/core/hotspotAnalyzer.js.map +1 -1
  198. package/dist/core/impact.d.ts +1 -1
  199. package/dist/core/impact.js.map +1 -1
  200. package/dist/core/importGraph.js.map +1 -1
  201. package/dist/core/indexCache.js.map +1 -1
  202. package/dist/core/intent.d.ts +1 -1
  203. package/dist/core/intent.js +143 -46
  204. package/dist/core/intent.js.map +1 -1
  205. package/dist/core/intentRouter.js +5467 -445
  206. package/dist/core/intentRouter.js.map +1 -1
  207. package/dist/core/issueEngine.js +1 -1
  208. package/dist/core/issueEngine.js.map +1 -1
  209. package/dist/core/languageDetector.js +1 -9
  210. package/dist/core/languageDetector.js.map +1 -1
  211. package/dist/core/languages/cppAdapter.js +3 -1
  212. package/dist/core/languages/cppAdapter.js.map +1 -1
  213. package/dist/core/languages/cppExports.js +6 -1
  214. package/dist/core/languages/cppExports.js.map +1 -1
  215. package/dist/core/languages/cppFunctions.js +3 -1
  216. package/dist/core/languages/cppFunctions.js.map +1 -1
  217. package/dist/core/languages/csharpAdapter.js.map +1 -1
  218. package/dist/core/languages/csharpFunctions.js +3 -1
  219. package/dist/core/languages/csharpFunctions.js.map +1 -1
  220. package/dist/core/languages/csharpImports.js +2 -1
  221. package/dist/core/languages/csharpImports.js.map +1 -1
  222. package/dist/core/languages/goAdapter.js.map +1 -1
  223. package/dist/core/languages/goExports.js.map +1 -1
  224. package/dist/core/languages/goFunctions.js +9 -3
  225. package/dist/core/languages/goFunctions.js.map +1 -1
  226. package/dist/core/languages/javaAdapter.js +1 -2
  227. package/dist/core/languages/javaAdapter.js.map +1 -1
  228. package/dist/core/languages/javaFunctions.js +6 -2
  229. package/dist/core/languages/javaFunctions.js.map +1 -1
  230. package/dist/core/languages/javascriptAdapter.js +43 -8
  231. package/dist/core/languages/javascriptAdapter.js.map +1 -1
  232. package/dist/core/languages/kotlinAdapter.js +5 -2
  233. package/dist/core/languages/kotlinAdapter.js.map +1 -1
  234. package/dist/core/languages/kotlinFunctions.js +5 -6
  235. package/dist/core/languages/kotlinFunctions.js.map +1 -1
  236. package/dist/core/languages/kotlinImports.js +3 -1
  237. package/dist/core/languages/kotlinImports.js.map +1 -1
  238. package/dist/core/languages/kotlinManifests.js +7 -1
  239. package/dist/core/languages/kotlinManifests.js.map +1 -1
  240. package/dist/core/languages/phpAdapter.js +4 -1
  241. package/dist/core/languages/phpAdapter.js.map +1 -1
  242. package/dist/core/languages/phpExports.js.map +1 -1
  243. package/dist/core/languages/phpFunctions.js +18 -6
  244. package/dist/core/languages/phpFunctions.js.map +1 -1
  245. package/dist/core/languages/phpManifests.js.map +1 -1
  246. package/dist/core/languages/pythonAdapter.js.map +1 -1
  247. package/dist/core/languages/pythonFunctions.js +9 -3
  248. package/dist/core/languages/pythonFunctions.js.map +1 -1
  249. package/dist/core/languages/pythonManifests.js.map +1 -1
  250. package/dist/core/languages/rubyAdapter.js.map +1 -1
  251. package/dist/core/languages/rubyFunctions.js +6 -2
  252. package/dist/core/languages/rubyFunctions.js.map +1 -1
  253. package/dist/core/languages/rustAdapter.js.map +1 -1
  254. package/dist/core/languages/rustFunctions.js +6 -2
  255. package/dist/core/languages/rustFunctions.js.map +1 -1
  256. package/dist/core/languages/swiftAdapter.js +3 -1
  257. package/dist/core/languages/swiftAdapter.js.map +1 -1
  258. package/dist/core/languages/swiftCyclomatic.js.map +1 -1
  259. package/dist/core/languages/swiftFunctions.js +3 -1
  260. package/dist/core/languages/swiftFunctions.js.map +1 -1
  261. package/dist/core/languages/swiftImports.js.map +1 -1
  262. package/dist/core/mergeRisk.js +5 -1
  263. package/dist/core/mergeRisk.js.map +1 -1
  264. package/dist/core/missionOutcome.d.ts +1 -1
  265. package/dist/core/missionOutcome.js +9 -4
  266. package/dist/core/missionOutcome.js.map +1 -1
  267. package/dist/core/missionProof.d.ts +1 -1
  268. package/dist/core/missionProof.js +8 -6
  269. package/dist/core/missionProof.js.map +1 -1
  270. package/dist/core/missionProofBaseline.d.ts +1 -1
  271. package/dist/core/missionProofBaseline.js +8 -2
  272. package/dist/core/missionProofBaseline.js.map +1 -1
  273. package/dist/core/missionProofMarkdown.d.ts +1 -1
  274. package/dist/core/missionProofMarkdown.js +4 -1
  275. package/dist/core/missionProofMarkdown.js.map +1 -1
  276. package/dist/core/missionProofSummary.d.ts +1 -1
  277. package/dist/core/monorepo.d.ts +1 -1
  278. package/dist/core/monorepo.js +4 -2
  279. package/dist/core/monorepo.js.map +1 -1
  280. package/dist/core/onboarding.d.ts +2 -1
  281. package/dist/core/onboarding.js.map +1 -1
  282. package/dist/core/outdatedDetector.js +5 -1
  283. package/dist/core/outdatedDetector.js.map +1 -1
  284. package/dist/core/ownership.js +3 -1
  285. package/dist/core/ownership.js.map +1 -1
  286. package/dist/core/pathClassifiers.js.map +1 -1
  287. package/dist/core/pluginDx.js +2 -1
  288. package/dist/core/pluginDx.js.map +1 -1
  289. package/dist/core/pluginTrust.js +1 -3
  290. package/dist/core/pluginTrust.js.map +1 -1
  291. package/dist/core/plugins.js +5 -5
  292. package/dist/core/plugins.js.map +1 -1
  293. package/dist/core/prDiff.d.ts +1 -2
  294. package/dist/core/prDiff.js +5 -1
  295. package/dist/core/prDiff.js.map +1 -1
  296. package/dist/core/preflight.js +15 -6
  297. package/dist/core/preflight.js.map +1 -1
  298. package/dist/core/privacy.js.map +1 -1
  299. package/dist/core/qualityScorecard.d.ts +1 -1
  300. package/dist/core/qualityScorecard.js +43 -11
  301. package/dist/core/qualityScorecard.js.map +1 -1
  302. package/dist/core/regressionPlan.js +25 -7
  303. package/dist/core/regressionPlan.js.map +1 -1
  304. package/dist/core/releaseEvidence.js +41 -17
  305. package/dist/core/releaseEvidence.js.map +1 -1
  306. package/dist/core/releaseTrain.js +66 -38
  307. package/dist/core/releaseTrain.js.map +1 -1
  308. package/dist/core/repositoryScanner.js +1 -3
  309. package/dist/core/repositoryScanner.js.map +1 -1
  310. package/dist/core/review.d.ts +1 -1
  311. package/dist/core/review.js +72 -10
  312. package/dist/core/review.js.map +1 -1
  313. package/dist/core/reviewDataflow.js +7 -1
  314. package/dist/core/reviewDataflow.js.map +1 -1
  315. package/dist/core/reviewPublicSurface.d.ts +13 -0
  316. package/dist/core/reviewPublicSurface.js +134 -0
  317. package/dist/core/reviewPublicSurface.js.map +1 -0
  318. package/dist/core/roadmapCatalog.js +122 -23
  319. package/dist/core/roadmapCatalog.js.map +1 -1
  320. package/dist/core/searchIndex.js +124 -17
  321. package/dist/core/searchIndex.js.map +1 -1
  322. package/dist/core/semanticGraph.js.map +1 -1
  323. package/dist/core/semanticSearch.js +20 -4
  324. package/dist/core/semanticSearch.js.map +1 -1
  325. package/dist/core/session.js +1 -2
  326. package/dist/core/session.js.map +1 -1
  327. package/dist/core/sessionResources.js +6 -2
  328. package/dist/core/sessionResources.js.map +1 -1
  329. package/dist/core/start.d.ts +3 -9
  330. package/dist/core/start.js +22 -3231
  331. package/dist/core/start.js.map +1 -1
  332. package/dist/core/startAdoptionLoop.d.ts +2 -0
  333. package/dist/core/startAdoptionLoop.js +41 -0
  334. package/dist/core/startAdoptionLoop.js.map +1 -0
  335. package/dist/core/startEvidence.d.ts +5 -0
  336. package/dist/core/startEvidence.js +62 -0
  337. package/dist/core/startEvidence.js.map +1 -0
  338. package/dist/core/startExecutionPlan.d.ts +16 -0
  339. package/dist/core/startExecutionPlan.js +185 -0
  340. package/dist/core/startExecutionPlan.js.map +1 -0
  341. package/dist/core/startHarness.d.ts +3 -0
  342. package/dist/core/startHarness.js +47 -0
  343. package/dist/core/startHarness.js.map +1 -0
  344. package/dist/core/startIntentTargets.d.ts +24 -0
  345. package/dist/core/startIntentTargets.js +1106 -0
  346. package/dist/core/startIntentTargets.js.map +1 -0
  347. package/dist/core/startMissionControl.d.ts +16 -0
  348. package/dist/core/startMissionControl.js +145 -0
  349. package/dist/core/startMissionControl.js.map +1 -0
  350. package/dist/core/startMissionPolicy.d.ts +19 -0
  351. package/dist/core/startMissionPolicy.js +246 -0
  352. package/dist/core/startMissionPolicy.js.map +1 -0
  353. package/dist/core/startMode.d.ts +11 -0
  354. package/dist/core/startMode.js +139 -0
  355. package/dist/core/startMode.js.map +1 -0
  356. package/dist/core/startOptions.d.ts +18 -0
  357. package/dist/core/startOptions.js +29 -0
  358. package/dist/core/startOptions.js.map +1 -0
  359. package/dist/core/startResume.d.ts +7 -0
  360. package/dist/core/startResume.js +468 -0
  361. package/dist/core/startResume.js.map +1 -0
  362. package/dist/core/startReviewGate.d.ts +11 -0
  363. package/dist/core/startReviewGate.js +200 -0
  364. package/dist/core/startReviewGate.js.map +1 -0
  365. package/dist/core/startRouteActions.d.ts +7 -0
  366. package/dist/core/startRouteActions.js +497 -0
  367. package/dist/core/startRouteActions.js.map +1 -0
  368. package/dist/core/startRunbook.d.ts +24 -0
  369. package/dist/core/startRunbook.js +271 -0
  370. package/dist/core/startRunbook.js.map +1 -0
  371. package/dist/core/startSuccessCriteria.d.ts +14 -0
  372. package/dist/core/startSuccessCriteria.js +497 -0
  373. package/dist/core/startSuccessCriteria.js.map +1 -0
  374. package/dist/core/taint.js +12 -3
  375. package/dist/core/taint.js.map +1 -1
  376. package/dist/core/telemetry.js +19 -5
  377. package/dist/core/telemetry.js.map +1 -1
  378. package/dist/core/trial.d.ts +1 -1
  379. package/dist/core/trial.js +15 -6
  380. package/dist/core/trial.js.map +1 -1
  381. package/dist/core/understand.d.ts +1 -1
  382. package/dist/core/understand.js +165 -51
  383. package/dist/core/understand.js.map +1 -1
  384. package/dist/core/upgradePreview.js +1 -1
  385. package/dist/core/upgradePreview.js.map +1 -1
  386. package/dist/core/watcher.js +18 -3
  387. package/dist/core/watcher.js.map +1 -1
  388. package/dist/core/workplan.js +87 -17
  389. package/dist/core/workplan.js.map +1 -1
  390. package/dist/core/workspace.js.map +1 -1
  391. package/dist/index.d.ts +9 -9
  392. package/dist/index.js +7 -7
  393. package/dist/index.js.map +1 -1
  394. package/dist/mcp/pagination.js.map +1 -1
  395. package/dist/mcp/prompts.js +28 -20
  396. package/dist/mcp/prompts.js.map +1 -1
  397. package/dist/mcp/server.js +6 -74
  398. package/dist/mcp/server.js.map +1 -1
  399. package/dist/mcp/serverPayload.d.ts +13 -0
  400. package/dist/mcp/serverPayload.js +61 -0
  401. package/dist/mcp/serverPayload.js.map +1 -0
  402. package/dist/mcp/tokenBudget.js.map +1 -1
  403. package/dist/mcp/tools/_shared.js.map +1 -1
  404. package/dist/mcp/tools/agentBrief.js +7 -1
  405. package/dist/mcp/tools/agentBrief.js.map +1 -1
  406. package/dist/mcp/tools/applyFix.js +1 -1
  407. package/dist/mcp/tools/applyFix.js.map +1 -1
  408. package/dist/mcp/tools/audit.js.map +1 -1
  409. package/dist/mcp/tools/bugHunt.js +2 -2
  410. package/dist/mcp/tools/bugHunt.js.map +1 -1
  411. package/dist/mcp/tools/claim.js +8 -3
  412. package/dist/mcp/tools/claim.js.map +1 -1
  413. package/dist/mcp/tools/collision.js +3 -1
  414. package/dist/mcp/tools/collision.js.map +1 -1
  415. package/dist/mcp/tools/coordinate.js.map +1 -1
  416. package/dist/mcp/tools/coordinateWatch.js +5 -2
  417. package/dist/mcp/tools/coordinateWatch.js.map +1 -1
  418. package/dist/mcp/tools/costSummary.js.map +1 -1
  419. package/dist/mcp/tools/coupling.js.map +1 -1
  420. package/dist/mcp/tools/coverage.js.map +1 -1
  421. package/dist/mcp/tools/dataflow.js.map +1 -1
  422. package/dist/mcp/tools/dependencies.js +4 -1
  423. package/dist/mcp/tools/dependencies.js.map +1 -1
  424. package/dist/mcp/tools/doctor.js.map +1 -1
  425. package/dist/mcp/tools/explainIssue.js +4 -1
  426. package/dist/mcp/tools/explainIssue.js.map +1 -1
  427. package/dist/mcp/tools/fixSuggest.js +5 -2
  428. package/dist/mcp/tools/fixSuggest.js.map +1 -1
  429. package/dist/mcp/tools/hotspots.js +4 -1
  430. package/dist/mcp/tools/hotspots.js.map +1 -1
  431. package/dist/mcp/tools/impact.js +10 -3
  432. package/dist/mcp/tools/impact.js.map +1 -1
  433. package/dist/mcp/tools/mergeRisk.js.map +1 -1
  434. package/dist/mcp/tools/plugin.js +6 -1
  435. package/dist/mcp/tools/plugin.js.map +1 -1
  436. package/dist/mcp/tools/prDiff.js.map +1 -1
  437. package/dist/mcp/tools/preflight.js +1 -5
  438. package/dist/mcp/tools/preflight.js.map +1 -1
  439. package/dist/mcp/tools/review.js.map +1 -1
  440. package/dist/mcp/tools/reviewWatch.d.ts +1 -1
  441. package/dist/mcp/tools/reviewWatch.js +9 -9
  442. package/dist/mcp/tools/reviewWatch.js.map +1 -1
  443. package/dist/mcp/tools/route.js +1 -1
  444. package/dist/mcp/tools/route.js.map +1 -1
  445. package/dist/mcp/tools/search.js.map +1 -1
  446. package/dist/mcp/tools/semanticGraph.js +8 -2
  447. package/dist/mcp/tools/semanticGraph.js.map +1 -1
  448. package/dist/mcp/tools/start.js.map +1 -1
  449. package/dist/mcp/tools/structure.js +7 -1
  450. package/dist/mcp/tools/structure.js.map +1 -1
  451. package/dist/mcp/tools/understand.js.map +1 -1
  452. package/dist/mcp/tools/workspaceGraph.js +10 -1
  453. package/dist/mcp/tools/workspaceGraph.js.map +1 -1
  454. package/dist/mcp/tools.js +3 -1
  455. package/dist/mcp/tools.js.map +1 -1
  456. package/dist/projscan-sbom.cdx.json +2136 -904
  457. package/dist/reporters/consoleAnalysisReporter.d.ts +2 -0
  458. package/dist/reporters/consoleAnalysisReporter.js +89 -0
  459. package/dist/reporters/consoleAnalysisReporter.js.map +1 -0
  460. package/dist/reporters/consoleArchitectureReporter.d.ts +3 -0
  461. package/dist/reporters/consoleArchitectureReporter.js +47 -0
  462. package/dist/reporters/consoleArchitectureReporter.js.map +1 -0
  463. package/dist/reporters/consoleAuditReporter.d.ts +2 -0
  464. package/dist/reporters/consoleAuditReporter.js +46 -0
  465. package/dist/reporters/consoleAuditReporter.js.map +1 -0
  466. package/dist/reporters/consoleCiReporter.d.ts +2 -0
  467. package/dist/reporters/consoleCiReporter.js +27 -0
  468. package/dist/reporters/consoleCiReporter.js.map +1 -0
  469. package/dist/reporters/consoleCouplingReporter.d.ts +2 -0
  470. package/dist/reporters/consoleCouplingReporter.js +53 -0
  471. package/dist/reporters/consoleCouplingReporter.js.map +1 -0
  472. package/dist/reporters/consoleCoverageReporter.d.ts +2 -0
  473. package/dist/reporters/consoleCoverageReporter.js +62 -0
  474. package/dist/reporters/consoleCoverageReporter.js.map +1 -0
  475. package/dist/reporters/consoleDependencyReporter.d.ts +2 -0
  476. package/dist/reporters/consoleDependencyReporter.js +64 -0
  477. package/dist/reporters/consoleDependencyReporter.js.map +1 -0
  478. package/dist/reporters/consoleDiffReporter.d.ts +2 -0
  479. package/dist/reporters/consoleDiffReporter.js +80 -0
  480. package/dist/reporters/consoleDiffReporter.js.map +1 -0
  481. package/dist/reporters/consoleExplanationReporter.d.ts +2 -0
  482. package/dist/reporters/consoleExplanationReporter.js +33 -0
  483. package/dist/reporters/consoleExplanationReporter.js.map +1 -0
  484. package/dist/reporters/consoleFileReporter.d.ts +2 -0
  485. package/dist/reporters/consoleFileReporter.js +133 -0
  486. package/dist/reporters/consoleFileReporter.js.map +1 -0
  487. package/dist/reporters/consoleFixGuidanceReporter.d.ts +8 -0
  488. package/dist/reporters/consoleFixGuidanceReporter.js +135 -0
  489. package/dist/reporters/consoleFixGuidanceReporter.js.map +1 -0
  490. package/dist/reporters/consoleHealthReporter.d.ts +13 -0
  491. package/dist/reporters/consoleHealthReporter.js +111 -0
  492. package/dist/reporters/consoleHealthReporter.js.map +1 -0
  493. package/dist/reporters/consoleHotspotReporter.d.ts +2 -0
  494. package/dist/reporters/consoleHotspotReporter.js +68 -0
  495. package/dist/reporters/consoleHotspotReporter.js.map +1 -0
  496. package/dist/reporters/consoleImpactReporter.d.ts +2 -0
  497. package/dist/reporters/consoleImpactReporter.js +65 -0
  498. package/dist/reporters/consoleImpactReporter.js.map +1 -0
  499. package/dist/reporters/consoleOutdatedReporter.d.ts +2 -0
  500. package/dist/reporters/consoleOutdatedReporter.js +54 -0
  501. package/dist/reporters/consoleOutdatedReporter.js.map +1 -0
  502. package/dist/reporters/consolePrDiffReporter.d.ts +2 -0
  503. package/dist/reporters/consolePrDiffReporter.js +75 -0
  504. package/dist/reporters/consolePrDiffReporter.js.map +1 -0
  505. package/dist/reporters/consoleReporter.d.ts +21 -38
  506. package/dist/reporters/consoleReporter.js +19 -1000
  507. package/dist/reporters/consoleReporter.js.map +1 -1
  508. package/dist/reporters/consoleReviewReporter.d.ts +2 -0
  509. package/dist/reporters/consoleReviewReporter.js +101 -0
  510. package/dist/reporters/consoleReviewReporter.js.map +1 -0
  511. package/dist/reporters/consoleUpgradeReporter.d.ts +2 -0
  512. package/dist/reporters/consoleUpgradeReporter.js +67 -0
  513. package/dist/reporters/consoleUpgradeReporter.js.map +1 -0
  514. package/dist/reporters/consoleWorkspaceReporter.d.ts +2 -0
  515. package/dist/reporters/consoleWorkspaceReporter.js +24 -0
  516. package/dist/reporters/consoleWorkspaceReporter.js.map +1 -0
  517. package/dist/reporters/htmlReporter.d.ts +2 -1
  518. package/dist/reporters/htmlReporter.js +9 -3
  519. package/dist/reporters/htmlReporter.js.map +1 -1
  520. package/dist/reporters/jsonReporter.d.ts +2 -1
  521. package/dist/reporters/jsonReporter.js.map +1 -1
  522. package/dist/reporters/markdownAnalysisReporter.d.ts +2 -0
  523. package/dist/reporters/markdownAnalysisReporter.js +40 -0
  524. package/dist/reporters/markdownAnalysisReporter.js.map +1 -0
  525. package/dist/reporters/markdownAuditReporter.d.ts +2 -0
  526. package/dist/reporters/markdownAuditReporter.js +27 -0
  527. package/dist/reporters/markdownAuditReporter.js.map +1 -0
  528. package/dist/reporters/markdownDependencyReporter.d.ts +2 -0
  529. package/dist/reporters/markdownDependencyReporter.js +33 -0
  530. package/dist/reporters/markdownDependencyReporter.js.map +1 -0
  531. package/dist/reporters/markdownDiffReporter.d.ts +2 -0
  532. package/dist/reporters/markdownDiffReporter.js +65 -0
  533. package/dist/reporters/markdownDiffReporter.js.map +1 -0
  534. package/dist/reporters/markdownFileReporter.d.ts +2 -0
  535. package/dist/reporters/markdownFileReporter.js +92 -0
  536. package/dist/reporters/markdownFileReporter.js.map +1 -0
  537. package/dist/reporters/markdownFixGuidanceReporter.d.ts +8 -0
  538. package/dist/reporters/markdownFixGuidanceReporter.js +95 -0
  539. package/dist/reporters/markdownFixGuidanceReporter.js.map +1 -0
  540. package/dist/reporters/markdownImpactReporter.d.ts +2 -0
  541. package/dist/reporters/markdownImpactReporter.js +52 -0
  542. package/dist/reporters/markdownImpactReporter.js.map +1 -0
  543. package/dist/reporters/markdownReporter.d.ts +10 -16
  544. package/dist/reporters/markdownReporter.js +9 -452
  545. package/dist/reporters/markdownReporter.js.map +1 -1
  546. package/dist/reporters/markdownReviewReporter.d.ts +2 -0
  547. package/dist/reporters/markdownReviewReporter.js +84 -0
  548. package/dist/reporters/markdownReviewReporter.js.map +1 -0
  549. package/dist/reporters/markdownUpgradeReporter.d.ts +2 -0
  550. package/dist/reporters/markdownUpgradeReporter.js +47 -0
  551. package/dist/reporters/markdownUpgradeReporter.js.map +1 -0
  552. package/dist/reporters/sarifReporter.js.map +1 -1
  553. package/dist/tool-manifest.json +4 -4
  554. package/dist/types/agentBrief.d.ts +48 -0
  555. package/dist/types/agentBrief.js +2 -0
  556. package/dist/types/agentBrief.js.map +1 -0
  557. package/dist/types/analysis.d.ts +32 -0
  558. package/dist/types/analysis.js +2 -0
  559. package/dist/types/analysis.js.map +1 -0
  560. package/dist/types/baseline.d.ts +59 -0
  561. package/dist/types/baseline.js +2 -0
  562. package/dist/types/baseline.js.map +1 -0
  563. package/dist/types/bugHunt.d.ts +41 -0
  564. package/dist/types/bugHunt.js +2 -0
  565. package/dist/types/bugHunt.js.map +1 -0
  566. package/dist/types/common.d.ts +34 -0
  567. package/dist/types/common.js +2 -0
  568. package/dist/types/common.js.map +1 -0
  569. package/dist/types/config.d.ts +56 -0
  570. package/dist/types/config.js +2 -0
  571. package/dist/types/config.js.map +1 -0
  572. package/dist/types/coupling.d.ts +40 -0
  573. package/dist/types/coupling.js +2 -0
  574. package/dist/types/coupling.js.map +1 -0
  575. package/dist/types/coverage.d.ts +32 -0
  576. package/dist/types/coverage.js +2 -0
  577. package/dist/types/coverage.js.map +1 -0
  578. package/dist/types/dependencyHealth.d.ts +61 -0
  579. package/dist/types/dependencyHealth.js +2 -0
  580. package/dist/types/dependencyHealth.js.map +1 -0
  581. package/dist/types/dogfood.d.ts +185 -0
  582. package/dist/types/dogfood.js +2 -0
  583. package/dist/types/dogfood.js.map +1 -0
  584. package/dist/types/evidencePack.d.ts +76 -0
  585. package/dist/types/evidencePack.js +2 -0
  586. package/dist/types/evidencePack.js.map +1 -0
  587. package/dist/types/fixes.d.ts +77 -0
  588. package/dist/types/fixes.js +2 -0
  589. package/dist/types/fixes.js.map +1 -0
  590. package/dist/types/graph.d.ts +80 -0
  591. package/dist/types/graph.js +2 -0
  592. package/dist/types/graph.js.map +1 -0
  593. package/dist/types/graphCorpus.d.ts +16 -0
  594. package/dist/types/graphCorpus.js +2 -0
  595. package/dist/types/graphCorpus.js.map +1 -0
  596. package/dist/types/hotspots.d.ts +42 -0
  597. package/dist/types/hotspots.js +2 -0
  598. package/dist/types/hotspots.js.map +1 -0
  599. package/dist/types/impact.d.ts +62 -0
  600. package/dist/types/impact.js +2 -0
  601. package/dist/types/impact.js.map +1 -0
  602. package/dist/types/inspection.d.ts +47 -0
  603. package/dist/types/inspection.js +2 -0
  604. package/dist/types/inspection.js.map +1 -0
  605. package/dist/types/mcp.d.ts +39 -0
  606. package/dist/types/mcp.js +2 -0
  607. package/dist/types/mcp.js.map +1 -0
  608. package/dist/types/pluginDx.d.ts +42 -0
  609. package/dist/types/pluginDx.js +2 -0
  610. package/dist/types/pluginDx.js.map +1 -0
  611. package/dist/types/prDiff.d.ts +41 -0
  612. package/dist/types/prDiff.js +2 -0
  613. package/dist/types/prDiff.js.map +1 -0
  614. package/dist/types/preflight.d.ts +122 -0
  615. package/dist/types/preflight.js +2 -0
  616. package/dist/types/preflight.js.map +1 -0
  617. package/dist/types/qualityScorecard.d.ts +34 -0
  618. package/dist/types/qualityScorecard.js +2 -0
  619. package/dist/types/qualityScorecard.js.map +1 -0
  620. package/dist/types/regressionPlan.d.ts +32 -0
  621. package/dist/types/regressionPlan.js +2 -0
  622. package/dist/types/regressionPlan.js.map +1 -0
  623. package/dist/types/releaseTrain.d.ts +37 -0
  624. package/dist/types/releaseTrain.js +2 -0
  625. package/dist/types/releaseTrain.js.map +1 -0
  626. package/dist/types/review.d.ts +203 -0
  627. package/dist/types/review.js +2 -0
  628. package/dist/types/review.js.map +1 -0
  629. package/dist/types/reviewContract.d.ts +9 -0
  630. package/dist/types/reviewContract.js +2 -0
  631. package/dist/types/reviewContract.js.map +1 -0
  632. package/dist/types/scanning.d.ts +111 -0
  633. package/dist/types/scanning.js +2 -0
  634. package/dist/types/scanning.js.map +1 -0
  635. package/dist/types/session.d.ts +42 -0
  636. package/dist/types/session.js +2 -0
  637. package/dist/types/session.js.map +1 -0
  638. package/dist/types/start.d.ts +437 -0
  639. package/dist/types/start.js +2 -0
  640. package/dist/types/start.js.map +1 -0
  641. package/dist/types/trial.d.ts +27 -0
  642. package/dist/types/trial.js +2 -0
  643. package/dist/types/trial.js.map +1 -0
  644. package/dist/types/understand.d.ts +153 -0
  645. package/dist/types/understand.js +2 -0
  646. package/dist/types/understand.js.map +1 -0
  647. package/dist/types/workplan.d.ts +67 -0
  648. package/dist/types/workplan.js +2 -0
  649. package/dist/types/workplan.js.map +1 -0
  650. package/dist/types/workplanHandoff.d.ts +11 -0
  651. package/dist/types/workplanHandoff.js +2 -0
  652. package/dist/types/workplanHandoff.js.map +1 -0
  653. package/dist/types/workspace.d.ts +18 -0
  654. package/dist/types/workspace.js +2 -0
  655. package/dist/types/workspace.js.map +1 -0
  656. package/dist/types.d.ts +34 -2348
  657. package/dist/types.js +0 -1
  658. package/dist/types.js.map +1 -1
  659. package/dist/utils/banner.js +15 -6
  660. package/dist/utils/banner.js.map +1 -1
  661. package/dist/utils/baseline.js +11 -9
  662. package/dist/utils/baseline.js.map +1 -1
  663. package/dist/utils/changedFiles.js +1 -1
  664. package/dist/utils/changedFiles.js.map +1 -1
  665. package/dist/utils/config.d.ts +2 -1
  666. package/dist/utils/config.js.map +1 -1
  667. package/dist/utils/formatSupport.d.ts +1 -1
  668. package/dist/utils/formatSupport.js +7 -1
  669. package/dist/utils/formatSupport.js.map +1 -1
  670. package/dist/utils/packageJsonLocator.js.map +1 -1
  671. package/docs/GUIDE.md +186 -146
  672. package/docs/PLUGIN-GALLERY.md +9 -1
  673. package/docs/ROADMAP.md +69 -68
  674. package/docs/demos/projscan-4-1-demo.html +46 -79
  675. package/docs/examples/plugins/graph-context.mjs +1 -2
  676. package/docs/examples/plugins/security-sensitive-files.mjs +2 -1
  677. package/package.json +10 -5
@@ -0,0 +1,139 @@
1
+ import { routeIntent } from './intentRouter.js';
2
+ import { isProductPlanningWorkplanRoute } from './startSuccessCriteria.js';
3
+ import { isWorkplanMode } from './workplan.js';
4
+ const MODE_RESOLVERS = [
5
+ releaseMode,
6
+ bugHuntMode,
7
+ productPlanningMode,
8
+ hardeningMode,
9
+ evidencePackMode,
10
+ reviewMode,
11
+ regressionMode,
12
+ prDiffMode,
13
+ mergeRiskMode,
14
+ primaryPreflightMode,
15
+ fallbackPreflightMode,
16
+ ];
17
+ export function resolveStartMode(value, intent) {
18
+ if (typeof value === 'string' && isWorkplanMode(value)) {
19
+ return {
20
+ mode: value,
21
+ source: 'explicit',
22
+ reason: `Mode ${value} was provided explicitly.`,
23
+ };
24
+ }
25
+ const inferred = inferModeFromIntent(intent);
26
+ if (inferred) {
27
+ return {
28
+ mode: inferred,
29
+ source: 'intent',
30
+ reason: `Intent "${intent}" maps to the ${inferred} workflow.`,
31
+ };
32
+ }
33
+ return {
34
+ mode: 'before_edit',
35
+ source: 'default',
36
+ reason: defaultModeReason(intent, routesForIntent(intent).length > 0),
37
+ };
38
+ }
39
+ export function inferModeFromIntent(intent) {
40
+ const routes = routesForIntent(intent);
41
+ const context = {
42
+ intent: intent ?? '',
43
+ routes,
44
+ primaryRoute: routes[0],
45
+ };
46
+ for (const resolver of MODE_RESOLVERS) {
47
+ const mode = resolver(context);
48
+ if (mode)
49
+ return mode;
50
+ }
51
+ return undefined;
52
+ }
53
+ export function routesForIntent(intent) {
54
+ if (!intent)
55
+ return [];
56
+ return routeIntent(intent).matches.map(routeEntryToStartIntent);
57
+ }
58
+ export function preflightModeFromIntent(intent) {
59
+ const text = intent.toLowerCase();
60
+ if (/\b(?:merge|merged|merging|release|rebase|rebasing|conflict|conflicts|resolve|resolving)\b/.test(text))
61
+ return 'before_merge';
62
+ if (/\bcommit|committing|committed|pr|pull\s+request\b/.test(text))
63
+ return 'before_commit';
64
+ return 'before_edit';
65
+ }
66
+ function defaultModeReason(intent, routed) {
67
+ if (!intent)
68
+ return 'No mode-specific intent or explicit mode was supplied, so start defaults to before_edit.';
69
+ if (routed) {
70
+ return `Mission Control routed the intent, but no workflow-mode hint matched "${intent}", so start defaults to before_edit.`;
71
+ }
72
+ return `No mode-specific intent matched "${intent}", so start defaults to before_edit.`;
73
+ }
74
+ function routeEntryToStartIntent(entry) {
75
+ return {
76
+ intent: entry.intent,
77
+ category: entry.category,
78
+ tool: entry.tool,
79
+ cli: entry.cli,
80
+ why: entry.why,
81
+ example: entry.example,
82
+ confidence: entry.confidence,
83
+ rank: entry.rank,
84
+ score: entry.score,
85
+ matchedKeywords: entry.matchedKeywords,
86
+ };
87
+ }
88
+ function releaseMode({ primaryRoute }) {
89
+ return primaryRoute?.tool === 'projscan_release_train' ? 'release' : undefined;
90
+ }
91
+ function bugHuntMode({ primaryRoute }) {
92
+ return primaryRoute?.tool === 'projscan_bug_hunt' && primaryRoute.confidence === 'high'
93
+ ? 'bug_hunt'
94
+ : undefined;
95
+ }
96
+ function productPlanningMode({ primaryRoute }) {
97
+ return isProductPlanningWorkplanRoute(primaryRoute) ? 'bug_hunt' : undefined;
98
+ }
99
+ function hardeningMode({ primaryRoute }) {
100
+ return primaryRoute?.tool === 'projscan_dataflow' && primaryRoute.confidence === 'high'
101
+ ? 'hardening'
102
+ : undefined;
103
+ }
104
+ function evidencePackMode({ primaryRoute }) {
105
+ return primaryRoute?.tool === 'projscan_evidence_pack' ? 'before_commit' : undefined;
106
+ }
107
+ function reviewMode({ intent, primaryRoute }) {
108
+ return primaryRoute?.tool === 'projscan_review' ? reviewModeFromIntent(intent) : undefined;
109
+ }
110
+ function regressionMode({ intent, primaryRoute }) {
111
+ return primaryRoute?.tool === 'projscan_regression_plan'
112
+ ? regressionModeFromIntent(intent)
113
+ : undefined;
114
+ }
115
+ function prDiffMode({ primaryRoute }) {
116
+ return primaryRoute?.tool === 'projscan_pr_diff' ? 'before_commit' : undefined;
117
+ }
118
+ function mergeRiskMode({ primaryRoute }) {
119
+ return primaryRoute?.tool === 'projscan_merge_risk' ? 'before_merge' : undefined;
120
+ }
121
+ function primaryPreflightMode({ intent, primaryRoute, }) {
122
+ return primaryRoute?.tool === 'projscan_preflight' ? preflightModeFromIntent(intent) : undefined;
123
+ }
124
+ function fallbackPreflightMode({ intent, routes }) {
125
+ if (routes.some((route) => route.tool === 'projscan_preflight') && hasPreflightModeHint(intent)) {
126
+ return preflightModeFromIntent(intent);
127
+ }
128
+ return undefined;
129
+ }
130
+ function hasPreflightModeHint(intent) {
131
+ return /\b(?:safe|safety|gate|preflight|commit|committing|committed|merge|merged|merging|rebase|rebasing|conflict|conflicts|resolve|resolving|edit|proceed|block|blocked|blocker|blockers|blocking|allowed)\b/i.test(intent);
132
+ }
133
+ function regressionModeFromIntent(intent) {
134
+ return /\bmerge|merged|merging|release\b/i.test(intent) ? 'before_merge' : 'before_commit';
135
+ }
136
+ function reviewModeFromIntent(intent) {
137
+ return /\bmerge|merged|merging\b/i.test(intent) ? 'before_merge' : 'before_commit';
138
+ }
139
+ //# sourceMappingURL=startMode.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"startMode.js","sourceRoot":"","sources":["../../src/core/startMode.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import { type StartModeResolution } from './startMode.js';
2
+ import type { WorkplanMode } from '../types.js';
3
+ export interface ComputeStartOptions {
4
+ mode?: WorkplanMode;
5
+ intent?: string;
6
+ missionDir?: string;
7
+ maxTasks?: number;
8
+ maxRisks?: number;
9
+ includeHandoff?: boolean;
10
+ }
11
+ export interface NormalizedStartOptions {
12
+ intent?: string;
13
+ modeResolution: StartModeResolution;
14
+ mode: WorkplanMode;
15
+ maxTasks: number;
16
+ maxRisks: number;
17
+ }
18
+ export declare function normalizeStartOptions(options?: ComputeStartOptions): NormalizedStartOptions;
@@ -0,0 +1,29 @@
1
+ import { resolveStartMode } from './startMode.js';
2
+ const DEFAULT_MAX_TASKS = 5;
3
+ const DEFAULT_MAX_RISKS = 5;
4
+ const MAX_START_ITEMS = 12;
5
+ export function normalizeStartOptions(options = {}) {
6
+ const intent = normalizeIntent(options.intent);
7
+ const modeResolution = resolveStartMode(options.mode, intent);
8
+ return {
9
+ intent,
10
+ modeResolution,
11
+ mode: modeResolution.mode,
12
+ maxTasks: normalizeLimit(options.maxTasks, DEFAULT_MAX_TASKS, MAX_START_ITEMS),
13
+ maxRisks: normalizeLimit(options.maxRisks, DEFAULT_MAX_RISKS, MAX_START_ITEMS),
14
+ };
15
+ }
16
+ function normalizeIntent(value) {
17
+ if (typeof value !== 'string')
18
+ return undefined;
19
+ const trimmed = value.trim().replace(/\s+/g, ' ');
20
+ if (trimmed.length === 0)
21
+ return undefined;
22
+ return trimmed.slice(0, 240);
23
+ }
24
+ function normalizeLimit(value, fallback, max) {
25
+ if (typeof value !== 'number' || !Number.isFinite(value))
26
+ return fallback;
27
+ return Math.max(1, Math.min(max, Math.floor(value)));
28
+ }
29
+ //# sourceMappingURL=startOptions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"startOptions.js","sourceRoot":"","sources":["../../src/core/startOptions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAA4B,MAAM,gBAAgB,CAAC;AAoB5E,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAC5B,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAC5B,MAAM,eAAe,GAAG,EAAE,CAAC;AAE3B,MAAM,UAAU,qBAAqB,CAAC,UAA+B,EAAE;IACrE,MAAM,MAAM,GAAG,eAAe,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAC/C,MAAM,cAAc,GAAG,gBAAgB,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IAC9D,OAAO;QACL,MAAM;QACN,cAAc;QACd,IAAI,EAAE,cAAc,CAAC,IAAI;QACzB,QAAQ,EAAE,cAAc,CAAC,OAAO,CAAC,QAAQ,EAAE,iBAAiB,EAAE,eAAe,CAAC;QAC9E,QAAQ,EAAE,cAAc,CAAC,OAAO,CAAC,QAAQ,EAAE,iBAAiB,EAAE,eAAe,CAAC;KAC/E,CAAC;AACJ,CAAC;AAED,SAAS,eAAe,CAAC,KAAyB;IAChD,IAAI,OAAO,KAAK,KAAK,QAAQ;QAAE,OAAO,SAAS,CAAC;IAChD,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAClD,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,SAAS,CAAC;IAC3C,OAAO,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AAC/B,CAAC;AAED,SAAS,cAAc,CAAC,KAAyB,EAAE,QAAgB,EAAE,GAAW;IAC9E,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC;QAAE,OAAO,QAAQ,CAAC;IAC1E,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACvD,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { MissionOutcome, StartExecutionCursor, StartExecutionPhase, StartExecutionPlan, StartMissionResume } from '../types/start.js';
2
+ export declare function missionResume(plan: StartExecutionPlan, outcome?: MissionOutcome): StartMissionResume;
3
+ export declare function proofCommandToolCall(command: string): StartMissionResume['toolCall'] | undefined;
4
+ export declare function executionCursor(phases: StartExecutionPhase[]): StartExecutionCursor;
5
+ export declare function argsAreReady(value: unknown): boolean;
6
+ export declare function isRunnableCommand(command: string): boolean;
7
+ export declare function uniqueStrings(values: string[]): string[];
@@ -0,0 +1,468 @@
1
+ import { isPlaceholder } from './startIntentTargets.js';
2
+ const CURSOR_SELECTORS = [
3
+ (phase, step) => phase.id === 'ready_now' && step.status === 'ready' && typeof step.command === 'string',
4
+ (phase, step) => phase.id === 'resolve_inputs' && step.status === 'blocked',
5
+ (phase, step) => phase.id === 'proof' && step.status === 'ready',
6
+ (phase) => phase.id === 'done_when',
7
+ (phase) => phase.id === 'next_action',
8
+ ];
9
+ const CURSOR_REASON_RULES = [
10
+ { matches: (step) => step.status === 'ready' && step.kind === 'tool', reason: readyToolReason },
11
+ {
12
+ matches: (step) => step.status === 'blocked' && step.kind === 'input',
13
+ reason: () => 'Resolve this blocked input before running dependent follow-up steps.',
14
+ },
15
+ {
16
+ matches: (step) => step.status === 'ready' && step.kind === 'proof',
17
+ reason: () => 'Run this proof command when action steps are complete.',
18
+ },
19
+ {
20
+ matches: (step) => step.kind === 'criterion',
21
+ reason: () => 'Use this criterion to decide when the task is complete.',
22
+ },
23
+ ];
24
+ function readyToolReason(step) {
25
+ return step.unlocks && step.unlocks.length > 0
26
+ ? 'Run this ready command next; it can unlock later inputs or follow-up steps.'
27
+ : 'Run this ready command next.';
28
+ }
29
+ export function missionResume(plan, outcome) {
30
+ const cursor = plan.cursor;
31
+ const commandBlock = runnableCursorCommand(cursor);
32
+ const toolCall = resumeToolCall(plan, cursor);
33
+ const followUps = resumeFollowUps(plan, cursor);
34
+ const inputBindings = resumeInputBindings(plan, cursor);
35
+ const checklist = resumeChecklist(plan, cursor, inputBindings, followUps);
36
+ const remainingProofItems = resumeRemainingProofItems(checklist);
37
+ const remainingProofCommands = resumeRemainingProofCommands(checklist);
38
+ const remainingProofToolCalls = resumeRemainingProofToolCalls(checklist);
39
+ const unlocks = resolveResumeReferences(plan, cursor.unlocks);
40
+ const blockedBy = resolveResumeReferences(plan, cursor.blockedBy);
41
+ const instruction = resumeInstruction(cursor, commandBlock);
42
+ const prompt = resumePrompt(cursor, commandBlock, instruction, unlocks, blockedBy, outcome);
43
+ const resume = {
44
+ currentStep: cursor,
45
+ status: cursor.status,
46
+ instruction,
47
+ prompt,
48
+ };
49
+ attachResumeAction(resume, commandBlock, toolCall);
50
+ attachResumeCollections(resume, {
51
+ followUps,
52
+ inputBindings,
53
+ checklist,
54
+ remainingProofItems,
55
+ remainingProofCommands,
56
+ remainingProofToolCalls,
57
+ unlocks,
58
+ blockedBy,
59
+ });
60
+ return resume;
61
+ }
62
+ function runnableCursorCommand(cursor) {
63
+ return cursor.command && isRunnableCommand(cursor.command) ? cursor.command : undefined;
64
+ }
65
+ function resumeInstruction(cursor, commandBlock) {
66
+ if (commandBlock)
67
+ return `Run ${commandBlock}.`;
68
+ if (cursor.instruction)
69
+ return `Resolve ${cursor.label}: ${cursor.instruction}`;
70
+ return `Continue with ${cursor.label}.`;
71
+ }
72
+ function resumePrompt(cursor, commandBlock, instruction, unlocks, blockedBy, outcome) {
73
+ const base = commandBlock
74
+ ? `Resume at ${cursor.stepId} in ${cursor.phaseId}: run \`${commandBlock}\`.${resumeUnlocksSentence(unlocks, cursor.unlocks)}`
75
+ : `Resume at ${cursor.stepId} in ${cursor.phaseId}: ${instruction}${resumeBlockersSentence(blockedBy, cursor.blockedBy)}`;
76
+ return outcome?.available ? `${outcome.resumePrompt} ${base}` : base;
77
+ }
78
+ function attachResumeAction(resume, commandBlock, toolCall) {
79
+ if (commandBlock)
80
+ resume.commandBlock = commandBlock;
81
+ if (toolCall)
82
+ resume.toolCall = toolCall;
83
+ }
84
+ function attachResumeCollections(resume, collections) {
85
+ if (collections.followUps.length > 0)
86
+ resume.followUps = collections.followUps;
87
+ if (collections.inputBindings.length > 0)
88
+ resume.inputBindings = collections.inputBindings;
89
+ if (collections.checklist.length > 0)
90
+ resume.checklist = collections.checklist;
91
+ if (collections.remainingProofItems.length > 0)
92
+ resume.remainingProofItems = collections.remainingProofItems;
93
+ if (collections.remainingProofCommands.length > 0)
94
+ resume.remainingProofCommands = collections.remainingProofCommands;
95
+ if (collections.remainingProofToolCalls.length > 0)
96
+ resume.remainingProofToolCalls = collections.remainingProofToolCalls;
97
+ if (collections.unlocks.length > 0)
98
+ resume.unlocks = collections.unlocks;
99
+ if (collections.blockedBy.length > 0)
100
+ resume.blockedBy = collections.blockedBy;
101
+ }
102
+ function resumeRemainingProofCommands(checklist) {
103
+ return checklist
104
+ .filter((item) => item.kind === 'run_proof' && typeof item.command === 'string')
105
+ .map((item) => item.command);
106
+ }
107
+ function resumeRemainingProofItems(checklist) {
108
+ return checklist.flatMap((item) => {
109
+ if (item.kind !== 'run_proof' || typeof item.command !== 'string')
110
+ return [];
111
+ const toolCall = proofChecklistToolCall(item);
112
+ return [
113
+ {
114
+ stepId: item.stepId,
115
+ status: item.status,
116
+ label: item.label,
117
+ command: item.command,
118
+ ...(toolCall ? { toolCall } : {}),
119
+ },
120
+ ];
121
+ });
122
+ }
123
+ function resumeRemainingProofToolCalls(checklist) {
124
+ return checklist.flatMap((item) => {
125
+ if (item.kind !== 'run_proof' || typeof item.command !== 'string')
126
+ return [];
127
+ const toolCall = proofChecklistToolCall(item);
128
+ return toolCall ? [{ stepId: item.stepId, command: item.command, ...toolCall }] : [];
129
+ });
130
+ }
131
+ function proofChecklistToolCall(item) {
132
+ if (item.tool) {
133
+ return {
134
+ tool: item.tool,
135
+ ...(typeof item.args !== 'undefined' ? { args: item.args } : {}),
136
+ };
137
+ }
138
+ return typeof item.command === 'string' ? proofCommandToolCall(item.command) : undefined;
139
+ }
140
+ export function proofCommandToolCall(command) {
141
+ const preflightMatch = /^projscan preflight(?: --mode ([a-z_]+))? --format json$/.exec(command);
142
+ if (preflightMatch) {
143
+ return {
144
+ tool: 'projscan_preflight',
145
+ args: preflightMatch[1] ? { mode: preflightMatch[1] } : {},
146
+ };
147
+ }
148
+ const understandMatch = /^projscan understand --view ([a-z_]+)(?: --intent "((?:\\.|[^"\\])*)")? --format json$/.exec(command);
149
+ if (understandMatch) {
150
+ return {
151
+ tool: 'projscan_understand',
152
+ args: {
153
+ view: understandMatch[1],
154
+ ...(understandMatch[2] ? { intent: unescapeDoubleQuoted(understandMatch[2]) } : {}),
155
+ },
156
+ };
157
+ }
158
+ if (command === 'projscan session touched --format json') {
159
+ return {
160
+ tool: 'projscan_session',
161
+ args: { action: 'touched' },
162
+ };
163
+ }
164
+ return undefined;
165
+ }
166
+ function unescapeDoubleQuoted(value) {
167
+ return value.replace(/\\(["\\$`])/g, '$1');
168
+ }
169
+ function resumeChecklist(plan, cursor, inputBindings, followUps) {
170
+ const current = findStepInPlan(plan, cursor.stepId);
171
+ const currentItem = current
172
+ ? resumeChecklistItemFromStep(current.phase, current.step, currentChecklistKind(current.step), cursor.stepId)
173
+ : undefined;
174
+ const includedStepIds = new Set(currentItem ? [currentItem.stepId] : []);
175
+ const inputItems = inputBindings.flatMap((binding) => {
176
+ if (includedStepIds.has(binding.inputId))
177
+ return [];
178
+ const found = findStepInPlan(plan, binding.inputId);
179
+ if (!found)
180
+ return [];
181
+ includedStepIds.add(found.step.id);
182
+ return [
183
+ {
184
+ id: `resume-${found.step.id}`,
185
+ kind: 'resolve_input',
186
+ phaseId: found.phase.id,
187
+ stepId: found.step.id,
188
+ status: found.step.status,
189
+ label: binding.label,
190
+ placeholder: binding.placeholder,
191
+ instruction: binding.instruction,
192
+ followUpIds: binding.followUpIds,
193
+ ...(found.step.dependsOn && found.step.dependsOn.length > 0
194
+ ? { dependsOn: found.step.dependsOn }
195
+ : {}),
196
+ ...(found.step.unlocks && found.step.unlocks.length > 0
197
+ ? { unlocks: found.step.unlocks }
198
+ : {}),
199
+ },
200
+ ];
201
+ });
202
+ const followUpItems = followUps.flatMap((followUp) => {
203
+ if (includedStepIds.has(followUp.id))
204
+ return [];
205
+ includedStepIds.add(followUp.id);
206
+ return [
207
+ {
208
+ id: `resume-${followUp.id}`,
209
+ kind: 'run_follow_up',
210
+ phaseId: followUp.phaseId,
211
+ stepId: followUp.id,
212
+ status: followUp.status,
213
+ label: followUp.label,
214
+ ...(followUp.command ? { command: followUp.command } : {}),
215
+ ...(followUp.tool ? { tool: followUp.tool } : {}),
216
+ ...(followUp.args ? { args: followUp.args } : {}),
217
+ ...(followUp.blockedBy && followUp.blockedBy.length > 0
218
+ ? { blockedBy: followUp.blockedBy }
219
+ : {}),
220
+ ...(followUp.dependsOn && followUp.dependsOn.length > 0
221
+ ? { dependsOn: followUp.dependsOn }
222
+ : {}),
223
+ },
224
+ ];
225
+ });
226
+ const currentCommand = current?.step.command;
227
+ const proofItems = stepsForPhase(plan, 'proof')
228
+ .filter(({ step }) => step.command && step.command !== currentCommand)
229
+ .map(({ phase, step }) => resumeChecklistItemFromStep(phase, step, 'run_proof', step.id));
230
+ const doneItems = stepsForPhase(plan, 'done_when').map(({ phase, step }) => resumeChecklistItemFromStep(phase, step, 'confirm_done', step.id));
231
+ return [
232
+ ...(currentItem ? [currentItem] : []),
233
+ ...inputItems,
234
+ ...followUpItems,
235
+ ...proofItems,
236
+ ...doneItems,
237
+ ];
238
+ }
239
+ function resumeChecklistItemFromStep(phase, step, kind, stepId) {
240
+ const item = {
241
+ id: `resume-${stepId}`,
242
+ kind,
243
+ phaseId: phase.id,
244
+ stepId,
245
+ status: step.status,
246
+ label: step.label,
247
+ };
248
+ appendChecklistStepFields(item, step);
249
+ return item;
250
+ }
251
+ function appendChecklistStepFields(item, step) {
252
+ addTruthyValue(item, 'command', step.command);
253
+ addTruthyValue(item, 'tool', step.tool);
254
+ addTruthyValue(item, 'args', step.args);
255
+ addTruthyValue(item, 'placeholder', step.placeholder);
256
+ addTruthyValue(item, 'instruction', step.instruction);
257
+ addNonEmptyStrings(item, 'blockedBy', step.blockedBy);
258
+ addNonEmptyStrings(item, 'dependsOn', step.dependsOn);
259
+ addNonEmptyStrings(item, 'unlocks', step.unlocks);
260
+ }
261
+ function currentChecklistKind(step) {
262
+ if (step.kind === 'input')
263
+ return 'resolve_input';
264
+ if (step.kind === 'proof')
265
+ return 'run_proof';
266
+ if (step.kind === 'criterion')
267
+ return 'confirm_done';
268
+ return 'run_current';
269
+ }
270
+ function resumeInputBindings(plan, cursor) {
271
+ const ids = uniqueStrings([
272
+ ...(cursor.kind === 'input' ? [cursor.stepId] : []),
273
+ ...(cursor.unlocks ?? []),
274
+ ]);
275
+ return ids.flatMap((id) => {
276
+ const found = findStepInPlan(plan, id);
277
+ if (!found || found.step.kind !== 'input' || !found.step.placeholder || !found.step.instruction)
278
+ return [];
279
+ const followUpIds = (found.step.unlocks ?? []).filter((unlockedId) => findStepInPlan(plan, unlockedId)?.phase.id === 'follow_up');
280
+ return [
281
+ {
282
+ inputId: found.step.id,
283
+ label: found.step.label,
284
+ placeholder: found.step.placeholder,
285
+ instruction: found.step.instruction,
286
+ followUpIds,
287
+ },
288
+ ];
289
+ });
290
+ }
291
+ function resumeFollowUps(plan, cursor) {
292
+ const followUpIds = new Set();
293
+ for (const id of cursor.unlocks ?? []) {
294
+ const found = findStepInPlan(plan, id);
295
+ if (!found)
296
+ continue;
297
+ if (found.phase.id === 'follow_up')
298
+ followUpIds.add(found.step.id);
299
+ for (const unlockedId of found.step.unlocks ?? []) {
300
+ const unlocked = findStepInPlan(plan, unlockedId);
301
+ if (unlocked?.phase.id === 'follow_up')
302
+ followUpIds.add(unlocked.step.id);
303
+ }
304
+ }
305
+ return Array.from(followUpIds).flatMap((id) => {
306
+ const found = findStepInPlan(plan, id);
307
+ if (!found)
308
+ return [];
309
+ return [
310
+ {
311
+ id: found.step.id,
312
+ phaseId: found.phase.id,
313
+ kind: found.step.kind,
314
+ status: found.step.status,
315
+ label: found.step.label,
316
+ ...(found.step.command ? { command: found.step.command } : {}),
317
+ ...(found.step.tool ? { tool: found.step.tool } : {}),
318
+ ...(found.step.args ? { args: found.step.args } : {}),
319
+ ...(found.step.blockedBy && found.step.blockedBy.length > 0
320
+ ? { blockedBy: found.step.blockedBy }
321
+ : {}),
322
+ ...(found.step.dependsOn && found.step.dependsOn.length > 0
323
+ ? { dependsOn: found.step.dependsOn }
324
+ : {}),
325
+ },
326
+ ];
327
+ });
328
+ }
329
+ function resumeToolCall(plan, cursor) {
330
+ const found = findStepInPlan(plan, cursor.stepId);
331
+ if (!found?.step.tool || !argsAreReady(found.step.args))
332
+ return undefined;
333
+ return {
334
+ tool: found.step.tool,
335
+ ...(typeof found.step.args !== 'undefined' ? { args: found.step.args } : {}),
336
+ };
337
+ }
338
+ function resolveResumeReferences(plan, ids) {
339
+ if (!ids || ids.length === 0)
340
+ return [];
341
+ const references = [];
342
+ for (const id of ids) {
343
+ const found = findStepInPlan(plan, id);
344
+ if (!found)
345
+ continue;
346
+ references.push({
347
+ id: found.step.id,
348
+ phaseId: found.phase.id,
349
+ kind: found.step.kind,
350
+ status: found.step.status,
351
+ label: found.step.label,
352
+ ...(found.step.instruction ? { instruction: found.step.instruction } : {}),
353
+ ...(found.step.command ? { command: found.step.command } : {}),
354
+ ...(found.step.placeholder ? { placeholder: found.step.placeholder } : {}),
355
+ });
356
+ }
357
+ return references;
358
+ }
359
+ function findStepInPlan(plan, id) {
360
+ for (const phase of plan.phases) {
361
+ for (const step of phase.steps) {
362
+ if (step.id === id)
363
+ return { phase, step };
364
+ }
365
+ }
366
+ return undefined;
367
+ }
368
+ function stepsForPhase(plan, phaseId) {
369
+ const phase = plan.phases.find((item) => item.id === phaseId);
370
+ return phase ? phase.steps.map((step) => ({ phase, step })) : [];
371
+ }
372
+ function resumeUnlocksSentence(unlocks, rawIds) {
373
+ if (unlocks.length > 0)
374
+ return ` This can unlock ${unlocks.map(formatResumeReferenceLabel).join(', ')}.`;
375
+ return rawIds && rawIds.length > 0 ? ` This can unlock ${rawIds.join(', ')}.` : '';
376
+ }
377
+ function resumeBlockersSentence(blockedBy, rawIds) {
378
+ if (blockedBy.length > 0)
379
+ return ` Blocked by ${blockedBy.map(formatResumeReferenceLabel).join(', ')}.`;
380
+ return rawIds && rawIds.length > 0 ? ` Blocked by ${rawIds.join(', ')}.` : '';
381
+ }
382
+ function formatResumeReferenceLabel(reference) {
383
+ return `${reference.id} (${reference.label})`;
384
+ }
385
+ export function executionCursor(phases) {
386
+ const selected = selectExecutionStep(phases);
387
+ return selected ? executionCursorFromSelection(selected) : fallbackExecutionCursor();
388
+ }
389
+ function selectExecutionStep(phases) {
390
+ for (const selector of CURSOR_SELECTORS) {
391
+ const selected = findExecutionStep(phases, selector);
392
+ if (selected)
393
+ return selected;
394
+ }
395
+ return undefined;
396
+ }
397
+ function fallbackExecutionCursor() {
398
+ return {
399
+ phaseId: 'done_when',
400
+ stepId: 'criterion-1',
401
+ status: 'pending',
402
+ kind: 'criterion',
403
+ label: 'The next action is complete and verified.',
404
+ reason: 'Use this criterion to decide when the task is complete.',
405
+ };
406
+ }
407
+ function executionCursorFromSelection(selected) {
408
+ const cursor = {
409
+ phaseId: selected.phase.id,
410
+ stepId: selected.step.id,
411
+ status: selected.step.status,
412
+ kind: selected.step.kind,
413
+ label: selected.step.label,
414
+ reason: executionCursorReason(selected.step),
415
+ };
416
+ appendCursorStepFields(cursor, selected.step);
417
+ return cursor;
418
+ }
419
+ function appendCursorStepFields(cursor, step) {
420
+ addTruthyValue(cursor, 'command', step.command);
421
+ addTruthyValue(cursor, 'tool', step.tool);
422
+ addDefinedValue(cursor, 'args', step.args);
423
+ addTruthyValue(cursor, 'instruction', step.instruction);
424
+ addTruthyValue(cursor, 'placeholder', step.placeholder);
425
+ addNonEmptyStrings(cursor, 'blockedBy', step.blockedBy);
426
+ addNonEmptyStrings(cursor, 'unlocks', step.unlocks);
427
+ }
428
+ function findExecutionStep(phases, predicate) {
429
+ for (const phase of phases) {
430
+ for (const step of phase.steps) {
431
+ if (predicate(phase, step))
432
+ return { phase, step };
433
+ }
434
+ }
435
+ return undefined;
436
+ }
437
+ function executionCursorReason(step) {
438
+ return (CURSOR_REASON_RULES.find((rule) => rule.matches(step))?.reason(step) ??
439
+ 'Use this step as the current execution pointer.');
440
+ }
441
+ export function argsAreReady(value) {
442
+ if (typeof value === 'string')
443
+ return !isPlaceholder(value);
444
+ if (Array.isArray(value))
445
+ return value.every(argsAreReady);
446
+ if (value && typeof value === 'object')
447
+ return Object.values(value).every(argsAreReady);
448
+ return true;
449
+ }
450
+ export function isRunnableCommand(command) {
451
+ return !/<[^<>]+>/.test(command);
452
+ }
453
+ export function uniqueStrings(values) {
454
+ return [...new Set(values.filter((value) => value.length > 0))];
455
+ }
456
+ function addTruthyValue(target, key, value) {
457
+ if (value)
458
+ target[key] = value;
459
+ }
460
+ function addDefinedValue(target, key, value) {
461
+ if (typeof value !== 'undefined')
462
+ target[key] = value;
463
+ }
464
+ function addNonEmptyStrings(target, key, values) {
465
+ if (values && values.length > 0)
466
+ target[key] = values;
467
+ }
468
+ //# sourceMappingURL=startResume.js.map