Skip to content

Towards concrete syntax parser integration #393

Towards concrete syntax parser integration

Towards concrete syntax parser integration #393

name: Build and profile and CoqDoc
on:
push:
branches: [ "main" ]
pull_request:
branches: [ "main" ]
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
permissions:
contents: read
pages: write
id-token: write
# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued.
# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete.
concurrency:
group: "pages"
cancel-in-progress: false
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Install Nix
uses: DeterminateSystems/nix-installer-action@v9
- name: Setup Magic Nix Cache
uses: DeterminateSystems/magic-nix-cache-action@main
- name: 'Build with Coq 8.19'
run: nix build -L '.#minuska-coq_8_19' --out-link ./result-minuska
- name: 'Build Coq examples (with Coq 8.19)'
run: nix build -L '.#examples-coq'
- name: 'Run standalone examples'
run: nix develop -L '.#examples-standalone' --command ./examples-standalone/test.sh
- name: 'Run hybrid examples'
run: nix develop -L '.#examples-hybrid' --command ./examples-hybrid/test.sh
- name: 'Build Docker image'
run: nix build -L '.#minuska-docker' --out-link ./result-minuska-docker
- name: 'Archive Docker image'
uses: actions/upload-artifact@v4
with:
name: 'minuska-docker-image'
path: |
./result-minuska-docker
retention-days: 5
#- name: Build
# run: nix develop '.#minuska' --command ./build-and-profile.sh
#- name: CoqDoc
# run: nix develop '.#minuska' --command make -C minuska/ html
- name: Setup Pages
uses: actions/configure-pages@v4
- name: Upload artifact
uses: actions/upload-pages-artifact@v3
with:
path: 'result-minuska/share/coq-minuska/Minuska.html/'
#path: 'minuska/html'
#- name: 'Build with Coq 8.17'
# run: nix build -L '.#minuska-coq_8_17'
# Deployment job
deploy:
if: github.ref == 'refs/heads/main'
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: ubuntu-latest
needs: build
steps:
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v4
package:
if: github.ref == 'refs/heads/main'
runs-on: ubuntu-latest
needs: build
permissions:
packages: write
steps:
- name: Download a single artifact
uses: actions/download-artifact@v4
with:
name: 'minuska-docker-image'
# path: './result-minuska-docker'
- name: Log in to the Container registry
uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: 'Push Docker image'
run: |
ls
docker image import ./result-minuska-docker ghcr.io/h0nzzik/minuska:${GITHUB_SHA}
docker image push ghcr.io/h0nzzik/minuska:${GITHUB_SHA}