name: code-explainer description: | UTILITY SKILL - Explain code snippets, functions, and algorithms in plain language. USE FOR: explain code, what does this code do, break down this function, help me understand this, walk through this algorithm, clarify this logic, explain this snippet, describe what happens here. DO NOT USE FOR: writing new code (use code generation), fixing bugs (use debugging), refactoring (use refactoring skills), code review with action items. INVOKES: file reading tools to access code, language detection for tailored explanations. FOR SINGLE OPERATIONS: If the user just needs to see file contents, use file reading tools directly.
Code Explainer
A skill that explains code snippets in clear, educational language. Helps developers understand unfamiliar code, algorithms, and programming patterns.
Skill Activation Triggers
Use this skill immediately when the user asks to:
- "Explain this code"
- "What does this function do?"
- "Break down this algorithm"
- "Help me understand this snippet"
- "Walk me through this code"
- "What's happening in this file?"
Key Indicators:
- User shares a code snippet and asks for explanation
- User is confused about existing code
- User wants to learn how something works
- User asks "what does X do?" about code
Do NOT use when:
- User wants to write new code
- User wants to fix a bug
- User wants code review with suggestions
- User wants refactoring recommendations
Quick Reference
| Property | Value |
|---|---|
| Input | Code snippet + optional language hint |
| Output | Plain language explanation |
| Best for | Learning, onboarding, code comprehension |
Explanation Guidelines
Structure
A good code explanation should include:
- Overview - One sentence summary of what the code does
- Step-by-step breakdown - Walk through the logic
- Key concepts - Explain any patterns or techniques used
- Example - Show sample input/output if applicable
Tone
- Educational and approachable
- Avoid jargon unless explaining it
- Use analogies when helpful
- Assume the reader is smart but unfamiliar with this specific code
Language-Specific Tips
| Language | Focus On |
|---|---|
| Python | List comprehensions, decorators, generators |
| JavaScript | Async/await, closures, callbacks |
| SQL | JOINs, subqueries, aggregations |
| Java | OOP patterns, generics, streams |
Examples
Example 1: Python Recursion
User prompt:
Explain this code:
```python
def factorial(n):
if n <= 1:
return 1
return n * factorial(n - 1)
Good response:
This is a recursive function that calculates the factorial of a number.
Overview: It multiplies a number by all positive integers less than it (e.g., 5! = 5 × 4 × 3 × 2 × 1 = 120).
Step by step:
- Base case (
if n <= 1): If n is 0 or 1, return 1 (since 0! and 1! both equal 1)- Recursive case: Otherwise, multiply n by factorial(n-1)
Example:
factorial(4)→ 4 × factorial(3) → 4 × 3 × factorial(2) → 4 × 3 × 2 × factorial(1) → 4 × 3 × 2 × 1 = 24
Example 2: JavaScript Async/Await
User prompt:
What does this code do?
```javascript
async function fetchUserData(userId) {
try {
const response = await fetch(`/api/users/${userId}`);
if (!response.ok) throw new Error('User not found');
return await response.json();
} catch (error) {
console.error('Failed:', error);
return null;
}
}
Good response:
This is an async function that fetches user data from an API.
Overview: It makes an HTTP request to get a user's data, handles errors gracefully, and returns the result as JSON.
Step by step:
async function- Declares this function will use await for promisesawait fetch(...)- Makes HTTP GET request, waits for responseif (!response.ok)- Checks if request succeeded (status 200-299)await response.json()- Parses response body as JSONcatchblock - If anything fails, logs error and returns nullKey pattern: This is the standard async/await pattern for API calls with error handling.
Error Cases
If the user provides:
- No code: Ask them to share the code they want explained
- Incomplete code: Explain what you can see and note what's missing
- Non-code text: Clarify you need actual code to explain
Integration Notes
This skill works well with:
- File reading tools (to access code from files)
- Language detection (to tailor explanations)
- Search tools (to find related documentation)