PELUX Software Factory Blueprint documentation
Software Factory Blueprint is maintained at https://github.com/Pelagicore/software-factory-blueprint
Maintainer: Joakim Gross [email protected]
You probably don't want to build the blueprint on its own, but rather use it as part of a deployment Software Factory. This approach is described in the intro chapter of these docs.
- cmake
- Sphinx
- sphinxcontrib-seqdiag
- sphinxcontrib-blockdiag
- sphinxcontrib-actdiag
- sphinxcontrib-manpage
- sphinxcontrib-spelling
- sphinx_rtd_theme
- texlive-latex-base (when building PDF)
- texlive-latex-extra (when building PDF)
- texlive-latex-recommended (when building PDF)
sudo apt-get install cmake python-pip
sudo pip install \
sphinxcontrib-seqdiag \
sphinxcontrib-blockdiag \
sphinxcontrib-actdiag \
sphinxcontrib-manpage \
sphinx_rtd_theme
The project uses cmake to configure the build. Supported options are:
ENABLE_PDF
- Enables building the docs in PDF format. Set to OFF by defaultPERFORM_SPELL_CHECK
- Performs a spell check on files. Set to ON by default
Configure and build from the git top dir like so:
cmake -H. -Bbuild
cd build
make
After a successful build you can find the documentation in build/docs/html/
if you open the index.html
in your browser you will see the entry point.
The project is intended to be used as a submodule in another project, in which case that project should take care of configuring, building, generating, etc. If the cmake file in this project is not the one invoked explicitly, e.g. when it is not the top level project cmake file, nothing will happen. This is to make sure this project does not interfere with the using project.
In order to not interfere with how the sidebar toctree is constructed in a
project using this as a submodule, all files in this repo that contain a
toctree need to have the suffix .trst
instead of just .rst
. This project
is configured to include .trst
files while projects using this as a
submodule should ignore that suffix.
A spell check is performed during the build step by default. It uses in-built language specific dictionaries and project specific dictionaries (spelling_wordlist.txt) to verify the spellings and causes the build to fail in case of any typos.
The project, which uses this blueprint, should have its own custom dictionary, similar to the one in blueprint (spelling_wordlist.txt). Currently, the sphinxcontrib-spelling module does not support multiple wordlists, so one should concatenate all wordlists to one specific list. In CMake, that can be done as follows:
add_custom_target(spelling
find "${CMAKE_CURRENT_SOURCE_DIR}" -iname "${WORDLIST_FILE}" -type f | xargs cat > ${BINARY_BUILD_DIR}/${WORDLIST_FILE}
COMMAND ${SPHINX_EXECUTABLE}
-W -b spelling
-c "${BINARY_BUILD_DIR}"
-d "${SPHINX_CACHE_DIR}"
"${CMAKE_CURRENT_SOURCE_DIR}"
"${CMAKE_BINARY_DIR}/spelling"
COMMENT "Spell-checking documentation with Sphinx"
The spell checker is added as a custom target, so to run it manually, simply type (after running cmake):
make spelling
To build the docs without checking the spelling, type:
make sphinx-html
Copyright (C) Pelagicore AB 2017
This work is licensed under the Creative Commons Attribution-ShareAlike 4.0 International License. To view a copy of this license, visit http://creativecommons.org/licenses/by-sa/4.0/ or send a letter to Creative Commons, PO Box 1866, Mountain View, CA 94042, USA.
Code and scripts are licensed under LGPL 2.1
SPDX-License-Identifier: CC-BY-SA-4.0