explain

$npx mdskill add TheBushidoCollective/han/explain

Clarify complex code and concepts for any developer level.

  • Translates technical jargon into plain English for quick understanding.
  • Reads code, tests, and git history to gather full context.
  • Structures answers from high-level summaries to specific details.
  • Prioritizes clarity over completeness to ensure true comprehension.

SKILL.md

.github/skills/explainView on GitHub ↗
---
name: explain
description: Explain code, concepts, or technical decisions in clear, understandable terms

allowed-tools:
  - Read
  - Grep
  - Glob
  - Bash
---

# Explainer Skill

Create clear, insightful explanations of code, concepts, and technical decisions.

## Core Principle

**Clarity over completeness.** An explanation is only useful if it's understood.

## Name

han-core:explain - Explain code, concepts, or technical decisions in clear, understandable terms

## Synopsis

```
/explain [arguments]
```

## Explanation Process

### 1. Understand the Question

**What are they really asking?**

- Literal question: "What does this do?"
- Deeper question: "Why does this exist?" or "How does this work?"
- Context matters: Junior dev vs senior dev needs different explanations

### 2. Gather Full Context

**Read before explaining:**

- The code in question (obvious)
- Surrounding code (function, class, module)
- Related code (what calls it, what it calls)
- Tests (reveal intended behavior)
- Comments (capture original reasoning)
- Git history (understand evolution)

**Anti-pattern:** Explaining code you only partially understand

### 3. Structure the Explanation

**Start broad, then narrow:**

1. **One-sentence summary**: What it does in plain English
2. **Purpose**: Why it exists, what problem it solves
3. **High-level approach**: How it solves the problem (conceptually)
4. **Implementation details**: Specific code patterns, algorithms
5. **Edge cases**: Unusual scenarios handled
6. **Related concepts**: Connections to other parts of the system

### 4. Choose the Right Level

**Match explanation to context:**

**For "What does this do?"**

```
BAD: "It's a reducer function that takes state and action..."
GOOD: "This manages the shopping cart state. When you add/remove
       items, it updates the cart and recalculates the total."
```

**For "How does this work?"**

```
BAD: "It just loops through items and sums prices."
GOOD: "It iterates through cart items, applies discounts to each,
       then sums the discounted prices. Tax is calculated on the
       subtotal, not individual items, to avoid rounding errors."
```

**For "Why this approach?"**

```
BAD: "Because it's faster."
GOOD: "We chose this over X because: (1) handles async updates
       correctly, (2) prevents race conditions when multiple users
       modify the cart, (3) makes testing easier. Trade-off is
       slightly more complex code."
```

## Explanation Levels

Tailor explanations based on context:

- **High-level**: What it does and why it exists
- **Implementation**: How it works internally
- **Technical details**: Specific algorithms, patterns, edge cases
- **Historical**: Why this approach was chosen over alternatives

## Explanation Patterns

### Code Explanation Format

```markdown
## What it does

[One-sentence plain English summary]

## Purpose

[Why this code exists, what problem it solves]

## How it works

1. [High-level step 1]
2. [High-level step 2]
3. [High-level step 3]

### Key details

- [Important implementation detail 1]
- [Important implementation detail 2]

### Example

[Concrete example showing usage]

## Related

- [Link to related code/docs]
```

### Concept Explanation Format

```markdown
## [Concept Name]

[One-sentence definition]

### Why it matters

[Practical importance, when you'd use it]

### How it works

[High-level explanation without jargon]

### Example

[Concrete, relatable example]

### In our codebase

[Where we use this concept, with links]

### Common pitfalls

[What to watch out for]
```

### Decision Explanation Format

```markdown
## Decision: [What was decided]

### Context

[Situation that required a decision]

### Options considered

1. **[Option 1]**: [Brief description]
   - Pros: [Key benefits]
   - Cons: [Key drawbacks]

2. **[Option 2]**: [Brief description]
   - Pros: [Key benefits]
   - Cons: [Key drawbacks]

### Choice: [Selected option]

**Rationale:**
[Why this option was chosen over others]

### Trade-offs accepted

[What we gave up by choosing this approach]

### References

[Links to discussions, docs, related decisions]
```

## Writing Guidelines

### Be Concrete

**Bad:** "This uses a common design pattern for state management"
**Good:** "This uses the Redux pattern: all state changes go through a central store via actions and reducers"

### Use Analogies (When Helpful)

**Example:**
"Think of this like a restaurant kitchen:

- Actions are customer orders
- Reducers are chefs preparing food
- Store is the completed order waiting area"

**Warning:** Don't force analogies. If it's clearer without, skip it.

### Show, Don't Just Tell

```typescript
// BAD explanation:
// "This function filters and maps the array"

// GOOD explanation:
// "This function finds all active users and formats them for display:
const displayUsers = users
  .filter(u => u.status === 'active')  // Only show active users
  .map(u => ({                         // Convert to display format
    id: u.id,
    name: `${u.firstName} ${u.lastName}`,
    joined: formatDate(u.createdAt)
  }))
```

### Avoid Jargon (Unless Explaining Jargon)

**Bad:** "This leverages a memoized selector with referential equality optimization"
**Good:** "This caches the filtered list so we don't recalculate it every render, improving performance"

