package pandoc
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
md5=ed0bb4281fb064e6f08c702e7becc473
    
    
  sha512=71164a661b26c5deffbf68911673170ed5bddd397e0e3e45d37bac9e6f6c048244f66da9967b7f0345015360780cc2b0b898dcf175b53a896df26eca77d45201
    
    
  Description
This library helps writing filters for pandoc, which is a tool to convert between textual formats notably, markdown and LaTeX
Published: 21 Nov 2023
README
The OCaml pandoc library
This library is meant to help creating filters for pandoc which is tool to convert between textual formats, notably markdown and LaTeX. It is vaguely inspired of the corresponding Haskell library.
Documentation
The documentation for the library is available online.
Building filters
Basically, a pandoc filter will
- read JSON data from the standard input with Yojson.Basic.from_channel,
- convert it to the library's standard representation with Pandoc.of_json,
- transform it using the Pandoc.mapfunction which recursively maps functions on various elements,
- convert the result to JSON with Pandoc.of_json,
- print the result on the standard output using Yojson.Basic.to_string.
Once you have build your filter (say, myfilter) you can use it to transform pandoc documents while they are being processed by using the --filter commandline argument. For instance:
pandoc --filter=myfilter file.md -o file.pdfExamples
Some examples are provided in the examples directory for you convenience (or because I needed those).
- pandoc-abbreviations: adds non-breakable spaces after abbreviations (listed in- abbreviationsfile). Pandoc already does this natively, but it does not play well with other plugins.
- pandoc-crossref: handles cross-references in LaTeX. It replaces references of the form- #chap:blaand- #sec:blito- \cref{chap:bla}and- \cref{sec:bli}respectively.
- pandoc-include: includes other documents. It replaces- !include "file"- by the contents of the file - fileand- ```{.ocaml include="test.ml" from=2 to=5} ```- by the contents of the file - test.mlbetween lines 2 and 5 (negative values for- toare counted from the end of the file). Useful for including small code snippets.
- pandoc-inspect: acts as the identity plugin, but prints the JSON output given by pandoc on the standard error. Useful for debugging and adding missing features to the library.
- pandoc-pdf2png: changes the extension of images from- .pdfto- .png. Useful if you want to compile both to pdf and html.
- pandoc-replace: replaces words by others. Useful for fixing capitalization for instance.
Bugs and features requests
The code is simple and stable enough for me but some features are missing. Feel free to fill bug reports or submit pull requests.
Dev Dependencies
None
Used by (7)
- 
  
    pandoc-abbreviations
  
  
    = "0.2.0"
- 
  
    pandoc-comment
  
  
    < "0.2.1"
- 
  
    pandoc-crossref
  
  
    = "0.2.0"
- 
  
    pandoc-include
  
  
    = "0.2.0"
- 
  
    pandoc-inspect
  
  
    = "0.2.0"
- 
  
    pandoc-pdf2png
  
  
    < "0.2.1"
- 
  
    pandoc-replace
  
  
    < "0.2.1"
Conflicts
None