From 1f076432db1ec20f5100a11b948e733685bc8557 Mon Sep 17 00:00:00 2001 From: Matthias Clasen Date: Mon, 1 Jul 2024 22:07:41 -0400 Subject: [PATCH] ci: Use catch to capture stacktraces For now, just try this out for the release build. If it works, we can add it to the other jobs too. --- .gitlab-ci.yml | 5 +- .gitlab-ci/install-meson-project.sh | 91 +++++++++++++++++++++++++++++ 2 files changed, 94 insertions(+), 2 deletions(-) create mode 100755 .gitlab-ci/install-meson-project.sh diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 3fa3ba16d1..35936c37d8 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -117,10 +117,11 @@ release-build: EXTRA_MESON_FLAGS: "--buildtype=release" script: - .gitlab-ci/show-info-linux.sh - - export PATH="$HOME/.local/bin:$PATH" + - mkdir _install + - export PATH="$HOME/.local/bin:${CI_PROJECT_DIR}/_install/bin:$PATH" + - .gitlab-ci/install-meson-project.sh --prefix ${CI_PROJECT_DIR}/_install https://gitlab.gnome.org/jadahl/catch.git main - meson subprojects download - meson subprojects update --reset - - mkdir _install - meson setup --prefix=${CI_PROJECT_DIR}/_install ${COMMON_MESON_FLAGS} diff --git a/.gitlab-ci/install-meson-project.sh b/.gitlab-ci/install-meson-project.sh new file mode 100755 index 0000000000..67e55b75c2 --- /dev/null +++ b/.gitlab-ci/install-meson-project.sh @@ -0,0 +1,91 @@ +#!/bin/bash + +set -e + +usage() { + cat <<-EOF + Usage: $(basename $0) [OPTION…] REPO_URL COMMIT + + Check out and install a meson project + + Options: + -Dkey=val Option to pass on to meson + --prefix Prefix to install to + --subdir Build subdirectory instead of whole project + --prepare Script to run before build + + -h, --help Display this help + + EOF +} + +TEMP=$(getopt \ + --name=$(basename $0) \ + --options='D:h' \ + --longoptions='prefix:' \ + --longoptions='subdir:' \ + --longoptions='prepare:' \ + --longoptions='help' \ + -- "$@") + +eval set -- "$TEMP" +unset TEMP + +MESON_OPTIONS=() +PREFIX=/usr +SUBDIR=. +PREPARE=: + +while true; do + case "$1" in + -D) + MESON_OPTIONS+=( -D$2 ) + shift 2 + ;; + + --prefix) + PREFIX=$2 + shift 2 + ;; + + --subdir) + SUBDIR=$2 + shift 2 + ;; + + --prepare) + PREPARE=$2 + shift 2 + ;; + + -h|--help) + usage + exit 0 + ;; + + --) + shift + break + ;; + esac +done + +if [[ $# -lt 2 ]]; then + usage + exit 1 +fi + +REPO_URL="$1" +COMMIT="$2" + +CHECKOUT_DIR=$(mktemp --directory) +trap "rm -rf $CHECKOUT_DIR" EXIT + +git clone --depth 1 "$REPO_URL" -b "$COMMIT" "$CHECKOUT_DIR" + +pushd "$CHECKOUT_DIR/$SUBDIR" +sh -c "$PREPARE" +meson setup --prefix "$PREFIX" _build "${MESON_OPTIONS[@]}" +meson compile -C _build +meson install -C _build +popd