name: dart-branch-cleanup description: "DART Branch Cleanup: analyze or clean stale repository branches"
dart-branch-cleanup
Use this skill in Codex to run the DART dart-branch-cleanup workflow. The editable
workflow source currently lives in .claude/commands/, and this generated
Codex skill is a first-class Codex entrypoint.
Invocation
- Claude Code/OpenCode:
/dart-branch-cleanup <arguments> - Codex:
$dart-branch-cleanup <arguments>
Treat the text after the skill name as $ARGUMENTS. When the workflow
references $1, $2, etc., map those to the positional values supplied by the
user.
Command Body
Analyze or clean branches: $ARGUMENTS
Required Reading
@AGENTS.md @docs/onboarding/ci-cd.md @docs/onboarding/contributing.md
Modes
analyze: inspect only, no deletionsaction: prepare follow-up, or delete only after ownership/safety are clear and the maintainer/user gives explicit approval for each local or remote branch deletion
Default to analyze if the requested mode is ambiguous.
Workflow
git fetch --all --no-prune- List stale remote-tracking refs without deleting them:
Ifgit remote prune origin --dry-runoriginuses SSH and port 22 is unavailable, keep the check read-only and use a temporary HTTPS rewrite instead of changing repository config:
To confirm that a remote PR branch was deleted without updating refs, query GitHub directly over HTTPS:git -c url.https://github.com/.insteadOf=git@github.com: \ fetch --all --no-prune git -c url.https://github.com/.insteadOf=git@github.com: \ remote prune origin --dry-rungit ls-remote --heads https://github.com/dartsim/dart.git <BRANCH> - Determine target branch, usually
origin/main. - For each branch:
git rev-list --left-right --count <TARGET>...<BRANCH> git log --oneline <TARGET>..<BRANCH> git diff --stat <TARGET>..<BRANCH> git cherry -v <TARGET> <BRANCH> - Before any explicitly approved local branch deletion, check whether the
branch is checked out by a linked worktree:
Dirty linked worktrees must not be removed, detached, or reset during branch cleanup. Only after explicit maintainer/user approval, switch that worktree to a preservation branch at the same commit to free the obsolete branch name before deleting the merged branch.git worktree list --porcelain git -C <WORKTREE> status --short --branch - The command
git branch --mergedmay not prove ancestry for PR branches that landed through a squash or merge commit. Use the merged PR state plus an empty tree diff or equivalentgit cherry -voutput as the deletion signal; if the history relationship is unclear, keep the branch. - Classify recommendations only; deleting a candidate requires explicit
maintainer/user approval:
ahead=0: safe deletion candidate- equivalent commits already landed: deletion candidate
- small, current, useful diff: keep or rebase into PR
- large or unclear diff: document follow-up before action
- Ask for explicit maintainer/user approval before pruning refs or deleting any local or remote branch, even when ownership, branch purpose, and remote impact look clear.
Output
- Branch summary with ahead/behind count and last commit date
- Useful commits or risks
- Recommendation: delete, keep, rebase, or needs follow-up
- Actions taken after explicit maintainer/user approval, if action mode was explicitly requested