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
Task Manager (Go)
An intelligent task and project management server with LLM-driven complexity analysis and smart subtask creation, using file-based markdown storage.
Documentation Workflow MVP
An AI-powered documentation management system with hierarchical context management and session continuity.
Itemit
A simple notes system for Itemit, built with TypeScript.
Blender AI MCP
Modular MCP Server + Blender Addon for AI-Driven 3D Modeling.
Ableton Live MCP
Control Ableton Live using OSC (Open Sound Control) commands.
Retrieval Augmented Thinking
A server implementing Chain of Draft reasoning for enhanced problem-solving capabilities using OpenAI.
Resource Hub
Connects to the Resource Hub to centrally configure and manage your MCP servers.
Audiense Insights
Marketing insights and audience analysis from Audiense reports, covering demographic, cultural, influencer, and content engagement analysis.
Leantime MCP Bridge
An MCP proxy bridge for the Leantime project management system, forwarding JSON-RPC messages with proper authentication.
AutoWP
Connects Claude to WordPress sites to create posts and manage sites using the WordPress REST API.