-
Notifications
You must be signed in to change notification settings - Fork 122
123 lines (105 loc) · 3.24 KB
/
release.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
name: Release tarball
on: [workflow_dispatch]
permissions:
id-token: write
attestations: write
env:
OPAMVERBOSE: 1
jobs:
build:
strategy:
matrix:
include:
- os: ubuntu-latest
container: rockylinux:8
ocaml_version: 5.0.0
opam_cache_key: rocky8-5.0.0
runs-on: ${{ matrix.os }}
container: ${{ matrix.container }}
env:
# Disable opam warning about running as root.
OPAMROOTISOK: 1
steps:
# This must be before checkout otherwise Github will use a zip of the
# code instead of git clone.
- name: System dependencies
run: |
dnf install --assumeyes \
gmp-devel \
pkg-config \
openssl \
curl \
git \
make \
unzip \
patch \
gcc \
gcc-c++ \
cmake \
bzip2 \
python3 \
findutils \
diffutils \
rsync \
which
- uses: actions/checkout@v4
# Retreive git history (but not files) so that `git desribe` works. This is
# used to set the version info in the compiler (printed by `sail --version`).
# The safe.directory command is needed because the current user does not
# own the git repo directory and that can be a security issue in some case
# (but not this one).
- name: Unshallow git history
run: |
git config --global --add safe.directory '*'
git fetch --unshallow --filter=tree:0
- name: Download OPAM
run: |
curl -L -o /usr/local/bin/opam https://github.com/ocaml/opam/releases/download/2.1.5/opam-2.1.5-i686-linux
chmod +x /usr/local/bin/opam
- name: Restore cached ~/.opam
id: cache-opam-restore
uses: actions/cache/restore@v4
with:
path: ~/.opam
key: ${{ matrix.opam_cache_key }}
- name: Init opam
if: steps.cache-opam-restore.outputs.cache-hit != 'true'
run: |
# Sandboxing doesn't work in Docker.
opam init --disable-sandboxing --yes --no-setup --shell=sh --compiler=${{ matrix.ocaml_version }} && \
eval "$(opam env)" && \
ocaml --version
- name: Save cached opam
if: steps.cache-opam-restore.outputs.cache-hit != 'true'
id: cache-opam-save
uses: actions/cache/save@v4
with:
path: ~/.opam
key: ${{ steps.cache-opam-restore.outputs.cache-primary-key }}
- name: Install Sail
run: |
eval $(opam env)
opam pin --yes --no-action add .
opam install sail --yes
# Build Z3 from source since the binary releases only support glibc 2.31
# and old distros like RHEL 8 have 2.28.
- name: Build Z3
run: |
git clone --depth 1 --branch z3-4.13.0 https://github.com/Z3Prover/z3.git
mkdir z3/build
cd z3/build
cmake -DCMAKE_BUILD_TYPE=Release ..
make -j4
make install
- name: Make release tarball
run: |
eval $(opam env)
make tarball TARBALL_EXTRA_BIN=$(which z3)
- uses: actions/attest-build-provenance@v1
with:
subject-path: _build/sail.tar.gz
- name: Upload tarball
uses: actions/upload-artifact@v4
with:
name: sail
path: _build/sail.tar.gz