md-pdf-mcp

Converts Markdown to styled PDFs using VS Code's markdown styling and Python's ReportLab.

{{ message }}

seanivore / Convert-Markdown-PDF-MCP Public

  • Notifications
  • Fork3
  • Star 8

Markdown To PDF Conversion MCP

8 stars3 forksBranches Tags Activity

Star

Notifications

md-pdf-mcp

BranchesTags

Go to file

Code

NameNameLast commit messageLast commit date
16 Commits
docsdocs
fonts/TTFfonts/TTF
md_pdf_mcpmd_pdf_mcp
src/md_pdf_mcpsrc/md_pdf_mcp
teststests
.gitignore.gitignore
.md-pdf-mcp.code-workspace.md-pdf-mcp.code-workspace
.python-version.python-version
AGENTS_SYSTEM_MESSAGE.mdAGENTS_SYSTEM_MESSAGE.md
CLAUDEME.mdCLAUDEME.md
README.mdREADME.md
basic_python_styles.pybasic_python_styles.py
cool.liquidcool.liquid
example_markdown_to_pdf.pyexample_markdown_to_pdf.py
pyproject.tomlpyproject.toml
requirements.txtrequirements.txt
setup.pysetup.py
test.liquidtest.liquid
uv.lockuv.lock
vscode_pdf_styles.pyvscode_pdf_styles.py
w3schools_vscode_style.pyw3schools_vscode_style.py
View all files

Repository files navigation

md-pdf-mcp (Markdown to PDF MCP Server)

Convert Markdown to gorgeously styled PDFs using VS Code's markdown styling and Python's ReportLab.

Components

Resources

The server implements a simple note storage system with:

  • Custom note:// URI scheme for accessing individual notes
  • Each note resource has a name, description and text/plain mimetype

Prompts

The server provides a single prompt:

  • summarize-notes: Creates summaries of all stored notes
    • Optional "style" argument to control detail level (brief/detailed)
    • Generates prompt combining all current notes with style preference

Tools

The server implements one tool:

  • add-note: Adds a new note to the server
    • Takes "name" and "content" as required string arguments
    • Updates server state and notifies clients of resource changes

Configuration

[TODO: Add configuration details specific to your implementation]

Quickstart

Install

Claude Desktop

On MacOS: ~/Library/Application\ Support/Claude/claude_desktop_config.jsonOn Windows: %APPDATA%/Claude/claude_desktop_config.json

Development/Unpublished Servers Configuration ``` "mcpServers": { "md-pdf-mcp": { "command": "uv", "args": [ "--directory", "/Users/path/to/your/local/md-pdf-mcp", "run", "md-pdf-mcp" ] } } ``` Published Servers Configuration ``` "mcpServers": { "md-pdf-mcp": { "command": "uvx", "args": [ "md-pdf-mcp" ] } } ```

Development

Building and Publishing

To prepare the package for distribution:

  1. Sync dependencies and update lockfile:

uv sync

  1. Build package distributions:

uv build

This will create source and wheel distributions in the dist/ directory.

  1. Publish to PyPI:

uv publish

Note: You'll need to set PyPI credentials via environment variables or command flags:

  • Token: --token or UV_PUBLISH_TOKEN
  • Or username/password: --username/UV_PUBLISH_USERNAME and --password/UV_PUBLISH_PASSWORD

Debugging

Since MCP servers run over stdio, debugging can be challenging. For the best debugging experience, we strongly recommend using the MCP Inspector.

You can launch the MCP Inspector via npm with this command:

npx @modelcontextprotocol/inspector uv --directory /Users/seanivore/Development/md-pdf-mcp run md-pdf-mcp

Upon launching, the Inspector will display a URL that you can access in your browser to begin debugging.

About

python mcp vscode pdf-converter cursor typography-layout markdown-formatting model-context-protocol mcp-server claudeme model-context-protocol-servers

Readme

Activity

8 stars

2 watching

3 forks

Report repository

Releases

No releases published

Languages

  • Python 98.2%
  • Liquid 1.8%

Related Servers