-
Notifications
You must be signed in to change notification settings - Fork 52
161 lines (129 loc) · 4.38 KB
/
documentation.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
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
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
name: Documentation
on:
push:
branches:
- main
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued.
# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete.
concurrency:
group: "pages"
cancel-in-progress: false
jobs:
build-main-documentation:
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: '3.11'
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -r docs/requirements.txt
- name: Build documentation
run: |
export SPHINX_BASE_URL="/itk-wasm/"
cd docs/
make html
- name: Upload artifact
uses: actions/upload-artifact@v4
with:
name: main-documentation
path: docs/_build/html
build-package-documentation:
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v4
- name: Free Disk Space (Ubuntu)
uses: jlumbroso/free-disk-space@main
- name: Pull latest Docker images
run: |
./src/docker/pull.sh
- uses: actions/setup-node@v4
with:
node-version: '20'
- name: Install
uses: pnpm/action-setup@v2
with:
version: 8
run_install: true
- name: Build itk-wasm
run: |
pnpm build
- name: Build package typescript documentation
run: |
for package in compare-images compress-stringify dicom downsample image-io mesh-io; do
mkdir -p docs/$package/ts/docs
mkdir -p docs/$package/ts/app
sed "s% basePath:.*% basePath: '/itk-wasm/$package/ts/docs',%" packages/$package/typescript/index.html > docs/$package/ts/docs/index.html
cp packages/$package/typescript/README.md docs/$package/ts/docs/
mkdir -p docs/$package/ts/docs/test/browser/demo-app
cp packages/$package/typescript/test/browser/demo-app/logo.svg docs/$package/ts/docs/test/browser/demo-app/
pushd packages/$package/typescript
rm -rf demo-app node_modules/.vite
export VITE_BASE_URL="/itk-wasm/$package/ts/app/"
pnpm build
popd
rsync -a packages/$package/typescript/demo-app/ docs/$package/ts/app/
done
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: '3.11'
- name: Build package python documentation
run: |
for package in compare-images compress-stringify dicom downsample image-io mesh-io; do
mkdir -p docs/$package/py/docs
mkdir -p docs/$package/py/app
export SPHINX_BASE_URL="/itk-wasm/$package/py/docs/"
pushd packages/$package/python/*$package/docs
pip install -r requirements.txt
make html
popd
rsync -a packages/$package/python/*$package/docs/_build/html/ docs/$package/py/docs/
done
- name: Upload artifact
uses: actions/upload-artifact@v4
with:
name: package-documentation
path: docs
consolidate-documentation:
needs: [build-main-documentation, build-package-documentation]
runs-on: ubuntu-22.04
steps:
- name: Download main documentation
uses: actions/download-artifact@v4
with:
name: main-documentation
path: docs
- name: Download package documentation
uses: actions/download-artifact@v4
with:
name: package-documentation
path: docs
- name: Upload Pages artifact
uses: actions/upload-pages-artifact@v3
with:
path: docs
retention-days: 7
deploy-gh-pages:
needs: consolidate-documentation
runs-on: ubuntu-22.04
# Grant GITHUB_TOKEN the permissions required to make a Pages deployment
permissions:
contents: read
pages: write # to deploy to Pages
id-token: write # to verify the deployment originates from an appropriate source
# Deploy to the github-pages environment
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
steps:
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v4
# with:
# preview: true <-> currently not available to the public