specweave 0.12.0 → 0.12.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 (674) hide show
  1. package/CLAUDE.md +22 -0
  2. package/dist/cli/commands/init.d.ts.map +1 -1
  3. package/dist/cli/commands/init.js +44 -12
  4. package/dist/cli/commands/init.js.map +1 -1
  5. package/dist/core/specs/spec-metadata-manager.d.ts +70 -0
  6. package/dist/core/specs/spec-metadata-manager.d.ts.map +1 -0
  7. package/dist/core/specs/spec-metadata-manager.js +371 -0
  8. package/dist/core/specs/spec-metadata-manager.js.map +1 -0
  9. package/dist/core/specs/spec-parser.d.ts +66 -0
  10. package/dist/core/specs/spec-parser.d.ts.map +1 -0
  11. package/dist/core/specs/spec-parser.js +276 -0
  12. package/dist/core/specs/spec-parser.js.map +1 -0
  13. package/dist/core/types/config.d.ts.map +1 -1
  14. package/dist/core/types/config.js +7 -0
  15. package/dist/core/types/config.js.map +1 -1
  16. package/dist/core/types/spec-metadata.d.ts +229 -0
  17. package/dist/core/types/spec-metadata.d.ts.map +1 -0
  18. package/dist/core/types/spec-metadata.js +14 -0
  19. package/dist/core/types/spec-metadata.js.map +1 -0
  20. package/dist/hooks/lib/prepare-reflection-context.js +1 -1
  21. package/dist/hooks/lib/prepare-reflection-context.js.map +1 -1
  22. package/dist/utils/external-resource-validator.d.ts.map +1 -1
  23. package/dist/utils/external-resource-validator.js +101 -59
  24. package/dist/utils/external-resource-validator.js.map +1 -1
  25. package/package.json +10 -3
  26. package/plugins/specweave/agents/pm/AGENT.md +183 -0
  27. package/plugins/specweave/hooks/post-increment-change.sh +94 -0
  28. package/plugins/specweave/hooks/post-increment-status-change.sh +143 -0
  29. package/plugins/specweave/hooks/post-spec-update.sh +158 -0
  30. package/plugins/specweave/hooks/post-user-story-complete.sh +179 -0
  31. package/plugins/specweave/lib/hooks/sync-living-docs.ts +57 -16
  32. package/plugins/specweave/skills/increment-planner/SKILL.md +17 -0
  33. package/plugins/specweave-ado/commands/specweave-ado-sync-spec.md +255 -0
  34. package/plugins/specweave-ado/lib/ado-spec-sync.ts +593 -0
  35. package/plugins/specweave-ado/skills/ado-sync/SKILL.md +12 -6
  36. package/plugins/specweave-github/commands/specweave-github-sync-from.md +147 -0
  37. package/plugins/specweave-github/commands/specweave-github-sync-spec.md +208 -0
  38. package/plugins/specweave-github/lib/cli-sync-increment-changes.ts +33 -0
  39. package/plugins/specweave-github/lib/github-issue-updater.ts +449 -0
  40. package/plugins/specweave-github/lib/github-spec-sync.ts +656 -0
  41. package/plugins/specweave-github/lib/github-sync-bidirectional.ts +342 -0
  42. package/plugins/specweave-github/lib/github-sync-increment-changes.ts +380 -0
  43. package/plugins/specweave-github/skills/github-sync/SKILL.md +16 -8
  44. package/plugins/specweave-jira/commands/specweave-jira-sync-spec.md +240 -0
  45. package/plugins/specweave-jira/lib/jira-spec-sync.ts +582 -0
  46. package/plugins/specweave-jira/skills/jira-sync/SKILL.md +20 -5
  47. package/src/templates/AGENTS.md.template +55 -9
  48. package/dist/cli/commands/docs-build.d.ts +0 -7
  49. package/dist/cli/commands/docs-build.d.ts.map +0 -1
  50. package/dist/cli/commands/docs-build.js +0 -31
  51. package/dist/cli/commands/docs-build.js.map +0 -1
  52. package/dist/cli/commands/docs-preview.d.ts +0 -7
  53. package/dist/cli/commands/docs-preview.d.ts.map +0 -1
  54. package/dist/cli/commands/docs-preview.js +0 -50
  55. package/dist/cli/commands/docs-preview.js.map +0 -1
  56. package/dist/cli/commands/docs-setup.d.ts +0 -7
  57. package/dist/cli/commands/docs-setup.d.ts.map +0 -1
  58. package/dist/cli/commands/docs-setup.js +0 -31
  59. package/dist/cli/commands/docs-setup.js.map +0 -1
  60. package/dist/cli/commands/plugin.d.ts +0 -54
  61. package/dist/cli/commands/plugin.d.ts.map +0 -1
  62. package/dist/core/rfc-generator.d.ts +0 -147
  63. package/dist/core/rfc-generator.d.ts.map +0 -1
  64. package/dist/core/rfc-generator.js +0 -434
  65. package/dist/core/rfc-generator.js.map +0 -1
  66. package/dist/core/schemas/plugin-manifest.schema.json +0 -253
  67. package/dist/plugins/specweave/lib/hooks/git-diff-analyzer.d.ts +0 -89
  68. package/dist/plugins/specweave/lib/hooks/git-diff-analyzer.d.ts.map +0 -1
  69. package/dist/plugins/specweave/lib/hooks/git-diff-analyzer.js +0 -226
  70. package/dist/plugins/specweave/lib/hooks/git-diff-analyzer.js.map +0 -1
  71. package/dist/plugins/specweave/lib/hooks/invoke-translator-skill.d.ts +0 -60
  72. package/dist/plugins/specweave/lib/hooks/invoke-translator-skill.d.ts.map +0 -1
  73. package/dist/plugins/specweave/lib/hooks/invoke-translator-skill.js +0 -201
  74. package/dist/plugins/specweave/lib/hooks/invoke-translator-skill.js.map +0 -1
  75. package/dist/plugins/specweave/lib/hooks/prepare-reflection-context.d.ts +0 -42
  76. package/dist/plugins/specweave/lib/hooks/prepare-reflection-context.d.ts.map +0 -1
  77. package/dist/plugins/specweave/lib/hooks/prepare-reflection-context.js +0 -123
  78. package/dist/plugins/specweave/lib/hooks/prepare-reflection-context.js.map +0 -1
  79. package/dist/plugins/specweave/lib/hooks/reflection-config-loader.d.ts +0 -45
  80. package/dist/plugins/specweave/lib/hooks/reflection-config-loader.d.ts.map +0 -1
  81. package/dist/plugins/specweave/lib/hooks/reflection-config-loader.js +0 -132
  82. package/dist/plugins/specweave/lib/hooks/reflection-config-loader.js.map +0 -1
  83. package/dist/plugins/specweave/lib/hooks/reflection-parser.d.ts +0 -33
  84. package/dist/plugins/specweave/lib/hooks/reflection-parser.d.ts.map +0 -1
  85. package/dist/plugins/specweave/lib/hooks/reflection-parser.js +0 -419
  86. package/dist/plugins/specweave/lib/hooks/reflection-parser.js.map +0 -1
  87. package/dist/plugins/specweave/lib/hooks/reflection-prompt-builder.d.ts +0 -56
  88. package/dist/plugins/specweave/lib/hooks/reflection-prompt-builder.d.ts.map +0 -1
  89. package/dist/plugins/specweave/lib/hooks/reflection-prompt-builder.js +0 -239
  90. package/dist/plugins/specweave/lib/hooks/reflection-prompt-builder.js.map +0 -1
  91. package/dist/plugins/specweave/lib/hooks/reflection-storage.d.ts +0 -64
  92. package/dist/plugins/specweave/lib/hooks/reflection-storage.d.ts.map +0 -1
  93. package/dist/plugins/specweave/lib/hooks/reflection-storage.js +0 -305
  94. package/dist/plugins/specweave/lib/hooks/reflection-storage.js.map +0 -1
  95. package/dist/plugins/specweave/lib/hooks/run-self-reflection.d.ts +0 -43
  96. package/dist/plugins/specweave/lib/hooks/run-self-reflection.d.ts.map +0 -1
  97. package/dist/plugins/specweave/lib/hooks/run-self-reflection.js +0 -203
  98. package/dist/plugins/specweave/lib/hooks/run-self-reflection.js.map +0 -1
  99. package/dist/plugins/specweave/lib/hooks/sync-living-docs.d.ts +0 -27
  100. package/dist/plugins/specweave/lib/hooks/sync-living-docs.d.ts.map +0 -1
  101. package/dist/plugins/specweave/lib/hooks/sync-living-docs.js +0 -116
  102. package/dist/plugins/specweave/lib/hooks/sync-living-docs.js.map +0 -1
  103. package/dist/plugins/specweave/lib/hooks/translate-file.d.ts +0 -59
  104. package/dist/plugins/specweave/lib/hooks/translate-file.d.ts.map +0 -1
  105. package/dist/plugins/specweave/lib/hooks/translate-file.js +0 -350
  106. package/dist/plugins/specweave/lib/hooks/translate-file.js.map +0 -1
  107. package/dist/plugins/specweave/lib/hooks/translate-living-docs.d.ts +0 -13
  108. package/dist/plugins/specweave/lib/hooks/translate-living-docs.d.ts.map +0 -1
  109. package/dist/plugins/specweave/lib/hooks/translate-living-docs.js +0 -175
  110. package/dist/plugins/specweave/lib/hooks/translate-living-docs.js.map +0 -1
  111. package/dist/plugins/specweave/lib/hooks/types/reflection-types.d.ts +0 -164
  112. package/dist/plugins/specweave/lib/hooks/types/reflection-types.d.ts.map +0 -1
  113. package/dist/plugins/specweave/lib/hooks/types/reflection-types.js +0 -73
  114. package/dist/plugins/specweave/lib/hooks/types/reflection-types.js.map +0 -1
  115. package/dist/plugins/specweave/lib/hooks/update-tasks-md.d.ts +0 -29
  116. package/dist/plugins/specweave/lib/hooks/update-tasks-md.d.ts.map +0 -1
  117. package/dist/plugins/specweave/lib/hooks/update-tasks-md.js +0 -203
  118. package/dist/plugins/specweave/lib/hooks/update-tasks-md.js.map +0 -1
  119. package/dist/plugins/specweave-ado/lib/ado-board-resolver.d.ts +0 -94
  120. package/dist/plugins/specweave-ado/lib/ado-board-resolver.d.ts.map +0 -1
  121. package/dist/plugins/specweave-ado/lib/ado-board-resolver.js +0 -219
  122. package/dist/plugins/specweave-ado/lib/ado-board-resolver.js.map +0 -1
  123. package/dist/plugins/specweave-ado/lib/ado-client-v2.d.ts +0 -124
  124. package/dist/plugins/specweave-ado/lib/ado-client-v2.d.ts.map +0 -1
  125. package/dist/plugins/specweave-ado/lib/ado-client-v2.js +0 -382
  126. package/dist/plugins/specweave-ado/lib/ado-client-v2.js.map +0 -1
  127. package/dist/plugins/specweave-ado/lib/ado-client.d.ts +0 -112
  128. package/dist/plugins/specweave-ado/lib/ado-client.d.ts.map +0 -1
  129. package/dist/plugins/specweave-ado/lib/ado-client.js +0 -257
  130. package/dist/plugins/specweave-ado/lib/ado-client.js.map +0 -1
  131. package/dist/plugins/specweave-ado/lib/ado-hierarchical-sync.d.ts +0 -40
  132. package/dist/plugins/specweave-ado/lib/ado-hierarchical-sync.d.ts.map +0 -1
  133. package/dist/plugins/specweave-ado/lib/ado-hierarchical-sync.js +0 -370
  134. package/dist/plugins/specweave-ado/lib/ado-hierarchical-sync.js.map +0 -1
  135. package/dist/plugins/specweave-ado/lib/project-selector.d.ts +0 -42
  136. package/dist/plugins/specweave-ado/lib/project-selector.d.ts.map +0 -1
  137. package/dist/plugins/specweave-ado/lib/project-selector.js +0 -211
  138. package/dist/plugins/specweave-ado/lib/project-selector.js.map +0 -1
  139. package/dist/plugins/specweave-github/lib/github-board-resolver.d.ts +0 -54
  140. package/dist/plugins/specweave-github/lib/github-board-resolver.d.ts.map +0 -1
  141. package/dist/plugins/specweave-github/lib/github-board-resolver.js +0 -122
  142. package/dist/plugins/specweave-github/lib/github-board-resolver.js.map +0 -1
  143. package/dist/plugins/specweave-github/lib/github-client-v2.d.ts +0 -104
  144. package/dist/plugins/specweave-github/lib/github-client-v2.d.ts.map +0 -1
  145. package/dist/plugins/specweave-github/lib/github-client-v2.js +0 -408
  146. package/dist/plugins/specweave-github/lib/github-client-v2.js.map +0 -1
  147. package/dist/plugins/specweave-github/lib/github-client.d.ts +0 -96
  148. package/dist/plugins/specweave-github/lib/github-client.d.ts.map +0 -1
  149. package/dist/plugins/specweave-github/lib/github-client.js +0 -299
  150. package/dist/plugins/specweave-github/lib/github-client.js.map +0 -1
  151. package/dist/plugins/specweave-github/lib/github-hierarchical-sync.d.ts +0 -29
  152. package/dist/plugins/specweave-github/lib/github-hierarchical-sync.d.ts.map +0 -1
  153. package/dist/plugins/specweave-github/lib/github-hierarchical-sync.js +0 -268
  154. package/dist/plugins/specweave-github/lib/github-hierarchical-sync.js.map +0 -1
  155. package/dist/plugins/specweave-github/lib/index.d.ts +0 -10
  156. package/dist/plugins/specweave-github/lib/index.d.ts.map +0 -1
  157. package/dist/plugins/specweave-github/lib/index.js +0 -10
  158. package/dist/plugins/specweave-github/lib/index.js.map +0 -1
  159. package/dist/plugins/specweave-github/lib/repo-selector.d.ts +0 -49
  160. package/dist/plugins/specweave-github/lib/repo-selector.d.ts.map +0 -1
  161. package/dist/plugins/specweave-github/lib/repo-selector.js +0 -216
  162. package/dist/plugins/specweave-github/lib/repo-selector.js.map +0 -1
  163. package/dist/plugins/specweave-github/lib/subtask-sync.d.ts +0 -51
  164. package/dist/plugins/specweave-github/lib/subtask-sync.d.ts.map +0 -1
  165. package/dist/plugins/specweave-github/lib/subtask-sync.js +0 -147
  166. package/dist/plugins/specweave-github/lib/subtask-sync.js.map +0 -1
  167. package/dist/plugins/specweave-github/lib/task-parser.d.ts +0 -37
  168. package/dist/plugins/specweave-github/lib/task-parser.d.ts.map +0 -1
  169. package/dist/plugins/specweave-github/lib/task-parser.js +0 -211
  170. package/dist/plugins/specweave-github/lib/task-parser.js.map +0 -1
  171. package/dist/plugins/specweave-github/lib/task-sync.d.ts +0 -51
  172. package/dist/plugins/specweave-github/lib/task-sync.d.ts.map +0 -1
  173. package/dist/plugins/specweave-github/lib/task-sync.js +0 -332
  174. package/dist/plugins/specweave-github/lib/task-sync.js.map +0 -1
  175. package/dist/plugins/specweave-github/lib/types.d.ts +0 -80
  176. package/dist/plugins/specweave-github/lib/types.d.ts.map +0 -1
  177. package/dist/plugins/specweave-github/lib/types.js +0 -5
  178. package/dist/plugins/specweave-github/lib/types.js.map +0 -1
  179. package/dist/plugins/specweave-jira/lib/jira-board-resolver.d.ts +0 -50
  180. package/dist/plugins/specweave-jira/lib/jira-board-resolver.d.ts.map +0 -1
  181. package/dist/plugins/specweave-jira/lib/jira-board-resolver.js +0 -84
  182. package/dist/plugins/specweave-jira/lib/jira-board-resolver.js.map +0 -1
  183. package/dist/plugins/specweave-jira/lib/jira-hierarchical-sync.d.ts +0 -33
  184. package/dist/plugins/specweave-jira/lib/jira-hierarchical-sync.d.ts.map +0 -1
  185. package/dist/plugins/specweave-jira/lib/jira-hierarchical-sync.js +0 -206
  186. package/dist/plugins/specweave-jira/lib/jira-hierarchical-sync.js.map +0 -1
  187. package/dist/plugins/specweave-jira/lib/project-selector.d.ts +0 -42
  188. package/dist/plugins/specweave-jira/lib/project-selector.d.ts.map +0 -1
  189. package/dist/plugins/specweave-jira/lib/project-selector.js +0 -216
  190. package/dist/plugins/specweave-jira/lib/project-selector.js.map +0 -1
  191. package/dist/plugins/specweave-jira/lib/reorganization-detector.d.ts +0 -67
  192. package/dist/plugins/specweave-jira/lib/reorganization-detector.d.ts.map +0 -1
  193. package/dist/plugins/specweave-jira/lib/reorganization-detector.js +0 -252
  194. package/dist/plugins/specweave-jira/lib/reorganization-detector.js.map +0 -1
  195. package/dist/plugins/specweave-jira/lib/setup-wizard.d.ts +0 -29
  196. package/dist/plugins/specweave-jira/lib/setup-wizard.d.ts.map +0 -1
  197. package/dist/plugins/specweave-jira/lib/setup-wizard.js +0 -219
  198. package/dist/plugins/specweave-jira/lib/setup-wizard.js.map +0 -1
  199. package/dist/src/adapters/adapter-base.d.ts +0 -71
  200. package/dist/src/adapters/adapter-base.d.ts.map +0 -1
  201. package/dist/src/adapters/adapter-base.js +0 -139
  202. package/dist/src/adapters/adapter-base.js.map +0 -1
  203. package/dist/src/adapters/adapter-interface.d.ts +0 -149
  204. package/dist/src/adapters/adapter-interface.d.ts.map +0 -1
  205. package/dist/src/adapters/adapter-interface.js +0 -8
  206. package/dist/src/adapters/adapter-interface.js.map +0 -1
  207. package/dist/src/adapters/adapter-loader.d.ts +0 -91
  208. package/dist/src/adapters/adapter-loader.d.ts.map +0 -1
  209. package/dist/src/adapters/adapter-loader.js +0 -238
  210. package/dist/src/adapters/adapter-loader.js.map +0 -1
  211. package/dist/src/adapters/agents-md-generator.d.ts +0 -48
  212. package/dist/src/adapters/agents-md-generator.d.ts.map +0 -1
  213. package/dist/src/adapters/agents-md-generator.js +0 -193
  214. package/dist/src/adapters/agents-md-generator.js.map +0 -1
  215. package/dist/src/adapters/claude/adapter.d.ts +0 -128
  216. package/dist/src/adapters/claude/adapter.d.ts.map +0 -1
  217. package/dist/src/adapters/claude/adapter.js +0 -415
  218. package/dist/src/adapters/claude/adapter.js.map +0 -1
  219. package/dist/src/adapters/claude-md-generator.d.ts +0 -78
  220. package/dist/src/adapters/claude-md-generator.d.ts.map +0 -1
  221. package/dist/src/adapters/claude-md-generator.js +0 -307
  222. package/dist/src/adapters/claude-md-generator.js.map +0 -1
  223. package/dist/src/adapters/codex/adapter.d.ts +0 -50
  224. package/dist/src/adapters/codex/adapter.d.ts.map +0 -1
  225. package/dist/src/adapters/codex/adapter.js +0 -316
  226. package/dist/src/adapters/codex/adapter.js.map +0 -1
  227. package/dist/src/adapters/cursor/adapter.d.ts +0 -98
  228. package/dist/src/adapters/cursor/adapter.d.ts.map +0 -1
  229. package/dist/src/adapters/cursor/adapter.js +0 -406
  230. package/dist/src/adapters/cursor/adapter.js.map +0 -1
  231. package/dist/src/adapters/doc-generator.d.ts +0 -69
  232. package/dist/src/adapters/doc-generator.d.ts.map +0 -1
  233. package/dist/src/adapters/doc-generator.js +0 -247
  234. package/dist/src/adapters/doc-generator.js.map +0 -1
  235. package/dist/src/adapters/gemini/adapter.d.ts +0 -50
  236. package/dist/src/adapters/gemini/adapter.d.ts.map +0 -1
  237. package/dist/src/adapters/gemini/adapter.js +0 -281
  238. package/dist/src/adapters/gemini/adapter.js.map +0 -1
  239. package/dist/src/adapters/generic/adapter.d.ts +0 -86
  240. package/dist/src/adapters/generic/adapter.d.ts.map +0 -1
  241. package/dist/src/adapters/generic/adapter.js +0 -338
  242. package/dist/src/adapters/generic/adapter.js.map +0 -1
  243. package/dist/src/cli/commands/abandon.d.ts +0 -13
  244. package/dist/src/cli/commands/abandon.d.ts.map +0 -1
  245. package/dist/src/cli/commands/abandon.js +0 -15
  246. package/dist/src/cli/commands/abandon.js.map +0 -1
  247. package/dist/src/cli/commands/import-docs.d.ts +0 -21
  248. package/dist/src/cli/commands/import-docs.d.ts.map +0 -1
  249. package/dist/src/cli/commands/import-docs.js +0 -146
  250. package/dist/src/cli/commands/import-docs.js.map +0 -1
  251. package/dist/src/cli/commands/init-multiproject.d.ts +0 -11
  252. package/dist/src/cli/commands/init-multiproject.d.ts.map +0 -1
  253. package/dist/src/cli/commands/init-multiproject.js +0 -202
  254. package/dist/src/cli/commands/init-multiproject.js.map +0 -1
  255. package/dist/src/cli/commands/init.d.ts +0 -9
  256. package/dist/src/cli/commands/init.d.ts.map +0 -1
  257. package/dist/src/cli/commands/init.js +0 -1205
  258. package/dist/src/cli/commands/init.js.map +0 -1
  259. package/dist/src/cli/commands/install.d.ts +0 -9
  260. package/dist/src/cli/commands/install.d.ts.map +0 -1
  261. package/dist/src/cli/commands/install.js +0 -127
  262. package/dist/src/cli/commands/install.js.map +0 -1
  263. package/dist/src/cli/commands/list.d.ts +0 -8
  264. package/dist/src/cli/commands/list.d.ts.map +0 -1
  265. package/dist/src/cli/commands/list.js +0 -119
  266. package/dist/src/cli/commands/list.js.map +0 -1
  267. package/dist/src/cli/commands/migrate-to-multiproject.d.ts +0 -37
  268. package/dist/src/cli/commands/migrate-to-multiproject.d.ts.map +0 -1
  269. package/dist/src/cli/commands/migrate-to-multiproject.js +0 -189
  270. package/dist/src/cli/commands/migrate-to-multiproject.js.map +0 -1
  271. package/dist/src/cli/commands/migrate-to-profiles.d.ts +0 -25
  272. package/dist/src/cli/commands/migrate-to-profiles.d.ts.map +0 -1
  273. package/dist/src/cli/commands/migrate-to-profiles.js +0 -350
  274. package/dist/src/cli/commands/migrate-to-profiles.js.map +0 -1
  275. package/dist/src/cli/commands/pause.d.ts +0 -13
  276. package/dist/src/cli/commands/pause.d.ts.map +0 -1
  277. package/dist/src/cli/commands/pause.js +0 -15
  278. package/dist/src/cli/commands/pause.js.map +0 -1
  279. package/dist/src/cli/commands/qa.d.ts +0 -54
  280. package/dist/src/cli/commands/qa.d.ts.map +0 -1
  281. package/dist/src/cli/commands/qa.js +0 -98
  282. package/dist/src/cli/commands/qa.js.map +0 -1
  283. package/dist/src/cli/commands/resume.d.ts +0 -12
  284. package/dist/src/cli/commands/resume.d.ts.map +0 -1
  285. package/dist/src/cli/commands/resume.js +0 -14
  286. package/dist/src/cli/commands/resume.js.map +0 -1
  287. package/dist/src/cli/commands/status.d.ts +0 -12
  288. package/dist/src/cli/commands/status.d.ts.map +0 -1
  289. package/dist/src/cli/commands/status.js +0 -23
  290. package/dist/src/cli/commands/status.js.map +0 -1
  291. package/dist/src/cli/commands/switch-project.d.ts +0 -13
  292. package/dist/src/cli/commands/switch-project.d.ts.map +0 -1
  293. package/dist/src/cli/commands/switch-project.js +0 -91
  294. package/dist/src/cli/commands/switch-project.js.map +0 -1
  295. package/dist/src/cli/commands/validate-jira.d.ts +0 -35
  296. package/dist/src/cli/commands/validate-jira.d.ts.map +0 -1
  297. package/dist/src/cli/commands/validate-jira.js +0 -112
  298. package/dist/src/cli/commands/validate-jira.js.map +0 -1
  299. package/dist/src/cli/commands/validate-plugins.d.ts +0 -41
  300. package/dist/src/cli/commands/validate-plugins.d.ts.map +0 -1
  301. package/dist/src/cli/commands/validate-plugins.js +0 -171
  302. package/dist/src/cli/commands/validate-plugins.js.map +0 -1
  303. package/dist/src/cli/helpers/issue-tracker/ado.d.ts +0 -57
  304. package/dist/src/cli/helpers/issue-tracker/ado.d.ts.map +0 -1
  305. package/dist/src/cli/helpers/issue-tracker/ado.js +0 -243
  306. package/dist/src/cli/helpers/issue-tracker/ado.js.map +0 -1
  307. package/dist/src/cli/helpers/issue-tracker/github.d.ts +0 -65
  308. package/dist/src/cli/helpers/issue-tracker/github.d.ts.map +0 -1
  309. package/dist/src/cli/helpers/issue-tracker/github.js +0 -426
  310. package/dist/src/cli/helpers/issue-tracker/github.js.map +0 -1
  311. package/dist/src/cli/helpers/issue-tracker/index.d.ts +0 -22
  312. package/dist/src/cli/helpers/issue-tracker/index.d.ts.map +0 -1
  313. package/dist/src/cli/helpers/issue-tracker/index.js +0 -314
  314. package/dist/src/cli/helpers/issue-tracker/index.js.map +0 -1
  315. package/dist/src/cli/helpers/issue-tracker/jira.d.ts +0 -61
  316. package/dist/src/cli/helpers/issue-tracker/jira.d.ts.map +0 -1
  317. package/dist/src/cli/helpers/issue-tracker/jira.js +0 -404
  318. package/dist/src/cli/helpers/issue-tracker/jira.js.map +0 -1
  319. package/dist/src/cli/helpers/issue-tracker/types.d.ts +0 -107
  320. package/dist/src/cli/helpers/issue-tracker/types.d.ts.map +0 -1
  321. package/dist/src/cli/helpers/issue-tracker/types.js +0 -16
  322. package/dist/src/cli/helpers/issue-tracker/types.js.map +0 -1
  323. package/dist/src/cli/helpers/issue-tracker/utils.d.ts +0 -112
  324. package/dist/src/cli/helpers/issue-tracker/utils.d.ts.map +0 -1
  325. package/dist/src/cli/helpers/issue-tracker/utils.js +0 -247
  326. package/dist/src/cli/helpers/issue-tracker/utils.js.map +0 -1
  327. package/dist/src/core/agent-model-manager.d.ts +0 -52
  328. package/dist/src/core/agent-model-manager.d.ts.map +0 -1
  329. package/dist/src/core/agent-model-manager.js +0 -120
  330. package/dist/src/core/agent-model-manager.js.map +0 -1
  331. package/dist/src/core/brownfield/analyzer.d.ts +0 -86
  332. package/dist/src/core/brownfield/analyzer.d.ts.map +0 -1
  333. package/dist/src/core/brownfield/analyzer.js +0 -365
  334. package/dist/src/core/brownfield/analyzer.js.map +0 -1
  335. package/dist/src/core/brownfield/importer.d.ts +0 -76
  336. package/dist/src/core/brownfield/importer.d.ts.map +0 -1
  337. package/dist/src/core/brownfield/importer.js +0 -287
  338. package/dist/src/core/brownfield/importer.js.map +0 -1
  339. package/dist/src/core/config-manager.d.ts +0 -47
  340. package/dist/src/core/config-manager.d.ts.map +0 -1
  341. package/dist/src/core/config-manager.js +0 -136
  342. package/dist/src/core/config-manager.js.map +0 -1
  343. package/dist/src/core/cost-tracker.d.ts +0 -108
  344. package/dist/src/core/cost-tracker.d.ts.map +0 -1
  345. package/dist/src/core/cost-tracker.js +0 -281
  346. package/dist/src/core/cost-tracker.js.map +0 -1
  347. package/dist/src/core/credentials-manager.d.ts +0 -107
  348. package/dist/src/core/credentials-manager.d.ts.map +0 -1
  349. package/dist/src/core/credentials-manager.js +0 -457
  350. package/dist/src/core/credentials-manager.js.map +0 -1
  351. package/dist/src/core/i18n/language-detector.d.ts +0 -29
  352. package/dist/src/core/i18n/language-detector.d.ts.map +0 -1
  353. package/dist/src/core/i18n/language-detector.js +0 -143
  354. package/dist/src/core/i18n/language-detector.js.map +0 -1
  355. package/dist/src/core/i18n/language-manager.d.ts +0 -101
  356. package/dist/src/core/i18n/language-manager.d.ts.map +0 -1
  357. package/dist/src/core/i18n/language-manager.js +0 -232
  358. package/dist/src/core/i18n/language-manager.js.map +0 -1
  359. package/dist/src/core/i18n/language-registry.d.ts +0 -44
  360. package/dist/src/core/i18n/language-registry.d.ts.map +0 -1
  361. package/dist/src/core/i18n/language-registry.js +0 -234
  362. package/dist/src/core/i18n/language-registry.js.map +0 -1
  363. package/dist/src/core/i18n/locale-manager.d.ts +0 -62
  364. package/dist/src/core/i18n/locale-manager.d.ts.map +0 -1
  365. package/dist/src/core/i18n/locale-manager.js +0 -137
  366. package/dist/src/core/i18n/locale-manager.js.map +0 -1
  367. package/dist/src/core/i18n/system-prompt-injector.d.ts +0 -33
  368. package/dist/src/core/i18n/system-prompt-injector.d.ts.map +0 -1
  369. package/dist/src/core/i18n/system-prompt-injector.js +0 -131
  370. package/dist/src/core/i18n/system-prompt-injector.js.map +0 -1
  371. package/dist/src/core/i18n/types.d.ts +0 -151
  372. package/dist/src/core/i18n/types.d.ts.map +0 -1
  373. package/dist/src/core/i18n/types.js +0 -11
  374. package/dist/src/core/i18n/types.js.map +0 -1
  375. package/dist/src/core/increment/limits.d.ts +0 -68
  376. package/dist/src/core/increment/limits.d.ts.map +0 -1
  377. package/dist/src/core/increment/limits.js +0 -224
  378. package/dist/src/core/increment/limits.js.map +0 -1
  379. package/dist/src/core/increment/metadata-manager.d.ts +0 -114
  380. package/dist/src/core/increment/metadata-manager.d.ts.map +0 -1
  381. package/dist/src/core/increment/metadata-manager.js +0 -320
  382. package/dist/src/core/increment/metadata-manager.js.map +0 -1
  383. package/dist/src/core/increment/status-commands.d.ts +0 -43
  384. package/dist/src/core/increment/status-commands.d.ts.map +0 -1
  385. package/dist/src/core/increment/status-commands.js +0 -277
  386. package/dist/src/core/increment/status-commands.js.map +0 -1
  387. package/dist/src/core/increment-status.d.ts +0 -72
  388. package/dist/src/core/increment-status.d.ts.map +0 -1
  389. package/dist/src/core/increment-status.js +0 -227
  390. package/dist/src/core/increment-status.js.map +0 -1
  391. package/dist/src/core/model-selector.d.ts +0 -57
  392. package/dist/src/core/model-selector.d.ts.map +0 -1
  393. package/dist/src/core/model-selector.js +0 -115
  394. package/dist/src/core/model-selector.js.map +0 -1
  395. package/dist/src/core/phase-detector.d.ts +0 -62
  396. package/dist/src/core/phase-detector.d.ts.map +0 -1
  397. package/dist/src/core/phase-detector.js +0 -229
  398. package/dist/src/core/phase-detector.js.map +0 -1
  399. package/dist/src/core/plugin-loader.d.ts +0 -131
  400. package/dist/src/core/plugin-loader.d.ts.map +0 -1
  401. package/dist/src/core/plugin-loader.js +0 -421
  402. package/dist/src/core/plugin-loader.js.map +0 -1
  403. package/dist/src/core/project-manager.d.ts +0 -127
  404. package/dist/src/core/project-manager.d.ts.map +0 -1
  405. package/dist/src/core/project-manager.js +0 -524
  406. package/dist/src/core/project-manager.js.map +0 -1
  407. package/dist/src/core/project-structure-detector.d.ts +0 -92
  408. package/dist/src/core/project-structure-detector.d.ts.map +0 -1
  409. package/dist/src/core/project-structure-detector.js +0 -289
  410. package/dist/src/core/project-structure-detector.js.map +0 -1
  411. package/dist/src/core/qa/qa-runner.d.ts +0 -16
  412. package/dist/src/core/qa/qa-runner.d.ts.map +0 -1
  413. package/dist/src/core/qa/qa-runner.js +0 -404
  414. package/dist/src/core/qa/qa-runner.js.map +0 -1
  415. package/dist/src/core/qa/quality-gate-decider.d.ts +0 -53
  416. package/dist/src/core/qa/quality-gate-decider.d.ts.map +0 -1
  417. package/dist/src/core/qa/quality-gate-decider.js +0 -268
  418. package/dist/src/core/qa/quality-gate-decider.js.map +0 -1
  419. package/dist/src/core/qa/risk-calculator.d.ts +0 -126
  420. package/dist/src/core/qa/risk-calculator.d.ts.map +0 -1
  421. package/dist/src/core/qa/risk-calculator.js +0 -247
  422. package/dist/src/core/qa/risk-calculator.js.map +0 -1
  423. package/dist/src/core/qa/types.d.ts +0 -315
  424. package/dist/src/core/qa/types.d.ts.map +0 -1
  425. package/dist/src/core/qa/types.js +0 -8
  426. package/dist/src/core/qa/types.js.map +0 -1
  427. package/dist/src/core/rfc-generator-v2.d.ts +0 -149
  428. package/dist/src/core/rfc-generator-v2.d.ts.map +0 -1
  429. package/dist/src/core/rfc-generator-v2.js +0 -399
  430. package/dist/src/core/rfc-generator-v2.js.map +0 -1
  431. package/dist/src/core/sync/bidirectional-engine.d.ts +0 -110
  432. package/dist/src/core/sync/bidirectional-engine.d.ts.map +0 -1
  433. package/dist/src/core/sync/bidirectional-engine.js +0 -356
  434. package/dist/src/core/sync/bidirectional-engine.js.map +0 -1
  435. package/dist/src/core/sync/folder-mapper.d.ts +0 -71
  436. package/dist/src/core/sync/folder-mapper.d.ts.map +0 -1
  437. package/dist/src/core/sync/folder-mapper.js +0 -168
  438. package/dist/src/core/sync/folder-mapper.js.map +0 -1
  439. package/dist/src/core/sync/profile-manager.d.ts +0 -72
  440. package/dist/src/core/sync/profile-manager.d.ts.map +0 -1
  441. package/dist/src/core/sync/profile-manager.js +0 -338
  442. package/dist/src/core/sync/profile-manager.js.map +0 -1
  443. package/dist/src/core/sync/profile-selector.d.ts +0 -52
  444. package/dist/src/core/sync/profile-selector.d.ts.map +0 -1
  445. package/dist/src/core/sync/profile-selector.js +0 -179
  446. package/dist/src/core/sync/profile-selector.js.map +0 -1
  447. package/dist/src/core/sync/profile-validator.d.ts +0 -52
  448. package/dist/src/core/sync/profile-validator.d.ts.map +0 -1
  449. package/dist/src/core/sync/profile-validator.js +0 -225
  450. package/dist/src/core/sync/profile-validator.js.map +0 -1
  451. package/dist/src/core/sync/project-context.d.ts +0 -81
  452. package/dist/src/core/sync/project-context.d.ts.map +0 -1
  453. package/dist/src/core/sync/project-context.js +0 -354
  454. package/dist/src/core/sync/project-context.js.map +0 -1
  455. package/dist/src/core/sync/rate-limiter.d.ts +0 -116
  456. package/dist/src/core/sync/rate-limiter.d.ts.map +0 -1
  457. package/dist/src/core/sync/rate-limiter.js +0 -308
  458. package/dist/src/core/sync/rate-limiter.js.map +0 -1
  459. package/dist/src/core/sync/time-range-selector.d.ts +0 -48
  460. package/dist/src/core/sync/time-range-selector.d.ts.map +0 -1
  461. package/dist/src/core/sync/time-range-selector.js +0 -224
  462. package/dist/src/core/sync/time-range-selector.js.map +0 -1
  463. package/dist/src/core/types/config.d.ts +0 -90
  464. package/dist/src/core/types/config.d.ts.map +0 -1
  465. package/dist/src/core/types/config.js +0 -37
  466. package/dist/src/core/types/config.js.map +0 -1
  467. package/dist/src/core/types/increment-metadata.d.ts +0 -120
  468. package/dist/src/core/types/increment-metadata.d.ts.map +0 -1
  469. package/dist/src/core/types/increment-metadata.js +0 -138
  470. package/dist/src/core/types/increment-metadata.js.map +0 -1
  471. package/dist/src/core/types/plugin.d.ts +0 -283
  472. package/dist/src/core/types/plugin.d.ts.map +0 -1
  473. package/dist/src/core/types/plugin.js +0 -49
  474. package/dist/src/core/types/plugin.js.map +0 -1
  475. package/dist/src/core/types/sync-profile.d.ts +0 -403
  476. package/dist/src/core/types/sync-profile.d.ts.map +0 -1
  477. package/dist/src/core/types/sync-profile.js +0 -55
  478. package/dist/src/core/types/sync-profile.js.map +0 -1
  479. package/dist/src/hooks/lib/types/reflection-types.d.ts +0 -125
  480. package/dist/src/hooks/lib/types/reflection-types.d.ts.map +0 -1
  481. package/dist/src/hooks/lib/types/reflection-types.js +0 -54
  482. package/dist/src/hooks/lib/types/reflection-types.js.map +0 -1
  483. package/dist/src/integrations/ado/ado-client.d.ts +0 -127
  484. package/dist/src/integrations/ado/ado-client.d.ts.map +0 -1
  485. package/dist/src/integrations/ado/ado-client.js +0 -416
  486. package/dist/src/integrations/ado/ado-client.js.map +0 -1
  487. package/dist/src/integrations/jira/jira-client.d.ts +0 -139
  488. package/dist/src/integrations/jira/jira-client.d.ts.map +0 -1
  489. package/dist/src/integrations/jira/jira-client.js +0 -386
  490. package/dist/src/integrations/jira/jira-client.js.map +0 -1
  491. package/dist/src/integrations/jira/jira-incremental-mapper.d.ts +0 -75
  492. package/dist/src/integrations/jira/jira-incremental-mapper.d.ts.map +0 -1
  493. package/dist/src/integrations/jira/jira-incremental-mapper.js +0 -474
  494. package/dist/src/integrations/jira/jira-incremental-mapper.js.map +0 -1
  495. package/dist/src/integrations/jira/jira-mapper.d.ts +0 -105
  496. package/dist/src/integrations/jira/jira-mapper.d.ts.map +0 -1
  497. package/dist/src/integrations/jira/jira-mapper.js +0 -494
  498. package/dist/src/integrations/jira/jira-mapper.js.map +0 -1
  499. package/dist/src/metrics/calculators/change-failure-rate.d.ts +0 -22
  500. package/dist/src/metrics/calculators/change-failure-rate.d.ts.map +0 -1
  501. package/dist/src/metrics/calculators/change-failure-rate.js +0 -70
  502. package/dist/src/metrics/calculators/change-failure-rate.js.map +0 -1
  503. package/dist/src/metrics/calculators/deployment-frequency.d.ts +0 -20
  504. package/dist/src/metrics/calculators/deployment-frequency.d.ts.map +0 -1
  505. package/dist/src/metrics/calculators/deployment-frequency.js +0 -61
  506. package/dist/src/metrics/calculators/deployment-frequency.js.map +0 -1
  507. package/dist/src/metrics/calculators/lead-time.d.ts +0 -22
  508. package/dist/src/metrics/calculators/lead-time.d.ts.map +0 -1
  509. package/dist/src/metrics/calculators/lead-time.js +0 -82
  510. package/dist/src/metrics/calculators/lead-time.js.map +0 -1
  511. package/dist/src/metrics/calculators/mttr.d.ts +0 -21
  512. package/dist/src/metrics/calculators/mttr.d.ts.map +0 -1
  513. package/dist/src/metrics/calculators/mttr.js +0 -60
  514. package/dist/src/metrics/calculators/mttr.js.map +0 -1
  515. package/dist/src/metrics/dora-calculator.d.ts +0 -28
  516. package/dist/src/metrics/dora-calculator.d.ts.map +0 -1
  517. package/dist/src/metrics/dora-calculator.js +0 -117
  518. package/dist/src/metrics/dora-calculator.js.map +0 -1
  519. package/dist/src/metrics/github-client.d.ts +0 -51
  520. package/dist/src/metrics/github-client.d.ts.map +0 -1
  521. package/dist/src/metrics/github-client.js +0 -133
  522. package/dist/src/metrics/github-client.js.map +0 -1
  523. package/dist/src/metrics/report-generator.d.ts +0 -17
  524. package/dist/src/metrics/report-generator.d.ts.map +0 -1
  525. package/dist/src/metrics/report-generator.js +0 -403
  526. package/dist/src/metrics/report-generator.js.map +0 -1
  527. package/dist/src/metrics/types.d.ts +0 -112
  528. package/dist/src/metrics/types.d.ts.map +0 -1
  529. package/dist/src/metrics/types.js +0 -10
  530. package/dist/src/metrics/types.js.map +0 -1
  531. package/dist/src/metrics/utils/percentile.d.ts +0 -25
  532. package/dist/src/metrics/utils/percentile.d.ts.map +0 -1
  533. package/dist/src/metrics/utils/percentile.js +0 -46
  534. package/dist/src/metrics/utils/percentile.js.map +0 -1
  535. package/dist/src/metrics/utils/tier-classifier.d.ts +0 -61
  536. package/dist/src/metrics/utils/tier-classifier.d.ts.map +0 -1
  537. package/dist/src/metrics/utils/tier-classifier.js +0 -100
  538. package/dist/src/metrics/utils/tier-classifier.js.map +0 -1
  539. package/dist/src/testing/test-generator.d.ts +0 -117
  540. package/dist/src/testing/test-generator.d.ts.map +0 -1
  541. package/dist/src/testing/test-generator.js +0 -370
  542. package/dist/src/testing/test-generator.js.map +0 -1
  543. package/dist/src/types/cost-tracking.d.ts +0 -43
  544. package/dist/src/types/cost-tracking.d.ts.map +0 -1
  545. package/dist/src/types/cost-tracking.js +0 -8
  546. package/dist/src/types/cost-tracking.js.map +0 -1
  547. package/dist/src/types/model-selection.d.ts +0 -53
  548. package/dist/src/types/model-selection.d.ts.map +0 -1
  549. package/dist/src/types/model-selection.js +0 -12
  550. package/dist/src/types/model-selection.js.map +0 -1
  551. package/dist/src/utils/agents-md-compiler.d.ts +0 -68
  552. package/dist/src/utils/agents-md-compiler.d.ts.map +0 -1
  553. package/dist/src/utils/agents-md-compiler.js +0 -420
  554. package/dist/src/utils/agents-md-compiler.js.map +0 -1
  555. package/dist/src/utils/auth-helpers.d.ts +0 -58
  556. package/dist/src/utils/auth-helpers.d.ts.map +0 -1
  557. package/dist/src/utils/auth-helpers.js +0 -108
  558. package/dist/src/utils/auth-helpers.js.map +0 -1
  559. package/dist/src/utils/auto-install.d.ts +0 -47
  560. package/dist/src/utils/auto-install.d.ts.map +0 -1
  561. package/dist/src/utils/auto-install.js +0 -211
  562. package/dist/src/utils/auto-install.js.map +0 -1
  563. package/dist/src/utils/claude-cli-detector.d.ts +0 -75
  564. package/dist/src/utils/claude-cli-detector.d.ts.map +0 -1
  565. package/dist/src/utils/claude-cli-detector.js +0 -285
  566. package/dist/src/utils/claude-cli-detector.js.map +0 -1
  567. package/dist/src/utils/cost-reporter.d.ts +0 -58
  568. package/dist/src/utils/cost-reporter.d.ts.map +0 -1
  569. package/dist/src/utils/cost-reporter.js +0 -224
  570. package/dist/src/utils/cost-reporter.js.map +0 -1
  571. package/dist/src/utils/docs-preview/config-generator.d.ts +0 -46
  572. package/dist/src/utils/docs-preview/config-generator.d.ts.map +0 -1
  573. package/dist/src/utils/docs-preview/config-generator.js +0 -377
  574. package/dist/src/utils/docs-preview/config-generator.js.map +0 -1
  575. package/dist/src/utils/docs-preview/docusaurus-setup.d.ts +0 -38
  576. package/dist/src/utils/docs-preview/docusaurus-setup.d.ts.map +0 -1
  577. package/dist/src/utils/docs-preview/docusaurus-setup.js +0 -177
  578. package/dist/src/utils/docs-preview/docusaurus-setup.js.map +0 -1
  579. package/dist/src/utils/docs-preview/index.d.ts +0 -7
  580. package/dist/src/utils/docs-preview/index.d.ts.map +0 -1
  581. package/dist/src/utils/docs-preview/index.js +0 -7
  582. package/dist/src/utils/docs-preview/index.js.map +0 -1
  583. package/dist/src/utils/docs-preview/package-installer.d.ts +0 -42
  584. package/dist/src/utils/docs-preview/package-installer.d.ts.map +0 -1
  585. package/dist/src/utils/docs-preview/package-installer.js +0 -182
  586. package/dist/src/utils/docs-preview/package-installer.js.map +0 -1
  587. package/dist/src/utils/docs-preview/server-manager.d.ts +0 -30
  588. package/dist/src/utils/docs-preview/server-manager.d.ts.map +0 -1
  589. package/dist/src/utils/docs-preview/server-manager.js +0 -212
  590. package/dist/src/utils/docs-preview/server-manager.js.map +0 -1
  591. package/dist/src/utils/docs-preview/sidebar-builder.d.ts +0 -32
  592. package/dist/src/utils/docs-preview/sidebar-builder.d.ts.map +0 -1
  593. package/dist/src/utils/docs-preview/sidebar-builder.js +0 -202
  594. package/dist/src/utils/docs-preview/sidebar-builder.js.map +0 -1
  595. package/dist/src/utils/docs-preview/types.d.ts +0 -57
  596. package/dist/src/utils/docs-preview/types.d.ts.map +0 -1
  597. package/dist/src/utils/docs-preview/types.js +0 -2
  598. package/dist/src/utils/docs-preview/types.js.map +0 -1
  599. package/dist/src/utils/env-file.d.ts +0 -88
  600. package/dist/src/utils/env-file.d.ts.map +0 -1
  601. package/dist/src/utils/env-file.js +0 -180
  602. package/dist/src/utils/env-file.js.map +0 -1
  603. package/dist/src/utils/env-multi-project-parser.d.ts +0 -220
  604. package/dist/src/utils/env-multi-project-parser.d.ts.map +0 -1
  605. package/dist/src/utils/env-multi-project-parser.js +0 -403
  606. package/dist/src/utils/env-multi-project-parser.js.map +0 -1
  607. package/dist/src/utils/esm-helpers.d.ts +0 -50
  608. package/dist/src/utils/esm-helpers.d.ts.map +0 -1
  609. package/dist/src/utils/esm-helpers.js +0 -57
  610. package/dist/src/utils/esm-helpers.js.map +0 -1
  611. package/dist/src/utils/execFileNoThrow.d.ts +0 -99
  612. package/dist/src/utils/execFileNoThrow.d.ts.map +0 -1
  613. package/dist/src/utils/execFileNoThrow.js +0 -137
  614. package/dist/src/utils/execFileNoThrow.js.map +0 -1
  615. package/dist/src/utils/external-resource-validator.d.ts +0 -102
  616. package/dist/src/utils/external-resource-validator.d.ts.map +0 -1
  617. package/dist/src/utils/external-resource-validator.js +0 -400
  618. package/dist/src/utils/external-resource-validator.js.map +0 -1
  619. package/dist/src/utils/generate-skills-index.d.ts +0 -24
  620. package/dist/src/utils/generate-skills-index.d.ts.map +0 -1
  621. package/dist/src/utils/generate-skills-index.js +0 -410
  622. package/dist/src/utils/generate-skills-index.js.map +0 -1
  623. package/dist/src/utils/model-selection.d.ts +0 -75
  624. package/dist/src/utils/model-selection.d.ts.map +0 -1
  625. package/dist/src/utils/model-selection.js +0 -204
  626. package/dist/src/utils/model-selection.js.map +0 -1
  627. package/dist/src/utils/plugin-validator.d.ts +0 -161
  628. package/dist/src/utils/plugin-validator.d.ts.map +0 -1
  629. package/dist/src/utils/plugin-validator.js +0 -558
  630. package/dist/src/utils/plugin-validator.js.map +0 -1
  631. package/dist/src/utils/pricing-constants.d.ts +0 -70
  632. package/dist/src/utils/pricing-constants.d.ts.map +0 -1
  633. package/dist/src/utils/pricing-constants.js +0 -71
  634. package/dist/src/utils/pricing-constants.js.map +0 -1
  635. package/dist/src/utils/project-detection.d.ts +0 -141
  636. package/dist/src/utils/project-detection.d.ts.map +0 -1
  637. package/dist/src/utils/project-detection.js +0 -321
  638. package/dist/src/utils/project-detection.js.map +0 -1
  639. package/dist/src/utils/string-utils.d.ts +0 -40
  640. package/dist/src/utils/string-utils.d.ts.map +0 -1
  641. package/dist/src/utils/string-utils.js +0 -58
  642. package/dist/src/utils/string-utils.js.map +0 -1
  643. package/dist/src/utils/translation.d.ts +0 -187
  644. package/dist/src/utils/translation.d.ts.map +0 -1
  645. package/dist/src/utils/translation.js +0 -414
  646. package/dist/src/utils/translation.js.map +0 -1
  647. package/dist/utils/docs-preview.bak/config-generator.d.ts +0 -46
  648. package/dist/utils/docs-preview.bak/config-generator.d.ts.map +0 -1
  649. package/dist/utils/docs-preview.bak/config-generator.js +0 -377
  650. package/dist/utils/docs-preview.bak/config-generator.js.map +0 -1
  651. package/dist/utils/docs-preview.bak/package-installer.d.ts +0 -42
  652. package/dist/utils/docs-preview.bak/package-installer.d.ts.map +0 -1
  653. package/dist/utils/docs-preview.bak/package-installer.js +0 -182
  654. package/dist/utils/docs-preview.bak/package-installer.js.map +0 -1
  655. package/dist/utils/docs-preview.bak/server-manager.d.ts +0 -30
  656. package/dist/utils/docs-preview.bak/server-manager.d.ts.map +0 -1
  657. package/dist/utils/docs-preview.bak/server-manager.js +0 -207
  658. package/dist/utils/docs-preview.bak/server-manager.js.map +0 -1
  659. package/dist/utils/docs-preview.bak/sidebar-builder.d.ts +0 -31
  660. package/dist/utils/docs-preview.bak/sidebar-builder.d.ts.map +0 -1
  661. package/dist/utils/docs-preview.bak/sidebar-builder.js +0 -202
  662. package/dist/utils/docs-preview.bak/sidebar-builder.js.map +0 -1
  663. package/dist/utils/docs-preview.bak/types.d.ts +0 -60
  664. package/dist/utils/docs-preview.bak/types.d.ts.map +0 -1
  665. package/dist/utils/docs-preview.bak/types.js +0 -5
  666. package/dist/utils/docs-preview.bak/types.js.map +0 -1
  667. package/dist/utils/plugin-detection.d.ts +0 -50
  668. package/dist/utils/plugin-detection.d.ts.map +0 -1
  669. package/dist/utils/secrets-loader.d.ts +0 -88
  670. package/dist/utils/secrets-loader.d.ts.map +0 -1
  671. package/dist/utils/secrets-loader.js +0 -271
  672. package/dist/utils/secrets-loader.js.map +0 -1
  673. package/src/templates/environments/minimal/.env.production +0 -16
  674. package/src/templates/environments/standard/.env.production +0 -30
