mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-03 19:36:16 +01:00
630930a60b
This is identical to the debian-stable image, except that it uses packages from the i386 dpkg architecture (i686-linux-gnu) instead of amd64 (x86_64-linux-gnu). x86_64 Docker hosts with x86_64 kernels can run i386 Docker images, so we can use our existing CI workers. Instead of duplicating the content of the Dockerfile, add a layer of architecture-switching so we can build essentially the same image from a different base. Signed-off-by: Simon McVittie <smcv@debian.org>
165 lines
4.5 KiB
Bash
Executable File
165 lines
4.5 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
read_arg() {
|
|
# $1 = arg name
|
|
# $2 = arg value
|
|
# $3 = arg parameter
|
|
local rematch='^[^=]*=(.*)$'
|
|
if [[ $2 =~ $rematch ]]; then
|
|
read -r "$1" <<< "${BASH_REMATCH[1]}"
|
|
else
|
|
read -r "$1" <<< "$3"
|
|
# There is no way to shift our callers args, so
|
|
# return 1 to indicate they should do it instead.
|
|
return 1
|
|
fi
|
|
}
|
|
|
|
if type -p podman; then
|
|
# Using podman
|
|
DOCKER_CMD="podman"
|
|
# Docker is actually implemented by podman, and its OCI output
|
|
# is incompatible with some of the dockerd instances on GitLab
|
|
# CI runners.
|
|
export BUILDAH_FORMAT=docker
|
|
elif getent group docker | grep -q "\b${USER}\b"; then
|
|
DOCKER_CMD="docker"
|
|
else
|
|
DOCKER_CMD="sudo docker"
|
|
fi
|
|
|
|
set -e
|
|
|
|
base=""
|
|
base_version=""
|
|
build=0
|
|
run=0
|
|
push=0
|
|
list=0
|
|
print_help=0
|
|
no_login=0
|
|
|
|
while (($# > 0)); do
|
|
case "${1%%=*}" in
|
|
build) build=1;;
|
|
run) run=1;;
|
|
push) push=1;;
|
|
list) list=1;;
|
|
help) print_help=1;;
|
|
--base|-b) read_arg base "$@" || shift;;
|
|
--base-version) read_arg base_version "$@" || shift;;
|
|
--no-login) no_login=1;;
|
|
*) echo -e "\\e[1;31mERROR\\e[0m: Unknown option '$1'"; exit 1;;
|
|
esac
|
|
shift
|
|
done
|
|
|
|
if [ $print_help == 1 ]; then
|
|
echo "$0 - Build and run Docker images"
|
|
echo ""
|
|
echo "Usage: $0 <command> [options] [basename]"
|
|
echo ""
|
|
echo "Available commands"
|
|
echo ""
|
|
echo " build --base=<BASENAME> - Build Docker image <BASENAME>.Dockerfile"
|
|
echo " run --base=<BASENAME> - Run Docker image <BASENAME>"
|
|
echo " push --base=<BASENAME> - Push Docker image <BASENAME> to the registry"
|
|
echo " list - List available images"
|
|
echo " help - This help message"
|
|
echo ""
|
|
echo "Options"
|
|
echo ""
|
|
echo " --base-version NUM - Image is version NUM"
|
|
echo " --no-login - Don't log in to registry"
|
|
echo ""
|
|
exit 0
|
|
fi
|
|
|
|
cd "$(dirname "$0")"
|
|
|
|
if [ $list == 1 ]; then
|
|
echo "Available Docker images:"
|
|
for f in *.Dockerfile; do
|
|
filename=$( basename -- "$f" )
|
|
basename="${filename%.*}"
|
|
|
|
echo -e " \\e[1;39m$basename\\e[0m"
|
|
done
|
|
# Special cases that don't have their own Dockerfile
|
|
echo -e " \\e[1;39mdebian-stable-i386\\e[0m"
|
|
exit 0
|
|
fi
|
|
|
|
# All commands after this require --base to be set
|
|
if [ -z "${base}" ]; then
|
|
echo "Usage: $0 <command>"
|
|
exit 1
|
|
fi
|
|
|
|
case "$base" in
|
|
(debian-stable-i386)
|
|
dockerfile=debian-stable
|
|
arch=386
|
|
if [ "$DOCKER_CMD" = "podman" ]; then
|
|
arch_prefix=docker.io/i386/
|
|
else
|
|
arch_prefix=i386/
|
|
fi
|
|
;;
|
|
(*)
|
|
dockerfile="$base"
|
|
arch=""
|
|
arch_prefix=""
|
|
;;
|
|
esac
|
|
|
|
if [ ! -f "$dockerfile.Dockerfile" ]; then
|
|
echo -e "\\e[1;31mERROR\\e[0m: Dockerfile for '$dockerfile' not found"
|
|
exit 1
|
|
fi
|
|
|
|
if [ -z "${base_version}" ]; then
|
|
base_version="latest"
|
|
else
|
|
base_version="v$base_version"
|
|
fi
|
|
|
|
TAG="registry.gitlab.gnome.org/gnome/glib/${base}:${base_version}"
|
|
|
|
if [ $build == 1 ]; then
|
|
echo -e "\\e[1;32mBUILDING\\e[0m: ${base} as ${TAG}"
|
|
$DOCKER_CMD build \
|
|
--build-arg HOST_USER_ID="$UID" \
|
|
--build-arg COVERITY_SCAN_PROJECT_NAME="${COVERITY_SCAN_PROJECT_NAME}" \
|
|
--build-arg COVERITY_SCAN_TOKEN="${COVERITY_SCAN_TOKEN}" \
|
|
${arch_prefix+--build-arg ARCHITECTURE_PREFIX="${arch_prefix}"} \
|
|
${arch+--arch="$arch"} \
|
|
--tag "${TAG}" \
|
|
--file "${dockerfile}.Dockerfile" .
|
|
exit $?
|
|
fi
|
|
|
|
if [ $push == 1 ]; then
|
|
echo -e "\\e[1;32mPUSHING\\e[0m: ${base} as ${TAG}"
|
|
|
|
if [ $no_login == 0 ]; then
|
|
$DOCKER_CMD login registry.gitlab.gnome.org
|
|
fi
|
|
|
|
$DOCKER_CMD push $TAG
|
|
exit $?
|
|
fi
|
|
|
|
if [ $run == 1 ]; then
|
|
echo -e "\\e[1;32mRUNNING\\e[0m: ${base} as ${TAG}"
|
|
$DOCKER_CMD run \
|
|
${arch+--arch="$arch"} \
|
|
--rm \
|
|
--volume "$(pwd)/..:/home/user/app" \
|
|
--workdir "/home/user/app" \
|
|
--tty \
|
|
--interactive "${TAG}" \
|
|
bash
|
|
exit $?
|
|
fi
|