Skip to content
This repository has been archived by the owner on Aug 4, 2021. It is now read-only.

shauser/pymdown-nomnoml

Repository files navigation

PyMdown pymdown_nomnoml plugin Build Status

A PyMdown extension to render pymdown_nomnoml diagrams

The pymdown_nomnoml extension will render any superfence using nomnoml into an SVG image. This provides a simple way to add diagrams in your documentation files in a readable syntax. You can also start playing around with nomnoml before installing.

Installation

Since nomnoml itself is written in JavaScript, you need to have NodeJS installed on your system.

Install the package with pip:

pip install pymdown-nomnoml

Enable the extension in your mkdocs.yml:

markdown_extensions:
    - pymdownx.superfences:
        custom_fences:
            - name: nomnoml
              class: nomnoml-diagram
              format: !!python/name:pymdown_nomnoml.fence_nomnoml_svg_b64

Example

You can now use the nomnoml extension like this:

# Document

This is a short diagram

``` nomnoml
[a] - [b]
[b] -> [c]
```

When building, the code block will be replaced by an SVG version of the diagram.

Limitations

Note that there are some known limitations of the SVG renderer and it is considered experimental by the nomnoml author. The alternatives to the SVG renderer are:

  • PNG renderer: This requires canvas support in nodejs, which is has some prerequisites. I'm planning to add support for this for version 1.0.
  • Canvas renderer: This embeds the nomnoml JavaScript library in the HTML and renders it at runtime. This will work, unless you want to print the document or export to PDF. I'm planning to add support for this for version 1.0.

The known limitations for the SVG renderer (this list is probably not exhaustive):

  • Dashed and dotted lines are rendered solid
  • Line rounding in corners is not implemented

Contributing

From reporting a bug to submitting a pull request: every contribution is appreciated and welcome. Report bugs, ask questions and request features using Github issues. If you want to contribute to the code of this project, please read the Contribution Guidelines.

About

PyMdown plugin for nomnoml

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •