specweave 0.22.0 → 0.22.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 (184) hide show
  1. package/CLAUDE.md +211 -0
  2. package/README.md +5 -5
  3. package/bin/specweave.js +5 -8
  4. package/dist/plugins/specweave-github/lib/CodeValidator.d.ts +1 -1
  5. package/dist/plugins/specweave-github/lib/CodeValidator.js +1 -1
  6. package/dist/plugins/specweave-github/lib/github-client-v2.d.ts +10 -0
  7. package/dist/plugins/specweave-github/lib/github-client-v2.d.ts.map +1 -1
  8. package/dist/plugins/specweave-github/lib/github-client-v2.js +26 -0
  9. package/dist/plugins/specweave-github/lib/github-client-v2.js.map +1 -1
  10. package/dist/plugins/specweave-github/lib/task-sync.d.ts.map +1 -1
  11. package/dist/plugins/specweave-github/lib/task-sync.js +7 -0
  12. package/dist/plugins/specweave-github/lib/task-sync.js.map +1 -1
  13. package/dist/src/cli/commands/migrate-to-profiles.d.ts +1 -0
  14. package/dist/src/cli/commands/migrate-to-profiles.d.ts.map +1 -1
  15. package/dist/src/cli/commands/migrate-to-profiles.js +12 -1
  16. package/dist/src/cli/commands/migrate-to-profiles.js.map +1 -1
  17. package/dist/src/cli/commands/next-command.d.ts +52 -0
  18. package/dist/src/cli/commands/next-command.d.ts.map +1 -0
  19. package/dist/src/cli/commands/next-command.js +204 -0
  20. package/dist/src/cli/commands/next-command.js.map +1 -0
  21. package/dist/src/cli/commands/sync-specs.d.ts +16 -0
  22. package/dist/src/cli/commands/sync-specs.d.ts.map +1 -0
  23. package/dist/src/cli/commands/sync-specs.js +130 -0
  24. package/dist/src/cli/commands/sync-specs.js.map +1 -0
  25. package/dist/src/cli/count-tasks.d.ts +20 -0
  26. package/dist/src/cli/count-tasks.d.ts.map +1 -0
  27. package/dist/src/cli/count-tasks.js +50 -0
  28. package/dist/src/cli/count-tasks.js.map +1 -0
  29. package/dist/src/config/ConfigManager.d.ts.map +1 -1
  30. package/dist/src/config/ConfigManager.js +2 -1
  31. package/dist/src/config/ConfigManager.js.map +1 -1
  32. package/dist/src/config/types.d.ts +50 -50
  33. package/dist/src/core/cicd/state-manager.d.ts +8 -0
  34. package/dist/src/core/cicd/state-manager.d.ts.map +1 -1
  35. package/dist/src/core/cicd/state-manager.js +60 -15
  36. package/dist/src/core/cicd/state-manager.js.map +1 -1
  37. package/dist/src/core/cost-tracker.d.ts.map +1 -1
  38. package/dist/src/core/cost-tracker.js +2 -1
  39. package/dist/src/core/cost-tracker.js.map +1 -1
  40. package/dist/src/core/iac/template-engine.d.ts.map +1 -1
  41. package/dist/src/core/iac/template-engine.js +28 -0
  42. package/dist/src/core/iac/template-engine.js.map +1 -1
  43. package/dist/src/core/iac/template-generator.d.ts +53 -0
  44. package/dist/src/core/iac/template-generator.d.ts.map +1 -0
  45. package/dist/src/core/iac/template-generator.js +125 -0
  46. package/dist/src/core/iac/template-generator.js.map +1 -0
  47. package/dist/src/core/increment/status-auto-transition.js +3 -3
  48. package/dist/src/core/increment/status-auto-transition.js.map +1 -1
  49. package/dist/src/core/living-docs/CodeValidator.js +1 -1
  50. package/dist/src/core/living-docs/CodeValidator.js.map +1 -1
  51. package/dist/src/core/living-docs/content-distributor.d.ts.map +1 -1
  52. package/dist/src/core/living-docs/content-distributor.js +11 -1
  53. package/dist/src/core/living-docs/content-distributor.js.map +1 -1
  54. package/dist/src/core/living-docs/living-docs-sync.d.ts +166 -0
  55. package/dist/src/core/living-docs/living-docs-sync.d.ts.map +1 -0
  56. package/dist/src/core/living-docs/living-docs-sync.js +726 -0
  57. package/dist/src/core/living-docs/living-docs-sync.js.map +1 -0
  58. package/dist/src/core/living-docs/task-project-specific-generator.d.ts +7 -3
  59. package/dist/src/core/living-docs/task-project-specific-generator.d.ts.map +1 -1
  60. package/dist/src/core/living-docs/task-project-specific-generator.js +40 -24
  61. package/dist/src/core/living-docs/task-project-specific-generator.js.map +1 -1
  62. package/dist/src/core/plugin-loader.d.ts +7 -0
  63. package/dist/src/core/plugin-loader.d.ts.map +1 -1
  64. package/dist/src/core/plugin-loader.js +18 -1
  65. package/dist/src/core/plugin-loader.js.map +1 -1
  66. package/dist/src/core/serverless/platform-data-loader.d.ts +8 -0
  67. package/dist/src/core/serverless/platform-data-loader.d.ts.map +1 -1
  68. package/dist/src/core/serverless/platform-data-loader.js +14 -0
  69. package/dist/src/core/serverless/platform-data-loader.js.map +1 -1
  70. package/dist/src/core/serverless/types.d.ts +1 -1
  71. package/dist/src/core/serverless/types.d.ts.map +1 -1
  72. package/dist/src/core/status-line/status-line-manager.d.ts +6 -2
  73. package/dist/src/core/status-line/status-line-manager.d.ts.map +1 -1
  74. package/dist/src/core/status-line/status-line-manager.js +11 -5
  75. package/dist/src/core/status-line/status-line-manager.js.map +1 -1
  76. package/dist/src/core/status-line/task-counter.d.ts +69 -0
  77. package/dist/src/core/status-line/task-counter.d.ts.map +1 -0
  78. package/dist/src/core/status-line/task-counter.js +107 -0
  79. package/dist/src/core/status-line/task-counter.js.map +1 -0
  80. package/dist/src/core/workflow/autonomous-executor.d.ts +111 -0
  81. package/dist/src/core/workflow/autonomous-executor.d.ts.map +1 -0
  82. package/dist/src/core/workflow/autonomous-executor.js +275 -0
  83. package/dist/src/core/workflow/autonomous-executor.js.map +1 -0
  84. package/dist/src/core/workflow/backlog-scanner.d.ts +94 -0
  85. package/dist/src/core/workflow/backlog-scanner.d.ts.map +1 -0
  86. package/dist/src/core/workflow/backlog-scanner.js +170 -0
  87. package/dist/src/core/workflow/backlog-scanner.js.map +1 -0
  88. package/dist/src/core/workflow/command-invoker.d.ts +86 -0
  89. package/dist/src/core/workflow/command-invoker.d.ts.map +1 -0
  90. package/dist/src/core/workflow/command-invoker.js +131 -0
  91. package/dist/src/core/workflow/command-invoker.js.map +1 -0
  92. package/dist/src/core/workflow/cost-estimator.d.ts +120 -0
  93. package/dist/src/core/workflow/cost-estimator.d.ts.map +1 -0
  94. package/dist/src/core/workflow/cost-estimator.js +222 -0
  95. package/dist/src/core/workflow/cost-estimator.js.map +1 -0
  96. package/dist/src/core/workflow/index.d.ts +20 -0
  97. package/dist/src/core/workflow/index.d.ts.map +1 -0
  98. package/dist/src/core/workflow/index.js +24 -0
  99. package/dist/src/core/workflow/index.js.map +1 -0
  100. package/dist/src/core/workflow/state-manager.d.ts +107 -0
  101. package/dist/src/core/workflow/state-manager.d.ts.map +1 -0
  102. package/dist/src/core/workflow/state-manager.js +126 -0
  103. package/dist/src/core/workflow/state-manager.js.map +1 -0
  104. package/dist/src/core/workflow/workflow-orchestrator.d.ts +93 -0
  105. package/dist/src/core/workflow/workflow-orchestrator.d.ts.map +1 -0
  106. package/dist/src/core/workflow/workflow-orchestrator.js +195 -0
  107. package/dist/src/core/workflow/workflow-orchestrator.js.map +1 -0
  108. package/dist/src/init/architecture/types.d.ts +10 -10
  109. package/dist/src/metrics/dora-calculator.js +2 -2
  110. package/dist/src/metrics/dora-calculator.js.map +1 -1
  111. package/dist/src/utils/pricing-constants.d.ts +5 -2
  112. package/dist/src/utils/pricing-constants.d.ts.map +1 -1
  113. package/dist/src/utils/pricing-constants.js +3 -2
  114. package/dist/src/utils/pricing-constants.js.map +1 -1
  115. package/package.json +4 -4
  116. package/plugins/specweave/agents/infrastructure/AGENT.md +88 -46
  117. package/plugins/specweave/agents/pm/AGENT.md +58 -1
  118. package/plugins/specweave/commands/specweave-archive-features.md +1 -1
  119. package/plugins/specweave/commands/specweave-archive-increments.md +1 -1
  120. package/plugins/specweave/commands/specweave-check-hooks.md +5 -0
  121. package/plugins/specweave/commands/specweave-done.md +12 -0
  122. package/plugins/specweave/commands/specweave-plan.md +1 -1
  123. package/plugins/specweave/commands/specweave-progress.md +108 -379
  124. package/plugins/specweave/commands/specweave-reopen.md +1 -1
  125. package/plugins/specweave/commands/specweave-restore-feature.md +1 -1
  126. package/plugins/specweave/commands/specweave-sync-specs.md +20 -48
  127. package/plugins/specweave/hooks/lib/update-status-line.sh +44 -35
  128. package/plugins/specweave/hooks/lib/validate-spec-status.sh +163 -0
  129. package/plugins/specweave/hooks/user-prompt-submit.sh +17 -35
  130. package/plugins/specweave/lib/hooks/update-tasks-md.js +52 -9
  131. package/plugins/specweave/lib/hooks/update-tasks-md.ts +77 -16
  132. package/plugins/specweave/templates/iac/aws-lambda/defaults.json +24 -0
  133. package/plugins/specweave/templates/iac/aws-lambda/templates/README.md.hbs +260 -0
  134. package/plugins/specweave/templates/iac/aws-lambda/templates/environments/dev.tfvars.hbs +34 -0
  135. package/plugins/specweave/templates/iac/aws-lambda/templates/environments/prod.tfvars.hbs +37 -0
  136. package/plugins/specweave/templates/iac/aws-lambda/templates/environments/staging.tfvars.hbs +35 -0
  137. package/plugins/specweave/templates/iac/aws-lambda/templates/outputs.tf.hbs +77 -0
  138. package/plugins/specweave/templates/iac/aws-lambda/templates/providers.tf.hbs +36 -0
  139. package/plugins/specweave/templates/iac/aws-lambda/templates/variables.tf.hbs +115 -0
  140. package/plugins/specweave/templates/iac/azure-functions/defaults.json +25 -0
  141. package/plugins/specweave/templates/iac/azure-functions/templates/README.md.hbs +268 -0
  142. package/plugins/specweave/templates/iac/azure-functions/templates/environments/dev.tfvars.hbs +34 -0
  143. package/plugins/specweave/templates/iac/azure-functions/templates/environments/prod.tfvars.hbs +46 -0
  144. package/plugins/specweave/templates/iac/azure-functions/templates/environments/staging.tfvars.hbs +34 -0
  145. package/plugins/specweave/templates/iac/azure-functions/templates/main.tf.hbs +225 -0
  146. package/plugins/specweave/templates/iac/azure-functions/templates/outputs.tf.hbs +89 -0
  147. package/plugins/specweave/templates/iac/azure-functions/templates/provider.tf.hbs +27 -0
  148. package/plugins/specweave/templates/iac/azure-functions/templates/providers.tf.hbs +35 -0
  149. package/plugins/specweave/templates/iac/azure-functions/templates/variables.tf.hbs +124 -0
  150. package/plugins/specweave/templates/iac/firebase/defaults.json +29 -0
  151. package/plugins/specweave/templates/iac/firebase/templates/README.md.hbs +35 -0
  152. package/plugins/specweave/templates/iac/firebase/templates/environments/dev.tfvars.hbs +7 -0
  153. package/plugins/specweave/templates/iac/firebase/templates/environments/prod.tfvars.hbs +7 -0
  154. package/plugins/specweave/templates/iac/firebase/templates/environments/staging.tfvars.hbs +7 -0
  155. package/plugins/specweave/templates/iac/firebase/templates/main.tf.hbs +90 -0
  156. package/plugins/specweave/templates/iac/firebase/templates/outputs.tf.hbs +15 -0
  157. package/plugins/specweave/templates/iac/firebase/templates/providers.tf.hbs +23 -0
  158. package/plugins/specweave/templates/iac/firebase/templates/variables.tf.hbs +42 -0
  159. package/plugins/specweave/templates/iac/gcp-cloud-functions/defaults.json +26 -0
  160. package/plugins/specweave/templates/iac/gcp-cloud-functions/templates/README.md.hbs +299 -0
  161. package/plugins/specweave/templates/iac/gcp-cloud-functions/templates/environments/dev.tfvars.hbs +36 -0
  162. package/plugins/specweave/templates/iac/gcp-cloud-functions/templates/environments/prod.tfvars.hbs +48 -0
  163. package/plugins/specweave/templates/iac/gcp-cloud-functions/templates/environments/staging.tfvars.hbs +41 -0
  164. package/plugins/specweave/templates/iac/gcp-cloud-functions/templates/main.tf.hbs +192 -0
  165. package/plugins/specweave/templates/iac/gcp-cloud-functions/templates/outputs.tf.hbs +66 -0
  166. package/plugins/specweave/templates/iac/gcp-cloud-functions/templates/providers.tf.hbs +25 -0
  167. package/plugins/specweave/templates/iac/gcp-cloud-functions/templates/variables.tf.hbs +119 -0
  168. package/plugins/specweave/templates/iac/supabase/defaults.json +15 -0
  169. package/plugins/specweave/templates/iac/supabase/templates/README.md.hbs +46 -0
  170. package/plugins/specweave/templates/iac/supabase/templates/main.tf.hbs +50 -0
  171. package/plugins/specweave-github/agents/github-manager/AGENT.md +39 -7
  172. package/plugins/specweave-github/commands/specweave-github-create-issue.md +5 -5
  173. package/plugins/specweave-github/lib/CodeValidator.ts +1 -1
  174. package/plugins/specweave-github/lib/github-client-v2.js +29 -0
  175. package/plugins/specweave-github/lib/github-client-v2.ts +30 -0
  176. package/plugins/specweave-github/lib/task-sync.js +4 -0
  177. package/plugins/specweave-github/lib/task-sync.ts +7 -0
  178. package/plugins/specweave-jira/lib/enhanced-jira-sync.js +3 -3
  179. package/plugins/specweave-release/hooks/.specweave/logs/dora-tracking.log +2022 -0
  180. package/src/templates/CLAUDE.md.template +31 -0
  181. package/dist/src/core/living-docs/ThreeLayerSyncManager.d.ts +0 -116
  182. package/dist/src/core/living-docs/ThreeLayerSyncManager.d.ts.map +0 -1
  183. package/dist/src/core/living-docs/ThreeLayerSyncManager.js +0 -356
  184. package/dist/src/core/living-docs/ThreeLayerSyncManager.js.map +0 -1
