The cloudFPFA documentation is available as GitHub pages at:
https://cloudfpga.github.io/Doc/ |
These pages are generated automatically from three sources:
- the so-called Organization Documentation provided by this
README.md
and theMarkdown
files located in the./docsrc/pages/
folders of this repository, - the so-called cF Repository Documentation provided by the
README.md
and theMarkdown
files located in each cF repository, - the so-called cF Source Code Documentation retrieved from the declarations and documentation comments in the software source files of the cF repositories.
We adopt the following tools for automating this documentation:
- Sphinx is a tool that makes it easy to create intelligent and beautiful documentation.
- Read the Docs (sphinx_rtd_theme) is a sphinx theme designed to look modern and be mobile-friendly.
- Travis CI is a hosted continuous integration service used to build and test software projects hosted at GitHub (both on our public and IBM enterprise repositories).
- Documenting the Organization
1.1 How to automatically compile the documentation
1.2 How to manually compile the documentation - Documenting the cF Repositories
- Documenting the cF Source Codes
The current Doc
repository defines the top-level structure of the cloudFPGA documentation.
It acts as a building pipeline of tasks that assembles the cloudFPGA documentation as a global
set of HTML pages compiled from the various repositories located in the cloudFPGA organization.
The global structure of the cloudFPGA documentation is defined by the markdown source files of
the organization located in the folders./docsrc/pages
.
Any change and commit to these folders will trigger an automatic re-compilation and re-generation of the GitHub pages. However, if you need to re-build and update this documentation locally, please follow the step-by-step procedure in the Manual documentation compilation section.
As mentioned above, an new compilation of the overall cloudFPGA documentation is triggered
whenever a commit to this current Doc repository occurs.
This build is performed by Travis CI
on a containerized environment and the resulting static
HTML files are pushed on the gh_pages
branch of the current
Doc repository.
The repository is configured to match this branch to the
GitHub Pages
and also bypass jekyll processing of GitHub Pages
by creating an empty
file named .nojekyll
on the repository. Eventually the final documentation is available
here.
If you need to manually compile the overall cloudFPGA documentation on your local development environment, please follow these steps:
To generate the Sphinx based python documentations, you need to setup:
which python3.6
virtualenv sphinx -p /usr/bin/python3.6
. sphinx/bin/activate
git clone [email protected]:cloudFPGA/Doc.git cloudFPGA-Doc
pip install -r ./cloudFPGA-Doc/docsrc/requirements.txt
. sphinx/bin/activate
cd cloudFPGA-Doc
git checkout master
< ... make your changes ... >
make clean
make localhtml
firefox _build/html/index.html & (to view your changes locally)
git checkout gh-pages (ensure you are on this branch)
git commit -am "rebuild docs"
git push
Each cloudFPGA repository should be accompanied by a minimal documentation provided in the form
of a README.md
file and / or other Markdown
files. These files (if present) will then be
pulled from their respective repositories and and will be parsed to generate the corresponding
HTML pages.
The following cF repositories are currently parsed for Markdown
files:
NOTE: In order to edit the documentation of the aforementioned repositories, you should apply the changes directly on the
Markdown
files in those repositories. Next, to make the changes being reflected onto the HTML pages, you can use the following automated or manual procedure.
Force a Restart Build job on the Travis CI page. This is useful when you don't have any changes for the current Organization Documentation but you want update the documentation of a specific cF repository.
Clone the Doc repo, create a minor commit and push it.
This is useful when you made changes in both the Organization Documentation
and the cF Repository Documentation. It is the push
request
that will trigger a new Travis CI building process.
The procedure is as follows:
git clone [email protected]:cloudFPGA/Doc.git cloudFPGA-Doc
cd cloudFPGA-Doc
< ... make your changes ... >
git commit -am "my changes in Doc repo"
git push
firefox https://pages.github.ibm.com/cloudFPGA/Doc/ & (view your changes)
NOTE: The documentation compilation on Travis CI is expected to take several minutes, so be patient when you submit changes as they won't take effect instantly.
The generation of the code documentation from the software source files is maintained in Dox, a separate repository of the cF organization. This documentation is in-lined as chapter 4.1 of the global cloudFPGA documentation, but it is also available here .