-
Notifications
You must be signed in to change notification settings - Fork 2
66 lines (56 loc) · 2.32 KB
/
test_docs.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
name: "Build and Deploy: Documentation (Doxygen, Sphinx, MkDocs)"
on: [push, pull_request, workflow_dispatch]
jobs:
build-deploy-docs:
runs-on: ubuntu-22.04 # ubuntu-latest; use static version for stability
steps:
- name: "Checkout"
uses: actions/checkout@v4
- name: "Setup Python"
uses: actions/setup-python@v4
with:
python-version: "3.11"
architecture: "x64"
- name: "Generate Doxygen XML output for C++ API"
uses: mattnotmitt/doxygen-action@v1.9.8
with:
doxyfile-path: AutonomyLib/docs/Doxyfile
working-directory: .
- name: "Install Python dependencies: MkDocs-Material, Sphinx-Immaterial, Breathe, Exhale"
shell: bash
run: |
python3 -m venv .env # virtual environment to avoid dependecy issues
source ./.env/bin/activate
python3 -m pip install --upgrade pip
pip install mkdocs mkdocs-material pymdown-extensions # mkdocstrings[python]
pip install sphinx sphinx-immaterial numpy msgpack-rpc-python
pip install breathe exhale # for doxygen -> sphinx -> html conversion
- name: "Generate C++ API documentation: Doxygen -> Sphinx -> HTML"
shell: bash
run: |
source ./.env/bin/activate
(cd ./AutonomyLib/docs; make html)
cp -r ./AutonomyLib/docs/_build/* ./docs/api/cpp/ # copy generated API documentation
deactivate
- name: "Generate Python API documentation: Sphinx -> HTML"
shell: bash
run: |
source ./.env/bin/activate
(cd ./python/docs; make html)
cp -r ./python/docs/_build/* ./docs/api/python/ # copy generated API documentation
deactivate
- name: "Generate project documentation: MkDocs -> HTML"
shell: bash
#run: bash ./scripts/build_docs.sh
run: |
cp ./README.md ./docs/
sed -i 's/](docs\//](/g' ./docs/README.md
source ./.env/bin/activate
mkdocs build
deactivate
- name: "Deploy generated HTML on commits to master branch"
uses: peaceiris/actions-gh-pages@v3
if: ${{ github.event_name == 'push' && github.ref == 'refs/heads/master' }}
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
publish_dir: ./build_docs