- Install Miniconda3 for Python 3.9.
- Run
conda update -n base -c defaults conda
to upgrade that base install to latest versions. - Run
conda env create -f environment.yml
to create thetextbook
environment. - Proceed with one of the next two options.
Automatic option (recommended for quality of life):
- Install conda-auto-env. All you have to do is clone the repo and source the script.
- Now any time you
cd
into the root of the textbook repo you'll have the right environment active. You lose the environment by cd'ing below it though.
Manual option:
- Run
conda activate textbook
to activate the environment every time you want to work on the textbook.
- Create an OPAM switch for the textbook, e.g.,
opam switch create textbook ocaml-base-compiler.4.14.0
. Ideally the compiler version for the switch should be the same as the compiler version specified in the preface's student-facing install instructions. However, Ocaml-Jupyter (which we need to install next) does not yet work with OCaml 5 and hasn't since 2023. - Install Ocaml-Jupyter with
opam install jupyter
. - Install the minimal set of packages needed by the textbook:
opam install ounit2 qcheck menhir zarith
. - For ease of editing OCaml code in VS Code while in the textbook switch, also
install these packages:
opam install ocaml-lsp-server ocamlformat
. - Run
ocaml-jupyter-opam-genspec
. Note in the output where it generated the kernelspec. Edit that file and change thedisplay_name
to just "OCaml". That's important. The display name will be hardcoded in each chapter that uses code cells, unfortunately, so we need a name that is consistent and independent of the name of the switch in the current semester. - Make sure you've already done the above Conda environment install and have that environment active.
- Run
jupyter kernelspec install --user --name ocaml-jupyter "$(opam var share)/jupyter"
- If your
~/.ocamlinit
contains#use "topfind";;
, then considering surrounding it with these assignment statements:The assignment statements will reduce the amount of output you see when building the textbook. But if yourSys.interactive := false;; #use "topfind";; Sys.interactive := true;;
~/.ocamlinit
does not already#use "topfind"
, or if you don't have such a file, there's no need to add it or the statements.
- Run
make html
or justmake
to build the HTML version. - Run
make view
(currently supported on Mac only) to conveniently open the generated HTML in your browser. - Run
make deploy
to deploy the textbook to GitHub Pages. Before doing that, you need to have a git remote set up. You can do so withgit remote add public git@github.com:cs3110/textbook.git
. The name of the remote,public
in that example command, can be configured at the top ofMakefile
if you want to use a different name.