Skip to main content

Drop-in replacement for MkDocs and Material for MkDocs. Self-contained documentation engine with vendored theme, plugins, KaTeX math, offline search, and zero external dependencies.

Project description

DocsForge

The drop-in replacement for MkDocs + Material for MkDocs. One package. One command. Beautiful docs. Zero CDN calls. โš ๏ธ Development Mode: DocsForge is under active development. Expect breaking changes and large updates until v11.0.0.

PyPI Docs License

DocsForge is a self-contained, actively-maintained documentation engine. If you use MkDocs, Material for MkDocs, or are looking for a modern alternative, you're in the right place.

๐Ÿ“– Documentation | ๐Ÿ“ฆ PyPI | ๐Ÿ™ GitHub | ๐Ÿ”„ Migrate from MkDocs


Why DocsForge?

MkDocs + Material DocsForge
Maintenance โš ๏ธ MkDocs is unmaintained; Material is maintenance-only โœ… Actively developed
Installation pip install mkdocs-material + 15+ plugins separately pip install docsforge โ€” everything included
CDN calls Google Fonts, KaTeX, Mermaid loaded from CDN on every build ๐Ÿ”’ Zero external network calls โ€” everything vendored
Math rendering Requires internet or manual KaTeX setup โœ… KaTeX vendored, works offline instantly
Diagrams Mermaid loaded from CDN โœ… Mermaid vendored
Icons Downloaded at build time โœ… 14,000+ icons included
Privacy External font/icon requests โœ… All assets self-hosted
Search Plugin + external JS โœ… Lunr.js built-in, works offline
PWA / Offline Not included โœ… Service worker + offline cache built-in

DocsForge is everything MkDocs + Material does, in one package, with zero external dependencies.


Migrating from MkDocs

One command converts your project:

# In your existing MkDocs project directory
pip install docsforge
docsforge migrate        # converts mkdocs.yml โ†’ docsforge.yml
docsforge build          # builds your site
docsforge serve          # live preview

docsforge migrate reads your mkdocs.yml, converts it to docsforge.yml, and reports which plugins are supported and which need attention.

docsforge migrate --dry-run    # preview changes without writing
docsforge migrate --force      # overwrite existing docsforge.yml

What gets migrated automatically:

  • Site configuration (name, URL, repo, nav)
  • Material theme settings
  • Supported plugins (search, tags, blog, info, meta, minify, privacy, social, offline, etc.)
  • Markdown extensions
  • Custom CSS/JS

DocsForge auto-detects legacy configs: If you run docsforge build in a directory with mkdocs.yml but no docsforge.yml, it will suggest running docsforge migrate.


What Makes DocsForge Different

๐Ÿ”’ Zero External Network Calls

Every asset is vendored: KaTeX for math, Mermaid for diagrams, all fonts and icons, the Material theme itself. Your docs build in an air-gapped environment.

๐Ÿ“ฆ One Package = Everything

No pip install mkdocs-material + pip install mkdocs-awesome-pages-plugin + pip install .... Just:

pip install docsforge

You get:

  • โšก Engine โ€” ProperDocs fork, vendored and maintained
  • ๐ŸŽจ Theme โ€” Material for MkDocs, fully included
  • ๐Ÿ”Œ Plugins โ€” 7 built-in: search, tags, blog, info, meta, minify, privacy, social, offline, optimize, typeset
  • ๐Ÿ“ Markdown โ€” 31 extensions pre-configured (pymdownx + python-markdown)
  • โž— Math โ€” KaTeX vendored ($$...$$ works out of the box)
  • ๐Ÿ–๏ธ Highlighting โ€” Pygments at build time
  • ๐Ÿ“ Diagrams โ€” TikZ auto-compiled to SVG, Mermaid built-in
  • ๐Ÿ” Search โ€” Lunr.js client-side full-text search
  • ๐ŸŒ™ Dark mode โ€” Light/dark toggle with auto system detection
  • ๐Ÿ“ฑ Offline โ€” Service worker caches all assets for PWA support
  • ๐Ÿ”ค Fonts โ€” Self-hosted (privacy plugin downloads Google Fonts locally)

๐Ÿš€ Production-Ready Defaults

Sensible defaults for everything. No config file needed for basic sites. Add a docsforge.yml when you need customization.


Installation

pip install docsforge

Requires Python 3.10+.


Quick Start

# Create a new project
docsforge new my-docs
cd my-docs

# Start the dev server
docsforge serve
# โ†’ http://localhost:8000

# Build for production
docsforge build
# โ†’ site/

Config File

