Claude-skill-registry gsd-add-todo
Capture idea or task as todo from current conversation context
install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/gsd-add-todo" ~/.claude/skills/majiayu000-claude-skill-registry-gsd-add-todo-aa1784 && rm -rf "$T"
manifest:
skills/data/gsd-add-todo/SKILL.mdsource content
<objective>
Capture an idea, task, or issue that surfaces during a GSD session as a structured todo for later work.
Enables "thought → capture → continue" flow without losing context or derailing current work. </objective>
<context> @.planning/STATE.md </context> <process> <step name="ensure_directory"> ```bash mkdir -p .planning/todos/pending .planning/todos/done ``` </step> <step name="check_existing_areas"> ```bash ls .planning/todos/pending/*.md 2>/dev/null | xargs -I {} grep "^area:" {} 2>/dev/null | cut -d' ' -f2 | sort -u ```Note existing areas for consistency in infer_area step. </step>
<step name="extract_content"> **With arguments:** Use as the title/focus. - `{{COMMAND_PREFIX}}add-todo Add auth token refresh` → title = "Add auth token refresh"Without arguments: Analyze recent conversation to extract:
- The specific problem, idea, or task discussed
- Relevant file paths mentioned
- Technical details (error messages, line numbers, constraints)
Formulate:
: 3-10 word descriptive title (action verb preferred)title
: What's wrong or why this is neededproblem
: Approach hints or "TBD" if just an ideasolution
: Relevant paths with line numbers from conversation </step>files
| Path pattern | Area |
|---|---|
, | |
, | |
, | |
, | |
, | |
| |
| |
, | |
| No files or unclear | |
Use existing area from step 2 if similar match exists. </step>
<step name="check_duplicates"> ```bash grep -l -i "[key words from title]" .planning/todos/pending/*.md 2>/dev/null ```If potential duplicate found:
- Read the existing todo
- Compare scope
If overlapping, use AskUserQuestion:
- header: "Duplicate?"
- question: "Similar todo exists: [title]. What would you like to do?"
- options:
- "Skip" — keep existing todo
- "Replace" — update existing with new context
- "Add anyway" — create as separate todo </step>
Generate slug from title (lowercase, hyphens, no special chars).
Write to
.planning/todos/pending/${date_prefix}-${slug}.md:
</step> <step name="update_state"> If `.planning/STATE.md` exists:--- created: [timestamp] title: [title] area: [area] files: - [file:lines] --- ## Problem [problem description - enough context for future Claude to understand weeks later] ## Solution [approach hints or "TBD"]
- Count todos:
ls .planning/todos/pending/*.md 2>/dev/null | wc -l - Update "### Pending Todos" under "## Accumulated Context" </step>
git add .planning/todos/pending/[filename] [ -f .planning/STATE.md ] && git add .planning/STATE.md git commit -m "$(cat <<'EOF' docs: capture todo - [title] Area: [area] EOF )"
Confirm: "Committed: docs: capture todo - [title]" </step>
<step name="confirm"> ``` Todo saved: .planning/todos/pending/[filename][title] Area: [area] Files: [count] referenced
Would you like to:
- Continue with current work
- Add another todo
- View all todos ({{COMMAND_PREFIX}}check-todos)
</step> </process> <output> - `.planning/todos/pending/[date]-[slug].md` - Updated `.planning/STATE.md` (if exists) </output> <anti_patterns> - Don't create todos for work in current plan (that's deviation rule territory) - Don't create elaborate solution sections — captures ideas, not plans - Don't block on missing information — "TBD" is fine </anti_patterns> <success_criteria> - [ ] Directory structure exists - [ ] Todo file created with valid frontmatter - [ ] Problem section has enough context for future Claude - [ ] No duplicates (checked and resolved) - [ ] Area consistent with existing todos - [ ] STATE.md updated if exists - [ ] Todo and state committed to git </success_criteria>