forked from drowl87/hextra_mirror
chore(ci): add support for building docs for multiple versions (#633)
* chore(ci): add support for building docs for multiple versions * chore(ci): enable fetching tags in GitHub Actions workflow * chore(build): add v0.8.6 version to build script
This commit is contained in:
parent
c3ce3b67e6
commit
a338c363ed
26
.github/workflows/pages.yml
vendored
26
.github/workflows/pages.yml
vendored
@ -1,5 +1,5 @@
|
|||||||
# Sample workflow for building and deploying a Hugo site to GitHub Pages
|
# Build and deploy Hextra docs site to GitHub Pages
|
||||||
name: Deploy Hugo site to Pages
|
name: Deploy Hextra docs site to Pages
|
||||||
|
|
||||||
on:
|
on:
|
||||||
# Runs on pushes targeting the default branch
|
# Runs on pushes targeting the default branch
|
||||||
@ -37,33 +37,37 @@ jobs:
|
|||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
fetch-depth: 0 # fetch all history for .GitInfo and .Lastmod
|
fetch-depth: 0 # fetch all history for .GitInfo and .Lastmod
|
||||||
|
fetch-tags: true
|
||||||
submodules: recursive
|
submodules: recursive
|
||||||
|
|
||||||
- name: Setup Go
|
- name: Setup Go
|
||||||
uses: actions/setup-go@v5
|
uses: actions/setup-go@v5
|
||||||
with:
|
with:
|
||||||
go-version: '1.23'
|
go-version: "1.24"
|
||||||
|
|
||||||
- name: Setup Pages
|
- name: Setup Pages
|
||||||
id: pages
|
id: pages
|
||||||
uses: actions/configure-pages@v5
|
uses: actions/configure-pages@v5
|
||||||
|
|
||||||
- name: Setup Hugo
|
- name: Setup Hugo
|
||||||
run: |
|
run: |
|
||||||
wget -O ${{ runner.temp }}/hugo.deb https://github.com/gohugoio/hugo/releases/download/v${HUGO_VERSION}/hugo_extended_${HUGO_VERSION}_linux-amd64.deb \
|
wget -O ${{ runner.temp }}/hugo.deb https://github.com/gohugoio/hugo/releases/download/v${HUGO_VERSION}/hugo_extended_${HUGO_VERSION}_linux-amd64.deb \
|
||||||
&& sudo dpkg -i ${{ runner.temp }}/hugo.deb
|
&& sudo dpkg -i ${{ runner.temp }}/hugo.deb
|
||||||
- name: Build with Hugo
|
|
||||||
|
- name: Make build script executable
|
||||||
|
run: chmod +x ./build.sh
|
||||||
|
|
||||||
|
- name: Build all site versions
|
||||||
env:
|
env:
|
||||||
# For maximum backward compatibility with Hugo modules
|
|
||||||
HUGO_ENVIRONMENT: production
|
HUGO_ENVIRONMENT: production
|
||||||
HUGO_ENV: production
|
HUGO_ENV: production
|
||||||
# Use the latest release of the theme to build exampleSite
|
|
||||||
run: |
|
run: |
|
||||||
cd exampleSite && rm go.mod
|
./build.sh "${{ steps.pages.outputs.base_url }}"
|
||||||
hugo mod init github.com/imfing/hextra/exampleSite
|
|
||||||
hugo mod get -u github.com/imfing/hextra
|
|
||||||
hugo --minify --baseURL "${{ steps.pages.outputs.base_url }}/"
|
|
||||||
- name: Upload artifact
|
- name: Upload artifact
|
||||||
uses: actions/upload-pages-artifact@v3
|
uses: actions/upload-pages-artifact@v3
|
||||||
with:
|
with:
|
||||||
path: ./exampleSite/public
|
path: ./public
|
||||||
|
|
||||||
# Deployment job
|
# Deployment job
|
||||||
deploy:
|
deploy:
|
||||||
|
55
build.sh
Executable file
55
build.sh
Executable file
@ -0,0 +1,55 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
# Specify the base URL
|
||||||
|
BASE_URL=${1:-"http://localhost:1313"}
|
||||||
|
|
||||||
|
echo "Using base URL: $BASE_URL"
|
||||||
|
|
||||||
|
# Version configuration - modify these arrays to specify versions to build
|
||||||
|
# Format: "ref:display_name" (ref can be tag, branch, or commit hash, display name is what will appear in URL)
|
||||||
|
MAIN_VERSION="main:latest"
|
||||||
|
VERSIONS=(
|
||||||
|
"main:latest" # latest version always builds from main
|
||||||
|
"v0.9.6:v0.9"
|
||||||
|
"v0.8.6:v0.8"
|
||||||
|
)
|
||||||
|
|
||||||
|
# Parse main version
|
||||||
|
IFS=':' read -r MAIN_REF MAIN_NAME <<< "$MAIN_VERSION"
|
||||||
|
|
||||||
|
# Ensure clean public directory
|
||||||
|
rm -rf public
|
||||||
|
mkdir -p public
|
||||||
|
mkdir -p public/versions
|
||||||
|
|
||||||
|
# Checkout and build main site
|
||||||
|
git checkout $MAIN_REF
|
||||||
|
GIT_HASH=$(git rev-parse --short HEAD)
|
||||||
|
echo "Building main site from $MAIN_REF (commit: $GIT_HASH)"
|
||||||
|
hugo \
|
||||||
|
--minify \
|
||||||
|
--themesDir=../.. --source=exampleSite \
|
||||||
|
--baseURL "$BASE_URL/" \
|
||||||
|
--destination=../public
|
||||||
|
|
||||||
|
# Build all versions
|
||||||
|
for VERSION in "${VERSIONS[@]}"; do
|
||||||
|
IFS=':' read -r REF NAME <<< "$VERSION"
|
||||||
|
|
||||||
|
git checkout $REF
|
||||||
|
GIT_HASH=$(git rev-parse --short HEAD)
|
||||||
|
echo "Building version $NAME from $REF (commit: $GIT_HASH)"
|
||||||
|
|
||||||
|
mkdir -p "public/versions/$NAME"
|
||||||
|
hugo \
|
||||||
|
--minify \
|
||||||
|
--themesDir=../.. --source=exampleSite \
|
||||||
|
--baseURL "$BASE_URL/versions/$NAME/" \
|
||||||
|
--destination="../public/versions/$NAME"
|
||||||
|
done
|
||||||
|
|
||||||
|
# Return to main branch
|
||||||
|
git checkout main
|
||||||
|
|
||||||
|
echo "Build completed"
|
Loading…
x
Reference in New Issue
Block a user