Skip to main content

A plugin for MkDocs plugin that allows you to add files from outside your `docs_dir`.

Project description

mkdocs-extrafiles

PyPI License Tests Code Style Coverage Status

mkdocs-extrafiles is a lightweight MkDocs plugin that allows you to add files and directories from outside MkDocs document directory (docs_dir) to your MkDocs site build.

Features

  • Pull individual files or glob patterns from anywhere outside your docs_dir.
  • Resolve relative paths against the MkDocs configuration directory.
  • Create real source File objects at build time.
  • Automatically watch added sources during live reload (mkdocs serve).

Installation

From PyPI

pip install mkdocs-extrafiles

or, with astral-uv:

uv add mkdocs-extrafiles

From source

git clone https://github.com/your-username/mkdocs-extrafiles.git
cd mkdocs-extrafiles
pip install .

Quickstart

  • src accepts absolute paths or paths relative to the MkDocs config file.
  • dest accepts relative paths to the docs_dir; during a build they are created in site_dir.

Glob patterns (*, ?, []) require dest to end with / to indicate a directory target.

Configuration

Enable the plugin and list the external sources inside mkdocs.yml:

plugins:
  - search
  - extrafiles:
      files:
        - src: README.md # file
          dest: external/README.md
        - src: LICENSE # file -> rename/relocate
          dest: external/LICENSE.txt
        - src: assets/** # glob (copies all matches)
          dest: external/assets/ # must end with '/' to indicate a directory

Behavior

  • mkdocs serve: Sources are streamed directly; nothing is copied into docs_dir, but live reload will watch the resolved absolute paths.
  • mkdocs build: Virtual files are materialized into site_dir, so deployments that publish only the build output still include the added sources.
  • Missing sources will result in a FileNotFoundError exception.

Troubleshooting

If you are using mkdocs-gen-files then you must place extrafiles after mkdocs-gen-files in your plugin settings.

plugins:
  - search
  - gen-files:
      scripts:
        - gen_ref_pages.py
  - extrafiles:
      files:
        - src: ../README.md
          dest: extras/README.md

Developer Guide

Set up a development environment with uv:

uv sync --all-extras --all-groups
uv run pytest tests
uv run ruff check
uv run ruff format

Key Development Principles

  • Maintain 100% passing tests, at least 80% test coverage, formatting, and linting before opening a pull request.
  • Update docstrings alongside code changes to keep the generated reference accurate.

Document Generation

Documentation is generated using MkDocs. The technical reference surfaces the reStructuredText style docstrings from the package's source code.

uv sync --group docs

# Run the development server
uv run mkdocs serve -f mkdocs/mkdocs.yaml
# Build the static site
uv run mkdocs build -f mkdocs/mkdocs.yaml

Contributing

Contributions are welcome! To get started:

  1. Fork the repository and create a new branch.
  2. Install development dependencies (see the developer guide).
  3. Add or update tests together with your change.
  4. Run the full test, linting, and formatting suite locally.
  5. Submit a pull request describing your changes and referencing any relevant issues.

For major changes, open an issue first to discuss your proposal.

License

Distributed under the GNU General Public License v3.0. See LICENSE for details.

Contact

Questions or issues? Please open an issue on the repository's issue tracker.

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

mkdocs_extrafiles-1.0.1.tar.gz (86.2 kB view details)

Uploaded Source

Built Distribution

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

mkdocs_extrafiles-1.0.1-py3-none-any.whl (31.5 kB view details)

Uploaded Python 3

File details

Details for the file mkdocs_extrafiles-1.0.1.tar.gz.

File metadata

  • Download URL: mkdocs_extrafiles-1.0.1.tar.gz
  • Upload date:
  • Size: 86.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mkdocs_extrafiles-1.0.1.tar.gz
Algorithm Hash digest
SHA256 79c2a07ca64d25765c5606e85c1bdcf78c243c84c719694a3fc420a3ed558801
MD5 1cb86acca7bb4f561241eeea57d52bbf
BLAKE2b-256 188432abff96515cd382ab2400d832ad8beeb6e5f729dc5d3ece9dce03acf3a9

See more details on using hashes here.

Provenance

The following attestation bundles were made for mkdocs_extrafiles-1.0.1.tar.gz:

Publisher: release.yaml on paddy74/mkdocs-extrafiles

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

File details

Details for the file mkdocs_extrafiles-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for mkdocs_extrafiles-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 eef6bfdfb9165eb44bab47bdb63438dff70433029b55b844378575d7182b5c37
MD5 0fbe8e6a3f781c9ee0b3336494958d1f
BLAKE2b-256 c38dfb0e8b4624c88a82c750713cfbe7c9d7a2309144b1b20e16abc127ce1058

See more details on using hashes here.

Provenance

The following attestation bundles were made for mkdocs_extrafiles-1.0.1-py3-none-any.whl:

Publisher: release.yaml on paddy74/mkdocs-extrafiles

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