Cover image
Try Now
2025-03-21

一个模型上下文协议(MCP)服务器,可访问对UV软件包管理器的文档。

3 years

Works with Finder

1

Github Watches

1

Github Forks

0

Github Stars

UV Documentation MCP Server

An MCP server that provides programmatic access to UV documentation through a standardized API. This server now leverages a modern, hierarchical resource structure that exposes both high‐level documentation sections and detailed command documentation (including subsections) as individual MCP resources. Tools have been streamlined, and many documentation queries are handled via the resource layer.

Links

Quick Start

  1. Requirements:
    Ensure Python 3.13+ is installed (minimum 3.10 for MCP SDK compatibility).

  2. Clone the Repository:

    git clone https://github.com/StevenBtw/uv-docs-mcp.git
    cd uv-docs-mcp
    
  3. Set Up Virtual Environment and Install Dependencies:

    python3.13 -m venv env
    source env/bin/activate   # On Windows use: env\\Scripts\\activate
    pip install -e .
    
  4. Run the Server:

    uv run uv-docs
    

    (If using Claude Desktop or other MCP clients, adjust configuration accordingly.)

Architecture

The server is built with a modular and hierarchical design that clearly separates concerns:

flowchart TD
    Client[MCP Client] --> Server[Server Layer]
    Server --> Resources[Resource Layer]
    Server --> Tools[Tools Layer]
    Server --> Prompts[Prompts Layer]
    
    Resources --> Cache[Cache System]
    Tools --> Cache
  • Resource Layer:
    Exposes UV documentation via URIs with the scheme uv-docs://. Resources are structured hierarchically:

    • Level 1: Base sections (e.g., uv-docs://cli, uv-docs://settings, uv-docs://resolver)
    • Level 2: Individual commands (e.g., uv-docs://cli/uv-run, uv-docs://cli/uv-cache)
    • Level 3: Command subsections (e.g., uv-docs://cli/uv-cache/uv-cache-dir)
  • Tools Layer:
    Provides operational commands to interact with the cache and perform real-time searches.

    • update_cache: Updates the documentation cache if the live version differs.
    • search_documentation: Searches UV documentation using real-time query execution.
  • Prompts Layer:
    Supplies prompt templates for AI assistants to generate documentation summaries (e.g., the summarize-docs prompt).

Components

Resources

Resources are accessed using the uv-docs:// URI scheme and provide the full hierarchy of documentation. For example:

  • Base Section:
    uv-docs://cli returns the list of all CLI commands.

  • Command Level:
    uv-docs://cli/uv-cache returns metadata about the uv cache command, including available documentation sections.

  • Subsection Level:
    uv-docs://cli/uv-cache/uv-cache-dir returns the detailed documentation content for the “uv cache dir” section.

Each resource returns JSON data with detailed metadata and, when requested, the full documentation content. This fine-grained breakdown allows MCP clients and AI assistants to query only the information they require.

Tools

The available tools have been streamlined:

  1. update_cache
    • Purpose: Update the documentation cache if the live version has changed.
    • Input:
      {
        "force": false
      }
      
  2. search_documentation
    • Purpose: Perform real-time searches over the UV documentation.
    • Input:
      {
        "query": "search query"
      }
      

Prompts

The server provides pre-built prompt templates for common documentation tasks:

  • summarize-docs:
    Creates a summary of UV documentation sections.
    Optional Arguments:
    {
      "section": "cli|settings|resolver"
    }
    
    If no section is specified, summaries for all sections are generated.

Installation & Configuration

MCP Server Configuration

For Claude Desktop or other systems, modify the MCP server settings appropriately:

Development/Unpublished Configuration

{
  "mcpServers": {
    "uv-docs": {
      "command": "uv",
      "args": [
        "--directory",
        "/Users/steven/Git/MCP/uv-docs",
        "run",
        "uv-docs"
      ]
    }
  }
}

Published Configuration

{
  "mcpServers": {
    "uv-docs": {
      "command": "uvx",
      "args": [
        "uv-docs"
      ]
    }
  }
}

Debugging & Inspection

For detailed debugging, use the MCP Inspector:

npx @modelcontextprotocol/inspector uv --directory /Users/steven/Git/MCP/uv-docs run uv-docs

Caching

The server implements a version-aware caching system to optimize documentation retrieval:

  • Initialization: The cache is automatically initialized at startup.
  • Version Checking: The live documentation version is checked against the cached version.
  • Segmented Caching: Each documentation section (e.g., CLI, settings, resolver) is cached separately.
  • Manual Updates: Use the update_cache tool when necessary.

Development

Project Structure

uv-docs/
├── src/
│   └── uv_docs/
│       ├── __init__.py
│       ├── server.py         # Server setup and routing
│       ├── resources.py      # Resource handling and MCP resource interface
│       ├── cache.py          # Version-aware cache system
│       ├── prompts.py        # Prompt templates for documentation tasks
│       └── tools.py          # Consolidated tool implementations (update_cache, search_documentation)
├── pyproject.toml            # Project configuration
└── README.md                # Project overview (this file)

Building & Publishing

  1. Sync Dependencies & Lockfile:
    uv sync
    
  2. Build Package Distributions:
    uv build
    
  3. Publish to PyPI:
    uv publish
    

Note: Set PyPI credentials via:

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

Debugging

For the best debugging experience, use the MCP Inspector:

npx @modelcontextprotocol/inspector uv --directory /Users/steven/Git/MCP/uv-docs run uv-docs

The Inspector will display a URL for browser-based debugging.

Caching

The server implements a version-aware caching system:

  • Cache initializes on server start
  • Version checks against live documentation
  • Automatic updates when version changes
  • Manual updates via update_cache tool
  • Each documentation section cached separately

相关推荐

  • NiKole Maxwell
  • I craft unique cereal names, stories, and ridiculously cute Cereal Baby images.

  • Bora Yalcin
  • Evaluator for marketplace product descriptions, checks for relevancy and keyword stuffing.

  • Joshua Armstrong
  • Confidential guide on numerology and astrology, based of GG33 Public information

  • https://suefel.com
  • Latest advice and best practices for custom GPT development.

  • Alexandru Strujac
  • Efficient thumbnail creator for YouTube videos

  • Callycode Limited
  • A geek-themed horoscope generator blending Bitcoin prices, tech jargon, and astrological whimsy.

  • Emmet Halm
  • Converts Figma frames into front-end code for various mobile frameworks.

  • Khalid kalib
  • Write professional emails

  • Beniyam Berhanu
  • Therapist adept at identifying core issues and offering practical advice with images.

  • Elijah Ng Shi Yi
  • Advanced software engineer GPT that excels through nailing the basics.

  • apappascs
  • 发现市场上最全面,最新的MCP服务器集合。该存储库充当集中式枢纽,提供了广泛的开源和专有MCP服务器目录,并提供功能,文档链接和贡献者。

  • ShrimpingIt
  • MCP系列GPIO Expander的基于Micropython I2C的操作,源自ADAFRUIT_MCP230XX

  • OffchainLabs
  • 进行以太坊的实施

  • huahuayu
  • 统一的API网关,用于将多个Etherscan样区块链Explorer API与对AI助手的模型上下文协议(MCP)支持。

  • deemkeen
  • 用电源组合控制您的MBOT2:MQTT+MCP+LLM

    Reviews

    1 (1)
    Avatar
    user_hovk5C6h
    2025-04-16

    I've been using uv-docs-mcp for a while now and I must say it's fantastic! The documentation is clear and concise, making the integration process smooth. StevenBtw has done a commendable job in creating this tool. Definitely check it out via the provided link: https://github.com/StevenBtw/uv-docs-mcp. Highly recommended for all developers looking for efficient document processing.