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

Uploaded Python 3

File details

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

File metadata

  • Download URL: docsforge-10.6.2.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.2.tar.gz
Algorithm Hash digest
SHA256 8712f2d91d0bb38f840305229867bebaf3a14499ce8bf29223c67d715d2a03f9
MD5 dbbbb29a999b0f33c2d62d7fc4976589
BLAKE2b-256 93eccfc39ccdfacb43d7ee749e8c1b56f22275b6b1c183f470ad969c378aa5da

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: docsforge-10.6.2-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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 9403eb4c653172a3cf35da3050bca8140f1802ebed7403155ead4c5be16eaf58
MD5 e6e2ee4c77553f7e68c47aa0fc76f41c
BLAKE2b-256 ec88d92e8261a3cde566d157d594e8aeccc6a99a9c45b265ac8c10be01b3fa6f

See more details on using hashes here.

Provenance

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