sync-skills
Skills 同步助手。将本地目录、GitHub 仓库或 skillsmp.com 页面的 skill 同步到用户选择的 AI 编码工具目录。使用 AskUserQuestion 选择目标(支持多选和自定义路径),展示同步计划后执行,同名 skill 会被覆盖。必须包含 ~/.agents/skills 作为同步目标。
Best use case
sync-skills is best used when you need a repeatable AI agent workflow instead of a one-off prompt.
Skills 同步助手。将本地目录、GitHub 仓库或 skillsmp.com 页面的 skill 同步到用户选择的 AI 编码工具目录。使用 AskUserQuestion 选择目标(支持多选和自定义路径),展示同步计划后执行,同名 skill 会被覆盖。必须包含 ~/.agents/skills 作为同步目标。
Teams using sync-skills should expect a more consistent output, faster repeated execution, less prompt rewriting.
When to use this skill
- You want a reusable workflow that can be run more than once with consistent structure.
When not to use this skill
- You only need a quick one-off answer and do not need a reusable workflow.
- You cannot install or maintain the underlying files, dependencies, or repository context.
Installation
Claude Code / Cursor / Codex
Manual Installation
- Download SKILL.md from GitHub
- Place it in
.claude/skills/sync-skills/SKILL.mdinside your project - Restart your AI agent — it will auto-discover the skill
How sync-skills Compares
| Feature / Agent | sync-skills | Standard Approach |
|---|---|---|
| Platform Support | Not specified | Limited / Varies |
| Context Awareness | High | Baseline |
| Installation Complexity | Unknown | N/A |
Frequently Asked Questions
What does this skill do?
Skills 同步助手。将本地目录、GitHub 仓库或 skillsmp.com 页面的 skill 同步到用户选择的 AI 编码工具目录。使用 AskUserQuestion 选择目标(支持多选和自定义路径),展示同步计划后执行,同名 skill 会被覆盖。必须包含 ~/.agents/skills 作为同步目标。
Where can I find the source code?
You can find the source code on GitHub using the link provided at the top of the page.
SKILL.md Source
# Sync Skills
将 skill 从本地目录、GitHub 仓库或 skillsmp.com 页面同步到多个 AI 编码工具目录。
> **🚨 核心要求**:
> 1. **必须包含 `~/.agents/skills`** 作为同步目标(不存在则自动创建)
> 2. **必须使用 AskUserQuestion** 让用户选择目标目录
> 3. **展示同步计划** 并等待用户最终确认
> 4. 同名 skill 直接覆盖,不单独提示
## When to Use
**触发场景:**
- 用户提供本地 skill 文件夹路径
- 用户提供 GitHub 仓库 URL
- 用户提供 skillsmp.com skill 页面 URL
- 需要将 skill 分发到多个 AI 工具目录
**工作流程:**
```
用户输入 → 识别来源类型 → 收集目标目录 → 用户选择目标 → 展示计划 → 用户确认 → 执行同步 → 报告结果
```
## Workflow
### Step 1: 识别来源类型
```bash
# 判断输入类型
if [[ "$input" =~ ^(/|~/|\./) ]]; then
SOURCE_TYPE="local"
SOURCE_PATH="$input"
elif [[ "$input" =~ github\.com ]]; then
SOURCE_TYPE="github"
SOURCE_URL="${input%.git}"
elif [[ "$input" =~ skillsmp\.com ]]; then
SOURCE_TYPE="skillsmp"
SOURCE_URL="$input"
else
echo "❌ 无法识别来源类型"
exit 1
fi
```
### Step 2: 收集目标目录
```bash
# 定义所有可能的目标目录
ALL_TARGETS=(
"$HOME/.agents/skills" # MANDATORY
"$HOME/.claude/skills"
"$HOME/.qoder/skills"
"$HOME/.copilot/skills"
"$HOME/.cursor/skills"
"$HOME/.gemini/skills"
"$HOME/.codex/skills"
"$HOME/.config/opencode/skill"
"$HOME/.codeium/windsurf/skills"
"$HOME/.qwen/skills"
"$HOME/.openclaw/skills"
)
# 确保 ~/.agents/skills 存在
mkdir -p "$HOME/.agents/skills"
# 收集已存在的目录
EXISTING_TARGETS=("$HOME/.agents/skills")
for target in "${ALL_TARGETS[@]:1}"; do
[ -d "$target" ] && EXISTING_TARGETS+=("$target")
done
```
### Step 3: 使用 AskUserQuestion 让用户选择目标
```xml
<parameter name="questions">[
{
"question": "选择要同步到的目标目录(可多选)",
"header": "目标目录",
"multiSelect": true,
"options": [
{
"label": "~/.agents/skills",
"description": "通用技能目录(所有工具共用)",
"markdown": "✅ **必选**"
},
{
"label": "~/.claude/skills",
"description": "Claude Code 技能目录"
},
{
"label": "~/.qoder/skills",
"description": "Qoder 技能目录"
}
// ... 根据实际存在的目录动态生成
]
}
]</parameter>
```
**关键点:**
- `~/.agents/skills` 始终作为第一个选项并标记为必选
- 支持多选
- 用户可通过 "Other" 输入自定义路径
### Step 4: 准备 skill 内容
```bash
case "$SOURCE_TYPE" in
local)
SKILL_NAME=$(basename "$SOURCE_PATH")
SKILL_SOURCE="$SOURCE_PATH"
;;
github)
TEMP_DIR=$(mktemp -d)
git clone -q "$SOURCE_URL" "$TEMP_DIR"
# 查找 SKILL.md 位置
if [ -f "$TEMP_DIR/SKILL.md" ]; then
SKILL_NAME=$(basename "$SOURCE_URL")
SKILL_SOURCE="$TEMP_DIR"
elif find "$TEMP_DIR" -name "SKILL.md" -quit; then
SKILL_SOURCE=$(find "$TEMP_DIR" -name "SKILL.md" -printf "%h" -quit)
SKILL_NAME=$(basename "$SKILL_SOURCE")
fi
;;
skillsmp)
# 抓取并解析页面内容
TEMP_DIR=$(mktemp -d)
# ... 解析逻辑 ...
;;
esac
```
### Step 5: 展示同步计划并等待确认
**将同步计划以清晰格式展示给用户:**
```
📋 同步计划:
来源:$SOURCE_TYPE
Skill:$SKILL_NAME
目标目录(共 $SELECTED_COUNT 个):
1. ~/.agents/skills [新建]
2. ~/.claude/skills [覆盖已有]
3. ~/custom/skills [新建]
⚠️ 同名 skill 将被直接覆盖,不会备份
确认执行?(Y/n)
```
### Step 6: 执行同步
```bash
for target in "${SELECTED_TARGETS[@]}"; do
# 创建目标目录(如不存在)
mkdir -p "$target"
# 删除同名 skill
if [ -d "$target/$SKILL_NAME" ]; then
echo " → 覆盖: $target/$SKILL_NAME"
rm -rf "$target/$SKILL_NAME"
else
echo " → 新建: $target/$SKILL_NAME"
fi
# 复制 skill
cp -r "$SKILL_SOURCE" "$target/"
done
# 清理临时目录
[ -n "$TEMP_DIR" ] && rm -rf "$TEMP_DIR"
```
### Step 7: 报告结果
```
✅ 同步完成!
已成功同步到 $SUCCESS_COUNT 个目录:
✓ ~/.agents/skills
✓ ~/.claude/skills
✓ ~/custom/skills
❌ 失败 $FAIL_COUNT 个目录:
✗ ~/.qoder/skills (权限拒绝)
```
## Reference
### 支持的目标目录
| Tool | User Level |
|------|------------|
| **Agents (Universal)** ⭐ | `~/.agents/skills` **[必选]** |
| Claude Code | `~/.claude/skills` |
| GitHub Copilot | `~/.copilot/skills` |
| Cursor | `~/.cursor/skills` |
| Qoder | `~/.qoder/skills` |
| Gemini CLI | `~/.gemini/skills` |
| OpenAI Codex | `~/.codex/skills` |
| Windsurf | `~/.codeium/windsurf/skills` |
| Qwen Code | `~/.qwen/skills` |
| OpenClaw | `~/.openclaw/skills` |
| OpenCode | `~/.config/opencode/skill` |
### 来源类型识别
```bash
# 本地目录
/path/to/skill
./skill
~/skill
# GitHub URL
https://github.com/user/repo
https://github.com/user/repo.git
git@github.com:user/repo.git
# skillsmp.com URL
https://skillsmp.com/skills/skill-name
```
### AskUserQuestion 完整示例
```xml
<function_calls>
<invoke name="AskUserQuestion">
<parameter name="questions">[
{
"question": "选择要同步到的目标目录(可多选,或选择「其他」输入自定义路径):",
"header": "目标目录选择",
"multiSelect": true,
"options": [
{
"label": "~/.agents/skills",
"description": "通用技能目录(所有工具共用)",
"markdown": "✅ **必选** - 多个 AI 工具共享"
},
{
"label": "~/.claude/skills",
"description": "Claude Code 技能目录"
},
{
"label": "~/.qoder/skills",
"description": "Qoder 技能目录"
}
]
},
{
"question": "同名 skill 将被直接覆盖,是否继续?",
"header": "覆盖策略确认",
"multiSelect": false,
"options": [
{"label": "继续执行", "description": "直接覆盖同名 skill"},
{"label": "取消操作", "description": "取消本次同步"}
]
}
]</parameter>
</invoke>
</function_calls>
```
## Gotchas
| 错误 | 正确做法 |
|------|----------|
| 跳过 `~/.agents/skills` | **始终包含**,不存在则创建 |
| 不使用 AskUserQuestion | **必须使用**让用户选择目标 |
| 不展示同步计划 | **必须展示**并等待用户确认 |
| 同步到不存在的目录 | 先检查 `-d`,不存在则创建 |
| GitHub 仓库结构判断错误 | 先查找 SKILL.md 位置 |
| 忘记清理临时文件 | 始终 `rm -rf /tmp/skill-sync-*` |
| GitHub URL 带 .git 后缀 | 先用 `${url%.git}` 去除 |
| 不处理用户自定义路径 | 通过 "Other" 选项支持 |
> **🚨 最常见错误**:
> 1. 跳过 `~/.agents/skills` - **这是严重错误**
> 2. 不展示同步计划直接执行 - **用户体验差**Related Skills
skill-optimizer
优化和重构现有 skill。用于检查目标 skill 的触发描述、SKILL.md 工作流、确认门槛、渐进式披露,以及 references/scripts/assets 的组织方式。当用户提到“优化 skill”“检查 skill 质量”“改进某个 skill”“重构技能说明”,或直接说明要优化哪些方面时使用。默认先审查、再出计划、等待用户确认后再修改目标 skill。
qoder-wiki
Qoder 官方文档知识库,包含产品介绍、用户指南、功能配置、扩展能力、账户定价和故障排查。当用户询问 Qoder 相关问题(如安装、使用、功能、定价、快捷键、MCP、Skills、Quest Mode、Repo Wiki 等)时使用此 skill。
prompt-optimizer
Prompt 优化助手。适用于用户想优化提示词、改进 AI 指令、为特定任务设计更好的 prompt,或需要选择合适提示框架时使用。会根据任务场景匹配合适框架,必要时先追问关键信息,再输出更清晰、更可执行的提示词版本。
paper-interpreter
论文解读助手。适用于用户发送 arXiv 论文链接,并希望下载论文、解读论文、生成读书笔记、做论文拆解或输出详细报告时使用。会在工作目录创建论文文件夹、下载 PDF 与 TeX Source(如有)、生成中文 Markdown 报告。默认先交付初稿,不自动复查;如果用户明确同意,再安排后续复查。不适用于只要简短推荐语的情况。
opendataloader-pdf
PDF 数据提取工具。当用户提到"PDF 提取"、"PDF 转 Markdown"、"PDF 解析"、"提取 PDF 内容"、"PDF 转 JSON"、"RAG PDF"时使用。OpenDataLoader PDF 是目前基准测试第一的 PDF 解析器,支持本地模式(快速、确定)和混合 AI 模式(复杂表格、扫描件、公式),输出 Markdown、JSON(带边界框)、HTML。适用于需要从 PDF 提取结构化数据用于 RAG/LLM pipeline,或需要批量处理 PDF 文档的场景。
openclaw-wiki
OpenClaw 官方文档知识库。适用于用户询问 OpenClaw 相关问题,如安装、配置、Gateway、WhatsApp/Telegram/Discord 等渠道连接、Sessions、Tools、Skills、Pi Agent、CLI、故障排查等场景。默认先查本地文档,文档不足时再考虑联网补充。
openclaw-session-cleaner
OpenClaw session 清理助手。用于用户提到清理 OpenClaw sessions、删除旧 cron session、压缩或重建 sessions.json、排查 session 文件膨胀时使用。触发后优先检查 ~/.openclaw/agents/main/sessions/ 下的 session 文件数量和 sessions.json 大小,并按指令执行清理。
openclaw-ops
OpenClaw 运维助手。用于用户提到 OpenClaw、小龙虾、gateway、渠道连接、消息发送失败、服务不可达、日志排查、渠道或 Agent 管理时使用。优先执行状态检查与故障分流;涉及重启、修复、更新、配置变更等高影响操作时,先向用户说明再执行。
mermaid
Mermaid 图绘制助手。适用于用户明确要求绘制 Mermaid 图,或提到流程图、架构图、时序图、状态图、甘特图、ER 图、用户旅程图、类图,并希望直接输出 Mermaid 代码块时使用。会先判断最合适的图类型,再生成可渲染、结构清晰的 Mermaid 代码,并在必要时附上简短说明或迭代建议。不适用于追求高保真视觉设计稿的场景。
github-code-interpreter
GitHub 源码解读助手。适用于用户提供 GitHub 仓库链接,并希望解读源码、理解原理、分析架构、生成学习报告或快速上手文档时使用。会在 working 目录下生成源码解读和快速上手两份文档。默认先交付初稿,不自动复查;如果用户明确同意,再安排后续复查。不适用于仅克隆仓库或只要一句简介的场景。
copaw-ops
CoPaw 运维助手。用于用户提到 copaw 运维、服务无响应、渠道断连、MCP 失败、模型调用失败、cron 不执行、Docker 部署、重载、重启或重置恢复时使用。优先执行状态检查与故障分流;涉及重启、重载、重置、配置修改等高影响动作时,先向用户说明再执行。
claudian-installer
Claudian 安装助手。适用于用户想在 Obsidian 仓库中安装 Claudian 插件,或提到“Claudian”“Claude Code in Obsidian”“install Claudian plugin”时使用。会把插件文件复制到目标 vault 并引导用户启用插件。