audit-icon-pipeline
について
このスキルは、レジストリとグリフマップ、アイコンディレクトリ、マニフェストを比較することで、アイコンパイプラインを監査し、不足しているアセットを検出します。すべてのパレットにおいて、スキル、エージェント、チーム向けのグリフ、アイコン、HDバリアントの欠落を特定します。レンダリング前、レジストリ更新後、または定期的なパイプライン健全性チェックにおいて、アセットの完全性を検証するためにご利用ください。
クイックインストール
Claude Code
推奨npx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/audit-icon-pipelineこのコマンドをClaude Codeにコピー&ペーストしてスキルをインストールします
ドキュメント
Audit Icon Pipeline
Find missing glyphs, missing icons, stale manifests. Diff registries vs glyph maps, icon dirs, manifests. Produce gap report for skills, agents, teams.
When Use
- New skills, agents, teams added — check icon needs
- Before full pipeline render — find what missing
- After registry updates — verify manifest sync
- Periodic pipeline health check
Inputs
- Optional: Entity type filter —
skill,agent,team, orall(default:all) - Optional: Palette to check (default:
cyberpunk— reference palette)
Steps
Step 1: Read Registries
Collect entity IDs from source-of-truth registries.
- Read
skills/_registry.yml— grab skill IDs across domains - Read
agents/_registry.yml— grab agent IDs - Read
teams/_registry.yml— grab team IDs - Record counts: skills, agents, teams
Got: Three ID lists with counts matching total_skills, total_agents, total_teams.
If fail: Registry file missing? Report path, skip that type.
Step 2: Read Glyph Mappings
Collect mapped entity IDs from glyph map files.
- Read
viz/R/glyphs.R— grab keys fromSKILL_GLYPHSlist - Read
viz/R/agent_glyphs.R— grab keys fromAGENT_GLYPHSlist - Read
viz/R/team_glyphs.R— grab keys fromTEAM_GLYPHSlist
Got: Three mapped-ID lists.
If fail: Glyph file missing? Report it, mark all entities of that type unmapped.
Step 3: Compute Missing Glyphs
Diff registry IDs vs mapped IDs.
- Missing skill glyphs:
registry_skill_ids - mapped_skill_ids - Missing agent glyphs:
registry_agent_ids - mapped_agent_ids - Missing team glyphs:
registry_team_ids - mapped_team_ids
Got: Lists of entity IDs in registries but no glyph function mapped.
If fail: Diff fails? Verify ID formats match between registry and glyph files (underscores vs hyphens).
Step 4: Check Rendered Icons
Verify mapped glyphs have rendered icon files.
- For each mapped skill ID, check
viz/public/icons/<palette>/<domain>/<skillId>.webp - For each mapped agent ID, check
viz/public/icons/<palette>/agents/<agentId>.webp - For each mapped team ID, check
viz/public/icons/<palette>/teams/<teamId>.webp - Check HD variants in
viz/public/icons-hd/— same structure
Got: Lists of entities with glyphs but no rendered icons (standard and/or HD).
If fail: Icon dir absent? Pipeline not run yet — report all as missing.
Step 5: Check Manifest Freshness
Compare manifest counts vs registry counts.
- Read
viz/public/data/icon-manifest.json— count entries - Read
viz/public/data/agent-icon-manifest.json— count entries - Read
viz/public/data/team-icon-manifest.json— count entries - Compare vs registry totals
Got: Manifest counts match registry counts. Mismatch → stale manifest.
If fail: Manifest files absent? Data pipeline needs to run first (node build-data.js && node build-icon-manifest.js).
Step 6: Detect Orphan Icons
Walk viz/public/icons*/. Flag WebP files whose <palette>/<domain>/<skillId> triple absent from icon-manifest.json.
- Enumerate WebP files:
find viz/public/icons* -name "*.webp" - For each file, extract
<domain>/<id>from path - Check if
<domain>/<id>has entry inicon-manifest.json - Collect non-matching files as orphans — on disk but unreferenced
# Quick orphan count per palette
node -e "
const fs = require('fs');
const manifest = JSON.parse(fs.readFileSync('viz/public/data/icon-manifest.json'));
const ids = new Set(manifest.map(e => e.domain + '/' + e.id));
const orphans = require('child_process')
.execSync('find viz/public/icons -name \"*.webp\"').toString().trim().split('\n')
.filter(p => { const parts = p.split('/'); const id = parts.slice(-2).join('/').replace('.webp',''); return !ids.has(id); });
console.log('Orphans:', orphans.length);
orphans.forEach(p => console.log(' ', p));
"
Got: Zero orphans. Any orphans → skills re-homed to different domain, no cleanup (18 orphans per re-homing = 9 palettes × 2 sizes).
If fail: Delete orphans manually — no manifest entry, will not be served. Re-home events rare, manual cleanup acceptable.
Step 7: Generate Gap Report
Produce structured summary.
- Format output as clear table or list:
=== Icon Pipeline Audit === MISSING GLYPHS (no glyph function): Skills: 5 missing — [list] Agents: 2 missing — [list] Teams: 0 missing MISSING ICONS (glyph exists, no rendered WebP): Standard (512px): 3 skills, 1 agent HD (1024px): 8 skills, 3 agents, 1 team STALE MANIFESTS: icon-manifest.json: 320 entries vs 326 registry (stale) agent-icon-manifest.json: 66 entries vs 66 registry (OK) team-icon-manifest.json: 15 entries vs 15 registry (OK) - Suggest next actions from findings
Got: Full gap report with actionable next steps.
If fail: All checks pass, zero gaps? Report "Pipeline fully in sync" — positive outcome.
Checks
- All three registries read OK
- All three glyph map files checked
- Icon dirs scanned — standard and HD
- Manifest freshness verified
- Orphan icons checked (disk paths vs manifest)
- Gap report produced — counts and entity lists
- Next steps provided
Pitfalls
- ID format mismatch: Registry uses kebab-case (
create-skill), glyph maps may use snake_case keys — normalize before comparison - Palette assumption: Checking only cyberpunk palette misses palette-specific rendering gaps
- Empty directories: Domain dir exists but empty counts as "icons present" when globbing — check file existence, not directory existence
- HD not rendered: HD icons live in separate tree (
icons-hd/) — don't confuse with standard icons - Orphans after re-homing: Skill domain changes?
build.shcreates icons at new path, does NOT delete old — always run Step 6 orphan check after domain migration
See Also
- create-glyph — create missing glyph flagged by this audit
- enhance-glyph — improve quality of existing glyphs
- render-icon-pipeline — run full pipeline to generate missing icons
GitHub リポジトリ
関連スキル
content-collections
メタこのスキルは、Content Collections(Markdown/MDXファイルを型安全なデータコレクションに変換するTypeScriptファーストのツール)の本番環境でテストされた設定を提供します。Zodバリデーションによる型安全性を実現し、ブログ、ドキュメントサイト、コンテンツ重視のVite + Reactアプリケーション構築時にご利用ください。Viteプラグインの設定、MDXコンパイルから、デプロイ最適化、スキーマバリデーションまで、すべてを網羅しています。
polymarket
メタこのスキルは、開発者がPolymarket予測市場プラットフォームを活用したアプリケーション構築を可能にします。API統合による取引や市場データの取得に加え、WebSocketを介したリアルタイムデータストリーミングにより、ライブ取引や市場活動を監視できます。取引戦略の実装や、ライブ市場更新を処理するツールの作成にご利用ください。
creating-opencode-plugins
メタこのスキルは、開発者がコマンド、ファイル、LSP操作など25種類以上のイベントタイプにフックするOpenCodeプラグインを作成することを支援します。JavaScript/TypeScriptモジュール向けに、プラグイン構造、イベントAPI仕様、および実装パターンを提供します。カスタムイベント駆動ロジックでOpenCode AIアシスタントのライフサイクルをインターセプト、監視、または拡張する必要がある場合にご利用ください。
sglang
メタSGLangは、高性能なLLMサービングフレームワークであり、RadixAttentionプレフィックスキャッシュを活用したJSON、正規表現、エージェントワークフロー向けの高速で構造化された生成を特長とします。特にプレフィックスが繰り返されるタスクにおいて、大幅に高速な推論を実現し、複雑な構造化出力やマルチターン対話に最適です。制約付きデコードが必要な場合や、広範なプレフィックス共有を伴うアプリケーションを構築する場合は、vLLMなどの代替案ではなくSGLangを選択してください。