@@ -0,0 +1,342 @@
1
+ /**
2
+ * Bidirectional GitHub Sync
3
+ *
4
+ * Syncs state from GitHub back to SpecWeave.
5
+ * Handles issue state changes, comments, assignees, labels, milestones.
6
+ *
7
+ * @module github-sync-bidirectional
8
+ */
9
+
10
+ import fs from 'fs-extra';
11
+ import path from 'path';
12
+ import { execFileNoThrow } from '../../../src/utils/execFileNoThrow.js';
13
+ import {
14
+ loadIncrementMetadata,
15
+ IncrementMetadata,
16
+ detectRepo
17
+ } from './github-issue-updater.js';
18
+
19
+ export interface GitHubIssueState {
20
+ number: number;
21
+ title: string;
22
+ body: string;
23
+ state: 'open' | 'closed';
24
+ labels: string[];
25
+ assignees: string[];
26
+ milestone?: string;
27
+ comments: GitHubComment[];
28
+ updated_at: string;
29
+ }
30
+
31
+ export interface GitHubComment {
32
+ id: number;
33
+ author: string;
34
+ body: string;
35
+ created_at: string;
36
+ }
37
+
38
+ export interface SyncConflict {
39
+ type: 'status' | 'assignee' | 'label';
40
+ githubValue: any;
41
+ specweaveValue: any;
42
+ resolution: 'github-wins' | 'specweave-wins' | 'prompt';
43
+ }
44
+
45
+ /**
46
+ * Sync from GitHub to SpecWeave
47
+ */
48
+ export async function syncFromGitHub(incrementId: string): Promise<void> {
49
+ console.log(`\n🔄 Syncing from GitHub for increment: ${incrementId}`);
50
+
51
+ try {
52
+ // 1. Load metadata
53
+ const metadata = await loadIncrementMetadata(incrementId);
54
+ if (!metadata?.github?.issue) {
55
+ console.log('ℹ️ No GitHub issue linked, nothing to sync');
56
+ return;
57
+ }
58
+
59
+ // 2. Detect repository
60
+ const repoInfo = await detectRepo();
61
+ if (!repoInfo) {
62
+ console.log('⚠️ Could not detect GitHub repository');
63
+ return;
64
+ }
65
+
66
+ const { owner, repo } = repoInfo;
67
+ const issueNumber = metadata.github.issue;
68
+
69
+ console.log(` Syncing from ${owner}/${repo}#${issueNumber}`);
70
+
71
+ // 3. Fetch current GitHub state
72
+ const githubState = await fetchGitHubIssueState(issueNumber, owner, repo);
73
+
74
+ // 4. Compare with local state
75
+ const conflicts = detectConflicts(metadata, githubState);
76
+
77
+ if (conflicts.length === 0) {
78
+ console.log('✅ No conflicts - GitHub and SpecWeave in sync');
79
+ return;
80
+ }
81
+
82
+ console.log(`⚠️ Detected ${conflicts.length} conflict(s)`);
83
+
84
+ // 5. Resolve conflicts
85
+ await resolveConflicts(incrementId, metadata, githubState, conflicts);
86
+
87
+ // 6. Sync comments
88
+ await syncComments(incrementId, githubState.comments);
89
+
90
+ // 7. Update metadata
91
+ await updateMetadata(incrementId, githubState);
92
+
93
+ console.log('✅ Bidirectional sync complete');
94
+
95
+ } catch (error) {
96
+ console.error('❌ Error syncing from GitHub:', error);
97
+ throw error;
98
+ }
99
+ }
100
+
101
+ /**
102
+ * Fetch current GitHub issue state
103
+ */
104
+ async function fetchGitHubIssueState(
105
+ issueNumber: number,
106
+ owner: string,
107
+ repo: string
108
+ ): Promise<GitHubIssueState> {
109
+ // Fetch issue details
110
+ const issueResult = await execFileNoThrow('gh', [
111
+ 'issue',
112
+ 'view',
113
+ String(issueNumber),
114
+ '--repo',
115
+ `${owner}/${repo}`,
116
+ '--json',
117
+ 'number,title,body,state,labels,assignees,milestone,updatedAt'
118
+ ]);
119
+
120
+ if (issueResult.status !== 0) {
121
+ throw new Error(`Failed to fetch issue: ${issueResult.stderr}`);
122
+ }
123
+
124
+ const issue = JSON.parse(issueResult.stdout);
125
+
126
+ // Fetch comments
127
+ const commentsResult = await execFileNoThrow('gh', [
128
+ 'api',
129
+ `repos/${owner}/${repo}/issues/${issueNumber}/comments`,
130
+ '--jq',
131
+ '.[] | {id: .id, author: .user.login, body: .body, created_at: .created_at}'
132
+ ]);
133
+
134
+ let comments: GitHubComment[] = [];
135
+ if (commentsResult.status === 0 && commentsResult.stdout.trim()) {
136
+ const commentLines = commentsResult.stdout.trim().split('\n');
137
+ comments = commentLines.map(line => JSON.parse(line));
138
+ }
139
+
140
+ return {
141
+ number: issue.number,
142
+ title: issue.title,
143
+ body: issue.body,
144
+ state: issue.state,
145
+ labels: issue.labels?.map((l: any) => l.name) || [],
146
+ assignees: issue.assignees?.map((a: any) => a.login) || [],
147
+ milestone: issue.milestone?.title,
148
+ comments,
149
+ updated_at: issue.updatedAt
150
+ };
151
+ }
152
+
153
+ /**
154
+ * Detect conflicts between GitHub and SpecWeave
155
+ */
156
+ function detectConflicts(
157
+ metadata: IncrementMetadata,
158
+ githubState: GitHubIssueState
159
+ ): SyncConflict[] {
160
+ const conflicts: SyncConflict[] = [];
161
+
162
+ // Status conflict
163
+ const specweaveStatus = metadata.status; // "active", "completed", "paused", "abandoned"
164
+ const githubStatus = githubState.state; // "open", "closed"
165
+
166
+ const expectedGitHubStatus = mapSpecWeaveStatusToGitHub(specweaveStatus);
167
+
168
+ if (githubStatus !== expectedGitHubStatus) {
169
+ conflicts.push({
170
+ type: 'status',
171
+ githubValue: githubStatus,
172
+ specweaveValue: specweaveStatus,
173
+ resolution: 'prompt' // Ask user
174
+ });
175
+ }
176
+
177
+ // TODO: Add assignee/label conflicts if needed in future
178
+
179
+ return conflicts;
180
+ }
181
+
182
+ /**
183
+ * Resolve conflicts
184
+ */
185
+ async function resolveConflicts(
186
+ incrementId: string,
187
+ metadata: IncrementMetadata,
188
+ githubState: GitHubIssueState,
189
+ conflicts: SyncConflict[]
190
+ ): Promise<void> {
191
+ for (const conflict of conflicts) {
192
+ console.log(`\n⚠️ Conflict detected: ${conflict.type}`);
193
+ console.log(` GitHub: ${conflict.githubValue}`);
194
+ console.log(` SpecWeave: ${conflict.specweaveValue}`);
195
+
196
+ if (conflict.type === 'status') {
197
+ await resolveStatusConflict(incrementId, metadata, githubState);
198
+ }
199
+ }
200
+ }
201
+
202
+ /**
203
+ * Resolve status conflict
204
+ */
205
+ async function resolveStatusConflict(
206
+ incrementId: string,
207
+ metadata: IncrementMetadata,
208
+ githubState: GitHubIssueState
209
+ ): Promise<void> {
210
+ const specweaveStatus = metadata.status;
211
+ const githubStatus = githubState.state;
212
+
213
+ // GitHub closed but SpecWeave active
214
+ if (githubStatus === 'closed' && specweaveStatus === 'active') {
215
+ console.log(`\n⚠️ **CONFLICT**: GitHub issue closed but SpecWeave increment still active!`);
216
+ console.log(` Recommendation: Run /specweave:done ${incrementId} to close increment`);
217
+ console.log(` Or reopen issue on GitHub if work is not complete`);
218
+ }
219
+
220
+ // GitHub open but SpecWeave completed
221
+ if (githubStatus === 'open' && specweaveStatus === 'completed') {
222
+ console.log(`\n⚠️ **CONFLICT**: SpecWeave increment completed but GitHub issue still open!`);
223
+ console.log(` Recommendation: Close GitHub issue #${metadata.github!.issue}`);
224
+ }
225
+
226
+ // GitHub open but SpecWeave paused
227
+ if (githubStatus === 'open' && specweaveStatus === 'paused') {
228
+ console.log(`\nℹ️ GitHub issue open, SpecWeave increment paused (OK)`);
229
+ }
230
+
231
+ // GitHub open but SpecWeave abandoned
232
+ if (githubStatus === 'open' && specweaveStatus === 'abandoned') {
233
+ console.log(`\n⚠️ **CONFLICT**: SpecWeave increment abandoned but GitHub issue still open!`);
234
+ console.log(` Recommendation: Close GitHub issue #${metadata.github!.issue} with reason`);
235
+ }
236
+ }
237
+
238
+ /**
239
+ * Sync comments from GitHub to SpecWeave
240
+ */
241
+ async function syncComments(
242
+ incrementId: string,
243
+ comments: GitHubComment[]
244
+ ): Promise<void> {
245
+ if (comments.length === 0) {
246
+ console.log('ℹ️ No comments to sync');
247
+ return;
248
+ }
249
+
250
+ const commentsPath = path.join(
251
+ process.cwd(),
252
+ '.specweave/increments',
253
+ incrementId,
254
+ 'logs/github-comments.md'
255
+ );
256
+
257
+ await fs.ensureFile(commentsPath);
258
+
259
+ // Load existing comments
260
+ let existingContent = '';
261
+ if (await fs.pathExists(commentsPath)) {
262
+ existingContent = await fs.readFile(commentsPath, 'utf-8');
263
+ }
264
+
265
+ // Extract existing comment IDs
266
+ const existingIds = new Set<number>();
267
+ const idMatches = existingContent.matchAll(/<!-- comment-id: (\d+) -->/g);
268
+ for (const match of idMatches) {
269
+ existingIds.add(parseInt(match[1], 10));
270
+ }
271
+
272
+ // Append new comments
273
+ const newComments = comments.filter(c => !existingIds.has(c.id));
274
+
275
+ if (newComments.length === 0) {
276
+ console.log('ℹ️ All comments already synced');
277
+ return;
278
+ }
279
+
280
+ console.log(`📝 Syncing ${newComments.length} new comment(s)`);
281
+
282
+ const commentsMarkdown = newComments.map(comment => `
283
+ ---
284
+
285
+ <!-- comment-id: ${comment.id} -->
286
+
287
+ **Author**: @${comment.author}
288
+ **Date**: ${new Date(comment.created_at).toLocaleString()}
289
+
290
+ ${comment.body}
291
+ `.trim()).join('\n\n');
292
+
293
+ await fs.appendFile(
294
+ commentsPath,
295
+ (existingContent ? '\n\n' : '') + commentsMarkdown
296
+ );
297
+
298
+ console.log(`✅ Comments saved to: logs/github-comments.md`);
299
+ }
300
+
301
+ /**
302
+ * Update metadata with GitHub state
303
+ */
304
+ async function updateMetadata(
305
+ incrementId: string,
306
+ githubState: GitHubIssueState
307
+ ): Promise<void> {
308
+ const metadataPath = path.join(
309
+ process.cwd(),
310
+ '.specweave/increments',
311
+ incrementId,
312
+ 'metadata.json'
313
+ );
314
+
315
+ const metadata = await fs.readJson(metadataPath);
316
+
317
+ // Update GitHub section
318
+ metadata.github = metadata.github || {};
319
+ metadata.github.synced = new Date().toISOString();
320
+ metadata.github.lastUpdated = githubState.updated_at;
321
+ metadata.github.state = githubState.state;
322
+
323
+ await fs.writeJson(metadataPath, metadata, { spaces: 2 });
324
+
325
+ console.log('✅ Metadata updated');
326
+ }
327
+
328
+ /**
329
+ * Map SpecWeave status to GitHub state
330
+ */
331
+ function mapSpecWeaveStatusToGitHub(status: string): 'open' | 'closed' {
332
+ switch (status) {
333
+ case 'completed':
334
+ case 'abandoned':
335
+ return 'closed';
336
+ case 'active':
337
+ case 'paused':
338
+ case 'planning':
339
+ default:
340
+ return 'open';
341
+ }
342
+ }
@@ -0,0 +1,380 @@
1
+ /**
2
+ * GitHub Sync for Increment Changes
3
+ *
4
+ * Handles syncing spec.md, plan.md, and tasks.md changes to GitHub issues.
5
+ * Detects scope changes, architecture updates, and task modifications.
6
+ *
7
+ * @module github-sync-increment-changes
8
+ */
9
+
10
+ import fs from 'fs-extra';
11
+ import path from 'path';
12
+ import { execSync } from 'child_process';
13
+ import {
14
+ loadIncrementMetadata,
15
+ detectRepo,
16
+ postScopeChangeComment
17
+ } from './github-issue-updater.js';
18
+ import { execFileNoThrow } from '../../../src/utils/execFileNoThrow.js';
19
+
20
+ export interface SpecChanges {
21
+ added: string[];
22
+ removed: string[];
23
+ modified: string[];
24
+ }
25
+
26
+ /**
27
+ * Sync increment file changes to GitHub
28
+ */
29
+ export async function syncIncrementChanges(
30
+ incrementId: string,
31
+ changedFile: 'spec.md' | 'plan.md' | 'tasks.md'
32
+ ): Promise<void> {
33
+ console.log(`\n🔄 Syncing ${changedFile} changes to GitHub...`);
34
+
35
+ try {
36
+ // 1. Load metadata
37
+ const metadata = await loadIncrementMetadata(incrementId);
38
+ if (!metadata?.github?.issue) {
39
+ console.log('ℹ️ No GitHub issue linked, skipping sync');
40
+ return;
41
+ }
42
+
43
+ // 2. Detect repository
44
+ const repoInfo = await detectRepo();
45
+ if (!repoInfo) {
46
+ console.log('⚠️ Could not detect GitHub repository, skipping sync');
47
+ return;
48
+ }
49
+
50
+ const { owner, repo } = repoInfo;
51
+ const issueNumber = metadata.github.issue;
52
+
53
+ // 3. Handle different file types
54
+ switch (changedFile) {
55
+ case 'spec.md':
56
+ await syncSpecChanges(incrementId, issueNumber, owner, repo);
57
+ break;
58
+ case 'plan.md':
59
+ await syncPlanChanges(incrementId, issueNumber, owner, repo);
60
+ break;
61
+ case 'tasks.md':
62
+ await syncTasksChanges(incrementId, issueNumber, owner, repo);
63
+ break;
64
+ }
65
+
66
+ console.log(`✅ ${changedFile} changes synced to issue #${issueNumber}`);
67
+
68
+ } catch (error) {
69
+ console.error(`❌ Error syncing ${changedFile}:`, error);
70
+ console.error(' (Non-blocking - continuing...)');
71
+ }
72
+ }
73
+
74
+ /**
75
+ * Sync spec.md changes (scope changes)
76
+ */
77
+ async function syncSpecChanges(
78
+ incrementId: string,
79
+ issueNumber: number,
80
+ owner: string,
81
+ repo: string
82
+ ): Promise<void> {
83
+ const specPath = path.join(
84
+ process.cwd(),
85
+ '.specweave/increments',
86
+ incrementId,
87
+ 'spec.md'
88
+ );
89
+
90
+ // Detect what changed in spec.md
91
+ const changes = await detectSpecChanges(specPath);
92
+
93
+ if (changes.added.length === 0 && changes.removed.length === 0 && changes.modified.length === 0) {
94
+ console.log('ℹ️ No significant spec changes detected');
95
+ return;
96
+ }
97
+
98
+ // Post scope change comment
99
+ await postScopeChangeComment(
100
+ issueNumber,
101
+ {
102
+ added: changes.added,
103
+ removed: changes.removed,
104
+ modified: changes.modified,
105
+ reason: 'Spec updated',
106
+ impact: estimateImpact(changes)
107
+ },
108
+ owner,
109
+ repo
110
+ );
111
+
112
+ // Update issue title if needed
113
+ const title = await extractSpecTitle(specPath);
114
+ if (title) {
115
+ await updateIssueTitle(issueNumber, title, owner, repo);
116
+ }
117
+ }
118
+
119
+ /**
120
+ * Sync plan.md changes (architecture updates)
121
+ */
122
+ async function syncPlanChanges(
123
+ incrementId: string,
124
+ issueNumber: number,
125
+ owner: string,
126
+ repo: string
127
+ ): Promise<void> {
128
+ const comment = `
129
+ 🏗️ **Architecture Plan Updated**
130
+
131
+ The implementation plan has been updated. See [\`plan.md\`](https://github.com/${owner}/${repo}/blob/develop/.specweave/increments/${incrementId}/plan.md) for details.
132
+
133
+ **Timestamp**: ${new Date().toISOString()}
134
+
135
+ ---
136
+ 🤖 Auto-updated by SpecWeave
137
+ `.trim();
138
+
139
+ await postComment(issueNumber, comment, owner, repo);
140
+ }
141
+
142
+ /**
143
+ * Sync tasks.md changes (task updates)
144
+ */
145
+ async function syncTasksChanges(
146
+ incrementId: string,
147
+ issueNumber: number,
148
+ owner: string,
149
+ repo: string
150
+ ): Promise<void> {
151
+ const tasksPath = path.join(
152
+ process.cwd(),
153
+ '.specweave/increments',
154
+ incrementId,
155
+ 'tasks.md'
156
+ );
157
+
158
+ // Extract task list
159
+ const tasks = await extractTasks(tasksPath);
160
+
161
+ // Update issue body with new task checklist
162
+ await updateIssueTaskChecklist(issueNumber, tasks, owner, repo);
163
+
164
+ const comment = `
165
+ 📋 **Task List Updated**
166
+
167
+ Tasks have been updated. Total tasks: ${tasks.length}
168
+
169
+ **Timestamp**: ${new Date().toISOString()}
170
+
171
+ ---
172
+ 🤖 Auto-updated by SpecWeave
173
+ `.trim();
174
+
175
+ await postComment(issueNumber, comment, owner, repo);
176
+ }
177
+
178
+ /**
179
+ * Detect changes in spec.md by comparing with git history
180
+ */
181
+ async function detectSpecChanges(specPath: string): Promise<SpecChanges> {
182
+ const changes: SpecChanges = {
183
+ added: [],
184
+ removed: [],
185
+ modified: []
186
+ };
187
+
188
+ try {
189
+ // Get git diff for spec.md
190
+ const diff = execSync(`git diff HEAD~1 "${specPath}" 2>/dev/null || true`, {
191
+ encoding: 'utf-8',
192
+ cwd: process.cwd()
193
+ });
194
+
195
+ if (!diff) {
196
+ return changes;
197
+ }
198
+
199
+ // Parse diff to find user story changes
200
+ const lines = diff.split('\n');
201
+ for (const line of lines) {
202
+ // Look for user story additions/removals
203
+ if (line.startsWith('+') && line.includes('US-')) {
204
+ const match = line.match(/US-\d+:([^(]+)/);
205
+ if (match) {
206
+ changes.added.push(match[1].trim());
207
+ }
208
+ } else if (line.startsWith('-') && line.includes('US-')) {
209
+ const match = line.match(/US-\d+:([^(]+)/);
210
+ if (match) {
211
+ changes.removed.push(match[1].trim());
212
+ }
213
+ }
214
+ }
215
+
216
+ } catch (error) {
217
+ console.warn('⚠️ Could not detect spec changes:', error);
218
+ }
219
+
220
+ return changes;
221
+ }
222
+
223
+ /**
224
+ * Extract title from spec.md frontmatter
225
+ */
226
+ async function extractSpecTitle(specPath: string): Promise<string | null> {
227
+ try {
228
+ const content = await fs.readFile(specPath, 'utf-8');
229
+ const match = content.match(/^#\s+(.+)$/m);
230
+ return match ? match[1].trim() : null;
231
+ } catch (error) {
232
+ return null;
233
+ }
234
+ }
235
+
236
+ /**
237
+ * Extract tasks from tasks.md
238
+ */
239
+ async function extractTasks(tasksPath: string): Promise<string[]> {
240
+ try {
241
+ const content = await fs.readFile(tasksPath, 'utf-8');
242
+ const tasks: string[] = [];
243
+ const lines = content.split('\n');
244
+
245
+ for (const line of lines) {
246
+ // Match task headers: ## T-001: Task name
247
+ const match = line.match(/^##\s+(T-\d+):\s*(.+)$/);
248
+ if (match) {
249
+ tasks.push(`${match[1]}: ${match[2]}`);
250
+ }
251
+ }
252
+
253
+ return tasks;
254
+ } catch (error) {
255
+ return [];
256
+ }
257
+ }
258
+
259
+ /**
260
+ * Estimate impact of spec changes
261
+ */
262
+ function estimateImpact(changes: SpecChanges): string {
263
+ const addedCount = changes.added.length;
264
+ const removedCount = changes.removed.length;
265
+
266
+ if (addedCount > removedCount) {
267
+ return `+${addedCount * 8} hours (${addedCount} user stories added)`;
268
+ } else if (removedCount > addedCount) {
269
+ return `-${removedCount * 8} hours (${removedCount} user stories removed)`;
270
+ } else {
271
+ return 'Neutral (scope adjusted)';
272
+ }
273
+ }
274
+
275
+ /**
276
+ * Update issue title
277
+ */
278
+ async function updateIssueTitle(
279
+ issueNumber: number,
280
+ title: string,
281
+ owner: string,
282
+ repo: string
283
+ ): Promise<void> {
284
+ const result = await execFileNoThrow('gh', [
285
+ 'issue',
286
+ 'edit',
287
+ String(issueNumber),
288
+ '--repo',
289
+ `${owner}/${repo}`,
290
+ '--title',
291
+ title
292
+ ]);
293
+
294
+ if (result.status !== 0) {
295
+ console.warn(`⚠️ Could not update issue title: ${result.stderr}`);
296
+ }
297
+ }
298
+
299
+ /**
300
+ * Update issue task checklist
301
+ */
302
+ async function updateIssueTaskChecklist(
303
+ issueNumber: number,
304
+ tasks: string[],
305
+ owner: string,
306
+ repo: string
307
+ ): Promise<void> {
308
+ // Get current issue body
309
+ const result = await execFileNoThrow('gh', [
310
+ 'issue',
311
+ 'view',
312
+ String(issueNumber),
313
+ '--repo',
314
+ `${owner}/${repo}`,
315
+ '--json',
316
+ 'body',
317
+ '-q',
318
+ '.body'
319
+ ]);
320
+
321
+ if (result.status !== 0) {
322
+ throw new Error(`Failed to get issue body: ${result.stderr}`);
323
+ }
324
+
325
+ const currentBody = result.stdout.trim();
326
+
327
+ // Build new task checklist
328
+ const taskChecklist = tasks.map(task => `- [ ] ${task}`).join('\n');
329
+
330
+ // Find and replace task section
331
+ const taskSectionRegex = /## Tasks\n\n[\s\S]*?(?=\n## |$)/;
332
+ const newTaskSection = `## Tasks\n\nProgress: 0/${tasks.length} tasks (0%)\n\n${taskChecklist}\n`;
333
+
334
+ let updatedBody: string;
335
+ if (taskSectionRegex.test(currentBody)) {
336
+ updatedBody = currentBody.replace(taskSectionRegex, newTaskSection);
337
+ } else {
338
+ // Append task section
339
+ updatedBody = currentBody + '\n\n' + newTaskSection;
340
+ }
341
+
342
+ // Update issue
343
+ const updateResult = await execFileNoThrow('gh', [
344
+ 'issue',
345
+ 'edit',
346
+ String(issueNumber),
347
+ '--repo',
348
+ `${owner}/${repo}`,
349
+ '--body',
350
+ updatedBody
351
+ ]);
352
+
353
+ if (updateResult.status !== 0) {
354
+ throw new Error(`Failed to update issue body: ${updateResult.stderr}`);
355
+ }
356
+ }
357
+
358
+ /**
359
+ * Post comment to issue
360
+ */
361
+ async function postComment(
362
+ issueNumber: number,
363
+ comment: string,
364
+ owner: string,
365
+ repo: string
366
+ ): Promise<void> {
367
+ const result = await execFileNoThrow('gh', [
368
+ 'issue',
369
+ 'comment',
370
+ String(issueNumber),
371
+ '--repo',
372
+ `${owner}/${repo}`,
373
+ '--body',
374
+ comment
375
+ ]);
376
+
377
+ if (result.status !== 0) {
378
+ throw new Error(`Failed to post comment: ${result.stderr}`);
379
+ }
380
+ }