AgentSkillsCN

manage-tasks

在计划中按顺序分解子步骤,有序管理各项实施任务

SKILL.md
--- frontmatter
name: manage-tasks
description: Manage implementation tasks with sequential sub-steps within a plan
user-invocable: false
allowed-tools: Read, Glob, Bash

Manage Tasks Skill

Manage implementation tasks with sequential sub-steps within a plan. Each task references deliverables from the solution document and contains ordered steps for execution.

Implementation Details: See design-for-manage-tasks.md for the complete specification including file format, all commands, parameters, and validation rules.

What This Skill Provides

  • Individual JSON file storage for each task (TOON output for LLM efficiency)
  • Sequential, immutable numbering (TASK-1, TASK-2, etc.)
  • Deliverable references (M:N relationship to solution_outline.md)
  • Delegation context (skill + workflow for execution)
  • Verification commands and criteria
  • Step management with status tracking
  • Simple execution loop via next query

When to Activate This Skill

Activate this skill when:

  • Creating or managing implementation tasks for a plan
  • Querying next actionable task/step
  • Marking steps as started/completed/skipped
  • Tracking implementation progress

Storage Location

Tasks are stored in the plan directory:

code
{plan_dir}/tasks/
  TASK-001-IMPL.json
  TASK-002-IMPL.json
  TASK-003-FIX.json

Filename format: TASK-{NNN}-{TYPE}.json where TYPE is: IMPL, FIX, SONAR, PR, LINT, SEC, DOC


File Format (Summary)

Tasks are stored as JSON and output as TOON (LLM-optimized):

json
{
  "number": 1,
  "title": "Update misc agents to TOON output",
  "status": "pending",
  "phase": "5-execute",
  "domain": "plan-marshall-plugin-dev",
  "profile": "implementation",
  "type": "IMPL",
  "origin": "plan",
  "skills": [
    "pm-plugin-development:plugin-maintain",
    "pm-plugin-development:plugin-architecture"
  ],
  "deliverable": 1,
  "depends_on": [],
  "description": "Migrate miscellaneous agents from JSON to TOON output format.",
  "steps": [
    {"number": 1, "title": "pm-plugin-development/agents/tool-coverage-agent.md", "status": "pending"},
    {"number": 2, "title": "pm-dev-builder/agents/gradle-builder.md", "status": "pending"},
    {"number": 3, "title": "pm-dev-frontend/commands/js-generate-coverage.md", "status": "pending"}
  ],
  "verification": {
    "commands": ["grep -L '```json' {files} | wc -l"],
    "criteria": "No JSON blocks remain",
    "manual": false
  },
  "current_step": 1
}

New Fields:

FieldTypeDescription
domainstringTask domain (arbitrary string, e.g., java, javascript, my-domain)
profilestringTask profile (e.g., implementation, module_testing)
typestringTask type for filename: IMPL, FIX, SONAR, PR, LINT, SEC, DOC
skillslistPre-resolved skills for task execution
originstringTask origin: plan (from task-plan phase) or fix (from verify)

Operations

Script: pm-workflow:manage-tasks:manage-tasks

CommandParametersDescription
add--plan-id + stdinAdd a new task (reads definition from stdin)
update--plan-id --number [--title] [--description] [--depends-on] [--status] [--domain] [--profile] [--skills] [--deliverable]Update task metadata
remove--plan-id --numberRemove a task
list--plan-id [--status] [--phase] [--deliverable] [--ready]List all tasks
get--plan-id --numberGet single task details
next--plan-id [--phase] [--include-context] [--ignore-deps]Get next pending task/step
tasks-by-domain--plan-id --domainList tasks filtered by domain
tasks-by-profile--plan-id --profileList tasks filtered by profile
next-tasks--plan-idGet all tasks ready for parallel execution
finalize-step--plan-id --task --step --outcome [--reason]Complete step with outcome (done/skipped)
add-step--plan-id --task --title [--after]Add step to task
remove-step--plan-id --task --stepRemove step from task

Add Command (stdin-based API)

The add command reads the task definition from stdin in TOON format. Only --plan-id is passed as a CLI argument.

Why stdin? Complex task definitions with verification commands containing shell metacharacters (pipes, wildcards, quotes) caused permission issues when passed as CLI arguments. The stdin approach avoids shell interpretation of these characters.

Stdin format:

toon
title: My Task Title
deliverable: 1
domain: plan-marshall-plugin-dev
profile: implementation
type: IMPL
phase: 5-execute
origin: plan
description: |
  Multi-line task description here.
  Can include any characters.

skills:
  - pm-plugin-development:plugin-maintain
  - pm-plugin-development:plugin-architecture

steps:
  - First step to execute
  - Second step to execute
  - Third step to execute

depends_on: none

