1
1
mirror of https://github.com/wez/wezterm.git synced 2024-11-23 15:04:36 +03:00
wezterm/ci/build-docs.sh

60 lines
1.8 KiB
Bash
Executable File

#!/bin/bash
SERVE=no
if [ "$1" == "serve" ] ; then
SERVE=yes
fi
for util in gelatyx ; do
if ! hash $util 2>/dev/null ; then
cargo install $util --locked
fi
done
tracked_markdown=$(mktemp)
trap "rm ${tracked_markdown}" "EXIT"
find docs -type f | egrep '\.(markdown|md)$' > $tracked_markdown
gelatyx --language lua --file-list $tracked_markdown --language-config ci/stylua.toml
gelatyx --language lua --file-list $tracked_markdown --language-config ci/stylua.toml --check || exit 1
set -ex
# Use the GH CLI to make an authenticated request if available,
# otherwise just do an ad-hoc curl.
# However, if we are called from within a GH actions workflow (BUILD_REASON
# is set), only use `gh` if GH_TOKEN is also set, otherwise it will refuse
# to run.
function ghapi() {
if hash gh 2>/dev/null && test \( -n "$BUILD_REASON" -a -n "$GH_TOKEN" \) -o -z "$BUILD_REASON"; then
gh api $1
else
curl https://api.github.com$1
fi
}
[[ -f /tmp/wezterm.releases.json ]] || ghapi /repos/wez/wezterm/releases > /tmp/wezterm.releases.json
[[ -f /tmp/wezterm.nightly.json ]] || ghapi /repos/wez/wezterm/releases/tags/nightly > /tmp/wezterm.nightly.json
python3 ci/subst-release-info.py || exit 1
python3 ci/generate-docs.py || exit 1
# Adjust path to pick up pip-installed binaries
PATH="$HOME/.local/bin;$PATH"
if hash black 2>/dev/null ; then
black ci/generate-docs.py ci/subst-release-info.py
fi
cp "assets/icon/terminal.png" docs/favicon.png
cp "assets/icon/wezterm-icon.svg" docs/favicon.svg
mkdir -p docs/fonts
cp assets/fonts/SymbolsNerdFontMono-Regular.ttf docs/fonts/
docker build -t wezterm/mkdocs-material -f ci/Dockerfile.docs .
if [ "$SERVE" == "yes" ] ; then
docker run --rm -it --network=host -v ${PWD}:/docs wezterm/mkdocs-material serve
else
docker run --rm -e CARDS=true -v ${PWD}:/docs wezterm/mkdocs-material build
fi