A Node.js-based MCP (Model Context Protocol) tool server that provides three focused documentation generation tools for Python projects. Built as an npm package that can be installed directly from the Git repository.
create_class_diagram
- Analyzes Python files and generates UML class diagrams in PlantUML formatcreate_tree_structure
- Creates clean directory tree structure documentation with smart exclusionscreate_module_functions
- Documents module-level functions with signatures, decorators, and type hints
- Zero Configuration: Works out of the box with sensible defaults
- Smart Exclusions: Automatically filters out cache, build, and IDE files
- Rich Documentation: Captures type hints, decorators, docstrings, and inheritance
- MCP Integration: Seamlessly integrates with AI assistants via Model Context Protocol
- Hybrid Architecture: Node.js orchestration + Python AST parsing for reliability
# Clone the repository
git clone https://github.com/your-username/mcp-docs-tools.git
cd mcp-docs-tools
# Install dependencies
npm install
# Install globally (optional)
npm install -g .
# Or run directly
npm start
# Install directly from GitHub
npm install -g git+https://github.com/your-username/mcp-docs-tools.git
# Then run
mcp-docs-tools
git clone https://github.com/your-username/mcp-docs-tools.git
cd mcp-docs-tools
npm install
npm start
- Node.js ≥18.0.0
- Python 3.x (for AST parsing)
- Git (for cloning the repository)
Start the server to expose tools via Model Context Protocol:
# If installed globally
mcp-docs-tools
# Or from the project directory
npm start
# Or run directly with node
node bin/server.js
The server will listen on stdin/stdout and expose three tools that can be called by MCP clients.
Purpose: Generate UML class diagrams from Python code
Parameters:
project_path
(string, required): Root path of the Python project to analyze
Output:
- File:
docs/uml.txt
- Format: PlantUML syntax
- Content: Classes with public/private methods, attributes, and inheritance relationships
Example:
@startuml
class MyClass {
+public_attr: str
-_private_attr: int
--
+__init__(self, name: str)
+public_method(self, arg: int): bool
-{static} _private_method(): None
}
@enduml
Purpose: Generate project directory tree structure
Parameters:
project_path
(string, required): Root path of the project to analyze
Output:
- File:
docs/tree-structure.txt
- Format: Unicode box-drawing tree
- Content: Complete file/directory structure with smart exclusions
Example:
my-project
├── src/
│ ├── main.py
│ └── utils/
│ └── helpers.py
├── tests/
│ └── test_main.py
└── README.md
Purpose: Document module-level functions and signatures
Parameters:
project_path
(string, required): Root path of the Python project to analyze
Output:
- File:
docs/module-functions.txt
- Format: Hierarchical markdown documentation
- Content: Functions organized by module with full signatures, decorators, and docstrings
Example:
## Module: src.utils.helpers
### `async def process_data(data: List[str], timeout: int = 30) -> Dict[str, Any]`
**Decorators:**
- `@retry(max_attempts=3)`
**Description:**
Process a list of data items with optional timeout.
**Line:** 42
The tool uses a hybrid architecture that combines the best of both worlds:
- Node.js Server: Handles MCP protocol, tool registration, and process orchestration
- Python Scripts: Perform robust AST parsing and documentation generation
- Clean Separation: Protocol handling separate from parsing logic
mcp-docs-tools/
├── package.json # npm package configuration
├── bin/
│ └── server.js # Main MCP server entry point
├── src/
│ ├── server.js # MCP server implementation
│ ├── tools/ # Tool implementations
│ │ ├── class-diagram.js # UML generation wrapper
│ │ ├── tree-structure.js # Tree generation wrapper
│ │ └── module-functions.js # Function docs wrapper
│ └── config/
│ └── exclusions.js # Default exclusion patterns
├── python/
│ ├── generate_uml.py # Python AST parsing for classes
│ ├── generate_tree.py # Directory tree generation
│ ├── generate_functions.py # Function parsing and documentation
│ └── requirements.txt # Python dependencies (none needed)
└── README.md
The tools automatically exclude common files and directories that shouldn't be documented:
__pycache__
,*.pyc
,*.pyo
,*.pyd
build
,dist
,eggs
,*.egg-info
- Virtual environments:
venv
,.venv
,env
,virtualenv
- Version control:
.git
,.svn
,.hg
- IDEs:
.idea
,.vscode
,.cursor
- Testing:
.pytest_cache
,.coverage
,.tox
node_modules
,target
,out
,bin
package-lock.json
,yarn.lock
,Pipfile.lock
.DS_Store
,Thumbs.db
,*.tmp
,*.log
The configuration depends on how you installed the tools:
Create a .cursorrules
file in your projects and add this to your Cursor MCP configuration:
{
"mcpServers": {
"docs-tools": {
"command": "node",
"args": ["/path/to/mcp-docs-tools/bin/server.js"],
"cwd": "/path/to/mcp-docs-tools"
}
}
}
Replace /path/to/mcp-docs-tools
with the actual path where you cloned the repository.
For example:
- macOS/Linux:
"/Users/yourname/projects/mcp-docs-tools"
- Windows:
"C:\\Users\\yourname\\projects\\mcp-docs-tools"
{
"mcpServers": {
"docs-tools": {
"command": "mcp-docs-tools"
}
}
}
Create this .cursorrules
file in your Python projects:
# Documentation Tools Integration
## Available MCP Tools
- `create_class_diagram` - Generate UML class diagrams
- `create_tree_structure` - Generate directory tree
- `create_module_functions` - Document module functions
## Usage
Run these tools at session start to generate documentation in `docs/` directory.
Reference the generated files to understand codebase structure.
## Generated Files
- `docs/uml.txt` - PlantUML class diagrams
- `docs/tree-structure.txt` - Directory structure
- `docs/module-functions.txt` - Function documentation
Add to your Claude Desktop MCP configuration:
{
"mcpServers": {
"docs-tools": {
"command": "node",
"args": ["/path/to/mcp-docs-tools/bin/server.js"],
"cwd": "/path/to/mcp-docs-tools"
}
}
}
Replace /path/to/mcp-docs-tools
with the actual path where you cloned the repository.
{
"mcpServers": {
"docs-tools": {
"command": "mcp-docs-tools"
}
}
}
-
Clone and install (recommended):
git clone https://github.com/your-username/mcp-docs-tools.git cd mcp-docs-tools npm install
-
Find your installation path:
pwd # Copy this path for your MCP configuration
-
Update your MCP config with the path from step 2
-
Test the tools in your Python projects!
The tools include comprehensive error handling:
- Python Process Failures: Detailed error messages with stdout/stderr
- Missing Dependencies: Clear instructions for Python installation
- File Permission Issues: Graceful handling with informative messages
- Invalid Project Paths: Path validation before processing
- Lightweight: Minimal memory footprint with short-lived Python processes
- Fast: Efficient AST parsing with smart file filtering
- Scalable: Handles large codebases with thousands of files
- Concurrent: Multiple tools can run simultaneously
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests if applicable
- Submit a pull request
MIT License - see LICENSE file for details.
- Issues: Report bugs and feature requests on GitHub
- Documentation: Full API documentation available in the repository
- Examples: Sample projects and usage patterns in the examples directory
Made with ❤️ for the Python development community