Documentation¶
Most readers love documentation, its creators hate it.
Unfortunately, nobody can look inside your head and have the same ingenious thoughts as you do. To ensure your thoughts also reach the afterworld, please document your stuff reasonably!
The documentation is split up in two parts: static and dynamic docs,
Static Docs¶
Dedicated documentation files reside in the doc/
directory, where this
readme file lies in as well. You can find ideas, milestones, planning and
workflow descriptions etc in here.
A good entry point may be the file doc/project_structure. it roughly explains where to find what code in the project.
If you made any relevant discoveries or gained insights that help others understand any part of the project:
Create a file and write down your thoughts
Ideally, use markdown syntax, alternatively plain text
Submit your contribution (pull request) so we can include it in the official repository
This ensures newcomers can start developing easily
Dynamic Docs¶
This type of documentation is written inside code files:
C++ methods and classes are documented in their header files
Python methods and classes are documented via docstrings
Due to potential documentation laziness, the above statements might be out-right fabrications.
Doc Generation¶
Dynamic documentation can be auto-generated from source documentation using doxygen.
after calling ./configure
, you can invoke
make doc
to create doxygen html and LaTeX files.
After creation, view them in a browser by
$BROWSER bin/doc/html/index.html
or, if you want to create LaTeX documents, run
make -C bin/doc/latex/ pdf
$PDFVIEWER bin/doc/latex/refman.pdf
Webdoc Generation¶
Install Dependencies¶
You will need nearly all the basic dependencies as if you would build openage itself. Namely cmake, make, python3, nyan, etc. Make sure you have these.
Furthermore you’ll need the following:
sudo apt update
sudo apt install doxygen graphwiz
python -m pip install --upgrade pip
pip install -U sphinx doxypypy recommonmark autodoc breathe graphviz sphinx-markdown-tables sphinx-rtd-theme sphinxcontrib-moderncmakedomain
Building Documentation¶
Dynamic documentation for webhosting-purposes can be auto-generated from source documentation using doxygen in the first stage with sphinx and breathe in the second stage.
after calling ./configure --build-webdoc
, you can invoke the complete building process with
make webdoc
Doxygen is taking care of the documentation of the C++ parts. Although Doxypypy will take care of the Python parts and the rearrangement of the Markdown doc parts, we use Sphinx in combination with Breathe to generate a clean documentation suitable to our needs and easily hostable in the web. After that make
-command you will find the openage-docs
folder one directory level over your cloned repository.
HINT: If you need to regenerate just the second stage with Sphinx you can call make webdoc-sphinx
.