summaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
authorGuillaume Boisseau2024-05-14 15:20:34 +0200
committerGitHub2024-05-14 15:20:34 +0200
commit0d5ef8ac5abc49e5adabee97edbb7ff712bd8d10 (patch)
tree45bd9be065218c24c259a84fd95c68644b7bf722 /scripts
parent44b31973eb5a8c27e5620081669488e3b5899638 (diff)
parent50f5794587c56be833bd2fc0f48d008a46fc69a0 (diff)
Merge pull request #169 from AeneasVerif/charon-pin
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/check-charon-install.sh69
-rwxr-xr-xscripts/update-charon-pin.sh7
2 files changed, 76 insertions, 0 deletions
diff --git a/scripts/check-charon-install.sh b/scripts/check-charon-install.sh
new file mode 100755
index 00000000..4f7a79d7
--- /dev/null
+++ b/scripts/check-charon-install.sh
@@ -0,0 +1,69 @@
+#!/usr/bin/env bash
+# This script checks that `./charon` contains a correctly set-up charon. Pass `--force` to execute the suggested commands.
+
+FORCE=
+if [[ "$1" == "--force" ]]; then
+ FORCE=1
+fi
+
+rebuild() {
+ if which rustup 2> /dev/null 1>&2; then
+ make test
+ elif which nix 2> /dev/null 1>&2; then
+ nix develop --command bash -c "make test"
+ else
+ echo 'Error: Neither `rustup` nor `nix` appears to be installed. Install one or the other in order to build `charon`.'
+ exit 1
+ fi
+}
+
+PINNED_COMMIT="$(tail -1 charon-pin)"
+if [ ! -e ./charon ]; then
+ if [[ "$FORCE" == "1" ]]; then
+ git clone https://github.com/AeneasVerif/charon
+ cd charon && git checkout "$PINNED_COMMIT" && rebuild
+ exit 0
+ else
+ echo 'Error: `charon` not found. Please clone the charon repository into `./charon` at the commit specified '\
+ 'in `./charon-pin`, or make a symlink to an existing clone of charon:'
+ echo ' $ git clone https://github.com/AeneasVerif/charon'
+ echo ' $ cd charon && git checkout '"$PINNED_COMMIT"' && make test'
+ echo 'To do this automatically, run `make setup-charon`.'
+ exit 1
+ fi
+fi
+
+# If charon is a symlink, we assume it's a working copy so we won't check
+# commit hashes.
+CHARON_IS_SYMLINK=
+if [ -L charon ]; then
+ echo 'Warning: `./charon` is a symlink; we assume it is a working copy and will not check commit hashes.'
+ CHARON_IS_SYMLINK=1
+fi
+
+cd charon
+
+ACTUAL_COMMIT="$(git rev-parse HEAD)"
+if [[ "$CHARON_IS_SYMLINK" != "1" && "$ACTUAL_COMMIT" != "$PINNED_COMMIT" ]]; then
+ if [[ "$FORCE" == "1" ]]; then
+ git checkout "$PINNED_COMMIT" && rebuild
+ exit 0
+ else
+ echo 'Error: `charon` commit is not the pinned commit. Update the charon repository to the commit specified in `./charon-pin`:'
+ echo ' $ cd charon && git checkout '"$PINNED_COMMIT"' && make test'
+ echo 'To do this automatically, run `make setup-charon`.'
+ exit 1
+ fi
+fi
+
+if [[ "$FORCE" == "1" ]]; then
+ rebuild
+ exit 0
+else
+ if [ ! -f bin/charon ]; then
+ echo 'Error: `./bin/charon` not found. The charon binary is needed to run aeneas tests; please build it:'
+ echo ' $ cd charon && make test'
+ echo 'To do this automatically, run `make setup-charon`.'
+ exit 1
+ fi
+fi
diff --git a/scripts/update-charon-pin.sh b/scripts/update-charon-pin.sh
new file mode 100755
index 00000000..418602b8
--- /dev/null
+++ b/scripts/update-charon-pin.sh
@@ -0,0 +1,7 @@
+#!/usr/bin/env bash
+if ! which jq 2> /dev/null 1>&2; then
+ echo 'Error: command `jq` not found.'
+ exit 1
+fi
+echo '# This is the commit from https://github.com/AeneasVerif/charon that should be used with this version of aeneas.' > ./charon-pin
+jq -r .nodes.charon.locked.rev flake.lock >> ./charon-pin