| name | Lightweight Task Workflow |
| description | FOLLOW THE STATE MACHINE IN SKILL.MD. When user says 'continue': (1) FIRST: Run pwd, (2) Announce STATE: CHECK_STATUS, (3) Read .claude/session.md to check Status field, (4) Route based on Status. NEVER auto-advance tasks. NEVER use TodoWrite. NEVER create git commits. |
| version | 1.0.0 |
Lightweight Task Workflow
π¨ CRITICAL: YOU MUST FOLLOW THE STATE MACHINE BELOW π¨
π¨ EVERY SINGLE MESSAGE MUST START WITH: π΅ STATE: [STATE_NAME] π¨
NOT JUST THE FIRST MESSAGE. EVERY. SINGLE. MESSAGE.
When you read a file - prefix with state. When you run a command - prefix with state. When you explain something - prefix with state. When you ask a question - prefix with state.
Example:
π΅ STATE: WORKING
Reading requirements.md...
π΅ STATE: WORKING
I can see the requirements specify...
π΅ STATE: WORKING
Now running tests...
π΅ STATE: WORKING
Test results show...
This skill is a persistent todo list based on 3 files in .claude/: tasks.md (checklist), requirements.md (specs), session.md (current state).
When user says "continue", you MUST:
- Run
pwdto check current working directory - Announce
π΅ STATE: CHECK_STATUS - Read
.claude/session.mdfrom the current project directory - Follow the state machine below based on the Status field
STATE MACHINE:
user: "continue"
β
ββββββββββββββββββ
βββββ CHECK_STATUS βββββββββββββ¬βββββββββββ
β β Read session.mdβ β β
β ββββββββββ¬ββββββββ β β
β β β β
Status= β β Status= β β
"Complete" β β "in progress" β β
β β β β
β β β β
βββββββββββββ ββββββββββββββββ β β
β AWAITING_ β β WORKING βββββββ β β
β COMMIT β β β β β β
β β β Read: β β β β
β Ask β β requirements β β β β
β permissionβ β tasks.md β β β β
β STOP β β β β β β
βββββββ¬ββββββ β Write: β β β β
β β session.md β β β β
user: yes β ββββββββ¬ββββββββ β β β
β β β β β
β β task done β β β
β β β β β
β β β β β
β ββββββββββββββββ β β β
β β VERIFY β β β β
β β β β β β
β β Run steps β β β β
β β from βββββββ β β
β β requirements β fail β β
β ββββββββ¬ββββββββ β β
β β β β
β β pass β β
β β β β
β β β β
β ββββββββββββββββ β β
β β COMPLETE β β β
β β β β β
β β Write: β β β
β β session.md β β β
β β Status= βββββββββββ β
β β "Complete" β β
β ββββββββββββββββ β
β β
β β
ββββββββββββββββββββ β
β MARK_TASK_ β β
β COMPLETE β β
β β β
β Write: tasks [x] β β
β Write: session.mdββββββββββββββββββββββββββββββββ
β (next task) β
ββββββββββββββββββββ
π¨ STATE DEFINITIONS - FOLLOW EXACTLY π¨
CHECK_STATUS:
ACTIONS:
1. Run pwd
2. Read .claude/session.md
3. Look at Status field
4. IF Status="Complete" OR "ready to commit" β Go to AWAITING_COMMIT
5. IF Status="in progress" OR missing β Go to WORKING
DO NOT: Read other files, launch agents, do anything except route
IF ERROR: STOP and tell user what failed
AWAITING_COMMIT:
ACTIONS:
1. Say: "Task X is complete. May I mark Task X as complete in tasks.md?"
2. STOP - wait for user response
3. IF user says yes β Go to MARK_TASK_COMPLETE
4. IF user says no β STOP, await further instruction
DO NOT: Read files, launch agents, work on next task, do anything except ask permission and STOP
IF ERROR: STOP and tell user what failed
MARK_TASK_COMPLETE:
ACTIONS:
1. Write tasks.md: Change [ ] to [x] for current task
2. Write session.md: Update to next task with Status="in progress"
3. Go to CHECK_STATUS
DO NOT: Read other files, launch agents, research next task
IF ERROR (e.g., plan mode, can't write): Say "I cannot edit files: [reason]" and STOP
NEVER try alternative actions if write fails
WORKING:
REMINDER: EVERY message in this state must start with: π΅ STATE: WORKING
ACTIONS:
1. Read requirements.md
2. Read tasks.md
3. Work on current task
4. Update session.md after TDD cycles
5. When task done β Go to VERIFY
EVERY message you send while WORKING must have the state prefix.
When you read a file β prefix with state
When you run tests β prefix with state
When you explain results β prefix with state
DO NOT: Skip to next task, work on multiple tasks
IF ERROR: Document in session.md as blocker, STOP
VERIFY:
REMINDER: EVERY message in this state must start with: π΅ STATE: VERIFY
ACTIONS:
1. Read Verification section from requirements.md
2. Run all verification commands
3. IF all pass β Go to COMPLETE
4. IF any fail β Go to WORKING (treat as blocker)
EVERY message you send while VERIFYING must have the state prefix.
DO NOT: Skip verification, claim complete without running checks
IF ERROR running verification: STOP and tell user
COMPLETE:
ACTIONS:
1. Write session.md: Set Status="Complete"
2. Go to CHECK_STATUS
DO NOT: Read files, launch agents, ask permission (that happens in AWAITING_COMMIT)
IF ERROR writing: STOP and tell user
CRITICAL: State Announcements
ALL messages MUST be prefixed with your current state.
Format:
**π΅ STATE: [STATE_NAME]**
[Your message here]
When transitioning:
**π’ TRANSITION: [STATE_A] β [STATE_B]**
Example:
**π΅ STATE: CHECK_STATUS**
Reading session.md to check current task status...
**π’ TRANSITION: CHECK_STATUS β AWAITING_COMMIT**
**π΅ STATE: AWAITING_COMMIT**
Task 2 is complete and ready for you to commit. May I mark Task 2 as complete in tasks.md?
When to Use This Skill
Activate when the user:
- Says "create a plan", "setup tasks", "new task list"
- Says "continue", "continue plan", "resume work", "where were we"
- Is working on multi-step projects that span multiple sessions
β οΈ CRITICAL: Task Management System
THIS SKILL REPLACES Claude Code's built-in TodoWrite functionality.
NEVER use the following tools:
- β TodoWrite
- β TodoRead
- β Any built-in todo/task tracking features
ALWAYS use this skill's files instead:
- β
.claude/tasks.mdfor task checklists - β
.claude/requirements.mdfor plans and implementation specs - β
.claude/session.mdfor session context and recovery
Why this matters: Using TodoWrite creates workflow conflicts. The built-in todo system stores tasks in internal state (not visible as files), causing the plan to be lost in chat history instead of persisted in .claude/requirements.md. This prevents session continuity and defeats the purpose of this skill.
If you find yourself wanting to use TodoWrite, STOP and use this skill's files instead.
Files This Skill Manages
IMPORTANT PATH GUIDANCE:
- This skill's definition files (SKILL.md, CLAUDE.md, README.md) live in
~/.claude/skills/lightweight-task-workflow/ - The task files are created in THE PROJECT'S .claude/ directory, NOT the skill directory
- Example: If working on project
<project-root>/, task files go in<project-root>/.claude/ - Always use relative paths from the project root:
./.claude/tasks.md,./.claude/requirements.md,./.claude/session.md - NEVER read from
~/.claude/skills/lightweight-task-workflow/tasks.md(that's the skill directory, not the project directory)
.claude/tasks.md - the task checklist (in the PROJECT directory)
- [ ] Task 1: Extract UserService
- [x] Task 2: Add tests
.claude/requirements.md - implementation specs and guidelines
## Global Guidelines
- Preserve existing API contracts - no breaking changes
- Add logging for error cases
- Follow repository's existing code style
## Verification & Definition of Done
Before marking any task complete, the following must pass:
- `npm test` - all tests must pass
- `npm run lint` - no lint errors
- `npm run build` - build must succeed
## Task 1: Extract UserService
- Move all user-related methods from AppService to new UserService
- Keep existing method signatures for backward compatibility
- Update dependency injection in app.module.ts
## Task 2: Add tests
- Cover happy path and error cases
- Include edge cases for null/undefined inputs
- Mock external dependencies
.claude/session.md - session recovery context
**Current Task:** Task 3
**Status:** in progress
## What's Done
- Task 1: Extracted UserService (commit a1b2c3d)
- Task 2: Added tests (commit e4f5g6h)
## Next Steps
1. Finish Task 3: Update documentation
## Context
- Using yarn for builds
- Commands: ./verify.sh
Behavior
When User Says "Create a Plan" or "Setup Tasks"
FIRST: Remember you are NOT using TodoWrite. Use this skill's .claude/ files exclusively.
- Ask user to describe their tasks
- Ask user about implementation approach:
- "What requirements or guidelines should I know for implementing these tasks?"
- "Are there testing/quality standards I should follow?"
- "Any architectural constraints or patterns to follow?"
- "What verification must pass before marking a task complete?" (e.g., npm test, ./verify.sh, build, lint, manual review)
- Capture their answers - these become the implementation specs
- Create
.claude/tasks.mdwith numbered checklist - format:- [ ] Task 1: [exact user wording],- [ ] Task 2: [exact user wording], etc. - Create
.claude/requirements.mdwith:- Global Guidelines section (testing, commands, patterns)
- Verification & Definition of Done section (commands/checks that must pass)
- Per-task requirements (one section per task with specs)
- Create
.claude/session.mdinitialized to Task 1 with Status="in progress" - Confirm setup complete
After setup: You enter the state machine at CHECK_STATUS with session.md showing Task 1 Status="in progress"
When User Says "Continue" or "Resume"
Start at CHECK_STATUS state: Read session.md and route based on Status field. Follow the state machine at the top of this file.
What to Track in requirements.md
Include: Global guidelines, Verification & Definition of Done (user can edit anytime), per-task requirements, learnings/edge cases discovered.
NOT for: Progress notes, debugging notes, code changes (that's git).
What to Track in session.md
Update at 4 triggers: (1) Start task, (2) End of TDD cycle (one line), (3) Hit blocker, (4) Complete task.
Include: Current task/status, completed tasks with commits, brief progress notes, blockers, next steps.
NOT for: Every change, file paths, verbose explanations.
Anti-Patterns: What NOT to Do
β WRONG: Investigating Codebase to Figure Out Progress
User: "continue"
Claude: *Reads tasks.md*
Claude: "Let me investigate the codebase to understand what's already been done"
Claude: *Searches through 10+ files, runs git log, checks test files*
Claude: *Wastes 2 minutes and 5000 tokens figuring out current state*
Claude: "I can see Task 1 was completed, let me start on Task 2..."
Problem: Wasted time and tokens. All that information was already in session.md.
β RIGHT: Reading session.md to Know Current State
User: "continue"
Claude: *Runs pwd*
Claude: "π΅ STATE: CHECK_STATUS"
Claude: *Reads session.md FIRST*
Claude: "Status shows 'in progress'. Routing to WORKING."
Claude: "π’ TRANSITION: CHECK_STATUS β WORKING"
Claude: "π΅ STATE: WORKING"
Claude: "Continuing Task 2: Add email validation..."
Result: Instant context, no wasted time, exactly where to resume. That's the whole point of session.md.
β WRONG: Skipping Verification
Claude: *Completes task implementation*
Claude: "Task 1 is complete and ready for you to commit"
Claude: "May I mark this task as complete?"
*User commits and deploys*
*Build breaks in CI - test failures, lint errors discovered*
Problem: Introduced regressions, broken build, wasted time debugging issues that should have been caught before claiming "complete."
β RIGHT: Running Verification Before Completion
Claude: *Completes task implementation*
Claude: *Reads requirements.md Verification section*
Claude: *Runs npm test* β All pass β
Claude: *Runs npm run lint* β All pass β
Claude: *Runs npm run build* β Success β
Claude: *Updates session.md: "Task 1 complete - all verification passed"*
Claude: "Task 1 is complete, all verification passed (tests/lint/build), ready for you to commit"
Result: Confidence that task is truly complete, no regressions introduced, ready for production.
β WRONG: Creating Git Commits
Claude: *Completes task implementation*
Claude: *Runs git add .*
Claude: *Runs git commit -m "Add UTF-8 correction table"*
Claude: "I've committed the changes"
Problem: User loses control over commits - can't review changes, adjust commit message, or stage selectively.
β RIGHT: Handing Off for User to Commit
Claude: *Completes task implementation*
Claude: *Updates .claude/session.md: "Task 1 complete - UTF-8 correction ready for commit"*
Claude: "Task 1 is complete and ready for you to commit. The changes include..."
Claude: "May I mark this task as complete in tasks.md?"
Result: User reviews changes, creates commit with their preferred message and staging, maintains full git control.
β WRONG: Auto-Advancing to Next Task
Claude: "Task 1 is complete, verification passed, ready for you to commit"
Claude: "May I mark this task as complete?"
Claude: "Let me explore the codebase to understand Task 2: Add email validation..."
Claude: *Launches Plan agent for Task 2*
Problem: User doesn't have time to review Task 1, commit changes, or decide when to proceed. Claude rushes ahead without permission.
β RIGHT: Stopping After Task Complete
Claude: "Task 1 is complete, verification passed, ready for you to commit"
Claude: "May I mark this task as complete in tasks.md?"
Claude: *Waits for user response*
User: *Reviews changes, creates commit*
User: "continue"
Claude: *Reads session.md, sees Status="Complete", routes to AWAITING_COMMIT*
Claude: "Task 1 is complete. May I mark it [x]?"
User: "yes"
Claude: *Updates tasks.md, updates session.md to Task 2 Status="in progress"*
User: "continue"
Claude: *Reads session.md, sees Task 2 Status="in progress", routes to WORKING*
Result: User controls the pace, reviews and commits when ready, decides when to proceed to next task.
Troubleshooting: Common Path Mistakes
Symptom: "Error reading file" when trying to continue tasks
Likely cause: You're looking in the skill directory instead of the project directory
Fix:
- Run
pwdto check current working directory - Look for
.claude/subdirectory in the project root - Read from
./.claude/tasks.md, NOT~/.claude/skills/lightweight-task-workflow/tasks.md - Remember: skill definition β task files
Example:
- β WRONG: Reading
~/.claude/skills/lightweight-task-workflow/tasks.md(skill directory) - β
RIGHT: Reading
./.claude/tasks.mdor<project-root>/.claude/tasks.md(project directory)
Important Rules
- ALWAYS prefix EVERY SINGLE MESSAGE with your state - Not just when entering a state. EVERY message. When you read a file, when you run a command, when you explain something - ALL messages start with
π΅ STATE: [STATE_NAME] - ALWAYS run pwd first - Check current working directory before reading files
- ALWAYS follow the state machine - Start at CHECK_STATUS, route based on Status field from session.md
- NEVER use TodoWrite, TodoRead, or Claude Code's built-in todo features - This skill replaces them entirely
- NEVER create git commits - User handles all commits
- NEVER auto-advance to next task - STOP and wait for user
- ALWAYS run verification from requirements.md before claiming complete
- ALWAYS read task files from PROJECT's
.claude/directory, not skill directory - Preserve user's exact wording when creating tasks
- Always ask permission before marking tasks complete
- Update requirements.md when discovering new constraints