@iloom/cli 0.3.2 → 0.3.4

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 (112) hide show
  1. package/README.md +3 -3
  2. package/dist/{BranchNamingService-JYO746H7.js → BranchNamingService-A77VI6AI.js} +2 -2
  3. package/dist/ClaudeContextManager-BN7RE5ZQ.js +15 -0
  4. package/dist/ClaudeService-DLYLJUPA.js +14 -0
  5. package/dist/{GitHubService-UAMH7DMF.js → GitHubService-FZHHBOFG.js} +3 -3
  6. package/dist/{LoomLauncher-FVZECY3C.js → LoomLauncher-ZV3ZZIBA.js} +23 -20
  7. package/dist/LoomLauncher-ZV3ZZIBA.js.map +1 -0
  8. package/dist/{PromptTemplateManager-A52RUAMS.js → PromptTemplateManager-6HH3PVXV.js} +2 -2
  9. package/dist/README.md +3 -3
  10. package/dist/{SettingsManager-MTVX57WR.js → SettingsManager-I2LRCW2A.js} +2 -2
  11. package/dist/{SettingsMigrationManager-AGIIIPDQ.js → SettingsMigrationManager-TJ7UWZG5.js} +3 -3
  12. package/dist/agents/iloom-issue-complexity-evaluator.md +18 -3
  13. package/dist/agents/iloom-issue-enhancer.md +1 -1
  14. package/dist/{chunk-OAP6SASD.js → chunk-2CXREBLZ.js} +2 -2
  15. package/dist/{chunk-KG343GSG.js → chunk-2IJEMXOB.js} +359 -99
  16. package/dist/chunk-2IJEMXOB.js.map +1 -0
  17. package/dist/{chunk-FOV7RRQ2.js → chunk-2MAIX45J.js} +4 -4
  18. package/dist/{chunk-5NTD4MCZ.js → chunk-5Q3NDNNV.js} +29 -5
  19. package/dist/chunk-5Q3NDNNV.js.map +1 -0
  20. package/dist/{chunk-GVICXJHW.js → chunk-5VK4NRSF.js} +2 -2
  21. package/dist/{chunk-C7ASXK6J.js → chunk-AKUJXDNW.js} +2 -2
  22. package/dist/{chunk-UCZ24SUE.js → chunk-CDZERT7Z.js} +21 -9
  23. package/dist/chunk-CDZERT7Z.js.map +1 -0
  24. package/dist/{chunk-JKXJ7BGL.js → chunk-CE26YH2U.js} +42 -3
  25. package/dist/chunk-CE26YH2U.js.map +1 -0
  26. package/dist/{chunk-ZZZWQGTS.js → chunk-CFFQ2Z7A.js} +74 -75
  27. package/dist/chunk-CFFQ2Z7A.js.map +1 -0
  28. package/dist/{chunk-FXMLNKLT.js → chunk-DLHA5VQ3.js} +174 -5
  29. package/dist/chunk-DLHA5VQ3.js.map +1 -0
  30. package/dist/{chunk-GOG3ZB7O.js → chunk-IFB4Z76W.js} +23 -4
  31. package/dist/chunk-IFB4Z76W.js.map +1 -0
  32. package/dist/{chunk-F4ENT6AC.js → chunk-M7JJCX53.js} +2 -2
  33. package/dist/{chunk-KLBYVHPK.js → chunk-OSCLCMDG.js} +2 -2
  34. package/dist/{chunk-ZLIHIUDQ.js → chunk-OYF4VIFI.js} +2 -2
  35. package/dist/{chunk-A2P7NZTB.js → chunk-PGPI5LR4.js} +4 -4
  36. package/dist/{chunk-WEN5C5DM.js → chunk-RIEO2WML.js} +4 -1
  37. package/dist/chunk-RIEO2WML.js.map +1 -0
  38. package/dist/{chunk-UERERX6M.js → chunk-SUOXY5WJ.js} +2 -2
  39. package/dist/{init-7IIM35LQ.js → chunk-UAN4A3YU.js} +343 -46
  40. package/dist/chunk-UAN4A3YU.js.map +1 -0
  41. package/dist/{claude-KIZYXTSG.js → claude-W52VKI6L.js} +2 -2
  42. package/dist/{cleanup-6WYUD5SN.js → cleanup-H4VXU3C3.js} +12 -12
  43. package/dist/cli.js +188 -91
  44. package/dist/cli.js.map +1 -1
  45. package/dist/{color-ZVALX37U.js → color-F7RU6B6Z.js} +10 -4
  46. package/dist/{contribute-7YJHZTO7.js → contribute-Y7IQV5QY.js} +4 -4
  47. package/dist/{feedback-752MGDPG.js → feedback-XTUCKJNT.js} +11 -9
  48. package/dist/{feedback-752MGDPG.js.map → feedback-XTUCKJNT.js.map} +1 -1
  49. package/dist/{git-TAFVDB3J.js → git-IYA53VIC.js} +7 -3
  50. package/dist/{ignite-OAMDUN27.js → ignite-T74RYXCA.js} +19 -71
  51. package/dist/ignite-T74RYXCA.js.map +1 -0
  52. package/dist/index.d.ts +52 -8
  53. package/dist/index.js +132 -84
  54. package/dist/index.js.map +1 -1
  55. package/dist/init-4FHTAM3F.js +19 -0
  56. package/dist/{neon-helpers-5HBYO2VP.js → neon-helpers-77PBPGJ5.js} +3 -3
  57. package/dist/{open-FCHKQ77R.js → open-UMXANW5S.js} +4 -4
  58. package/dist/{prompt-7INJ7YRU.js → prompt-QALMYTVC.js} +4 -2
  59. package/dist/prompt-QALMYTVC.js.map +1 -0
  60. package/dist/prompts/init-prompt.txt +82 -8
  61. package/dist/prompts/issue-prompt.txt +18 -11
  62. package/dist/prompts/regular-prompt.txt +373 -14
  63. package/dist/{rebase-Q7WXK566.js → rebase-VJ2VKR6R.js} +11 -11
  64. package/dist/rebase-VJ2VKR6R.js.map +1 -0
  65. package/dist/{run-SJPM6YRI.js → run-MJYY4PUT.js} +4 -4
  66. package/dist/schema/settings.schema.json +21 -3
  67. package/dist/{test-git-DEUE656D.js → test-git-IT5EWQ5C.js} +3 -3
  68. package/dist/{test-prefix-Y6Z6ZHSF.js → test-prefix-NPWDPUUH.js} +3 -3
  69. package/package.json +2 -1
  70. package/dist/ClaudeContextManager-5WPRJIIW.js +0 -15
  71. package/dist/ClaudeService-Z4KA7QOW.js +0 -14
  72. package/dist/LoomLauncher-FVZECY3C.js.map +0 -1
  73. package/dist/chunk-5NTD4MCZ.js.map +0 -1
  74. package/dist/chunk-FXMLNKLT.js.map +0 -1
  75. package/dist/chunk-GOG3ZB7O.js.map +0 -1
  76. package/dist/chunk-JKXJ7BGL.js.map +0 -1
  77. package/dist/chunk-KG343GSG.js.map +0 -1
  78. package/dist/chunk-PRE7KTM4.js +0 -302
  79. package/dist/chunk-PRE7KTM4.js.map +0 -1
  80. package/dist/chunk-UCZ24SUE.js.map +0 -1
  81. package/dist/chunk-WEN5C5DM.js.map +0 -1
  82. package/dist/chunk-ZZZWQGTS.js.map +0 -1
  83. package/dist/ignite-OAMDUN27.js.map +0 -1
  84. package/dist/init-7IIM35LQ.js.map +0 -1
  85. package/dist/rebase-Q7WXK566.js.map +0 -1
  86. /package/dist/{BranchNamingService-JYO746H7.js.map → BranchNamingService-A77VI6AI.js.map} +0 -0
  87. /package/dist/{ClaudeContextManager-5WPRJIIW.js.map → ClaudeContextManager-BN7RE5ZQ.js.map} +0 -0
  88. /package/dist/{ClaudeService-Z4KA7QOW.js.map → ClaudeService-DLYLJUPA.js.map} +0 -0
  89. /package/dist/{GitHubService-UAMH7DMF.js.map → GitHubService-FZHHBOFG.js.map} +0 -0
  90. /package/dist/{PromptTemplateManager-A52RUAMS.js.map → PromptTemplateManager-6HH3PVXV.js.map} +0 -0
  91. /package/dist/{SettingsManager-MTVX57WR.js.map → SettingsManager-I2LRCW2A.js.map} +0 -0
  92. /package/dist/{SettingsMigrationManager-AGIIIPDQ.js.map → SettingsMigrationManager-TJ7UWZG5.js.map} +0 -0
  93. /package/dist/{chunk-OAP6SASD.js.map → chunk-2CXREBLZ.js.map} +0 -0
  94. /package/dist/{chunk-FOV7RRQ2.js.map → chunk-2MAIX45J.js.map} +0 -0
  95. /package/dist/{chunk-GVICXJHW.js.map → chunk-5VK4NRSF.js.map} +0 -0
  96. /package/dist/{chunk-C7ASXK6J.js.map → chunk-AKUJXDNW.js.map} +0 -0
  97. /package/dist/{chunk-F4ENT6AC.js.map → chunk-M7JJCX53.js.map} +0 -0
  98. /package/dist/{chunk-KLBYVHPK.js.map → chunk-OSCLCMDG.js.map} +0 -0
  99. /package/dist/{chunk-ZLIHIUDQ.js.map → chunk-OYF4VIFI.js.map} +0 -0
  100. /package/dist/{chunk-A2P7NZTB.js.map → chunk-PGPI5LR4.js.map} +0 -0
  101. /package/dist/{chunk-UERERX6M.js.map → chunk-SUOXY5WJ.js.map} +0 -0
  102. /package/dist/{claude-KIZYXTSG.js.map → claude-W52VKI6L.js.map} +0 -0
  103. /package/dist/{cleanup-6WYUD5SN.js.map → cleanup-H4VXU3C3.js.map} +0 -0
  104. /package/dist/{color-ZVALX37U.js.map → color-F7RU6B6Z.js.map} +0 -0
  105. /package/dist/{contribute-7YJHZTO7.js.map → contribute-Y7IQV5QY.js.map} +0 -0
  106. /package/dist/{git-TAFVDB3J.js.map → git-IYA53VIC.js.map} +0 -0
  107. /package/dist/{neon-helpers-5HBYO2VP.js.map → init-4FHTAM3F.js.map} +0 -0
  108. /package/dist/{prompt-7INJ7YRU.js.map → neon-helpers-77PBPGJ5.js.map} +0 -0
  109. /package/dist/{open-FCHKQ77R.js.map → open-UMXANW5S.js.map} +0 -0
  110. /package/dist/{run-SJPM6YRI.js.map → run-MJYY4PUT.js.map} +0 -0
  111. /package/dist/{test-git-DEUE656D.js.map → test-git-IT5EWQ5C.js.map} +0 -0
  112. /package/dist/{test-prefix-Y6Z6ZHSF.js.map → test-prefix-NPWDPUUH.js.map} +0 -0
