forked from emdgroup/baybe
-
Notifications
You must be signed in to change notification settings - Fork 0
94 lines (90 loc) · 3.03 KB
/
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
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
name: Documentation
on:
push:
branches:
- main
release:
types:
- published
workflow_dispatch: # Allow manually triggering the workflow
concurrency:
group: ${{ github.workflow }}
cancel-in-progress: true
jobs:
build:
runs-on: ubuntu-latest
permissions:
contents: write
pages: write
id-token: write
steps:
- uses: actions/checkout@v4
with:
ref: ${{ github.ref }}
- uses: actions/setup-python@v5
with: {python-version: "3.10"}
- name: Install tox
run: pip install tox-uv
- name: Build Docs
run: tox -e docs-py310 -- -r
- name: Configure sphinx bot for pushing and fetch branches
run: |
git config --local user.email "sphinx-upload[bot]@users.noreply.github.com"
git config --local user.name "sphinx-upload[bot]"
git fetch origin gh-pages:gh-pages
git checkout gh-pages
git fetch origin main:main
git show main:docs/scripts/utils.py > utils.py
- name: Check for Hotfix
id: hotfix
run: |
pip install packaging
git fetch --tags
tags=$(git tag -l)
if ${{ github.event_name == 'release' }}; then
HOTFIX_VERSION=$(python utils.py hotfix "${{github.event.release.tag_name}}" "$tags")
else
HOTFIX_VERSION="False"
fi
echo "$HOTFIX_VERSION"
echo "hotfix=$HOTFIX_VERSION" >> "$GITHUB_OUTPUT"
- name: Verify setting of hotfix
run: |
echo "The value of hotfix is ${{ steps.hotfix.outputs.hotfix }}"
- if: ${{ steps.hotfix.outputs.hotfix == 'False'}}
name: Copy latest folder to gh-pages branch and update branch
run: |
if [ -d "latest" ]; then
rm -rf latest
fi
mkdir ./latest
cp -r docs/build/* ./latest
echo "Successfully copied into latest"
python utils.py html latest
git add -f latest
- if: ${{ github.event_name == 'release' }}
name: Create numbered version
run: |
FOLDER=${{github.event.release.tag_name}}
mkdir ./$FOLDER
cp -r docs/build/* ./$FOLDER
python utils.py selector_page $FOLDER
python utils.py html $FOLDER
git add -f $FOLDER
git add -f versions.html
- if: ${{ (github.event_name == 'release') && (steps.hotfix.outputs.hotfix == 'False') }}
name: Copy stable folder to gh-pages branch when releasing
run: |
if [ -d "stable" ]; then
rm -rf stable
fi
mkdir ./stable
cp -rv docs/build/* ./stable
python utils.py html stable
git add -f stable
- name: Create git commit
run: |
git_hash=$(git rev-parse --short "$GITHUB_SHA")
git commit -m "Sphinx documentation for ${git_hash}"
- name: Push changes to gh-pages branch
run: git push origin gh-pages