Skip to main content

Mkdocs automatic paths/addresses building - auto-completion support (VSC)

Project description

coverage badge coverage badge

Links

Dependencies

  • Python 3.8+
  • mkdocs 1.4+
  • BeautifulSoup 4+

Overview

About

The mkdocs-addresses is a plugin for mkdocs which offers:

  • Abstraction of the concrete tree hierarchy of pages and anchors within those when writing a link, utilizing unique identifiers:

    Benefit from a strong separation between logic and content, avoiding all addresses rewrite steps when some files are modified, split, merged or moved.

  • Verification of numerous links and addresses to ensure the absence of dead links or images within the documentation (including verifications beyond mkdocs 1.5+ capabilities):

    The tool warns you when something becomes wrong during development.

  • Convenient helpers to facilitate the usage of those identifiers within the docs pages. For users working with compatible IDEs, this translates to the availability of auto-completion features:

    Don't lose time searching for the exact name of the anchor in the file that is... where is it again? Let the autocompletion tool find them for you.

Identifiers: separating structure from content

Relying on the attr_list markdown extension, use identifiers instead of actual paths to point to specific anchors in the documentation:

## Very important title with anchor and id {: #point-here }
In another file: navigate to [this very important title](--point-here).

The plugin automatically rebuilds the appropriate addresses, considering various factors such as the source file location, the target, the use_directory_urls option, ...

Reduce dependencies on the files hierarchy

Identifiers still work after:

  • Changing header content
  • Moving sections from one file to another
  • Renaming files
  • Moving files

move-deeper

Provide autocompletion helpers (IDE dependent)

(Currently only available for VSC-like IDEs)

  • All snippets are automatically kept up to date while working on the documentation.
  • They provide various markdown snippets, to get a quick and easy access to all the references defined in the documentation, and use them within the markdown code they are usual used for.
Kind Suggestion completion Inserted markdown
Doc identifier --point-here --point-here
Doc links Link.point-here [link to some place in the docs](--point-here)
Images in assets/ (identifier) !!file_in_assets_jpg !!file_in_assets_jpg
Images in assets/ Img.file_in_assets_jpg ![alt content](!!file_in_assets_jpg)
Other files links ++file_path_in_docs_html ++file_path_in_docs_html
Other files links File.file_path_in_docs_html [link to a file](++file_path_in_docs_html)
External Links * Ext.global_ref [global_ref][global_ref]
Code inclusions** ::md that_file_md --<8-- "include/that_file.md"

*: requires an external_links_file for global references is configured.

**: requires the use of inclusions directories.

autocomplete

Tracking dead links or addresses in the docs

The plugin also explores the documentation and warns you if it finds invalid addresses or identifiers. This works for:

  • Addresses in links
  • Addresses of images
  • Identifiers used by the plugin

errors-example

User handed configuration

A lot of options are available for the user to fine tune the plugin's behavior.

Installation

Install the package on your machine (or in your project if you are using a virtual env):

pip install mkdocs-addresses

Register the plugin in the mkdocs.yml file:

plugins:
    - search            # To redeclare when plugins are added to mkdocs.yml
    - mkdocs-addresses

Configure the plugin (see below).

Recommended mkdocs.yml configuration

See the online documentation for more details.

Markdown extensions

markdown_extensions:
    - attr_list             # To define the identifiers in the markdown content
    - pymdownx.snippets:    # If you need inclusions code snippets
        check_paths: true
        auto_append: ["path_to_external_links_definition.md"]
        #               ^ see plugin's external_link_file configuration

Plugin configuration

plugins:
    - search
    - mkdocs-addresses:
        - external_links_file: path_to_links_definition_if_any.md
        - inclusions:
            - location1_if_any
            - location2...

Note that the default configuration also implies the following choices:

        - dump_snippets_file: .vscode/links.code-snippets
        - fail_fast: false
        - ignore_auto_headers: true
        - ide: vsc

So, if VSC isn't the utilized IDE, the ide option should at the very least be modified.

When using mkdocs 1.5+

Significant enhancements in address verification logic (which was notoriously lacking in earlier versions...) have been added in mkdocs 1.5+. But the plugin does more work, and the identifiers it is utilizing are generating warnings in the console.

Hence, deactivate the default verification logic for mkdocs 1.5+:

validation:
    absolute_links: ignore
    unrecognized_links: ignore

Links

License

Apache-2.0 Copyright © 2023 Zinelli Frédéric

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_addresses-0.5.6.tar.gz (50.7 kB view details)

Uploaded Source

Built Distribution

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

mkdocs_addresses-0.5.6-py3-none-any.whl (61.4 kB view details)

Uploaded Python 3

File details

Details for the file mkdocs_addresses-0.5.6.tar.gz.

File metadata

  • Download URL: mkdocs_addresses-0.5.6.tar.gz
  • Upload date:
  • Size: 50.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.4 CPython/3.10.10 Linux/6.14.0-37-generic

File hashes

Hashes for mkdocs_addresses-0.5.6.tar.gz
Algorithm Hash digest
SHA256 7d4d5549048f2f47a2628db018d2a801b195498ac089a19a72f8003f2b0c72cf
MD5 f819292eec2ca99dc316a482fb5355b0
BLAKE2b-256 7f6a46c4ea5efc185316e9dce02a4f3a3c29ff420798378be110cb8e55651fed

See more details on using hashes here.

File details

Details for the file mkdocs_addresses-0.5.6-py3-none-any.whl.

File metadata

  • Download URL: mkdocs_addresses-0.5.6-py3-none-any.whl
  • Upload date:
  • Size: 61.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.4 CPython/3.10.10 Linux/6.14.0-37-generic

File hashes

Hashes for mkdocs_addresses-0.5.6-py3-none-any.whl
Algorithm Hash digest
SHA256 fde6b0675d2cf8e45e6158a5eefabbe49b0bc0283c9b3b275852cf9f7528a25e
MD5 9be67fa716ca912dc2c1f3938a2cc130
BLAKE2b-256 a763657337d751395d87d4c591f15561a72a9c7030a2f1fca28ab56e7e6450a9

See more details on using hashes here.

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