2022-12-20 08:49:16 +00:00
|
|
|
name: Cabal cache
|
|
|
|
|
2022-12-29 12:44:17 +00:00
|
|
|
|
2022-12-20 08:49:16 +00:00
|
|
|
on:
|
|
|
|
push:
|
|
|
|
branches:
|
|
|
|
- master
|
|
|
|
pull_request:
|
|
|
|
branches:
|
|
|
|
- master
|
|
|
|
|
|
|
|
jobs:
|
|
|
|
build-linux:
|
|
|
|
name: Build linux binary
|
|
|
|
runs-on: ${{ matrix.os }}
|
|
|
|
env:
|
|
|
|
CABAL_VER: 3.6.2.0
|
|
|
|
JSON_VERSION: "0.0.7"
|
|
|
|
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
|
|
|
|
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
|
|
|
|
S3_HOST: ${{ secrets.S3_HOST }}
|
|
|
|
strategy:
|
|
|
|
fail-fast: true
|
|
|
|
matrix:
|
|
|
|
include:
|
|
|
|
- os: ubuntu-latest
|
2023-01-15 12:01:15 +00:00
|
|
|
ARTIFACT: "i386-linux-cabal"
|
2022-12-20 08:49:16 +00:00
|
|
|
GHC_VER: 8.10.7
|
|
|
|
ARCH: 32
|
|
|
|
steps:
|
|
|
|
- name: Checkout code
|
|
|
|
uses: actions/checkout@v3
|
|
|
|
with:
|
|
|
|
submodules: 'true'
|
|
|
|
|
|
|
|
- if: matrix.ARCH == '32'
|
|
|
|
name: Run build (32 bit linux)
|
|
|
|
uses: docker://hasufell/i386-alpine-haskell:3.12
|
|
|
|
with:
|
|
|
|
args: sh .github/scripts/cabal-cache.sh
|
|
|
|
env:
|
|
|
|
ARTIFACT: ${{ matrix.ARTIFACT }}
|
|
|
|
ARCH: ${{ matrix.ARCH }}
|
|
|
|
GHC_VER: ${{ matrix.GHC_VER }}
|
|
|
|
DISTRO: Alpine
|
|
|
|
AWS_SECRET_ACCESS_KEY: ${{ env.AWS_SECRET_ACCESS_KEY }}
|
|
|
|
AWS_ACCESS_KEY_ID: ${{ env.AWS_ACCESS_KEY_ID }}
|
|
|
|
S3_HOST: ${{ env.S3_HOST }}
|
|
|
|
|
|
|
|
- if: matrix.ARCH == '64'
|
|
|
|
name: Run build (64 bit linux)
|
|
|
|
uses: docker://hasufell/alpine-haskell:3.12
|
|
|
|
with:
|
|
|
|
args: sh .github/scripts/cabal-cache.sh
|
|
|
|
env:
|
|
|
|
ARTIFACT: ${{ matrix.ARTIFACT }}
|
|
|
|
ARCH: ${{ matrix.ARCH }}
|
|
|
|
GHC_VER: ${{ matrix.GHC_VER }}
|
|
|
|
DISTRO: Alpine
|
|
|
|
AWS_SECRET_ACCESS_KEY: ${{ env.AWS_SECRET_ACCESS_KEY }}
|
|
|
|
AWS_ACCESS_KEY_ID: ${{ env.AWS_ACCESS_KEY_ID }}
|
|
|
|
S3_HOST: ${{ env.S3_HOST }}
|
|
|
|
|
|
|
|
- if: always()
|
|
|
|
name: Upload artifact
|
|
|
|
uses: actions/upload-artifact@v3
|
|
|
|
with:
|
|
|
|
name: artifacts
|
|
|
|
path: |
|
|
|
|
./out/*
|
|
|
|
|
|
|
|
|
|
|
|
build-arm:
|
|
|
|
name: Build ARM binary
|
|
|
|
runs-on: ${{ matrix.os }}
|
|
|
|
env:
|
|
|
|
CABAL_VER: 3.6.2.0
|
|
|
|
JSON_VERSION: "0.0.7"
|
|
|
|
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
|
|
|
|
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
|
|
|
|
S3_HOST: ${{ secrets.S3_HOST }}
|
|
|
|
strategy:
|
|
|
|
fail-fast: true
|
|
|
|
matrix:
|
|
|
|
include:
|
2023-01-15 12:01:15 +00:00
|
|
|
- os: [self-hosted, Linux, ARM64, aarch32-linux]
|
|
|
|
ARTIFACT: "armv7-linux-cabal"
|
2022-12-20 08:49:16 +00:00
|
|
|
GHC_VER: 8.10.7
|
|
|
|
ARCH: ARM
|
|
|
|
steps:
|
|
|
|
- uses: docker://arm64v8/ubuntu:focal
|
|
|
|
name: Cleanup (aarch64 linux)
|
|
|
|
with:
|
2023-01-15 12:01:15 +00:00
|
|
|
args: "find . -mindepth 1 -maxdepth 1 -exec rm -rf -- {} +"
|
2022-12-20 08:49:16 +00:00
|
|
|
|
|
|
|
- name: git config
|
|
|
|
run: |
|
|
|
|
git config --global --get-all safe.directory | grep '^\*$' || git config --global --add safe.directory "*"
|
|
|
|
shell: bash
|
|
|
|
|
|
|
|
- name: Checkout code
|
|
|
|
uses: actions/checkout@v3
|
|
|
|
with:
|
|
|
|
submodules: 'true'
|
|
|
|
|
|
|
|
- if: matrix.ARCH == 'ARM'
|
|
|
|
uses: docker://hasufell/arm32v7-ubuntu-haskell:focal
|
|
|
|
name: Run build (armv7 linux)
|
|
|
|
with:
|
|
|
|
args: sh .github/scripts/cabal-cache.sh
|
|
|
|
env:
|
|
|
|
ARTIFACT: ${{ matrix.ARTIFACT }}
|
|
|
|
ARCH: ${{ matrix.ARCH }}
|
|
|
|
GHC_VER: ${{ matrix.GHC_VER }}
|
|
|
|
DISTRO: Ubuntu
|
|
|
|
AWS_SECRET_ACCESS_KEY: ${{ env.AWS_SECRET_ACCESS_KEY }}
|
|
|
|
AWS_ACCESS_KEY_ID: ${{ env.AWS_ACCESS_KEY_ID }}
|
|
|
|
S3_HOST: ${{ env.S3_HOST }}
|
|
|
|
|
|
|
|
- if: matrix.ARCH == 'ARM64'
|
|
|
|
uses: docker://hasufell/arm64v8-ubuntu-haskell:focal
|
|
|
|
name: Run build (aarch64 linux)
|
|
|
|
with:
|
|
|
|
args: sh .github/scripts/cabal-cache.sh
|
|
|
|
env:
|
|
|
|
ARTIFACT: ${{ matrix.ARTIFACT }}
|
|
|
|
ARCH: ${{ matrix.ARCH }}
|
|
|
|
GHC_VER: ${{ matrix.GHC_VER }}
|
|
|
|
DISTRO: Ubuntu
|
|
|
|
AWS_SECRET_ACCESS_KEY: ${{ env.AWS_SECRET_ACCESS_KEY }}
|
|
|
|
AWS_ACCESS_KEY_ID: ${{ env.AWS_ACCESS_KEY_ID }}
|
|
|
|
S3_HOST: ${{ env.S3_HOST }}
|
|
|
|
|
|
|
|
- if: always()
|
|
|
|
name: Upload artifact
|
|
|
|
uses: actions/upload-artifact@v3
|
|
|
|
with:
|
|
|
|
name: artifacts
|
|
|
|
path: |
|
|
|
|
./out/*
|
|
|
|
|
2022-12-20 12:49:10 +00:00
|
|
|
- if: always()
|
|
|
|
uses: docker://arm64v8/ubuntu:focal
|
|
|
|
name: Cleanup (aarch64 linux)
|
|
|
|
with:
|
|
|
|
args: rm -rf .ghcup/ cabal/ dist-newstyle/ out/ cabal-cache
|
|
|
|
|
|
|
|
|