Skills install-bensz-skills
当需要把本仓库 pipelines/skills 下的所有 skills 安装到系统级(默认同时安装到 Codex: ~/.codex/skills 和 Claude Code: ~/.claude/skills),以便在任意项目/对话中可被发现与调用时使用。使用 MD5 哈希进行版本控制,仅安装有更新的 skills;支持强制覆盖安装、指定单一目标安装和远程安装模式(--remote --check/--auto)。
install
source · Clone the upstream repo
git clone https://github.com/huangwb8/skills
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/huangwb8/skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/install-bensz-skills" ~/.claude/skills/huangwb8-skills-install-bensz-skills && rm -rf "$T"
manifest:
install-bensz-skills/SKILL.mdsource content
Install Bensz Skills(系统级安装器)
与 bensz-collect-bugs 的协作约定
- 因本 skill 设计缺陷导致的 bug,先用
规范记录到bensz-collect-bugs
,不要直接修改用户本地已安装的 skill 源码;若有 workaround,先记 bug,再继续完成任务。~/.bensz-skills/bugs/ - 只有用户明确要求“report bensz skills bugs”等公开上报时,才用本地
上传新增 bug 到gh
;不要 pull / clone 整个仓库。huangwb8/bensz-bugs
目的:把当前仓库
pipelines/skills/ 中的所有 skills(包括 install-bensz-skills 自身)复制安装到:
- Codex:
~/.codex/skills/ - Claude Code:
~/.claude/skills/
从而让这些 skills 在任意项目里都能被发现与触发(不依赖当前 workdir,也不使用软链接)。
安装模式
本地安装模式(默认)
直接从本地仓库安装 skills。
远程安装模式
从远程 GitHub 仓库下载并安装 skills,支持交互式确认和自动强制安装。
远程安装前置条件
- 本地已安装 Git(
可用)git --version - 具备 PyYAML 依赖(
)python3 -m pip install pyyaml
你要做的事(触发后必须执行)
执行时不要先做
test -f ./install-bensz-skills/... 之类的“脚本存在性检测”。直接运行安装脚本即可;若当前项目目录没有 install-bensz-skills/,就改用系统级已安装位置(~/.codex/skills/ 或 ~/.claude/skills/)的脚本运行,并在需要时用 --source 显式指定源目录。
本地安装
- 运行安装脚本:
# 默认:同时安装到 Codex 和 Claude Code(仅安装有更新的) # 说明:脚本会优先从当前目录自动识别 skills 源目录(支持 ./pipelines/skills、./skills、或当前目录本身) python3 install-bensz-skills/scripts/install.py # 仅安装到 Claude Code python3 install-bensz-skills/scripts/install.py --claude # 仅安装到 Codex python3 install-bensz-skills/scripts/install.py --codex # 强制重新安装所有 skills(忽略版本检查) python3 install-bensz-skills/scripts/install.py --force # 预览模式(不实际安装) python3 install-bensz-skills/scripts/install.py --dry-run # 指定额外 skills 源目录 python3 install-bensz-skills/scripts/install.py --source /path/to/skills # 多个源目录(逗号分隔) python3 install-bensz-skills/scripts/install.py --source /path/skills-a,/path/skills-b
如果你在某个项目目录里只有
skills/(没有 install-bensz-skills/),但安装器已被系统级安装(通常在 ~/.codex/skills/ 或 ~/.claude/skills/),可直接运行系统级脚本:
# Codex 安装位置(优先) python3 ~/.codex/skills/install-bensz-skills/scripts/install.py # 或 Claude Code 安装位置 python3 ~/.claude/skills/install-bensz-skills/scripts/install.py # 若无法自动识别源目录,则显式指定 python3 ~/.codex/skills/install-bensz-skills/scripts/install.py --source ./skills
远程安装
交互式检查模式(
--remote --check):
# 检查并交互式安装远程技能 python3 install-bensz-skills/scripts/install.py --remote --check # 仅对 Claude Code 执行远程检查 python3 install-bensz-skills/scripts/install.py --remote --check --claude # 仅对 Codex 执行远程检查 python3 install-bensz-skills/scripts/install.py --remote --check --codex
流程:
- 创建临时目录
~/.bensz-skills/installation/tmp-remote-install - 询问是否安装每个远程源(根据配置文件)
- 下载远程技能到临时目录
- 与本地已安装技能对比,生成更新报告
- 询问是否确认安装/更新
- 执行安装/更新
- 清理临时目录
自动强制模式(
--remote --auto):
# 自动下载并强制安装所有远程技能(无确认) python3 install-bensz-skills/scripts/install.py --remote --auto # 仅对 Claude Code 执行自动安装 python3 install-bensz-skills/scripts/install.py --remote --auto --claude
流程:
- 创建临时目录
- 直接下载所有远程技能(无确认)
- 强制安装/更新(无对比,无确认)
- 清理临时目录
Legacy 技能清理
安装前会先读取
install-bensz-skills/config.yaml 中的 legacy_skill_names,并从 ~/.codex/skills/ / ~/.claude/skills/ 删除这些已弃用旧名,避免 skill 改名后旧目录继续留在系统级目录里干扰触发。
如果只想单独执行清理,可直接运行:
python3 install-bensz-skills/scripts/remove_legacy_skills.py python3 install-bensz-skills/scripts/remove_legacy_skills.py --codex python3 install-bensz-skills/scripts/remove_legacy_skills.py --claude --dry-run
验证
建议在任意其它目录执行:
codex exec "列出所有可用的技能"
MD5 版本控制机制
脚本使用 MD5 哈希值进行智能版本控制:
- 版本计算:对 skill 目录内的可安装文件进行 MD5 计算(排除
、tests/
、缓存与临时文件,以及 skill 根目录下给人看的plans/
/README.md
)CHANGELOG.md - 版本存储:安装后在目标目录生成平台特定 manifest(
)记录版本信息.skill-manifest.{codex,claude}.json - 智能安装:
- ✅ 已安装且版本未变:跳过,不重复安装
- ✅ 版本已变化:强制覆盖安装
- ✅ 新 skill:直接安装
安装报告示例
============================================================ 📦 正在安装到 CLAUUDE: /Users/xxx/.claude/skills ============================================================ 【安装过程】 ──────────────────────────────────────────────────────────── installed: /Users/xxx/.claude/skills/nsfc-bib-manager 【安装摘要】 ──────────────────────────────────────────────────────────── ┌────────────────────────┬──────────────┬─────────────────┐ │ Skill 名称 │ 状态 │ 原因 │ ├────────────────────────┼──────────────┼─────────────────┤ │ nsfc-bib-manager │ ✅ 已安装 │ 版本已更新... │ │ git-commit │ ⏭️ 跳过 │ 版本未变化 │ └────────────────────────┴──────────────┴─────────────────┘ 【辅助技能(已忽略,仅用于开发)】(1 个) • install-bensz-skills ⏭️ 跳过 ──────────────────────────────────────────────────────────── 📊 统计 ──────────────────────────────────────────────────────────── 普通技能: 1 个已安装, 1 个跳过 ============================================================ 🎯 总体安装摘要 ============================================================ 总计数: • 已安装/更新: 1 个 • 跳过: 1 个
注:完整报告格式规范见 references/install-report-template.md。
安装策略(脚本保证)
- 仅安装"包含
的目录"(即每个 skill 的根目录)。SKILL.md - skill 根目录下的
、README.md
不会被复制到系统级目录,避免把面向人的说明文档带进 AI 的技能上下文。CHANGELOG.md - 技能类型控制:通过 SKILL.md 中的
字段控制(category
可安装,normal
和auxiliary
不安装)。test - MD5 版本检查:优先检查
,回退到重新计算.skill-manifest.{codex,claude}.json - 直接替换:发现到目标路径已存在同名目录且版本变化时,直接删除旧版本并安装新版本(不备份)
- 理由:Git 已提供版本控制,可随时回退;新版本通常比旧版本更好
- 若存在旧的
软链接:会移除该软链接(不删除真实目录)。pipeline-skills - 若
声明了config.yaml
:安装前会先删除这些已弃用旧 skill 名称对应的系统级目录。legacy_skill_names
命令行参数
本地安装参数
| 参数 | 说明 |
|---|---|
| 预览模式,不实际写入文件 |
| 仅安装到 Codex |
| 仅安装到 Claude Code |
| 强制重新安装所有 skills(忽略 MD5 检查) |
| 指定额外的 skills 源目录路径 |
远程安装参数
| 参数 | 说明 |
|---|---|
| 启用远程安装模式(必须与 或 一起使用) |
| 检查模式(交互式确认后再安装) |
| 自动模式(强制安装,无需确认) |
| 仅安装指定远程源(如 、) |
参数组合:
:交互式远程安装--remote --check
:自动强制远程安装--remote --auto
:仅对 Codex 执行远程检查--remote --check --codex
:仅对 Claude Code 执行远程检查--remote --check --claude
:仅检查并安装 general 源--remote --check --general
远程源配置
远程技能源通过
config.yaml 配置文件定义:
# install-bensz-skills/config.yaml remote_sources: - id: "general" name: "通用技能" url: "https://github.com/huangwb8/skills" branch: "main" skills_path: "." description: "通用技能,建议所有用户安装" recommended: true - id: "research" name: "科研技能" url: "https://github.com/huangwb8/ChineseResearchLaTeX" branch: "main" skills_path: "skills" description: "科研相关技能,建议有科研需要的用户安装" recommended: false legacy_skill_names: - "make_latex_model" - "transfer_old_latex_to_new" - "write-paper-sci" - "explain-figures"
配置字段说明:
:源 ID(用于id
过滤)--{id}
:源名称(用于显示和提示)name
:Git 仓库 URLurl
:分支名称(默认branch
)main
:技能目录相对于仓库根目录的路径skills_path
如果远程仓库的根目录本身就是 skills 根目录,
skills_path 应写为 .。
:源描述(用于提示用户)description
:是否推荐安装(影响默认提示行为)recommended
:需要从系统级目录主动清理的旧 skill 名称列表legacy_skill_names
常见问题
本地安装
- 如果你刚更新了本仓库的技能:再次触发本 skill 运行脚本即可完成系统级更新(仅安装有变化的)。
- 需要强制重装:使用
参数。--force - Claude Code / Codex 都需要新会话才会重新加载更新后的技能;安装后建议新建会话验证。
- 如何回退到旧版本:使用 Git 回退源代码后,重新运行安装脚本即可(不备份旧版本)。
远程安装
- 如何添加新的远程源:编辑
,在config.yaml
数组中添加新的源配置。remote_sources - 远程安装失败:检查网络连接和 Git 是否安装。某些网络环境可能需要配置代理。
- 临时目录未清理:手动删除
目录。~/.bensz-skills/installation/tmp-remote-install - 安装记录与临时目录在哪里:统一保存在
下;其中 manifest 在~/.bensz-skills/installation/
,远程安装临时目录在~/.bensz-skills/installation/manifests/
。~/.bensz-skills/installation/tmp-remote-install - 远程技能与本地冲突:远程安装会覆盖本地同名技能,建议先备份或使用
模式预览变更。--check