Merge pull request #476 from vaddisrinivas/add-code-tour
feat(engineering): add code-tour skill
This commit is contained in:
136
engineering/code-tour/SKILL.md
Normal file
136
engineering/code-tour/SKILL.md
Normal file
@@ -0,0 +1,136 @@
|
||||
---
|
||||
name: "code-tour"
|
||||
description: "Use when the user asks to create a CodeTour .tour file — persona-targeted, step-by-step walkthroughs that link to real files and line numbers. Trigger for: create a tour, onboarding tour, architecture tour, PR review tour, explain how X works, vibe check, RCA tour, contributor guide, or any structured code walkthrough request."
|
||||
---
|
||||
|
||||
# Code Tour
|
||||
|
||||
Create **CodeTour** files — persona-targeted, step-by-step walkthroughs of a codebase that link directly to files and line numbers. CodeTour files live in `.tours/` and work with the [VS Code CodeTour extension](https://github.com/microsoft/codetour).
|
||||
|
||||
## Overview
|
||||
|
||||
A great tour is a **narrative** — a story told to a specific person about what matters, why it matters, and what to do next. Only create `.tour` JSON files. Never modify source code.
|
||||
|
||||
## When to Use This Skill
|
||||
|
||||
- User asks to create a code tour, onboarding tour, or architecture walkthrough
|
||||
- User says "tour for this PR", "explain how X works", "vibe check", "RCA tour"
|
||||
- User wants a contributor guide, security review, or bug investigation walkthrough
|
||||
- Any request for a structured walkthrough with file/line anchors
|
||||
|
||||
## Core Workflow
|
||||
|
||||
### 1. Discover the repo
|
||||
|
||||
Before asking anything, explore the codebase:
|
||||
- List root directory, read README, check config files
|
||||
- Identify language(s), framework(s), project purpose
|
||||
- Map folder structure 1-2 levels deep
|
||||
- Find entry points — every path in the tour must be real
|
||||
|
||||
### 2. Infer the intent
|
||||
|
||||
One message should be enough. Infer persona, depth, and focus silently.
|
||||
|
||||
| User says | Persona | Depth |
|
||||
|-----------|---------|-------|
|
||||
| "tour for this PR" | pr-reviewer | standard |
|
||||
| "why did X break" / "RCA" | rca-investigator | standard |
|
||||
| "onboarding" / "new joiner" | new-joiner | standard |
|
||||
| "quick tour" / "vibe check" | vibecoder | quick |
|
||||
| "architecture" | architect | deep |
|
||||
| "security" / "auth review" | security-reviewer | standard |
|
||||
|
||||
### 3. Read actual files
|
||||
|
||||
**Every file path and line number must be verified.** A tour pointing to the wrong line is worse than no tour.
|
||||
|
||||
### 4. Write the tour
|
||||
|
||||
Save to `.tours/<persona>-<focus>.tour`.
|
||||
|
||||
```json
|
||||
{
|
||||
"$schema": "https://aka.ms/codetour-schema",
|
||||
"title": "Descriptive Title — Persona / Goal",
|
||||
"description": "Who this is for and what they'll understand after.",
|
||||
"ref": "main",
|
||||
"steps": []
|
||||
}
|
||||
```
|
||||
|
||||
### Step types
|
||||
|
||||
| Type | When to use | Example |
|
||||
|------|-------------|---------|
|
||||
| **Content** | Intro/closing only (max 2) | `{ "title": "Welcome", "description": "..." }` |
|
||||
| **Directory** | Orient to a module | `{ "directory": "src/services", "title": "..." }` |
|
||||
| **File + line** | The workhorse | `{ "file": "src/auth.ts", "line": 42, "title": "..." }` |
|
||||
| **Selection** | Highlight a code block | `{ "file": "...", "selection": {...}, "title": "..." }` |
|
||||
| **Pattern** | Regex match (volatile files) | `{ "file": "...", "pattern": "class App", "title": "..." }` |
|
||||
| **URI** | Link to PR, issue, doc | `{ "uri": "https://...", "title": "..." }` |
|
||||
|
||||
### Step count
|
||||
|
||||
| Depth | Steps | Use for |
|
||||
|-------|-------|---------|
|
||||
| Quick | 5-8 | Vibecoder, fast exploration |
|
||||
| Standard | 9-13 | Most personas |
|
||||
| Deep | 14-18 | Architect, RCA |
|
||||
|
||||
### Writing descriptions — SMIG formula
|
||||
|
||||
- **S — Situation**: What is the reader looking at?
|
||||
- **M — Mechanism**: How does this code work?
|
||||
- **I — Implication**: Why does this matter for this persona?
|
||||
- **G — Gotcha**: What would a smart person get wrong?
|
||||
|
||||
### 5. Validate
|
||||
|
||||
- [ ] Every `file` path relative to repo root (no leading `/` or `./`)
|
||||
- [ ] Every `file` confirmed to exist
|
||||
- [ ] Every `line` verified by reading the file
|
||||
- [ ] First step has `file` or `directory` anchor
|
||||
- [ ] At most 2 content-only steps
|
||||
- [ ] `nextTour` matches another tour's `title` exactly if set
|
||||
|
||||
## The 20 Personas
|
||||
|
||||
| Persona | Goal | Must cover |
|
||||
|---------|------|------------|
|
||||
| **Vibecoder** | Get the vibe fast | Entry point, main modules. Max 8 steps. |
|
||||
| **New joiner** | Structured ramp-up | Directories, setup, business context |
|
||||
| **Bug fixer** | Root cause fast | Trigger -> fault points -> tests |
|
||||
| **RCA investigator** | Why did it fail | Causality chain, observability anchors |
|
||||
| **Feature explainer** | End-to-end | UI -> API -> backend -> storage |
|
||||
| **PR reviewer** | Review correctly | Change story, invariants, risky areas |
|
||||
| **Architect** | Shape and rationale | Boundaries, tradeoffs, extension points |
|
||||
| **Security reviewer** | Trust boundaries | Auth flow, validation, secret handling |
|
||||
| **Refactorer** | Safe restructuring | Seams, hidden deps, extraction order |
|
||||
| **External contributor** | Contribute safely | Safe areas, conventions, landmines |
|
||||
|
||||
## Narrative Arc
|
||||
|
||||
1. **Orientation** — `file` or `directory` step (never content-only first step — blank in VS Code)
|
||||
2. **High-level map** — 1-3 directory steps showing major modules
|
||||
3. **Core path** — file/line steps, the heart of the tour
|
||||
4. **Closing** — what the reader can now do, suggested follow-ups
|
||||
|
||||
## Anti-Patterns
|
||||
|
||||
| Anti-pattern | Fix |
|
||||
|---|---|
|
||||
| **File listing** — "this file contains the models" | Tell a story. Each step depends on the previous. |
|
||||
| **Generic descriptions** | Name the specific pattern unique to this codebase. |
|
||||
| **Line number guessing** | Never write a line you didn't verify by reading. |
|
||||
| **Too many steps** for quick depth | Actually cut steps. |
|
||||
| **Hallucinated files** | If it doesn't exist, skip the step. |
|
||||
| **Recap closing** — "we covered X, Y, Z" | Tell the reader what they can now *do*. |
|
||||
| **Content-only first step** | Anchor step 1 to a file or directory. |
|
||||
|
||||
## Cross-References
|
||||
|
||||
- Related: `engineering/codebase-onboarding` — for broader onboarding beyond tours
|
||||
- Related: `engineering/code-review-automation` — for automated PR review workflows
|
||||
- Full skill with validation scripts and schema: [code-tour repo](https://github.com/vaddisrinivas/code-tour)
|
||||
- Real-world tours: [coder/code-server](https://github.com/coder/code-server/blob/main/.tours/contributing.tour)
|
||||
Reference in New Issue
Block a user