Support Center & Knowledge base

Getting started

Writing documentation can be done by just working on each repository individually or you can work with the documentation engine and see the end result while working. This is a good idea to get a feeling for how it will look like and verify that links, images and diagrams are correct.

You’ll have to start by cloning the Documentation repository, which has sub modules:

$ git clone --recursive

If you’ve already cloned it, you can get the submodules by doing the following:

$ git submodule update --init --recursive

The system is relying on all content sitting in the content folder:

<repository root>
└── Source
    └── Hugo
        └── content

Linking to repositories

The repositories.json file configures at which path (sub-folder) under the content folder repositories will be linked to, and with which name. The content folder should contain the parent folders, with a matching and the contents of the Documentation folder from the repository directly in this. This is best achieved by creating a symbolic link to the repositories Documentation folder.

Open a shell and navigate to the correct sub-folder in the content folder.


$ ln -s <repository-folder>/Documentation <folder-name>


c:> mklink /d <folder-name> <repository-folder>\Documentation 



$ ln -s /Projects/Dolittle/Runtime/Documentation overview


c:> mklink /d overview c:\Projects\Dolittle\Runtime\Documentation 

Chances are you are contributing to the code of the repository and you can therefor leave it in place and maintain code and documentation side-by-side.

As an alternative to manually setting up the symlinks to each repository, you can add a repositories.local.json file, and run the command.

For any local repositories you want to link to, use the full path to the repository on your local machine instead of the url to the github project. You can also mix these up with public respository urls for convenience.

    "/Users/username/code/Dolittle/DotNET.fundamentals/": {
        "name": "dotnet-fundamentals",
        "path": "api"
    "": {
        "name": "overview",
        "path": "runtime"
There are some linked dependencies in certain files, so it's recommended that you copy the content from `repositories.json` into `repositories.local.json` and change the url on the local repository you are working with. As described above.

Building and running

Install dependencies

You need to install node dependencies in the Source/Hugo folder. You can do this through using npm or yarn.


$ npm install


$ yarn

Install Hugo

You will need to install Hugo. Once you have Hugo installed, you open a shell and navigate to the Source/Hugo folder. From this you simply do:


$ hugo server


c:> hugo server

This should then yield something like the following:

                   | EN
  Pages            | 191
  Paginator pages  |   0
  Non-page files   |  32
  Static files     | 209
  Processed images |   0
  Aliases          |   2
  Sitemaps         |   1
  Cleaned          |   0

Total in 149 ms
Watching for changes in /Users/einari/Projects/Dolittle/Documentation/Source/Hugo/{content,repositories,themes,..}
Watching for config changes in /Users/einari/Projects/Dolittle/Documentation/Source/Hugo/config.toml
Serving pages from memory
Running in Fast Render Mode. For full rebuilds on change: hugo server --disableFastRender
Web Server is available at //localhost:1313/ (bind address
Press Ctrl+C to stop

It is now a matter of opening up a browser to the URL http://localhost:1313 and start writing documentation. With the default option, the page will live reload when saving any files.


All documentation is written in markdown following the GitHub flavor. Markdown can be written using the simplest of editors (Pico, Nano, Notepad), but there are editors out there that gives great value and guides you through giving you feedback on errors. Editors like Visual Studio Code and Sublime Text comes highly recommended. VSCode has for instance a markdown preview feature.

<div class=“alert alert-success”

role=“alert”>Happy documenting