Skip to main content

Checks Markdown code blocks in a MkDocs site against user-defined actions

Project description

mkdocs-code-validator

Checks Markdown code blocks in a MkDocs site against user-defined actions

PyPI License GitHub Workflow Status

pip install mkdocs-code-validator

Usage

Activate the plugin in mkdocs.yml. The identifiers config is mandatory. And the plugin doesn't work without pymdownx.superfences:

plugins:
  - search
  - code-validator:
      identifiers:
        bash:
          validators:
            - grep a
markdown_extensions:
  - pymdownx.superfences

The above contrived config checks that every ```bash code block in the Markdown files of this MkDocs site must contain the letter "a", otherwise a warning will appear.

The content of each code block is piped as stdin to the command. The exit code of the command is what's checked: a non-zero code will produce a warning (which in MkDocs you can make fatal with the --strict flag). The output of the command is not used in any way, only preserved on the screen as part of a warning.

You can add any number of identifiers, and within them any number of validators commands, each of them has the ability to produce a warning.

If stdin is not usable with your command, the input can be passed as a temporary file instead -- that is done if the command contains the exact argument $< (which is then replaced with a file path). For the above example, changing the command to grep a $< would be equivalent (other than technicalities).

The commands do not allow freeform shell syntax, it's just one subprocess to call with its arguments. To explicitly opt into a shell, just run it as (e.g.) sh -c 'if grep a; then exit 1; fi'. Or, with a temporary file: sh -c 'if grep a "$1"; then exit 1; fi' $<.

The definition of what a code block is is all according to the pymdownx.superfences extension. It must be enabled; the plugin won't do anything without it.

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-code-validator-0.1.1.tar.gz (5.4 kB view details)

Uploaded Source

Built Distribution

mkdocs_code_validator-0.1.1-py3-none-any.whl (5.5 kB view details)

Uploaded Python 3

File details

Details for the file mkdocs-code-validator-0.1.1.tar.gz.

File metadata

  • Download URL: mkdocs-code-validator-0.1.1.tar.gz
  • Upload date:
  • Size: 5.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/3.9.6 Linux/5.13.10-arch1-1

File hashes

Hashes for mkdocs-code-validator-0.1.1.tar.gz
Algorithm Hash digest
SHA256 b27a13bbc99abc5cde8da491ed323f26d154d5274a4b5ce0fa6ba956b1361e56
MD5 2a55bd9c016159f79a8001389ed38993
BLAKE2b-256 96cb5d351772e92e867958cc706ed88a651dfd6a83c05663edba133baff401f4

See more details on using hashes here.

File details

Details for the file mkdocs_code_validator-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for mkdocs_code_validator-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 529573bc990e2ea2a9255608efd145cb522f95e6e223146ab75d57e41270d29e
MD5 f382347cbe5f07df03f4a7f3bf2fb475
BLAKE2b-256 eca5a35893b12ae096bd2e8653f84283e79a909b2f9c716ad5d1fc97f85352ef

See more details on using hashes here.

Supported by

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