Skip to content

Merge pull request #178 from sgouezel/main #266

Merge pull request #178 from sgouezel/main

Merge pull request #178 from sgouezel/main #266

Workflow file for this run

on:
push:
branches:
- main
# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
permissions:
contents: read
pages: write
id-token: write
# allow write to manipulate cache
actions: write
jobs:
build_blueprint:
runs-on: ubuntu-latest
name: Build blueprint
steps:
- name: Checkout project
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Install Python
uses: actions/setup-python@v5
with:
python-version: '3.9'
cache: 'pip' # cache pip dependencies
- name: Update pip
run: |
pip install --upgrade pip
- name: Install blueprint apt dependencies
run: |
sudo apt-get update
sudo apt-get install -y graphviz libgraphviz-dev pdf2svg dvisvgm
- name: Install blueprint dependencies
run: |
cd blueprint && pip install -r requirements.txt
- name: Build blueprint and copy to `docs/blueprint`
run: |
make blueprint
mkdir -p docs
mv blueprint/web docs/
- name: Clear previously saved cache
uses: DareFox/delete-cache-by-key@v1.0.1
with:
key: Blueprint-cache
mode: exact
continue-on-error: true
- name: Save blueprint for future use
uses: actions/cache/save@v4
with:
path: |
docs/web
key: Blueprint-cache
- name: Restore previous documentation, while we wait for the next one to be generated
uses: actions/cache/restore@v4
with:
path: |
docs/docs
key: Documentation-cache
continue-on-error: true
- name: Setup Pages
uses: actions/configure-pages@v4
- name: Upload blueprint artifact
uses: actions/upload-pages-artifact@v2
with:
path: docs
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v3
# generate doc after blueprint (as it's quite a bit longer)
build_docs:
runs-on: ubuntu-latest
name: Build docs
steps:
- name: Checkout project
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Install elan
run: curl https://raw.githubusercontent.com/leanprover/elan/master/elan-init.sh -sSf | sh -s -- -y --default-toolchain $(cat lean-toolchain)
- name: Build project
run: make LAKEBIN='~/.elan/bin/lake' build
- name: Cache mathlib docs
uses: actions/cache@v3
with:
path: |
.lake/build/doc/Init
.lake/build/doc/Lake
.lake/build/doc/Lean
.lake/build/doc/Std
.lake/build/doc/Mathlib
.lake/build/doc/declarations
!.lake/build/doc/declarations/declaration-data-PrimeNumberTheoremAnd*
key: MathlibDoc-${{ hashFiles('lake-manifest.json') }}
restore-keys: |
MathlibDoc-
- name: Build documentation
run: make LAKEBIN='~/.elan/bin/lake' doc
- name: Copy documentation to `docs/docs`
run: |
mkdir -p docs
cp -r .lake/build/doc docs/docs
- name: Clear previously saved cache
uses: DareFox/delete-cache-by-key@v1.0.1
with:
key: Documentation-cache
mode: exact
continue-on-error: true
- name: Save documentation for future use
uses: actions/cache/save@v4
with:
path: |
docs/docs
key: Documentation-cache
#- name: Download blueprint artifacts
# uses: actions/download-artifact@v3
# with:
# path: blueprint_artifacts
#
#- name: Extract blueprint artifacts
# run: tar xvf blueprint_artifacts/github-pages/artifact.tar -C docs/
- name: Restore previously generated blueprint
uses: actions/cache/restore@v4
with:
path: |
docs/web
key: Blueprint-cache
continue-on-error: true
- name: Upload docs & blueprint artifact
uses: actions/upload-pages-artifact@v2
with:
path: docs
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v3