skills/skill-tweaker/SKILL.md
Fix, improve, or update existing Claude Code skills. Use when: (1) User reports a skill isn't working or triggering incorrectly, (2) User wants to adjust skill behavior, (3) User says 'fix skill', 'update skill', 'tweak skill', 'skill not working', 'skill triggers too often'. Edits SKILL.md frontmatter and body, scripts/references/assets, debugs trigger issues.
npx skillsauth add takazudo/claude-resources skill-tweakerInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Find skills at:
$HOME/.claude/skills/<name>/SKILL.md (personal).claude/skills/<name>/SKILL.md (project)Case-sensitivity check (IMPORTANT for macOS): The skill file may be named SKILL.md (uppercase) or skill.md (lowercase). On case-insensitive filesystems (macOS), both resolve to the same file on disk, but git tracks them as separate entries. Before editing:
git ls-files --stage '<skill-dir>/'SKILL.md and skill.md exist in the git index, remove the duplicate: git rm --cached '<path>/SKILL.md' (keep the one matching the project convention)Read the skill file and any referenced files (scripts/, references/, assets/).
Common problems and fixes:
| Problem | Likely Cause | Fix |
|---------|-------------|-----|
| Skill not triggering | Poor description | Rewrite with clear trigger keywords and scenarios. Claude tends to undertrigger — make the description slightly pushy (e.g. "Make sure to use this skill whenever the user mentions X, Y, or Z, even if they don't explicitly ask for it") |
| Skill triggers too often | Description too broad | Make description more specific; add disable-model-invocation: true for manual-only |
| Skill not visible | Exceeds character budget | Run /context to check; shorten description or increase SLASH_COMMAND_TOOL_CHAR_BUDGET |
| Wrong agent used in fork | agent: field incorrect | Change to correct agent name |
| Forked skill lacks context | Missing instructions | Skill content IS the prompt in fork mode - make it self-contained |
| Script fails | Bug or environment issue | Read and test the script |
Inserting a new step into a numbered step list: When a skill is structured as Step 1, Step 2, Step 3, ... and you need to add a new step between existing ones, renumber the steps so the sequence stays contiguous. Do NOT introduce fractional numbers like "Step 2.5", and do NOT insert "Step 0" at the start. Examples:
After renumbering, grep the skill file for stale references (e.g., "Step 3" where you now mean "Step 4") and fix them. Also check any sibling files (scripts, references) that mention step numbers.
Frontmatter fields reference:
| Field | Description |
|-------|-------------|
| name | Skill name (lowercase, hyphens, max 64 chars) |
| description | What it does + when to use. Primary trigger mechanism |
| disable-model-invocation | true = manual only via /skill-name |
| user-invocable | false = hidden from / menu, Claude can still auto-invoke |
| argument-hint | Hint in autocomplete (e.g., [filename]) |
| allowed-tools | Tools allowed without permission when active |
| model | Model override when active |
| context | fork = run in isolated subagent context |
| agent | Agent type for fork: Explore, Plan, general-purpose, or custom agent name |
| hooks | Lifecycle hooks |
Substitution variables: $ARGUMENTS, $0, $1, ${CLAUDE_SESSION_ID}
Dynamic injection: Use the exclamation-backtick pattern (e.g. exclamation + backtick-wrapped command) to run shell commands before skill content is sent to Claude.
Writing principles when rewriting body content:
Format the edited SKILL.md file using the mdx-formatter to ensure consistent markdown formatting:
pnpm dlx @takazudo/mdx-formatter --write <path-to-SKILL.md>
Scan the skill's SKILL.md and all referenced scripts/files for ~/ in file paths. Replace with $HOME/.
Why: ~ is a shell expansion feature. It is NOT expanded by Node.js fs operations, Python open(), or non-login shell contexts. Using ~/ in these contexts creates a literal directory named ~ inside the working directory instead of resolving to the user's home directory. This has caused real bugs where a ~/ directory was accidentally created inside a repo.
What to check:
~/foo/bar in scripts or skill instructionsReplace with: $HOME/foo/bar (expanded by both shell and most runtimes)
After editing:
~/ paths in file operations -- use $HOME/ instead (see Step 5)If SKILL.md is getting too long (approaching 500 lines):
references/ filesdevelopment
Link Claude Code skill names mentioned in a CodeGrid article (data/{series}/{n}.md) to the author's public claude-resources repo, pinned to the latest commit hash so links don't rot. Use when: (1) user says 'linkify cc resources', 'link the skills', 'link skill names', or invokes /dev-linkify-cc-resources; (2) editing a CodeGrid article that mentions `/commits`, `/pr-complete`, `/skill-creator` or other Claude Code skills and they should point to claude-resources. Only links skills that actually exist in the public repo; skips hypothetical examples and code blocks.
development
Second opinion from Claude Opus on a plan or approach. Use when: (1) Planning phase of /big-plan needs a higher-quality review than /codex-2nd / /gco-2nd, (2) User says 'opus 2nd' or 'opus opinion', (3) Wanting Anthropic's larger model to critique a plan. Spawns a general-purpose Agent with model: opus that reads the plan file and returns structured feedback. Anthropic quota — not free.
tools
AI-based testing via subagent + a per-task test-flow skill. Use when the user wants to verify something that mechanical assertions can't fully capture — image recognition, visual size/position comparison, animation smoothness, multi-step manual flows that need AI judgment. Triggers: 'AI-based test', 'AI test', 'visual verify', 'image recognition test', 'manual operation test', 'human-eye check', 'verify visually', 'compare screenshots', 'looks the same', 'looks correct'. The skill's job is to (1) author a focused test-flow skill that captures the exact procedure + verdict criteria, then (2) dispatch a verification subagent via the Agent tool that loads BOTH the test-flow skill AND a browser-driving skill (/verify-ui primary, /headless-browser fallback) so the subagent has clear context and consistent verdicts. NEVER uses `claude -p` — subagent dispatch goes through the Agent tool exclusively.
development
End-of-workflow audit of touched GitHub issues, PRs, and branches via a Sonnet subagent. Use when: (1) /big-plan, /x-as-pr, or /x-wt-teams finishes its main work and needs to verify every touched resource is in the right state (closed when done, kept when ongoing, deleted when dead), (2) User says 'cleanup resources', 'audit cleanup', or 'check what should be closed', (3) A long workflow ends and the manager wants a structured paper trail of what it closed/kept/deleted. Auto-execute by default — the Sonnet agent proposes, the manager (you) executes safe actions and prints a final report.