Skip to main content

Sphinx extension for documenting FastMCP tools (cards, badges, cross-refs)

Project description

sphinx-autodoc-fastmcp

Sphinx extension that documents FastMCP tools with card-style section entries built from the shared api-* layout regions, plus safety badges, parameter tables, and cross-reference roles.

The shipped output intentionally keeps a section wrapper for stable ToC labels and :tool: / :toolref: behavior, but the inner card, badges, and type rendering now come from sphinx_ux_autodoc_layout, sphinx_ux_badges, and sphinx_autodoc_typehints_gp.

Features

  • fastmcp-tool: Renders a tool entry as a section card with shared api-header / api-content regions plus a section target for ToC and {ref} labels.
  • fastmcp-tool-input: Parameter table for a tool (place after prose in MyST).
  • fastmcp-tool-summary: Summary tables grouped by safety tier.
  • Roles: :tool:, :toolref:, :toolicon / :tooliconl / :tooliconr / :tooliconil / :tooliconir:, :badge:

Configuration

In conf.py after sphinx_autodoc_fastmcp is listed in extensions:

fastmcp_tool_modules = [
    "myproject.tools.server_tools",
    "myproject.tools.session_tools",
]
fastmcp_area_map = {
    "server_tools": "sessions",
    "session_tools": "sessions",
}
fastmcp_model_module = "myproject.models"
fastmcp_model_classes = {"SessionInfo", "WindowInfo"}
fastmcp_section_badge_map = {"Inspect": "readonly", "Act": "mutating", "Destroy": "destructive"}
fastmcp_section_badge_pages = {"tools/index", "index"}
fastmcp_collector_mode = "register"  # or "introspect"

See the package docstrings and sphinx_autodoc_fastmcp.setup() for defaults.

Dependencies

  • Python 3.10+
  • Sphinx 8.1+
  • sphinx-ux-badges, sphinx-ux-autodoc-layout, and sphinx-autodoc-typehints-gp are declared dependencies and installed automatically with this package.

sphinx_autodoc_fastmcp automatically registers sphinx_ux_badges, sphinx_ux_autodoc_layout, and sphinx_autodoc_typehints_gp via app.setup_extension(). You do not need to add them separately to your extensions list.

Documentation

See the full documentation for directive options, role reference, and live tool card demos.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sphinx_autodoc_fastmcp-0.0.1a16.dev0.tar.gz (26.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file sphinx_autodoc_fastmcp-0.0.1a16.dev0.tar.gz.

File metadata

File hashes

Hashes for sphinx_autodoc_fastmcp-0.0.1a16.dev0.tar.gz
Algorithm Hash digest
SHA256 4921549b0ea3447a666e2353fdcfc1f07f32eeca4259e44f03db93b639ff91cd
MD5 69d573ae629df423995f4526b756cc91
BLAKE2b-256 1f67966553c94b932d7e7eecf30e962d3b02d607cd934735558c8a8e088ff9bf

See more details on using hashes here.

Provenance

The following attestation bundles were made for sphinx_autodoc_fastmcp-0.0.1a16.dev0.tar.gz:

Publisher: release.yml on git-pull/gp-sphinx

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file sphinx_autodoc_fastmcp-0.0.1a16.dev0-py3-none-any.whl.

File metadata

File hashes

Hashes for sphinx_autodoc_fastmcp-0.0.1a16.dev0-py3-none-any.whl
Algorithm Hash digest
SHA256 96d74920b39e63e8fc31c338034334a3087a2365e15c614c9ada5e7f867c0b4d
MD5 562afd16035fbb88085098c5e39622aa
BLAKE2b-256 04f5e7c30862d8cddfd34d50997b6bba6a7a4d901c762deb83b048d675ad72a3

See more details on using hashes here.

Provenance

The following attestation bundles were made for sphinx_autodoc_fastmcp-0.0.1a16.dev0-py3-none-any.whl:

Publisher: release.yml on git-pull/gp-sphinx

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page