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
Panda Odoo
An MCP server for integrating with the Odoo ERP system.
OSP Marketing Tools for Node.js
A suite of tools for technical marketing content creation, optimization, and product positioning based on Open Strategy Partners' methodologies.
Basecamp
Interact with Basecamp 3 to manage projects, to-dos, and messages.
SilverBullet MCP Server
An MCP server that enables LLMs and other clients to interact with your SilverBullet notes and data.
MCP Sync
A CLI tool to synchronize MCP (Model Context Protocol) settings across multiple AI coding tools.
Planka
Interact with Planka, a Trello-like kanban board, to manage projects, boards, and cards. Requires Planka server URL and credentials.
Obsidian via REST
Access and manage your Obsidian vault through a local REST API.
Linear MCP Server
An MCP server for interacting with the Linear API, allowing AI agents to manage issues, projects, and teams.
Bakalรกลi
Access data from the Bakalรกลi school system, including schedules, absences, and grades, through a standardized API.
DeepWriter
Interact with the DeepWriter API, an AI-powered writing assistant.