 
Here we use git-of-theseus to show how the polylith codebase has evolved over time.
As you can see, the codebase has been constantly reworked to keep it in shape:
 
This second diagram shows how people have contributed with source code (mostly Clojure code) to the codebase:
 
If you want to try it out yourself, start by cloning the polylith repo (if you haven’t already):
git clone git@github.com:polyfy/polylith.gitTo generate these diagrams, we need to have python and pip installed.
Create Python virtual environment in e.g. a python-venv directory, and install git-of-theseus:
mkdir python-venv
cd python-venv
python -m venv .venv
source .venv/bin/activate
pip install git-of-theseusNow you can ask git-of-theseus to analyze the repository:
git-of-theseus-analyze ../polylithThis will generate different json files that can be used by other commands to generate diagrams, e.g.:
git-of-theseus-stack-plot cohorts.json --outfile code-over-time.png
git-of-theseus-stack-plot authors.json --outfile contribution.pngShow more options:
git-of-theseus-analyze --help
git-of-theseus-stack-plot --helpGource is another tool that can create animations to visualize how the codebase has evolved over time.
Here is an example animation (click to open):
If you want to try it out yourself, start by installing it:
brew install gource
brew install ffmpegThis will generate a polylith.mp4 file:
gource --seconds-per-day 0.2 --auto-skip-seconds 1 --max-file-lag 0.1 --background 9dabcb --logo doc/images/visualize-the-repo/logo.png --disable-bloom --font-size 18 --font-colour 566ca1 --hide filenames --date-format "%d %B %Y" --dir-colour eeeeee --dir-name-depth 2 --caption-colour ff0000 --dir-font-size 12 -o - | ffmpeg -y -r 60 -f image2pipe -vcodec ppm -i - -vcodec libx264 -preset ultrafast -pix_fmt yuv420p -crf 1 -threads 0 -bf 0 polylith.mp4You can also experiment without generating a file:
gource --seconds-per-day 0.2 \
       --auto-skip-seconds 1 \
       --max-file-lag 0.1 \
       --background 9dabcb \
       --logo doc/images/visualize-the-repo/logo.png \
       --disable-bloom \
       --font-size 18 \
       --font-colour 566ca1 \
       --hide filenames \
       --date-format "%d %B %Y" \
       --dir-colour eeeeee \
       --dir-name-depth 2 \
       --caption-colour ff0000 \
       --dir-font-size 12Can you improve this documentation?Edit on GitHub
cljdoc builds & hosts documentation for Clojure/Script libraries
| Ctrl+k | Jump to recent docs | 
| ← | Move to previous article | 
| → | Move to next article | 
| Ctrl+/ | Jump to the search field |