Bartosz Milewski's 'Category Theory for Programmers' unofficial PDF and LaTeX source
Go to file
2018-07-30 23:10:57 +03:00
src Completely using the libertine package, no need to install local fonts 2018-07-30 23:10:57 +03:00
.gitignore Placing appendices in own part. This fixes #74 2018-07-30 15:06:25 +03:00
.travis.yml Travis s3 deploy (#132) 2018-07-30 00:25:37 +03:00
LICENSE Updating readme 2017-10-16 21:36:25 +03:00
README.md Bumping version 2018-07-30 13:43:34 +03:00
shell.nix Changing 'Libertine' to use the package. Misc preamble tweaks. (#131) 2018-07-30 12:20:46 +03:00

Category Theory for Programmers

Category Theory for Programmers

image Direct link: category-theory-for-programmers.pdf
(Latest release: v0.8.0, July 2018)

Build Status
(latest CI build)

This is an unofficial PDF version of "Category Theory for Programmers" by Bartosz Milewski, converted from his blogpost series.


Conversion is done by scraping the blog with Mercury Web Parser to get a clean HTML content, modifying and tweaking with Beautiful Soup, finally, converting to LaTeX with Pandoc. See scraper.py for additional information.

Please report any formatting/content issues, or better yet, send a PR!

Building

For macOS Users: The Inconsolata LGC, Linux Libertine, and Libertinus Math fonts are not included in MacTex. You need to install them separately. Download the Inconsolata LGC fonts here, the Linux Libertine fonts here, and the Libertinus Math font here. To install the fonts system-wide, move all the downloaded .otf files into the /Library/Fonts folder. After completing these tasks, continue with the instructions below.

The src directory contains the LaTeX sources. To recompile the book, go there and enter:

$ make

The file preamble.tex contains all the configuration and style declarations.

Chances for successful compilation are increased if you have almost complete installation of recent TeX Live distribution (the PDF here is compiled with 2017 release). The needed OpenType fonts must be installed in the operating system.

To remove all the generated PDFs and auxiliary files in the whole src tree:

$ make clean-all

Tip: you can use a utility like entr to run a command after any *.tex file changes, e.g.:

$ ls **/*.tex | entr make

This will monitor all the *.tex files for changes, and will execute the make command if any of them changes. This speeds up development significantly, as you can freely modify any of the files, and get almost instant feedback!

Acknowledgements

PDF LaTeX source and the tools to create it are based on the work by Andres Raba et al., available here: https://github.com/sarabander/sicp-pdf.
The book content is taken, with permission, from Bartosz Milewski's blogpost series, and adapted to the LaTeX format.

Thanks to the following people for contributing corrections/conversions and misc:

  • Oleg Rakitskiy
  • Jared Weakly
  • Paolo G. Giarrusso
  • Adi Shavit
  • Mico from the TeX.StackExchange community
  • Marcello Seri
  • Erwin Maruli Tua Pakpahan
  • Markus Hauck
  • ...and many others!

Note from Bartosz: I really appreciate all your contributions. You made this book much better than I could have imagined. Thank you!

License

The PDF book, .tex files, and associated images and figures in directories src/fig and src/content are licensed under Creative Commons Attribution-ShareAlike 4.0 International License (cc by-sa).

The script files scraper.py and others are licensed under GNU General Public License version 3 (for details, see LICENSE).