 
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 |