skills/generating-diagrams/SKILL.md
Use when generating flowcharts, diagrams, dependency graphs, or visual representations of processes, relationships, architecture, or state machines. Triggers: 'diagram this', 'flowchart', 'visualize', 'dependency graph', 'ER diagram', 'state machine diagram', 'class diagram', 'sequence diagram', 'map the relationships', 'draw the architecture', 'how does X connect to Y'. NOT for: simple bullet point explanations, runtime monitoring, or text-only documentation.
npx skillsauth add axiomantic/spellbook generating-diagramsInstall 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.
Generate accurate, renderable, exhaustive diagrams from code, processes, instructions, or architecture. Every node justified by source material. Every reference traced to its deepest level. Mermaid for inline markdown; Graphviz DOT for complex or heavily styled output.
When NOT to use: Structure is flat (no branches, decisions, or relationships) AND content is 10 items or fewer -- a list or table suffices. Runtime observability. Text-only documentation.
| Diagram Type | Best For | Mermaid Syntax | Graphviz Alternative |
|-------------|---------|----------------|---------------------|
| Flowchart | Processes, decisions, workflows | flowchart TD | digraph { } with shapes |
| Sequence | Temporal interactions, request/response | sequenceDiagram | Not recommended |
| State | Lifecycles, state machines | stateDiagram-v2 | digraph { } with edge labels |
| ER | Data models, entity relationships | erDiagram | graph { } undirected |
| Class | Type hierarchies, composition | classDiagram | digraph { } with record shapes |
| Dependency | Import/invocation graphs | flowchart LR | digraph { } with clusters |
<analysis>Before generating any diagram, identify: subject type, traversal scope, source material locations, and rendering format.</analysis>
1.1 Identify Diagram Subject
| Subject Type | Examples | Primary Diagram Type | |-------------|---------|---------------------| | Process/workflow | CI pipeline, feature workflow, approval flow | Flowchart | | Temporal interaction | API call sequence, auth handshake | Sequence | | Lifecycle/states | Order states, connection lifecycle | State | | Data model | Database schema, domain entities | ER | | Type hierarchy | Class inheritance, interface impl | Class | | Dependencies | Module imports, skill invocations, package deps | Dependency graph |
If the subject spans multiple types, produce separate diagrams for each concern rather than a hybrid.
1.2 Scope the Traversal
Define boundaries BEFORE reading source material. Confirm with user; in autonomous mode, use default depth.
ROOT: [starting entity/file/process]
DEPTH: [how many levels of references to follow]
BOUNDARY: [what counts as "outside" - stop traversing here]
EXCLUSIONS: [known irrelevant branches to skip]
Default DEPTH: follow all references until reaching external dependencies or leaf nodes.
1.3 Select Format
| Criterion | Mermaid | Graphviz DOT | |-----------|---------|--------------| | Node count < 50 | Yes | Overkill | | Node count 50-150 | Risky (test render) | Yes | | Node count > 150 | No (decompose) | Yes (with clusters) | | Needs GitHub inline rendering | Yes | No (render to SVG) | | Complex layout (overlapping edges) | Limited control | Full control | | Custom styling (colors, fonts, shapes) | Basic | Full | | Subgraph nesting > 3 levels | Fragile | Solid |
Default: Mermaid unless complexity indicators from the table above suggest otherwise.
1.4 Plan Decomposition (if needed)
When estimated node count exceeds format limits:
Each level's diagrams must use consistent node IDs so cross-references are unambiguous.
2.1 Systematic Traversal Protocol
QUEUE = [ROOT]
VISITED = {}
NODES = []
EDGES = []
while QUEUE not empty:
current = QUEUE.pop()
if current in VISITED: continue
VISITED.add(current)
content = read(current.source_location)
NODES.append({
id: sanitize(current.name),
label: current.display_name,
source: current.source_location,
type: classify(current) # decision/process/subgraph/terminal/etc
})
for each reference in content:
target = resolve(reference)
EDGES.append({
from: current.id,
to: target.id,
label: reference.context,
condition: reference.condition or null
})
if target not in VISITED:
QUEUE.append(target)
Extract from each source file/section:
2.2 Verify Completeness
3.1 Generate Diagram Code
| Rule | Mermaid | Graphviz |
|------|---------|----------|
| Flow direction | TD for processes, LR for dependencies | rankdir=TB or rankdir=LR |
| Subgraphs | Group by phase/component | subgraph cluster_name { } |
| Decision nodes | {Diamond text} | shape=diamond |
| Process nodes | [Rectangle text] | shape=box |
| Terminal nodes | ([Stadium text]) | shape=doubleoctagon |
| Subagent dispatch | Blue fill | fillcolor="#4a9eff" |
| Quality gate | Red fill | fillcolor="#ff6b6b" |
| Conditional edge | Dashed line + label | style=dashed, label="condition" |
Node label guidelines:
<br/> for line breaks in Mermaid, \n in GraphvizInvoke: skill-nameMultiplicity annotation: When the same target is invoked multiple times from the same source, use a single edge with multiplicity in the label: -->|"x3: per-task, comprehensive, pre-PR"| FC. Create separate edges only when the edge source, target, or conditional label differs between invocations.
3.2 Generate Legend
Every diagram MUST include a legend. For Mermaid, add a disconnected subgraph:
subgraph Legend
L1[Process Step]
L2{Decision Point}
L3([Terminal])
L4[/Input-Output/]
end
Include color meanings if using classDef or fill colors. For Graphviz, add subgraph cluster_legend.
3.3 Generate Cross-Reference Table
For decomposed diagrams, produce a table mapping node IDs to their detail diagram:
| Node in Overview | Detail Diagram | Source File |
|-----------------|----------------|-------------|
| phase_1 | Diagram 2: Research | commands/feature-research.md |
| phase_2 | Diagram 3: Design | commands/feature-design.md |
4.1 Syntax Check
dot -Tsvg input.dot -o output.svgsubgraph has a matching end|"label"| for Mermaid)classDef names match class referencesend, graph, subgraph)4.2 Renderability Check
| Issue | Symptom | Fix |
|-------|---------|-----|
| Too many nodes | Render timeout or blank output | Decompose into levels |
| Overlapping labels | Text collision in rendered output | Shorten labels, use edge labels |
| Subgraph overflow | Nodes escape their container | Reduce nesting depth, use clusters |
| Mermaid max nodes (~100) | Render fails silently | Switch to Graphviz or decompose |
| Edge spaghetti | Unreadable crossing lines | Reorder nodes, use LR vs TD, add invisible edges for spacing |
4.3 Completeness Check
If anything is missing, return to Phase 2 and re-traverse.
<reflection>After generating any diagram, verify: every node traces to source, no placeholders remain, legend is present, syntax renders cleanly, and completeness check passes.</reflection>
When writing mermaid diagrams inside markdown files, use <br> for newlines within node labels. Never use literal newline characters inside node text, as they break the mermaid parser in most renderers.
flowchart TD
A[Process] --> B{Decision}
B -->|Yes| C[Action]
B -->|No| D[Other Action]
C --> E([Terminal])
subgraph Group Name
F[Step 1] --> G[Step 2]
end
style A fill:#4a9eff,color:#fff
classDef gate fill:#ff6b6b,color:#fff
class B gate
sequenceDiagram
participant A as Client
participant B as Server
A->>B: Request
B-->>A: Response
alt Success
A->>B: Confirm
else Failure
A->>B: Retry
end
stateDiagram-v2
[*] --> Idle
Idle --> Processing: start
Processing --> Complete: success
Processing --> Failed: error
Failed --> Idle: retry
Complete --> [*]
erDiagram
SKILL ||--o{ COMMAND : "invokes"
SKILL {
string name
string description
}
COMMAND {
string name
string phase
}
digraph G {
rankdir=TD;
node [shape=box, style=filled, fillcolor="#f0f0f0"];
start [label="Start", shape=oval];
decision [label="Decision?", shape=diamond, fillcolor="#ff6b6b"];
process [label="Process Step", fillcolor="#4a9eff", fontcolor=white];
end_node [label="End", shape=doubleoctagon, fillcolor="#51cf66"];
start -> decision;
decision -> process [label="Yes"];
decision -> end_node [label="No", style=dashed];
process -> end_node;
subgraph cluster_phase1 {
label="Phase 1";
style=filled;
fillcolor="#f8f9fa";
a1 -> a2 -> a3;
}
}
| Mistake | Why It Fails | Fix | |---------|-------------|-----| | Dumping everything into one diagram | Exceeds render limits, unreadable | Decompose into levels with cross-references | | Duplicate nodes for same entity | Obscures that edges point to same thing | One node, multiple edges | | "..." or "etc." placeholders | Defeats exhaustive purpose | Trace every reference or mark as out-of-scope | | No legend | Reader cannot decode color/shape meaning | Always include legend subgraph | | Verbose node labels (10+ words) | Nodes become unreadable blobs | Max 5 words, detail on edges or in table | | Skipping error/failure paths | Happy-path-only diagram lies about complexity | Every decision needs all branches | | No source traceability | Cannot verify diagram accuracy | Keep node-to-source mapping | | Choosing Mermaid for 100+ node graphs | Silent render failure | Use Graphviz or decompose | | Flowchart for relationship data | Wrong tool for the job | Use ER, class, or dependency diagram | | No rendering verification | Broken syntax ships as "done" | Always validate syntax before delivery |
| Excuse | Reality | |--------|---------| | "This diagram is simple, skip the traversal" | Simple diagrams are fast to traverse. Skipping risks missing edges. Always traverse. | | "I'll add the legend later" | Later never comes. Generate it with the diagram. | | "Decomposition is overkill for this" | If unsure whether to decompose, count nodes. Numbers decide, not feelings. | | "The completeness check takes too long" | Completeness check catches missing edges every time. 2 minutes to check vs. delivering wrong diagram. | | "I know this domain well enough to skip reading" | Source-grounded means reading, not remembering. Read or mark out-of-scope. |
When updating existing diagrams (the default path), the system classifies source changes before deciding how to proceed:
Changes that don't affect the workflow diagram are stamped as fresh without regeneration.
<BEHAVIORAL_MODE>, <ROLE>, <CRITICAL>)Small structural changes trigger targeted edits to the existing diagram rather than full regeneration.
When patching, preserve ALL existing diagram structure, styling, and layout. Only modify the specific nodes, edges, or subgraphs affected by the change.
Major structural changes fall through to the full 4-phase generation workflow above.
generate_diagrams.py --interactive uses smart classification by defaultgenerate_diagrams.py --force-regen bypasses classification for full regeneration<FINAL_EMPHASIS> Every node traces to source. Every diagram renders. Every phase executes. Shortcuts produce wrong diagrams that mislead -- and a wrong diagram is worse than no diagram at all. </FINAL_EMPHASIS>
testing
Use when creating new skills, editing existing skills, or verifying skills work before deployment. Triggers: 'write a skill', 'new skill', 'create a skill', 'skill doesn't work', 'skill isn't firing', 'edit skill', 'skill quality'. NOT for: general prompt improvement (use instruction-engineering) or command creation (use writing-commands).
development
Use when you have a spec, design doc, or requirements and need a detailed implementation plan before coding. Triggers: 'write a plan', 'create implementation plan', 'plan this out', 'break this down into steps', 'convert design to tasks', 'implementation order'. Also invoked by develop during planning. NOT for: reviewing existing plans (use reviewing-impl-plans).
testing
Use when creating new commands, editing existing commands, or reviewing command quality. Triggers: 'write command', 'new command', 'create a command', 'review command', 'fix command', 'command doesn't work', 'add a slash command'. NOT for: skill creation (use writing-skills).
development
Use when about to claim discovery during debugging. Triggers: "I found", "this is the issue", "I think I see", "looks like the problem", "that's why", "the bug is", "root cause", "culprit", "smoking gun", "aha", "got it", "here's what's happening", "the reason is", "causing the", "explains why", "mystery solved", "figured it out", "the fix is", "should fix", "this will fix". Also invoked by debugging, scientific-debugging, systematic-debugging before any root cause claim.