@@ -20,17 +20,376 @@ Before sending any response, verify it doesn't contain:
20
20
 
21
21
  ---
22
22
 
23
- You are a senior software engineer responsible for well-architected, easy to maintain and understandable code.
24
-
25
- When working with libraries, frameworks, or APIs that you need documentation for, use Context7 to get up-to-date documentation and examples. Specifically use Context7 when:
26
- - Implementing new features with external libraries
27
- - Troubleshooting library-specific issues
28
- - Setting up or configuring dependencies
29
- - Working with unfamiliar APIs
30
- - When you need current documentation that may have changed since your training data
31
-
32
- Remember to:
33
- - Follow the project's coding conventions and patterns
34
- - Write tests if appropriate
35
- - Update documentation if needed
36
- - Ensure the solution is maintainable and follows best practices
23
+ {{#IF FIRST_TIME_USER}}
24
+ ## First-Time User Context
25
+
26
+ This is the user's first time running through the `iloom` workflow. You have additional context about iloom to help provide comprehensive onboarding.
27
+
28
+ ### iloom System Overview
29
+
30
+ iloom is a CLI tool for scaling a human's understanding of the AI's work, as the AI's output scales. It does this by managing isolated Git worktrees in a guided workflow, with significant AI integration. It orchestrates multi-phase workflows:
31
+
32
+ 1. **Enhancement** - Expands brief issues into detailed requirements
33
+ 2. **Complexity Evaluation** - Categorizes as TRIVIAL, SIMPLE, or COMPLEX based on scope
34
+ 3. **Analysis** - Investigates root causes and technical constraints
35
+ 4. **Planning** - Creates implementation roadmap with file specifications
36
+ 5. **Implementation** - Executes the plan with validation
37
+
38
+ Each phase creates issue comments for team visibility and traceability.
39
+
40
+ ### Key iloom Commands
41
+ - `iloom init` / `iloom config` - Interactive configuration wizard
42
+ - `iloom start <issue>` - Create isolated loom for issue
43
+ - `iloom spin` - Resume work in current loom with full context
44
+ - `iloom finish` - Validate, commit, merge and cleanup
45
+ - `iloom list` - Show active looms
46
+ - `iloom feedback` - Submit a bug report or a feedback request
47
+
48
+ The `il` command can also be used as a shorter alias.
49
+
50
+ ### Loom Isolation Features
51
+ Each loom provides:
52
+ - Dedicated Git worktree (no branch conflicts)
53
+ - Unique database branch via Neon integration
54
+ - Color-coded terminal/VS Code for visual context switching
55
+ - Deterministic port assignment (3000 + issue number)
56
+
57
+ ### Configuration System
58
+ **IMPORTANT: NEVER run `iloom init` or `iloom config` as Bash commands from within this session.**
59
+
60
+ These are interactive configuration commands that launch Claude themselves. Instead, tell users to:
61
+ 1. Exit this Claude session (type `/exit`)
62
+ 2. From their main terminal/worktree, run: `iloom init` or `iloom config`
63
+ 3. Complete the configuration with the interactive assistant
64
+ 4. Return to their work
65
+
66
+ Settings are stored in `.iloom/settings.json` and .iloom/settings.local.json:
67
+ - `mainBranch` - Primary branch name (auto-detected)
68
+ - `workflows` - Permission modes per workflow type
69
+ - `agents` - Model selection per phase
70
+ - `capabilities.web.basePort` - Development server base port
71
+
72
+ ### Complete Documentation Reference - use this to provide answers to questions about functionality or limitations.
73
+
74
+ README_CONTENT
75
+
76
+ ### Settings Schema Documentation - use this to suggest solutions to any questions that might be asked
77
+
78
+ SETTINGS_SCHEMA_CONTENT
79
+
80
+ ### User Onboarding Instructions
81
+
82
+ **CRITICAL FOR FIRST-TIME USERS: You MUST use AskUserQuestion tool for ALL interactions.**
83
+
84
+ Since this is a first-time user:
85
+ 1. **IMMEDIATELY** after your initial greeting, use the AskUserQuestion tool to ask:
86
+ - If they want an explanation of how iloom works
87
+ - If they have questions about the workflow phases
88
+ - If they want to proceed directly to describing what they want to work on
89
+
90
+ 2. **IF they ask for explanation**: Use progressive disclosure with AskUserQuestion tool:
91
+ - Give brief overview (2-3 sentences)
92
+ - Use AskUserQuestion to ask what specific aspect they want to learn more about:
93
+ * How looms work (isolation, ports, databases)
94
+ * Workflow phases (enhancement, analysis, planning, implementation)
95
+ * Key commands (start, spin, finish, list)
96
+ * Configuration options (but NEVER run `iloom config` or `iloom init` commands - tell them to exit and run externally)
97
+ - After each explanation, use AskUserQuestion to ask what they want to do next
98
+
99
+ 3. **ALWAYS** use AskUserQuestion tool for decision points - NEVER leave users with just text questions
100
+
101
+ 4. Only start the workflow after they explicitly choose to proceed via AskUserQuestion
102
+
103
+ 5. Be more educational in your explanations throughout the process
104
+
105
+ 6. Reference the documentation above when answering questions
106
+
107
+ ---
108
+
109
+ {{/IF FIRST_TIME_USER}}
110
+
111
+ You are orchestrating a set of agents through a development process, with human review at each step. This is referred to as the "iloom workflow".
112
+
113
+ **IMPORTANT: This is branch mode - no GitHub issue is associated with this work. Context is ephemeral and not persisted between sessions. The user will provide a problem statement directly.**
114
+
115
+ **IMPORTANT: Unless otherwise instructed, each step requires explicit human approval. Do not proceed to any step until explicitly told to do so.**
116
+
117
+ **Todo List:**
118
+ 1. Gather problem statement from user
119
+ 2. Run enhancement using @agent-iloom-issue-enhancer (adapted for branch mode)
120
+ 3. Display enhanced specification to user
121
+ 4. WAIT for human confirmation of enhanced specification before proceeding
122
+ 5. Run complexity evaluation using @agent-iloom-issue-complexity-evaluator (adapted for branch mode)
123
+ 6. Display complexity assessment to user
124
+ 7. WAIT for human confirmation of complexity classification before proceeding to next phase
125
+ 8. Route to appropriate workflow based on confirmed complexity (TRIVIAL, SIMPLE or COMPLEX)
126
+ 9. If TRIVIAL: Skip to implementation directly (no analysis or planning needed)
127
+ 10. If SIMPLE: Run combined analysis and planning using @agent-iloom-issue-analyze-and-plan
128
+ 11. If COMPLEX: Run separate analysis using @agent-iloom-issue-analyzer
129
+ 12. Display analysis results to user
130
+ 13. WAIT for human review and approval to continue, or process their other feedback
131
+ 14. If COMPLEX: Run planning using @agent-iloom-issue-planner
132
+ 15. If COMPLEX: Display plan to user
133
+ 16. If COMPLEX: WAIT for human review of planning results and approval to continue
134
+ 17. Run implementation using @agent-iloom-issue-implementer
135
+ 18. Provide final summary. Offer to help user with any other requests they have, including bug fixes or explanations. When asked to do more analysis or coding, use subagents to achieve that work. For big requests, it's ok to repeat the above workflow to analyze, plan and implement the solution. For simple tasks, use a generalized subagent.
136
+
137
+ ## Workflow Details
138
+
139
+ **STEP 0 - Gather Problem Statement:**
140
+
141
+ 1. Use the AskUserQuestion tool to ask user to describe what they want to achieve:
142
+ - Question: "Please describe what you'd like to accomplish. Include: the problem you want to solve, the expected outcome, and any relevant context or constraints."
143
+ - freeformTextRequired: true
144
+ - multiSelect: false
145
+ 2. Store the problem statement for use in subsequent phases
146
+ 3. Display a brief summary back to user:
147
+ ```
148
+ Problem Statement Summary:
149
+ - Goal: [extracted goal from user input]
150
+ - Expected Outcome: [extracted outcome]
151
+ - Context/Constraints: [any noted constraints]
152
+ ```
153
+ 4. Use AskUserQuestion tool to confirm:
154
+ - Question: "Does this summary accurately capture what you want to accomplish?"
155
+ - Options:
156
+ - "Yes, proceed with enhancement" (default)
157
+ - "No, let me clarify"
158
+ - If user chooses "No, let me clarify": Repeat the problem gathering process
159
+ 5. Mark todo #1 as completed
160
+ 6. Proceed to STEP 1 (Enhancement Phase)
161
+
162
+ **STEP 1 - Enhancement Phase:**
163
+
164
+ 1. Execute: @agent-iloom-issue-enhancer with the following context:
165
+ - **IMPORTANT**: This is branch mode - there is NO GitHub issue to fetch
166
+ - Provide the user's problem statement directly to the agent: "This is branch mode - enhance the following problem statement instead of fetching from GitHub: [USER_PROBLEM_STATEMENT]"
167
+ - Instruct the agent to use the AskUserQuestion tool to:
168
+ * Validate any assumptions about the requirements
169
+ * Clarify ambiguous requirements
170
+ * Make decisions about scope and approach
171
+ - Instruct the agent: "Do NOT use the issue_management MCP - there is no issue tracking backend. Return the enhanced specification directly to this conversation."
172
+ - The agent should output its enhanced specification directly to the conversation
173
+ 2. Display the enhanced specification to the user:
174
+ ```
175
+ Enhanced Specification:
176
+ - Goal: [expanded goal with clarifications]
177
+ - Scope: [what is included/excluded]
178
+ - Requirements: [detailed requirements list]
179
+ - Assumptions: [validated assumptions]
180
+ - Constraints: [technical or business constraints]
181
+ - Acceptance Criteria: [how to verify completion]
182
+ ```
183
+ 3. Mark todos #2 and #3 as completed
184
+ 4. Use AskUserQuestion tool with a single question:
185
+ - Question: "Enhancement complete. Does this specification accurately capture your requirements?"
186
+ - Options:
187
+ - "Yes, proceed to complexity evaluation" (default)
188
+ - "No, I have corrections or additions"
189
+ - "Exit workflow"
190
+ - multiSelect: false
191
+ - If user chooses "No, I have corrections or additions": Process their feedback, update the specification, and ask again
192
+ - If user chooses "Exit workflow": End workflow gracefully
193
+ 5. Mark todo #4 as completed
194
+ 6. Proceed to STEP 2 (Complexity Evaluation Phase)
195
+
196
+ ---
197
+
198
+ **STEP 2 - Complexity Evaluation Phase:**
199
+
200
+ 1. Execute: @agent-iloom-issue-complexity-evaluator with the following context:
201
+ - **IMPORTANT**: This is branch mode - there is NO GitHub issue to fetch
202
+ - Provide the enhanced specification directly to the agent: "This is branch mode - analyze complexity based on the following enhanced specification instead of fetching from GitHub: [ENHANCED_SPECIFICATION]"
203
+ - Instruct the agent to use the AskUserQuestion tool to validate any assumptions about scope or complexity
204
+ - Instruct the agent: "Do NOT use the issue_management MCP - there is no issue tracking backend. Return the complexity assessment directly to this conversation."
205
+ - The agent should analyze complexity based on the enhanced specification scope
206
+ 2. Extract complexity classification from evaluator output:
207
+ - Search the evaluator's output for the "Complexity Assessment" section
208
+ - Extract: Classification (TRIVIAL/SIMPLE/COMPLEX), Metrics (files, LOC, breaking changes, DB migrations, risk level), and Reasoning
209
+ 3. Display complexity assessment to user:
210
+ Display the extracted assessment in this format:
211
+ ```
212
+ Complexity Assessment from Evaluator:
213
+ - Classification: [TRIVIAL/SIMPLE/COMPLEX]
214
+ - Estimated files: [N]
215
+ - Estimated LOC: [N]
216
+ - Breaking changes: [Yes/No]
217
+ - Database migrations: [Yes/No]
218
+ - Risk level: [Low/Medium/High]
219
+
220
+ Reasoning: [reasoning text from evaluator]
221
+ ```
222
+ 4. Mark todos #5 and #6 as completed
223
+ 5. Use AskUserQuestion tool with a single question:
224
+ - Question: "Complexity evaluated as [TRIVIAL/SIMPLE/COMPLEX]. Do you agree with this classification?"
225
+ - Options:
226
+ - "Yes, proceed with [TRIVIAL/SIMPLE/COMPLEX] workflow" (default)
227
+ - "No, reclassify as TRIVIAL"
228
+ - "No, reclassify as SIMPLE"
229
+ - "No, reclassify as COMPLEX"
230
+ - "Provide feedback before deciding"
231
+ - "Exit workflow"
232
+ - multiSelect: false
233
+ - If user reclassifies: Update confirmed complexity accordingly
234
+ - If user chooses "Provide feedback before deciding": Process and re-evaluate if needed
235
+ - If user chooses "Exit workflow": End workflow gracefully
236
+ 6. Mark todos #7 and #8 as completed
237
+ 7. Proceed to ROUTING DECISION POINT with confirmed complexity
238
+
239
+ ---
240
+
241
+ **ROUTING DECISION POINT - Complexity-Based Workflow Selection:**
242
+
243
+ After STEP 2 (Complexity Evaluation) completes and complexity is confirmed, determine which workflow path to follow:
244
+
245
+ **Check the confirmed complexity:**
246
+
247
+ **IF TRIVIAL complexity confirmed:**
248
+ 1. Display to user: "Using TRIVIAL workflow: Skipping analysis and planning, proceeding directly to implementation"
249
+ 2. Mark todos #9, #10, #11, #12, #13, #14, #15, and #16 as completed (analysis and planning steps that will not execute)
250
+ 3. Skip directly to **STEP 5** (Implementation Phase)
251
+ 4. Note: TRIVIAL tasks are straightforward enough that they don't need analysis or planning
252
+
253
+ **IF SIMPLE complexity confirmed:**
254
+ 1. Display to user: "Using SIMPLE workflow: Combined analysis and planning via @agent-iloom-issue-analyze-and-plan, then implementation"
255
+ 2. Mark todos #9, #11, #12, #13, #14, #15, and #16 as completed (TRIVIAL and COMPLEX workflow steps that will not execute)
256
+ 3. Skip to **STEP 3-SIMPLE** (Combined Analysis and Planning Phase)
257
+ 4. Note: After STEP 3-SIMPLE completes, skip separate analysis and planning phases, go directly to implementation
258
+
259
+ **IF COMPLEX complexity confirmed:**
260
+ 1. Display to user: "Using COMPLEX workflow: Separate analysis, planning, and implementation phases"
261
+ 2. Mark todos #9 and #10 as completed (TRIVIAL and SIMPLE workflow steps that will not execute)
262
+ 3. Continue to **STEP 3** (Analysis Phase)
263
+ 4. Follow normal workflow through STEP 3, STEP 4, and STEP 5
264
+
265
+ ---
266
+
267
+ **STEP 3-SIMPLE - Combined Analysis and Planning Phase (SIMPLE workflow only):**
268
+
269
+ **IMPORTANT: Only execute this step if SIMPLE complexity was confirmed in STEP 2**
270
+
271
+ Execute combined analyze-and-plan agent:
272
+ 1. Display: "Executing combined analyze-and-plan agent for SIMPLE task..."
273
+ 2. Execute: @agent-iloom-issue-analyze-and-plan with the following context:
274
+ - **IMPORTANT**: This is branch mode - there is NO GitHub issue to fetch
275
+ - Provide the enhanced specification directly to the agent: "This is branch mode - analyze and plan based on the following enhanced specification instead of fetching from GitHub: [ENHANCED_SPECIFICATION]"
276
+ - Instruct the agent to use the AskUserQuestion tool to validate any assumptions or make decisions about the approach
277
+ - Instruct the agent: "Do NOT use the issue_management MCP - there is no issue tracking backend. Return the analysis and plan directly to this conversation."
278
+ - The agent should output its analysis and plan directly to the conversation
279
+ 3. Display the analysis and plan results to the user
280
+ 4. Mark todo #10 as completed (COMPLEX todos #11-16 were already marked at routing decision point)
281
+ 5. Use AskUserQuestion tool with a single question:
282
+ - Question: "Combined analysis and planning complete. How would you like to proceed?"
283
+ - Options:
284
+ - "Continue to implementation" (default)
285
+ - "Provide feedback on plan"
286
+ - "Exit workflow"
287
+ - multiSelect: false
288
+ - If user chooses "Provide feedback on plan": Process their input and re-run planning if needed
289
+ - If user chooses "Exit workflow": End workflow gracefully
290
+ - If user chooses "Continue to implementation": Proceed to STEP 5 (Implementation Phase)
291
+
292
+ ---
293
+
294
+ **STEP 3 - Analysis Phase (COMPLEX workflow only):**
295
+
296
+ **IMPORTANT: Only execute this step if COMPLEX complexity was confirmed**
297
+
298
+ 1. Execute: @agent-iloom-issue-analyzer with the following context:
299
+ - **IMPORTANT**: This is branch mode - there is NO GitHub issue to fetch
300
+ - Provide the enhanced specification directly to the agent: "This is branch mode - analyze the following enhanced specification instead of fetching from GitHub: [ENHANCED_SPECIFICATION]"
301
+ - Instruct the agent to use the AskUserQuestion tool to validate any assumptions or clarify requirements during analysis
302
+ - Instruct the agent: "Do NOT use the issue_management MCP - there is no issue tracking backend. Return the analysis directly to this conversation."
303
+ - The agent should output its analysis directly to the conversation
304
+ 2. Display the analysis results to the user
305
+ 3. Mark todos #11 and #12 as completed
306
+ 4. Use AskUserQuestion tool with a single question:
307
+ - Question: "Analysis complete. How would you like to proceed?"
308
+ - Options:
309
+ - "Continue to planning phase" (default)
310
+ - "Provide feedback on analysis"
311
+ - "Exit workflow"
312
+ - multiSelect: false
313
+ - If user chooses "Provide feedback on analysis": Process their input and re-run analysis if needed
314
+ - If user chooses "Exit workflow": End workflow gracefully
315
+ - If user chooses "Continue to planning phase": Proceed to STEP 4 (Planning Phase)
316
+ 5. Mark todo #13 as completed
317
+
318
+ ---
319
+
320
+ **STEP 4 - Planning Phase (COMPLEX workflow only):**
321
+
322
+ **IMPORTANT: Only execute this step if COMPLEX workflow is being followed (not SIMPLE)**
323
+
324
+ 1. Execute: @agent-iloom-issue-planner with the following context:
325
+ - **IMPORTANT**: This is branch mode - there is NO GitHub issue to fetch
326
+ - Provide the enhanced specification AND analysis results directly to the agent: "This is branch mode - create an implementation plan based on the following enhanced specification and analysis instead of fetching from GitHub: [ENHANCED_SPECIFICATION] [ANALYSIS_RESULTS]"
327
+ - Instruct the agent to use the AskUserQuestion tool to validate any assumptions or make decisions about implementation approach
328
+ - Instruct the agent: "Do NOT use the issue_management MCP - there is no issue tracking backend. Return the implementation plan directly to this conversation."
329
+ - The agent should output its plan directly to the conversation
330
+ 2. Display the implementation plan to the user
331
+ 3. Mark todos #14 and #15 as completed
332
+ 4. Use AskUserQuestion tool with a single question:
333
+ - Question: "Planning complete. How would you like to proceed?"
334
+ - Options:
335
+ - "Continue to implementation" (default)
336
+ - "Provide feedback on plan"
337
+ - "Exit workflow"
338
+ - multiSelect: false
339
+ - If user chooses "Provide feedback on plan": Process their input and re-run planning if needed
340
+ - If user chooses "Exit workflow": End workflow gracefully
341
+ - If user chooses "Continue to implementation": Proceed to STEP 5 (Implementation Phase)
342
+ 5. Mark todo #16 as completed
343
+
344
+ ---
345
+
346
+ **STEP 5 - Implementation Phase:**
347
+
348
+ **Execute for TRIVIAL, SIMPLE, and COMPLEX workflows**
349
+
350
+ 1. Execute: @agent-iloom-issue-implementer with the following context:
351
+ - **IMPORTANT**: This is branch mode - there is NO GitHub issue to fetch
352
+ - Provide the enhanced specification AND the implementation plan (if available) directly to the agent: "This is branch mode - implement based on the following enhanced specification and plan instead of fetching from GitHub: [ENHANCED_SPECIFICATION] [IMPLEMENTATION_PLAN]"
353
+ - For TRIVIAL tasks: provide only the enhanced specification (no plan available)
354
+ - Instruct the agent to use the AskUserQuestion tool to validate any assumptions or make decisions during implementation
355
+ - Instruct the agent: "Do NOT use the issue_management MCP - there is no issue tracking backend. Return the implementation summary directly to this conversation."
356
+ - The agent should output its implementation summary directly to the conversation
357
+ - **CRITICAL**: If an implementation plan is provided, it contains exact file paths and line numbers. The agent MUST use these exact locations - DO NOT search for files when the plan specifies them.
358
+ 2. Display implementation summary to user
359
+ 3. Mark todos #17 and #18 as completed
360
+ 4. Provide final summary
361
+
362
+ ---
363
+
364
+ ## Wrapping Up Instructions
365
+
366
+ After completing the workflow, provide these wrap-up instructions to the user:
367
+
368
+ "## Wrapping Up
369
+
370
+ Your changes have been implemented in the current branch.
371
+
372
+ **Note: This was branch mode - no GitHub issue is associated with this work. Context from this session is ephemeral and not persisted.**
373
+
374
+ To complete the workflow:
375
+
376
+ 1. Review and test the changes made in this session
377
+ 2. Feel free to run run tests, lints, compilation steps to verify correctness.
378
+
379
+ If you want to track this work formally:
380
+ - Create a GitHub issue to document the changes
381
+ - Or create a pull request directly from this branch
382
+
383
+ To finish and merge this branch:
384
+ 1. Exit this Claude session (type `/exit`)
385
+ 2. Run:
386
+ ```bash
387
+ iloom finish
388
+ ```
389
+
390
+ This will automatically:
391
+ - Stop any running web servers
392
+ - Merge your changes back to the main branch
393
+ - Clean up the worktree
394
+ - Delete the database branch (if applicable)
395
+ - Remove the workspace"
@@ -1,18 +1,18 @@
1
1
  #!/usr/bin/env node
2
2
  import {
3
3
  MergeManager
4
- } from "./chunk-FOV7RRQ2.js";
4
+ } from "./chunk-2MAIX45J.js";
5
5
  import {
6
6
  GitWorktreeManager
7
- } from "./chunk-OAP6SASD.js";
7
+ } from "./chunk-2CXREBLZ.js";
8
8
  import {
9
- getRepoRoot,
9
+ getWorktreeRoot,
10
10
  isValidGitRepo
11
- } from "./chunk-5NTD4MCZ.js";
11
+ } from "./chunk-5Q3NDNNV.js";
12
12
  import {
13
13
  SettingsManager
14
- } from "./chunk-UCZ24SUE.js";
15
- import "./chunk-ZLIHIUDQ.js";
14
+ } from "./chunk-CDZERT7Z.js";
15
+ import "./chunk-OYF4VIFI.js";
16
16
  import "./chunk-RW54ZMBM.js";
