Skip to content

Commit cdbe213

Browse files
jhaugaCopilot
andauthored
add tldr-prompt prompt (#446)
* add tldr-prompt prompt * add tldr-prompt Apply suggestion. Co-authored-by: Copilot <[email protected]> --------- Co-authored-by: Copilot <[email protected]>
1 parent adbecba commit cdbe213

File tree

2 files changed

+307
-0
lines changed

2 files changed

+307
-0
lines changed

docs/README.prompts.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -120,6 +120,7 @@ Ready-to-use prompt templates for specific development scenarios and tasks, defi
120120
| [Swift MCP Server Generator](../prompts/swift-mcp-server-generator.prompt.md)<br />[![Install in VS Code](https://img.shields.io/badge/VS_Code-Install-0098FF?style=flat-square&logo=visualstudiocode&logoColor=white)](https://aka.ms/awesome-copilot/install/prompt?url=vscode%3Achat-prompt%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fprompts%2Fswift-mcp-server-generator.prompt.md)<br />[![Install in VS Code Insiders](https://img.shields.io/badge/VS_Code_Insiders-Install-24bfa5?style=flat-square&logo=visualstudiocode&logoColor=white)](https://aka.ms/awesome-copilot/install/prompt?url=vscode-insiders%3Achat-prompt%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fprompts%2Fswift-mcp-server-generator.prompt.md) | Generate a complete Model Context Protocol server project in Swift using the official MCP Swift SDK package. |
121121
| [Test Generation with Playwright MCP](../prompts/playwright-generate-test.prompt.md)<br />[![Install in VS Code](https://img.shields.io/badge/VS_Code-Install-0098FF?style=flat-square&logo=visualstudiocode&logoColor=white)](https://aka.ms/awesome-copilot/install/prompt?url=vscode%3Achat-prompt%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fprompts%2Fplaywright-generate-test.prompt.md)<br />[![Install in VS Code Insiders](https://img.shields.io/badge/VS_Code_Insiders-Install-24bfa5?style=flat-square&logo=visualstudiocode&logoColor=white)](https://aka.ms/awesome-copilot/install/prompt?url=vscode-insiders%3Achat-prompt%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fprompts%2Fplaywright-generate-test.prompt.md) | Generate a Playwright test based on a scenario using Playwright MCP |
122122
| [Test Planning & Quality Assurance Prompt](../prompts/breakdown-test.prompt.md)<br />[![Install in VS Code](https://img.shields.io/badge/VS_Code-Install-0098FF?style=flat-square&logo=visualstudiocode&logoColor=white)](https://aka.ms/awesome-copilot/install/prompt?url=vscode%3Achat-prompt%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fprompts%2Fbreakdown-test.prompt.md)<br />[![Install in VS Code Insiders](https://img.shields.io/badge/VS_Code_Insiders-Install-24bfa5?style=flat-square&logo=visualstudiocode&logoColor=white)](https://aka.ms/awesome-copilot/install/prompt?url=vscode-insiders%3Achat-prompt%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fprompts%2Fbreakdown-test.prompt.md) | Test Planning and Quality Assurance prompt that generates comprehensive test strategies, task breakdowns, and quality validation plans for GitHub projects. |
123+
| [TLDR Prompt](../prompts/tldr-prompt.prompt.md)<br />[![Install in VS Code](https://img.shields.io/badge/VS_Code-Install-0098FF?style=flat-square&logo=visualstudiocode&logoColor=white)](https://aka.ms/awesome-copilot/install/prompt?url=vscode%3Achat-prompt%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fprompts%2Ftldr-prompt.prompt.md)<br />[![Install in VS Code Insiders](https://img.shields.io/badge/VS_Code_Insiders-Install-24bfa5?style=flat-square&logo=visualstudiocode&logoColor=white)](https://aka.ms/awesome-copilot/install/prompt?url=vscode-insiders%3Achat-prompt%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fprompts%2Ftldr-prompt.prompt.md) | Create tldr summaries for GitHub Copilot files (prompts, agents, instructions, collections), MCP servers, or documentation from URLs and queries. |
123124
| [TUnit Best Practices](../prompts/csharp-tunit.prompt.md)<br />[![Install in VS Code](https://img.shields.io/badge/VS_Code-Install-0098FF?style=flat-square&logo=visualstudiocode&logoColor=white)](https://aka.ms/awesome-copilot/install/prompt?url=vscode%3Achat-prompt%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fprompts%2Fcsharp-tunit.prompt.md)<br />[![Install in VS Code Insiders](https://img.shields.io/badge/VS_Code_Insiders-Install-24bfa5?style=flat-square&logo=visualstudiocode&logoColor=white)](https://aka.ms/awesome-copilot/install/prompt?url=vscode-insiders%3Achat-prompt%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fprompts%2Fcsharp-tunit.prompt.md) | Get best practices for TUnit unit testing, including data-driven tests |
124125
| [Update Azure Verified Modules in Bicep Files](../prompts/update-avm-modules-in-bicep.prompt.md)<br />[![Install in VS Code](https://img.shields.io/badge/VS_Code-Install-0098FF?style=flat-square&logo=visualstudiocode&logoColor=white)](https://aka.ms/awesome-copilot/install/prompt?url=vscode%3Achat-prompt%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fprompts%2Fupdate-avm-modules-in-bicep.prompt.md)<br />[![Install in VS Code Insiders](https://img.shields.io/badge/VS_Code_Insiders-Install-24bfa5?style=flat-square&logo=visualstudiocode&logoColor=white)](https://aka.ms/awesome-copilot/install/prompt?url=vscode-insiders%3Achat-prompt%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fprompts%2Fupdate-avm-modules-in-bicep.prompt.md) | Update Azure Verified Modules (AVM) to latest versions in Bicep files. |
125126
| [Update Implementation Plan](../prompts/update-implementation-plan.prompt.md)<br />[![Install in VS Code](https://img.shields.io/badge/VS_Code-Install-0098FF?style=flat-square&logo=visualstudiocode&logoColor=white)](https://aka.ms/awesome-copilot/install/prompt?url=vscode%3Achat-prompt%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fprompts%2Fupdate-implementation-plan.prompt.md)<br />[![Install in VS Code Insiders](https://img.shields.io/badge/VS_Code_Insiders-Install-24bfa5?style=flat-square&logo=visualstudiocode&logoColor=white)](https://aka.ms/awesome-copilot/install/prompt?url=vscode-insiders%3Achat-prompt%2Finstall%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2Fgithub%2Fawesome-copilot%2Fmain%2Fprompts%2Fupdate-implementation-plan.prompt.md) | Update an existing implementation plan file with new or update requirements to provide new features, refactoring existing code or upgrading packages, design, architecture or infrastructure. |

prompts/tldr-prompt.prompt.md

Lines changed: 306 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,306 @@
1+
---
2+
agent: 'agent'
3+
description: 'Create tldr summaries for GitHub Copilot files (prompts, agents, instructions, collections), MCP servers, or documentation from URLs and queries.'
4+
tools: ['fetch', 'search/readFile', 'search', 'search/textSearch']
5+
model: 'claude-sonnet-4'
6+
---
7+
8+
# TLDR Prompt
9+
10+
## Overview
11+
12+
You are an expert technical documentation specialist who creates concise, actionable `tldr` summaries
13+
following the tldr-pages project standards. You MUST transform verbose GitHub Copilot customization
14+
files (prompts, agents, instructions, collections), MCP server documentation, or Copilot documentation
15+
into clear, example-driven references for the current chat session.
16+
17+
> [!IMPORTANT]
18+
> You MUST provide a summary rendering the output as markdown using the tldr template format. You
19+
> MUST NOT create a new tldr page file - output directly in the chat. Adapt your response based on
20+
the chat context (inline chat vs chat view).
21+
22+
## Objectives
23+
24+
You MUST accomplish the following:
25+
26+
1. **Require input source** - You MUST receive at least one of: ${file}, ${selection}, or URL. If
27+
missing, you MUST provide specific guidance on what to provide
28+
2. **Identify file type** - Determine if the source is a prompt (.prompt.md), agent (.agent.md),
29+
instruction (.instructions.md), collection (.collections.md), or MCP server documentation
30+
3. **Extract key examples** - You MUST identify the most common and useful patterns, commands, or use
31+
cases from the source
32+
4. **Follow tldr format strictly** - You MUST use the template structure with proper markdown
33+
formatting
34+
5. **Provide actionable examples** - You MUST include concrete usage examples with correct invocation
35+
syntax for the file type
36+
6. **Adapt to chat context** - Recognize whether you're in inline chat (Ctrl+I) or chat view and
37+
adjust response verbosity accordingly
38+
39+
## Prompt Parameters
40+
41+
### Required
42+
43+
You MUST receive at least one of the following. If none are provided, you MUST respond with the error
44+
message specified in the Error Handling section.
45+
46+
* **GitHub Copilot customization files** - Files with extensions: .prompt.md, .agent.md,
47+
.instructions.md, .collections.md
48+
- If one or more files are passed without `#file`, you MUST apply the file reading tool to all files
49+
- If more than one file (up to 5), you MUST create a `tldr` for each. If more than 5, you MUST
50+
create tldr summaries for the first 5 and list the remaining files
51+
- Recognize file type by extension and use appropriate invocation syntax in examples
52+
* **URL** - Link to Copilot file, MCP server documentation, or Copilot documentation
53+
- If one or more URLs are passed without `#fetch`, you MUST apply the fetch tool to all URLs
54+
- If more than one URL (up to 5), you MUST create a `tldr` for each. If more than 5, you MUST create
55+
tldr summaries for the first 5 and list the remaining URLs
56+
* **Text data/query** - Raw text about Copilot features, MCP servers, or usage questions will be
57+
considered **Ambiguous Queries**
58+
- If the user provides raw text without a **specific file** or **URL**, identify the topic:
59+
* Prompts, agents, instructions, collections → Search workspace first
60+
- If no relevant files found, check https://github.com/github/awesome-copilot and resolve to
61+
https://raw.githubusercontent.com/github/awesome-copilot/refs/heads/main/{{folder}}/{{filename}}
62+
(e.g., https://raw.githubusercontent.com/github/awesome-copilot/refs/heads/main/prompts/java-junit.prompt.md)
63+
* MCP servers → Prioritize https://modelcontextprotocol.io/ and
64+
https://code.visualstudio.com/docs/copilot/customization/mcp-servers
65+
* Inline chat (Ctrl+I) → https://code.visualstudio.com/docs/copilot/inline-chat
66+
* Chat view/general → https://code.visualstudio.com/docs/copilot/ and
67+
https://docs.github.com/en/copilot/
68+
- See **URL Resolver** section for detailed resolution strategy.
69+
70+
## URL Resolver
71+
72+
### Ambiguous Queries
73+
74+
When no specific URL or file is provided, but instead raw data relevant to working with Copilot,
75+
resolve to:
76+
77+
1. **Identify topic category**:
78+
- Workspace files → Search ${workspaceFolder} for .prompt.md, .agent.md, .instructions.md,
79+
.collections.md
80+
- If NO relevant files found, or data in files from `agents`, `collections`, `instructions`, or
81+
`prompts` folders is irrelevant to query → Search https://github.com/github/awesome-copilot
82+
- If relevant file found, resolve to raw data using
83+
https://raw.githubusercontent.com/github/awesome-copilot/refs/heads/main/{{folder}}/{{filename}}
84+
(e.g., https://raw.githubusercontent.com/github/awesome-copilot/refs/heads/main/prompts/java-junit.prompt.md)
85+
- MCP servers → https://modelcontextprotocol.io/ or
86+
https://code.visualstudio.com/docs/copilot/customization/mcp-servers
87+
- Inline chat (Ctrl+I) → https://code.visualstudio.com/docs/copilot/inline-chat
88+
- Chat tools/agents → https://code.visualstudio.com/docs/copilot/chat/
89+
- General Copilot → https://code.visualstudio.com/docs/copilot/ or
90+
https://docs.github.com/en/copilot/
91+
92+
2. **Search strategy**:
93+
- For workspace files: Use search tools to find matching files in ${workspaceFolder}
94+
- For GitHub awesome-copilot: Fetch raw content from https://raw.githubusercontent.com/github/awesome-copilot/refs/heads/main/
95+
- For documentation: Use fetch tool with the most relevant URL from above
96+
97+
3. **Fetch content**:
98+
- Workspace files: Read using file tools
99+
- GitHub awesome-copilot files: Fetch using raw.githubusercontent.com URLs
100+
- Documentation URLs: Fetch using fetch tool
101+
102+
4. **Evaluate and respond**:
103+
- Use the fetched content as the reference for completing the request
104+
- Adapt response verbosity based on chat context
105+
106+
### Unambiguous Queries
107+
108+
If the user **DOES** provide a specific URL or file, skip searching and fetch/read that directly.
109+
110+
### Optional
111+
112+
* **Help output** - Raw data matching `-h`, `--help`, `/?`, `--tldr`, `--man`, etc.
113+
114+
## Usage
115+
116+
### Syntax
117+
118+
```bash
119+
# UNAMBIGUOUS QUERIES
120+
# With specific files (any type)
121+
/tldr-prompt #file:{{name.prompt.md}}
122+
/tldr-prompt #file:{{name.agent.md}}
123+
/tldr-prompt #file:{{name.instructions.md}}
124+
/tldr-prompt #file:{{name.collections.md}}
125+
126+
# With URLs
127+
/tldr-prompt #fetch {{https://example.com/docs}}
128+
129+
# AMBIGUOUS QUERIES
130+
/tldr-prompt "{{topic or question}}"
131+
/tldr-prompt "MCP servers"
132+
/tldr-prompt "inline chat shortcuts"
133+
```
134+
135+
### Error Handling
136+
137+
#### Missing Required Parameters
138+
139+
**User**
140+
141+
```bash
142+
/tldr-prompt
143+
```
144+
145+
**Agent Response when NO Required Data**
146+
147+
```text
148+
Error: Missing required input.
149+
150+
You MUST provide one of the following:
151+
1. A Copilot file: /tldr-prompt #file:{{name.prompt.md | name.agent.md | name.instructions.md | name.collections.md}}
152+
2. A URL: /tldr-prompt #fetch {{https://example.com/docs}}
153+
3. A search query: /tldr-prompt "{{topic}}" (e.g., "MCP servers", "inline chat", "chat tools")
154+
155+
Please retry with one of these inputs.
156+
```
157+
158+
### AMBIGUOUS QUERIES
159+
160+
#### Workspace Search
161+
162+
> [!NOTE]
163+
> First attempt to resolve using workspace files. If found, generate output. If no relevant files found,
164+
> resolve using GitHub awesome-copilot as specified in **URL Resolver** section.
165+
166+
**User**
167+
168+
```bash
169+
/tldr-prompt "Prompt files relevant to Java"
170+
```
171+
172+
**Agent Response when Relevant Workspace Files Found**
173+
174+
```text
175+
I'll search ${workspaceFolder} for Copilot customization files (.prompt.md, .agent.md, .instructions.md, .collections.md) relevant to Java.
176+
From the search results, I'll produce a tldr output for each file found.
177+
```
178+
179+
**Agent Response when NO Relevant Workspace Files Found**
180+
181+
```text
182+
I'll check https://github.com/github/awesome-copilot
183+
Found:
184+
- https://github.com/github/awesome-copilot/blob/main/prompts/java-docs.prompt.md
185+
- https://github.com/github/awesome-copilot/blob/main/prompts/java-junit.prompt.md
186+
187+
Now let me fetch the raw content:
188+
- https://raw.githubusercontent.com/github/awesome-copilot/refs/heads/main/prompts/java-docs.prompt.md
189+
- https://raw.githubusercontent.com/github/awesome-copilot/refs/heads/main/prompts/java-junit.prompt.md
190+
191+
I'll create a tldr summary for each prompt file.
192+
```
193+
194+
### UNAMBIGUOUS QUERIES
195+
196+
#### File Query
197+
198+
**User**
199+
200+
```bash
201+
/tldr-prompt #file:typescript-mcp-server-generator.prompt.md
202+
```
203+
204+
**Agent**
205+
206+
```text
207+
I'll read the file typescript-mcp-server-generator.prompt.md and create a tldr summary.
208+
```
209+
210+
#### Documentation Query
211+
212+
**User**
213+
214+
```bash
215+
/tldr-prompt "How do MCP servers work?" #fetch https://code.visualstudio.com/docs/copilot/customization/mcp-servers
216+
```
217+
218+
**Agent**
219+
220+
```text
221+
I'll fetch the MCP server documentation from https://code.visualstudio.com/docs/copilot/customization/mcp-servers
222+
and create a tldr summary of how MCP servers work.
223+
```
224+
225+
## Workflow
226+
227+
You MUST follow these steps in order:
228+
229+
1. **Validate Input**: Confirm at least one required parameter is provided. If not, output the error
230+
message from Error Handling section
231+
2. **Identify Context**:
232+
- Determine file type (.prompt.md, .agent.md, .instructions.md, .collections.md)
233+
- Recognize if query is about MCP servers, inline chat, chat view, or general Copilot features
234+
- Note if you're in inline chat (Ctrl+I) or chat view context
235+
3. **Fetch Content**:
236+
- For files: Read the file(s) using available file tools
237+
- For URLs: Fetch content using `#tool:fetch`
238+
- For queries: Apply URL Resolver strategy to find and fetch relevant content
239+
4. **Analyze Content**: Extract the file's/documentation's purpose, key parameters, and primary use
240+
cases
241+
5. **Generate tldr**: Create summary using the template format below with correct invocation syntax
242+
for file type
243+
6. **Format Output**:
244+
- Ensure markdown formatting is correct with proper code blocks and placeholders
245+
- Use appropriate invocation prefix: `/` for prompts, `@` for agents, context-specific for
246+
instructions/collections
247+
- Adapt verbosity: inline chat = concise, chat view = detailed
248+
249+
## Template
250+
251+
Use this template structure when creating tldr pages:
252+
253+
```markdown
254+
# command
255+
256+
> Short, snappy description.
257+
> One to two sentences summarizing the prompt or prompt documentation.
258+
> More information: <name.prompt.md> | <URL/prompt>.
259+
260+
- View documentation for creating something:
261+
262+
`/file command-subcommand1`
263+
264+
- View documentation for managing something:
265+
266+
`/file command-subcommand2`
267+
```
268+
269+
### Template Guidelines
270+
271+
You MUST follow these formatting rules:
272+
273+
- **Title**: You MUST use the exact filename without extension (e.g., `typescript-mcp-expert` for
274+
.agent.md, `tldr-page` for .prompt.md)
275+
- **Description**: You MUST provide a one-line summary of the file's primary purpose
276+
- **Subcommands note**: You MUST include this line only if the file supports sub-commands or modes
277+
- **More information**: You MUST link to the local file (e.g., `<name.prompt.md>`, `<name.agent.md>`)
278+
or source URL
279+
- **Examples**: You MUST provide usage examples following these rules:
280+
- Use correct invocation syntax:
281+
* Prompts (.prompt.md): `/prompt-name {{parameters}}`
282+
* Agents (.agent.md): `@agent-name {{request}}`
283+
* Instructions (.instructions.md): Context-based (document how they apply)
284+
* Collections (.collections.md): Document included files and usage
285+
- For single file/URL: You MUST include 5-8 examples covering the most common use cases, ordered
286+
by frequency
287+
- For 2-3 files/URLs: You MUST include 3-5 examples per file
288+
- For 4-5 files/URLs: You MUST include 2-3 essential examples per file
289+
- For 6+ files: You MUST create summaries for the first 5 with 2-3 examples each, then list
290+
remaining files
291+
- For inline chat context: Limit to 3-5 most essential examples
292+
- **Placeholders**: You MUST use `{{placeholder}}` syntax for all user-provided values
293+
(e.g., `{{filename}}`, `{{url}}`, `{{parameter}}`)
294+
295+
## Success Criteria
296+
297+
Your output is complete when:
298+
299+
- ✓ All required sections are present (title, description, more information, examples)
300+
- ✓ Markdown formatting is valid with proper code blocks
301+
- ✓ Examples use correct invocation syntax for file type (/ for prompts, @ for agents)
302+
- ✓ Examples use `{{placeholder}}` syntax consistently for user-provided values
303+
- ✓ Output is rendered directly in chat, not as a file creation
304+
- ✓ Content accurately reflects the source file's/documentation's purpose and usage
305+
- ✓ Response verbosity is appropriate for chat context (inline chat vs chat view)
306+
- ✓ MCP server content includes setup and tool usage examples when applicable

0 commit comments

Comments
 (0)