prjct-cli 1.22.0 → 1.23.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 (448) hide show
  1. package/CHANGELOG.md +147 -0
  2. package/bin/prjct +30 -13
  3. package/dist/bin/prjct.mjs +917 -35845
  4. package/dist/bin/prjct.mjs.map +7 -0
  5. package/dist/cli/linear.mjs +16 -0
  6. package/dist/cli/linear.mjs.map +7 -0
  7. package/dist/templates.json +1 -0
  8. package/package.json +4 -5
  9. package/bin/prjct.ts +0 -342
  10. package/core/__tests__/agentic/analysis-injection.test.ts +0 -377
  11. package/core/__tests__/agentic/cache-eviction.test.ts +0 -294
  12. package/core/__tests__/agentic/command-context.test.ts +0 -281
  13. package/core/__tests__/agentic/command-executor.test.ts +0 -659
  14. package/core/__tests__/agentic/domain-classifier.test.ts +0 -330
  15. package/core/__tests__/agentic/injection-validator.test.ts +0 -255
  16. package/core/__tests__/agentic/memory-system.test.ts +0 -281
  17. package/core/__tests__/agentic/plan-mode.test.ts +0 -386
  18. package/core/__tests__/agentic/prompt-assembly.test.ts +0 -298
  19. package/core/__tests__/agentic/prompt-builder.test.ts +0 -243
  20. package/core/__tests__/agentic/response-validator.test.ts +0 -263
  21. package/core/__tests__/agentic/semantic-matching.test.ts +0 -131
  22. package/core/__tests__/agentic/smart-context.test.ts +0 -372
  23. package/core/__tests__/agentic/tech-normalizer.test.ts +0 -136
  24. package/core/__tests__/agentic/token-budget.test.ts +0 -294
  25. package/core/__tests__/ai-tools/formatters.test.ts +0 -476
  26. package/core/__tests__/domain/bm25.test.ts +0 -225
  27. package/core/__tests__/domain/change-propagator.test.ts +0 -100
  28. package/core/__tests__/domain/fibonacci.test.ts +0 -113
  29. package/core/__tests__/domain/file-hasher.test.ts +0 -146
  30. package/core/__tests__/domain/file-ranker.test.ts +0 -169
  31. package/core/__tests__/domain/git-cochange.test.ts +0 -121
  32. package/core/__tests__/domain/import-graph.test.ts +0 -156
  33. package/core/__tests__/domain/velocity.test.ts +0 -623
  34. package/core/__tests__/infrastructure/performance-tracker.test.ts +0 -328
  35. package/core/__tests__/schemas/model.test.ts +0 -272
  36. package/core/__tests__/services/dependency-validator.test.ts +0 -175
  37. package/core/__tests__/services/hierarchical-agent-resolver.test.ts +0 -359
  38. package/core/__tests__/services/nested-context-resolver.test.ts +0 -443
  39. package/core/__tests__/services/project-index.test.ts +0 -355
  40. package/core/__tests__/services/staleness-checker.test.ts +0 -204
  41. package/core/__tests__/storage/analysis-storage.test.ts +0 -641
  42. package/core/__tests__/storage/archive-storage.test.ts +0 -455
  43. package/core/__tests__/storage/safe-reader.test.ts +0 -262
  44. package/core/__tests__/storage/sqlite-migration.test.ts +0 -1016
  45. package/core/__tests__/storage/state-storage-feedback.test.ts +0 -463
  46. package/core/__tests__/storage/state-storage-history.test.ts +0 -469
  47. package/core/__tests__/storage/storage-manager.test.ts +0 -383
  48. package/core/__tests__/storage/subtask-handoff.test.ts +0 -237
  49. package/core/__tests__/types/fs.test.ts +0 -125
  50. package/core/__tests__/utils/date-helper.test.ts +0 -449
  51. package/core/__tests__/utils/output.test.ts +0 -278
  52. package/core/__tests__/utils/preserve-sections.test.ts +0 -216
  53. package/core/__tests__/utils/project-commands.test.ts +0 -71
  54. package/core/__tests__/utils/retry.test.ts +0 -381
  55. package/core/__tests__/workflow/state-machine.test.ts +0 -216
  56. package/core/agentic/agent-router.ts +0 -150
  57. package/core/agentic/anti-hallucination.ts +0 -141
  58. package/core/agentic/chain-of-thought.ts +0 -234
  59. package/core/agentic/command-classifier.ts +0 -141
  60. package/core/agentic/command-context.ts +0 -168
  61. package/core/agentic/command-executor.ts +0 -471
  62. package/core/agentic/context-builder.ts +0 -285
  63. package/core/agentic/domain-classifier.ts +0 -525
  64. package/core/agentic/environment-block.ts +0 -102
  65. package/core/agentic/ground-truth.ts +0 -706
  66. package/core/agentic/index.ts +0 -193
  67. package/core/agentic/injection-validator.ts +0 -208
  68. package/core/agentic/loop-detector.ts +0 -451
  69. package/core/agentic/memory-system.ts +0 -1547
  70. package/core/agentic/orchestrator-executor.ts +0 -579
  71. package/core/agentic/plan-mode.ts +0 -525
  72. package/core/agentic/prompt-builder.ts +0 -1069
  73. package/core/agentic/response-validator.ts +0 -98
  74. package/core/agentic/services.ts +0 -167
  75. package/core/agentic/skill-loader.ts +0 -106
  76. package/core/agentic/smart-context.ts +0 -393
  77. package/core/agentic/tech-normalizer.ts +0 -167
  78. package/core/agentic/template-executor.ts +0 -272
  79. package/core/agentic/template-loader.ts +0 -109
  80. package/core/agentic/token-budget.ts +0 -226
  81. package/core/agentic/tool-registry.ts +0 -146
  82. package/core/agents/index.ts +0 -28
  83. package/core/agents/performance.ts +0 -429
  84. package/core/ai-tools/formatters.ts +0 -341
  85. package/core/ai-tools/generator.ts +0 -144
  86. package/core/ai-tools/index.ts +0 -15
  87. package/core/ai-tools/registry.ts +0 -201
  88. package/core/bus/bus.ts +0 -314
  89. package/core/bus/index.ts +0 -8
  90. package/core/cli/linear.ts +0 -500
  91. package/core/cli/lint-meta-commentary.ts +0 -177
  92. package/core/cli/start.ts +0 -386
  93. package/core/commands/analysis.ts +0 -1274
  94. package/core/commands/analytics.ts +0 -342
  95. package/core/commands/base.ts +0 -118
  96. package/core/commands/cleanup.ts +0 -157
  97. package/core/commands/command-data.ts +0 -463
  98. package/core/commands/commands.ts +0 -306
  99. package/core/commands/context.ts +0 -238
  100. package/core/commands/design.ts +0 -77
  101. package/core/commands/index.ts +0 -19
  102. package/core/commands/maintenance.ts +0 -77
  103. package/core/commands/performance.ts +0 -114
  104. package/core/commands/planning.ts +0 -662
  105. package/core/commands/register.ts +0 -127
  106. package/core/commands/registry.ts +0 -444
  107. package/core/commands/setup.ts +0 -280
  108. package/core/commands/shipping.ts +0 -267
  109. package/core/commands/snapshots.ts +0 -297
  110. package/core/commands/uninstall.ts +0 -542
  111. package/core/commands/velocity.ts +0 -149
  112. package/core/commands/workflow.ts +0 -505
  113. package/core/config/command-context.config.json +0 -66
  114. package/core/constants/index.ts +0 -379
  115. package/core/context/generator.ts +0 -368
  116. package/core/context-tools/files-tool.ts +0 -577
  117. package/core/context-tools/imports-tool.ts +0 -400
  118. package/core/context-tools/index.ts +0 -434
  119. package/core/context-tools/recent-tool.ts +0 -301
  120. package/core/context-tools/signatures-tool.ts +0 -495
  121. package/core/context-tools/summary-tool.ts +0 -301
  122. package/core/context-tools/token-counter.ts +0 -273
  123. package/core/context-tools/types.ts +0 -253
  124. package/core/domain/agent-generator.ts +0 -186
  125. package/core/domain/agent-loader.ts +0 -419
  126. package/core/domain/analyzer.ts +0 -387
  127. package/core/domain/architecture-generator.ts +0 -108
  128. package/core/domain/bm25.ts +0 -525
  129. package/core/domain/change-propagator.ts +0 -162
  130. package/core/domain/context-estimator.ts +0 -175
  131. package/core/domain/fibonacci.ts +0 -128
  132. package/core/domain/file-hasher.ts +0 -296
  133. package/core/domain/file-ranker.ts +0 -151
  134. package/core/domain/git-cochange.ts +0 -250
  135. package/core/domain/import-graph.ts +0 -315
  136. package/core/domain/snapshot-manager.ts +0 -415
  137. package/core/domain/task-stack.ts +0 -578
  138. package/core/domain/velocity.ts +0 -470
  139. package/core/errors.ts +0 -335
  140. package/core/events/events.ts +0 -85
  141. package/core/events/index.ts +0 -8
  142. package/core/index.ts +0 -481
  143. package/core/infrastructure/agent-detector.ts +0 -135
  144. package/core/infrastructure/ai-provider.ts +0 -578
  145. package/core/infrastructure/author-detector.ts +0 -133
  146. package/core/infrastructure/capability-installer.ts +0 -76
  147. package/core/infrastructure/claude-agent.ts +0 -297
  148. package/core/infrastructure/command-installer.ts +0 -752
  149. package/core/infrastructure/config-manager.ts +0 -364
  150. package/core/infrastructure/editors-config.ts +0 -172
  151. package/core/infrastructure/path-manager.ts +0 -571
  152. package/core/infrastructure/performance-tracker.ts +0 -326
  153. package/core/infrastructure/permission-manager.ts +0 -289
  154. package/core/infrastructure/setup.ts +0 -1061
  155. package/core/infrastructure/update-checker.ts +0 -246
  156. package/core/integrations/issue-tracker/enricher.ts +0 -271
  157. package/core/integrations/issue-tracker/index.ts +0 -8
  158. package/core/integrations/issue-tracker/manager.ts +0 -286
  159. package/core/integrations/issue-tracker/types.ts +0 -310
  160. package/core/integrations/jira/cache.ts +0 -57
  161. package/core/integrations/jira/client.ts +0 -688
  162. package/core/integrations/jira/index.ts +0 -23
  163. package/core/integrations/jira/service.ts +0 -244
  164. package/core/integrations/linear/cache.ts +0 -68
  165. package/core/integrations/linear/client.ts +0 -436
  166. package/core/integrations/linear/index.ts +0 -20
  167. package/core/integrations/linear/service.ts +0 -260
  168. package/core/integrations/linear/sync.ts +0 -314
  169. package/core/outcomes/analyzer.ts +0 -286
  170. package/core/outcomes/index.ts +0 -34
  171. package/core/outcomes/recorder.ts +0 -195
  172. package/core/plugin/builtin/webhook.ts +0 -148
  173. package/core/plugin/hooks.ts +0 -315
  174. package/core/plugin/index.ts +0 -50
  175. package/core/plugin/loader.ts +0 -354
  176. package/core/plugin/registry.ts +0 -326
  177. package/core/schemas/agents.ts +0 -27
  178. package/core/schemas/analysis.ts +0 -530
  179. package/core/schemas/classification.ts +0 -91
  180. package/core/schemas/command-context.ts +0 -29
  181. package/core/schemas/enriched-task.ts +0 -291
  182. package/core/schemas/ideas.ts +0 -114
  183. package/core/schemas/index.ts +0 -53
  184. package/core/schemas/issues.ts +0 -159
  185. package/core/schemas/llm-output.ts +0 -170
  186. package/core/schemas/metrics.ts +0 -143
  187. package/core/schemas/model.ts +0 -153
  188. package/core/schemas/outcomes.ts +0 -487
  189. package/core/schemas/performance.ts +0 -128
  190. package/core/schemas/permissions.ts +0 -180
  191. package/core/schemas/prd.ts +0 -450
  192. package/core/schemas/project.ts +0 -57
  193. package/core/schemas/roadmap.ts +0 -322
  194. package/core/schemas/schemas.ts +0 -38
  195. package/core/schemas/shipped.ts +0 -109
  196. package/core/schemas/state.ts +0 -284
  197. package/core/schemas/velocity.ts +0 -103
  198. package/core/server/index.ts +0 -21
  199. package/core/server/routes-extended.ts +0 -566
  200. package/core/server/routes.ts +0 -176
  201. package/core/server/server.ts +0 -149
  202. package/core/server/sse.ts +0 -192
  203. package/core/services/agent-generator.ts +0 -385
  204. package/core/services/agent-service.ts +0 -168
  205. package/core/services/breakdown-service.ts +0 -124
  206. package/core/services/context-generator.ts +0 -445
  207. package/core/services/context-selector.ts +0 -429
  208. package/core/services/dependency-validator.ts +0 -318
  209. package/core/services/diff-generator.ts +0 -313
  210. package/core/services/doctor-service.ts +0 -423
  211. package/core/services/file-categorizer.ts +0 -448
  212. package/core/services/file-scorer.ts +0 -270
  213. package/core/services/git-analyzer.ts +0 -293
  214. package/core/services/hierarchical-agent-resolver.ts +0 -236
  215. package/core/services/hooks-service.ts +0 -685
  216. package/core/services/index.ts +0 -46
  217. package/core/services/local-state-generator.ts +0 -158
  218. package/core/services/memory-service.ts +0 -181
  219. package/core/services/nested-context-resolver.ts +0 -842
  220. package/core/services/project-index.ts +0 -911
  221. package/core/services/project-service.ts +0 -155
  222. package/core/services/session-tracker.ts +0 -287
  223. package/core/services/skill-installer.ts +0 -447
  224. package/core/services/skill-lock.ts +0 -132
  225. package/core/services/skill-service.ts +0 -306
  226. package/core/services/stack-detector.ts +0 -229
  227. package/core/services/staleness-checker.ts +0 -327
  228. package/core/services/sync-service.ts +0 -1515
  229. package/core/services/sync-verifier.ts +0 -253
  230. package/core/services/watch-service.ts +0 -312
  231. package/core/session/compaction.ts +0 -248
  232. package/core/session/index.ts +0 -35
  233. package/core/session/log-migration.ts +0 -88
  234. package/core/session/metrics.ts +0 -323
  235. package/core/session/session-log-manager.ts +0 -307
  236. package/core/session/task-session-manager.ts +0 -404
  237. package/core/session/utils.ts +0 -51
  238. package/core/storage/analysis-storage.ts +0 -373
  239. package/core/storage/archive-storage.ts +0 -205
  240. package/core/storage/database.ts +0 -575
  241. package/core/storage/ideas-storage.ts +0 -298
  242. package/core/storage/index-storage.ts +0 -523
  243. package/core/storage/index.ts +0 -79
  244. package/core/storage/metrics-storage.ts +0 -321
  245. package/core/storage/migrate-json.ts +0 -720
  246. package/core/storage/queue-storage.ts +0 -336
  247. package/core/storage/safe-reader.ts +0 -105
  248. package/core/storage/shipped-storage.ts +0 -253
  249. package/core/storage/state-storage.ts +0 -1035
  250. package/core/storage/storage-manager.ts +0 -205
  251. package/core/storage/storage.ts +0 -177
  252. package/core/storage/velocity-storage.ts +0 -149
  253. package/core/sync/auth-config.ts +0 -138
  254. package/core/sync/index.ts +0 -31
  255. package/core/sync/oauth-handler.ts +0 -143
  256. package/core/sync/sync-client.ts +0 -251
  257. package/core/sync/sync-manager.ts +0 -327
  258. package/core/tsconfig.json +0 -22
  259. package/core/types/agentic.ts +0 -760
  260. package/core/types/agents.ts +0 -150
  261. package/core/types/bus.ts +0 -193
  262. package/core/types/citations.ts +0 -22
  263. package/core/types/commands.ts +0 -399
  264. package/core/types/config.ts +0 -92
  265. package/core/types/core.ts +0 -96
  266. package/core/types/diff.ts +0 -41
  267. package/core/types/domain.ts +0 -71
  268. package/core/types/errors.ts +0 -111
  269. package/core/types/events.ts +0 -42
  270. package/core/types/fs.ts +0 -72
  271. package/core/types/index.ts +0 -510
  272. package/core/types/infrastructure.ts +0 -210
  273. package/core/types/integrations.ts +0 -31
  274. package/core/types/jira.ts +0 -51
  275. package/core/types/logger.ts +0 -17
  276. package/core/types/memory.ts +0 -313
  277. package/core/types/outcomes.ts +0 -190
  278. package/core/types/output.ts +0 -47
  279. package/core/types/plugin.ts +0 -25
  280. package/core/types/project-sync.ts +0 -129
  281. package/core/types/provider.ts +0 -163
  282. package/core/types/server.ts +0 -71
  283. package/core/types/services.ts +0 -84
  284. package/core/types/session.ts +0 -135
  285. package/core/types/stack.ts +0 -19
  286. package/core/types/storage.ts +0 -318
  287. package/core/types/sync-verifier.ts +0 -33
  288. package/core/types/sync.ts +0 -121
  289. package/core/types/task.ts +0 -72
  290. package/core/types/template.ts +0 -24
  291. package/core/types/utils.ts +0 -92
  292. package/core/types/workflow.ts +0 -23
  293. package/core/utils/agent-stream.ts +0 -140
  294. package/core/utils/animations.ts +0 -251
  295. package/core/utils/branding.ts +0 -88
  296. package/core/utils/cache.ts +0 -187
  297. package/core/utils/citations.ts +0 -39
  298. package/core/utils/collection-filters.ts +0 -209
  299. package/core/utils/date-helper.ts +0 -176
  300. package/core/utils/error-messages.ts +0 -38
  301. package/core/utils/file-helper.ts +0 -277
  302. package/core/utils/fs-helpers.ts +0 -14
  303. package/core/utils/help.ts +0 -314
  304. package/core/utils/jsonl-helper.ts +0 -290
  305. package/core/utils/keychain.ts +0 -127
  306. package/core/utils/logger.ts +0 -77
  307. package/core/utils/markdown-builder.ts +0 -280
  308. package/core/utils/next-steps.ts +0 -95
  309. package/core/utils/output.ts +0 -403
  310. package/core/utils/preserve-sections.ts +0 -218
  311. package/core/utils/project-commands.ts +0 -126
  312. package/core/utils/project-credentials.ts +0 -143
  313. package/core/utils/provider-cache.ts +0 -49
  314. package/core/utils/retry.ts +0 -318
  315. package/core/utils/runtime.ts +0 -108
  316. package/core/utils/session-helper.ts +0 -278
  317. package/core/utils/subtask-table.ts +0 -227
  318. package/core/utils/version.ts +0 -128
  319. package/core/wizard/index.ts +0 -13
  320. package/core/wizard/onboarding.ts +0 -633
  321. package/core/workflow/index.ts +0 -7
  322. package/core/workflow/state-machine.ts +0 -198
  323. package/core/workflow/workflow-preferences.ts +0 -294
  324. package/dist/core/infrastructure/command-installer.js +0 -1141
  325. package/dist/core/infrastructure/editors-config.js +0 -177
  326. package/dist/core/infrastructure/setup.js +0 -2244
  327. package/dist/core/utils/version.js +0 -141
  328. package/templates/agentic/agent-routing.md +0 -45
  329. package/templates/agentic/agents/uxui.md +0 -63
  330. package/templates/agentic/checklist-routing.md +0 -98
  331. package/templates/agentic/orchestrator.md +0 -68
  332. package/templates/agentic/task-fragmentation.md +0 -89
  333. package/templates/agents/AGENTS.md +0 -68
  334. package/templates/analysis/analyze.md +0 -84
  335. package/templates/analysis/patterns.md +0 -60
  336. package/templates/antigravity/SKILL.md +0 -39
  337. package/templates/architect/discovery.md +0 -67
  338. package/templates/architect/phases.md +0 -59
  339. package/templates/checklists/architecture.md +0 -28
  340. package/templates/checklists/code-quality.md +0 -28
  341. package/templates/checklists/data.md +0 -33
  342. package/templates/checklists/documentation.md +0 -33
  343. package/templates/checklists/infrastructure.md +0 -33
  344. package/templates/checklists/performance.md +0 -33
  345. package/templates/checklists/security.md +0 -33
  346. package/templates/checklists/testing.md +0 -33
  347. package/templates/checklists/ux-ui.md +0 -37
  348. package/templates/commands/analyze.md +0 -56
  349. package/templates/commands/auth.md +0 -234
  350. package/templates/commands/bug.md +0 -163
  351. package/templates/commands/cleanup.md +0 -19
  352. package/templates/commands/dash.md +0 -99
  353. package/templates/commands/design.md +0 -15
  354. package/templates/commands/done.md +0 -291
  355. package/templates/commands/enrich.md +0 -174
  356. package/templates/commands/git.md +0 -295
  357. package/templates/commands/history.md +0 -389
  358. package/templates/commands/idea.md +0 -88
  359. package/templates/commands/impact.md +0 -864
  360. package/templates/commands/init.md +0 -54
  361. package/templates/commands/jira.md +0 -278
  362. package/templates/commands/linear.md +0 -288
  363. package/templates/commands/merge.md +0 -206
  364. package/templates/commands/next.md +0 -80
  365. package/templates/commands/p.md +0 -67
  366. package/templates/commands/p.toml +0 -37
  367. package/templates/commands/pause.md +0 -136
  368. package/templates/commands/plan.md +0 -696
  369. package/templates/commands/prd.md +0 -356
  370. package/templates/commands/resume.md +0 -171
  371. package/templates/commands/review.md +0 -276
  372. package/templates/commands/serve.md +0 -118
  373. package/templates/commands/setup.md +0 -91
  374. package/templates/commands/ship.md +0 -475
  375. package/templates/commands/skill.md +0 -259
  376. package/templates/commands/spec.md +0 -218
  377. package/templates/commands/status.md +0 -207
  378. package/templates/commands/sync.md +0 -104
  379. package/templates/commands/task.md +0 -312
  380. package/templates/commands/test.md +0 -93
  381. package/templates/commands/update.md +0 -63
  382. package/templates/commands/verify.md +0 -204
  383. package/templates/commands/workflow.md +0 -150
  384. package/templates/config/skill-mappings.json +0 -82
  385. package/templates/context/dashboard.md +0 -256
  386. package/templates/context/roadmap.md +0 -221
  387. package/templates/cursor/commands/bug.md +0 -8
  388. package/templates/cursor/commands/done.md +0 -4
  389. package/templates/cursor/commands/pause.md +0 -6
  390. package/templates/cursor/commands/resume.md +0 -4
  391. package/templates/cursor/commands/ship.md +0 -8
  392. package/templates/cursor/commands/sync.md +0 -4
  393. package/templates/cursor/commands/task.md +0 -8
  394. package/templates/cursor/p.md +0 -29
  395. package/templates/cursor/router.mdc +0 -28
  396. package/templates/design/api.md +0 -95
  397. package/templates/design/architecture.md +0 -77
  398. package/templates/design/component.md +0 -89
  399. package/templates/design/database.md +0 -78
  400. package/templates/design/flow.md +0 -94
  401. package/templates/global/ANTIGRAVITY.md +0 -254
  402. package/templates/global/CLAUDE.md +0 -497
  403. package/templates/global/CURSOR.mdc +0 -266
  404. package/templates/global/GEMINI.md +0 -293
  405. package/templates/global/STORAGE-SPEC.md +0 -391
  406. package/templates/global/WINDSURF.md +0 -266
  407. package/templates/global/modules/CLAUDE-commands.md +0 -70
  408. package/templates/global/modules/CLAUDE-core.md +0 -105
  409. package/templates/global/modules/CLAUDE-git.md +0 -50
  410. package/templates/global/modules/CLAUDE-intelligence.md +0 -92
  411. package/templates/global/modules/CLAUDE-storage.md +0 -50
  412. package/templates/global/modules/module-config.json +0 -36
  413. package/templates/mcp-config.json +0 -19
  414. package/templates/permissions/default.jsonc +0 -60
  415. package/templates/permissions/permissive.jsonc +0 -49
  416. package/templates/permissions/strict.jsonc +0 -58
  417. package/templates/planning-methodology.md +0 -195
  418. package/templates/skills/code-review.md +0 -47
  419. package/templates/skills/debug.md +0 -61
  420. package/templates/skills/refactor.md +0 -47
  421. package/templates/subagents/agent-base.md +0 -20
  422. package/templates/subagents/domain/backend.md +0 -109
  423. package/templates/subagents/domain/database.md +0 -121
  424. package/templates/subagents/domain/devops.md +0 -152
  425. package/templates/subagents/domain/frontend.md +0 -103
  426. package/templates/subagents/domain/testing.md +0 -169
  427. package/templates/subagents/pm-expert.md +0 -366
  428. package/templates/subagents/workflow/chief-architect.md +0 -657
  429. package/templates/subagents/workflow/prjct-planner.md +0 -159
  430. package/templates/subagents/workflow/prjct-shipper.md +0 -188
  431. package/templates/subagents/workflow/prjct-workflow.md +0 -98
  432. package/templates/tools/bash.txt +0 -22
  433. package/templates/tools/edit.txt +0 -18
  434. package/templates/tools/glob.txt +0 -19
  435. package/templates/tools/grep.txt +0 -21
  436. package/templates/tools/read.txt +0 -14
  437. package/templates/tools/task.txt +0 -20
  438. package/templates/tools/webfetch.txt +0 -16
  439. package/templates/tools/websearch.txt +0 -18
  440. package/templates/tools/write.txt +0 -17
  441. package/templates/windsurf/router.md +0 -28
  442. package/templates/windsurf/workflows/bug.md +0 -8
  443. package/templates/windsurf/workflows/done.md +0 -4
  444. package/templates/windsurf/workflows/pause.md +0 -4
  445. package/templates/windsurf/workflows/resume.md +0 -4
  446. package/templates/windsurf/workflows/ship.md +0 -8
  447. package/templates/windsurf/workflows/sync.md +0 -4
  448. package/templates/windsurf/workflows/task.md +0 -8