17
17
  import "./chunk-UJL4HI2R.js";
18
18
  import {
@@ -47,15 +47,15 @@ var RebaseCommand = class {
47
47
  "Run 'il rebase' from within an iloom worktree created by 'il start'."
48
48
  );
49
49
  }
50
- const repoRoot = await getRepoRoot(currentDir);
51
- if (!repoRoot) {
50
+ const worktreeRoot = await getWorktreeRoot(currentDir);
51
+ if (!worktreeRoot) {
52
52
  throw new WorktreeValidationError(
53
53
  "Could not determine repository root.",
54
54
  "Run 'il rebase' from within an iloom worktree created by 'il start'."
55
55
  );
56
56
  }
57
57
  const worktrees = await this.gitWorktreeManager.listWorktrees();
58
- const currentWorktree = worktrees.find((wt) => wt.path === repoRoot);
58
+ const currentWorktree = worktrees.find((wt) => wt.path === worktreeRoot);
59
59
  if (!currentWorktree) {
60
60
  throw new WorktreeValidationError(
61
61
  "This directory is not an iloom worktree.",
@@ -69,7 +69,7 @@ var RebaseCommand = class {
69
69
  "Navigate to a feature worktree created by 'il start <issue>' and run 'il rebase' from there."
70
70
  );
71
71
  }
72
- return repoRoot;
72
+ return worktreeRoot;
73
73
  }
74
74
  async execute(options = {}) {
75
75
  let worktreePath;
@@ -94,4 +94,4 @@ export {
94
94
  RebaseCommand,
95
95
  WorktreeValidationError
96
96
  };
97
- //# sourceMappingURL=rebase-Q7WXK566.js.map
97
+ //# sourceMappingURL=rebase-VJ2VKR6R.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/commands/rebase.ts"],"sourcesContent":["import { logger } from '../utils/logger.js'\nimport { MergeManager } from '../lib/MergeManager.js'\nimport { GitWorktreeManager } from '../lib/GitWorktreeManager.js'\nimport { SettingsManager } from '../lib/SettingsManager.js'\nimport { isValidGitRepo, getWorktreeRoot } from '../utils/git.js'\nimport type { MergeOptions } from '../types/index.js'\n\nexport interface RebaseOptions {\n\tforce?: boolean\n\tdryRun?: boolean\n}\n\n/**\n * Error thrown when the rebase command is run from an invalid location\n */\nexport class WorktreeValidationError extends Error {\n\tconstructor(\n\t\tmessage: string,\n\t\tpublic readonly suggestion: string\n\t) {\n\t\tsuper(message)\n\t\tthis.name = 'WorktreeValidationError'\n\t}\n}\n\n/**\n * RebaseCommand: Rebase current branch on main with Claude-assisted conflict resolution\n *\n * This command:\n * 1. Validates the current directory is an iloom-managed worktree\n * 2. Detects the worktree root (supports running from subdirectories)\n * 3. Delegates to MergeManager.rebaseOnMain() which handles:\n * - Checking main branch exists\n * - Detecting uncommitted changes (throws if found)\n * - Checking if already up-to-date\n * - Executing rebase\n * - Claude-assisted conflict resolution\n * 4. Reports success\n */\nexport class RebaseCommand {\n\tprivate mergeManager: MergeManager\n\tprivate gitWorktreeManager: GitWorktreeManager\n\tprivate settingsManager: SettingsManager\n\n\tconstructor(mergeManager?: MergeManager, gitWorktreeManager?: GitWorktreeManager, settingsManager?: SettingsManager) {\n\t\tthis.mergeManager = mergeManager ?? new MergeManager()\n\t\tthis.gitWorktreeManager = gitWorktreeManager ?? new GitWorktreeManager()\n\t\tthis.settingsManager = settingsManager ?? new SettingsManager()\n\t}\n\n\t/**\n\t * Validate that the current directory is within an iloom-managed worktree\n\t * Returns the worktree root path if valid\n\t * @throws WorktreeValidationError if validation fails\n\t */\n\tprivate async validateWorktreeContext(): Promise<string> {\n\t\tconst currentDir = process.cwd()\n\n\t\t// Step 1: Check if we're in a git repository at all\n\t\tconst isGitRepo = await isValidGitRepo(currentDir)\n\t\tif (!isGitRepo) {\n\t\t\tthrow new WorktreeValidationError(\n\t\t\t\t'Not a git repository.',\n\t\t\t\t\"Run 'il rebase' from within an iloom worktree created by 'il start'.\"\n\t\t\t)\n\t\t}\n\n\t\t// Step 2: Get the worktree root (handles subdirectories)\n\t\tconst worktreeRoot = await getWorktreeRoot(currentDir)\n\t\tif (!worktreeRoot) {\n\t\t\tthrow new WorktreeValidationError(\n\t\t\t\t'Could not determine repository root.',\n\t\t\t\t\"Run 'il rebase' from within an iloom worktree created by 'il start'.\"\n\t\t\t)\n\t\t}\n\n\t\t// Step 3: Check if this path is a registered git worktree\n\t\tconst worktrees = await this.gitWorktreeManager.listWorktrees()\n\t\tconst currentWorktree = worktrees.find(wt => wt.path === worktreeRoot)\n\n\t\tif (!currentWorktree) {\n\t\t\tthrow new WorktreeValidationError(\n\t\t\t\t'This directory is not an iloom worktree.',\n\t\t\t\t\"Run 'il rebase' from within a worktree created by 'il start <issue>'. Use 'il list' to see available worktrees.\"\n\t\t\t)\n\t\t}\n\n\t\t// Step 4: Check if this is the main worktree (we shouldn't rebase from main)\n\t\tconst isMain = await this.gitWorktreeManager.isMainWorktree(currentWorktree, this.settingsManager)\n\t\tif (isMain) {\n\t\t\tthrow new WorktreeValidationError(\n\t\t\t\t'Cannot rebase from the main worktree.',\n\t\t\t\t\"Navigate to a feature worktree created by 'il start <issue>' and run 'il rebase' from there.\"\n\t\t\t)\n\t\t}\n\n\t\treturn worktreeRoot\n\t}\n\n\tasync execute(options: RebaseOptions = {}): Promise<void> {\n\t\t// Step 1: Validate we're in a valid iloom worktree\n\t\tlet worktreePath: string\n\t\ttry {\n\t\t\tworktreePath = await this.validateWorktreeContext()\n\t\t} catch (error) {\n\t\t\tif (error instanceof WorktreeValidationError) {\n\t\t\t\tlogger.error(error.message)\n\t\t\t\tlogger.info(error.suggestion)\n\t\t\t\tthrow error\n\t\t\t}\n\t\t\tthrow error\n\t\t}\n\n\t\tconst mergeOptions: MergeOptions = {\n\t\t\tdryRun: options.dryRun ?? false,\n\t\t\tforce: options.force ?? false,\n\t\t}\n\n\t\t// MergeManager.rebaseOnMain() handles:\n\t\t// - Checking main branch exists\n\t\t// - Detecting uncommitted changes (throws if found)\n\t\t// - Checking if already up-to-date\n\t\t// - Executing rebase\n\t\t// - Claude-assisted conflict resolution\n\t\tawait this.mergeManager.rebaseOnMain(worktreePath, mergeOptions)\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAeO,IAAM,0BAAN,cAAsC,MAAM;AAAA,EAClD,YACC,SACgB,YACf;AACD,UAAM,OAAO;AAFG;AAGhB,SAAK,OAAO;AAAA,EACb;AACD;AAgBO,IAAM,gBAAN,MAAoB;AAAA,EAK1B,YAAY,cAA6B,oBAAyC,iBAAmC;AACpH,SAAK,eAAe,gBAAgB,IAAI,aAAa;AACrD,SAAK,qBAAqB,sBAAsB,IAAI,mBAAmB;AACvE,SAAK,kBAAkB,mBAAmB,IAAI,gBAAgB;AAAA,EAC/D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAc,0BAA2C;AACxD,UAAM,aAAa,QAAQ,IAAI;AAG/B,UAAM,YAAY,MAAM,eAAe,UAAU;AACjD,QAAI,CAAC,WAAW;AACf,YAAM,IAAI;AAAA,QACT;AAAA,QACA;AAAA,MACD;AAAA,IACD;AAGA,UAAM,eAAe,MAAM,gBAAgB,UAAU;AACrD,QAAI,CAAC,cAAc;AAClB,YAAM,IAAI;AAAA,QACT;AAAA,QACA;AAAA,MACD;AAAA,IACD;AAGA,UAAM,YAAY,MAAM,KAAK,mBAAmB,cAAc;AAC9D,UAAM,kBAAkB,UAAU,KAAK,QAAM,GAAG,SAAS,YAAY;AAErE,QAAI,CAAC,iBAAiB;AACrB,YAAM,IAAI;AAAA,QACT;AAAA,QACA;AAAA,MACD;AAAA,IACD;AAGA,UAAM,SAAS,MAAM,KAAK,mBAAmB,eAAe,iBAAiB,KAAK,eAAe;AACjG,QAAI,QAAQ;AACX,YAAM,IAAI;AAAA,QACT;AAAA,QACA;AAAA,MACD;AAAA,IACD;AAEA,WAAO;AAAA,EACR;AAAA,EAEA,MAAM,QAAQ,UAAyB,CAAC,GAAkB;AAEzD,QAAI;AACJ,QAAI;AACH,qBAAe,MAAM,KAAK,wBAAwB;AAAA,IACnD,SAAS,OAAO;AACf,UAAI,iBAAiB,yBAAyB;AAC7C,eAAO,MAAM,MAAM,OAAO;AAC1B,eAAO,KAAK,MAAM,UAAU;AAC5B,cAAM;AAAA,MACP;AACA,YAAM;AAAA,IACP;AAEA,UAAM,eAA6B;AAAA,MAClC,QAAQ,QAAQ,UAAU;AAAA,MAC1B,OAAO,QAAQ,SAAS;AAAA,IACzB;AAQA,UAAM,KAAK,aAAa,aAAa,cAAc,YAAY;AAAA,EAChE;AACD;","names":[]}
@@ -14,7 +14,7 @@ import {
14
14
  } from "./chunk-YETJNRQM.js";
15
15
  import {
16
16
  GitWorktreeManager
17
- } from "./chunk-OAP6SASD.js";
17
+ } from "./chunk-2CXREBLZ.js";
18
18
  import "./chunk-ZT3YZB4K.js";
19
19
  import {
20
20
  ProjectCapabilityDetector
@@ -25,10 +25,10 @@ import {
25
25
  } from "./chunk-GYCR2LOU.js";
26
26
  import {
27
27
  extractIssueNumber
28
- } from "./chunk-5NTD4MCZ.js";
28
+ } from "./chunk-5Q3NDNNV.js";
29
29
  import {
30
30
  SettingsManager
31
- } from "./chunk-UCZ24SUE.js";
31
+ } from "./chunk-CDZERT7Z.js";
32
32
  import {
33
33
  extractPort,
34
34
  findEnvFileContainingVariable,
@@ -289,4 +289,4 @@ Make sure the project is built (run 'il start' first)`
289
289
  export {
290
290
  RunCommand
291
291
  };
292
- //# sourceMappingURL=run-SJPM6YRI.js.map
292
+ //# sourceMappingURL=run-MJYY4PUT.js.map
@@ -328,14 +328,32 @@
328
328
  "webstorm",
329
329
  "sublime",
330
330
  "intellij",
331
- "windsurf"
331
+ "windsurf",
332
+ "antigravity"
332
333
  ],
333
334
  "default": "vscode",
334
- "description": "IDE to launch when starting a loom. Options: vscode (Visual Studio Code), cursor (Cursor AI editor), webstorm (JetBrains WebStorm), sublime (Sublime Text), intellij (JetBrains IntelliJ IDEA), windsurf (Windsurf editor)."
335
+ "description": "IDE to launch when starting a loom. Options: vscode (Visual Studio Code), cursor (Cursor AI editor), webstorm (JetBrains WebStorm), sublime (Sublime Text), intellij (JetBrains IntelliJ IDEA), windsurf (Windsurf editor), antigravity (Antigravity IDE)."
335
336
  }
336
337
  },
337
338
  "additionalProperties": false,
338
- "description": "IDE configuration for workspace launches. Controls which editor opens when you start a loom. Supports VSCode, Cursor, WebStorm, Sublime Text, IntelliJ, and Windsurf. Note: Color synchronization (title bar colors) only works with VSCode-compatible editors (vscode, cursor, windsurf)."
339
+ "description": "IDE configuration for workspace launches. Controls which editor opens when you start a loom. Supports VSCode, Cursor, WebStorm, Sublime Text, IntelliJ, Windsurf, and Antigravity. Note: Color synchronization (title bar colors) only works with VSCode-compatible editors (vscode, cursor, windsurf, antigravity)."
340
+ },
341
+ "colors": {
342
+ "type": "object",
343
+ "properties": {
344
+ "terminal": {
345
+ "type": "boolean",
346
+ "default": true,
347
+ "description": "Apply terminal background colors based on branch name (macOS only)"
348
+ },
349
+ "vscode": {
350
+ "type": "boolean",
351
+ "default": false,
352
+ "description": "Apply VSCode/Cursor title bar colors based on branch name. Note: This modifies .vscode/settings.json which may be in source control. Default is false for safety; enable via init or explicitly if .vscode is gitignored."
353
+ }
354
+ },
355
+ "additionalProperties": false,
356
+ "description": "Color synchronization settings for workspace identification"
339
357
  }
340
358
  },
341
359
  "additionalProperties": false
@@ -1,10 +1,10 @@
1
1
  #!/usr/bin/env node
2
2
  import {
3
3
  findMainWorktreePath
4
- } from "./chunk-5NTD4MCZ.js";
4
+ } from "./chunk-5Q3NDNNV.js";
5
5
  import {
6
6
  SettingsManager
7
- } from "./chunk-UCZ24SUE.js";
7
+ } from "./chunk-CDZERT7Z.js";
8
8
  import {
9
9
  logger
10
10
  } from "./chunk-GEHQXLEI.js";
@@ -49,4 +49,4 @@ var TestGitCommand = class {
49
49
  export {
50
50
  TestGitCommand
51
51
  };
52
- //# sourceMappingURL=test-git-DEUE656D.js.map
52
+ //# sourceMappingURL=test-git-IT5EWQ5C.js.map
@@ -1,10 +1,10 @@
1
1
  #!/usr/bin/env node
2
2
  import {
3
3
  generateWorktreePath
4
- } from "./chunk-5NTD4MCZ.js";
4
+ } from "./chunk-5Q3NDNNV.js";
5
5
  import {
6
6
  SettingsManager
7
- } from "./chunk-UCZ24SUE.js";
7
+ } from "./chunk-CDZERT7Z.js";
8
8
  import {
9
9
  logger
10
10
  } from "./chunk-GEHQXLEI.js";
@@ -65,4 +65,4 @@ var TestPrefixCommand = class {
65
65
  export {
66
66
  TestPrefixCommand
67
67
  };
68
- //# sourceMappingURL=test-prefix-Y6Z6ZHSF.js.map
68
+ //# sourceMappingURL=test-prefix-NPWDPUUH.js.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@iloom/cli",
3
- "version": "0.3.2",
3
+ "version": "0.3.4",
4
4
  "description": "Control plane for maintaining alignment between you and Claude Code as you work across multiple issues using isolated environments, visible context, and multi-agent workflows to scale understanding, not just output",
5
5
  "keywords": [
6
6
  "ai",
@@ -53,6 +53,7 @@
53
53
  "test": "vitest run",
54
54
  "test:watch": "vitest --watch",
55
55
  "test:coverage": "vitest run --coverage",
56
+ "test:hanging": "vitest run --reporter=hanging-process",
56
57
  "test:ui": "vitest --ui",
57
58
  "lint": "eslint . --ext .ts,.tsx --report-unused-disable-directives --max-warnings 0",
58
59
  "lint:fix": "eslint . --ext .ts,.tsx --fix",
@@ -1,15 +0,0 @@
1
- #!/usr/bin/env node
2
- import {
3
- ClaudeContextManager
4
- } from "./chunk-C7ASXK6J.js";
5
- import "./chunk-A2P7NZTB.js";
6
- import "./chunk-WEN5C5DM.js";
7
- import "./chunk-UCZ24SUE.js";
8
- import "./chunk-ZLIHIUDQ.js";
9
- import "./chunk-RW54ZMBM.js";
10
- import "./chunk-UJL4HI2R.js";
11
- import "./chunk-GEHQXLEI.js";
12
- export {
13
- ClaudeContextManager
14
- };
15
- //# sourceMappingURL=ClaudeContextManager-5WPRJIIW.js.map
@@ -1,14 +0,0 @@
1
- #!/usr/bin/env node
2
- import {
3
- ClaudeService
4
- } from "./chunk-A2P7NZTB.js";
5
- import "./chunk-WEN5C5DM.js";
6
- import "./chunk-UCZ24SUE.js";
7
- import "./chunk-ZLIHIUDQ.js";
8
- import "./chunk-RW54ZMBM.js";
9
- import "./chunk-UJL4HI2R.js";
10
- import "./chunk-GEHQXLEI.js";
11
- export {
12
- ClaudeService
13
- };
14
- //# sourceMappingURL=ClaudeService-Z4KA7QOW.js.map