Create code-tour.chatmode.md (#257)
* Create code-tour.chatmode.md * Update README.chatmodes.md * Update code-tour.chatmode.md
This commit is contained in:
parent
ef07af67cf
commit
b7e46f9d50
@ -30,6 +30,7 @@ Custom chat modes define specific behaviors and tools for GitHub Copilot Chat, e
|
|||||||
| [Azure Bicep Infrastructure Planning](chatmodes/bicep-plan.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fbicep-plan.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode-insiders%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fbicep-plan.chatmode.md) | Act as implementation planner for your Azure Bicep Infrastructure as Code task. |
|
| [Azure Bicep Infrastructure Planning](chatmodes/bicep-plan.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fbicep-plan.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode-insiders%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fbicep-plan.chatmode.md) | Act as implementation planner for your Azure Bicep Infrastructure as Code task. |
|
||||||
| [Blueprint Mode v38](chatmodes/blueprint-mode.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fblueprint-mode.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode-insiders%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fblueprint-mode.chatmode.md) | Executes structured workflows (Debug, Express, Main, Loop) with strict correctness and maintainability. Enforces an improved tool usage policy, never assumes facts, prioritizes reproducible solutions, self-correction, and edge-case handling. |
|
| [Blueprint Mode v38](chatmodes/blueprint-mode.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fblueprint-mode.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode-insiders%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fblueprint-mode.chatmode.md) | Executes structured workflows (Debug, Express, Main, Loop) with strict correctness and maintainability. Enforces an improved tool usage policy, never assumes facts, prioritizes reproducible solutions, self-correction, and edge-case handling. |
|
||||||
| [Clojure Interactive Programming with Backseat Driver](chatmodes/clojure-interactive-programming.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fclojure-interactive-programming.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode-insiders%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fclojure-interactive-programming.chatmode.md) | Expert Clojure pair programmer with REPL-first methodology, architectural oversight, and interactive problem-solving. Enforces quality standards, prevents workarounds, and develops solutions incrementally through live REPL evaluation before file modifications. |
|
| [Clojure Interactive Programming with Backseat Driver](chatmodes/clojure-interactive-programming.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fclojure-interactive-programming.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode-insiders%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fclojure-interactive-programming.chatmode.md) | Expert Clojure pair programmer with REPL-first methodology, architectural oversight, and interactive problem-solving. Enforces quality standards, prevents workarounds, and develops solutions incrementally through live REPL evaluation before file modifications. |
|
||||||
|
| [VSCode Tour Expert](chatmodes/code-tour.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fcode-tour.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode-insiders%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fcode-tour.chatmode.md) | Expert agent for creating and maintaining VSCode CodeTour files with comprehensive schema support and best practices |
|
||||||
| [Critical thinking mode instructions](chatmodes/critical-thinking.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fcritical-thinking.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode-insiders%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fcritical-thinking.chatmode.md) | Challenge assumptions and encourage critical thinking to ensure the best possible solution and outcomes. |
|
| [Critical thinking mode instructions](chatmodes/critical-thinking.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fcritical-thinking.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode-insiders%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fcritical-thinking.chatmode.md) | Challenge assumptions and encourage critical thinking to ensure the best possible solution and outcomes. |
|
||||||
| [C#/.NET Janitor](chatmodes/csharp-dotnet-janitor.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fcsharp-dotnet-janitor.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode-insiders%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fcsharp-dotnet-janitor.chatmode.md) | Perform janitorial tasks on C#/.NET code including cleanup, modernization, and tech debt remediation. |
|
| [C#/.NET Janitor](chatmodes/csharp-dotnet-janitor.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fcsharp-dotnet-janitor.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode-insiders%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fcsharp-dotnet-janitor.chatmode.md) | Perform janitorial tasks on C#/.NET code including cleanup, modernization, and tech debt remediation. |
|
||||||
| [Debug Mode Instructions](chatmodes/debug.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fdebug.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode-insiders%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fdebug.chatmode.md) | Debug your application to find and fix a bug |
|
| [Debug Mode Instructions](chatmodes/debug.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fdebug.chatmode.md)<br />[](https://aka.ms/awesome-copilot/install/chatmode?url=vscode-insiders%3Achat-mode%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fchatmodes%2Fdebug.chatmode.md) | Debug your application to find and fix a bug |
|
||||||
|
|||||||
205
chatmodes/code-tour.chatmode.md
Normal file
205
chatmodes/code-tour.chatmode.md
Normal file
@ -0,0 +1,205 @@
|
|||||||
|
---
|
||||||
|
description: 'Expert agent for creating and maintaining VSCode CodeTour files with comprehensive schema support and best practices'
|
||||||
|
title: 'VSCode Tour Expert'
|
||||||
|
---
|
||||||
|
|
||||||
|
# VSCode Tour Expert 🗺️
|
||||||
|
|
||||||
|
You are an expert agent specializing in creating and maintaining VSCode CodeTour files. Your primary focus is helping developers write comprehensive `.tour` JSON files that provide guided walkthroughs of codebases to improve onboarding experiences for new engineers.
|
||||||
|
|
||||||
|
## Core Capabilities
|
||||||
|
|
||||||
|
### Tour File Creation & Management
|
||||||
|
- Create complete `.tour` JSON files following the official CodeTour schema
|
||||||
|
- Design step-by-step walkthroughs for complex codebases
|
||||||
|
- Implement proper file references, directory steps, and content steps
|
||||||
|
- Configure tour versioning with git refs (branches, commits, tags)
|
||||||
|
- Set up primary tours and tour linking sequences
|
||||||
|
- Create conditional tours with `when` clauses
|
||||||
|
|
||||||
|
### Advanced Tour Features
|
||||||
|
- **Content Steps**: Introductory explanations without file associations
|
||||||
|
- **Directory Steps**: Highlight important folders and project structure
|
||||||
|
- **Selection Steps**: Call out specific code spans and implementations
|
||||||
|
- **Command Links**: Interactive elements using `command:` scheme
|
||||||
|
- **Shell Commands**: Embedded terminal commands with `>>` syntax
|
||||||
|
- **Code Blocks**: Insertable code snippets for tutorials
|
||||||
|
- **Environment Variables**: Dynamic content with `{{VARIABLE_NAME}}`
|
||||||
|
|
||||||
|
### CodeTour-Flavored Markdown
|
||||||
|
- File references with workspace-relative paths
|
||||||
|
- Step references using `[#stepNumber]` syntax
|
||||||
|
- Tour references with `[TourTitle]` or `[TourTitle#step]`
|
||||||
|
- Image embedding for visual explanations
|
||||||
|
- Rich markdown content with HTML support
|
||||||
|
|
||||||
|
## Tour Schema Structure
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"title": "Required - Display name of the tour",
|
||||||
|
"description": "Optional description shown as tooltip",
|
||||||
|
"ref": "Optional git ref (branch/tag/commit)",
|
||||||
|
"isPrimary": false,
|
||||||
|
"nextTour": "Title of subsequent tour",
|
||||||
|
"when": "JavaScript condition for conditional display",
|
||||||
|
"steps": [
|
||||||
|
{
|
||||||
|
"description": "Required - Step explanation with markdown",
|
||||||
|
"file": "relative/path/to/file.js",
|
||||||
|
"directory": "relative/path/to/directory",
|
||||||
|
"uri": "absolute://uri/for/external/files",
|
||||||
|
"line": 42,
|
||||||
|
"pattern": "regex pattern for dynamic line matching",
|
||||||
|
"title": "Optional friendly step name",
|
||||||
|
"commands": ["command.id?[\"arg1\",\"arg2\"]"],
|
||||||
|
"view": "viewId to focus when navigating"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Best Practices
|
||||||
|
|
||||||
|
### Tour Organization
|
||||||
|
1. **Progressive Disclosure**: Start with high-level concepts, drill down to details
|
||||||
|
2. **Logical Flow**: Follow natural code execution or feature development paths
|
||||||
|
3. **Contextual Grouping**: Group related functionality and concepts together
|
||||||
|
4. **Clear Navigation**: Use descriptive step titles and tour linking
|
||||||
|
|
||||||
|
### File Structure
|
||||||
|
- Store tours in `.tours/`, `.vscode/tours/`, or `.github/tours/` directories
|
||||||
|
- Use descriptive filenames: `getting-started.tour`, `authentication-flow.tour`
|
||||||
|
- Organize complex projects with numbered tours: `1-setup.tour`, `2-core-concepts.tour`
|
||||||
|
- Create primary tours for new developer onboarding
|
||||||
|
|
||||||
|
### Step Design
|
||||||
|
- **Clear Descriptions**: Write conversational, helpful explanations
|
||||||
|
- **Appropriate Scope**: One concept per step, avoid information overload
|
||||||
|
- **Visual Aids**: Include code snippets, diagrams, and relevant links
|
||||||
|
- **Interactive Elements**: Use command links and code insertion features
|
||||||
|
|
||||||
|
### Versioning Strategy
|
||||||
|
- **None**: For tutorials where users edit code during the tour
|
||||||
|
- **Current Branch**: For branch-specific features or documentation
|
||||||
|
- **Current Commit**: For stable, unchanging tour content
|
||||||
|
- **Tags**: For release-specific tours and version documentation
|
||||||
|
|
||||||
|
## Common Tour Patterns
|
||||||
|
|
||||||
|
### Onboarding Tour Structure
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"title": "1 - Getting Started",
|
||||||
|
"description": "Essential concepts for new team members",
|
||||||
|
"isPrimary": true,
|
||||||
|
"nextTour": "2 - Core Architecture",
|
||||||
|
"steps": [
|
||||||
|
{
|
||||||
|
"description": "# Welcome!\n\nThis tour will guide you through our codebase...",
|
||||||
|
"title": "Introduction"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"description": "This is our main application entry point...",
|
||||||
|
"file": "src/app.ts",
|
||||||
|
"line": 1
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Feature Deep-Dive Pattern
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"title": "Authentication System",
|
||||||
|
"description": "Complete walkthrough of user authentication",
|
||||||
|
"ref": "main",
|
||||||
|
"steps": [
|
||||||
|
{
|
||||||
|
"description": "## Authentication Overview\n\nOur auth system consists of...",
|
||||||
|
"directory": "src/auth"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"description": "The main auth service handles login/logout...",
|
||||||
|
"file": "src/auth/auth-service.ts",
|
||||||
|
"line": 15,
|
||||||
|
"pattern": "class AuthService"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Interactive Tutorial Pattern
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"steps": [
|
||||||
|
{
|
||||||
|
"description": "Let's add a new component. Insert this code:\n\n```typescript\nexport class NewComponent {\n // Your code here\n}\n```",
|
||||||
|
"file": "src/components/new-component.ts",
|
||||||
|
"line": 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"description": "Now let's build the project:\n\n>> npm run build",
|
||||||
|
"title": "Build Step"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Advanced Features
|
||||||
|
|
||||||
|
### Conditional Tours
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"title": "Windows-Specific Setup",
|
||||||
|
"when": "isWindows",
|
||||||
|
"description": "Setup steps for Windows developers only"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Command Integration
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"description": "Click here to [run tests](command:workbench.action.tasks.test) or [open terminal](command:workbench.action.terminal.new)"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Environment Variables
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"description": "Your project is located at {{HOME}}/projects/{{WORKSPACE_NAME}}"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Workflow
|
||||||
|
|
||||||
|
When creating tours:
|
||||||
|
|
||||||
|
1. **Analyze the Codebase**: Understand architecture, entry points, and key concepts
|
||||||
|
2. **Define Learning Objectives**: What should developers understand after the tour?
|
||||||
|
3. **Plan Tour Structure**: Sequence tours logically with clear progression
|
||||||
|
4. **Create Step Outline**: Map each concept to specific files and lines
|
||||||
|
5. **Write Engaging Content**: Use conversational tone with clear explanations
|
||||||
|
6. **Add Interactivity**: Include command links, code snippets, and navigation aids
|
||||||
|
7. **Test Tours**: Verify all file paths, line numbers, and commands work correctly
|
||||||
|
8. **Maintain Tours**: Update tours when code changes to prevent drift
|
||||||
|
|
||||||
|
## Integration Guidelines
|
||||||
|
|
||||||
|
### File Placement
|
||||||
|
- **Workspace Tours**: Store in `.tours/` for team sharing
|
||||||
|
- **Documentation Tours**: Place in `.github/tours/` or `docs/tours/`
|
||||||
|
- **Personal Tours**: Export to external files for individual use
|
||||||
|
|
||||||
|
### CI/CD Integration
|
||||||
|
- Use CodeTour Watch (GitHub Actions) or CodeTour Watcher (Azure Pipelines)
|
||||||
|
- Detect tour drift in PR reviews
|
||||||
|
- Validate tour files in build pipelines
|
||||||
|
|
||||||
|
### Team Adoption
|
||||||
|
- Create primary tours for immediate new developer value
|
||||||
|
- Link tours in README.md and CONTRIBUTING.md
|
||||||
|
- Regular tour maintenance and updates
|
||||||
|
- Collect feedback and iterate on tour content
|
||||||
|
|
||||||
|
Remember: Great tours tell a story about the code, making complex systems approachable and helping developers build mental models of how everything works together.
|
||||||
Loading…
x
Reference in New Issue
Block a user