@@ -55,6 +55,18 @@ You are acting as the Product Manager to validate increment completion before cl
55
55
 
56
56
  **🔥 CRITICAL: PM agent MUST validate all 3 gates before allowing closure!**
57
57
 
58
+ **⛔ CRITICAL: PM Validation Report File Location**
59
+
60
+ When the PM agent writes the validation report, it MUST go in the `reports/` subfolder:
61
+ - ✅ **CORRECT**: `.specweave/increments/####-name/reports/PM-VALIDATION-REPORT.md`
62
+ - ❌ **WRONG**: `.specweave/increments/####-name/PM-VALIDATION-REPORT.md`
63
+
64
+ **Folder structure rules**:
65
+ - ONLY spec.md, plan.md, tasks.md allowed in increment root
66
+ - ALL reports MUST go in `reports/` subfolder
67
+ - ALL scripts MUST go in `scripts/` subfolder
68
+ - ALL logs MUST go in `logs/` subfolder
69
+
58
70
  Invoke PM agent with validation task:
59
71
 
60
72
  ```
@@ -1,5 +1,5 @@
1
1
  ---
2
- name: specweave-plan
2
+ name: specweave:plan
3
3
  description: Generate plan.md and tasks.md for PLANNING increment using Architect Agent
4
4
  ---
5
5
 
@@ -1,407 +1,136 @@
1
1
  ---
2
2
  name: specweave:progress
3
- description: Show progress for ALL active increments (up to 2), task completion %, PM gates, and next actions
3
+ description: Show progress for all active increments with task completion status
4
4
  ---
5
5
 
6
6
  # Progress Tracking
7
7
 
8
- **Quick Status Check**: See exactly where you are in ALL your active increments.
9
-
10
- **NEW**: Now shows **ALL active increments** (max 2) with full progress for each!
11
-
12
- Shows:
13
- - **ALL active increment statuses** (not just one!)
14
- - Task completion percentage (per increment)
15
- - PM gate preview (tasks, tests, docs)
16
- - Next action to take
17
- - Time tracking
18
- - WIP limit warnings (if >2 active)
19
-
20
- ---
21
-
22
- ## Quick Start
23
-
24
- ```bash
25
- # Check progress for all active increments (recommended)
26
- specweave progress
27
-
28
- # Or use the full command name
29
- specweave status --verbose
30
-
31
- # Filter by increment type
32
- specweave progress --type feature
33
- ```
34
-
35
- **Note**: `progress` is an alias for `status --verbose` with automatic verbose mode enabled.
36
-
37
- ---
8
+ Simple, fast progress check for all active increments.
38
9
 
39
10
  ## Usage
40
11
 
41
12
  ```bash
