Embed OCaml notebooks in any web page thanks to WebComponents! Just copy and paste the following script in your html page source to load the integration: ```html ``` This will introduce a new html tag `` to present OCaml code, for example: ```html let x = 42 ``` The script will initialize a CodeMirror editor integrated with the OCaml interpreter, Merlin and OCamlformat (all running in a web worker). [**Check out the online demo**](https://art-w.github.io/x-ocaml/) for more details, including how to load additional OCaml libraries and ppx in your page. For an even easier integration, @patricoferris made a command-line tool [`xocmd`](https://github.com/patricoferris/xocmd) to convert markdown files to use ``! ## Compilation To avoid relying on a public CDN and host your own copy of the `x-ocaml` scripts, you can reproduce the javascript files with: ```shell $ git clone --recursive https://github.com/art-w/x-ocaml $ cd x-ocaml # Install the dependencies with either dune: x-ocaml/ $ dune pkg lock # Or with opam: x-ocaml/ $ opam update && opam install . --deps-only # Make sure to use the release profile to optimize the js file size x-ocaml/ $ dune build --profile=release x-ocaml/ $ ls *.js x-ocaml.js x-ocaml.worker+effects.js x-ocaml.worker.js ``` ## Acknowledgments This project was heavily inspired by the amazing [`sketch.sh`](https://sketch.sh), [@jonludlam's notebooks in Odoc](https://jon.recoil.org/notebooks/foundations/foundations1.html#a-first-session-with-ocaml), [`blogaml` by @panglesd](https://github.com/panglesd/blogaml), and all the wonderful people who made [Try OCaml](https://try.ocamlpro.com/) and other online playgrounds! It was made possible thanks to the invaluable [`js_of_ocaml-toplevel`](https://github.com/ocsigen/js_of_ocaml) library, the magical [`merlin-js` by @voodoos](https://github.com/voodoos/merlin-js), the excellent [CodeMirror bindings by @patricoferris](https://github.com/patricoferris/jsoo-code-mirror/), the guidance of @Julow on `ocamlformat` and the javascript expertise of @xvw.