mirror of
https://github.com/catlog22/Claude-Code-Workflow.git
synced 2026-02-05 01:50:27 +08:00
- Enhanced 14 commands with flexible parameter support - Standardized argument formats across all commands - Added English parameter descriptions for clarity - Maintained backward compatibility Commands optimized: - analyze-with-file: Added --depth, --max-iterations - brainstorm-with-file: Added --perspectives, --max-ideas, --focus - debug-with-file: Added --scope, --focus, --depth - issue-execute: Unified format, added --skip-tests, --skip-build, --dry-run - lite-plan-a/b/c: Added depth and execution control flags - execute: Added --parallel, --filter, --skip-tests - brainstorm-to-cycle: Unified to --session format, added --launch - lite-fix: Added --hotfix, --severity, --scope - clean: Added --focus, --target, --confirm - lite-execute: Unified --plan format, added execution control - compact: Added --description, --tags, --force - issue-new: Complete flexible parameter support Unchanged (already optimal): - issue-plan, issue-discover, issue-queue, issue-discover-by-prompt
342 lines
11 KiB
Markdown
342 lines
11 KiB
Markdown
---
|
|
description: Lightweight interactive planning workflow with single-agent merged mode for explore → clarify → plan full flow. Supports depth control and auto-clarification.
|
|
argument-hint: "TASK=\"<task description or file.md path>\" [--depth=standard|deep] [--auto-clarify] [--max-rounds=<n>] [--verbose]"
|
|
---
|
|
|
|
# Workflow Lite-Plan-A (Merged Mode)
|
|
|
|
## Overview
|
|
|
|
Single-agent merged mode for lightweight planning. One agent handles exploration, clarification, and planning in a continuous conversation, maximizing context retention and minimizing agent creation overhead.
|
|
|
|
**Core capabilities:**
|
|
- **Single agent dual-role execution** (explorer + planner in one conversation)
|
|
- Context automatically preserved across phases (no serialization loss)
|
|
- Reduced user interaction rounds (1-2 vs 3-4)
|
|
- Best for Low/Medium complexity tasks with single exploration angle
|
|
|
|
## Applicable Scenarios
|
|
|
|
- **Low/Medium complexity tasks**
|
|
- Single exploration angle sufficient
|
|
- Prioritize minimal agent creation and coherent context
|
|
- Clear, well-defined tasks within single module
|
|
|
|
## Core Advantages
|
|
|
|
| Metric | Traditional Separated Mode | Plan-A Merged Mode |
|
|
|--------|---------------------------|-------------------|
|
|
| Agent creation count | 2-5 | **1** |
|
|
| Context transfer | Serialized, lossy | **Automatic retention** |
|
|
| User interaction rounds | 3-4 | **1-2** |
|
|
| Execution time | Multiple spawn/close | **30-50%↓** |
|
|
|
|
## Task Description
|
|
|
|
**Target task**: $TASK
|
|
|
|
- `--depth`: Exploration depth (standard|deep)
|
|
- `--auto-clarify`: Auto clarify, skip confirmation
|
|
- `--max-rounds`: Max interaction rounds
|
|
|
|
## Execution Process
|
|
|
|
```
|
|
┌─────────────────────────────────────────────────────────────┐
|
|
│ spawn_agent (dual role: explorer + planner) │
|
|
│ ↓ │
|
|
│ Phase 1: Exploration → output findings + clarification_needs│
|
|
│ ↓ │
|
|
│ wait() → get exploration results │
|
|
│ ↓ │
|
|
│ [If clarification needed] Main process collects user answers│
|
|
│ ↓ │
|
|
│ send_input(clarification_answers + "generate plan") │
|
|
│ ↓ │
|
|
│ Phase 2: Planning → output plan.json │
|
|
│ ↓ │
|
|
│ wait() → get planning results │
|
|
│ ↓ │
|
|
│ close_agent() │
|
|
└─────────────────────────────────────────────────────────────┘
|
|
```
|
|
|
|
## Implementation
|
|
|
|
### Session Setup
|
|
|
|
**Session Setup** (MANDATORY - follow exactly):
|
|
```javascript
|
|
// Helper: Get UTC+8 (China Standard Time) ISO string
|
|
const getUtc8ISOString = () => new Date(Date.now() + 8 * 60 * 60 * 1000).toISOString()
|
|
|
|
const taskSlug = "$TASK".toLowerCase().replace(/[^a-z0-9]+/g, '-').substring(0, 40)
|
|
const dateStr = getUtc8ISOString().substring(0, 10) // Format: 2025-11-29
|
|
|
|
const sessionId = `${taskSlug}-${dateStr}` // e.g., "implement-jwt-refresh-2025-11-29"
|
|
const sessionFolder = `.workflow/.lite-plan/${sessionId}`
|
|
|
|
// Create session folder
|
|
mkdir -p ${sessionFolder}
|
|
```
|
|
|
|
### Complexity Assessment & Angle Selection
|
|
|
|
```javascript
|
|
const complexity = analyzeTaskComplexity("$TASK")
|
|
// Plan-A is suitable for Low/Medium; High complexity should use Plan-B
|
|
|
|
const ANGLE_PRESETS = {
|
|
architecture: ['architecture', 'dependencies'],
|
|
security: ['security', 'auth-patterns'],
|
|
performance: ['performance', 'bottlenecks'],
|
|
bugfix: ['error-handling', 'dataflow'],
|
|
feature: ['patterns', 'integration-points']
|
|
}
|
|
|
|
// Plan-A selects only 1-2 most relevant angles
|
|
const primaryAngle = selectPrimaryAngle("$TASK")
|
|
```
|
|
|
|
---
|
|
|
|
### Phase 1 & 2: Single Agent Dual-Role Execution (Codex Pattern)
|
|
|
|
```javascript
|
|
// ==================== PLAN-A: SINGLE AGENT MERGED MODE ====================
|
|
|
|
// Step 1: Create dual-role agent (role files read by agent itself)
|
|
const agent = spawn_agent({
|
|
message: `
|
|
## TASK ASSIGNMENT
|
|
|
|
### Overview
|
|
You will complete this task in TWO phases using a SINGLE conversation:
|
|
1. **Phase 1**: Explore codebase, output findings and clarification questions
|
|
2. **Phase 2**: After receiving clarification answers, generate implementation plan
|
|
|
|
### Task Description
|
|
${task_description}
|
|
|
|
### Session Info
|
|
- Session ID: ${sessionId}
|
|
- Session Folder: ${sessionFolder}
|
|
- Primary Angle: ${primaryAngle}
|
|
|
|
---
|
|
|
|
## PHASE 1: EXPLORATION
|
|
|
|
### MANDATORY FIRST STEPS (Agent Execute)
|
|
1. **Read explorer role**: ~/.codex/agents/cli-explore-agent.md (MUST read first)
|
|
2. **Read planner role**: ~/.codex/agents/cli-lite-planning-agent.md (for Phase 2)
|
|
3. Run: ccw tool exec get_modules_by_depth '{}'
|
|
4. Run: rg -l "{keyword_from_task}" --type ts
|
|
5. Read: .workflow/project-tech.json
|
|
6. Read: .workflow/project-guidelines.json
|
|
|
|
### Exploration Focus: ${primaryAngle}
|
|
- Identify relevant files and modules
|
|
- Discover existing patterns and conventions
|
|
- Map dependencies and integration points
|
|
- Note constraints and limitations
|
|
|
|
### Phase 1 Output Format
|
|
|
|
\`\`\`
|
|
## EXPLORATION COMPLETE
|
|
|
|
### Findings Summary
|
|
- [Key finding 1]
|
|
- [Key finding 2]
|
|
- [Key finding 3]
|
|
|
|
### Relevant Files
|
|
| File | Relevance | Rationale |
|
|
|------|-----------|-----------|
|
|
| path/to/file1.ts | 0.9 | [reason] |
|
|
| path/to/file2.ts | 0.8 | [reason] |
|
|
|
|
### Patterns to Follow
|
|
- [Pattern 1 with code example]
|
|
- [Pattern 2 with code example]
|
|
|
|
### Integration Points
|
|
- [file:line] - [description]
|
|
|
|
### Constraints
|
|
- [Constraint 1]
|
|
- [Constraint 2]
|
|
|
|
CLARIFICATION_NEEDED:
|
|
Q1: [question] | Options: [A, B, C] | Recommended: [B]
|
|
Q2: [question] | Options: [A, B] | Recommended: [A]
|
|
\`\`\`
|
|
|
|
**If no clarification needed**, output:
|
|
\`\`\`
|
|
CLARIFICATION_NEEDED: NONE
|
|
|
|
Ready for Phase 2. Send "PROCEED_TO_PLANNING" to continue.
|
|
\`\`\`
|
|
|
|
### Write Exploration File
|
|
Write findings to: ${sessionFolder}/exploration.json
|
|
`
|
|
})
|
|
|
|
// Step 2: Wait for Phase 1 to complete
|
|
const phase1Result = wait({ ids: [agent], timeout_ms: 600000 })
|
|
const phase1Output = phase1Result.status[agent].completed
|
|
|
|
// Step 3: Handle clarification (if needed)
|
|
let clarificationAnswers = null
|
|
|
|
if (phase1Output.includes('CLARIFICATION_NEEDED:') && !phase1Output.includes('CLARIFICATION_NEEDED: NONE')) {
|
|
// Parse questions, collect user answers
|
|
const questions = parseClarificationQuestions(phase1Output)
|
|
|
|
// Display questions to user, collect answers
|
|
console.log(`
|
|
## Clarification Needed
|
|
|
|
${questions.map((q, i) => `
|
|
### Q${i+1}: ${q.question}
|
|
Options: ${q.options.join(', ')}
|
|
Recommended: ${q.recommended}
|
|
`).join('\n')}
|
|
|
|
**Please provide your answers...**
|
|
`)
|
|
|
|
// Wait for user input...
|
|
clarificationAnswers = collectUserAnswers(questions)
|
|
}
|
|
|
|
// Step 4: Send Phase 2 instruction (continue with same agent)
|
|
send_input({
|
|
id: agent,
|
|
message: `
|
|
## PHASE 2: GENERATE PLAN
|
|
|
|
${clarificationAnswers ? `
|
|
### Clarification Answers
|
|
${clarificationAnswers.map(a => `Q: ${a.question}\nA: ${a.answer}`).join('\n\n')}
|
|
` : '### No clarification needed - proceeding with exploration findings'}
|
|
|
|
### Planning Instructions
|
|
|
|
1. **Read Schema**
|
|
Execute: cat ~/.claude/workflows/cli-templates/schemas/plan-json-schema.json
|
|
|
|
2. **Generate Plan** based on your exploration findings
|
|
- Summary: 2-3 sentence overview
|
|
- Approach: High-level strategy
|
|
- Tasks: 2-7 tasks grouped by feature (NOT by file)
|
|
- Each task needs: id, title, scope, action, description, modification_points, implementation, acceptance, depends_on
|
|
|
|
3. **Task Grouping Rules**
|
|
- Group by feature: All changes for one feature = one task
|
|
- Substantial tasks: 15-60 minutes of work each
|
|
- True dependencies only: Use depends_on sparingly
|
|
- Prefer parallel: Most tasks should be independent
|
|
|
|
4. **Write Output**
|
|
Write: ${sessionFolder}/plan.json
|
|
|
|
### Output Format
|
|
Return brief completion summary after writing plan.json
|
|
`
|
|
})
|
|
|
|
// Step 5: Wait for Phase 2 to complete
|
|
const phase2Result = wait({ ids: [agent], timeout_ms: 600000 })
|
|
|
|
// Step 6: Cleanup
|
|
close_agent({ id: agent })
|
|
```
|
|
|
|
---
|
|
|
|
### Phase 3: Confirmation
|
|
|
|
```javascript
|
|
const plan = JSON.parse(Read(`${sessionFolder}/plan.json`))
|
|
|
|
console.log(`
|
|
## Implementation Plan
|
|
|
|
**Summary**: ${plan.summary}
|
|
**Approach**: ${plan.approach}
|
|
**Complexity**: ${plan.complexity}
|
|
|
|
**Tasks** (${plan.tasks.length}):
|
|
${plan.tasks.map((t, i) => `${i+1}. ${t.title} (${t.scope})`).join('\n')}
|
|
|
|
**Estimated Time**: ${plan.estimated_time}
|
|
|
|
---
|
|
|
|
## Confirmation Required
|
|
|
|
Please review the plan above and reply with one of the following:
|
|
|
|
- **"Allow"** - Proceed with this plan, output plan.json
|
|
- **"Modify"** - Describe what changes you want to make
|
|
- **"Cancel"** - Abort the planning workflow
|
|
|
|
**WAITING FOR USER CONFIRMATION...**
|
|
`)
|
|
```
|
|
|
|
---
|
|
|
|
## Codex vs Claude Comparison (for merged mode)
|
|
|
|
| Aspect | Claude Code Task | Codex Subagent (Plan-A) |
|
|
|--------|------------------|------------------------|
|
|
| **Creation** | `Task({ subagent_type, prompt })` | `spawn_agent({ message: role + task })` |
|
|
| **Role Loading** | Auto via `subagent_type` | Manual: Agent reads `~/.codex/agents/*.md` |
|
|
| **Multi-phase** | Separate agents or resume | **Single agent + send_input** |
|
|
| **Context Retention** | Lossy (serialization) | **Automatic (same conversation)** |
|
|
| **Follow-up** | `resume` parameter | `send_input({ id, message })` |
|
|
| **Cleanup** | Automatic | **Explicit `close_agent({ id })`** |
|
|
|
|
**Plan-A Advantages**:
|
|
- Zero context loss between phases
|
|
- Single agent lifecycle to manage
|
|
- Minimal overhead for simple tasks
|
|
|
|
---
|
|
|
|
## Session Folder Structure
|
|
|
|
```
|
|
.workflow/.lite-plan/{task-slug}-{YYYY-MM-DD}/
|
|
├── exploration.json # Phase 1 output
|
|
└── plan.json # Phase 2 output (after confirmation)
|
|
```
|
|
|
|
## Workflow States
|
|
|
|
| State | Action | Next |
|
|
|-------|--------|------|
|
|
| Phase 1 Output | Exploration complete | → Wait for clarification or Phase 2 |
|
|
| Clarification Output | Questions displayed | → Wait for user reply |
|
|
| User Replied | Answers received | → send_input to Phase 2 |
|
|
| Phase 2 Output | Plan generated | → Phase 3 (Confirmation) |
|
|
| User: "Allow" | Confirmed | → Output complete |
|
|
| User: "Modify" | Changes requested | → send_input with revisions |
|
|
| User: "Cancel" | Aborted | → close_agent, end workflow |
|
|
|
|
## Error Handling
|
|
|
|
| Error | Resolution |
|
|
|-------|------------|
|
|
| Phase 1 timeout | Continue wait or send_input to request convergence |
|
|
| Phase 2 timeout | send_input requesting current progress output |
|
|
| Agent unexpectedly closed | Re-spawn, paste previous output in message |
|
|
| User cancels | close_agent, preserve generated files |
|
|
|
|
**Execute task**: $TASK
|