@@ -1,706 +0,0 @@
1
- /**
2
- * Ground Truth
3
- * Verifies actual state before critical operations.
4
- *
5
- * OPTIMIZATION (P1.3): Anti-Hallucination Pattern
6
- * - Reads actual files before assuming state
7
- * - Compares expected vs actual state
8
- * - Provides specific warnings for mismatches
9
- * - Logs verification results for debugging
10
- *
11
- * Source: Devin, Cursor, Augment Code patterns
12
- */
13
-
14
- import { exec } from 'node:child_process'
15
- import fs from 'node:fs/promises'
16
- import os from 'node:os'
17
- import path from 'node:path'
18
- import { promisify } from 'node:util'
19
-
20
- import type { GroundTruthContext, VerificationResult, Verifier } from '../types'
21
- import { getErrorMessage, isNotFoundError } from '../types/fs'
22
-
23
- const execAsync = promisify(exec)
24
-
25
- // =============================================================================
26
- // Utilities
27
- // =============================================================================
28
-
29
- /**
30
- * Format duration from milliseconds to human-readable string
31
- */
32
- export function formatDuration(ms: number): string {
33
- const hours = Math.floor(ms / (1000 * 60 * 60))
34
- const minutes = Math.floor((ms % (1000 * 60 * 60)) / (1000 * 60))
35
-
36
- if (hours > 0) {
37
- return `${hours}h ${minutes}m`
38
- }
39
- return `${minutes}m`
40
- }
41
-
42
- /**
43
- * Escape special regex characters in a string
44
- */
45
- export function escapeRegex(string: string): string {
46
- return string.replace(/[.*+?^${}()|[\]\\]/g, '\\$&')
47
- }
48
-
49
- /**
50
- * Format verification warnings for display
51
- */
52
- export function formatWarnings(result: VerificationResult): string | null {
53
- if (result.verified || result.warnings.length === 0) {
54
- return null
55
- }
56
-
57
- let output = ' Ground Truth Warnings:\n'
58
- result.warnings.forEach((w) => {
59
- output += ` - ${w}\n`
60
- })
61
-
62
- if (result.recommendations.length > 0) {
63
- output += '\nRecommendations:\n'
64
- result.recommendations.forEach((r) => {
65
- output += ` -> ${r}\n`
66
- })
67
- }
68
-
69
- return output
70
- }
71
-
72
- // =============================================================================
73
- // Verifiers
74
- // =============================================================================
75
-
76
- /**
77
- * Done Command Verifier
78
- * Verify task is actually complete-able
79
- */
80
- export async function verifyDone(context: GroundTruthContext): Promise<VerificationResult> {
81
- const warnings: string[] = []
82
- const recommendations: string[] = []
83
- const actual: Record<string, unknown> = {}
84
-
85
- // 1. Verify now.md exists and has real content
86
- const nowPath = context.paths.now
87
- try {
88
- const nowContent = await fs.readFile(nowPath, 'utf-8')
89
- actual.nowExists = true
90
- actual.nowContent = nowContent.trim()
91
- actual.nowLength = nowContent.length
92
-
93
- // Check for placeholder content
94
- if (nowContent.includes('No current task') || nowContent.match(/^#\s*NOW\s*$/m)) {
95
- warnings.push('now.md appears to be empty or placeholder')
96
- recommendations.push('Start a task first with /p:now "task"')
97
- }
98
-
99
- // Check for task metadata (started time)
100
- const startedMatch = nowContent.match(/Started:\s*(.+)/i)
101
- if (startedMatch) {
102
- actual.startedAt = startedMatch[1]
103
- // Calculate duration
104
- const startTime = new Date(startedMatch[1])
105
- if (!Number.isNaN(startTime.getTime())) {
106
- actual.durationMs = Date.now() - startTime.getTime()
107
- actual.durationFormatted = formatDuration(actual.durationMs as number)
108
- }
109
- }
110
- } catch (error) {
111
- if (isNotFoundError(error)) {
112
- actual.nowExists = false
113
- warnings.push('now.md does not exist')
114
- recommendations.push('Create a task with /p:now "task"')
115
- } else {
116
- throw error
117
- }
118
- }
119
-
120
- // 2. Verify next.md for auto-start
121
- const nextPath = context.paths.next
122
- try {
123
- const nextContent = await fs.readFile(nextPath, 'utf-8')
124
- actual.nextExists = true
125
- const tasks = nextContent.match(/- \[ \]/g) || []
126
- actual.pendingTasks = tasks.length
127
- } catch (error) {
128
- if (isNotFoundError(error)) {
129
- actual.nextExists = false
130
- actual.pendingTasks = 0
131
- } else {
132
- throw error
133
- }
134
- }
135
-
136
- // 3. Verify metrics.md is writable
137
- const metricsPath = context.paths.metrics
138
- try {
139
- await fs.access(path.dirname(metricsPath), fs.constants.W_OK)
140
- actual.metricsWritable = true
141
- } catch (error) {
142
- if (isNotFoundError(error)) {
143
- actual.metricsWritable = false
144
- warnings.push('Cannot write to metrics directory')
145
- } else {
146
- throw error
147
- }
148
- }
149
-
150
- return {
151
- verified: warnings.length === 0,
152
- actual,
153
- warnings,
154
- recommendations,
155
- }
156
- }
157
-
158
- /**
159
- * Ship Command Verifier
160
- * Verify feature is ready to ship
161
- */
162
- export async function verifyShip(context: GroundTruthContext): Promise<VerificationResult> {
163
- const warnings: string[] = []
164
- const recommendations: string[] = []
165
- const actual: Record<string, unknown> = {}
166
-
167
- // 1. Check for uncommitted changes
168
- try {
169
- const { stdout: gitStatus } = await execAsync('git status --porcelain', {
170
- cwd: context.projectPath,
171
- })
172
- actual.hasUncommittedChanges = gitStatus.trim().length > 0
173
- actual.uncommittedFiles = gitStatus.trim().split('\n').filter(Boolean).length
174
-
175
- if (actual.hasUncommittedChanges) {
176
- warnings.push(`${actual.uncommittedFiles} uncommitted file(s)`)
177
- recommendations.push('Commit changes before shipping')
178
- }
179
- } catch (_error) {
180
- // Git errors (not a repo, git not installed) are not blockers
181
- actual.gitAvailable = false
182
- }
183
-
184
- // 2. Check for package.json version (if exists)
185
- const pkgPath = path.join(context.projectPath, 'package.json')
186
- try {
187
- const pkgContent = await fs.readFile(pkgPath, 'utf-8')
188
- const pkg = JSON.parse(pkgContent)
189
- actual.currentVersion = pkg.version
190
- actual.hasPackageJson = true
191
- } catch (error) {
192
- if (isNotFoundError(error)) {
193
- actual.hasPackageJson = false
194
- } else if (error instanceof SyntaxError) {
195
- actual.hasPackageJson = false
196
- warnings.push('package.json has invalid JSON')
197
- } else {
198
- throw error
199
- }
200
- }
201
-
202
- // 3. Check shipped.md for duplicate feature names
203
- const shippedPath = context.paths.shipped
204
- try {
205
- const shippedContent = await fs.readFile(shippedPath, 'utf-8')
206
- actual.shippedExists = true
207
-
208
- // Check if feature name already shipped today
209
- const featureName = context.params.feature || context.params.description
210
- if (featureName) {
211
- const today = new Date().toISOString().split('T')[0]
212
- const todayPattern = new RegExp(`${today}.*${escapeRegex(featureName)}`, 'i')
213
- if (todayPattern.test(shippedContent)) {
214
- warnings.push(`Feature "${featureName}" already shipped today`)
215
- recommendations.push('Use a different feature name or skip /p:ship')
216
- }
217
- }
218
- } catch (error) {
219
- if (isNotFoundError(error)) {
220
- actual.shippedExists = false
221
- } else {
222
- throw error
223
- }
224
- }
225
-
226
- // 4. Check for test failures (if test script exists)
227
- if (actual.hasPackageJson) {
228
- try {
229
- const pkgContent = await fs.readFile(pkgPath, 'utf-8')
230
- const pkg = JSON.parse(pkgContent)
231
- actual.hasTestScript = !!pkg.scripts?.test
232
- // Note: We don't run tests here, just check if they exist
233
- // Running tests is the user's responsibility
234
- } catch (error) {
235
- if (isNotFoundError(error) || error instanceof SyntaxError) {
236
- actual.hasTestScript = false
237
- } else {
238
- throw error
239
- }
240
- }
241
- }
242
-
243
- return {
244
- verified: warnings.length === 0,
245
- actual,
246
- warnings,
247
- recommendations,
248
- }
249
- }
250
-
251
- /**
252
- * Feature Command Verifier
253
- * Verify feature can be added
254
- */
255
- export async function verifyFeature(context: GroundTruthContext): Promise<VerificationResult> {
256
- const warnings: string[] = []
257
- const recommendations: string[] = []
258
- const actual: Record<string, unknown> = {}
259
-
260
- // 1. Check next.md capacity
261
- const nextPath = context.paths.next
262
- try {
263
- const nextContent = await fs.readFile(nextPath, 'utf-8')
264
- actual.nextExists = true
265
- const tasks = nextContent.match(/- \[[ x]\]/g) || []
266
- actual.taskCount = tasks.length
267
- actual.pendingTasks = (nextContent.match(/- \[ \]/g) || []).length
268
-
269
- if ((actual.taskCount as number) >= 90) {
270
- warnings.push(`Queue nearly full (${actual.taskCount}/100 tasks)`)
271
- recommendations.push('Complete some tasks before adding more')
272
- }
273
- } catch (error) {
274
- if (isNotFoundError(error)) {
275
- actual.nextExists = false
276
- actual.taskCount = 0
277
- } else {
278
- throw error
279
- }
280
- }
281
-
282
- // 2. Check roadmap.md for duplicate features
283
- const roadmapPath = context.paths.roadmap
284
- try {
285
- const roadmapContent = await fs.readFile(roadmapPath, 'utf-8')
286
- actual.roadmapExists = true
287
-
288
- const featureName = context.params.description || context.params.feature
289
- if (featureName) {
290
- const featurePattern = new RegExp(escapeRegex(featureName), 'i')
291
- if (featurePattern.test(roadmapContent)) {
292
- warnings.push(`Feature "${featureName}" may already exist in roadmap`)
293
- recommendations.push('Check roadmap for duplicates with /p:roadmap')
294
- }
295
- }
296
- } catch (error) {
297
- if (isNotFoundError(error)) {
298
- actual.roadmapExists = false
299
- } else {
300
- throw error
301
- }
302
- }
303
-
304
- // 3. Check if there's an active task (should complete first?)
305
- const nowPath = context.paths.now
306
- try {
307
- const nowContent = await fs.readFile(nowPath, 'utf-8')
308
- actual.hasActiveTask = nowContent.trim().length > 0 && !nowContent.includes('No current task')
309
-
310
- if (actual.hasActiveTask) {
311
- recommendations.push('Consider completing current task first with /p:done')
312
- }
313
- } catch (error) {
314
- if (isNotFoundError(error)) {
315
- actual.hasActiveTask = false
316
- } else {
317
- throw error
318
- }
319
- }
320
-
321
- return {
322
- verified: warnings.length === 0,
323
- actual,
324
- warnings,
325
- recommendations,
326
- }
327
- }
328
-
329
- /**
330
- * Now Command Verifier
331
- * Verify task can be set (anti-hallucination: warn if replacing)
332
- */
333
- export async function verifyNow(context: GroundTruthContext): Promise<VerificationResult> {
334
- const warnings: string[] = []
335
- const recommendations: string[] = []
336
- const actual: Record<string, unknown> = {}
337
-
338
- // 1. Check if there's already an active task
339
- const nowPath = context.paths.now
340
- try {
341
- const nowContent = await fs.readFile(nowPath, 'utf-8')
342
- actual.nowExists = true
343
- actual.nowContent = nowContent.trim()
344
-
345
- const hasRealTask =
346
- nowContent.trim().length > 0 &&
347
- !nowContent.includes('No current task') &&
348
- !nowContent.match(/^#\s*NOW\s*$/m)
349
-
350
- actual.hasActiveTask = hasRealTask
351
-
352
- // ANTI-HALLUCINATION: Warn if replacing existing task
353
- if (hasRealTask && context.params.task) {
354
- const taskPreview = nowContent.substring(0, 50).replace(/\n/g, ' ')
355
- warnings.push(`Replacing existing task: "${taskPreview}..."`)
356
- recommendations.push('Use /p:done first to track completion')
357
- }
358
- } catch (error) {
359
- if (isNotFoundError(error)) {
360
- actual.nowExists = false
361
- actual.hasActiveTask = false
362
- } else {
363
- throw error
364
- }
365
- }
366
-
367
- // 2. Check next.md for available tasks
368
- const nextPath = context.paths.next
369
- try {
370
- const nextContent = await fs.readFile(nextPath, 'utf-8')
371
- const pendingTasks = (nextContent.match(/- \[ \]/g) || []).length
372
- actual.pendingTasks = pendingTasks
373
-
374
- if (!context.params.task && pendingTasks > 0) {
375
- recommendations.push(`${pendingTasks} tasks available in queue`)
376
- }
377
- } catch (error) {
378
- if (isNotFoundError(error)) {
379
- actual.pendingTasks = 0
380
- } else {
381
- throw error
382
- }
383
- }
384
-
385
- return {
386
- verified: warnings.length === 0,
387
- actual,
388
- warnings,
389
- recommendations,
390
- }
391
- }
392
-
393
- /**
394
- * Init Command Verifier
395
- * Verify project can be initialized
396
- */
397
- export async function verifyInit(context: GroundTruthContext): Promise<VerificationResult> {
398
- const warnings: string[] = []
399
- const recommendations: string[] = []
400
- const actual: Record<string, unknown> = {}
401
-
402
- // 1. Check if already initialized
403
- const configPath = path.join(context.projectPath, '.prjct/prjct.config.json')
404
- try {
405
- const configContent = await fs.readFile(configPath, 'utf-8')
406
- actual.alreadyInitialized = true
407
- actual.existingConfig = JSON.parse(configContent)
408
- warnings.push('Project already initialized')
409
- recommendations.push('Use /p:analyze to refresh analysis or delete .prjct/ to reinitialize')
410
- } catch (error) {
411
- if (isNotFoundError(error)) {
412
- actual.alreadyInitialized = false
413
- } else if (error instanceof SyntaxError) {
414
- actual.alreadyInitialized = false
415
- warnings.push('Existing config has invalid JSON')
416
- } else {
417
- throw error
418
- }
419
- }
420
-
421
- // 2. Check if global storage path is writable
422
- const globalPath = path.join(os.homedir(), '.prjct-cli')
423
- try {
424
- await fs.access(globalPath, fs.constants.W_OK)
425
- actual.globalPathWritable = true
426
- } catch (error) {
427
- if (isNotFoundError(error)) {
428
- try {
429
- // Try to create it
430
- await fs.mkdir(globalPath, { recursive: true })
431
- actual.globalPathWritable = true
432
- actual.globalPathCreated = true
433
- } catch (_mkdirError) {
434
- actual.globalPathWritable = false
435
- warnings.push('Cannot write to ~/.prjct-cli')
436
- recommendations.push('Check directory permissions')
437
- }
438
- } else {
439
- actual.globalPathWritable = false
440
- warnings.push('Cannot write to ~/.prjct-cli')
441
- recommendations.push('Check directory permissions')
442
- }
443
- }
444
-
445
- return {
446
- verified: warnings.length === 0,
447
- actual,
448
- warnings,
449
- recommendations,
450
- }
451
- }
452
-
453
- /**
454
- * Sync Command Verifier
455
- * Verify sync can proceed
456
- */
457
- export async function verifySync(context: GroundTruthContext): Promise<VerificationResult> {
458
- const warnings: string[] = []
459
- const recommendations: string[] = []
460
- const actual: Record<string, unknown> = {}
461
-
462
- // 1. Check if project is initialized
463
- const configPath = path.join(context.projectPath, '.prjct/prjct.config.json')
464
- try {
465
- const configContent = await fs.readFile(configPath, 'utf-8')
466
- actual.hasConfig = true
467
- actual.config = JSON.parse(configContent)
468
- } catch (error) {
469
- if (isNotFoundError(error)) {
470
- actual.hasConfig = false
471
- warnings.push('Project not initialized')
472
- recommendations.push('Run /p:init first')
473
- return { verified: false, actual, warnings, recommendations }
474
- } else if (error instanceof SyntaxError) {
475
- actual.hasConfig = false
476
- warnings.push('Config file has invalid JSON')
477
- recommendations.push('Delete .prjct/ and run /p:init')
478
- return { verified: false, actual, warnings, recommendations }
479
- } else {
480
- throw error
481
- }
482
- }
483
-
484
- // 2. Check if global storage exists
485
- const projectId = (actual.config as { projectId?: string })?.projectId
486
- const globalProjectPath = path.join(os.homedir(), '.prjct-cli/projects', projectId || '')
487
- try {
488
- await fs.access(globalProjectPath)
489
- actual.globalStorageExists = true
490
- } catch (error) {
491
- if (isNotFoundError(error)) {
492
- actual.globalStorageExists = false
493
- warnings.push('Global storage missing')
494
- recommendations.push('Run /p:init to recreate')
495
- } else {
496
- throw error
497
- }
498
- }
499
-
500
- return {
501
- verified: warnings.length === 0,
502
- actual,
503
- warnings,
504
- recommendations,
505
- }
506
- }
507
-
508
- /**
509
- * Analyze Command Verifier
510
- * Verify analysis can proceed
511
- */
512
- export async function verifyAnalyze(context: GroundTruthContext): Promise<VerificationResult> {
513
- const warnings: string[] = []
514
- const recommendations: string[] = []
515
- const actual: Record<string, unknown> = {}
516
-
517
- // 1. Check if project has recognizable structure
518
- const files = ['package.json', 'Cargo.toml', 'go.mod', 'requirements.txt', 'Gemfile', 'pom.xml']
519
- actual.detectedFiles = []
520
-
521
- for (const file of files) {
522
- try {
523
- await fs.access(path.join(context.projectPath, file))
524
- ;(actual.detectedFiles as string[]).push(file)
525
- } catch (error) {
526
- // ENOENT expected - file doesn't exist
527
- if (!isNotFoundError(error)) {
528
- throw error
529
- }
530
- }
531
- }
532
-
533
- if ((actual.detectedFiles as string[]).length === 0) {
534
- warnings.push('No recognizable project files detected')
535
- recommendations.push('Analysis may be limited without package.json or similar')
536
- }
537
-
538
- // 2. Check for source directories
539
- const srcDirs = ['src', 'lib', 'app', 'core', 'components']
540
- actual.detectedSrcDirs = []
541
-
542
- for (const dir of srcDirs) {
543
- try {
544
- const stat = await fs.stat(path.join(context.projectPath, dir))
545
- if (stat.isDirectory()) {
546
- ;(actual.detectedSrcDirs as string[]).push(dir)
547
- }
548
- } catch (error) {
549
- // ENOENT expected - directory doesn't exist
550
- if (!isNotFoundError(error)) {
551
- throw error
552
- }
553
- }
554
- }
555
-
556
- return {
557
- verified: true, // Analysis can always proceed, even with warnings
558
- actual,
559
- warnings,
560
- recommendations,
561
- }
562
- }
563
-
564
- /**
565
- * Spec Command Verifier
566
- * Verify spec can be created
567
- */
568
- export async function verifySpec(context: GroundTruthContext): Promise<VerificationResult> {
569
- const warnings: string[] = []
570
- const recommendations: string[] = []
571
- const actual: Record<string, unknown> = {}
572
-
573
- // 1. Check specs directory exists
574
- const specsPath = context.paths.specs
575
- try {
576
- await fs.access(specsPath)
577
- actual.specsExists = true
578
-
579
- // List existing specs
580
- const files = await fs.readdir(specsPath)
581
- actual.existingSpecs = files.filter((f) => f.endsWith('.md'))
582
- actual.specCount = (actual.existingSpecs as string[]).length
583
- } catch (error) {
584
- if (isNotFoundError(error)) {
585
- actual.specsExists = false
586
- actual.specCount = 0
587
- } else {
588
- throw error
589
- }
590
- }
591
-
592
- // 2. Check for duplicate spec name
593
- const featureName = context.params.feature || context.params.name || context.params.description
594
- if (featureName && actual.existingSpecs) {
595
- const slug = featureName.toLowerCase().replace(/\s+/g, '-')
596
- if ((actual.existingSpecs as string[]).includes(`${slug}.md`)) {
597
- warnings.push(`Spec "${featureName}" already exists`)
598
- recommendations.push('Use a different name or edit existing spec')
599
- }
600
- }
601
-
602
- return {
603
- verified: warnings.length === 0,
604
- actual,
605
- warnings,
606
- recommendations,
607
- }
608
- }
609
-
610
- /**
611
- * Command-specific ground truth verifiers
612
- */
613
- export const verifiers: Record<string, Verifier> = {
614
- done: verifyDone,
615
- ship: verifyShip,
616
- feature: verifyFeature,
617
- now: verifyNow,
618
- init: verifyInit,
619
- sync: verifySync,
620
- analyze: verifyAnalyze,
621
- spec: verifySpec,
622
- }
623
-
624
- // =============================================================================
625
- // Main Functions
626
- // =============================================================================
627
-
628
- /**
629
- * Verify ground truth before command execution
630
- */
631
- export async function verify(
632
- commandName: string,
633
- context: GroundTruthContext,
634
- state: unknown
635
- ): Promise<VerificationResult> {
636
- const verifier = verifiers[commandName]
637
-
638
- if (!verifier) {
639
- // No specific verification needed
640
- return {
641
- verified: true,
642
- actual: {},
643
- warnings: [],
644
- recommendations: [],
645
- }
646
- }
647
-
648
- try {
649
- return await verifier(context, state)
650
- } catch (error) {
651
- return {
652
- verified: false,
653
- actual: {},
654
- warnings: [`Verification error: ${getErrorMessage(error)}`],
655
- recommendations: ['Check file permissions and project configuration'],
656
- }
657
- }
658
- }
659
-
660
- /**
661
- * Prepare command by verifying ground truth
662
- * Returns enhanced context with verification results
663
- */
664
- export async function prepareCommand(
665
- commandName: string,
666
- context: GroundTruthContext,
667
- state: unknown
668
- ) {
669
- const verification = await verify(commandName, context, state)
670
-
671
- return {
672
- ...context,
673
- groundTruth: {
674
- ...verification,
675
- verifiedAt: new Date().toISOString(),
676
- command: commandName,
677
- },
678
- }
679
- }
680
-
681
- /**
682
- * Check if command requires ground truth verification
683
- */
684
- export function requiresVerification(commandName: string): boolean {
685
- // ANTI-HALLUCINATION: Expanded verification for more commands
686
- return ['done', 'ship', 'feature', 'spec', 'now', 'init', 'sync', 'analyze'].includes(commandName)
687
- }
688
-
689
- const groundTruth = {
690
- verify,
691
- prepareCommand,
692
- requiresVerification,
693
- verifiers,
694
- formatWarnings,
695
- formatDuration,
696
- escapeRegex,
697
- verifyDone,
698
- verifyShip,
699
- verifyFeature,
700
- verifyNow,
701
- verifyInit,
702
- verifySync,
703
- verifyAnalyze,
704
- verifySpec,
705
- }
706
- export default groundTruth