taskwarrior-plugin/skills/task-release/SKILL.md
Release a taskwarrior task without closing it — stops +ACTIVE clock and annotates state for handoff. Use when pausing mid-task, handing off to another agent, or aborting cleanly.
npx skillsauth add laurigates/claude-plugins task-releaseInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Release an active claim without closing the task. Pairs with /taskwarrior:task-claim: claim picks the task up, release puts it back down.
| Use this skill when... | Use a sibling skill instead when... |
|---|---|
| Pausing a task mid-flight (lunch break, context switch, end of session) | The work has landed in a commit — use /taskwarrior:task-done |
| Handing off to another agent — leaving an annotation describing where you stopped | Starting work on a fresh task — use /taskwarrior:task-claim |
| Aborting a started task because scope was wrong | Filing a brand-new task to capture the work — use /taskwarrior:task-add |
task --versionfind . -maxdepth 1 -name '.git' -print -quitGit probes (git rev-parse --show-toplevel, git branch --show-current)
write to stderr in a no-git cwd, and stderr from a Context backtick
aborts the skill before its body runs. Git toplevel and current-branch
resolution are done in the body via the Bash tool (where 2>/dev/null
and exit-code handling are tolerated).
Parse $ARGUMENTS:
$0 — task ID (required).--clear-identity — clear agent / host / branch / worktree UDAs in addition to pid. Use when the next agent should not inherit any context (e.g. cross-host handoff). Default behaviour preserves these so the queue still shows who last touched the task.--no-coworker-marker — skip the /git:coworker-check --release step. By default, releasing the task also drops the git-side session marker so destructive ops in this clone are no longer guarded.Execute this release workflow:
task "$TASKID" export | jq '.[0] | {id, description, status, start, agent, pid, host, branch, worktree, annotations}'
Use export | jq — never info / list. Decide:
| Condition | Action |
|---|---|
| status is not pending | Abort. Released tasks must be pending; if it is already closed, the release is a no-op. |
| start is unset (not +ACTIVE) | Warn but proceed — annotation + UDA drain still useful as a "I looked at this" signal. |
| start is set | Standard path. Continue. |
If the user did not pass a message, ask them for one with a single AskUserQuestion. The annotation is the handoff payload — without it the next agent has only timestamps. Keep the prompt focused: "Where did you stop? (one sentence)".
Annotate before stopping — if the stop fails (e.g. concurrent modify), the annotation is still captured:
task "$TASKID" annotate "released by $AGENT — state: $MESSAGE"
$AGENT is read from the task's existing agent UDA (the claim stamped it); fall back to claude-${CLAUDE_SESSION_ID:0:8} if unset.
task "$TASKID" stop
This clears the built-in start attribute and removes the +ACTIVE virtual tag. The task is back in the dispatch pool for /taskwarrior:task-coordinate.
Always clear pid (the process is going away):
task "$TASKID" modify pid:
When --clear-identity is passed, also clear the rest:
task "$TASKID" modify agent: host: branch: worktree:
The empty-value field: syntax removes a UDA in taskwarrior. Default behaviour keeps agent / host / branch / worktree so task-status "Recently touched" can attribute the work.
Unless --no-coworker-marker was passed:
Use SlashCommand to invoke `/git:coworker-check --release`.
Fallback if SlashCommand is unavailable:
bash "$(git rev-parse --show-toplevel)/git-plugin/skills/git-coworker-check/scripts/release-session.sh" --project-dir "$(pwd)"
Print:
start timestamp to now — read before stopping)pid only / full drain/taskwarrior:task-coordinate to dispatch the now-unclaimed work onto the next wave/taskwarrior:task-claim <id> to re-claim later| Context | Command |
|---|---|
| Read existing claim before release | task _get "$TASKID".agent (single-field, exit 0 even when unset) |
| Time-spent computation | task "$TASKID" export \| jq '.[0].start' then compute against now |
| Bulk release of stale claims | Pair with task +ACTIVE start.before:now-4h export \| jq '.[].id' |
| Skip empty-result failures | Always export \| jq, never task active list |
| Step | Command |
|---|---|
| Annotate | task ID annotate "released by AGENT — state: MSG" |
| Stop active | task ID stop |
| Clear pid | task ID modify pid: |
| Full identity drain | task ID modify agent: host: branch: worktree: pid: |
| Drop git marker | /git:coworker-check --release |
/taskwarrior:task-claim — pair: pick up an unclaimed task/taskwarrior:task-done — close after landing (also auto-stops + drains identity)/taskwarrior:task-coordinate — finds the next dispatch candidate/git:coworker-check — sister marker that this skill drops on --release.claude/rules/agent-coworker-detection.md — combined-signal rationaletesting
Verify accumulated bug claims at upstream HEAD and dedup against trackers before filing issues. Use when filing upstream reports from backlogs, audit docs, or git-history findings.
documentation
Gate outward-bound text (upstream issues, docs, PR bodies) through isolated haiku fresh-reader critique before publishing. Use when an artifact must survive a reader with zero project context.
tools
Suggest improvements to SKILL.md content, descriptions, or tool config from eval results. Use when raising pass rates, fixing triggering, or iterating on a skill after evaluation.
tools
deadbranch CLI for stale-branch cleanup — dry-run preview, TUI or non-interactive delete, protects main/develop/WIP. Use when asked to clean up branches, prune branches, or remove stale branches.