agent-add-rule
npx skills add https://github.com/ravnhq/ai-toolkit --skill agent-add-rule
Agent 安装分布
Skill 文档
Add Rule â Place Agent Instructions Correctly
Add a new rule or convention to the right location in the progressive disclosure structure.
Context Spectrum
Static (root CLAUDE.md) â loaded every conversation. Token cost always paid.
Semi-dynamic (docs/agents/) â linked from root. Loaded when Claude follows a link.
Fully dynamic (skills) â metadata only in context. Body loaded on trigger.
Workflow
Step 1: Ask
Ask the user: “What rule or convention do you want to add?”
Accept free text. If the user already provided it (e.g., /agent-add-rule always use snake_case for database columns), skip this step.
Step 2: Analyze Current Structure
Read:
- Root CLAUDE.md
- List files in docs/agents/
- List available skills
Understand what already exists so you don’t duplicate or contradict.
Step 3: Classify
Apply this decision tree:
Does the agent consistently get this wrong WITHOUT being told?
âââ NO â Challenge: "Does this justify its token cost?"
â If user still wants it â treat as semi-dynamic
â
âââ YES â Does it apply to EVERY task?
â âââ YES â Root CLAUDE.md (static)
â â Examples: package manager, multi-tenancy, project scripts
â â
â âââ NO â docs/agents/ file (semi-dynamic)
â Examples: lint rules, test thresholds, API conventions
â
âââ Is it a repeatable workflow or procedural knowledge?
âââ YES â Skill (fully dynamic)
â Examples: deployment process, PR review checklist, migration procedure
â
âââ NO â Probably not needed. Ask: "Does this justify its token cost?"
Key questions to ask the user:
- “Does the agent consistently get this wrong?” â If no, consider skipping
- “Does this apply to every task or just some?” â Static vs semi-dynamic
- “Is this a rule or a workflow?” â docs/agents/ vs skill
- “Will this change frequently?” â Skills are easier to evolve independently
Step 4: Recommend
Present the recommended placement with reasoning:
Recommendation: Add to docs/agents/guardrails.md
Reasoning:
- This is a data handling rule, not a universal workflow rule
- It applies only when working with the database
- guardrails.md already covers data isolation patterns
- Adding to root would cost tokens on every conversation unnecessarily
Step 5: Confirm
Ask the user to confirm or override. If they override, respect their choice but note the trade-off:
- Moving to root: “This adds ~X lines to every conversation’s context”
- Moving to docs/agents/: “This won’t be visible unless Claude follows the link”
- Moving to skill: “This will only load when triggered by matching keywords”
Step 6: Write
Based on confirmed placement:
If root CLAUDE.md:
- Add the rule under the appropriate section (Key Rules, Workflow, etc.)
- Warn: “This adds to every conversation’s token budget”
- Keep it concise â 1-2 lines max
If existing docs/agents/ file:
- Read the target file
- Add the rule under the appropriate section
- Keep consistent formatting with existing content
If new docs/agents/ file:
- Create the file with a clear heading and the rule
- Update root CLAUDE.md links section with a new entry including routing signal
- Example:
- API Conventions (docs/agents/api-conventions.md) â REST patterns, error response format, pagination
If skill:
- Tell the user to run
/agent-skill-creatorto scaffold it - Provide the rule content as input for the skill body
Examples
Example 1: Universal Rule â Root
User: “Always use pnpm, never npm”
Classification: Agent gets this wrong without being told + applies to every task â Root
Action: Add to Key Rules section in CLAUDE.md
Example 2: Topic-Specific Rule â docs/agents/
User: “API responses must always include a requestId field”
Classification: Agent might get wrong + only applies to API work â Semi-dynamic
Action: Add to docs/agents/guardrails.md or create docs/agents/api-conventions.md
Example 3: Complex Workflow â Skill
User: “When deploying, always run migrations first, then build, then deploy to staging, verify, then production”
Classification: Repeatable multi-step procedure â Fully dynamic (skill)
Action: Suggest /agent-skill-creator to create a deployment skill
Example 4: Unnecessary Rule â Challenge
User: “Always use const instead of let“
Classification: ESLint already enforces this â Not needed
Response: “ESLint already enforces this via the prefer-const rule. Adding it to agent instructions would cost tokens without benefit. Skip?”
Positive Trigger
User: “Add a new convention that API responses must include a request ID and put it in the right agent config location.”
Expected behavior: Use agent-add-rule guidance to classify placement, confirm with the user, and apply the rule in the appropriate location.
Non-Trigger
User: “Implement a feature flag system for staged rollouts in our backend service.”
Expected behavior: Do not prioritize agent-add-rule; use an implementation-focused skill/workflow instead.
Principles
- Challenge before adding: Every rule costs tokens. Ask “does this justify its token cost?”
- No duplication: If ESLint, TypeScript, or another tool already enforces it, don’t add it
- Routing signals matter: When adding to docs/agents/, update the root CLAUDE.md link description so Claude knows when to follow it
- One level deep: Never cross-reference between docs/agents/ files. All links go from root
Troubleshooting
Skill Does Not Trigger
- Error: The skill is not selected when expected.
- Cause: Request wording does not clearly match the description trigger conditions.
- Solution: Rephrase with explicit domain/task keywords from the description and retry.
Guidance Conflicts With Another Skill
- Error: Instructions from multiple skills conflict in one task.
- Cause: Overlapping scope across loaded skills.
- Solution: State which skill is authoritative for the current step and apply that workflow first.
Output Is Too Generic
- Error: Result lacks concrete, actionable detail.
- Cause: Task input omitted context, constraints, or target format.
- Solution: Add specific constraints (environment, scope, format, success criteria) and rerun.