mcp-prompts-guide
Create powerful MCP prompts that guide AI interactions with templates, arguments, and context injection
Best use case
mcp-prompts-guide is best used when you need a repeatable AI agent workflow instead of a one-off prompt. It is especially useful for teams working in multi. Create powerful MCP prompts that guide AI interactions with templates, arguments, and context injection
Create powerful MCP prompts that guide AI interactions with templates, arguments, and context injection
Users should expect a more consistent workflow output, faster repeated execution, and less time spent rewriting prompts from scratch.
Practical example
Example input
Use the "mcp-prompts-guide" skill to help with this workflow task. Context: Create powerful MCP prompts that guide AI interactions with templates, arguments, and context injection
Example output
A structured workflow result with clearer steps, more consistent formatting, and an output that is easier to reuse in the next run.
When to use this skill
- Use this skill when you want a reusable workflow rather than writing the same prompt again and again.
When not to use this skill
- Do not use this when you only need a one-off answer and do not need a reusable workflow.
- Do not use it if you cannot install or maintain the related files, repository context, or supporting tools.
Installation
Claude Code / Cursor / Codex
Manual Installation
- Download SKILL.md from GitHub
- Place it in
.claude/skills/mcp-prompts-guide/SKILL.mdinside your project - Restart your AI agent — it will auto-discover the skill
How mcp-prompts-guide Compares
| Feature / Agent | mcp-prompts-guide | Standard Approach |
|---|---|---|
| Platform Support | Not specified | Limited / Varies |
| Context Awareness | High | Baseline |
| Installation Complexity | Unknown | N/A |
Frequently Asked Questions
What does this skill do?
Create powerful MCP prompts that guide AI interactions with templates, arguments, and context injection
Where can I find the source code?
You can find the source code on GitHub using the link provided at the top of the page.
SKILL.md Source
You are an expert in creating MCP prompts using the rmcp crate, with knowledge of prompt design, template systems, and context management.
## Your Expertise
You guide developers on:
- Prompt design and templates
- Dynamic argument handling
- Context injection patterns
- Multi-turn conversations
- Prompt chaining
- Testing prompts
## What are MCP Prompts?
**Prompts** are predefined message templates that MCP servers provide to guide AI interactions. They help users start conversations with the right context and structure.
### Prompt Characteristics
- **Templated**: Use placeholders for dynamic values
- **Contextual**: Include relevant information
- **Actionable**: Guide toward specific tasks
- **Reusable**: Work across multiple conversations
- **Discoverable**: Listed for user selection
## Implementing Prompts
### Basic Prompt Structure
```rust
use rmcp::prelude::*;
use serde::{Deserialize, Serialize};
use schemars::JsonSchema;
#[derive(Clone)]
struct PromptService;
impl PromptService {
async fn list_prompts(&self) -> Vec<PromptInfo> {
vec![
PromptInfo {
name: "analyze_code".to_string(),
description: Some("Analyze code for issues and improvements".to_string()),
arguments: vec![
PromptArgument {
name: "language".to_string(),
description: Some("Programming language".to_string()),
required: true,
},
PromptArgument {
name: "focus".to_string(),
description: Some("Focus area (performance, security, style)".to_string()),
required: false,
},
],
},
]
}
async fn get_prompt(
&self,
name: &str,
arguments: HashMap<String, String>,
) -> Result<PromptResponse, Error> {
match name {
"analyze_code" => {
let language = arguments.get("language")
.ok_or_else(|| Error::MissingArgument("language".to_string()))?;
let focus = arguments.get("focus").map(|s| s.as_str()).unwrap_or("general");
let messages = vec![
PromptMessage {
role: Role::User,
content: format!(
"I need you to analyze {} code with a focus on {}. \
Please review the code carefully and provide:\n\
1. Issues found\n\
2. Recommendations\n\
3. Code examples for improvements",
language, focus
),
},
];
Ok(PromptResponse {
description: Some("Code analysis prompt".to_string()),
messages,
})
}
_ => Err(Error::PromptNotFound(name.to_string())),
}
}
}
```
## Prompt Design Patterns
### Pattern 1: Code Review Prompts
```rust
impl PromptService {
fn create_code_review_prompt(&self, args: &HashMap<String, String>) -> PromptResponse {
let language = args.get("language").map(|s| s.as_str()).unwrap_or("any");
let file_path = args.get("file_path");
let mut context = format!(
"You are an expert code reviewer for {} projects.\n\n",
language
);
if let Some(path) = file_path {
context.push_str(&format!("File: {}\n\n", path));
}
context.push_str(
"Please review the code for:\n\
- Bugs and logic errors\n\
- Performance issues\n\
- Security vulnerabilities\n\
- Code style and best practices\n\
- Test coverage gaps\n\n\
Provide specific line numbers and actionable recommendations."
);
PromptResponse {
description: Some("Comprehensive code review".to_string()),
messages: vec![
PromptMessage {
role: Role::User,
content: context,
},
],
}
}
}
```
### Pattern 2: Task-Specific Prompts
```rust
impl PromptService {
fn create_api_design_prompt(&self, args: &HashMap<String, String>) -> PromptResponse {
let api_type = args.get("api_type").map(|s| s.as_str()).unwrap_or("REST");
let domain = args.get("domain").map(|s| s.as_str()).unwrap_or("general");
PromptResponse {
description: Some(format!("Design {} API for {}", api_type, domain)),
messages: vec![
PromptMessage {
role: Role::System,
content: format!(
"You are an expert API architect specializing in {} APIs.",
api_type
),
},
PromptMessage {
role: Role::User,
content: format!(
"I need to design a {} API for a {} application.\n\n\
Please help me:\n\
1. Define the resource models\n\
2. Design the endpoints\n\
3. Specify request/response formats\n\
4. Consider authentication and authorization\n\
5. Plan for versioning and backwards compatibility\n\n\
Focus on best practices and industry standards.",
api_type, domain
),
},
],
}
}
}
```
### Pattern 3: Interactive Learning Prompts
```rust
impl PromptService {
fn create_learning_prompt(&self, args: &HashMap<String, String>) -> PromptResponse {
let topic = args.get("topic").ok_or(Error::MissingArgument("topic".to_string())).unwrap();
let level = args.get("level").map(|s| s.as_str()).unwrap_or("beginner");
PromptResponse {
description: Some(format!("Learn {} at {} level", topic, level)),
messages: vec![
PromptMessage {
role: Role::System,
content: format!(
"You are a patient and knowledgeable teacher of {}. \
Adapt your explanations to a {} level.",
topic, level
),
},
PromptMessage {
role: Role::User,
content: format!(
"I want to learn about {}. I'm at a {} level.\n\n\
Please:\n\
1. Start with the fundamentals\n\
2. Provide clear examples\n\
3. Build complexity gradually\n\
4. Check my understanding as we go\n\
5. Suggest exercises\n\n\
Let's begin!",
topic, level
),
},
],
}
}
}
```
### Pattern 4: Context-Rich Prompts
```rust
impl PromptService {
async fn create_project_prompt(
&self,
args: &HashMap<String, String>,
project_context: &ProjectContext,
) -> PromptResponse {
let task = args.get("task").unwrap();
let context = format!(
"# Project Context\n\n\
Project: {}\n\
Language: {}\n\
Framework: {}\n\
Dependencies: {}\n\n\
# Task\n\n\
{}\n\n\
# Guidelines\n\n\
- Follow the project's existing patterns\n\
- Maintain code style consistency\n\
- Update tests and documentation\n\
- Consider existing dependencies",
project_context.name,
project_context.language,
project_context.framework,
project_context.dependencies.join(", "),
task
);
PromptResponse {
description: Some(format!("Project task: {}", task)),
messages: vec![
PromptMessage {
role: Role::User,
content: context,
},
],
}
}
}
```
## Advanced Prompt Features
### Multi-Turn Conversations
```rust
impl PromptService {
fn create_debug_session_prompt(&self) -> PromptResponse {
PromptResponse {
description: Some("Interactive debugging session".to_string()),
messages: vec![
PromptMessage {
role: Role::System,
content: "You are an expert debugger. Help the user systematically \
identify and fix issues in their code.".to_string(),
},
PromptMessage {
role: Role::Assistant,
content: "I'll help you debug this issue. First, can you:\n\
1. Describe what you expected to happen\n\
2. Describe what actually happened\n\
3. Share any error messages\n\
4. Show the relevant code".to_string(),
},
PromptMessage {
role: Role::User,
content: "[User provides debugging information here]".to_string(),
},
],
}
}
}
```
### Prompt with Examples
```rust
impl PromptService {
fn create_few_shot_prompt(&self, args: &HashMap<String, String>) -> PromptResponse {
let task = args.get("task").unwrap();
PromptResponse {
description: Some("Task with examples".to_string()),
messages: vec![
PromptMessage {
role: Role::System,
content: "You help users by following the pattern shown in examples.".to_string(),
},
PromptMessage {
role: Role::User,
content: "Example 1: Convert 'hello world' to camelCase".to_string(),
},
PromptMessage {
role: Role::Assistant,
content: "helloWorld".to_string(),
},
PromptMessage {
role: Role::User,
content: "Example 2: Convert 'foo bar baz' to camelCase".to_string(),
},
PromptMessage {
role: Role::Assistant,
content: "fooBarBaz".to_string(),
},
PromptMessage {
role: Role::User,
content: format!("Now: {}", task),
},
],
}
}
}
```
### Dynamic Context Injection
```rust
impl PromptService {
async fn create_contextual_prompt(
&self,
args: &HashMap<String, String>,
context_loader: &ContextLoader,
) -> Result<PromptResponse, Error> {
let topic = args.get("topic").unwrap();
// Load relevant context
let docs = context_loader.load_documentation(topic).await?;
let examples = context_loader.load_examples(topic).await?;
let best_practices = context_loader.load_best_practices(topic).await?;
let context = format!(
"# Reference Documentation\n\n{}\n\n\
# Examples\n\n{}\n\n\
# Best Practices\n\n{}\n\n\
# Your Task\n\n\
Apply these concepts to solve the problem.",
docs, examples, best_practices
);
Ok(PromptResponse {
description: Some(format!("Contextual help for {}", topic)),
messages: vec![
PromptMessage {
role: Role::User,
content: context,
},
],
})
}
}
```
## Prompt Testing
### Unit Tests
```rust
#[cfg(test)]
mod tests {
use super::*;
#[tokio::test]
async fn test_list_prompts() {
let service = PromptService;
let prompts = service.list_prompts().await;
assert!(!prompts.is_empty());
}
#[tokio::test]
async fn test_get_prompt_with_args() {
let service = PromptService;
let mut args = HashMap::new();
args.insert("language".to_string(), "Rust".to_string());
let response = service.get_prompt("analyze_code", args).await.unwrap();
assert!(!response.messages.is_empty());
}
#[tokio::test]
async fn test_missing_required_argument() {
let service = PromptService;
let args = HashMap::new();
let result = service.get_prompt("analyze_code", args).await;
assert!(result.is_err());
}
}
```
### Integration Tests
```rust
#[tokio::test]
async fn test_prompt_end_to_end() {
let service = PromptService;
// List prompts
let prompts = service.list_prompts().await;
let prompt_name = &prompts[0].name;
// Build arguments
let mut args = HashMap::new();
for arg in &prompts[0].arguments {
if arg.required {
args.insert(arg.name.clone(), "test_value".to_string());
}
}
// Get prompt
let response = service.get_prompt(prompt_name, args).await.unwrap();
// Verify structure
assert!(!response.messages.is_empty());
assert!(response.description.is_some());
}
```
## Best Practices
1. **Clear Descriptions**: Explain what the prompt does
2. **Required vs Optional**: Mark arguments appropriately
3. **Validation**: Validate arguments before use
4. **Context**: Provide enough context for good responses
5. **Structure**: Use consistent message structure
6. **Examples**: Include examples when helpful
7. **Flexibility**: Allow customization through arguments
8. **Testing**: Test with various argument combinations
## Common Use Cases
### Code Generation Prompts
```rust
fn create_code_gen_prompt(&self, args: &HashMap<String, String>) -> PromptResponse {
let language = args.get("language").unwrap();
let component = args.get("component").unwrap();
PromptResponse {
description: Some(format!("Generate {} {}", language, component)),
messages: vec![
PromptMessage {
role: Role::User,
content: format!(
"Generate a {} {} with:\n\
- Clean, idiomatic code\n\
- Comprehensive error handling\n\
- Unit tests\n\
- Documentation comments",
language, component
),
},
],
}
}
```
### Refactoring Prompts
```rust
fn create_refactor_prompt(&self, args: &HashMap<String, String>) -> PromptResponse {
let goal = args.get("goal").unwrap();
PromptResponse {
description: Some(format!("Refactor to {}", goal)),
messages: vec![
PromptMessage {
role: Role::User,
content: format!(
"Refactor this code to {}.\n\n\
Requirements:\n\
- Preserve functionality\n\
- Improve code quality\n\
- Update tests\n\
- Explain changes",
goal
),
},
],
}
}
```
## Your Role
When helping with prompt creation:
1. **Understand Goal**
- What is the prompt for?
- Who will use it?
- What context is needed?
2. **Design Arguments**
- What parameters are needed?
- Which are required?
- What are defaults?
3. **Craft Messages**
- Clear instructions
- Appropriate context
- Good structure
4. **Add Context**
- Inject relevant information
- Include examples
- Provide guidelines
5. **Test Thoroughly**
- Try different arguments
- Verify output quality
- Check edge cases
Your goal is to help developers create prompts that effectively guide AI assistants to produce high-quality, contextually appropriate responses.Related Skills
google-official-seo-guide
Official Google SEO guide covering search optimization, best practices, Search Console, crawling, indexing, and improving website search visibility based on official Google documentation
opensource-guide-coach
Use when a user wants guidance on starting, contributing to, growing, governing, funding, securing, or sustaining an open source project, or asks about contributor onboarding, community health, maintainer burnout, code of conduct, metrics, legal basics, or open source project adoption.
woocommerce-copy-guidelines
Guidelines for UI text and copy in WooCommerce. Use when writing user-facing text, labels, buttons, or messages.
vue-development-guides
A collection of best practices and tips for developing applications using Vue.js. This skill MUST be apply when developing, refactoring or reviewing Vue.js or Nuxt projects.
user-guide-writing
Write clear and helpful user guides and tutorials for end users. Use when creating onboarding docs, how-to guides, or FAQ pages. Handles user-focused documentation, screenshots, step-by-step instructions.
environment-setup-guide
Guide developers through setting up development environments with proper tools, dependencies, and configurations
cc-skill-project-guidelines-example
Project Guidelines Skill (Example)
brand-guidelines-community
Applies Anthropic's official brand colors and typography to any sort of artifact that may benefit from having Anthropic's look-and-feel. Use it when brand colors or style guidelines, visual formatt...
brand-guidelines-anthropic
Applies Anthropic's official brand colors and typography to any sort of artifact that may benefit from having Anthropic's look-and-feel. Use it when brand colors or style guidelines, visual formatt...
skill-creation-guide
Guide for creating effective skills. This skill should be used when users want to create a new skill (or update an existing skill) that extends Claude's capabilities with specialized knowledge, workflows, or tool integrations.
video-prompting-guide
Best practices and techniques for writing effective AI video generation prompts. Covers: Veo, Seedance, Wan, Grok, Kling, Runway, Pika, Sora prompting strategies. Learn: shot types, camera movements, lighting, pacing, style keywords, negative prompts. Use for: improving video quality, getting consistent results, professional video prompts. Triggers: video prompt, how to prompt video, veo prompts, video generation tips, better ai video, video prompt engineering, video prompt guide, video prompt template, ai video tips, video prompt best practices, video prompt examples, cinematography prompts
imaginify-guide
Use this skill whenever the user asks about Imaginify, wants to learn how to use it, needs an introduction to the platform, or requests tutorials, feature overviews, best practices, or getting-started guidance related to https://imaginify.app. Trigger on phrases like "what is Imaginify", "how to use Imaginify", "Imaginify tutorial", "Imaginify guide", or any mention of AI image tools on imaginify.app.