objective
1
总安装量
1
周安装量
#46849
全站排名
安装命令
npx skills add https://github.com/dagster-io/erk --skill objective
Agent 安装分布
trae
1
droid
1
codex
1
github-copilot
1
Skill 文档
Objective Skill
Overview
Objectives are coordination documents for goals requiring multiple plans/PRs to complete. Unlike erk-plans (single executable implementations), objectives track progress across related work and capture lessons learned along the way.
Scope range:
- Small: Feature requiring 2-3 related PRs
- Medium: Refactor spanning several plans
- Large: Long-running strategic direction emitting many plans
Objective vs Erk-Plan
| Aspect | Erk-Plan | Objective |
|---|---|---|
| Purpose | Single executable implementation | Coordinate 2+ related plans/PRs |
| Scope | One PR or tightly-coupled change | Multiple plans toward coherent goal |
| Body | Machine-parseable metadata | Human-readable markdown |
| Comments | Session context dumps | Action logs + lessons |
| Label | erk-plan |
erk-objective |
| Tooling | erk plan submit/implement |
Manual updates via comments |
Key Design Principles
- Human-first – Plain markdown, no machine-generated metadata
- Incremental capture – Each action gets its own comment
- Lessons as first-class – Every action comment includes lessons learned
- Clear roadmap – Status visible at a glance in the body
- Body stays current – Update body when roadmap status changes
- Steelthread-first – Each phase starts with minimal vertical slice proving the concept works
- One PR per sub-phase – Sub-phases (1A, 1B, 1C) are sized for coherent single PRs
- Always shippable – System remains functional after each merged PR
- Body is source of truth – Body always contains complete current state; comments are the changelog
- Two-step for all changes – Every addition (context, decisions, phases) gets a comment AND body update
- Context over code – Provide references to patterns, not prescriptive implementations
- Session handoff ready – Body should be self-contained for any session to pick up and implement
Quick Reference
Creating an Objective
gh issue create --title "Objective: [Title]" --label "erk-objective" --body "$(cat <<'EOF'
# Objective: [Title]
> [1-2 sentence summary]
## Goal
[What success looks like - concrete end state]
## Design Decisions
1. **[Decision name]**: [What was decided]
## Roadmap
### Phase 1A: [Name] Steelthread (1 PR)
Minimal vertical slice proving the concept works.
| Step | Description | Status | PR |
|------|-------------|--------|-----|
| 1A.1 | [Minimal infrastructure] | pending | |
| 1A.2 | [Wire into one command] | pending | |
**Test:** [End-to-end acceptance test for steelthread]
### Phase 1B: Complete [Name] (1 PR)
Fill out remaining functionality.
| Step | Description | Status | PR |
|------|-------------|--------|-----|
| 1B.1 | [Extend to remaining commands] | pending | |
| 1B.2 | [Full test coverage] | pending | |
**Test:** [Full acceptance criteria]
## Current Focus
**Next action:** [What should happen next]
EOF
)"
Logging an Action
Post an action comment after completing work. See format.md for full template.
gh issue comment <issue-number> --body "$(cat <<'EOF'
## Action: [Brief title]
**Date:** YYYY-MM-DD | **PR:** #123 | **Phase/Step:** 1A.2
### What Was Done
### Lessons Learned
### Roadmap Updates
EOF
)"
After posting, update the issue body (roadmap statuses, “Current Focus”).
Spawning an Erk-Plan
To implement a specific roadmap step, create an erk-plan that references the objective:
erk plan create --title "Implement [step description]" --body "Part of Objective #123, Step 1.2"
Workflow Summary
- Create objective – When starting multi-plan work
- Log actions – After completing each significant piece of work
- Update body – Keep roadmap status current
- Spawn erk-plans – For individual implementation steps
- Close – When goal achieved or abandoned (proactively ask when all steps done)
Resources
references/
format.md– Complete templates, examples, and update patternsworkflow.md– Creating objectives, spawning plans, steelthread structuringupdating.md– Quick reference for the two-step update workflowclosing.md– Closing triggers and procedures