Grafische Element & visuelle Effekte
Abgabe für den Kurs Grafische Elemente & visuelle Effekte im Wintersemester 19/20 bei Prof. Klaus Keller an der FH Potsdam.
Building the book
This book is generated from source using the Nix tool. If you have Nix installed, you can generate the book using the exerimental flake feature. Both Nix and Nix flakes are somewhat esoteric tools in the software world, so the following explanation will explain their installation in depth.
Installation
The easiest way to install this project is to build it as a Nix flake. Flakes are an experimental Nix feature, so first you'd need to install the stable version of Nix:
curl -L https://nixos.org/nix/install | sh
With stable Nix installed, we can use Nix to aquire a temporary shell with unstable Nix. Note that this doesn't install Nix permanently, so you have to repeat this step every time you interact with flakes.
nix run nixpkgs.nixUnstable
In this temporary shell, we can finally build a Nix flake. No need to download anything prior or checkout a Git repository!
nix build github:erictapen/geve#pdf
If no errors happened, the final PDF file can be found in the current directory in result/geve.pdf
. Note that result
is just a symlink.
Hacking
If you want to hack on the project, you might want to use the Stack build tool. Executing stack run
should be enough to generate the svg files in the cache
dir.
If you are using Nix (with experimental flakes support enabled) and want to skip the stack
part, you should be fine with pulling all necessary dependencies via nix develop
, then run runhaskell src/Main.hs
.
cache
dir
The After running, the cache
directory is populated with images. Most of the images are generated only if they can't be found in the cache, so if you modify the source code you might need to delete the files in cache
before rerunning the program.
Code formatting
The code is formatted with ormolu. To format every Haskell source file in the repository, you can run ormolu --mode inplace $(find src/ -name '*.hs')
.