Skip to content

Commit

Permalink
Merge pull request #47 from nicholasbishop/bishop-book-split-2
Browse files Browse the repository at this point in the history
Bishop book split 2
  • Loading branch information
nicholasbishop authored Jul 6, 2024
2 parents 4e4e190 + 46ff933 commit 4e319f7
Show file tree
Hide file tree
Showing 3 changed files with 37 additions and 24 deletions.
45 changes: 29 additions & 16 deletions .github/workflows/book.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,14 @@ name: Book
on:
push:
branches: [main]
tags: ['*']
permissions:
contents: write
# Adapted from:
# https://github.com/rust-lang/mdBook/wiki/Automated-Deployment%3A-GitHub-Actions#github-pages-deploy
jobs:
deploy:
if: github.repository == 'rust-osdev/uefi-rs'
# if: github.repository == 'rust-osdev/uefi-rs'
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
Expand All @@ -21,24 +22,36 @@ jobs:
echo `pwd`/mdbook >> $GITHUB_PATH
- name: Deploy GitHub Pages
run: |
cd book
mdbook build
git worktree add gh-pages gh-pages
# Configure git user so that `git commit` works.
git config user.name "Deploy from CI"
git config user.email ""
cd gh-pages
# Get the highest `uefi` release tag.
highest_tag="$(git tag --list | grep uefi-v | sort -V | tail -1)"
# Create worktrees for both the `main` branch and the highest tag.
git worktree add --detach wt-main main
git worktree add --detach wt-tag "${highest_tag}"
# Create a worktree for the `gh-pages` branch.
git worktree add wt-gh-pages gh-pages
# Delete the ref to avoid keeping history.
git update-ref -d refs/heads/gh-pages
# Place the book under a "HEAD" directory so that we can later
# add other versions (e.g. "stable" or "v0.17") without breaking
# URLs.
rm -rf HEAD
mv ../book HEAD
git add HEAD
# Add an index in the root to redirect to HEAD. If we eventually
# serve multiple versions, this can be changed to a real index.
cp ../head_redirect.html index.html
git add index.html
git -C wt-gh-pages update-ref -d refs/heads/gh-pages
# Delete existing book builds.
rm -rf wt-gh-pages/HEAD wt-gh-pages/latest-release
# Build the book for both `main` and the highest tag.
mdbook build --dest-dir wt-gh-pages/HEAD wt-main
mdbook build --dest-dir wt-gh-pages/latest-release wt-tag
cd wt-gh-pages
# Add an index in the root to redirect to the latest release.
cp ../redirect.html index.html
# Commit and push.
git add HEAD latest-release index.html
git commit -m "Deploy $GITHUB_SHA to gh-pages"
git push --force
8 changes: 0 additions & 8 deletions book/head_redirect.html

This file was deleted.

8 changes: 8 additions & 0 deletions book/redirect.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
<!DOCTYPE html>
<head>
<meta charset="utf-8">
<title>Redirecting to latest release documentation</title>
<meta http-equiv="refresh" content="0; URL=latest-release">
</head>

Redirecting to <a href="latest-release">./latest-release</a>...

0 comments on commit 4e319f7

Please sign in to comment.