mirror of
https://github.com/catlog22/Claude-Code-Workflow.git
synced 2026-02-11 02:33:51 +08:00
Added tree-style execution process diagrams using ASCII art (├─, └─, │) to 34 workflow command files across three directories for improved readability and execution flow clarity. ## Changes by Directory ### workflow/ root (17 files) - lite-plan.md, lite-execute.md, lite-fix.md - plan.md, execute.md, replan.md - status.md, review.md, review-fix.md - review-session-cycle.md, review-module-cycle.md - session commands (start, complete, resume, list) - tdd-plan.md, tdd-verify.md, test-cycle-execute.md, test-gen.md, test-fix-gen.md ### workflow/ui-design/ (10 files) - layout-extract.md, animation-extract.md, style-extract.md - generate.md, import-from-code.md, codify-style.md - imitate-auto.md, explore-auto.md - reference-page-generator.md, design-sync.md ### workflow/tools/ (8 files) - conflict-resolution.md, task-generate-agent.md, context-gather.md - tdd-coverage-analysis.md, task-generate-tdd.md - test-task-generate.md, test-concept-enhanced.md, test-context-gather.md ## Diagram Features - Input parsing with flag enumeration - Decision branching with conditional paths - Phase/step hierarchy with clear nesting - Mode detection and validation flows 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
612 lines
22 KiB
Markdown
612 lines
22 KiB
Markdown
---
|
|
name: lite-execute
|
|
description: Execute tasks based on in-memory plan, prompt description, or file content
|
|
argument-hint: "[--in-memory] [\"task description\"|file-path]"
|
|
allowed-tools: TodoWrite(*), Task(*), Bash(*)
|
|
---
|
|
|
|
# Workflow Lite-Execute Command (/workflow:lite-execute)
|
|
|
|
## Overview
|
|
|
|
Flexible task execution command supporting three input modes: in-memory plan (from lite-plan), direct prompt description, or file content. Handles execution orchestration, progress tracking, and optional code review.
|
|
|
|
**Core capabilities:**
|
|
- Multi-mode input (in-memory plan, prompt description, or file path)
|
|
- Execution orchestration (Agent or Codex) with full context
|
|
- Live progress tracking via TodoWrite at execution call level
|
|
- Optional code review with selected tool (Gemini, Agent, or custom)
|
|
- Context continuity across multiple executions
|
|
- Intelligent format detection (Enhanced Task JSON vs plain text)
|
|
|
|
## Usage
|
|
|
|
### Command Syntax
|
|
```bash
|
|
/workflow:lite-execute [FLAGS] <INPUT>
|
|
|
|
# Flags
|
|
--in-memory Use plan from memory (called by lite-plan)
|
|
|
|
# Arguments
|
|
<input> Task description string, or path to file (required)
|
|
```
|
|
|
|
## Input Modes
|
|
|
|
### Mode 1: In-Memory Plan
|
|
|
|
**Trigger**: Called by lite-plan after Phase 4 approval with `--in-memory` flag
|
|
|
|
**Input Source**: `executionContext` global variable set by lite-plan
|
|
|
|
**Content**: Complete execution context (see Data Structures section)
|
|
|
|
**Behavior**:
|
|
- Skip execution method selection (already set by lite-plan)
|
|
- Directly proceed to execution with full context
|
|
- All planning artifacts available (exploration, clarifications, plan)
|
|
|
|
### Mode 2: Prompt Description
|
|
|
|
**Trigger**: User calls with task description string
|
|
|
|
**Input**: Simple task description (e.g., "Add unit tests for auth module")
|
|
|
|
**Behavior**:
|
|
- Store prompt as `originalUserInput`
|
|
- Create simple execution plan from prompt
|
|
- AskUserQuestion: Select execution method (Agent/Codex/Auto)
|
|
- AskUserQuestion: Select code review tool (Skip/Gemini/Agent/Other)
|
|
- Proceed to execution with `originalUserInput` included
|
|
|
|
**User Interaction**:
|
|
```javascript
|
|
AskUserQuestion({
|
|
questions: [
|
|
{
|
|
question: "Select execution method:",
|
|
header: "Execution",
|
|
multiSelect: false,
|
|
options: [
|
|
{ label: "Agent", description: "@code-developer agent" },
|
|
{ label: "Codex", description: "codex CLI tool" },
|
|
{ label: "Auto", description: "Auto-select based on complexity" }
|
|
]
|
|
},
|
|
{
|
|
question: "Enable code review after execution?",
|
|
header: "Code Review",
|
|
multiSelect: false,
|
|
options: [
|
|
{ label: "Skip", description: "No review" },
|
|
{ label: "Gemini Review", description: "Gemini CLI tool" },
|
|
{ label: "Agent Review", description: "Current agent review" }
|
|
]
|
|
}
|
|
]
|
|
})
|
|
```
|
|
|
|
### Mode 3: File Content
|
|
|
|
**Trigger**: User calls with file path
|
|
|
|
**Input**: Path to file containing task description or plan.json
|
|
|
|
**Step 1: Read and Detect Format**
|
|
|
|
```javascript
|
|
fileContent = Read(filePath)
|
|
|
|
// Attempt JSON parsing
|
|
try {
|
|
jsonData = JSON.parse(fileContent)
|
|
|
|
// Check if plan.json from lite-plan session
|
|
if (jsonData.summary && jsonData.approach && jsonData.tasks) {
|
|
planObject = jsonData
|
|
originalUserInput = jsonData.summary
|
|
isPlanJson = true
|
|
} else {
|
|
// Valid JSON but not plan.json - treat as plain text
|
|
originalUserInput = fileContent
|
|
isPlanJson = false
|
|
}
|
|
} catch {
|
|
// Not valid JSON - treat as plain text prompt
|
|
originalUserInput = fileContent
|
|
isPlanJson = false
|
|
}
|
|
```
|
|
|
|
**Step 2: Create Execution Plan**
|
|
|
|
If `isPlanJson === true`:
|
|
- Use `planObject` directly
|
|
- User selects execution method and code review
|
|
|
|
If `isPlanJson === false`:
|
|
- Treat file content as prompt (same behavior as Mode 2)
|
|
- Create simple execution plan from content
|
|
|
|
**Step 3: User Interaction**
|
|
|
|
- AskUserQuestion: Select execution method (Agent/Codex/Auto)
|
|
- AskUserQuestion: Select code review tool
|
|
- Proceed to execution with full context
|
|
|
|
## Execution Process
|
|
|
|
```
|
|
Input Parsing:
|
|
└─ Decision (mode detection):
|
|
├─ --in-memory flag → Mode 1: Load executionContext → Skip user selection
|
|
├─ Ends with .md/.json/.txt → Mode 3: Read file → Detect format
|
|
│ ├─ Valid plan.json → Use planObject → User selects method + review
|
|
│ └─ Not plan.json → Treat as prompt → User selects method + review
|
|
└─ Other → Mode 2: Prompt description → User selects method + review
|
|
|
|
Execution:
|
|
├─ Step 1: Initialize result tracking (previousExecutionResults = [])
|
|
├─ Step 2: Task grouping & batch creation
|
|
│ ├─ Infer dependencies (same file → sequential, keywords → sequential)
|
|
│ ├─ Group into batches (parallel: independent, sequential: dependent)
|
|
│ └─ Create TodoWrite list for batches
|
|
├─ Step 3: Launch execution
|
|
│ ├─ Phase 1: All parallel batches (⚡ concurrent via multiple tool calls)
|
|
│ └─ Phase 2: Sequential batches (→ one by one)
|
|
├─ Step 4: Track progress (TodoWrite updates per batch)
|
|
└─ Step 5: Code review (if codeReviewTool ≠ "Skip")
|
|
|
|
Output:
|
|
└─ Execution complete with results in previousExecutionResults[]
|
|
```
|
|
|
|
## Detailed Execution Steps
|
|
|
|
### Step 1: Initialize Execution Tracking
|
|
|
|
**Operations**:
|
|
- Initialize result tracking for multi-execution scenarios
|
|
- Set up `previousExecutionResults` array for context continuity
|
|
|
|
```javascript
|
|
// Initialize result tracking
|
|
previousExecutionResults = []
|
|
```
|
|
|
|
### Step 2: Task Grouping & Batch Creation
|
|
|
|
**Dependency Analysis & Grouping Algorithm**:
|
|
```javascript
|
|
// Infer dependencies: same file → sequential, keywords (use/integrate) → sequential
|
|
function inferDependencies(tasks) {
|
|
return tasks.map((task, i) => {
|
|
const deps = []
|
|
const file = task.file || task.title.match(/in\s+([^\s:]+)/)?.[1]
|
|
const keywords = (task.description || task.title).toLowerCase()
|
|
|
|
for (let j = 0; j < i; j++) {
|
|
const prevFile = tasks[j].file || tasks[j].title.match(/in\s+([^\s:]+)/)?.[1]
|
|
if (file && prevFile === file) deps.push(j) // Same file
|
|
else if (/use|integrate|call|import/.test(keywords)) deps.push(j) // Keyword dependency
|
|
}
|
|
return { ...task, taskIndex: i, dependencies: deps }
|
|
})
|
|
}
|
|
|
|
// Group into batches: independent → parallel [P1,P2...], dependent → sequential [S1,S2...]
|
|
function createExecutionCalls(tasks, executionMethod) {
|
|
const tasksWithDeps = inferDependencies(tasks)
|
|
const maxBatch = executionMethod === "Codex" ? 4 : 7
|
|
const calls = []
|
|
const processed = new Set()
|
|
|
|
// Parallel: independent tasks, different files, max batch size
|
|
const parallelGroups = []
|
|
tasksWithDeps.forEach(t => {
|
|
if (t.dependencies.length === 0 && !processed.has(t.taskIndex)) {
|
|
const group = [t]
|
|
processed.add(t.taskIndex)
|
|
tasksWithDeps.forEach(o => {
|
|
if (!o.dependencies.length && !processed.has(o.taskIndex) &&
|
|
group.length < maxBatch && t.file !== o.file) {
|
|
group.push(o)
|
|
processed.add(o.taskIndex)
|
|
}
|
|
})
|
|
parallelGroups.push(group)
|
|
}
|
|
})
|
|
|
|
// Sequential: dependent tasks, batch when deps satisfied
|
|
const remaining = tasksWithDeps.filter(t => !processed.has(t.taskIndex))
|
|
while (remaining.length > 0) {
|
|
const batch = remaining.filter((t, i) =>
|
|
i < maxBatch && t.dependencies.every(d => processed.has(d))
|
|
)
|
|
if (!batch.length) break
|
|
batch.forEach(t => processed.add(t.taskIndex))
|
|
calls.push({ executionType: "sequential", groupId: `S${calls.length + 1}`, tasks: batch })
|
|
remaining.splice(0, remaining.length, ...remaining.filter(t => !processed.has(t.taskIndex)))
|
|
}
|
|
|
|
// Combine results
|
|
return [
|
|
...parallelGroups.map((g, i) => ({
|
|
method: executionMethod, executionType: "parallel", groupId: `P${i+1}`,
|
|
taskSummary: g.map(t => t.title).join(' | '), tasks: g
|
|
})),
|
|
...calls.map(c => ({ ...c, method: executionMethod, taskSummary: c.tasks.map(t => t.title).join(' → ') }))
|
|
]
|
|
}
|
|
|
|
executionCalls = createExecutionCalls(planObject.tasks, executionMethod).map(c => ({ ...c, id: `[${c.groupId}]` }))
|
|
|
|
TodoWrite({
|
|
todos: executionCalls.map(c => ({
|
|
content: `${c.executionType === "parallel" ? "⚡" : "→"} ${c.id} (${c.tasks.length} tasks)`,
|
|
status: "pending",
|
|
activeForm: `Executing ${c.id}`
|
|
}))
|
|
})
|
|
```
|
|
|
|
### Step 3: Launch Execution
|
|
|
|
**Execution Flow**: Parallel batches concurrently → Sequential batches in order
|
|
```javascript
|
|
const parallel = executionCalls.filter(c => c.executionType === "parallel")
|
|
const sequential = executionCalls.filter(c => c.executionType === "sequential")
|
|
|
|
// Phase 1: Launch all parallel batches (single message with multiple tool calls)
|
|
if (parallel.length > 0) {
|
|
TodoWrite({ todos: executionCalls.map(c => ({ status: c.executionType === "parallel" ? "in_progress" : "pending" })) })
|
|
parallelResults = await Promise.all(parallel.map(c => executeBatch(c)))
|
|
previousExecutionResults.push(...parallelResults)
|
|
TodoWrite({ todos: executionCalls.map(c => ({ status: parallel.includes(c) ? "completed" : "pending" })) })
|
|
}
|
|
|
|
// Phase 2: Execute sequential batches one by one
|
|
for (const call of sequential) {
|
|
TodoWrite({ todos: executionCalls.map(c => ({ status: c === call ? "in_progress" : "..." })) })
|
|
result = await executeBatch(call)
|
|
previousExecutionResults.push(result)
|
|
TodoWrite({ todos: executionCalls.map(c => ({ status: "completed" or "pending" })) })
|
|
}
|
|
```
|
|
|
|
**Option A: Agent Execution**
|
|
|
|
When to use:
|
|
- `executionMethod = "Agent"`
|
|
- `executionMethod = "Auto" AND complexity = "Low"`
|
|
|
|
Agent call format:
|
|
```javascript
|
|
function formatTaskForAgent(task, index) {
|
|
return `
|
|
### Task ${index + 1}: ${task.title}
|
|
**File**: ${task.file}
|
|
**Action**: ${task.action}
|
|
**Description**: ${task.description}
|
|
|
|
**Implementation Steps**:
|
|
${task.implementation.map((step, i) => `${i + 1}. ${step}`).join('\n')}
|
|
|
|
**Reference**:
|
|
- Pattern: ${task.reference.pattern}
|
|
- Example Files: ${task.reference.files.join(', ')}
|
|
- Guidance: ${task.reference.examples}
|
|
|
|
**Acceptance Criteria**:
|
|
${task.acceptance.map((criterion, i) => `${i + 1}. ${criterion}`).join('\n')}
|
|
`
|
|
}
|
|
|
|
Task(
|
|
subagent_type="code-developer",
|
|
description="Implement planned tasks",
|
|
prompt=`
|
|
${originalUserInput ? `## Original User Request\n${originalUserInput}\n\n` : ''}
|
|
|
|
## Implementation Plan
|
|
|
|
**Summary**: ${planObject.summary}
|
|
**Approach**: ${planObject.approach}
|
|
|
|
## Task Breakdown (${planObject.tasks.length} tasks)
|
|
${planObject.tasks.map((task, i) => formatTaskForAgent(task, i)).join('\n')}
|
|
|
|
${previousExecutionResults.length > 0 ? `\n## Previous Execution Results\n${previousExecutionResults.map(result => `
|
|
[${result.executionId}] ${result.status}
|
|
Tasks: ${result.tasksSummary}
|
|
Completion: ${result.completionSummary}
|
|
Outputs: ${result.keyOutputs || 'See git diff'}
|
|
${result.notes ? `Notes: ${result.notes}` : ''}
|
|
`).join('\n---\n')}` : ''}
|
|
|
|
## Multi-Angle Code Context
|
|
|
|
${explorationsContext && Object.keys(explorationsContext).length > 0 ?
|
|
explorationAngles.map(angle => {
|
|
const exp = explorationsContext[angle]
|
|
return `### Exploration Angle: ${angle}
|
|
|
|
**Project Structure**: ${exp.project_structure || 'N/A'}
|
|
**Relevant Files**: ${exp.relevant_files?.join(', ') || 'None'}
|
|
**Patterns**: ${exp.patterns || 'N/A'}
|
|
**Dependencies**: ${exp.dependencies || 'N/A'}
|
|
**Integration Points**: ${exp.integration_points || 'N/A'}
|
|
**Constraints**: ${exp.constraints || 'N/A'}`
|
|
}).join('\n\n---\n\n')
|
|
: "No exploration performed"
|
|
}
|
|
|
|
${clarificationContext ? `\n## Clarifications\n${JSON.stringify(clarificationContext, null, 2)}` : ''}
|
|
|
|
${executionContext?.session?.artifacts ? `\n## Exploration Artifact Files
|
|
|
|
Detailed exploration context available in:
|
|
${executionContext.session.artifacts.explorations?.map(exp =>
|
|
`- Angle: ${exp.angle} → ${exp.path}`
|
|
).join('\n') || ''}
|
|
${executionContext.session.artifacts.explorations_manifest ? `- Manifest: ${executionContext.session.artifacts.explorations_manifest}` : ''}
|
|
- Plan: ${executionContext.session.artifacts.plan}
|
|
|
|
Read exploration files for comprehensive context from multiple angles.` : ''}
|
|
|
|
## Requirements
|
|
MUST complete ALL ${planObject.tasks.length} tasks listed above in this single execution.
|
|
Return only after all tasks are fully implemented and tested.
|
|
`
|
|
)
|
|
```
|
|
|
|
**Result Collection**: After completion, collect result following `executionResult` structure (see Data Structures section)
|
|
|
|
**Option B: CLI Execution (Codex)**
|
|
|
|
When to use:
|
|
- `executionMethod = "Codex"`
|
|
- `executionMethod = "Auto" AND complexity = "Medium" or "High"`
|
|
|
|
**Artifact Path Delegation**:
|
|
- Include artifact file paths in CLI prompt for enhanced context
|
|
- Codex can read artifact files for detailed planning information
|
|
- Example: Reference exploration.json for architecture patterns
|
|
|
|
Command format:
|
|
```bash
|
|
function formatTaskForCodex(task, index) {
|
|
return `
|
|
${index + 1}. ${task.title} (${task.file})
|
|
Action: ${task.action}
|
|
What: ${task.description}
|
|
How:
|
|
${task.implementation.map((step, i) => ` ${i + 1}. ${step}`).join('\n')}
|
|
Reference: ${task.reference.pattern} (see ${task.reference.files.join(', ')})
|
|
Guidance: ${task.reference.examples}
|
|
Verify:
|
|
${task.acceptance.map((criterion, i) => ` - ${criterion}`).join('\n')}
|
|
`
|
|
}
|
|
|
|
codex --full-auto exec "
|
|
${originalUserInput ? `## Original User Request\n${originalUserInput}\n\n` : ''}
|
|
|
|
## Implementation Plan
|
|
|
|
TASK: ${planObject.summary}
|
|
APPROACH: ${planObject.approach}
|
|
|
|
### Task Breakdown (${planObject.tasks.length} tasks)
|
|
${planObject.tasks.map((task, i) => formatTaskForCodex(task, i)).join('\n')}
|
|
|
|
${previousExecutionResults.length > 0 ? `\n### Previous Execution Results\n${previousExecutionResults.map(result => `
|
|
[${result.executionId}] ${result.status}
|
|
Tasks: ${result.tasksSummary}
|
|
Status: ${result.completionSummary}
|
|
Outputs: ${result.keyOutputs || 'See git diff'}
|
|
${result.notes ? `Notes: ${result.notes}` : ''}
|
|
`).join('\n---\n')}
|
|
|
|
IMPORTANT: Review previous results. Build on completed work. Avoid duplication.
|
|
` : ''}
|
|
|
|
### Multi-Angle Code Context
|
|
|
|
${explorationsContext && Object.keys(explorationsContext).length > 0 ?
|
|
`Exploration conducted from ${explorationAngles.length} angles:
|
|
|
|
${explorationAngles.map(angle => {
|
|
const exp = explorationsContext[angle]
|
|
return `Angle: ${angle}
|
|
- Structure: ${exp.project_structure || 'Standard structure'}
|
|
- Files: ${exp.relevant_files?.slice(0, 5).join(', ') || 'TBD'}${exp.relevant_files?.length > 5 ? ` (+${exp.relevant_files.length - 5} more)` : ''}
|
|
- Patterns: ${exp.patterns?.substring(0, 100) || 'Follow existing'}${exp.patterns?.length > 100 ? '...' : ''}
|
|
- Constraints: ${exp.constraints || 'None'}`
|
|
}).join('\n\n')}
|
|
`
|
|
: 'No prior exploration - analyze codebase as needed'
|
|
}
|
|
|
|
${clarificationContext ? `\n### User Clarifications\n${Object.entries(clarificationContext).map(([q, a]) => `${q}: ${a}`).join('\n')}` : ''}
|
|
|
|
${executionContext?.session?.artifacts ? `\n### Exploration Artifact Files
|
|
Detailed context from multiple exploration angles available in:
|
|
${executionContext.session.artifacts.explorations?.map(exp =>
|
|
`- Angle: ${exp.angle} → ${exp.path}`
|
|
).join('\n') || ''}
|
|
${executionContext.session.artifacts.explorations_manifest ? `- Manifest: ${executionContext.session.artifacts.explorations_manifest}` : ''}
|
|
- Plan: ${executionContext.session.artifacts.plan}
|
|
|
|
Read exploration files for comprehensive architectural, pattern, and constraint details from multiple angles.
|
|
` : ''}
|
|
|
|
## Requirements
|
|
MUST complete ALL ${planObject.tasks.length} tasks listed above in this single execution.
|
|
Return only after all tasks are fully implemented and tested.
|
|
|
|
Complexity: ${planObject.complexity}
|
|
" --skip-git-repo-check -s danger-full-access
|
|
```
|
|
|
|
**Execution with tracking**:
|
|
```javascript
|
|
// Launch CLI in foreground (NOT background)
|
|
// Timeout based on complexity: Low=40min, Medium=60min, High=100min
|
|
const timeoutByComplexity = {
|
|
"Low": 2400000, // 40 minutes
|
|
"Medium": 3600000, // 60 minutes
|
|
"High": 6000000 // 100 minutes
|
|
}
|
|
|
|
bash_result = Bash(
|
|
command=cli_command,
|
|
timeout=timeoutByComplexity[planObject.complexity] || 3600000
|
|
)
|
|
|
|
// Update TodoWrite when execution completes
|
|
```
|
|
|
|
**Result Collection**: After completion, analyze output and collect result following `executionResult` structure
|
|
|
|
### Step 4: Progress Tracking
|
|
|
|
Progress tracked at batch level (not individual task level). Icons: ⚡ (parallel, concurrent), → (sequential, one-by-one)
|
|
|
|
### Step 5: Code Review (Optional)
|
|
|
|
**Skip Condition**: Only run if `codeReviewTool ≠ "Skip"`
|
|
|
|
**Review Focus**: Verify implementation against plan acceptance criteria
|
|
- Read plan.json for task acceptance criteria
|
|
- Check each acceptance criterion is fulfilled
|
|
- Validate code quality and identify issues
|
|
- Ensure alignment with planned approach
|
|
|
|
**Operations**:
|
|
- Agent Review: Current agent performs direct review
|
|
- Gemini Review: Execute gemini CLI with review prompt
|
|
- Custom tool: Execute specified CLI tool (qwen, codex, etc.)
|
|
|
|
**Unified Review Template** (All tools use same standard):
|
|
|
|
**Review Criteria**:
|
|
- **Acceptance Criteria**: Verify each criterion from plan.tasks[].acceptance
|
|
- **Code Quality**: Analyze quality, identify issues, suggest improvements
|
|
- **Plan Alignment**: Validate implementation matches planned approach
|
|
|
|
**Shared Prompt Template** (used by all CLI tools):
|
|
```
|
|
PURPOSE: Code review for implemented changes against plan acceptance criteria
|
|
TASK: • Verify plan acceptance criteria fulfillment • Analyze code quality • Identify issues • Suggest improvements • Validate plan adherence
|
|
MODE: analysis
|
|
CONTEXT: @**/* @{plan.json} [@{exploration.json}] | Memory: Review lite-execute changes against plan requirements
|
|
EXPECTED: Quality assessment with acceptance criteria verification, issue identification, and recommendations. Explicitly check each acceptance criterion from plan.json tasks.
|
|
RULES: $(cat ~/.claude/workflows/cli-templates/prompts/analysis/02-review-code-quality.txt) | Focus on plan acceptance criteria and plan adherence | analysis=READ-ONLY
|
|
```
|
|
|
|
**Tool-Specific Execution** (Apply shared prompt template above):
|
|
|
|
```bash
|
|
# Method 1: Agent Review (current agent)
|
|
# - Read plan.json: ${executionContext.session.artifacts.plan}
|
|
# - Apply unified review criteria (see Shared Prompt Template)
|
|
# - Report findings directly
|
|
|
|
# Method 2: Gemini Review (recommended)
|
|
gemini -p "[Shared Prompt Template with artifacts]"
|
|
# CONTEXT includes: @**/* @${plan.json} [@${exploration.json}]
|
|
|
|
# Method 3: Qwen Review (alternative)
|
|
qwen -p "[Shared Prompt Template with artifacts]"
|
|
# Same prompt as Gemini, different execution engine
|
|
|
|
# Method 4: Codex Review (autonomous)
|
|
codex --full-auto exec "[Verify plan acceptance criteria at ${plan.json}]" --skip-git-repo-check -s danger-full-access
|
|
```
|
|
|
|
**Implementation Note**: Replace `[Shared Prompt Template with artifacts]` placeholder with actual template content, substituting:
|
|
- `@{plan.json}` → `@${executionContext.session.artifacts.plan}`
|
|
- `[@{exploration.json}]` → exploration files from artifacts (if exists)
|
|
|
|
## Best Practices
|
|
|
|
**Input Modes**: In-memory (lite-plan), prompt (standalone), file (JSON/text)
|
|
**Batch Limits**: Agent 7 tasks, CLI 4 tasks
|
|
**Execution**: Parallel batches use single Claude message with multiple tool calls (no concurrency limit)
|
|
|
|
## Error Handling
|
|
|
|
| Error | Cause | Resolution |
|
|
|-------|-------|------------|
|
|
| Missing executionContext | --in-memory without context | Error: "No execution context found. Only available when called by lite-plan." |
|
|
| File not found | File path doesn't exist | Error: "File not found: {path}. Check file path." |
|
|
| Empty file | File exists but no content | Error: "File is empty: {path}. Provide task description." |
|
|
| Invalid Enhanced Task JSON | JSON missing required fields | Warning: "Missing required fields. Treating as plain text." |
|
|
| Malformed JSON | JSON parsing fails | Treat as plain text (expected for non-JSON files) |
|
|
| Execution failure | Agent/Codex crashes | Display error, save partial progress, suggest retry |
|
|
| Codex unavailable | Codex not installed | Show installation instructions, offer Agent execution |
|
|
|
|
## Data Structures
|
|
|
|
### executionContext (Input - Mode 1)
|
|
|
|
Passed from lite-plan via global variable:
|
|
|
|
```javascript
|
|
{
|
|
planObject: {
|
|
summary: string,
|
|
approach: string,
|
|
tasks: [...],
|
|
estimated_time: string,
|
|
recommended_execution: string,
|
|
complexity: string
|
|
},
|
|
explorationsContext: {...} | null, // Multi-angle explorations
|
|
explorationAngles: string[], // List of exploration angles
|
|
explorationManifest: {...} | null, // Exploration manifest
|
|
clarificationContext: {...} | null,
|
|
executionMethod: "Agent" | "Codex" | "Auto",
|
|
codeReviewTool: "Skip" | "Gemini Review" | "Agent Review" | string,
|
|
originalUserInput: string,
|
|
|
|
// Session artifacts location (saved by lite-plan)
|
|
session: {
|
|
id: string, // Session identifier: {taskSlug}-{shortTimestamp}
|
|
folder: string, // Session folder path: .workflow/.lite-plan/{session-id}
|
|
artifacts: {
|
|
explorations: [{angle, path}], // exploration-{angle}.json paths
|
|
explorations_manifest: string, // explorations-manifest.json path
|
|
plan: string // plan.json path (always present)
|
|
}
|
|
}
|
|
}
|
|
```
|
|
|
|
**Artifact Usage**:
|
|
- Artifact files contain detailed planning context
|
|
- Pass artifact paths to CLI tools and agents for enhanced context
|
|
- See execution options below for usage examples
|
|
|
|
### executionResult (Output)
|
|
|
|
Collected after each execution call completes:
|
|
|
|
```javascript
|
|
{
|
|
executionId: string, // e.g., "[Agent-1]", "[Codex-1]"
|
|
status: "completed" | "partial" | "failed",
|
|
tasksSummary: string, // Brief description of tasks handled
|
|
completionSummary: string, // What was completed
|
|
keyOutputs: string, // Files created/modified, key changes
|
|
notes: string // Important context for next execution
|
|
}
|
|
```
|
|
|
|
Appended to `previousExecutionResults` array for context continuity in multi-execution scenarios.
|