--- name: contribute-turbo description: "Submit turbo skill improvements back to the upstream repo. Adapts to repo mode: fork mode creates a PR, source mode pushes directly. Use when the user asks to \"contribute to turbo\", \"submit turbo changes\", \"PR my skill changes\", \"contribute back\", or \"upstream my changes\"." --- # Contribute Turbo Submit staged turbo skill improvements from `~/.turbo/repo/` back to the upstream repo. The workflow adapts based on `repoMode` in `~/.turbo/config.json`. ## Step 1: Verify Contributor Status Read `~/.turbo/config.json` and check `repoMode`: - `"fork"` or `"source"` — proceed - `"clone"` — tell the user that contributions require a fork. Offer to help convert their clone to a fork (add their fork as origin, rename current origin to upstream). Stop. - Missing config or repo — tell the user to run the Turbo setup first. Stop. Verify the repo exists and has the expected remotes: ```bash git -C ~/.turbo/repo remote -v ``` ## Step 2: Mirror Installed Skill Changes Port session corrections from `~/.claude/skills//` (where edits land first) into `~/.turbo/repo/skills//` (the basis for the contribution), leaving any persistent local customizations in the installed copy untouched. Detect drifted skills: ```bash for skill in ~/.claude/skills/*/; do name=$(basename "$skill") repo_dir=~/.turbo/repo/skills/"$name" [ -d "$repo_dir" ] || continue diff -rq "$skill" "$repo_dir" >/dev/null 2>&1 && continue echo "$name" done ``` For each drifted skill, first check whether the repo copy already has unstaged changes for it (`git -C ~/.turbo/repo status --porcelain skills//`). If it does, use `AskUserQuestion` to ask the user how to proceed before mirroring — those changes will conflate with mirrored corrections in Step 3 if not resolved. Then read both versions of every changed file and classify each hunk: - **Correction** — a session edit meant to improve the skill upstream. For modified files, apply each correction hunk with the Edit tool. For new files in the installed copy, create the matching file in the repo copy with the Write tool. For files deleted from the installed copy, remove the repo copy with `rm`. - **Customization** — a persistent local addition that does not belong upstream (extra workflow steps, personal paths, machine-specific notes, internal references). Leave it in the installed copy; do not propagate. - **Ambiguous** — use `AskUserQuestion` to confirm classification before applying. ## Step 3: Review Pending Changes Check what changes exist in the local repo: ```bash git -C ~/.turbo/repo diff --name-only git -C ~/.turbo/repo diff --cached --name-only ``` If there are unstaged changes to skill files, stage the specific skill directories that changed: ```bash git -C ~/.turbo/repo add skills// ``` If there are no changes at all, tell the user there is nothing to contribute and stop. Present the changes in a summary table: ``` | # | Skill | Change Summary | |---|-------|----------------| | 1 | /evaluate-findings | Added handling for security-default findings | | 2 | /self-improve | Clarified routing for trusted reviewer feedback | ``` Use `AskUserQuestion` to confirm which changes to include. If the user deselects some, unstage those files. ## Step 4: Validate Skill Quality Read `~/.turbo/repo/SKILL-CONVENTIONS.md` for the turbo project's skill conventions. These conventions supplement `/create-skill`'s general best practices with turbo-specific patterns. For each confirmed skill, if `/create-skill` has not been invoked for it in this session, run `/create-skill` to review and refine the skill. Any improvements from the review become part of the contribution. ## Step 5: Craft Contribution Context For each change, construct a "why" explanation. The goal: the turbo maintainer should understand what happened and why the existing instructions were insufficient, without learning anything about the contributor's project. Use this template: > During [general workflow description], the skill's instructions [what was missing or wrong]. This caused [what happened]. The change [what it does] so that [benefit]. **Example:** > During a code review session, the evaluate-findings skill encountered a finding with `security-default` severity. The existing instructions only handled `critical`, `high`, `medium`, and `low` severities, causing the finding to be silently dropped. The change adds `security-default` to the severity handling table so these findings are properly triaged. ### Privacy Filter Before finalizing, verify each "why" description contains none of the following: - Project or repo names - File paths from the user's project - Company or product names - API keys, URLs, or credentials - Business logic or domain-specific terminology that identifies the project - User names beyond the contributor's GitHub handle Output the drafted context as text. Then use `AskUserQuestion` for approval. The user must approve the contribution message before proceeding. ## Step 6: Commit Rules Run `/commit-rules` to load commit message rules and technical constraints. ## Step 7: Create Branch and Commit When multiple skills were changed, batch related changes into a single branch and commit. Create separate branches only when changes are independent and unrelated. ### Fork mode Create a feature branch: ```bash git -C ~/.turbo/repo checkout -b improve/- ``` Commit with a message matching the turbo repo style (check `git -C ~/.turbo/repo log -n 10 --oneline`). Incorporate the "why" context in the commit message. ### Source mode Stay on main. Commit directly with the same message style. ## Step 8: Push ### Fork mode Run `/github-voice` to load writing style rules. Push and create a PR: ```bash git -C ~/.turbo/repo push -u origin improve/- ``` Create the PR against the upstream repo: ```bash gh pr create --repo tobihagemann/turbo --head :improve/- --title "..." --body "..." ``` PR body format: ```markdown ## Summary - [1-3 bullet points] ## Context [The crafted "why" explanation from Step 5] ``` Return to main after creating the PR: ```bash git -C ~/.turbo/repo checkout main ``` Report the PR URL. ### Source mode Pull and rebase before pushing to incorporate any upstream changes: ```bash git -C ~/.turbo/repo pull --rebase origin main ``` If the rebase pulled in new commits, run `/update-turbo` to apply upstream changes (skill updates, migrations, config changes) to the local installation before pushing. Then push: ```bash git -C ~/.turbo/repo push origin main ``` Report the pushed commit hash. ## Step 9: Update Config In source mode, update `~/.turbo/config.json` so the next `/update-turbo` does not re-surface the just-pushed changes: 1. Read `~/.turbo/config.json` 2. Set `lastUpdateHead` (add the key if it does not exist) to the current HEAD: `git -C ~/.turbo/repo rev-parse HEAD` 3. Write the updated config back Report that the contribution is complete. Skip this step in fork mode (the upstream has not changed until the PR is merged).