@shrkcrft/cli 0.1.0-alpha.2

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 (450) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +15 -0
  3. package/dist/asset-preview/apply-action-hint-stub.d.ts +28 -0
  4. package/dist/asset-preview/apply-action-hint-stub.d.ts.map +1 -0
  5. package/dist/asset-preview/apply-action-hint-stub.js +170 -0
  6. package/dist/asset-preview/apply-asset-preview.d.ts +31 -0
  7. package/dist/asset-preview/apply-asset-preview.d.ts.map +1 -0
  8. package/dist/asset-preview/apply-asset-preview.js +210 -0
  9. package/dist/asset-preview/apply-knowledge-stale-fix.d.ts +37 -0
  10. package/dist/asset-preview/apply-knowledge-stale-fix.d.ts.map +1 -0
  11. package/dist/asset-preview/apply-knowledge-stale-fix.js +344 -0
  12. package/dist/asset-preview/apply-missing-barrel.d.ts +15 -0
  13. package/dist/asset-preview/apply-missing-barrel.d.ts.map +1 -0
  14. package/dist/asset-preview/apply-missing-barrel.js +65 -0
  15. package/dist/asset-preview/apply-template-drift-fix.d.ts +21 -0
  16. package/dist/asset-preview/apply-template-drift-fix.d.ts.map +1 -0
  17. package/dist/asset-preview/apply-template-drift-fix.js +125 -0
  18. package/dist/asset-preview/apply-template-update.d.ts +43 -0
  19. package/dist/asset-preview/apply-template-update.d.ts.map +1 -0
  20. package/dist/asset-preview/apply-template-update.js +257 -0
  21. package/dist/asset-preview/entry-mutator.d.ts +106 -0
  22. package/dist/asset-preview/entry-mutator.d.ts.map +1 -0
  23. package/dist/asset-preview/entry-mutator.js +428 -0
  24. package/dist/authoring/authoring-kit.d.ts +36 -0
  25. package/dist/authoring/authoring-kit.d.ts.map +1 -0
  26. package/dist/authoring/authoring-kit.js +106 -0
  27. package/dist/command-registry.d.ts +158 -0
  28. package/dist/command-registry.d.ts.map +1 -0
  29. package/dist/command-registry.js +348 -0
  30. package/dist/commands/apply.command.d.ts +3 -0
  31. package/dist/commands/apply.command.d.ts.map +1 -0
  32. package/dist/commands/apply.command.js +879 -0
  33. package/dist/commands/architecture.command.d.ts +5 -0
  34. package/dist/commands/architecture.command.d.ts.map +1 -0
  35. package/dist/commands/architecture.command.js +141 -0
  36. package/dist/commands/ask.command.d.ts +3 -0
  37. package/dist/commands/ask.command.d.ts.map +1 -0
  38. package/dist/commands/ask.command.js +58 -0
  39. package/dist/commands/audit.command.d.ts +3 -0
  40. package/dist/commands/audit.command.d.ts.map +1 -0
  41. package/dist/commands/audit.command.js +141 -0
  42. package/dist/commands/biome.command.d.ts +7 -0
  43. package/dist/commands/biome.command.d.ts.map +1 -0
  44. package/dist/commands/biome.command.js +350 -0
  45. package/dist/commands/boundaries.command.d.ts +9 -0
  46. package/dist/commands/boundaries.command.d.ts.map +1 -0
  47. package/dist/commands/boundaries.command.js +314 -0
  48. package/dist/commands/brief.command.d.ts +3 -0
  49. package/dist/commands/brief.command.d.ts.map +1 -0
  50. package/dist/commands/brief.command.js +206 -0
  51. package/dist/commands/bundle.command.d.ts +3 -0
  52. package/dist/commands/bundle.command.d.ts.map +1 -0
  53. package/dist/commands/bundle.command.js +1183 -0
  54. package/dist/commands/changes.command.d.ts +3 -0
  55. package/dist/commands/changes.command.d.ts.map +1 -0
  56. package/dist/commands/changes.command.js +155 -0
  57. package/dist/commands/check.command.d.ts +3 -0
  58. package/dist/commands/check.command.d.ts.map +1 -0
  59. package/dist/commands/check.command.js +553 -0
  60. package/dist/commands/checks.command.d.ts +29 -0
  61. package/dist/commands/checks.command.d.ts.map +1 -0
  62. package/dist/commands/checks.command.js +521 -0
  63. package/dist/commands/ci.command.d.ts +3 -0
  64. package/dist/commands/ci.command.d.ts.map +1 -0
  65. package/dist/commands/ci.command.js +680 -0
  66. package/dist/commands/codemod.command.d.ts +3 -0
  67. package/dist/commands/codemod.command.d.ts.map +1 -0
  68. package/dist/commands/codemod.command.js +130 -0
  69. package/dist/commands/command-catalog.d.ts +265 -0
  70. package/dist/commands/command-catalog.d.ts.map +1 -0
  71. package/dist/commands/command-catalog.js +3242 -0
  72. package/dist/commands/commands.command.d.ts +92 -0
  73. package/dist/commands/commands.command.d.ts.map +1 -0
  74. package/dist/commands/commands.command.js +1208 -0
  75. package/dist/commands/constructs.command.d.ts +15 -0
  76. package/dist/commands/constructs.command.d.ts.map +1 -0
  77. package/dist/commands/constructs.command.js +669 -0
  78. package/dist/commands/context.command.d.ts +3 -0
  79. package/dist/commands/context.command.d.ts.map +1 -0
  80. package/dist/commands/context.command.js +120 -0
  81. package/dist/commands/contract-gate.command.d.ts +5 -0
  82. package/dist/commands/contract-gate.command.d.ts.map +1 -0
  83. package/dist/commands/contract-gate.command.js +208 -0
  84. package/dist/commands/contract-templates.command.d.ts +8 -0
  85. package/dist/commands/contract-templates.command.d.ts.map +1 -0
  86. package/dist/commands/contract-templates.command.js +151 -0
  87. package/dist/commands/contract.command.d.ts +3 -0
  88. package/dist/commands/contract.command.d.ts.map +1 -0
  89. package/dist/commands/contract.command.js +105 -0
  90. package/dist/commands/conventions.command.d.ts +8 -0
  91. package/dist/commands/conventions.command.d.ts.map +1 -0
  92. package/dist/commands/conventions.command.js +169 -0
  93. package/dist/commands/coverage.command.d.ts +3 -0
  94. package/dist/commands/coverage.command.d.ts.map +1 -0
  95. package/dist/commands/coverage.command.js +56 -0
  96. package/dist/commands/daily.commands.d.ts +5 -0
  97. package/dist/commands/daily.commands.d.ts.map +1 -0
  98. package/dist/commands/daily.commands.js +224 -0
  99. package/dist/commands/dashboard-export.command.d.ts +4 -0
  100. package/dist/commands/dashboard-export.command.d.ts.map +1 -0
  101. package/dist/commands/dashboard-export.command.js +86 -0
  102. package/dist/commands/dashboard.command.d.ts +3 -0
  103. package/dist/commands/dashboard.command.d.ts.map +1 -0
  104. package/dist/commands/dashboard.command.js +106 -0
  105. package/dist/commands/dev.command.d.ts +3 -0
  106. package/dist/commands/dev.command.d.ts.map +1 -0
  107. package/dist/commands/dev.command.js +1392 -0
  108. package/dist/commands/diagnostics.command.d.ts +5 -0
  109. package/dist/commands/diagnostics.command.d.ts.map +1 -0
  110. package/dist/commands/diagnostics.command.js +97 -0
  111. package/dist/commands/docs.command.d.ts +4 -0
  112. package/dist/commands/docs.command.d.ts.map +1 -0
  113. package/dist/commands/docs.command.js +34 -0
  114. package/dist/commands/doctor.command.d.ts +7 -0
  115. package/dist/commands/doctor.command.d.ts.map +1 -0
  116. package/dist/commands/doctor.command.js +681 -0
  117. package/dist/commands/drift.command.d.ts +3 -0
  118. package/dist/commands/drift.command.d.ts.map +1 -0
  119. package/dist/commands/drift.command.js +124 -0
  120. package/dist/commands/eslint.command.d.ts +7 -0
  121. package/dist/commands/eslint.command.d.ts.map +1 -0
  122. package/dist/commands/eslint.command.js +423 -0
  123. package/dist/commands/explore.command.d.ts +3 -0
  124. package/dist/commands/explore.command.d.ts.map +1 -0
  125. package/dist/commands/explore.command.js +65 -0
  126. package/dist/commands/export-bundle.command.d.ts +6 -0
  127. package/dist/commands/export-bundle.command.d.ts.map +1 -0
  128. package/dist/commands/export-bundle.command.js +96 -0
  129. package/dist/commands/export.command.d.ts +3 -0
  130. package/dist/commands/export.command.d.ts.map +1 -0
  131. package/dist/commands/export.command.js +83 -0
  132. package/dist/commands/feedback-dispatch.command.d.ts +12 -0
  133. package/dist/commands/feedback-dispatch.command.d.ts.map +1 -0
  134. package/dist/commands/feedback-dispatch.command.js +63 -0
  135. package/dist/commands/feedback.command.d.ts +11 -0
  136. package/dist/commands/feedback.command.d.ts.map +1 -0
  137. package/dist/commands/feedback.command.js +336 -0
  138. package/dist/commands/fix.command.d.ts +3 -0
  139. package/dist/commands/fix.command.d.ts.map +1 -0
  140. package/dist/commands/fix.command.js +776 -0
  141. package/dist/commands/gen.command.d.ts +3 -0
  142. package/dist/commands/gen.command.d.ts.map +1 -0
  143. package/dist/commands/gen.command.js +136 -0
  144. package/dist/commands/git.command.d.ts +6 -0
  145. package/dist/commands/git.command.d.ts.map +1 -0
  146. package/dist/commands/git.command.js +81 -0
  147. package/dist/commands/graph.command.d.ts +3 -0
  148. package/dist/commands/graph.command.d.ts.map +1 -0
  149. package/dist/commands/graph.command.js +287 -0
  150. package/dist/commands/grounding.command.d.ts +7 -0
  151. package/dist/commands/grounding.command.d.ts.map +1 -0
  152. package/dist/commands/grounding.command.js +54 -0
  153. package/dist/commands/help.command.d.ts +20 -0
  154. package/dist/commands/help.command.d.ts.map +1 -0
  155. package/dist/commands/help.command.js +127 -0
  156. package/dist/commands/helper.command.d.ts +6 -0
  157. package/dist/commands/helper.command.d.ts.map +1 -0
  158. package/dist/commands/helper.command.js +170 -0
  159. package/dist/commands/ide.command.d.ts +6 -0
  160. package/dist/commands/ide.command.d.ts.map +1 -0
  161. package/dist/commands/ide.command.js +340 -0
  162. package/dist/commands/impact.command.d.ts +3 -0
  163. package/dist/commands/impact.command.d.ts.map +1 -0
  164. package/dist/commands/impact.command.js +819 -0
  165. package/dist/commands/import.command.d.ts +3 -0
  166. package/dist/commands/import.command.d.ts.map +1 -0
  167. package/dist/commands/import.command.js +115 -0
  168. package/dist/commands/infer.command.d.ts +3 -0
  169. package/dist/commands/infer.command.d.ts.map +1 -0
  170. package/dist/commands/infer.command.js +227 -0
  171. package/dist/commands/ingest.command.d.ts +6 -0
  172. package/dist/commands/ingest.command.d.ts.map +1 -0
  173. package/dist/commands/ingest.command.js +532 -0
  174. package/dist/commands/init.command.d.ts +3 -0
  175. package/dist/commands/init.command.d.ts.map +1 -0
  176. package/dist/commands/init.command.js +301 -0
  177. package/dist/commands/inspect.command.d.ts +3 -0
  178. package/dist/commands/inspect.command.d.ts.map +1 -0
  179. package/dist/commands/inspect.command.js +122 -0
  180. package/dist/commands/knowledge-author.command.d.ts +22 -0
  181. package/dist/commands/knowledge-author.command.d.ts.map +1 -0
  182. package/dist/commands/knowledge-author.command.js +366 -0
  183. package/dist/commands/knowledge-propose.command.d.ts +3 -0
  184. package/dist/commands/knowledge-propose.command.d.ts.map +1 -0
  185. package/dist/commands/knowledge-propose.command.js +125 -0
  186. package/dist/commands/knowledge.command.d.ts +18 -0
  187. package/dist/commands/knowledge.command.d.ts.map +1 -0
  188. package/dist/commands/knowledge.command.js +538 -0
  189. package/dist/commands/languages.command.d.ts +3 -0
  190. package/dist/commands/languages.command.d.ts.map +1 -0
  191. package/dist/commands/languages.command.js +300 -0
  192. package/dist/commands/lint.command.d.ts +15 -0
  193. package/dist/commands/lint.command.d.ts.map +1 -0
  194. package/dist/commands/lint.command.js +194 -0
  195. package/dist/commands/mcp.command.d.ts +3 -0
  196. package/dist/commands/mcp.command.d.ts.map +1 -0
  197. package/dist/commands/mcp.command.js +74 -0
  198. package/dist/commands/memory.command.d.ts +11 -0
  199. package/dist/commands/memory.command.d.ts.map +1 -0
  200. package/dist/commands/memory.command.js +264 -0
  201. package/dist/commands/onboard.command.d.ts +3 -0
  202. package/dist/commands/onboard.command.d.ts.map +1 -0
  203. package/dist/commands/onboard.command.js +650 -0
  204. package/dist/commands/orchestrate.command.d.ts +3 -0
  205. package/dist/commands/orchestrate.command.d.ts.map +1 -0
  206. package/dist/commands/orchestrate.command.js +49 -0
  207. package/dist/commands/owners.command.d.ts +5 -0
  208. package/dist/commands/owners.command.d.ts.map +1 -0
  209. package/dist/commands/owners.command.js +113 -0
  210. package/dist/commands/ownership.command.d.ts +5 -0
  211. package/dist/commands/ownership.command.d.ts.map +1 -0
  212. package/dist/commands/ownership.command.js +117 -0
  213. package/dist/commands/pack-author.command.d.ts +30 -0
  214. package/dist/commands/pack-author.command.d.ts.map +1 -0
  215. package/dist/commands/pack-author.command.js +242 -0
  216. package/dist/commands/packs-new.d.ts +27 -0
  217. package/dist/commands/packs-new.d.ts.map +1 -0
  218. package/dist/commands/packs-new.js +805 -0
  219. package/dist/commands/packs.command.d.ts +15 -0
  220. package/dist/commands/packs.command.d.ts.map +1 -0
  221. package/dist/commands/packs.command.js +958 -0
  222. package/dist/commands/paths.command.d.ts +6 -0
  223. package/dist/commands/paths.command.d.ts.map +1 -0
  224. package/dist/commands/paths.command.js +97 -0
  225. package/dist/commands/pipelines.command.d.ts +9 -0
  226. package/dist/commands/pipelines.command.d.ts.map +1 -0
  227. package/dist/commands/pipelines.command.js +308 -0
  228. package/dist/commands/plan-check.command.d.ts +27 -0
  229. package/dist/commands/plan-check.command.d.ts.map +1 -0
  230. package/dist/commands/plan-check.command.js +150 -0
  231. package/dist/commands/plan-simulate.command.d.ts +3 -0
  232. package/dist/commands/plan-simulate.command.d.ts.map +1 -0
  233. package/dist/commands/plan-simulate.command.js +60 -0
  234. package/dist/commands/plan.command.d.ts +8 -0
  235. package/dist/commands/plan.command.d.ts.map +1 -0
  236. package/dist/commands/plan.command.js +139 -0
  237. package/dist/commands/playbooks.command.d.ts +10 -0
  238. package/dist/commands/playbooks.command.d.ts.map +1 -0
  239. package/dist/commands/playbooks.command.js +296 -0
  240. package/dist/commands/plugin.command.d.ts +11 -0
  241. package/dist/commands/plugin.command.d.ts.map +1 -0
  242. package/dist/commands/plugin.command.js +394 -0
  243. package/dist/commands/policy.command.d.ts +8 -0
  244. package/dist/commands/policy.command.d.ts.map +1 -0
  245. package/dist/commands/policy.command.js +451 -0
  246. package/dist/commands/pr.command.d.ts +3 -0
  247. package/dist/commands/pr.command.d.ts.map +1 -0
  248. package/dist/commands/pr.command.js +132 -0
  249. package/dist/commands/preflight.command.d.ts +3 -0
  250. package/dist/commands/preflight.command.d.ts.map +1 -0
  251. package/dist/commands/preflight.command.js +102 -0
  252. package/dist/commands/presets.command.d.ts +17 -0
  253. package/dist/commands/presets.command.d.ts.map +1 -0
  254. package/dist/commands/presets.command.js +647 -0
  255. package/dist/commands/profiles.command.d.ts +7 -0
  256. package/dist/commands/profiles.command.d.ts.map +1 -0
  257. package/dist/commands/profiles.command.js +151 -0
  258. package/dist/commands/provenance.command.d.ts +26 -0
  259. package/dist/commands/provenance.command.d.ts.map +1 -0
  260. package/dist/commands/provenance.command.js +237 -0
  261. package/dist/commands/quality.command.d.ts +5 -0
  262. package/dist/commands/quality.command.d.ts.map +1 -0
  263. package/dist/commands/quality.command.js +69 -0
  264. package/dist/commands/recommend.command.d.ts +4 -0
  265. package/dist/commands/recommend.command.d.ts.map +1 -0
  266. package/dist/commands/recommend.command.js +270 -0
  267. package/dist/commands/registrations.command.d.ts +3 -0
  268. package/dist/commands/registrations.command.d.ts.map +1 -0
  269. package/dist/commands/registrations.command.js +300 -0
  270. package/dist/commands/registry.command.d.ts +4 -0
  271. package/dist/commands/registry.command.d.ts.map +1 -0
  272. package/dist/commands/registry.command.js +37 -0
  273. package/dist/commands/release.command.d.ts +4 -0
  274. package/dist/commands/release.command.d.ts.map +1 -0
  275. package/dist/commands/release.command.js +639 -0
  276. package/dist/commands/repo.command.d.ts +3 -0
  277. package/dist/commands/repo.command.d.ts.map +1 -0
  278. package/dist/commands/repo.command.js +24 -0
  279. package/dist/commands/report.command.d.ts +3 -0
  280. package/dist/commands/report.command.d.ts.map +1 -0
  281. package/dist/commands/report.command.js +511 -0
  282. package/dist/commands/reposet.command.d.ts +6 -0
  283. package/dist/commands/reposet.command.d.ts.map +1 -0
  284. package/dist/commands/reposet.command.js +120 -0
  285. package/dist/commands/review.command.d.ts +3 -0
  286. package/dist/commands/review.command.d.ts.map +1 -0
  287. package/dist/commands/review.command.js +354 -0
  288. package/dist/commands/risk.command.d.ts +3 -0
  289. package/dist/commands/risk.command.d.ts.map +1 -0
  290. package/dist/commands/risk.command.js +56 -0
  291. package/dist/commands/rounds.command.d.ts +8 -0
  292. package/dist/commands/rounds.command.d.ts.map +1 -0
  293. package/dist/commands/rounds.command.js +180 -0
  294. package/dist/commands/rules.command.d.ts +49 -0
  295. package/dist/commands/rules.command.d.ts.map +1 -0
  296. package/dist/commands/rules.command.js +435 -0
  297. package/dist/commands/runtime.command.d.ts +3 -0
  298. package/dist/commands/runtime.command.d.ts.map +1 -0
  299. package/dist/commands/runtime.command.js +56 -0
  300. package/dist/commands/safety.command.d.ts +3 -0
  301. package/dist/commands/safety.command.d.ts.map +1 -0
  302. package/dist/commands/safety.command.js +117 -0
  303. package/dist/commands/scaffolds.command.d.ts +5 -0
  304. package/dist/commands/scaffolds.command.d.ts.map +1 -0
  305. package/dist/commands/scaffolds.command.js +122 -0
  306. package/dist/commands/schemas.command.d.ts +21 -0
  307. package/dist/commands/schemas.command.d.ts.map +1 -0
  308. package/dist/commands/schemas.command.js +296 -0
  309. package/dist/commands/search.command.d.ts +12 -0
  310. package/dist/commands/search.command.d.ts.map +1 -0
  311. package/dist/commands/search.command.js +275 -0
  312. package/dist/commands/self-config.command.d.ts +7 -0
  313. package/dist/commands/self-config.command.d.ts.map +1 -0
  314. package/dist/commands/self-config.command.js +156 -0
  315. package/dist/commands/self.command.d.ts +3 -0
  316. package/dist/commands/self.command.d.ts.map +1 -0
  317. package/dist/commands/self.command.js +117 -0
  318. package/dist/commands/simulate.command.d.ts +3 -0
  319. package/dist/commands/simulate.command.d.ts.map +1 -0
  320. package/dist/commands/simulate.command.js +54 -0
  321. package/dist/commands/spec.command.d.ts +29 -0
  322. package/dist/commands/spec.command.d.ts.map +1 -0
  323. package/dist/commands/spec.command.js +985 -0
  324. package/dist/commands/start-here.command.d.ts +3 -0
  325. package/dist/commands/start-here.command.d.ts.map +1 -0
  326. package/dist/commands/start-here.command.js +35 -0
  327. package/dist/commands/stats.command.d.ts +3 -0
  328. package/dist/commands/stats.command.d.ts.map +1 -0
  329. package/dist/commands/stats.command.js +88 -0
  330. package/dist/commands/surface.command.d.ts +15 -0
  331. package/dist/commands/surface.command.d.ts.map +1 -0
  332. package/dist/commands/surface.command.js +328 -0
  333. package/dist/commands/task-context.command.d.ts +7 -0
  334. package/dist/commands/task-context.command.d.ts.map +1 -0
  335. package/dist/commands/task-context.command.js +646 -0
  336. package/dist/commands/task.command.d.ts +3 -0
  337. package/dist/commands/task.command.d.ts.map +1 -0
  338. package/dist/commands/task.command.js +301 -0
  339. package/dist/commands/template-quality.command.d.ts +5 -0
  340. package/dist/commands/template-quality.command.d.ts.map +1 -0
  341. package/dist/commands/template-quality.command.js +128 -0
  342. package/dist/commands/templates.command.d.ts +26 -0
  343. package/dist/commands/templates.command.d.ts.map +1 -0
  344. package/dist/commands/templates.command.js +964 -0
  345. package/dist/commands/test.command.d.ts +3 -0
  346. package/dist/commands/test.command.d.ts.map +1 -0
  347. package/dist/commands/test.command.js +262 -0
  348. package/dist/commands/tests.command.d.ts +5 -0
  349. package/dist/commands/tests.command.d.ts.map +1 -0
  350. package/dist/commands/tests.command.js +97 -0
  351. package/dist/commands/trace.command.d.ts +3 -0
  352. package/dist/commands/trace.command.d.ts.map +1 -0
  353. package/dist/commands/trace.command.js +121 -0
  354. package/dist/commands/upgrade.command.d.ts +4 -0
  355. package/dist/commands/upgrade.command.d.ts.map +1 -0
  356. package/dist/commands/upgrade.command.js +43 -0
  357. package/dist/commands/version.command.d.ts +3 -0
  358. package/dist/commands/version.command.d.ts.map +1 -0
  359. package/dist/commands/version.command.js +10 -0
  360. package/dist/commands/why.command.d.ts +24 -0
  361. package/dist/commands/why.command.d.ts.map +1 -0
  362. package/dist/commands/why.command.js +119 -0
  363. package/dist/dashboard/dashboard-api-server.d.ts +21 -0
  364. package/dist/dashboard/dashboard-api-server.d.ts.map +1 -0
  365. package/dist/dashboard/dashboard-api-server.js +410 -0
  366. package/dist/dashboard/live-session-server.d.ts +18 -0
  367. package/dist/dashboard/live-session-server.d.ts.map +1 -0
  368. package/dist/dashboard/live-session-server.js +133 -0
  369. package/dist/diff/collect-changed-paths.d.ts +27 -0
  370. package/dist/diff/collect-changed-paths.d.ts.map +1 -0
  371. package/dist/diff/collect-changed-paths.js +68 -0
  372. package/dist/doctor/doctor-tags.d.ts +63 -0
  373. package/dist/doctor/doctor-tags.d.ts.map +1 -0
  374. package/dist/doctor/doctor-tags.js +146 -0
  375. package/dist/export/export-formats.d.ts +22 -0
  376. package/dist/export/export-formats.d.ts.map +1 -0
  377. package/dist/export/export-formats.js +135 -0
  378. package/dist/index.d.ts +22 -0
  379. package/dist/index.d.ts.map +1 -0
  380. package/dist/index.js +21 -0
  381. package/dist/init/detected-block.d.ts +57 -0
  382. package/dist/init/detected-block.d.ts.map +1 -0
  383. package/dist/init/detected-block.js +197 -0
  384. package/dist/init/gitignore.d.ts +30 -0
  385. package/dist/init/gitignore.d.ts.map +1 -0
  386. package/dist/init/gitignore.js +110 -0
  387. package/dist/init/init-templates.d.ts +6 -0
  388. package/dist/init/init-templates.d.ts.map +1 -0
  389. package/dist/init/init-templates.js +413 -0
  390. package/dist/main.d.ts +18 -0
  391. package/dist/main.d.ts.map +1 -0
  392. package/dist/main.js +699 -0
  393. package/dist/output/failure-hints.d.ts +55 -0
  394. package/dist/output/failure-hints.d.ts.map +1 -0
  395. package/dist/output/failure-hints.js +159 -0
  396. package/dist/output/format-output.d.ts +9 -0
  397. package/dist/output/format-output.d.ts.map +1 -0
  398. package/dist/output/format-output.js +26 -0
  399. package/dist/output/print-error.d.ts +3 -0
  400. package/dist/output/print-error.d.ts.map +1 -0
  401. package/dist/output/print-error.js +14 -0
  402. package/dist/output/watch-loop.d.ts +37 -0
  403. package/dist/output/watch-loop.d.ts.map +1 -0
  404. package/dist/output/watch-loop.js +115 -0
  405. package/dist/schemas/json-schemas.d.ts +1630 -0
  406. package/dist/schemas/json-schemas.d.ts.map +1 -0
  407. package/dist/schemas/json-schemas.js +811 -0
  408. package/dist/surface/about.d.ts +10 -0
  409. package/dist/surface/about.d.ts.map +1 -0
  410. package/dist/surface/about.js +53 -0
  411. package/dist/surface/load-surface-context.d.ts +34 -0
  412. package/dist/surface/load-surface-context.d.ts.map +1 -0
  413. package/dist/surface/load-surface-context.js +100 -0
  414. package/dist/surface/no-args-landing.d.ts +7 -0
  415. package/dist/surface/no-args-landing.d.ts.map +1 -0
  416. package/dist/surface/no-args-landing.js +36 -0
  417. package/dist/surface/not-enabled-error.d.ts +24 -0
  418. package/dist/surface/not-enabled-error.d.ts.map +1 -0
  419. package/dist/surface/not-enabled-error.js +36 -0
  420. package/dist/surface/profiles.d.ts +37 -0
  421. package/dist/surface/profiles.d.ts.map +1 -0
  422. package/dist/surface/profiles.js +151 -0
  423. package/dist/surface/shape-defaults.d.ts +21 -0
  424. package/dist/surface/shape-defaults.d.ts.map +1 -0
  425. package/dist/surface/shape-defaults.js +50 -0
  426. package/dist/surface/spine-extractor.d.ts +38 -0
  427. package/dist/surface/spine-extractor.d.ts.map +1 -0
  428. package/dist/surface/spine-extractor.js +100 -0
  429. package/dist/surface/surface-config-writer.d.ts +59 -0
  430. package/dist/surface/surface-config-writer.d.ts.map +1 -0
  431. package/dist/surface/surface-config-writer.js +135 -0
  432. package/dist/surface/surface-summary.d.ts +66 -0
  433. package/dist/surface/surface-summary.d.ts.map +1 -0
  434. package/dist/surface/surface-summary.js +162 -0
  435. package/dist/surface/tier.d.ts +100 -0
  436. package/dist/surface/tier.d.ts.map +1 -0
  437. package/dist/surface/tier.js +172 -0
  438. package/dist/task-next/apply-batch-runner.d.ts +42 -0
  439. package/dist/task-next/apply-batch-runner.d.ts.map +1 -0
  440. package/dist/task-next/apply-batch-runner.js +192 -0
  441. package/dist/task-next/task-next-ranker.d.ts +75 -0
  442. package/dist/task-next/task-next-ranker.d.ts.map +1 -0
  443. package/dist/task-next/task-next-ranker.js +179 -0
  444. package/dist/usage/usage-log.d.ts +54 -0
  445. package/dist/usage/usage-log.d.ts.map +1 -0
  446. package/dist/usage/usage-log.js +105 -0
  447. package/dist/validation/run-validation-loop.d.ts +38 -0
  448. package/dist/validation/run-validation-loop.d.ts.map +1 -0
  449. package/dist/validation/run-validation-loop.js +100 -0
  450. package/package.json +73 -0
