-
Notifications
You must be signed in to change notification settings - Fork 10
49 lines (49 loc) · 1.48 KB
/
docs.yml
File metadata and controls
49 lines (49 loc) · 1.48 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
name: Build docs
on:
push:
branches:
- main
permissions:
contents: read
pages: write
id-token: write
jobs:
deploy:
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: ubuntu-latest
steps:
- uses: actions/configure-pages@v5
- uses: actions/checkout@v5
- uses: actions/setup-python@v5
with:
python-version: 3.x
- run: pip install zensical
- name: Copy README to docs with fixed relative links
run: |
python3 -c "
import re, os
repo_url = os.environ['REPO_URL']
with open('README.md') as f:
content = f.read()
# Strip ./docs/ prefix so links resolve within the docs directory
content = content.replace('./docs/', './')
# Convert remaining relative links with directory paths to absolute GitHub URLs
# (these point to repo files outside docs/, e.g. ./validation/README.md)
content = re.sub(
r'(\[[^\]]*\])\(\./([^)]*\/[^)]*)\)',
rf'\1({repo_url}/blob/main/\2)',
content,
)
with open('docs/index.md', 'w') as f:
f.write(content)
"
env:
REPO_URL: ${{ github.server_url }}/${{ github.repository }}
- run: zensical build --clean
- uses: actions/upload-pages-artifact@v4
with:
path: site
- uses: actions/deploy-pages@v4
id: deployment