From super-pm
Scans super-pm skills for metadata completeness, file size issues, doc path consistency, and search dependency availability. Run periodically for maintenance audits.
How this skill is triggered — by the user, by Claude, or both
Slash command
/super-pm:pm-selfcheckThis skill is limited to the following tools:
The summary Claude sees in its skill listing — used to decide when to auto-load this skill
```bash
bash "$(dirname "${BASH_SOURCE[0]}")"/check-update.sh 2>/dev/null || true
echo "🔍 pm-selfcheck v1.0"
echo "正在扫描 super-pm 健康状态..."
echo ""
扫描所有 SKILL.md,检查:
name: 字段是否缺失version: 字段是否缺失description: 字段是否缺失allowed-tools: 字段是否缺失| 评级 | 范围 | 状态 |
|---|---|---|
| ⚠️ 超大 | > 600行 | 需要拆分 |
| ✅ 标准 | 200-600行 | 健康 |
| ⚠️ 薄弱 | < 100行 | 需要补充 |
扫描所有 docs/ 引用,检查:
docs/01-需求调研/、docs/02-方案设计/ 等docs/01-demand-insight/ 等docs/xxx.md)检查搜索增强工具是否可用:
echo "=== 4. 搜索依赖检测 ==="
# AnySearch skill 检测
ANYSEARCH_FOUND=false
for candidate in \
"$HOME/.claude/skills/anysearch/scripts/anysearch_cli.py" \
"$HOME/.opencode/skills/anysearch/scripts/anysearch_cli.py" \
"$HOME/.openclaw/skills/anysearch/scripts/anysearch_cli.py" \
"$HOME/.cursor/skills/anysearch/scripts/anysearch_cli.py" \
"$HOME/.anysearch/scripts/anysearch_cli.py"; do
if [ -f "$candidate" ]; then
ANYSEARCH_FOUND=true
echo "✅ AnySearch: 已安装 ($candidate)"
break
fi
done
if [ "$ANYSEARCH_FOUND" = false ]; then
echo "❌ AnySearch: 未安装(搜索将降级到 Exa MCP / WebSearch)"
echo " 安装: git clone https://github.com/konglong87/anysearch.git ~/.claude/skills/anysearch"
fi
# Exa MCP 检测(检查 settings.json 中是否配置了 mcpServers.exa)
EXA_FOUND=false
for settings_file in \
".claude/settings.json" \
"$HOME/.claude/settings.json"; do
if [ -f "$settings_file" ] && grep -q '"exa"' "$settings_file" 2>/dev/null; then
EXA_FOUND=true
echo "✅ Exa MCP: 已配置 ($settings_file)"
break
fi
done
if [ "$EXA_FOUND" = false ]; then
echo "❌ Exa MCP: 未配置(搜索将降级到 WebSearch)"
echo " 配置: 在 .claude/settings.json 中添加 mcpServers.exa"
fi
# WebSearch 始终可用
echo "✅ WebSearch: 内置兜底,始终可用"
根据扫描结果给出维护建议。
执行以下命令收集数据:
echo "=== 1. 元数据完整性 ==="
for f in $(find ~/.claude/skills/super-pm -name 'SKILL.md' | sort); do
dir=$(dirname "$f" | sed 's|.*/super-pm/||')
missing=""
grep -q '^name:' "$f" || missing="$missing name"
grep -q '^version:' "$f" || missing="$missing version"
grep -q '^description:' "$f" || missing="$missing description"
grep -q 'allowed-tools:' "$f" || missing="$missing allowed-tools"
if [ -n "$missing" ]; then
echo "❌ $dir 缺失:$missing"
fi
done
echo ""
echo "=== 2. 体积检查 ==="
for f in $(find ~/.claude/skills/super-pm -name 'SKILL.md' | sort); do
dir=$(dirname "$f" | sed 's|.*/super-pm/||' | sed 's|/|/|')
lines=$(wc -l < "$f" | tr -d ' ')
if [ "$lines" -gt 600 ]; then
echo "⚠️ $dir: ${lines}行 (超大)"
elif [ "$lines" -lt 100 ]; then
echo "⚠️ $dir: ${lines}行 (薄弱)"
fi
done
echo "✅ 其他skill体积正常"
echo ""
echo "=== 3. 文档路径检查 ==="
for f in $(find ~/.claude/skills/super-pm -name 'SKILL.md' | sort); do
dir=$(dirname "$f" | sed 's|.*/super-pm/||')
grep -oP '`?docs/[^`()\n]+`?' "$f" 2>/dev/null | sed "s/^/$dir: /"
done
# pm-selfcheck 报告
**检查时间**: {当前时间}
**super-pm 版本**: v2.2.0
## 1️⃣ 元数据完整性
{自动检测结果}
## 2️⃣ 体积状态
{自动检测结果}
## 3️⃣ 文档路径引用
{自动检测结果}
## 4️⃣ 搜索依赖状态
{自动检测结果 — AnySearch / Exa MCP / WebSearch 可用性}
## 5️⃣ 维护建议
{根据检测结果生成建议}
出现以下情况立即停止并回溯:
| 误区 | 正确做法 |
|---|---|
| 使用"应该"、"大概"、"看起来"做结论 | 必须基于实际数据和验证 |
| 未运行检查就声称已完成 | 先验证,再陈述 |
⚠️ 任何异常请标注修复。
npx claudepluginhub konglong87/superpm --plugin super-pmAudits pm-skills skills against structural conventions and quality criteria, producing a pass/fail report with actionable recommendations. Use before shipping or after editing a skill.
Audits skill quality against routing, progressive loading, and verification criteria. Produces health reports with per-skill ratings and a Gate outcome.
Audits Claude skills and commands for quality with quick scans of changed files or full stocktakes using subagents, checklists, and AI verdicts. Invoke via /skill-stocktake.