42
- # Check current progress
43
13
  /specweave:progress
44
-
45
- # Show progress for specific increment
46
- /specweave:progress 0001
47
- ```
48
-
49
- ---
50
-
51
- ## What It Shows
52
-
53
- ### 1. Active Increment Info
54
- - Increment ID and name
55
- - Current status (planned, in-progress, completed)
56
- - Time started and last activity
57
-
58
- ### 2. Task Progress (with %)
59
- - Visual task list with completion indicators
60
- - Percentage complete (P1 tasks weighted higher)
61
- - Next incomplete task highlighted
62
- - Stuck/blocked task warnings
63
-
64
- ### 3. PM Gates Preview
65
- - **Gate 1**: Tasks completed (P1 required)
66
- - **Gate 2**: Tests passing (>80% coverage)
67
- - **Gate 3**: Documentation updated
68
-
69
- ### 4. Next Action Guidance
70
- - Suggests exact command to run next
71
- - Warns about WIP limit violations
72
- - Alerts for long-inactive increments
73
-
74
- ---
75
-
76
- ## Example Output
77
-
78
- ### Normal Progress
79
-
80
- ```
81
- 📊 Current Progress
82
-
83
- Active Increment: 0001-user-authentication
84
- Status: in-progress (started 2 hours ago)
85
-
86
- Task Progress: 3/12 completed (25%)
87
- ├─ [✅] T001: Setup auth module (P1) - 5 min ago
88
- ├─ [✅] T002: Create user model (P1) - 10 min ago
89
- ├─ [✅] T003: Implement JWT tokens (P1) - 15 min ago
90
- ├─ [⏳] T004: Add password hashing (P1) ← NEXT
91
- ├─ [ ] T005: Create login endpoint (P1)
92
- ├─ [ ] T006: Add logout endpoint (P2)
93
- └─ 6 more tasks...
94
-
95
- PM Gates Preview:
96
- ├─ Gate 1 (Tasks): 3/8 P1 tasks done (38%) ⏳
97
- ├─ Gate 2 (Tests): 2/5 passing (40%) ⏳
98
- └─ Gate 3 (Docs): CLAUDE.md ✅, README.md ⏳
99
-
100
- Last Activity: 5 minutes ago
101
- Next Action: Run `/do 0001` to resume at T004
102
-
103
- 💡 Tip: `/do` auto-resumes from last incomplete task!
104
- ```
105
-
106
- ### No Active Work
107
-
108
- ```
109
- 📊 Current Progress
110
-
111
- No active increment found.
112
-
113
- Recent Increments:
114
- ├─ 0003-payment-flow (completed) - 1 day ago
115
- ├─ 0002-user-profile (completed) - 2 days ago
116
- └─ 0001-auth (closed) - 3 days ago
117
-
118
- Next Action: Run `/specweave inc "feature description"` to start new work
119
-
120
- 💡 Tip: `/inc` is your starting point for all new features
121
- ```
122
-
123
- ### Multiple In-Progress (WIP Limit Warning)
124
-
125
- ```
126
- 📊 Current Progress
127
-
128
- ⚠️ Warning: 2 increments in-progress (exceeds recommended WIP limit: 1)
129
-
130
- Active Increments:
131
- 1. 0002-payment-flow (in-progress)
132
- └─ Task Progress: 5/10 completed (50%)
133
-
134
- 2. 0003-notifications (in-progress)
135
- └─ Task Progress: 2/8 completed (25%)
136
-
137
- Recommendation: Focus on completing 0002 before starting new work.
138
-
139
- Next Action: Run `/do 0002` to continue payment-flow
140
- ```
141
-
142
- ### Stuck/Inactive Increment
143
-
144
- ```
145
- 📊 Current Progress
146
-
147
- Active Increment: 0001-user-authentication
148
- Status: in-progress (started 2 days ago)
149
-
150
- ⚠️ Warning: Last activity was 6 hours ago
151
- └─ Current task T005 may be stuck or blocked
152
-
153
- Task Progress: 4/12 completed (33%)
154
- ├─ [✅] T001: Setup auth module (P1)
155
- ├─ [✅] T002: Create user model (P1)
156
- ├─ [✅] T003: Implement JWT tokens (P1)
157
- ├─ [✅] T004: Add password hashing (P1)
158
- ├─ [🔄] T005: Create login endpoint (P1) ← STUCK? (6 hours)
159
- ├─ [ ] T006: Add logout endpoint (P2)
160
- └─ 6 more tasks...
161
-
162
- Next Action:
163
- 1. Run `/do 0001` to retry T005
164
- 2. Or manually review T005 for blockers
165
- 3. Or skip T005 and defer to next increment
166
-
167
- 💡 Tip: Long-running tasks may need breaking down
168
14
  ```
169
15
 
170
- ---
171
-
172
16
  ## Implementation
173
17
 
174
- **How `/progress` works** (UPGRADED for multi-active support):
175
-
176
- ### Step 1: Find ALL Active Increments (FAST!)
177
-
178
- ```typescript
179
- // NEW: Use ActiveIncrementManager cache (10x faster!)
180
- import { MetadataManager } from './src/core/increment/metadata-manager.js';
181
-
182
- // Get ALL active increments (from cache, not scan!)
183
- const activeIncrements = MetadataManager.getActive();
184
-
185
- // Performance:
186
- // - OLD: Scan 31 metadata files (~50ms)
187
- // - NEW: Read 1 cache + 1-2 metadata files (~5ms) ✅
188
- ```
189
-
190
- ### Step 2: Parse Tasks and Calculate %
191
-
192
- ```bash
193
- # Read tasks.md
194
- # Count completed vs total
195
- # Weight P1 tasks higher (2x), P2 (1.5x), P3 (1x)
196
- # Calculate percentage
197
-
198
- Example:
199
- - P1 tasks: 3/8 complete = 3*2 / 8*2 = 6/16 (37.5%)
200
- - P2 tasks: 2/3 complete = 2*1.5 / 3*1.5 = 3/4.5 (66%)
201
- - P3 tasks: 1/1 complete = 1*1 / 1*1 = 1/1 (100%)
202
-
203
- Overall: (6 + 3 + 1) / (16 + 4.5 + 1) = 10/21.5 = 46.5%
204
- ```
205
-
206
- ### Step 3: Check PM Gates
207
-
208
18
  ```bash
