2025-03-04 13:55:17 -05:00
|
|
|
---
|
2025-03-21 16:25:12 -04:00
|
|
|
description: Guide for using meta-development script (scripts/dev.js) to manage task-driven development workflows
|
2025-03-21 14:17:43 -04:00
|
|
|
globs: **/*
|
2025-03-04 13:55:17 -05:00
|
|
|
alwaysApply: true
|
|
|
|
---
|
|
|
|
|
2025-03-21 16:25:12 -04:00
|
|
|
- **Development Workflow Process**
|
|
|
|
- Start new projects by running `node scripts/dev.js parse-prd --input=<prd-file.txt>` to generate initial tasks.json
|
|
|
|
- Begin coding sessions with `node scripts/dev.js list` to see current tasks, status, and IDs
|
|
|
|
- Analyze task complexity with `node scripts/dev.js analyze-complexity --research` before breaking down tasks
|
|
|
|
- Select tasks based on dependencies (all marked 'done'), priority level, and ID order
|
|
|
|
- Clarify tasks by checking task files in tasks/ directory or asking for user input
|
2025-03-22 00:02:22 -04:00
|
|
|
- View specific task details using `node scripts/dev.js show --id=<id>` to understand implementation requirements
|
2025-03-21 16:25:12 -04:00
|
|
|
- Break down complex tasks using `node scripts/dev.js expand --id=<id>` with appropriate flags
|
2025-03-21 18:37:24 -04:00
|
|
|
- Clear existing subtasks if needed using `node scripts/dev.js clear-subtasks --id=<id>` before regenerating
|
2025-03-21 16:25:12 -04:00
|
|
|
- Implement code following task details, dependencies, and project standards
|
|
|
|
- Verify tasks according to test strategies before marking as complete
|
|
|
|
- Mark completed tasks with `node scripts/dev.js set-status --id=<id> --status=done`
|
|
|
|
- Update dependent tasks when implementation differs from original plan
|
|
|
|
- Generate task files with `node scripts/dev.js generate` after updating tasks.json
|
2025-03-22 00:51:53 -04:00
|
|
|
- Maintain valid dependency structure with `node scripts/dev.js fix-dependencies` when needed
|
2025-03-21 16:25:12 -04:00
|
|
|
- Respect dependency chains and task priorities when selecting work
|
|
|
|
- Report progress regularly using the list command
|
2025-03-04 13:55:17 -05:00
|
|
|
|
2025-03-21 16:25:12 -04:00
|
|
|
- **Task Complexity Analysis**
|
|
|
|
- Run `node scripts/dev.js analyze-complexity --research` for comprehensive analysis
|
|
|
|
- Review complexity report in scripts/task-complexity-report.json
|
|
|
|
- Focus on tasks with highest complexity scores (8-10) for detailed breakdown
|
|
|
|
- Use analysis results to determine appropriate subtask allocation
|
|
|
|
- Note that reports are automatically used by the expand command
|
2025-03-04 13:55:17 -05:00
|
|
|
|
2025-03-21 16:25:12 -04:00
|
|
|
- **Task Breakdown Process**
|
|
|
|
- For tasks with complexity analysis, use `node scripts/dev.js expand --id=<id>`
|
|
|
|
- Otherwise use `node scripts/dev.js expand --id=<id> --subtasks=<number>`
|
|
|
|
- Add `--research` flag to leverage Perplexity AI for research-backed expansion
|
|
|
|
- Use `--prompt="<context>"` to provide additional context when needed
|
|
|
|
- Review and adjust generated subtasks as necessary
|
|
|
|
- Use `--all` flag to expand multiple pending tasks at once
|
2025-03-21 18:37:24 -04:00
|
|
|
- If subtasks need regeneration, clear them first with `clear-subtasks` command
|
2025-03-21 16:25:12 -04:00
|
|
|
|
|
|
|
- **Implementation Drift Handling**
|
|
|
|
- When implementation differs significantly from planned approach
|
|
|
|
- When future tasks need modification due to current implementation choices
|
|
|
|
- When new dependencies or requirements emerge
|
|
|
|
- Call `node scripts/dev.js update --from=<futureTaskId> --prompt="<explanation>"` to update tasks.json
|
|
|
|
|
|
|
|
- **Task Status Management**
|
|
|
|
- Use 'pending' for tasks ready to be worked on
|
|
|
|
- Use 'done' for completed and verified tasks
|
|
|
|
- Use 'deferred' for postponed tasks
|
|
|
|
- Add custom status values as needed for project-specific workflows
|
|
|
|
|
|
|
|
- **Task File Format Reference**
|
|
|
|
```
|
|
|
|
# Task ID: <id>
|
|
|
|
# Title: <title>
|
|
|
|
# Status: <status>
|
|
|
|
# Dependencies: <comma-separated list of dependency IDs>
|
|
|
|
# Priority: <priority>
|
|
|
|
# Description: <brief description>
|
|
|
|
# Details:
|
|
|
|
<detailed implementation notes>
|
|
|
|
|
|
|
|
# Test Strategy:
|
|
|
|
<verification approach>
|
|
|
|
```
|
|
|
|
|
|
|
|
- **Command Reference: parse-prd**
|
|
|
|
- Syntax: `node scripts/dev.js parse-prd --input=<prd-file.txt>`
|
|
|
|
- Description: Parses a PRD document and generates a tasks.json file with structured tasks
|
|
|
|
- Parameters:
|
|
|
|
- `--input=<file>`: Path to the PRD text file (default: sample-prd.txt)
|
|
|
|
- Example: `node scripts/dev.js parse-prd --input=requirements.txt`
|
|
|
|
- Notes: Will overwrite existing tasks.json file. Use with caution.
|
|
|
|
|
|
|
|
- **Command Reference: update**
|
|
|
|
- Syntax: `node scripts/dev.js update --from=<id> --prompt="<prompt>"`
|
|
|
|
- Description: Updates tasks with ID >= specified ID based on the provided prompt
|
|
|
|
- Parameters:
|
|
|
|
- `--from=<id>`: Task ID from which to start updating (required)
|
|
|
|
- `--prompt="<text>"`: Explanation of changes or new context (required)
|
|
|
|
- Example: `node scripts/dev.js update --from=4 --prompt="Now we are using Express instead of Fastify."`
|
|
|
|
- Notes: Only updates tasks not marked as 'done'. Completed tasks remain unchanged.
|
|
|
|
|
|
|
|
- **Command Reference: generate**
|
|
|
|
- Syntax: `node scripts/dev.js generate`
|
|
|
|
- Description: Generates individual task files in tasks/ directory based on tasks.json
|
|
|
|
- Parameters: None
|
|
|
|
- Example: `node scripts/dev.js generate`
|
|
|
|
- Notes: Overwrites existing task files. Creates tasks/ directory if needed.
|
|
|
|
|
|
|
|
- **Command Reference: set-status**
|
|
|
|
- Syntax: `node scripts/dev.js set-status --id=<id> --status=<status>`
|
|
|
|
- Description: Updates the status of a specific task in tasks.json
|
|
|
|
- Parameters:
|
|
|
|
- `--id=<id>`: ID of the task to update (required)
|
|
|
|
- `--status=<status>`: New status value (required)
|
|
|
|
- Example: `node scripts/dev.js set-status --id=3 --status=done`
|
|
|
|
- Notes: Common values are 'done', 'pending', and 'deferred', but any string is accepted.
|
|
|
|
|
|
|
|
- **Command Reference: list**
|
|
|
|
- Syntax: `node scripts/dev.js list`
|
|
|
|
- Description: Lists all tasks in tasks.json with IDs, titles, and status
|
|
|
|
- Parameters: None
|
|
|
|
- Example: `node scripts/dev.js list`
|
|
|
|
- Notes: Provides quick overview of project progress. Use at start of sessions.
|
|
|
|
|
|
|
|
- **Command Reference: expand**
|
|
|
|
- Syntax: `node scripts/dev.js expand --id=<id> [--num=<number>] [--research] [--prompt="<context>"]`
|
|
|
|
- Description: Expands a task with subtasks for detailed implementation
|
|
|
|
- Parameters:
|
|
|
|
- `--id=<id>`: ID of task to expand (required unless using --all)
|
|
|
|
- `--all`: Expand all pending tasks, prioritized by complexity
|
|
|
|
- `--num=<number>`: Number of subtasks to generate (default: from complexity report)
|
|
|
|
- `--research`: Use Perplexity AI for research-backed generation
|
|
|
|
- `--prompt="<text>"`: Additional context for subtask generation
|
|
|
|
- `--force`: Regenerate subtasks even for tasks that already have them
|
|
|
|
- Example: `node scripts/dev.js expand --id=3 --num=5 --research --prompt="Focus on security aspects"`
|
|
|
|
- Notes: Uses complexity report recommendations if available.
|
|
|
|
|
|
|
|
- **Command Reference: analyze-complexity**
|
|
|
|
- Syntax: `node scripts/dev.js analyze-complexity [options]`
|
|
|
|
- Description: Analyzes task complexity and generates expansion recommendations
|
|
|
|
- Parameters:
|
|
|
|
- `--output=<file>, -o`: Output file path (default: scripts/task-complexity-report.json)
|
|
|
|
- `--model=<model>, -m`: Override LLM model to use
|
|
|
|
- `--threshold=<number>, -t`: Minimum score for expansion recommendation (default: 5)
|
|
|
|
- `--file=<path>, -f`: Use alternative tasks.json file
|
|
|
|
- `--research, -r`: Use Perplexity AI for research-backed analysis
|
|
|
|
- Example: `node scripts/dev.js analyze-complexity --research`
|
|
|
|
- Notes: Report includes complexity scores, recommended subtasks, and tailored prompts.
|
|
|
|
|
2025-03-21 18:37:24 -04:00
|
|
|
- **Command Reference: clear-subtasks**
|
|
|
|
- Syntax: `node scripts/dev.js clear-subtasks --id=<id>`
|
|
|
|
- Description: Removes subtasks from specified tasks to allow regeneration
|
|
|
|
- Parameters:
|
|
|
|
- `--id=<id>`: ID or comma-separated IDs of tasks to clear subtasks from
|
|
|
|
- `--all`: Clear subtasks from all tasks
|
|
|
|
- Examples:
|
|
|
|
- `node scripts/dev.js clear-subtasks --id=3`
|
|
|
|
- `node scripts/dev.js clear-subtasks --id=1,2,3`
|
|
|
|
- `node scripts/dev.js clear-subtasks --all`
|
|
|
|
- Notes:
|
|
|
|
- Task files are automatically regenerated after clearing subtasks
|
|
|
|
- Can be combined with expand command to immediately generate new subtasks
|
|
|
|
- Works with both parent tasks and individual subtasks
|
|
|
|
|
2025-03-21 16:25:12 -04:00
|
|
|
- **Task Structure Fields**
|
|
|
|
- **id**: Unique identifier for the task (Example: `1`)
|
|
|
|
- **title**: Brief, descriptive title (Example: `"Initialize Repo"`)
|
|
|
|
- **description**: Concise summary of what the task involves (Example: `"Create a new repository, set up initial structure."`)
|
|
|
|
- **status**: Current state of the task (Example: `"pending"`, `"done"`, `"deferred"`)
|
|
|
|
- **dependencies**: IDs of prerequisite tasks (Example: `[1, 2]`)
|
2025-03-22 00:02:22 -04:00
|
|
|
- Dependencies are displayed with status indicators (✅ for completed, ⏱️ for pending)
|
|
|
|
- This helps quickly identify which prerequisite tasks are blocking work
|
2025-03-21 16:25:12 -04:00
|
|
|
- **priority**: Importance level (Example: `"high"`, `"medium"`, `"low"`)
|
|
|
|
- **details**: In-depth implementation instructions (Example: `"Use GitHub client ID/secret, handle callback, set session token."`)
|
|
|
|
- **testStrategy**: Verification approach (Example: `"Deploy and call endpoint to confirm 'Hello World' response."`)
|
|
|
|
- **subtasks**: List of smaller, more specific tasks (Example: `[{"id": 1, "title": "Configure OAuth", ...}]`)
|
|
|
|
|
|
|
|
- **Environment Variables Configuration**
|
|
|
|
- **ANTHROPIC_API_KEY** (Required): Your Anthropic API key for Claude (Example: `ANTHROPIC_API_KEY=sk-ant-api03-...`)
|
|
|
|
- **MODEL** (Default: `"claude-3-7-sonnet-20250219"`): Claude model to use (Example: `MODEL=claude-3-opus-20240229`)
|
|
|
|
- **MAX_TOKENS** (Default: `"4000"`): Maximum tokens for responses (Example: `MAX_TOKENS=8000`)
|
|
|
|
- **TEMPERATURE** (Default: `"0.7"`): Temperature for model responses (Example: `TEMPERATURE=0.5`)
|
|
|
|
- **DEBUG** (Default: `"false"`): Enable debug logging (Example: `DEBUG=true`)
|
|
|
|
- **LOG_LEVEL** (Default: `"info"`): Console output level (Example: `LOG_LEVEL=debug`)
|
|
|
|
- **DEFAULT_SUBTASKS** (Default: `"3"`): Default subtask count (Example: `DEFAULT_SUBTASKS=5`)
|
|
|
|
- **DEFAULT_PRIORITY** (Default: `"medium"`): Default priority (Example: `DEFAULT_PRIORITY=high`)
|
|
|
|
- **PROJECT_NAME** (Default: `"MCP SaaS MVP"`): Project name in metadata (Example: `PROJECT_NAME=My Awesome Project`)
|
|
|
|
- **PROJECT_VERSION** (Default: `"1.0.0"`): Version in metadata (Example: `PROJECT_VERSION=2.1.0`)
|
|
|
|
- **PERPLEXITY_API_KEY**: For research-backed features (Example: `PERPLEXITY_API_KEY=pplx-...`)
|
|
|
|
- **PERPLEXITY_MODEL** (Default: `"sonar-medium-online"`): Perplexity model (Example: `PERPLEXITY_MODEL=sonar-large-online`)
|
2025-03-22 00:02:22 -04:00
|
|
|
|
|
|
|
- **Determining the Next Task**
|
|
|
|
- Run `node scripts/dev.js next` to show the next task to work on
|
|
|
|
- The next command identifies tasks with all dependencies satisfied
|
|
|
|
- Tasks are prioritized by priority level, dependency count, and ID
|
|
|
|
- The command shows comprehensive task information including:
|
|
|
|
- Basic task details and description
|
|
|
|
- Implementation details
|
|
|
|
- Subtasks (if they exist)
|
|
|
|
- Contextual suggested actions
|
|
|
|
- Recommended before starting any new development work
|
|
|
|
- Respects your project's dependency structure
|
|
|
|
- Ensures tasks are completed in the appropriate sequence
|
|
|
|
- Provides ready-to-use commands for common task actions
|
|
|
|
|
|
|
|
- **Viewing Specific Task Details**
|
|
|
|
- Run `node scripts/dev.js show --id=<id>` or `node scripts/dev.js show <id>` to view a specific task
|
|
|
|
- Use dot notation for subtasks: `node scripts/dev.js show 1.2` (shows subtask 2 of task 1)
|
|
|
|
- Displays comprehensive information similar to the next command, but for a specific task
|
|
|
|
- For parent tasks, shows all subtasks and their current status
|
|
|
|
- For subtasks, shows parent task information and relationship
|
|
|
|
- Provides contextual suggested actions appropriate for the specific task
|
|
|
|
- Useful for examining task details before implementation or checking status
|
|
|
|
|
|
|
|
- **Managing Task Dependencies**
|
|
|
|
- Use `node scripts/dev.js add-dependency --id=<id> --depends-on=<id>` to add a dependency
|
|
|
|
- Use `node scripts/dev.js remove-dependency --id=<id> --depends-on=<id>` to remove a dependency
|
|
|
|
- The system prevents circular dependencies and duplicate dependency entries
|
|
|
|
- Dependencies are checked for existence before being added or removed
|
|
|
|
- Task files are automatically regenerated after dependency changes
|
|
|
|
- Dependencies are visualized with status indicators in task listings and files
|
|
|
|
|
|
|
|
- **Command Reference: add-dependency**
|
|
|
|
- Syntax: `node scripts/dev.js add-dependency --id=<id> --depends-on=<id>`
|
|
|
|
- Description: Adds a dependency relationship between two tasks
|
|
|
|
- Parameters:
|
|
|
|
- `--id=<id>`: ID of task that will depend on another task (required)
|
|
|
|
- `--depends-on=<id>`: ID of task that will become a dependency (required)
|
|
|
|
- Example: `node scripts/dev.js add-dependency --id=22 --depends-on=21`
|
|
|
|
- Notes: Prevents circular dependencies and duplicates; updates task files automatically
|
|
|
|
|
|
|
|
- **Command Reference: remove-dependency**
|
|
|
|
- Syntax: `node scripts/dev.js remove-dependency --id=<id> --depends-on=<id>`
|
|
|
|
- Description: Removes a dependency relationship between two tasks
|
|
|
|
- Parameters:
|
|
|
|
- `--id=<id>`: ID of task to remove dependency from (required)
|
|
|
|
- `--depends-on=<id>`: ID of task to remove as a dependency (required)
|
|
|
|
- Example: `node scripts/dev.js remove-dependency --id=22 --depends-on=21`
|
|
|
|
- Notes: Checks if dependency actually exists; updates task files automatically
|
2025-03-22 00:51:53 -04:00
|
|
|
|
|
|
|
- **Command Reference: validate-dependencies**
|
|
|
|
- Syntax: `node scripts/dev.js validate-dependencies [options]`
|
|
|
|
- Description: Checks for and identifies invalid dependencies in tasks.json and task files
|
|
|
|
- Parameters:
|
|
|
|
- `--file=<path>, -f`: Use alternative tasks.json file (default: 'tasks/tasks.json')
|
|
|
|
- Example: `node scripts/dev.js validate-dependencies`
|
|
|
|
- Notes:
|
|
|
|
- Reports all non-existent dependencies and self-dependencies without modifying files
|
|
|
|
- Provides detailed statistics on task dependency state
|
|
|
|
- Use before fix-dependencies to audit your task structure
|
|
|
|
|
|
|
|
- **Command Reference: fix-dependencies**
|
|
|
|
- Syntax: `node scripts/dev.js fix-dependencies [options]`
|
|
|
|
- Description: Finds and fixes all invalid dependencies in tasks.json and task files
|
|
|
|
- Parameters:
|
|
|
|
- `--file=<path>, -f`: Use alternative tasks.json file (default: 'tasks/tasks.json')
|
|
|
|
- Example: `node scripts/dev.js fix-dependencies`
|
|
|
|
- Notes:
|
|
|
|
- Removes references to non-existent tasks and subtasks
|
|
|
|
- Eliminates self-dependencies (tasks depending on themselves)
|
|
|
|
- Regenerates task files with corrected dependencies
|
|
|
|
- Provides detailed report of all fixes made
|