update (#6) #17
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Ubuntu build | |
on: | |
push: | |
branches: | |
- main | |
pull_request: | |
branches: | |
- main | |
workflow_dispatch: | |
permissions: | |
actions: write | |
contents: write # only for delete-branch option | |
issues: write | |
pull-requests: write | |
######################################################################## | |
## | |
## This CI is an adaptation from agda-cateogories. | |
## | |
## CONFIGURATION | |
## | |
## Key variables: | |
## | |
## AGDA_COMMIT picks the version of Agda to use to build the library. | |
## It can either be a hash of a specific commit (to target a bugfix for | |
## instance) or a tag e.g. tags/v2.6.1.3 (to target a released version). | |
## | |
## The rest: | |
## | |
## Basically do not touch GHC_VERSION and CABAL_VERSION as long as | |
## they aren't a problem in the build. If you have time to waste, it | |
## could be worth investigating whether newer versions of ghc produce | |
## more efficient Agda executable and could cut down the build time. | |
## Just be aware that actions are flaky and small variations are to be | |
## expected. | |
## | |
## The CABAL_INSTALL variable only passes `-O1` optimisations to ghc | |
## because github actions cannot currently handle a build using `-O2`. | |
## To be experimented with again in the future to see if things have | |
## gotten better. | |
## | |
## The AGDA variable specifies the command to use to build the library. | |
## It currently passes the flag `-Werror` to ensure maximal compliance | |
## with e.g. not relying on deprecated definitions. | |
## The rest are some arbitrary runtime arguments that shape the way Agda | |
## allocates and garbage collects memory. It should make things faster. | |
## Limits can be bumped if the builds start erroring with out of memory | |
## errors. | |
## | |
######################################################################## | |
env: | |
AGDA_COMMIT: tags/v2.6.4.3 | |
GHC_VERSION: 8.10.7 | |
CABAL_VERSION: 3.6.2.0 | |
CABAL_INSTALL: cabal install --overwrite-policy=always --ghc-options='-O1 +RTS -M6G -RTS' --installdir $HOME/.cabal/bin | |
AGDA: agda --auto-inline -Werror +RTS -M6G -H3.5G -A128M -RTS -i . -i src/ | |
jobs: | |
test-library: | |
runs-on: ubuntu-latest | |
steps: | |
# By default github actions do not pull the repo | |
- name: Checkout mech-type-theories | |
uses: actions/checkout@v4 | |
with: | |
submodules: recursive | |
######################################################################## | |
## SETTINGS | |
######################################################################## | |
- name: Initialise variables | |
run: | | |
# Only deploy if the build follows from pushing to master | |
if [[ '${{ github.ref }}' == 'refs/heads/main' ]]; then | |
echo "AGDA_DEPLOY=true" >> $GITHUB_ENV | |
fi | |
# The script won't be able to find Agda if we don't tell it to look at the | |
# content of ~/.cabal/bin | |
- name: Put cabal programs in PATH | |
run: echo "$HOME/.cabal/bin" >> $GITHUB_PATH | |
######################################################################## | |
## CACHING | |
######################################################################## | |
# This caching step allows us to save a lot of building time by only | |
# downloading ghc and cabal and rebuilding Agda if absolutely necessary | |
# i.e. if we change either the version of Agda, ghc, or cabal that we want | |
# to use for the build. | |
- name: Open cache | |
uses: actions/cache@v4 | |
id: cache-everything | |
with: | |
path: | | |
~/.cabal/packages | |
~/.cabal/store | |
~/.cabal/bin | |
~/.cabal/share | |
key: mech-type-theories-${{ runner.os }}-${{ env.GHC_VERSION }}-${{ env.CABAL_VERSION }}-${{ env.AGDA_COMMIT }}-cache | |
######################################################################## | |
## INSTALLATION STEPS | |
######################################################################## | |
- name: Install ghc and cabal | |
if: steps.cache-everything.outputs.cache-hit != 'true' | |
uses: haskell-actions/setup@v2 | |
with: | |
ghc-version: ${{ env.GHC_VERSION }} | |
cabal-version: ${{ env.CABAL_VERSION }} | |
- name: Cabal update | |
if: steps.cache-everything.outputs.cache-hit != 'true' | |
run: cabal update | |
- name: Download and install Agda from github | |
if: steps.cache-everything.outputs.cache-hit != 'true' | |
run: | | |
git clone https://github.com/agda/agda | |
cd agda | |
git checkout ${{ env.AGDA_COMMIT }} | |
mkdir -p doc | |
touch doc/user-manual.pdf | |
# make sure it exists | |
mkdir -p $HOME/.cabal/bin | |
${{ env.CABAL_INSTALL }} | |
cd .. | |
######################################################################## | |
## TESTING | |
######################################################################## | |
# Build README.agda! | |
- name: Test mech-type-theories | |
run: | | |
${{ env.AGDA }} src/README.agda | |
# Note that if you want to deploy html for different versions like the | |
# standard library does, you will need to be a bit more subtle in this | |
# step. | |
- name: Generate HTML | |
if: ${{ success() && env.AGDA_DEPLOY }} | |
run: | | |
${{ env.AGDA }} --html --highlight-occurrence --html-dir=html src/README.agda | |
######################################################################## | |
## DEPLOYMENT | |
######################################################################## | |
- name: Install Beautifulsoup4 | |
if: ${{ success() && env.AGDA_DEPLOY }} | |
run: | | |
pip3 install --user beautifulsoup4 | |
- name: Install pandoc | |
if: ${{ success() && env.AGDA_DEPLOY }} | |
run: | | |
sudo apt install -y pandoc | |
- name: Process HTML | |
if: ${{ success() && env.AGDA_DEPLOY }} | |
run: | | |
cp assets/Agda.css html/Agda.css | |
cp assets/styling.css html/styling.css | |
cp -r assets/images html/images | |
for f in html/*.html; do python3 assets/process.py $f; done | |
pandoc README.md -H assets/include.html --no-highlight --metadata pagetitle='Mechanizations of Type Theories' -t html --css styling.css -o html/index.html | |
- name: Deploy HTML | |
uses: JamesIves/github-pages-deploy-action@v4.6.3 | |
if: ${{ success() && env.AGDA_DEPLOY }} | |
with: | |
branch: gh-pages | |
folder: html |