# pandoc-plot
## A Pandoc filter to generate figures from code blocks in documents
[data:image/s3,"s3://crabby-images/5a910/5a910658829c4c33234078714b1e9234281db796" alt="license"](https://www.gnu.org/licenses/gpl.html)
`pandoc-plot` turns code blocks present in your documents (Markdown, LaTeX, etc.) into embedded figures, using your plotting toolkit of choice, including Matplotlib, ggplot2, MATLAB, Mathematica, and more.
## Overview
This program is a [Pandoc](https://pandoc.org/) filter. It can therefore
be used in the middle of conversion from input format to output format,
replacing code blocks with figures.
The filter recognizes code blocks with classes that match plotting
toolkits. For example, using the `matplotlib` toolkit:
```` markdown
# My document
This is a paragraph.
```{.matplotlib}
import matplotlib.pyplot as plt
plt.figure()
plt.plot([0,1,2,3,4], [1,2,3,4,5])
plt.title('This is an example figure')
```
````
Putting the above in `input.md`, we can then generate the plot and embed
it in an HTML page:
``` bash
pandoc --filter pandoc-plot input.md --output output.html
```
The resulting `output.html` looks like this:
```html
My document
This is a paragraph.
```
## Supported toolkits
`pandoc-plot` currently supports the following plotting toolkits
(**installed separately**):
- `matplotlib`: plots using the [matplotlib](https://matplotlib.org/)
Python library;
- `plotly_python` : plots using the
[plotly](https://plotly.com/python/) Python library;
- `plotly_r`: plots using the [plotly](https://plotly.com/r/) R
library
- `matlabplot`: plots using [MATLAB](https://www.mathworks.com/);
- `mathplot` : plots using
[Mathematica](https://www.wolfram.com/mathematica/);
- `octaveplot`: plots using [GNU
Octave](https://www.gnu.org/software/octave/);
- `ggplot2`: plots using [ggplot2](https://ggplot2.tidyverse.org/);
- `gnuplot`: plots using [gnuplot](http://www.gnuplot.info/);
- `graphviz`: graphs using [Graphviz](http://graphviz.org/);
- `bokeh`: plots using the [Bokeh](https://bokeh.org/) visualization library;
- `plotsjl`: plots using the [Julia `Plots.jl`](https://docs.juliaplots.org/latest/) package;
- `plantuml`: diagrams using the [PlantUML](https://plantuml.com/) software suite.
To know which toolkits are useable on *your machine* (and which ones are
not available), you can check with the `toolkits` command:
``` bash
pandoc-plot toolkits
```
**Wish your plotting toolkit of choice was available? Please [raise an
issue](https://github.com/LaurentRDC/pandoc-plot/issues)\!**
## Documentation
You can find more information in the documentation, available either in the
source repository file `MANUAL.md`, on the [webpage](https://laurentrdc.github.io/pandoc-plot/MANUAL.html), or via the command `pandoc-plot --manual`.
## Installation
### Binaries and Installers
[data:image/s3,"s3://crabby-images/d6368/d6368f0d1ba31ec9778bd8379d74821cdd8f6b46" alt="Latest release"](https://github.com/LaurentRDC/pandoc-plot/releases)
Windows, Linux, and Mac OS binaries are available on the [GitHub release
page](https://github.com/LaurentRDC/pandoc-plot/releases). There are
also Windows installers.
### conda
[data:image/s3,"s3://crabby-images/9a6aa/9a6aad5ed4321544aa26a785549402bee8c0db69" alt="Conda Version"](https://anaconda.org/conda-forge/pandoc-plot)
Like `pandoc`, `pandoc-plot` is available as a package installable with
[`conda`](https://docs.conda.io/en/latest/). [Click here to see the
package page](https://anaconda.org/conda-forge/pandoc-plot).
To install in the current environment:
``` sh
conda install -c conda-forge pandoc-plot
```
### Homebrew
[data:image/s3,"s3://crabby-images/d5901/d5901b7a1411fc2ded7382954b73c84a199ba794" alt="homebrew version"](https://formulae.brew.sh/formula/pandoc-plot)
`pandoc-plot` is available as a package via [`Homebrew`](https://brew.sh/). [Click here to see the package page](https://formulae.brew.sh/formula/pandoc-plot#default).
To install:
```sh
brew install pandoc-plot
```
### winget
You can install `pandoc-plot` from the [Windows Package
Manager](https://github.com/microsoft/winget-cli) `winget` (just like
`pandoc`). To install:
``` sh
winget install pandoc-plot
```
### Arch Linux
[data:image/s3,"s3://crabby-images/194c2/194c2a27823de3eb51a69417ef8476495e2c9459" alt="AUR version"](https://aur.archlinux.org/packages/pandoc-plot-bin/)
You can install `pandoc-plot` from the [archlinux user repository](https://aur.archlinux.org/packages/pandoc-plot-bin/) as `pandoc-plot-bin`. You can install using e.g. `yay`:
```sh
yay -S pandoc-plot-bin
```
### From Hackage/Stackage
[data:image/s3,"s3://crabby-images/3b50f/3b50fd228e2465150a9022a5b8cab7faf72fb5fe" alt="Hackage version"](http://hackage.haskell.org/package/pandoc-plot)
`pandoc-plot` is available on
[Hackage](http://hackage.haskell.org/package/pandoc-plot) and
[Stackage](https://www.stackage.org/nightly/package/pandoc-plot). Using
the [`cabal-install`](https://www.haskell.org/cabal/) tool:
``` bash
cabal update
cabal install
```
### From source
Building from source can be done using [`cabal`](https://www.haskell.org/cabal/):
``` bash
git clone https://github.com/LaurentRDC/pandoc-plot
cd pandoc-plot
cabal install # Alternatively, `stack install`
```