Learning-Assistant-MCP
An MCP server that helps developers understand what theyβre building by explaining concepts, reviewing approaches, and guiding them toward better solutions.
Learning Assistant MCP Server π
An educational MCP (Model Context Protocol) server that helps developers learn, understand code, and improve their programming skills through AI-powered tools.
Features π
This MCP server provides 8 powerful learning tools:
- explainConcept - Get simple explanations of programming concepts with examples
- reviewCode - Get constructive feedback on your code with improvement suggestions
- suggestBestPractice - Learn industry best practices for any programming task
- compareApproaches - Compare different solutions and understand tradeoffs
- generateLearningPath - Get a structured roadmap to learn any technology
- debugHelper - Understand and fix errors with guided debugging help
- explainThisCode - Get detailed explanations of how code works
- quizMe - Test your knowledge with auto-generated practice questions
Installation π¦
Prerequisites
- Node.js 18.0.0 or higher
- Cursor IDE or any MCP-compatible client
Setup
- Clone this repository:
git clone https://github.com/YOUR_USERNAME/learning-assistant-mcp.git
cd learning-assistant-mcp
- Install dependencies:
npm install
- Build the project:
npm run build
- Configure your MCP client (e.g., Cursor IDE):
Add to your ~/.cursor/mcp.json:
{
"mcpServers": {
"learning-assistant": {
"command": "node",
"args": [
"/absolute/path/to/learning-assistant-mcp/dist/index.js"
]
}
}
}
Replace /absolute/path/to/learning-assistant-mcp with the actual path where you cloned the repository.
- Restart Cursor IDE
Usage π‘
Once installed, you can use the tools in Cursor Chat:
Example Prompts
- "Explain what closures are in JavaScript for a beginner"
- "Review this code and suggest improvements"
- "What are the best practices for error handling in React?"
- "Compare REST API vs GraphQL"
- "Create a learning path to master TypeScript"
- "Help me debug this error: Cannot read property 'map' of undefined"
- "Explain what this regex pattern does: /^[a-z]+$/i"
- "Quiz me on JavaScript async/await with 5 questions"
Development π οΈ
# Run in development mode
npm run dev
# Build TypeScript
npm run build
# Run the built server
npm start
Project Structure π
learning-assistant-mcp/
βββ src/
β βββ index.ts # Main server implementation
βββ dist/ # Compiled JavaScript (generated)
βββ package.json
βββ tsconfig.json
βββ README.md
Tools Reference π
explainConcept
Explains programming concepts in beginner-friendly terms.
Parameters:
concept(string): The concept to explainlevel(optional): "beginner" | "intermediate" | "advanced"language(optional): Programming language context
reviewCode
Reviews code and provides constructive feedback.
Parameters:
code(string): Code to reviewlanguage(string): Programming languagecontext(optional): What the code should dofocusAreas(optional): Array of focus areas
suggestBestPractice
Suggests best practices for programming tasks.
Parameters:
task(string): The task or areatechnology(optional): Specific framework/librarycurrentApproach(optional): Your current approach
compareApproaches
Compares different programming approaches.
Parameters:
problem(string): The problem to solveapproaches(array): List of approaches to comparecriteria(optional): Comparison criteria
generateLearningPath
Creates structured learning roadmaps.
Parameters:
topic(string): What to learncurrentLevel: Your current levelgoalLevel: Target proficiencytimeCommitment(optional): Available time
debugHelper
Helps debug errors and bugs.
Parameters:
error(string): Error message or bug descriptioncode(optional): Relevant codelanguage(optional): Programming languagecontext(optional): What you were doing
explainThisCode
Provides detailed code explanations.
Parameters:
code(string): Code to explainlanguage(string): Programming languagedetailLevel(optional): "overview" | "detailed" | "line-by-line"
quizMe
Generates practice questions.
Parameters:
topic(string): Topic to quiz ondifficulty(optional): "easy" | "medium" | "hard"questionCount(optional): Number of questions (1-10)questionType(optional): Type of questions
Contributing π€
Contributions are welcome! Please feel free to submit a Pull Request.
License π
MIT License - see LICENSE file for details
Author β¨
Muhammad Yasir Khan
Support π¬
If you have questions or need help, please open an issue on GitHub.
Related Servers
esa.io
An MCP server for the esa.io API, allowing you to search, read, create, update, and delete posts.
Notion API MCP
Interact with Notion's API to manage todo lists, databases, and content organization.
Rezdy Agent
Search marketplace products, manage bookings, and handle customer relationships using the Rezdy Agent API.
Agentic Tools
Provides AI assistants with advanced task management and memory capabilities using local JSON file storage.
MCP Easy Copy
Easily discover and copy available MCP services within Claude Desktop.
md-pdf-mcp
Converts Markdown to styled PDFs using VS Code's markdown styling and Python's ReportLab.
AI Tutor
An AI-powered tutor for higher education that supports both Claude and OpenAI models through MCP.
ffl-mcp
Give AI a "send file" capability via P2P (Local-first)
SS&C Next Generation
Connects AI agents to the SS&C Next Generation REST API to automate business processes.
arXiv Chatbot
A local chatbot for searching and interacting with arXiv documents using LangChain.