From 10830bedfa7d06af1cf3de9390814167f5d35485 Mon Sep 17 00:00:00 2001 From: Ralf Jung <jung@mpi-sws.org> Date: Wed, 20 Sep 2017 23:14:22 +0200 Subject: [PATCH] fix opam --- Makefile | 2 +- build/opam-ci.sh | 40 +++++++++++++++++++++++----------------- 2 files changed, 24 insertions(+), 18 deletions(-) diff --git a/Makefile b/Makefile index 483d8f937..69ffb18b7 100644 --- a/Makefile +++ b/Makefile @@ -34,7 +34,7 @@ build-dep: build-dep/opam phony # Add the pin and (re)install build-dep package. @# Reinstallation is needed in case the pin already exists, but the builddep package changed. @BUILD_DEP_PACKAGE="$$(egrep "^name:" build-dep/opam | sed 's/^name: *"\(.*\)" */\1/')"; \ - opam pin add "$$BUILD_DEP_PACKAGE" "$$(pwd)/build-dep" -k path $(OPAMFLAGS) && \ + opam pin add "$$BUILD_DEP_PACKAGE".dev "$$(pwd)/build-dep" -k path $(OPAMFLAGS) && \ opam reinstall "$$BUILD_DEP_PACKAGE" # Some files that do *not* need to be forwarded to Makefile.coq diff --git a/build/opam-ci.sh b/build/opam-ci.sh index 81d270443..27ae623d2 100755 --- a/build/opam-ci.sh +++ b/build/opam-ci.sh @@ -1,30 +1,38 @@ #!/bin/bash set -e ## This script installs the build dependencies for CI builds. +function run_and_print() { + echo "$ $@" + "$@" +} # Prepare OPAM configuration export OPAMROOT="$(pwd)/opamroot" export OPAMJOBS="$((2*$CPU_CORES))" export OPAM_EDITOR="$(which false)" -# Make sure we got a good OPAM -test -d "$OPAMROOT" || (mkdir "$OPAMROOT" && opam init --no-setup -y) +# Make sure we got a good OPAM. +test -d "$OPAMROOT" || (mkdir "$OPAMROOT" && run_and_print opam init --no-setup -y) eval `opam conf env` +# Delete old pins from opam.pins times. +run_and_print opam pin remove coq-stdpp -n +run_and_print opam pin remove coq-iris -n +# Make sure the pin for the builddep package is not stale. +run_and_print make build-dep/opam + +# Get us all the latest repositories if test $(find "$OPAMROOT/repo/package-index" -mtime +0); then # last update was more than a day ago - opam update + run_and_print opam update else # only update iris-dev - test -d "$OPAMROOT/repo/iris-dev" && opam update iris-dev + if test -d "$OPAMROOT/repo/iris-dev"; then run_and_print opam update iris-dev; fi fi -test -d "$OPAMROOT/repo/coq-extra-dev" && opam repo remove coq-extra-dev -test -d "$OPAMROOT/repo/coq-core-dev" || opam repo add coq-core-dev https://coq.inria.fr/opam/core-dev -p 5 -test -d "$OPAMROOT/repo/coq-released" || opam repo add coq-released https://coq.inria.fr/opam/released -p 10 -test -d "$OPAMROOT/repo/iris-dev" || opam repo add iris-dev https://gitlab.mpi-sws.org/FP/opam-dev.git -p 20 - -# Make sure we have no undesired pins left from opam.pins times -opam pin remove coq-stdpp -n -opam pin remove coq-iris -n +test -d "$OPAMROOT/repo/coq-extra-dev" && run_and_print opam repo remove coq-extra-dev +test -d "$OPAMROOT/repo/coq-core-dev" || run_and_print opam repo add coq-core-dev https://coq.inria.fr/opam/core-dev -p 5 +test -d "$OPAMROOT/repo/coq-released" || run_and_print opam repo add coq-released https://coq.inria.fr/opam/released -p 10 +test -d "$OPAMROOT/repo/iris-dev" || run_and_print opam repo add iris-dev https://gitlab.mpi-sws.org/FP/opam-dev.git -p 20 +echo # We really want to run all of the following in one opam transaction, but due to opam limitations, # that is not currently possible. @@ -40,16 +48,14 @@ while (( "$#" )); do # while there are arguments left echo "[opam-ci] $PACKAGE already pinned to $VERSION" else echo "[opam-ci] Pinning $PACKAGE to $VERSION" - opam pin add "$PACKAGE" "$VERSION" -k version -y + run_and_print opam pin add "$PACKAGE" "$VERSION" -k version -y fi done -# Make sure the pin for the builddep package is not stale. -make build-dep/opam - # Upgrade cached things. +echo echo "[opam-ci] Upgrading opam" -opam upgrade -y +run_and_print opam upgrade -y # Install build-dependencies. echo -- GitLab