DocsForge looks for config in this priority:

  1. docsforge.yml / docsforge.yaml โ† preferred
  2. mkdocs.yml / mkdocs.yaml โ† legacy fallback (shows migration hint)

Minimal docsforge.yml

site_name: My Documentation
site_url: https://example.com/

That's it. All plugins, extensions, and theme settings use sensible defaults.

Full example

site_name: My Docs
site_url: https://example.com/
site_author: Your Name

repo_url: https://github.com/username/repo

nav:
  - Home: index.md
  - Getting started: getting-started.md
  - Blog:
    - blog/index.md

theme:
  name: material
  palette:
    - media: "(prefers-color-scheme: light)"
      scheme: default
      primary: indigo
      accent: indigo
      toggle:
        icon: material/brightness-7
        name: Switch to dark mode
    - media: "(prefers-color-scheme: dark)"
      scheme: slate
      primary: indigo
      accent: indigo
      toggle:
        icon: material/brightness-4
        name: Switch to light mode

CLI Reference

Command Description
docsforge new <name> Scaffold a new project
docsforge serve Live-reload dev server
docsforge build Static site build
docsforge migrate Convert mkdocs.yml โ†’ docsforge.yml
docsforge gh-deploy Deploy to GitHub Pages

PWA / Offline Support

Every built site includes a service worker that:

  • Caches HTML pages (network-first, updates in background)
  • Caches assets (CSS, JS, fonts, images โ€” cache-first for speed)
  • Versioned updates โ€” Each build generates a unique SW hash, forcing browser refresh
  • Auto cleanup โ€” Old caches purged when new version activates

No configuration needed. Works offline after the first visit.


Keywords

DocsForge is the best alternative to: MkDocs, Material for MkDocs, Docusaurus, GitBook, ReadTheDocs, VuePress, Hugo documentation.

Use DocsForge for: Python project documentation, API docs, technical documentation, knowledge bases, blogs, product docs, internal wikis, open-source project sites, static site generation with Markdown.

Features: static site generator, markdown documentation, material design theme, dark mode, offline support, PWA, KaTeX math, Mermaid diagrams, TikZ diagrams, built-in search, tags, blogging, privacy-focused, no CDN, self-hosted fonts, vendored dependencies, zero-config documentation.


Changelog

See full changelog in the documentation.

Recent highlights:

  • v10.4.1 โ€” Mermaid auto-config, search plugin cleanup
  • v10.3.3 โ€” Versioned service worker with auto cache cleanup
  • v10.3.0 โ€” TikZ diagrams, blog plugin, theme playground
  • v10.1.0 โ€” Zero-config Markdown, KaTeX math, dark mode toggle

License

LGPL v3-or-later


DocsForge is built by QQ (Cyrus) and Nova โ˜„๏ธ โ€” because documentation tools should just work.

Star History

Star History Chart

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

docsforge-10.7.1.tar.gz (5.1 MB view details)

Uploaded Source

Built Distribution

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

docsforge-10.7.1-py3-none-any.whl (10.8 MB view details)

Uploaded Python 3

File details

Details for the file docsforge-10.7.1.tar.gz.

File metadata

  • Download URL: docsforge-10.7.1.tar.gz
  • Upload date:
  • Size: 5.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for docsforge-10.7.1.tar.gz
Algorithm Hash digest
SHA256 0107f9e713697ec71f4c5ab595dd3da4e3c54db74827069a511186dff01e8321
MD5 d1fcd27e5704d5a24e68e5e31154014e
BLAKE2b-256 96c6fea7b43572b09c13e035cfd76911ccab1446cb1ac5eb6a9631e72bb9c741

See more details on using hashes here.

Provenance

The following attestation bundles were made for docsforge-10.7.1.tar.gz:

Publisher: publish.yml on QQSHI13/docsforge

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

File details

Details for the file docsforge-10.7.1-py3-none-any.whl.

File metadata

  • Download URL: docsforge-10.7.1-py3-none-any.whl
  • Upload date:
  • Size: 10.8 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for docsforge-10.7.1-py3-none-any.whl
Algorithm Hash digest
SHA256 86a0502903622d691e16de0a12e61402d5aa46f7b7da33bec2b2fc23c84aea1f
MD5 b6e9c1d35ca4e21225f8aebfad5750ff
BLAKE2b-256 e755fa596af3fa41d91a56c2ff28a09ea86c224188ac9d8887d03f127cf32844

See more details on using hashes here.

Provenance

The following attestation bundles were made for docsforge-10.7.1-py3-none-any.whl:

Publisher: publish.yml on QQSHI13/docsforge

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