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.6.4.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.6.4-py3-none-any.whl (10.8 MB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: docsforge-10.6.4.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.6.4.tar.gz
Algorithm Hash digest
SHA256 c4a0cd7909ecea920ac0774cfa5e8a531e570f70c017f6251e569803e9c3d93c
MD5 6e9d513731708b4bb22d8385cf521768
BLAKE2b-256 332a6e3498437143245690ee29539dbe80283d7b288101c82a85cdc223f6b5c6

See more details on using hashes here.

Provenance

The following attestation bundles were made for docsforge-10.6.4.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.6.4-py3-none-any.whl.

File metadata

  • Download URL: docsforge-10.6.4-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.6.4-py3-none-any.whl
Algorithm Hash digest
SHA256 8d1e28d74c059c733bf2997d01599ac8d6611fdcc1e31b99d0913f8e7bf324c3
MD5 03b6547e6d4f4a6a2d129caaeb69a876
BLAKE2b-256 b5d7e75f72b340506c8ee8c9caf68c771e2afd35a365689a5bfaf74052605cf5

See more details on using hashes here.

Provenance

The following attestation bundles were made for docsforge-10.6.4-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