**Exception:** When explaining what jargon means:
"Memoization means caching function results so we don't recompute the same thing twice."

## Common Explanation Scenarios

### Explaining Error Messages

```markdown
## Error: "Cannot read property 'map' of undefined"

**What happened:**
You're trying to use `.map()` on something that's `undefined`.

**Where:** [Link to line]

**Why:**
The `users` array hasn't loaded yet (async), so it's `undefined`
when the component first renders.

**Fix:**
```typescript
// Before
users.map(u => ...)

// After
{users?.map(u => ...) || <Loading />}
```

**Why this works:**
`?.` is optional chaining - it only calls `.map()` if `users`
exists. If not, it shows a loading state instead.

```

### Explaining "Why Not X?"

```markdown
## Why not use X?

**Context:** [What X is]

**Reasons we chose Y instead:**

1. **[Primary reason]**: [Explanation]
2. **[Secondary reason]**: [Explanation]
3. **[Tertiary reason]**: [Explanation]

**Trade-offs:**
Y is slower than X, but the reliability benefit outweighs the
50ms performance difference.

**When X would be better:**
If we needed real-time updates (< 100ms), X would be the right choice.
```

### Explaining Legacy Code

```markdown
## Legacy: [Module Name]

**What it does:** [Current function]

**History:**
This was written in 2019 when [context]. At the time, [justification].

**Why it looks odd today:**
Modern approaches would use [better pattern], but this works and
changing it isn't worth the risk.

**If you must modify it:**
1. [Key constraint to preserve]
2. [Another constraint]
3. Add tests first (none exist currently)

**Related:** See [modern equivalent] for new code.
```

## Output Format

- Start with a brief summary
- Break complex explanations into sections
- Use code examples to illustrate points
- Link to relevant documentation
- Avoid jargon unless explaining jargon

## Anti-Patterns

### Assuming Knowledge

```
BAD: "This uses HOCs to inject props via connect()"
GOOD: "This connects the component to Redux, giving it access
       to the store data it needs. See: [Redux docs link]"
```

### Over-explaining Obvious Code

```typescript
// Don't explain this:
const total = price * quantity  // Multiplies price by quantity

// Do explain this:
const total = price * quantity * (1 - discount) * TAX_RATE
// Discount applied before tax, per accounting requirements
```

### Vague References

```
BAD: "Similar to what we do in other places"
GOOD: "Similar to UserService.findActive() in services/user.ts:45"
```

### Explaining *How* When Asked *Why*

**Question:** "Why do we use a Set here instead of an Array?"

**Bad:** "A Set is initialized with `new Set()` and supports `.add()` and `.has()` methods..."

**Good:** "A Set automatically removes duplicates. We need unique user IDs, and Set handles that for us. An Array would require manual duplicate checking."

## Verification

**After explaining, check:**

- Does this answer the actual question asked?
- Is it understandable without reading it 3 times?
- Are technical terms explained or linked?
- Are there concrete examples?
- Does it avoid unnecessary complexity?
- Would someone new to the codebase understand this?

## Examples

When the user says:

- "Explain what this function does"
- "Why are we using this pattern here?"
- "What's the difference between these two approaches?"
- "How does the authentication flow work?"
- "Explain this error message"

## Integration with Other Skills

- Use **code-reviewer** skill when explaining code quality issues
- Use **proof-of-work** skill when explaining behavior (show actual output)
- Use **simplicity-principles** skill when explaining why simpler is better
- Reference other skills when explaining patterns they cover

## Notes

- Focus on clarity over completeness
- Use analogies when helpful
- Provide context for technical decisions
- Include links to related code or docs

## Remember

**The best explanation is the one that's understood, not the one that's most complete.**

If in doubt, start simple and add detail only when needed.

More from TheBushidoCollective/han

SkillDescription
absinthe-resolversUse when implementing GraphQL resolvers with Absinthe. Covers resolver patterns, dataloader integration, batching, and error handling.
absinthe-schemaUse when designing GraphQL schemas with Absinthe. Covers type definitions, interfaces, unions, enums, and schema organization patterns.
absinthe-subscriptionsUse when implementing real-time GraphQL subscriptions with Absinthe. Covers Phoenix channels, PubSub, and subscription patterns.
act-docker-setupUse when configuring Docker environments for act, selecting runner images, managing container resources, or troubleshooting Docker-related issues with local GitHub Actions testing.
act-local-testingUse when testing GitHub Actions workflows locally with act. Covers act CLI usage, Docker configuration, debugging workflows, and troubleshooting common issues when running workflows on your local machine.
act-workflow-syntaxUse when creating or modifying GitHub Actions workflow files. Provides guidance on workflow syntax, triggers, jobs, steps, and expressions for creating valid GitHub Actions workflows that can be tested locally with act.
ameba-configurationUse when configuring Ameba rules and settings for Crystal projects including .ameba.yml setup, rule management, severity levels, and code quality enforcement.
ameba-custom-rulesUse when creating custom Ameba rules for Crystal code analysis including rule development, AST traversal, issue reporting, and rule testing.
ameba-integrationUse when integrating Ameba into development workflows including CI/CD pipelines, pre-commit hooks, GitHub Actions, and automated code review processes.
analyze-performanceAnalyze performance metrics and identify slow transactions in Sentry