-
Notifications
You must be signed in to change notification settings - Fork 33
189 lines (155 loc) · 5.44 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
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
name: Documentation
# This workflow is divided in 3 jobs, ocaml_docs, sphinx_docs, deploy_docs.
# - The ocaml_docs build the ocaml documentation, it runs for every push,
# if it fails no more work is done
# - The sphinx_docs job build the sphinx documentation, it runs only if a PR
# is open. if it fails no more work is done
# - deploy_docs only run on the next branch when code is pushed. It retrieve
# the ocaml and sphinx documentation and deploy them on the gh-pages branch
on:
push:
tags:
- "v*.*.*"
branches:
- next
- main
pull_request:
env:
OCAML_DEFAULT_VERSION: 4.14.2
# Add OPAMYES=true to the environment, this is usefill to replace `-y` option
# in any opam call
OPAMYES: true
jobs:
# For any push and PR, build the documentation from the ocaml comments
# If this build fails, the documentation workflow stops
# If it succeeds, an artifact is made with the generated documentation
# (html format only). This artifact is used in the deploying job
ocaml_docs:
name: OCaml documentation
runs-on: ubuntu-latest
env:
OPAMWITHDOC: true
steps:
# Checkout the code of the current branch
- name: Checkout code
uses: actions/checkout@v4
# Update apt-get database
- name: Update apt-get database
run: sudo apt-get update
# Get an OCaml environment with opam installed and the proper ocaml version
# opam will used opam cache environment if retrieved
- name: Use OCaml ${{ env.OCAML_DEFAULT_VERSION }}
uses: ocaml/setup-ocaml@v3
with:
ocaml-compiler: ${{ env.OCAML_DEFAULT_VERSION }}
# https://github.com/ocaml/dune/issues/7720
dune-cache: false
- name: Retrieve annotated tags for dune
run: git fetch --tags --force
# Install dependencies if the cache is not retrieved
# odoc is installed as deps with { with-doc } in opam files
- name: opam install deps
run: opam exec -- make deps
- name: Perform version substitution
run: opam exec -- dune subst
# Make the documentation
- name: Make OCaml documentation
run: opam exec -- dune build @doc
# Create and upload an artifact `ocaml_doc` that contains the ocaml
# documentation in html format.
- name: Upload ocaml documentation
uses: actions/upload-artifact@v4
with:
name: ocaml_doc
path: _build/default/_doc/_html/
sphinx_docs:
name: Sphinx documentation
runs-on: ubuntu-latest
outputs:
version-name: ${{ steps.version-name.outputs.target }}
steps:
# Checkout the code of the current branch
- name: Checkout code
uses: actions/checkout@v4
- name: Determine version name
id: version-name
run: |
echo "target=${GITHUB_REF#*/*/}" >> $GITHUB_OUTPUT
# Build the sphinx documentation
# and automatically print any error or warning
- name: Build sphinx documentation
uses: ammaraskar/sphinx-action@master
with:
docs-folder: "docs/sphinx_docs/"
build-command: >
sphinx-build -W -b html
-A current_version=${{ steps.version-name.outputs.target }}
. _build
# Create and upload an artifact `sphinx_doc` that contains the sphinx
# documentation in html format.
- name: Upload sphinx documentation
uses: actions/upload-artifact@v4
with:
name: sphinx_doc
path: docs/sphinx_docs/_build
deploy_docs:
name: Deploy documentation
permissions:
contents: write
if: ${{ github.event_name == 'push' }}
needs:
- ocaml_docs
- sphinx_docs
runs-on: ubuntu-latest
steps:
- name: Download sphinx documentation
uses: actions/download-artifact@v4
with:
name: sphinx_doc
path: _build/${{ needs.sphinx_docs.outputs.version-name }}
- name: Download ocaml documentation
uses: actions/download-artifact@v4
with:
name: ocaml_doc
path: _build/${{ needs.sphinx_docs.outputs.version-name }}/API
- name: deploy-doc
uses: JamesIves/github-pages-deploy-action@3.6.2
with:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
BRANCH: gh-pages
FOLDER: _build
CLEAN: false
update_versions:
name: Update documentation versions
permissions:
contents: write
needs: deploy_docs
runs-on: ubuntu-latest
if: ${{ github.event_name == 'push' }}
steps:
- name: Checkout documentation
uses: actions/checkout@v4
with:
ref: gh-pages
- name: Update latest version
if: startsWith(github.ref, 'refs/tags/')
run: |
ln -nsf ${{ needs.sphinx_docs.outputs.version-name }} latest
- name: Write versions to JSON file
run: |
rm -f versions.json
echo -n '[' >versions.json
PREFIX=''
for version in $(ls -d */ | sort -n); do
echo -n "$PREFIX" >>versions.json
PREFIX=','
echo -n '{"url": "/alt-ergo/'$version'", "slug": "'${version%/}'"}' >>versions.json
done
echo -n ']' >>versions.json
- name: Push new versions
run: |
git config user.name github-actions
git config user.email github-actions@github.com
git add versions.json
git commit -m 'Update versions.json' || exit 0
git push