install-bensz-skills
SKILL.md
Install Bensz Skills(系统级安装器)
目的:把当前仓库 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
流程:
- 创建临时目录
~/.install-bensz-skills/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
流程:
- 创建临时目录
- 直接下载所有远程技能(无确认)
- 强制安装/更新(无对比,无确认)
- 清理临时目录
验证
建议在任意其它目录执行:
codex exec "列出所有可用的技能"
MD5 版本控制机制
脚本使用 MD5 哈希值进行智能版本控制:
- 版本计算:对 skill 目录内的可安装文件进行 MD5 计算(排除
tests/、plans/、缓存与临时文件) - 版本存储:安装后在目标目录生成平台特定 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.md的目录"(即每个 skill 的根目录)。 - 技能类型控制:通过 SKILL.md 中的
category字段控制(normal可安装,auxiliary和test不安装)。 - MD5 版本检查:优先检查
.skill-manifest.{codex,claude}.json,回退到重新计算 - 直接替换:发现到目标路径已存在同名目录且版本变化时,直接删除旧版本并安装新版本(不备份)
- 理由:Git 已提供版本控制,可随时回退;新版本通常比旧版本更好
- 若存在旧的
pipeline-skills软链接:会移除该软链接(不删除真实目录)。
命令行参数
本地安装参数
| 参数 | 说明 |
|---|---|
--dry-run |
预览模式,不实际写入文件 |
--codex |
仅安装到 Codex |
--claude |
仅安装到 Claude Code |
--force |
强制重新安装所有 skills(忽略 MD5 检查) |
--source |
指定额外的 skills 源目录路径 |
远程安装参数
| 参数 | 说明 |
|---|---|
--remote |
启用远程安装模式(必须与 --check 或 --auto 一起使用) |
--check |
检查模式(交互式确认后再安装) |
--auto |
自动模式(强制安装,无需确认) |
--{id} |
仅安装指定远程源(如 --general、--research) |
参数组合:
--remote --check:交互式远程安装--remote --auto:自动强制远程安装--remote --check --codex:仅对 Codex 执行远程检查--remote --check --claude:仅对 Claude Code 执行远程检查--remote --check --general:仅检查并安装 general 源
远程源配置
远程技能源通过 config.yaml 配置文件定义:
# install-bensz-skills/config.yaml
remote_sources:
- id: "general"
name: "通用技能"
url: "https://github.com/huangwb8/skills"
branch: "main"
skills_path: "skills"
description: "通用技能,建议所有用户安装"
recommended: true
- id: "research"
name: "科研技能"
url: "https://github.com/huangwb8/ChineseResearchLaTeX"
branch: "main"
skills_path: "skills"
description: "科研相关技能,建议有科研需要的用户安装"
recommended: false
配置字段说明:
id:源 ID(用于--{id}过滤)name:源名称(用于显示和提示)url:Git 仓库 URLbranch:分支名称(默认main)skills_path:技能目录相对于仓库根目录的路径description:源描述(用于提示用户)recommended:是否推荐安装(影响默认提示行为)
常见问题
本地安装
- 如果你刚更新了本仓库的技能:再次触发本 skill 运行脚本即可完成系统级更新(仅安装有变化的)。
- 需要强制重装:使用
--force参数。 - Claude Code / Codex 都需要新会话才会重新加载更新后的技能;安装后建议新建会话验证。
- 如何回退到旧版本:使用 Git 回退源代码后,重新运行安装脚本即可(不备份旧版本)。
远程安装
- 如何添加新的远程源:编辑
config.yaml,在remote_sources数组中添加新的源配置。 - 远程安装失败:检查网络连接和 Git 是否安装。某些网络环境可能需要配置代理。
- 临时目录未清理:手动删除
~/.install-bensz-skills/tmp-remote-install目录。 - 远程技能与本地冲突:远程安装会覆盖本地同名技能,建议先备份或使用
--check模式预览变更。
Weekly Installs
1
Repository
huangwb8/skillsGitHub Stars
17
First Seen
5 days ago
Security Audits
Installed on
mcpjam1
claude-code1
replit1
junie1
windsurf1
zencoder1