-
Notifications
You must be signed in to change notification settings - Fork 42
142 lines (139 loc) · 4.18 KB
/
pages.yml
File metadata and controls
142 lines (139 loc) · 4.18 KB
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
name: Pages
on:
workflow_call:
workflow_dispatch:
permissions:
id-token: write
contents: read
pages: write
jobs:
build-doxygen-xml:
runs-on: ubuntu-24.04
steps:
- name: Checkout repository
uses: actions/checkout@v6
- name: Install Doxygen
run: |
sudo apt-get update
sudo apt-get install --no-install-recommends -y doxygen
- name: Run Doxygen
run: doxygen Doxyfile
- name: Upload Doxygen documentation
uses: actions/upload-artifact@v6
with:
name: doxygen-documentation-xml
path: xml
build-sphinx:
runs-on: ubuntu-24.04
needs:
- build-doxygen-xml
steps:
- name: Checkout repository
uses: actions/checkout@v6
- name: Set up Python
uses: actions/setup-python@v6
with:
python-version: '3.14'
- name: Install Doxygen and Graphviz
run: |
sudo apt-get update
sudo apt-get install --no-install-recommends -y doxygen graphviz
- name: Install dependencies
run: |
python3 -m pip install -r docs/requirements.txt
python3 -m pip install graphviz pyyaml
- name: Download artifact
uses: actions/download-artifact@v7
with:
name: doxygen-documentation-xml
path: xml
- name: Generate CI jobs graph
run: |
python3 scripts/jobs_graph.py --out docs/_static/ci_graph --format svg
- name: Configure project
run: >
cmake -S . -B build -D USE_DOCS=ON
- name: Build i18n
run: |
cmake --build build -t docs_gettext -- --quiet
cmake --build build -t docs_update -- --quiet
- name: Build documentation
run: |
cmake --build build -t docs_html -- --quiet
- name: Upload artifact
uses: actions/upload-artifact@v6
with:
name: sphinx-documentation
path: ./build/docs/_build/html
build-scoreboard:
runs-on: ubuntu-24.04
steps:
- name: Checkout repository
uses: actions/checkout@v6
- name: Set up Python
uses: actions/setup-python@v6
with:
python-version: '3.14'
- name: Install dependencies
run: |
python3 -m pip install -r requirements.txt
python3 -m pip install -r scoreboard/requirements.txt
- name: Download performance data
uses: actions/download-artifact@v7
with:
name: perf-stat
- name: Extract performance data
run: |
mkdir -p build/perf_stat_dir
# The uploaded artifact contains a nested perf-stat.zip inside.
# First unzip extracts the inner archive; the second extracts perf_stat_dir/*.
unzip -o perf-stat.zip -d .
if [ -f "perf-stat.zip" ]; then
mv -f perf-stat.zip perf-stat-inner.zip
unzip -o perf-stat-inner.zip -d .
fi
- name: CMake configure
run: |
cmake -S . -B build -DUSE_SCOREBOARD=ON
- name: CMake build
run: |
cmake --build build --parallel -- --quiet
- name: Upload artifact
uses: actions/upload-artifact@v6
with:
name: scoreboard
path: ./build/scoreboard/html/
deploy-pages:
if: ${{ !github.event.repository.fork && github.ref == 'refs/heads/master' }}
needs:
- build-sphinx
- build-scoreboard
runs-on: ubuntu-24.04
environment:
name: github-pages
concurrency:
group: github-pages-deploy
cancel-in-progress: false
steps:
- name: Download artifact
uses: actions/download-artifact@v7
with:
name: sphinx-documentation
path: ./
- name: Download artifact
uses: actions/download-artifact@v7
with:
name: scoreboard
path: ./scoreboard/
- name: Download coverage artifact
uses: actions/download-artifact@v7
with:
name: cov-report
path: ./coverage/
- name: Upload artifact
uses: actions/upload-pages-artifact@v5
with:
path: ./
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v4