Skip to content

Merge feature into main branch #941

Merge feature into main branch

Merge feature into main branch #941

Workflow file for this run

---
name: Test building documentation
on:
pull_request:
types:
- opened
- reopened
- synchronize
jobs:
changes:
name: Detect changes
runs-on: ubuntu-latest
outputs:
cpp: ${{ steps.filter.outputs.cpp }}
python: ${{ steps.filter.outputs.python }}
doc: ${{ steps.filter.outputs.doc }}
any: ${{ steps.filter.outputs.any }}
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Detect changes
uses: dorny/paths-filter@v3
id: filter
with:
filters: |
build_files: &build_files
- '.github/workflows/test_doc.yml'
- 'build'
- 'build.bat'
- 'build_system/main.py'
- 'build_system/core/**'
- 'build_system/util/**'
- 'build_system/targets/*.py'
cpp: &cpp
- *build_files
- 'build_system/targets/documentation/cpp/*'
- 'cpp/**/include/**'
python: &python
- *build_files
- 'build_system/targets/documentation/python/*'
- 'python/subprojects/**/mlrl/**'
doc: &doc
- *build_files
- 'build_system/targets/documentation/*'
- 'doc/**'
any:
- *cpp
- *python
- *doc
build_doc:
needs: changes
if: ${{ needs.changes.outputs.any == 'true' }}
name: Test building documentation
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Setup Python
uses: actions/setup-python@v5
with:
python-version-file: .version-python
- name: Prepare ccache
uses: hendrikmuhs/ccache-action@v1
with:
key: build-doc-ccache
- name: Install Doxygen
uses: ssciwr/doxygen-install@v1
- name: Generate C++ Apidoc
if: ${{ needs.changes.outputs.cpp == 'true' && needs.changes.outputs.doc != 'true' }}
run: GPU_SUPPORT=disabled ./build apidoc_cpp
- name: Generate Python Apidoc
if: ${{ needs.changes.outputs.python == 'true' && needs.changes.outputs.doc != 'true' }}
run: GPU_SUPPORT=disabled ./build apidoc_python
- name: Install Roboto font
if: ${{ needs.changes.outputs.doc == 'true' }}
run: sudo apt install -y fonts-roboto
- name: Generate documentation
if: ${{ needs.changes.outputs.doc == 'true' }}
run: GPU_SUPPORT=disabled ./build doc
check_links:
needs: changes
if: ${{ needs.changes.outputs.any == 'true' }}
name: Check links in documentation
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Setup Python
uses: actions/setup-python@v5
with:
python-version-file: .version-python
- name: Prepare ccache
uses: hendrikmuhs/ccache-action@v1
with:
key: check-links-ccache
- name: Install Doxygen
uses: ssciwr/doxygen-install@v1
- name: Install Roboto font
run: sudo apt install -y fonts-roboto
- name: Check links in documentation
run: GPU_SUPPORT=disabled SPHINX_BUILDER=linkcheck ./build doc
check_spelling:
needs: changes
if: ${{ needs.changes.outputs.any == 'true' }}
name: Check for spelling mistakes in documentation
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Setup Python
uses: actions/setup-python@v5
with:
python-version-file: .version-python
- name: Prepare ccache
uses: hendrikmuhs/ccache-action@v1
with:
key: check-spelling-ccache
- name: Install Doxygen
uses: ssciwr/doxygen-install@v1
- name: Install Roboto font
run: sudo apt install -y fonts-roboto
- name: Check for spelling mistakes in documentation
run: GPU_SUPPORT=disabled SPHINX_BUILDER=spelling ./build doc