209
- # Gate 1: Tasks
210
- # - Count P1 tasks completed
211
- # - Status: ✅ all done, ⏳ in progress, ❌ blocked
212
-
213
- # Gate 2: Tests
214
- # - Run test suite (npm test or equivalent)
215
- # - Check coverage report
216
- # - Status: ✅ >80%, ⏳ 50-80%, ❌ <50%
217
-
218
- # Gate 3: Docs
219
- # - Check if CLAUDE.md updated recently
220
- # - Check if README.md mentions new feature
221
- # - Status: updated, ⏳ partial, ❌ outdated
19
+ #!/bin/bash
20
+
21
+ echo ""
22
+ echo "📊 Increment Progress"
23
+ echo "================================"
24
+ echo ""
25
+
26
+ # Counters
27
+ active_count=0
28
+ other_count=0
29
+
30
+ # Scan all increments
31
+ for dir in .specweave/increments/*/; do
32
+ [ ! -d "$dir" ] && continue
33
+
34
+ increment=$(basename "$dir")
35
+ metadata="$dir/metadata.json"
36
+
37
+ # Skip if no metadata
38
+ [ ! -f "$metadata" ] && continue
39
+
40
+ # Get status
41
+ inc_status=$(jq -r '.status' "$metadata" 2>/dev/null)
42
+
43
+ # Skip completed/archived
44
+ [ "$inc_status" = "completed" ] && continue
45
+ [ "$inc_status" = "archived" ] && continue
46
+
47
+ # Count for summary
48
+ if [ "$inc_status" = "in-progress" ]; then
49
+ active_count=$((active_count + 1))
50
+ else
51
+ other_count=$((other_count + 1))
52
+ fi
53
+
54
+ # Get task stats from tasks.md
55
+ tasks_file="$dir/tasks.md"
56
+ if [ -f "$tasks_file" ]; then
57
+ # Count tasks (headers with T-NNN format - both ### and ####)
58
+ total=$(grep -cE '^#{3,4}\s*T-[0-9]' "$tasks_file" 2>/dev/null | tr -d '\n' || echo "0")
59
+ # Count completed (various formats)
60
+ completed=$(grep -cE '(✅ COMPLETE|\[COMPLETED\]|\[x\] Completed)' "$tasks_file" 2>/dev/null | tr -d '\n' || echo "0")
61
+
62
+ # Ensure we have valid numbers (fallback to 0 if empty)
63
+ total=${total:-0}
64
+ completed=${completed:-0}
65
+
66
+ if [ "$total" -gt 0 ] 2>/dev/null; then
67
+ percent=$((completed * 100 / total))
68
+ else
69
+ percent=0
70
+ fi
71
+ else
72
+ total=0
73
+ completed=0
74
+ percent=0
75
+ fi
76
+
77
+ # Display based on status
78
+ if [ "$inc_status" = "in-progress" ]; then
79
+ echo "🟢 ACTIVE: $increment"
80
+ echo " Status: $inc_status"
81
+ echo " Tasks: $completed/$total completed ($percent%)"
82
+ echo " Next: /specweave:do $increment"
83
+ echo ""
84
+ else
85
+ echo "⏸️ $inc_status: $increment"
86
+ echo " Tasks: $completed/$total ($percent%)"
87
+ echo ""
88
+ fi
89
+ done
90
+
91
+ echo "================================"
92
+ echo "Summary:"
93
+ echo " Active increments: $active_count"
94
+ echo " Other non-completed: $other_count"
95
+
96
+ if [ "$active_count" -eq 0 ]; then
97
+ echo ""
98
+ echo "💡 No active work. Run /specweave:increment to start new work"
99
+ elif [ "$active_count" -gt 0 ]; then
100
+ echo ""
101
+ echo "💡 Continue with /specweave:do"
102
+ fi
103
+
104
+ echo ""
222
105
  ```
223
106
 
224
- ### Step 4: Display ALL Active Increments
225
-
226
- ```typescript
227
- // NEW: Display progress for EACH active increment
228
- for (const increment of activeIncrements) {
229
- console.log(`\n📊 ${increment.id}`);
230
- console.log(`Status: ${increment.status}`);
231
- console.log(`Task Progress: ${completed}/${total} (${percent}%)`);
232
- console.log(`Next: /specweave:do ${increment.id}`);
233
- }
107
+ ## Example Output
234
108
 
235
- // Show WIP limit info
236
- if (activeIncrements.length === 0) {
237
- console.log('No active increments. Run /specweave:increment to start new work.');
238
- } else if (activeIncrements.length === 1) {
239
- console.log('✅ 1 active increment (optimal focus)');
240
- } else if (activeIncrements.length === 2) {
241
- console.log('✅ 2 active increments (at WIP limit, but OK)');
242
- } else if (activeIncrements.length > 2) {
243
- console.log('⚠️ >2 active increments (exceeds WIP limit!)');
244
- }
245
109
  ```
110
+ 📊 Increment Progress
111
+ ================================
246
112
 
247
- ---
113
+ 🟢 ACTIVE: 0037-project-specific-tasks
114
+ Status: in-progress
115
+ Tasks: 72/85 completed (84%)
116
+ Next: /specweave:do 0037-project-specific-tasks
248
117
 
249
- ## When to Use `/specweave:progress`
118
+ ⏸️ planning: 0039-ultra-smart-next-command
119
+ Tasks: 0/45 (0%)
250
120
 
251
- Use `/specweave:progress` when you:
252
- - ✅ Come back after a break and need context
253
- - Want to see overall completion status
254
- - ✅ Need to know which task to work on next
255
- - ✅ Forgot which increment you're working on
256
- - ✅ Want to check if PM gates will pass
257
- - ✅ Suspect a task is stuck or blocked
258
- - ✅ Have multiple increments and need to prioritize
121
+ ================================
122
+ Summary:
123
+ Active increments: 1
124
+ Other non-completed: 1
259
125
 
260
- **Typical workflow**:
261
- ```bash
262
- # Morning: Check what you were working on
263
- /specweave:progress
264
-
265
- # Shows: "Active: 0002-payments, Task 5/10 (50%)"
266
- # Shows: "Next: /specweave:do 0002 to resume at T006"
267
-
268
- /specweave:do 0002
269
- # Auto-resumes from T006
126
+ 💡 Continue with /specweave:do
270
127
  ```
271
128
 
272
- ---
273
-
274
- ## Pro Tips
275
-
276
- 1. **Shows ALL active increments** - `/specweave:progress` displays up to 2 active increments with full progress
277
- 2. **10x faster** - Uses cache instead of scanning 31 metadata files (5ms vs 50ms)
278
- 3. **Smart resume** - `/specweave:do` picks up where you left off (no task ID needed)
279
- 4. **WIP limits** - 2 active increments allowed (feature + hotfix/bug)
280
- 5. **Completion %** - P1 tasks weighted higher (they're critical path)
281
- 6. **Time tracking** - Warns if tasks are stuck (>2 hours inactive)
282
-
283
- ---
284
-
285
- ## Related Commands
286
-
287
- - `/inc` - Start new increment (auto-closes previous if ready)
288
- - `/do` - Execute tasks (auto-resumes from next incomplete)
289
- - `/validate` - Run quality checks (optional)
290
- - `/done` - Explicitly close increment (optional if `/inc` auto-closes)
291
-
292
- ---
293
-
294
- **💡 Remember**: `/progress` is your "where am I?" command. Use it anytime you need orientation!
295
-
296
- ---
297
-
298
- ## Executable Implementation
299
-
300
- ```typescript
301
- import { Task } from '@claude/types';
302
-
303
- const task = new Task('progress-check', 'Show progress for all active increments');
304
-
305
- task.run(async () => {
306
- const { MetadataManager } = await import('../../../dist/src/core/increment/metadata-manager.js');
307
- const fs = await import('fs-extra');
308
- const path = await import('path');
309
-
310
- // Step 1: Get ALL active increments (FAST via cache!)
311
- const activeIncrements = MetadataManager.getActive();
312
-
313
- // Step 2: Check if specific increment requested
314
- const requestedId = process.argv[2]?.replace(/^0+/, '').padStart(4, '0');
315
- const increments = requestedId
316
- ? activeIncrements.filter(inc => inc.id === requestedId)
317
- : activeIncrements;
318
-
319
- // Step 3: Display results
320
- console.log('\n📊 Current Progress\n');
321
-
322
- if (increments.length === 0) {
323
- if (requestedId) {
324
- console.log(`❌ Increment ${requestedId} is not active`);
325
- } else {
326
- console.log('No active increments found.\n');
327
- console.log('Recent Increments:');
328
- const allIncrements = MetadataManager.getAll()
329
- .filter(m => m.status === 'completed' || m.status === 'closed')
330
- .sort((a, b) => new Date(b.lastActivity).getTime() - new Date(a.lastActivity).getTime())
331
- .slice(0, 3);
332
-
333
- allIncrements.forEach(inc => {
334
- const age = Math.floor((Date.now() - new Date(inc.lastActivity).getTime()) / (1000 * 60 * 60 * 24));
335
- console.log(`├─ ${inc.id} (${inc.status}) - ${age} day${age === 1 ? '' : 's'} ago`);
336
- });
337
-
338
- console.log('\nNext Action: Run /specweave:increment "feature description" to start new work');
339
- }
340
- return;
341
- }
342
-
343
- // Step 4: Show progress for each active increment
344
- for (const increment of increments) {
345
- console.log(`📦 Increment: ${increment.id}`);
346
- console.log(`Status: ${increment.status}`);
347
-
348
- const started = new Date(increment.created);
349
- const lastActivity = new Date(increment.lastActivity);
350
- const ageHours = Math.floor((Date.now() - started.getTime()) / (1000 * 60 * 60));
351
- const lastActivityHours = Math.floor((Date.now() - lastActivity.getTime()) / (1000 * 60 * 60));
352
-
353
- console.log(`Started: ${ageHours} hours ago`);
354
- console.log(`Last Activity: ${lastActivityHours} hours ago`);
355
-
356
- // Try to read tasks.md for progress
357
- const incrementPath = path.default.join(process.cwd(), '.specweave/increments', increment.id);
358
- const tasksPath = path.default.join(incrementPath, 'tasks.md');
359
-
360
- if (await fs.default.pathExists(tasksPath)) {
361
- const tasksContent = await fs.default.readFile(tasksPath, 'utf-8');
362
-
363
- // Count tasks
364
- const taskLines = tasksContent.split('\n').filter(line =>
365
- line.match(/^#+\s+(T-?\d+|Task-?\d+):/i)
366
- );
367
- const completedTasks = tasksContent.split('\n').filter(line =>
368
- line.includes('[✅]') || line.includes('[x]') || line.includes('[X]')
369
- );
370
-
371
- const total = taskLines.length;
372
- const completed = completedTasks.length;
373
- const percent = total > 0 ? Math.round((completed / total) * 100) : 0;
374
-
375
- console.log(`\nTask Progress: ${completed}/${total} completed (${percent}%)`);
376
-
377
- if (total > 0) {
378
- console.log('\nTasks:');
379
- taskLines.slice(0, 10).forEach(line => {
380
- const isComplete = line.includes('[✅]') || line.includes('[x]') || line.includes('[X]');
381
- const marker = isComplete ? '✅' : '⏳';
382
- const taskName = line.replace(/^#+\s+/, '').replace(/\s*\[.*?\]\s*/, '').trim();
383
- console.log(` ${marker} ${taskName}`);
384
- });
385
-
386
- if (taskLines.length > 10) {
387
- console.log(` ... and ${taskLines.length - 10} more tasks`);
388
- }
389
- }
390
- }
391
-
392
- console.log(`\nNext Action: Run /specweave:do ${increment.id} to continue work\n`);
393
- }
129
+ ## What It Shows
394
130
 
