Software_development_department sync-template
install
source · Clone the upstream repo
git clone https://github.com/tranhieutt/software_development_department
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/tranhieutt/software_development_department "$T" && mkdir -p ~/.claude/skills && cp -r "$T/.claude/skills/sync-template" ~/.claude/skills/tranhieutt-software-development-department-sync-template && rm -rf "$T"
manifest:
.claude/skills/sync-template/SKILL.mdsource content
Sync the
.claude/ directory from an upstream template repository into this project.
Determine the upstream URL
If
$ARGUMENTS is provided, use it as the upstream repository URL.
If
$ARGUMENTS is empty, check CLAUDE.md for a line like:
**Template upstream**: <url>
If no URL is found in either place, ask the user:
"What is the upstream template repository URL to sync from? (e.g. https://github.com/owner/repo)"
Do not proceed until a URL is confirmed.
Steps
1. Fetch the upstream template
Run:
SYNC_TMP=$(mktemp -d /tmp/template-sync-XXXXXX) git clone --filter=blob:none --sparse "$UPSTREAM_URL" "$SYNC_TMP" 2>&1 cd "$SYNC_TMP" && git sparse-checkout set .claude
If the clone fails (no internet, repo moved, auth required, etc.) stop immediately and report the error clearly. Do not attempt fallbacks.
2. Show a diff summary
Compare
$SYNC_TMP/.claude/ against the project's .claude/ directory and report:
- New files — present in upstream but not locally (will be added)
- Modified files — present in both but with different content (will be overwritten)
- Local-only files — present locally but not in upstream (will be kept unchanged — these are project-specific customizations)
If there are no differences, say so and skip to clean-up.
3. Ask for confirmation
Present the diff summary and ask:
"Apply these changes from
? Type yes to apply or no to cancel."<upstream-url>
Do not proceed until the user explicitly confirms with "yes".
4. Apply the changes
From the project root, run:
cp -r "$SYNC_TMP/.claude/." .claude/
This will:
- Overwrite files that exist in both upstream and locally
- Add new files from upstream
- Preserve all local-only files (project-specific agents, skills, rules, hooks)
5. Report
List each file that was added or updated, grouped by type:
- Added:
[file list] - Updated:
[file list]
6. Clean up
rm -rf "$SYNC_TMP"
Confirm: "Sync complete. Temp directory removed."
Important constraints
- Never delete local files that don't exist in upstream — they may be project-specific customizations (agents, skills, rules, hooks added after the template was cloned)
- Never modify
,CLAUDE.md
,PRD.md
, or any files outsideTODO.md
— this skill only touches.claude/.claude/ - If the user's
has meaningful customizations to a file that upstream has also changed, flag it specifically: "Note:.claude/
was modified locally — upstream changes will overwrite. Review diff before confirming if you want to preserve local changes."[file]