A Pandoc filter to express diagrams inline using the Haskell EDSL Diagrams.
'diagrams-pandoc' replaces appropriately marked code blocks in pandoc input with images. The code blocks are compiled using the Haskell EDSL Diagrams. Each block should define a Diagram named example
, to be output. This name and other defaults can be overridden by command-line arguments to the diagrams-pandoc program.
A pandoc filter to express diagrams inline using the haskell EDSL diagrams.
Usage
Create an input file called demo.md
with the following text:
This is how to draw a circle:
~~~ diagram
example = circle 1
~~~
Install diagrams-pandoc, then run pandoc as follows:
pandoc -t html demo.md --filter diagrams-pandoc -o demo.html -s
The file demo.html should now have an img tag pointing at a PNG of a circle.
Attributes
You can specify attributes to control how the diagram is generated. The following, for example,
~~~ {.diagram width=800 height=400 caption="A circle"}
example = circle 1
~~~
will override the default width and height of the generated diagram, and provide a caption for it. The following attributes are supported:
width
: The width of the generated diagram, in pixels. The default is 500.height
: The height of the generated diagram, in pixels. The default is 200.caption
: The caption of the diagram. Providing a caption makes the diagram appear as a figure, rather than an inline image. Diagrams have no caption by default.alt
: The alt text of the diagram. The caption is used as the default value if it is provided, otherwise it is empty.
Details
diagrams-pandoc
compiles code blocks containing diagrams expressions and includes the resulting images in the pandoc markup. It is meant to be run as a pandoc filter as shown above.
diagrams-pandoc
evaluates the diagrams expression example
by default. This can be modified by passing a command line argument.
diagrams-pandoc
is aware of two code block classes. A block with the diagram
class will be replaced by the resulting image---the code will not appear in the output. A block with the diagram-haskell
class will produce both an image and a (syntax highlighted) code block. The input block is replaced by image appears before the code block, and the diagram-haskell
class is replaced by the haskell
class, so that pandoc can perform syntax highlighting as usual.
diagrams-pandoc
produces images in the pdf
format when used with the latex
and beamer
writers of pandoc
and produced png
output otherwise.
I have only tested with pandoc's markdown reader. In particular, the rst reader does not attach classes to code blocks, only to Div elements.
Installing
diagrams-pandoc
is on Hackage. To install, run cabal install diagrams-pandoc
TODO
- use pandoc output type to pick an image file format
- for formats which are more human-readable (eg, markdown, rst), leave code block alone?
- provide command-line flags to override default behavior
- add Backends besides Cairo
- Support RST by handling
Div class=diagram [CodeBlock foo bar]
the same asCodeBlock class=diagram bar
- Alternate install directions using
stack
.