395
- // Step 5: Show WIP limit warnings
396
- if (activeIncrements.length > 2) {
397
- console.log('⚠️ Warning: More than 2 active increments (exceeds WIP limit)');
398
- console.log('💡 Recommendation: Focus on completing one increment before starting new work\n');
399
- } else if (activeIncrements.length === 2) {
400
- console.log('✅ 2 active increments (at WIP limit, but OK)\n');
401
- } else if (activeIncrements.length === 1) {
402
- console.log('✅ 1 active increment (optimal focus)\n');
403
- }
404
- });
131
+ - **Active increments** (in-progress): Shown first with green indicator
132
+ - **Other non-completed**: planning, paused, blocked, etc.
133
+ - **Task completion**: X/Y completed (Z%)
134
+ - **Next action**: Which command to run
405
135
 
406
- export default task;
407
- ```
136
+ **Note**: Skips completed and archived increments.
@@ -1,5 +1,5 @@
1
1
  ---
2
- name: specweave-reopen
2
+ name: specweave:reopen
3
3
  description: |
4
4
  Reopen completed increments, tasks, or user stories when issues are discovered.
5
5
  Validates WIP limits, creates audit trail, and syncs to external tools.
@@ -1,5 +1,5 @@
1
1
  ---
2
- name: specweave-restore-feature
2
+ name: specweave:restore-feature
3
3
  description: Restore a feature or epic from archive back to active status
4
4
  ---
5
5
 
@@ -1,11 +1,11 @@
1
1
  ---
2
2
  name: specweave:sync-specs
3
- description: Sync only specs folder to living docs - distributes increment specs into hierarchical user stories without updating architecture, operations, or other docs
3
+ description: Sync increment specifications to living docs structure. Auto-generates feature IDs for greenfield increments (FS-XXX). Use after completing an increment to make it visible in living docs.
4
4
  ---
5
5
 
6
- # Sync Specs Only
6
+ # Sync Increment Specifications to Living Docs
7
7
 
8
- You are executing the SpecWeave specs-only sync command. This distributes increment specs specifically into the living docs specs folder using the Universal Hierarchy (Epic Feature → User Story → Task), without touching other documentation areas.
8
+ Syncs increment specs to living docs structure for stakeholder visibility. Auto-generates feature IDs for greenfield increments.
9
9
 
10
10
  ---
11
11
 
@@ -85,58 +85,30 @@ fi
85
85
 
86
86
  ---
87
87
 
88
- ## STEP 3: Execute Spec Distribution
88
+ ## STEP 3: Execute Spec Sync
89
89
 
90
- ### 3.1 Run SpecDistributor
90
+ ### 3.1 Run Sync Command
91
91
 
92
- **Execute the distribution using Node.js**:
92
+ **Execute the sync using the CLI command**:
93
93
 
94
- ```javascript
95
- // Direct execution via Node.js
96
- node -e "
97
- import('./dist/src/core/living-docs/spec-distributor.js').then(async ({ SpecDistributor }) => {
98
- const distributor = new SpecDistributor(process.cwd());
94
+ ```typescript
95
+ import { syncSpecs } from './dist/src/cli/commands/sync-specs.js';
99
96
 
100
- console.log('🚀 Starting spec distribution...');
101
- console.log(' 📄 Reading spec.md from increment ${INCREMENT_ID}');
97
+ // Parse arguments
98
+ const args = process.argv.slice(2); // e.g., ['0040', '--dry-run']
102
99
 
103
- try {
104
- const result = await distributor.distribute('${INCREMENT_ID}');
105
-
106
- console.log('');
107
- console.log('✅ Distribution successful!');
108
- console.log(' 📊 Total stories: ' + result.totalStories);
109
- console.log(' 📁 Total files created: ' + result.totalFiles);
110
- console.log(' 🎯 Feature ID: ' + result.specId);
111
-
112
- if (result.epicPath) {
113
- console.log(' 📂 Feature path: ' + result.epicPath);
114
- }
115
-
116
- if (result.userStoryPaths && result.userStoryPaths.length > 0) {
117
- console.log(' 📝 User stories created:');
118
- result.userStoryPaths.forEach(p => console.log(' • ' + p));
119
- }
120
-
121
- if (result.warnings && result.warnings.length > 0) {
122
- console.log('');
123
- console.log('⚠️ Warnings:');
124
- result.warnings.forEach(w => console.log(' • ' + w));
125
- }
126
-
127
- // Update acceptance criteria status based on completed tasks
128
- console.log('');
129
- console.log('📊 Updating acceptance criteria status...');
130
- await distributor.updateAcceptanceCriteriaStatus('${INCREMENT_ID}');
131
-
132
- } catch (error) {
133
- console.error('❌ Distribution failed:', error.message);
134
- process.exit(1);
135
- }
136
- });
137
- "
100
+ // Execute sync
101
+ await syncSpecs(args);
138
102
  ```
139
103
 
104
+ **This will**:
105
+ 1. Auto-generate feature ID for greenfield increments (FS-040, FS-041, etc.)
106
+ 2. Parse spec.md for user stories and acceptance criteria
107
+ 3. Create living docs structure:
108
+ - `.specweave/docs/internal/specs/_features/FS-XXX/FEATURE.md`
109
+ - `.specweave/docs/internal/specs/specweave/FS-XXX/README.md`
110
+ - `.specweave/docs/internal/specs/specweave/FS-XXX/us-*.md`
111
+
140
112
  ---
141
113
 
142
114
  ## STEP 4: Report Distribution Results