Skip to main content

PlantUML diagrams preprocessor for Foliant.

Project description

PlantUML Diagrams Preprocessor for Foliant

PlantUML is a tool to generate diagrams from plain text. This preprocessor finds PlantUML diagrams definitions in the source and converts them into images on the fly during project build.

Installation

$ pip install foliantcontrib.plantuml

Config

To enable the preprocessor, add plantuml to preprocessors section in the project config:

preprocessors:
    - plantuml

The preprocessor has a number of options:

preprocessors:
    - plantuml:
        cache_dir: !path .diagramscache
        plantuml_path: plantuml
        format: png
        params:
            ...
        parse_raw: true
        as_image: true

cache_dir : Path to the directory with the generated diagrams. It can be a path relative to the project root or a global one; you can use ~/ shortcut.

>   **Note**
>
>   To save time during build, only new and modified diagrams are rendered. The generated images are cached and reused in future builds.

plantuml_path : Path to PlantUML launcher. By default, it is assumed that you have the command plantuml in your PATH, but if PlantUML uses another command to launch, or if the plantuml launcher is installed in a custom place, you can define it here.

format : Diagram format, list of supported formats. Default: png.

Another way to specify format is to use t<format> option in params.

params : Params passed to the image generation command:

    preprocessors:
        - plantuml:
            params:
                config: !path plantuml.cfg

To see the full list of params, run the command that launches PlantUML, with `-h` command line option.

parse_raw : If this flag is true, the preprocessor will also process all PlantUML diagrams which are not wrapped in <plantuml>...</plantuml> tags. Default value is false.

as_image : If true — inserts scheme into document as md-image. If false — inserts the file generated by PlantUML directly into the document (only for svg format). Default: true

Usage

To insert a diagram definition in your Markdown source, enclose it between <plantuml>...</plantuml> tags (indentation inside tags is optional):

Here’s a diagram:

<plantuml>
    @startuml
        ...
    @enduml
</plantuml>

To set a caption, use caption option:

Diagram with a caption:

<plantuml caption="Sample diagram from the official site">
    @startuml
        ...
    @enduml
</plantuml>

You can override values from the preprocessor config for each diagram.

By default, diagrams are in PNG. But this diagram is in EPS:

<plantuml caption="Vector diagram" format="eps">
    @startuml
        ...
    @enduml
</plantuml>

Sometimes it can be necessary to process auto-generated documents that contain multiple PlantUML diagrams definitions without using Foliant-specific tags syntax. Use the parse_raw option in these cases.

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

foliantcontrib.plantuml-1.0.10.tar.gz (8.9 kB view details)

Uploaded Source

Built Distribution

foliantcontrib.plantuml-1.0.10-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

File details

Details for the file foliantcontrib.plantuml-1.0.10.tar.gz.

File metadata

  • Download URL: foliantcontrib.plantuml-1.0.10.tar.gz
  • Upload date:
  • Size: 8.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.9.5

File hashes

Hashes for foliantcontrib.plantuml-1.0.10.tar.gz
Algorithm Hash digest
SHA256 dbd5ebeb874592733f9c044df047fe5989011177220e35d6fd9eb9ce4fcb30f2
MD5 28c646bb185fef2b4f90be5581c62251
BLAKE2b-256 42a8884e64a0fdcd6ce04c4ea2d84af6f091eac01a211c7face05d456272da99

See more details on using hashes here.

File details

Details for the file foliantcontrib.plantuml-1.0.10-py3-none-any.whl.

File metadata

  • Download URL: foliantcontrib.plantuml-1.0.10-py3-none-any.whl
  • Upload date:
  • Size: 7.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.9.5

File hashes

Hashes for foliantcontrib.plantuml-1.0.10-py3-none-any.whl
Algorithm Hash digest
SHA256 5f11931ddcc7b76b85a534ed45c3c29357d2abc0531d3c42aa93a2f1fecd2dba
MD5 bdf7760f58cbcff88ccefdfc5dc42e66
BLAKE2b-256 dfdd425ab93e5337e2922363aef329e1ea105b31754af579f0b365c711082548

See more details on using hashes here.

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