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.3.tar.gz (5.6 kB view details)

Uploaded Source

Built Distribution

mkdocs_code_validator-0.1.3-py3-none-any.whl (5.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: mkdocs-code-validator-0.1.3.tar.gz
  • Upload date:
  • Size: 5.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.10.5 Linux/5.18.9-arch1-1

File hashes

Hashes for mkdocs-code-validator-0.1.3.tar.gz
Algorithm Hash digest
SHA256 ebd060b6404534f27ef6c46906ce10c3b9947da92fee1984680dc4fbee7070d2
MD5 d5589d7268a4193d8a7abc67a0f43b38
BLAKE2b-256 d347e010f32198cb61d199f58cd1eaaa508e327d1f2051ac612b92341ee5f416

See more details on using hashes here.

Provenance

File details

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

File metadata

File hashes

Hashes for mkdocs_code_validator-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 e607acdf92515e270cf901355ed4b5e92f3b0390e83f9f7b3301ac5969948780
MD5 be0b3bf0b67ae688b0ae49a7552737e1
BLAKE2b-256 969595dd5bdb64e65de31843f4739adcdbc5fa694b80d4f6e5ab1ecc5af4a395

See more details on using hashes here.

Provenance

Supported by

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