verification:
  commands:
    - grep -l '```json' marketplace/bundles/*.md | wc -l
    - mvn verify
  criteria: All grep commands return 0 (no JSON blocks remain)
  manual: false

Required fields: title, deliverable, domain, profile, skills, steps

Optional fields: phase (default: execute), description, depends_on, verification, origin (default: plan)

Field values:

  • deliverable: Single positive integer (one deliverable per task, 1:1 constraint)
  • domain: Domain from references.json (e.g., java, javascript, plan-marshall-plugin-dev)
  • profile: Profile key from marshal.json (e.g., implementation, module_testing)
  • skills: Array of bundle:skill format strings
  • phase: One of init, outline, plan, execute, finalize
  • depends_on: none or task references like TASK-1, TASK-2
  • origin: plan (from task-plan phase) or fix (from verify phase)

List/Next Filters

ParameterDescription
--phaseFilter by plan phase (init/outline/plan/execute/finalize)
--deliverableFilter by deliverable number
--readyOnly tasks with satisfied dependencies
--ignore-deps(next only) Ignore dependency constraints

Quick Examples

Add a task

bash
python3 .plan/execute-script.py pm-workflow:manage-tasks:manage-tasks add \
  --plan-id my-feature <<'EOF'
title: Update misc agents to TOON
deliverable: 1
domain: java
description: |
  Migrate miscellaneous agents from JSON to TOON output format.

steps:
  - file1.md
  - file2.md
  - file3.md

verification:
  commands:
    - mvn verify
  criteria: Build passes
EOF

Add a task with dependencies

bash
python3 .plan/execute-script.py pm-workflow:manage-tasks:manage-tasks add \
  --plan-id my-feature <<'EOF'
title: Write integration tests
deliverable: 3
domain: java-testing
description: Add integration tests for new endpoint

steps:
  - Create test class
  - Add test methods
  - Run tests

depends_on: TASK-1, TASK-2

verification:
  commands:
    - mvn verify -Pintegration
  criteria: All tests pass
EOF

Add a task with complex verification commands (shell metacharacters)

bash
python3 .plan/execute-script.py pm-workflow:manage-tasks:manage-tasks add \
  --plan-id migrate-json-to-toon <<'EOF'
title: Migrate agent outputs to TOON
deliverable: 1
domain: plan-marshall-plugin-dev
description: |
  Update agents to use TOON format instead of JSON.

steps:
  - Update java-implement-agent.md
  - Update java-verify-agent.md
  - Update gradle-builder.md

verification:
  commands:
    - grep -l '```json' marketplace/bundles/pm-dev-java/agents/*.md | wc -l
    - grep -l '```json' marketplace/bundles/pm-dev-builder/agents/*.md | wc -l
  criteria: All grep commands return 0 (no JSON blocks remain)
EOF

Get next task/step (respects dependencies)

bash
python3 .plan/execute-script.py pm-workflow:manage-tasks:manage-tasks next \
  --plan-id my-feature

Get next task in specific phase

bash
python3 .plan/execute-script.py pm-workflow:manage-tasks:manage-tasks next \
  --plan-id my-feature \
  --phase 5-execute

List ready tasks only

bash
python3 .plan/execute-script.py pm-workflow:manage-tasks:manage-tasks list \
  --plan-id my-feature \
  --ready

Finalize step (mark done or skipped)

bash
# Mark step as done
python3 .plan/execute-script.py pm-workflow:manage-tasks:manage-tasks finalize-step \
  --plan-id my-feature \
  --task 2 \
  --step 3 \
  --outcome done

# Skip step with reason
python3 .plan/execute-script.py pm-workflow:manage-tasks:manage-tasks finalize-step \
  --plan-id my-feature \
  --task 2 \
  --step 3 \
  --outcome skipped \
  --reason "File already exists"

Integration Points

With task-plan-agent

Task-plan agents create tasks during plan refinement using heredoc:

bash
python3 .plan/execute-script.py pm-workflow:manage-tasks:manage-tasks add \
  --plan-id {plan_id} <<'EOF'
title: {task_title}
deliverable: {deliverable_number}
domain: {domain}
steps:
  - {step1}
  - {step2}
...
EOF

With plan-execute

Plan-execute iterates through tasks:

code
LOOP:
  1. manage-tasks next --plan-id {plan_id}
  2. IF no next: DONE
  3. SPAWN implement agent
  4. CONTINUE

With implement-agent

Implement agents execute steps:

code
1. manage-tasks get --plan-id {plan_id} --number {N}
2. FOR EACH step: execute → finalize-step --outcome done
3. RUN verification

Deliverable-to-Task Relationship

Tasks reference deliverables from solution_outline.md using the deliverable field in stdin.

Constraint: Each task maps to exactly one deliverable. No aggregation.

PatternDescriptionExample
1:1One task per deliverabledeliverable: 1 - Task implements deliverable 1
1:NOne deliverable, multiple profilesTASK-1-IMPL and TASK-2-TEST both have deliverable: 1

1:N pattern: When a deliverable has multiple profiles (implementation + module_testing), it creates multiple tasks - one per profile. Both tasks reference the same deliverable.


Dependency Management

Tasks can depend on other tasks using the depends_on field in stdin:

yaml
# Task 3 waits for Task 1 and Task 2 to complete
depends_on: TASK-1, TASK-2

# No dependencies
depends_on: none

Dependency enforcement:

  • next command only returns tasks with satisfied dependencies
  • Use --ignore-deps to bypass dependency checking
  • Use --ready filter to list only ready tasks

Blocked output: When tasks are blocked by dependencies, next returns:

toon
next: null
blocked_tasks[2]{number,title,waiting_for}:
1,Write tests,TASK-3
2,Deploy,TASK-3, TASK-4

Phase Filtering

Tasks belong to plan phases: 1-init, 2-refine, 3-outline, 4-plan, 5-execute, 6-verify, 7-finalize

Filter by phase:

bash
# List execute phase tasks only
--phase 5-execute

# Get next task in verify phase
next --phase 6-verify

# Get next task in finalize phase
next --phase 7-finalize

Phase purpose:

  • init: Setup tasks (create directories, configs)
  • outline: Solution outline creation
  • plan: Task planning and skill resolution
  • execute: Implementation tasks (code changes)
  • verify: Quality verification tasks (build, lint, tests)
  • finalize: Shipping tasks (commit, PR, knowledge capture)

Status Model

Task Status: pendingin_progressdone (or blocked)

Step Status: pendingin_progressdone (or skipped)


Related Documents