Claude Code 多仓库同步、跨设备任务传递、模块管理工具。
- 多仓库批量同步——通过 GitHub topic 自动发现仓库,一键 pull/commit/push
- 跨设备配置同步——settings.json、skills、hooks、keybindings 等通过 dotfiles 仓库同步
- 跨设备任务传递——通过 HANDOFF.md 在设备间传递待办任务
- 第三方模块管理——从 GitHub 安装/更新/删除/恢复 skills
- 首次引导向导——交互式 .env 配置,小白也能完成
- 多 workspace 路径支持——仓库分散在不同目录也能统一管理
- Windows:打开 PowerShell,运行:
winget install --id Git.Git -e
- macOS:打开终端(Terminal),运行:
brew install git - Linux:打开终端(Terminal),运行:
sudo apt install git
- Windows:继续在 PowerShell 中运行:
安装后重新打开 PowerShell,输入
winget install --id Python.Python.3.13 -e
python --version确认版本号 >= 3.10 - macOS:继续在 Terminal 中运行:
brew install python - Linux:继续在 Terminal 中运行:
sudo apt install python3
- Windows:继续在 PowerShell 中运行:
winget install --id GitHub.cli -e
- macOS:继续在 Terminal 中运行:
brew install gh - Linux:参考 GitHub CLI 官方文档
安装完成后,继续在同一个 PowerShell(或 Terminal)中运行:
gh auth login按提示选择:GitHub.com → HTTPS → Login with a web browser,然后在浏览器中完成授权。
需要已安装并可正常使用的 Claude Code CLI。如果还没安装,请参考 Claude Code 官方文档。
打开终端(Windows 用 PowerShell 或 Git Bash,macOS/Linux 用 Terminal),运行:
git clone https://github.com/LtxPoi/CC_Sync.git继续在同一个终端中,对每个想同步的仓库运行:
gh repo edit <你的用户名>/<仓库名> --add-topic claude-code-workspace不知道用户名?继续在同一个终端中运行
gh api user -q .login查看。
⚠️ 这一步必须在交互式终端中运行(不是在 Claude Code 里)。Windows 用户请打开 Git Bash,macOS/Linux 用户用 Terminal。
在终端中进入你克隆下来的 CC_Sync 目录并运行(路径根据你实际情况修改):
# Windows 示例(请替换为你的实际路径)
cd /c/Projects/CC_Sync
# macOS/Linux 示例
cd ~/Projects/CC_Sync然后运行:
bash sync.sh首次运行会启动配置向导,依次询问:
问题 1:dotfiles 仓库路径
输入你想用来存放 Claude Code 配置文件的 git 仓库路径。如果还没有,填一个新路径(脚本会自动创建)。
示例:
- Windows:
C:/dotfiles或D:/config/dotfiles - macOS/Linux:
~/dotfiles
Windows 路径不区分大小写(
C:/Dotfiles和c:/dotfiles等效)。
问题 2:是否启用仓库同步?
输入 y 启用。启用后会继续询问:
- 仓库存放路径:输入你平时存代码的目录,多个用
;分隔(如D:/Projects;E:/Work) - GitHub topic 标签:直接按回车使用默认值
claude-code-workspace
配置完成后,脚本会立即执行一次完整同步。
配置完成后,以后的所有操作都在 Claude Code 中完成。
- 打开 Claude Code
- 进入 CC_Sync 目录(如果 CC 不在这个目录,用
cd切换)
直接对 Claude 说:
- “同步”
- “推一下”
- “pull 所有仓库”
- “检查一下各个项目的状态”
或者输入:/sync
Claude 会自动执行同步脚本,然后:
- 展示同步结果汇总(哪些成功、哪些失败、哪些无变化)
- 如果有配置文件冲突,会用选择题问你“保留哪个版本”
- 如果有新仓库,会问你“克隆到哪个目录”
- 如果有跨设备任务(HANDOFF),会自动执行或提示你手动完成
- 如果某个仓库 pull 冲突,会分析差异并建议解决方案
你只需要在 Claude 提问时做决定,其余全自动。
对 Claude 说:
- “查看设备列表”
- “注册新设备 MyLaptop”(名称你自己取,必须唯一)
- “移除设备 OldPC”
对 Claude 说:
- “查看已安装的模块”
- “检查更新”
- “更新所有模块”
- “安装 anthropics/skills 里的 pdf skill”
- “删除 xxx 模块”
- “新设备恢复所有模块”
HANDOFF 是 CC_Sync 的跨设备任务传递机制。当你在 A 设备上需要 B 设备做某件事时,可以通过它留言。
前提:每台设备需要先注册一个唯一名称。 在 Claude Code 中说:
- “注册新设备 HomeMac”
- “注册新设备 OfficePC”
设备名可以是任何英文名称,但必须唯一。建议用能让你一眼认出是哪台电脑的名字,比如
HomeMac、OfficePC、MyLaptop。
留任务: 在 A 设备的 Claude Code 中说:
- “给 OfficePC 留个任务:把 xxx 项目的配置文件复制过来”
- “给 HomeMac 留个任务:运行 pip install requests”
- “所有设备都要做:更新 gh CLI”(写入 ANY section,所有设备都会看到)
接收任务: 在 B 设备的 Claude Code 中运行 /sync 时,Claude 会自动:
- 检测到待办任务
- 向你报告任务内容
- 逐条执行(命令直接运行,需要手动操作的会提示你)
- 完成后自动清除任务
不需要手动编辑任何文件,全部通过自然语言完成。
如果你喜欢直接在终端中操作,以下是完整命令参考。在终端(Git Bash 或 Terminal)中运行:
| 命令 | 说明 |
|---|---|
bash sync.sh |
完整同步 |
bash sync.sh device list |
查看设备 |
bash sync.sh device add <名称> |
注册设备 |
bash sync.sh device remove <名称> |
移除设备 |
bash sync.sh repo-sync enable |
开启仓库同步 |
bash sync.sh repo-sync unignore <名称> |
恢复忽略的仓库 |
bash module-manager.sh list |
查看模块 |
bash module-manager.sh check --all |
检查更新 |
bash module-manager.sh update --all |
更新所有 |
bash module-manager.sh install <source> |
安装模块 |
bash module-manager.sh remove <名称> |
删除模块 |
bash module-manager.sh restore |
新设备恢复 |
首次运行后会在项目根目录生成 .env 文件(已加入 .gitignore,不会被提交):
| 字段 | 说明 | 示例 |
|---|---|---|
DOTFILES_PATH |
dotfiles 仓库路径(必填) | C:/dotfiles |
ENABLE_REPO_SYNC |
是否启用仓库同步 | true 或 false |
WORKSPACE_ROOTS |
仓库存放路径(多个用 ; 分隔) |
D:/Projects;E:/Work |
TOPIC |
GitHub topic 标签 | claude-code-workspace |
CC_Sync/
├── sync.sh # 主脚本
├── module-manager.sh # 模块管理
├── lib/
│ ├── common.sh # 共享 bash 工具
│ ├── handoff.py # HANDOFF.md 解析/写入
│ └── module_helper.py # 模块管理 Python helper
├── HANDOFF.md # 跨设备任务传递
├── CLAUDE.md # Claude Code 项目级指令
├── .env # 本机配置(自动生成,不提交)
├── .sync_ignore # 永久忽略的仓库列表
└── .claude/
├── skills/ # 技能定义(/sync、/module-manager)
└── hooks/ # 会话启动检查
.env 不存在。请在交互式终端(Git Bash 或 Terminal)中运行 bash sync.sh 完成首次配置。Claude Code 的 bash 工具是非交互的,无法运行向导。
gh CLI 不走系统代理。在受限网络环境下,需要在终端(Git Bash 或 Terminal)中手动设置:
export HTTPS_PROXY=http://127.0.0.1:<端口号>Windows 上的 CRLF 幻影改动(行尾符差异),不是真正的内容变更。
- 在终端(PowerShell 或 Git Bash)中克隆:
git clone https://github.com/LtxPoi/CC_Sync.git - 继续在终端中进入目录并运行(路径替换为你的实际位置):
cd /c/Projects/CC_Sync && bash sync.sh(完成向导) - 打开 Claude Code,进入 CC_Sync 目录,说“注册新设备 xxx”
- 继续在 Claude Code 中说“同步”拉取所有配置和代码
- 继续在 Claude Code 中说“恢复所有模块”
VRPSPshinOvO