mit einem Klick
writing-claude-directives
// Use when writing instructions that guide Claude behavior - skills, CLAUDE.md files, agent prompts, system prompts. Covers token efficiency, compliance techniques, and discovery optimization.
// Use when writing instructions that guide Claude behavior - skills, CLAUDE.md files, agent prompts, system prompts. Covers token efficiency, compliance techniques, and discovery optimization.
| name | writing-claude-directives |
| description | Use when writing instructions that guide Claude behavior - skills, CLAUDE.md files, agent prompts, system prompts. Covers token efficiency, compliance techniques, and discovery optimization. |
| user-invocable | false |
REQUIRED: Also apply ed3d-extending-claude:prompt-security-hardening when using this skill. Directives that demonstrate unsafe secrets handling teach agents to leak secrets.
1. Claude is smart. Only write what it doesn't already know. Challenge each line: does this justify its token cost?
2. Positive > Negative framing. "Don't do X" triggers thinking about X (pink elephant problem). Say what TO do, not what to avoid.
# Bad: triggers the behavior
Don't create duplicate files
# Good: directs to correct behavior
Update existing files in place
3. Context motivates compliance. Explain WHY, not just WHAT. Claude generalizes from motivation.
# Less effective
NEVER use ellipses
# More effective
Your response will be read aloud by a text-to-speech engine, so never use ellipses since the TTS engine cannot pronounce them.
4. Placement matters. Instructions at prompt start and end receive higher attention. Critical rules go at boundaries.
5. ~150 instruction limit. More instructions = uniform degradation across ALL rules. Prune ruthlessly.
6. Repetition enforces critical rules. For high-stakes requirements, repeat with different framings.
Targets:
Progressive disclosure: Main file is overview + links. Reference files load on-demand.
The description field determines if Claude finds your skill.
Format: Start with "Use when..." + specific triggers + what it does.
Write in third person. Injected into system prompt.
# Bad: vague, first person
description: I help with async testing
# Good: triggers + action, third person
description: Use when tests have race conditions or timing dependencies - replaces arbitrary timeouts with condition polling
Keywords: Include error messages, symptoms, tool names Claude might search for.
Claude 4.x models are highly responsive to instructions. Lead with context and motivation; reserve imperatives for critical boundaries.
Explain WHY the rule exists. Claude generalizes from the explanation:
# Instead of raw authority
You MUST run tests before committing.
# Provide motivation
Run tests before committing. Untested commits break CI for the whole team and block other developers from merging their work.
Use structure to make compliance the path of least resistance:
| Pattern | Example |
|---|---|
| Workflow steps | Numbered steps with verification gates |
| Task tracking (TaskCreate/TaskUpdate) | Checklists without tracking = skipped steps (TodoWrite in older versions) |
| Forced commitment | "Announce: I'm using [skill]" |
| Explicit blocking | "If X happens, stop and do Y instead" |
For Claude 4.x, aggressive language ("YOU MUST", "CRITICAL") can cause overtriggering. Use normal language first:
# Often sufficient for 4.x
Use this tool when searching for files.
# Reserve imperatives for true boundaries
Never commit secrets to version control.
Close loopholes when needed, but prefer context over authority:
# Good: context + loophole closure
Write the test first. Code written before its test tends to test the implementation rather than the behavior, making refactoring harder later. If you find yourself with untested code, delete it and start with the test.
| Type | Approach |
|---|---|
| Discipline (TDD, verification) | Context + structural enforcement + loophole closure |
| Technique (patterns, how-to) | Clear steps, "we want quality" framing |
| Reference (documentation) | Clarity only, no persuasion needed |
Claude parses XML effectively. Use for multi-part directives:
<task>What to accomplish</task>
<constraints>Hard requirements</constraints>
<output_format>Expected structure</output_format>
<examples>Input/output pairs</examples>
XML also works as format indicators:
<smoothly_flowing_prose>Write report sections here</smoothly_flowing_prose>
<structured_data>JSON or tables here</structured_data>
XML outperforms markdown, JSON, or YAML for rule preservation in long prompts.
The formatting style in your prompt influences Claude's response. Include markdown formatting in your prompts when you want markdown output. Remove markdown from prompts if you want plain text output.
Break complex tasks into checkable steps:
## Workflow
- [ ] Step 1: Analyze inputs
- [ ] Step 2: Generate plan
- [ ] Step 3: Validate plan
- [ ] Step 4: Execute
- [ ] Step 5: Verify output
Validate → fix → repeat:
1. Generate output
2. Run validator
3. If errors: fix and go to step 2
4. Only proceed when validation passes
Match specificity to fragility:
| Task Type | Freedom | Style |
|---|---|---|
| Fragile operations | Low | Exact scripts, no modifications |
| Preferred patterns | Medium | Templates with parameters |
| Context-dependent | High | Principles and heuristics |
<default_to_action>
By default, implement changes rather than only suggesting them. If the user's intent is unclear, infer the most useful likely action and proceed, using tools to discover any missing details instead of guessing. Try to infer the user's intent about whether a tool call is intended or not, and act accordingly.
</default_to_action>
<do_not_act_before_instructions>
Do not jump into implementation or change files unless clearly instructed. When the user's intent is ambiguous, default to providing information, doing research, and providing recommendations rather than taking action. Only proceed with edits when the user explicitly requests them.
</do_not_act_before_instructions>
Claude 4.x tends to overengineer. Include this when needed:
Avoid over-engineering. Only make changes that are directly requested or clearly necessary. Keep solutions simple and focused.
Don't add features, refactor code, or make "improvements" beyond what was asked. A bug fix doesn't need surrounding code cleaned up. A simple feature doesn't need extra configurability.
Don't add error handling, fallbacks, or validation for scenarios that can't happen. Trust internal code and framework guarantees. Only validate at system boundaries (user input, external APIs). Don't use backwards-compatibility shims when you can just change the code.
Don't create helpers, utilities, or abstractions for one-time operations. Don't design for hypothetical future requirements. The right amount of complexity is the minimum needed for the current task. Reuse existing abstractions where possible and follow DRY.
When extended thinking is disabled, Opus 4.5 is sensitive to the word "think" and variants. Replace with:
Gerund form (verb + -ing): writing-skills, testing-code, debugging-errors
Name by action or insight: condition-based-waiting not async-helpers
| Mistake | Fix |
|---|---|
| Verbose explanations | Claude knows basics - omit |
| Multiple valid approaches | Pick one default, escape hatch for edge cases |
| Vague triggers | Specific symptoms: "tests flaky", "race condition" |
| Deeply nested references | Keep one level deep from main file |
| Windows paths | Always forward slashes |
| Aggressive language for 4.x | Lead with context, reserve imperatives for boundaries |
For discipline-enforcing directives, anticipate excuses:
## Red Flags - STOP
If you find yourself reasoning any of these, you're rationalizing:
- "This is simple enough to skip"
- "I already tested manually"
- "The spirit not the letter"
- "This case is different"
All mean: Follow the process.
For multi-context-window workflows and state management across sessions, see long-running-state-patterns.md in this directory.
See graphviz-conventions.dot for flowchart style guide.
Use flowcharts for: Non-obvious decisions, process loops, "when to use A vs B"
Don't use for: Reference material (use tables), linear steps (use lists)
ALWAYS use this skill when writing or refactoring code. Includes context-dependent sub-skills to empower different coding styles across languages and runtimes.
Use when writing, reviewing, or modifying Rust code - covers error handling with thiserror+miette, type system patterns, async and serde conventions, testing crates, dependency pinning, and module organization
Use when the user wants to export a Claude Code session transcript as a readable Markdown file — converts the current session (or a specified transcript path) into GitHub-flavored Markdown with metadata header, collapsible tool results, and thinking blocks
Use when the user wants to review their recent Claude Code sessions for patterns — analyzes the last N sessions (default 5) in the current project, dispatching parallel reviewers per session, then synthesizing cross-session findings
Use when the user wants to review a Claude Code session for quality — analyzes the current session (or a specified transcript path) for prompting effectiveness, agent performance, and environment gaps, producing actionable recommendations
Use when writing skills, CLAUDE.md files, agent prompts, or any directives that involve shell commands, environment variables, API credentials, file creation, or git operations - prevents secrets leakage into LLM context, unsafe shell patterns, and credential exposure