From rails-consultant
Explains code (files, classes, methods) or user-facing flows (features, actions) with git context, logic walkthroughs, and design patterns.
How this skill is triggered — by the user, by Claude, or both
Slash command
/rails-consultant:explain [file path, class name, method, or flow description][file path, class name, method, or flow description]ExploreThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
Explain `$ARGUMENTS`. Do the research and deliver the explanation in one pass.
Explain $ARGUMENTS. Do the research and deliver the explanation in one pass.
Determine the mode from the argument:
Start by checking the git history for the file: git log --oneline -15 <file> and git log -1 -p <file> for the most recent change. Commit messages often reveal the "why" that the code itself doesn't — a bug that was fixed, a refactor that simplified something, a workaround for an external constraint. Note anything that reframes the code before diving into it.
Then read the code carefully and explain in this order:
Plain English. No jargon, no code. Describe what this code accomplishes from the outside — what goes in, what comes out, what changes as a result. Write it the way you'd explain it to the client who asked for the feature.
Narrate the code path in plain English, step by step. For each meaningful chunk:
Don't narrate every line — skip the obvious. Focus on the parts that require interpretation.
Name the Rails, Ruby, or design patterns this code is using — and why they appear here. Examples:
call method, one responsibility"delegate to avoid Law of Demeter violations"If the code is using a pattern poorly or unexpectedly, name that too — neutrally. This isn't a review, but understanding requires knowing when something is off-label.
Any non-obvious behaviour, implicit dependencies, or things that would surprise someone maintaining this code. Not a critique — just "here's what you'd need to know to work safely in this area."
Start with the Rails router. Locate the route(s) that correspond to the described flow. From each entry point, trace the execution path through the codebase — controllers, service objects, models, callbacks, jobs, mailers. Follow both success and failure paths.
Then deliver the explanation in two parts: a diagram and a summary.
Render a concise visual flowchart of the system using box-drawing characters. The diagram should show:
Conventions:
┌─┐, │, ├──, └──, ▼, ◄YES / NOThe goal is to outline the system concisely — show how it behaves, not how the code is structured. A reader should be able to understand the full lifecycle from the diagram alone.
See the example in example.md for the expected style and level of detail.
After the diagram, add three sections in plain English:
Entry points — every way this flow can be triggered. For each, one sentence describing what triggers it and what it does.
Branching logic — the conditions that shape the flow. Feature flags, state checks, validations, guard clauses — anything that determines which path is taken.
Side effects — everything with consequences outside the immediate flow. Jobs, mailers, external API calls, broadcasts, cache writes, state transitions. The things you'd need to know about before touching this code.
Clear and direct. You're translating, not teaching and not judging. The goal is that they finish with a working mental model of what this code does and how to navigate it. Skip all hedging — if something is unclear in the code itself, say so plainly.
npx claudepluginhub thoughtbot/rails-consultant --plugin rails-consultantExplains complex code, algorithms, system behaviors, and architectures with narratives, visual diagrams, and step-by-step breakdowns for all developer levels.
Explains complex code, files, or concepts using structural search and mermaid diagrams. Useful for architecture, data flow, and design analysis.
Explains code using visual diagrams, analogies, and step-by-step walkthroughs. Use when teaching a codebase or answering 'how does this work?'