Skip to content

dmbaturin/ocamlbook.org

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ocaml-book

A free (as in freedom) OCaml textbook.

Contributing

This book is licensed under Creative Commons Attribution Share-Alike, a free culture license.

It's meant to be a collaborative effort that belongs to the community and can freely shared, updated and maintained even if the original authors no longer have the time and motivation to maintain it.

Everyone is welcome to contribute. Just create a pull request.

Building

You will need:

  • soupault website generator, version 2.0.0 or newer
  • cmark for Markdown to HTML conversion
  • highlight for static syntax highlighting
  • The OCaml compiler for build-time example typechecking
  • GNU Make

Once you have all dependencies, run make all, the output will be in build/.

Note on cmark

cmark versions before and after 0.29 have different HTML tag stripping behaviour and there is no set of options that can work for both.

Pre-0.29 versions would leave HTML tags alone unless run in "safe mode" (--safe).

cmark 0.29 unexpectedly made "safe mode" the new default and will remove all HTML tags unless you run it with --unsafe.

Why a locally run program working with local files would want to do that by default is beyond me. Why they didn't add a backwards-compatibility mechanism like an environment variable is also beyond me.

Anyway, the md = "cmark --unsafe" line in soupault.conf will only work with cmark >=0.29.

If you are building on a system with an older cmark version, remove --unsafe because older cmark versions do not understand that option, but neither do they need it.

Maybe I should just move to another convertor.

Reading

A live version is available at https://ocamlbook.org