@@ -0,0 +1,451 @@
1
+ import { existsSync, readFileSync } from 'node:fs';
2
+ import * as nodePath from 'node:path';
3
+ import { appendPolicyOverrideAudit, applyPolicyOverrides, ChangedScopeMode, classifyChangedScope, evaluatePolicy, inspectSharkcraft, listPolicyOverrides, PolicySeverity, resolveChangedFiles, runPolicySnapshot, runPolicyTest, runPolicyTestsForAll, summariseChangedScope, } from '@shrkcrft/inspector';
4
+ import { flagBool, flagString, flagList, resolveCwd, } from "../command-registry.js";
5
+ import { asJson, header } from "../output/format-output.js";
6
+ function buildEvaluateInput(args) {
7
+ const out = {};
8
+ const plan = flagString(args, 'plan');
9
+ if (plan)
10
+ out.planFile = plan;
11
+ const bundle = flagString(args, 'bundle');
12
+ if (bundle)
13
+ out.bundleId = bundle;
14
+ const session = flagString(args, 'session');
15
+ if (session)
16
+ out.sessionId = session;
17
+ if (flagBool(args, 'no-pack-policies'))
18
+ out.skipPackPolicies = true;
19
+ if (flagBool(args, 'require-signed-policy-packs'))
20
+ out.requireSignedPolicyPacks = true;
21
+ const local = flagList(args, 'local-files');
22
+ if (local.length > 0)
23
+ out.localPolicyFiles = local;
24
+ return out;
25
+ }
26
+ export const policyListCommand = {
27
+ name: 'list',
28
+ description: 'List registered policy checks (local + pack).',
29
+ usage: 'shrk policy list [--json] [--no-pack-policies] [--require-signed-policy-packs]',
30
+ async run(args) {
31
+ const cwd = resolveCwd(args);
32
+ const inspection = await inspectSharkcraft({ cwd });
33
+ const report = await evaluatePolicy(inspection, {
34
+ ...buildEvaluateInput(args),
35
+ onlyId: '__none__', // skip predicate execution; we only want registrations
36
+ });
37
+ const regs = report.registrations;
38
+ if (flagBool(args, 'json')) {
39
+ process.stdout.write(asJson(regs) + '\n');
40
+ return 0;
41
+ }
42
+ process.stdout.write(header(`Policy checks (${regs.length})`));
43
+ for (const r of regs) {
44
+ process.stdout.write(` [${r.source}] ${r.severity.padEnd(7)} ${r.id.padEnd(40)} ${r.title}\n`);
45
+ }
46
+ return 0;
47
+ },
48
+ };
49
+ export const policyGetCommand = {
50
+ name: 'get',
51
+ description: 'Show details for a registered policy check.',
52
+ usage: 'shrk policy get <id> [--json]',
53
+ async run(args) {
54
+ const id = args.positional[0];
55
+ if (!id) {
56
+ process.stderr.write('Usage: shrk policy get <id>\n');
57
+ return 2;
58
+ }
59
+ const cwd = resolveCwd(args);
60
+ const inspection = await inspectSharkcraft({ cwd });
61
+ const report = await evaluatePolicy(inspection, {
62
+ ...buildEvaluateInput(args),
63
+ onlyId: '__none__',
64
+ });
65
+ const reg = report.registrations.find((r) => r.id === id);
66
+ if (!reg) {
67
+ process.stderr.write(`No policy check "${id}"\n`);
68
+ return 1;
69
+ }
70
+ if (flagBool(args, 'json')) {
71
+ process.stdout.write(asJson(reg) + '\n');
72
+ return 0;
73
+ }
74
+ process.stdout.write(`${reg.id}\n title: ${reg.title}\n severity: ${reg.severity}\n source: ${reg.source}\n file: ${reg.sourceFile}\n`);
75
+ if (reg.packName)
76
+ process.stdout.write(` pack: ${reg.packName} (${reg.signatureStatus ?? 'unknown'})\n`);
77
+ return 0;
78
+ },
79
+ };
80
+ export const policyTestCommand = {
81
+ name: 'test',
82
+ description: 'Test policy checks against fixtures or inline JSON input.',
83
+ usage: 'shrk policy test <id> [--fixture <dir>] [--input <json>] [--update-snapshot] [--json]\n shrk policy test --all [--fixture <dir>] [--json]',
84
+ async run(args) {
85
+ const cwd = resolveCwd(args);
86
+ const inspection = await inspectSharkcraft({ cwd });
87
+ const all = flagBool(args, 'all');
88
+ const fixtureFlag = flagString(args, 'fixture');
89
+ const inputFlag = flagString(args, 'input');
90
+ const id = args.positional[0];
91
+ if (all) {
92
+ const batch = await runPolicyTestsForAll(inspection, {
93
+ ...(fixtureFlag ? { fixtureDir: fixtureFlag } : {}),
94
+ });
95
+ if (flagBool(args, 'json')) {
96
+ process.stdout.write(asJson(batch) + '\n');
97
+ return batch.summary.failed === 0 ? 0 : 1;
98
+ }
99
+ process.stdout.write(header(`Policy tests (${batch.summary.total})`));
100
+ for (const r of batch.results) {
101
+ const tag = r.passed ? 'OK ' : 'FAIL';
102
+ process.stdout.write(` ${tag} ${r.policyId.padEnd(36)} ${r.inputSource}\n`);
103
+ for (const c of r.checks) {
104
+ process.stdout.write(` [${c.severity}] ${c.message}\n`);
105
+ }
106
+ if (r.expectationOutcome && !r.expectationOutcome.matched) {
107
+ for (const m of r.expectationOutcome.mismatches)
108
+ process.stdout.write(` ! expectation: ${m}\n`);
109
+ }
110
+ }
111
+ process.stdout.write(`\nSummary: ${batch.summary.passed}/${batch.summary.total} passed\n`);
112
+ return batch.summary.failed === 0 ? 0 : 1;
113
+ }
114
+ if (!id) {
115
+ process.stderr.write('Usage: shrk policy test <id> [--fixture <dir>|--input <json>]\n');
116
+ return 2;
117
+ }
118
+ let policyInput;
119
+ if (inputFlag) {
120
+ try {
121
+ // If inputFlag is a JSON path or inline JSON.
122
+ if (existsSync(inputFlag)) {
123
+ policyInput = JSON.parse(readFileSync(inputFlag, 'utf8'));
124
+ }
125
+ else {
126
+ policyInput = JSON.parse(inputFlag);
127
+ }
128
+ }
129
+ catch (e) {
130
+ process.stderr.write(`Invalid --input: ${e.message}\n`);
131
+ return 2;
132
+ }
133
+ }
134
+ const wantSnapshotUpdate = flagBool(args, 'update-snapshot');
135
+ if (wantSnapshotUpdate || (fixtureFlag && existsSync(nodePath.join(fixtureFlag, 'snapshot.json')))) {
136
+ const snapshotFile = fixtureFlag
137
+ ? nodePath.join(fixtureFlag, 'snapshot.json')
138
+ : nodePath.join(cwd, '.sharkcraft', 'policy-snapshots', `${id}.snapshot.json`);
139
+ const outcome = await runPolicySnapshot(inspection, {
140
+ policyId: id,
141
+ ...(fixtureFlag ? { fixtureDir: fixtureFlag } : {}),
142
+ ...(policyInput ? { policyInput } : {}),
143
+ }, {
144
+ snapshotFile,
145
+ updateSnapshot: wantSnapshotUpdate,
146
+ });
147
+ if (flagBool(args, 'json')) {
148
+ process.stdout.write(asJson(outcome) + '\n');
149
+ return outcome.matchesSnapshot ? 0 : 1;
150
+ }
151
+ process.stdout.write(header(`Policy snapshot: ${id}`));
152
+ process.stdout.write(`snapshot: ${snapshotFile}\n`);
153
+ process.stdout.write(`input: ${outcome.inputSource}\n`);
154
+ process.stdout.write(`current: ${outcome.result.passed ? 'pass' : 'fail'}\n`);
155
+ if (outcome.updated)
156
+ process.stdout.write('snapshot: WRITTEN\n');
157
+ if (!outcome.matchesSnapshot) {
158
+ process.stdout.write('result: SNAPSHOT MISMATCH\n');
159
+ for (const d of outcome.diffs)
160
+ process.stdout.write(` - ${d}\n`);
161
+ }
162
+ else {
163
+ process.stdout.write('result: snapshot matches\n');
164
+ }
165
+ return outcome.matchesSnapshot ? 0 : 1;
166
+ }
167
+ const result = await runPolicyTest(inspection, {
168
+ policyId: id,
169
+ ...(fixtureFlag ? { fixtureDir: fixtureFlag } : {}),
170
+ ...(policyInput ? { policyInput } : {}),
171
+ });
172
+ if (flagBool(args, 'json')) {
173
+ process.stdout.write(asJson(result) + '\n');
174
+ return result.passed ? 0 : 1;
175
+ }
176
+ process.stdout.write(header(`Policy test: ${id}`));
177
+ process.stdout.write(`input: ${result.inputSource}\n`);
178
+ if (result.registration) {
179
+ process.stdout.write(`registered: [${result.registration.source}] severity=${result.registration.severity}\n`);
180
+ }
181
+ else {
182
+ process.stdout.write('registered: (not registered locally — fixture-only test)\n');
183
+ }
184
+ if (result.checks.length === 0) {
185
+ process.stdout.write(`result: PASS\n`);
186
+ }
187
+ else {
188
+ process.stdout.write(`result: FAIL\n`);
189
+ for (const c of result.checks) {
190
+ process.stdout.write(` [${c.severity}] ${c.title} — ${c.message}\n`);
191
+ if (c.suggestedFix)
192
+ process.stdout.write(` fix: ${c.suggestedFix}\n`);
193
+ if (c.context)
194
+ process.stdout.write(` evidence: ${JSON.stringify(c.context)}\n`);
195
+ }
196
+ }
197
+ if (result.expectationOutcome) {
198
+ if (result.expectationOutcome.matched) {
199
+ process.stdout.write('expectation: MET\n');
200
+ }
201
+ else {
202
+ process.stdout.write('expectation: MISMATCH\n');
203
+ for (const m of result.expectationOutcome.mismatches)
204
+ process.stdout.write(` - ${m}\n`);
205
+ }
206
+ return result.expectationOutcome.matched ? 0 : 1;
207
+ }
208
+ return result.passed ? 0 : 1;
209
+ },
210
+ };
211
+ function readChangedScopeOptionsForPolicy(args, projectRoot) {
212
+ const changedOnly = flagBool(args, 'changed-only');
213
+ const since = flagString(args, 'since');
214
+ const staged = flagBool(args, 'staged');
215
+ const files = flagList(args, 'files');
216
+ if (!changedOnly && !since && !staged && files.length === 0)
217
+ return null;
218
+ return {
219
+ projectRoot,
220
+ ...(since ? { since } : {}),
221
+ ...(staged ? { staged: true } : {}),
222
+ ...(files.length > 0 ? { files } : {}),
223
+ includeWorktree: changedOnly || !since,
224
+ };
225
+ }
226
+ export const policyRunCommand = {
227
+ name: 'run',
228
+ description: 'Run all policy checks; alias for `policy check` with richer output. `--explain-overrides` shows applied overrides; `--record-override-audit` appends them to `.sharkcraft/policy-override-audit.log`. `--changed-only|--since|--staged|--files` filters findings via the shared changed-scope classifier.',
229
+ usage: 'shrk policy run [--plan <plan.json>] [--bundle <id>] [--no-pack-policies] [--require-signed-policy-packs] [--explain-overrides] [--record-override-audit] [--changed-only|--since <ref>|--staged|--files a,b,c] [--json]',
230
+ async run(args) {
231
+ const cwd = resolveCwd(args);
232
+ const inspection = await inspectSharkcraft({ cwd });
233
+ const baseReport = await evaluatePolicy(inspection, buildEvaluateInput(args));
234
+ const overrides = listPolicyOverrides(inspection);
235
+ const explainOverrides = flagBool(args, 'explain-overrides');
236
+ const recordAudit = flagBool(args, 'record-override-audit');
237
+ const { report, explain } = applyPolicyOverrides(baseReport, overrides);
238
+ const changedScopeOpts = readChangedScopeOptionsForPolicy(args, cwd);
239
+ const classification = changedScopeOpts
240
+ ? (() => {
241
+ const resolved = resolveChangedFiles(changedScopeOpts);
242
+ return classifyChangedScope({
243
+ projectRoot: cwd,
244
+ current: report.checks.map((c) => ({
245
+ key: `${c.id}:${c.context?.file ?? ''}`,
246
+ code: c.id,
247
+ severity: c.severity,
248
+ message: c.message,
249
+ file: c.context?.file,
250
+ })),
251
+ changedFiles: resolved.files,
252
+ });
253
+ })()
254
+ : null;
255
+ if (recordAudit && explain.applied.length > 0) {
256
+ const entries = explain.applied.map((a) => ({
257
+ policyId: a.policyId,
258
+ ...(a.originalSeverity ? { originalSeverity: a.originalSeverity } : {}),
259
+ ...(a.appliedSeverity ? { effectiveSeverity: a.appliedSeverity } : {}),
260
+ disabled: a.disabled === true,
261
+ ...(a.reason ? { reason: a.reason } : {}),
262
+ sourceConfig: 'sharkcraft.config.ts',
263
+ command: 'shrk policy run',
264
+ }));
265
+ appendPolicyOverrideAudit(inspection, entries);
266
+ }
267
+ if (flagBool(args, 'json')) {
268
+ process.stdout.write(asJson({
269
+ ...report,
270
+ ...(explainOverrides ? { overrides: explain } : {}),
271
+ ...(classification ? { changedScope: classification } : {}),
272
+ }) + '\n');
273
+ return report.summary.passed ? 0 : 1;
274
+ }
275
+ process.stdout.write(header(`Policy run (${report.registrations.length} registered)`));
276
+ process.stdout.write(`passed=${report.summary.passed} info=${report.summary.info} warning=${report.summary.warning} error=${report.summary.error} critical=${report.summary.critical}\n`);
277
+ if (classification) {
278
+ process.stdout.write(`changed-scope: ${summariseChangedScope(classification)}\n`);
279
+ }
280
+ void ChangedScopeMode;
281
+ process.stdout.write('Registered:\n');
282
+ for (const r of report.registrations) {
283
+ process.stdout.write(` [${r.source}] ${r.id}\n`);
284
+ }
285
+ process.stdout.write('Findings:\n');
286
+ for (const c of report.checks.slice(0, 50)) {
287
+ process.stdout.write(` [${c.severity}] ${c.id}: ${c.message}\n`);
288
+ }
289
+ if (explainOverrides) {
290
+ process.stdout.write('Applied overrides:\n');
291
+ for (const a of explain.applied) {
292
+ const detail = a.disabled
293
+ ? `disabled (was ${a.originalSeverity ?? '?'})`
294
+ : `${a.originalSeverity ?? '?'} → ${a.appliedSeverity ?? '?'}`;
295
+ process.stdout.write(` • ${a.policyId} — ${detail}${a.reason ? ` — ${a.reason}` : ''}\n`);
296
+ }
297
+ if (explain.applied.length === 0)
298
+ process.stdout.write(' (none)\n');
299
+ }
300
+ if (recordAudit) {
301
+ if (explain.applied.length > 0)
302
+ process.stdout.write(`Recorded ${explain.applied.length} entry/entries in policy-override-audit.log\n`);
303
+ else
304
+ process.stdout.write('No overrides applied — nothing recorded.\n');
305
+ }
306
+ void PolicySeverity;
307
+ void existsSync;
308
+ void readFileSync;
309
+ void nodePath;
310
+ return report.summary.passed ? 0 : 1;
311
+ },
312
+ };
313
+ export const policySnapshotCommand = {
314
+ name: 'snapshot',
315
+ description: 'Capture / compare policy snapshots (writes only under fixture dirs). Supports --gate (CI) and --accept (rewrite after review).',
316
+ usage: 'shrk policy snapshot <id> [--input <json>|--fixture <dir>] [--gate] [--accept] [--update-snapshot] [--json]\n shrk policy snapshot --all --fixture <dir> [--gate] [--accept] [--json]',
317
+ async run(args) {
318
+ const cwd = resolveCwd(args);
319
+ const inspection = await inspectSharkcraft({ cwd });
320
+ const all = flagBool(args, 'all');
321
+ const fixtureFlag = flagString(args, 'fixture');
322
+ const inputFlag = flagString(args, 'input');
323
+ const updateSnap = flagBool(args, 'update-snapshot') || flagBool(args, 'accept');
324
+ const gate = flagBool(args, 'gate');
325
+ const wantJson = flagBool(args, 'json');
326
+ const buckets = {
327
+ passed: [],
328
+ drifted: [],
329
+ missing: [],
330
+ updated: [],
331
+ skipped: [],
332
+ };
333
+ const runOne = async (id, fixture, policyInput) => {
334
+ const snapshotFile = fixture
335
+ ? nodePath.join(fixture, 'snapshot.json')
336
+ : nodePath.join(cwd, '.sharkcraft', 'policy-snapshots', `${id}.snapshot.json`);
337
+ const had = existsSync(snapshotFile);
338
+ const outcome = await runPolicySnapshot(inspection, {
339
+ policyId: id,
340
+ ...(fixture ? { fixtureDir: fixture } : {}),
341
+ ...(policyInput ? { policyInput } : {}),
342
+ }, { snapshotFile, updateSnapshot: updateSnap });
343
+ let bucket;
344
+ if (!had) {
345
+ bucket = updateSnap ? 'updated' : 'missing';
346
+ }
347
+ else if (outcome.updated) {
348
+ bucket = 'updated';
349
+ }
350
+ else if (outcome.matchesSnapshot) {
351
+ bucket = 'passed';
352
+ }
353
+ else {
354
+ bucket = 'drifted';
355
+ }
356
+ buckets[bucket].push({ id, bucket, outcome });
357
+ };
358
+ if (all) {
359
+ if (!fixtureFlag) {
360
+ process.stderr.write('Usage: shrk policy snapshot --all --fixture <dir>\n');
361
+ return 2;
362
+ }
363
+ if (!existsSync(fixtureFlag)) {
364
+ process.stderr.write(`Fixture dir not found: ${fixtureFlag}\n`);
365
+ return 1;
366
+ }
367
+ const { readdirSync } = await import('node:fs');
368
+ const subs = readdirSync(fixtureFlag, { withFileTypes: true }).filter((e) => e.isDirectory());
369
+ for (const s of subs) {
370
+ await runOne(s.name, nodePath.join(fixtureFlag, s.name), undefined);
371
+ }
372
+ }
373
+ else {
374
+ const id = args.positional[0];
375
+ if (!id) {
376
+ process.stderr.write('Usage: shrk policy snapshot <id> [--input <json>|--fixture <dir>]\n');
377
+ return 2;
378
+ }
379
+ let policyInput;
380
+ if (inputFlag) {
381
+ try {
382
+ policyInput = existsSync(inputFlag)
383
+ ? JSON.parse(readFileSync(inputFlag, 'utf8'))
384
+ : JSON.parse(inputFlag);
385
+ }
386
+ catch (e) {
387
+ process.stderr.write(`Invalid --input: ${e.message}\n`);
388
+ return 2;
389
+ }
390
+ }
391
+ await runOne(id, fixtureFlag ?? undefined, policyInput);
392
+ }
393
+ const summary = {
394
+ passed: buckets.passed.length,
395
+ drifted: buckets.drifted.length,
396
+ missing: buckets.missing.length,
397
+ updated: buckets.updated.length,
398
+ skipped: buckets.skipped.length,
399
+ total: buckets.passed.length +
400
+ buckets.drifted.length +
401
+ buckets.missing.length +
402
+ buckets.updated.length +
403
+ buckets.skipped.length,
404
+ };
405
+ const gateFailed = gate && (summary.drifted > 0 || summary.missing > 0);
406
+ if (wantJson) {
407
+ const report = {
408
+ schema: 'sharkcraft.policy-snapshot-batch/v1',
409
+ summary,
410
+ passed: buckets.passed.map((b) => b.outcome),
411
+ drifted: buckets.drifted.map((b) => b.outcome),
412
+ missing: buckets.missing.map((b) => b.outcome),
413
+ updated: buckets.updated.map((b) => b.outcome),
414
+ skipped: buckets.skipped.map((b) => b.outcome),
415
+ gate,
416
+ gatePassed: !gateFailed,
417
+ };
418
+ process.stdout.write(asJson(report) + '\n');
419
+ return gateFailed ? 1 : 0;
420
+ }
421
+ process.stdout.write(header(`Policy snapshots (${summary.total})`));
422
+ process.stdout.write(`passed=${summary.passed} drifted=${summary.drifted} missing=${summary.missing} updated=${summary.updated} skipped=${summary.skipped}\n`);
423
+ const printBucket = (label, tag, list) => {
424
+ if (list.length === 0)
425
+ return;
426
+ process.stdout.write(`\n${label}:\n`);
427
+ for (const r of list) {
428
+ process.stdout.write(` ${tag} ${r.id.padEnd(36)} ${r.outcome.snapshotFile}\n`);
429
+ for (const d of r.outcome.diffs.slice(0, 3)) {
430
+ process.stdout.write(` - ${d}\n`);
431
+ }
432
+ }
433
+ };
434
+ printBucket('Passed', 'OK ', buckets.passed);
435
+ printBucket('Drifted', 'DIFF ', buckets.drifted);
436
+ printBucket('Missing snapshot', 'MISS ', buckets.missing);
437
+ printBucket('Updated', 'WRITE', buckets.updated);
438
+ printBucket('Skipped', 'SKIP ', buckets.skipped);
439
+ if (gate) {
440
+ process.stdout.write(`\nGate: ${gateFailed ? 'FAILED' : 'OK'}\n`);
441
+ }
442
+ return gateFailed ? 1 : 0;
443
+ },
444
+ };
445
+ // Keep the existing `policy check` name for backwards compatibility.
446
+ export const policyCheckCommand = {
447
+ name: 'check',
448
+ description: 'Run policy engine across boundaries, ownership, plans, packs.',
449
+ usage: 'shrk policy check [--plan <plan>] [--bundle <id>] [--session <id>] [--json]',
450
+ run: policyRunCommand.run,
451
+ };
@@ -0,0 +1,3 @@
1
+ import { type ICommandHandler } from '../command-registry.js';
2
+ export declare const prCommand: ICommandHandler;
3
+ //# sourceMappingURL=pr.command.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pr.command.d.ts","sourceRoot":"","sources":["../../src/commands/pr.command.ts"],"names":[],"mappings":"AAgBA,OAAO,EAML,KAAK,eAAe,EAErB,MAAM,wBAAwB,CAAC;AAgGhC,eAAO,MAAM,SAAS,EAAE,eAcvB,CAAC"}
@@ -0,0 +1,132 @@
1
+ /**
2
+ * `shrk pr <verb>`.
3
+ *
4
+ * Generates a deterministic PR description from `shrk changes summary` +
5
+ * any reports present under `.sharkcraft/reports/`.
6
+ *
7
+ * Read-only at the inspector level. `--output <file>` writes only when the
8
+ * developer explicitly opts in.
9
+ */
10
+ import { existsSync, mkdirSync, writeFileSync } from 'node:fs';
11
+ import * as nodePath from 'node:path';
12
+ import { buildPrSummary, inspectSharkcraft, } from '@shrkcrft/inspector';
13
+ import { flagBool, flagNumber, flagString, flagList, resolveCwd, } from "../command-registry.js";
14
+ import { asJson } from "../output/format-output.js";
15
+ async function runPrSummary(args) {
16
+ const cwd = resolveCwd(args);
17
+ const inspection = await inspectSharkcraft({ cwd });
18
+ const opts = {};
19
+ const since = flagString(args, 'since');
20
+ const staged = flagBool(args, 'staged');
21
+ const files = flagList(args, 'files');
22
+ const maxItems = flagNumber(args, 'max-items');
23
+ if (since)
24
+ opts.since = since;
25
+ if (staged)
26
+ opts.staged = true;
27
+ if (files.length > 0)
28
+ opts.files = files;
29
+ if (typeof maxItems === 'number')
30
+ opts.maxItems = maxItems;
31
+ if (flagBool(args, 'include-raw-links'))
32
+ opts.includeRawLinks = true;
33
+ // Session / bundle artifact sources.
34
+ const fromSession = flagString(args, 'from-session');
35
+ if (fromSession)
36
+ opts.fromSession = fromSession;
37
+ const fromBundle = flagString(args, 'from-bundle');
38
+ if (fromBundle)
39
+ opts.fromBundle = fromBundle;
40
+ const report = await buildPrSummary(inspection, opts);
41
+ const format = flagString(args, 'format') ?? (flagBool(args, 'json') ? 'json' : 'markdown');
42
+ const output = flagString(args, 'output');
43
+ if (format === 'json') {
44
+ const payload = asJson(report) + '\n';
45
+ if (output)
46
+ writeOutputFile(cwd, output, payload);
47
+ else
48
+ process.stdout.write(payload);
49
+ return 0;
50
+ }
51
+ if (output) {
52
+ writeOutputFile(cwd, output, report.markdown);
53
+ return 0;
54
+ }
55
+ // Default human output is a compact summary (the long markdown body
56
+ // is one flag away via --full / --verbose, or to a file via
57
+ // --output). Keeps `shrk pr summary` under ~25 lines in the terminal.
58
+ const wantsFull = flagBool(args, 'full') || flagBool(args, 'verbose');
59
+ if (wantsFull || format !== 'markdown') {
60
+ process.stdout.write(report.markdown);
61
+ return 0;
62
+ }
63
+ process.stdout.write(renderPrSummaryCompact(report.markdown));
64
+ return 0;
65
+ }
66
+ function renderPrSummaryCompact(markdown) {
67
+ // The PR body is a Markdown document; for the compact view we keep the
68
+ // first heading + its first ~6 list items + the test-plan headline, and
69
+ // point at the long form. This is a pure string slice — no parsing.
70
+ const lines = markdown.split('\n');
71
+ const out = [];
72
+ let kept = 0;
73
+ let inList = false;
74
+ let listCount = 0;
75
+ for (const line of lines) {
76
+ if (line.startsWith('## ')) {
77
+ inList = false;
78
+ listCount = 0;
79
+ out.push(line);
80
+ kept += 1;
81
+ if (kept > 60)
82
+ break;
83
+ continue;
84
+ }
85
+ if (line.startsWith('- ') || line.startsWith('* ')) {
86
+ inList = true;
87
+ listCount += 1;
88
+ if (listCount <= 6)
89
+ out.push(line);
90
+ else if (listCount === 7)
91
+ out.push(' …');
92
+ kept += 1;
93
+ continue;
94
+ }
95
+ if (line.trim().length === 0) {
96
+ inList = false;
97
+ out.push(line);
98
+ kept += 1;
99
+ continue;
100
+ }
101
+ if (!inList) {
102
+ out.push(line);
103
+ kept += 1;
104
+ }
105
+ }
106
+ out.push('');
107
+ out.push('(text mode is summary-only — pass --full / --verbose for the full PR body, --json for machine output, --output <file> to write to disk.)');
108
+ return out.join('\n') + '\n';
109
+ }
110
+ function writeOutputFile(cwd, file, body) {
111
+ const abs = nodePath.isAbsolute(file) ? file : nodePath.join(cwd, file);
112
+ const dir = nodePath.dirname(abs);
113
+ if (!existsSync(dir))
114
+ mkdirSync(dir, { recursive: true });
115
+ writeFileSync(abs, body, 'utf8');
116
+ process.stdout.write(`Wrote ${abs}\n`);
117
+ }
118
+ export const prCommand = {
119
+ name: 'pr',
120
+ description: 'PR summary / description generator. Consumes `shrk changes summary` + .sharkcraft/reports/*. Read-only by default. Write only when --output is passed.',
121
+ usage: 'shrk pr <summary|description> [--since <ref>|--staged|--files a,b,c] [--max-items N] [--format markdown|json] [--output <file>] [--include-raw-links]',
122
+ async run(args) {
123
+ const sub = args.positional[0];
124
+ const sliced = { ...args, positional: args.positional.slice(1) };
125
+ if (sub === 'summary' || sub === 'description')
126
+ return runPrSummary(sliced);
127
+ if (sub === undefined)
128
+ return runPrSummary(args);
129
+ process.stderr.write('Usage: shrk pr <summary|description> [...]\n');
130
+ return 2;
131
+ },
132
+ };
@@ -0,0 +1,3 @@
1
+ import { type ICommandHandler } from '../command-registry.js';
2
+ export declare const preflightCommand: ICommandHandler;
3
+ //# sourceMappingURL=preflight.command.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"preflight.command.d.ts","sourceRoot":"","sources":["../../src/commands/preflight.command.ts"],"names":[],"mappings":"AAoBA,OAAO,EAIL,KAAK,eAAe,EAErB,MAAM,wBAAwB,CAAC;AAgBhC,eAAO,MAAM,gBAAgB,EAAE,eAmF9B,CAAC"}