-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathMakefile
86 lines (76 loc) · 2.54 KB
/
Makefile
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
# Default flags
XSOCK?=/tmp/.X11-unix
DUNSTRC=${HOME}/.config/dunst/dunstrc
DOCKER_REPO?=dunst/dunst
DOCKER_REPO_CI?=ghcr.io/dunst-project/docker-images
DOCKER_TECHNIQUE?=build
REPO=./dunst
CFLAGS?=-Werror
DOCKER?=docker
DOCKER_TARGETS?=all dunstify test-valgrind install
# Temporary workaround to fix an incompatibility of clang 14 with valgrind 3.19.
# clang 14 uses dwarf v5 by default which valgrind just supports 3.20 and newer.
# This can be removed once debian-bookworm and ubuntu-jammy are retired or they
# backported a newer version of valgrind.
ifeq (clang, ${CC})
CFLAGS+=-gdwarf-4
endif
# Structure of the makefile
#
# We have generic targets (run pull build clean), wich
# depend on the image's specific target
#
# Every docker image flavor has a unique name. It is used as
# the docker repository's tag and the tag is encoded in the
# target's name, whenever the target is image-specific.
#
# Every target is constructed by `ci-<action>-<flavor>`,
# which actually build/pull/run the single docker image.
#
# The image names for the flavors are found in the variable
# IMG_CI, which is automatically filled (if unset) by the
# Dockerfiles in the ci folder.
IMG_CI?=$(shell find ci -name 'Dockerfile.*' | sed 's/ci\/Dockerfile\.\(.*\)/\1/')
# force make to execute the find call only once
IMG_CI:=${IMG_CI}
.PHONY: all ci pull build clean
all: ci
ci: ci-run
run: ci-run
pull: ci-pull
build: ci-build
clean: ci-clean
# Pull all images from docker hub
ci-pull: ${IMG_CI:%=ci-pull-%}
ci-pull-%:
$(DOCKER) pull "${DOCKER_REPO_CI}:${@:ci-pull-%=%}"
# Build all images locally from the git repository
ci-build: ${IMG_CI:%=ci-build-%}
ci-build-%:
$(DOCKER) build \
-t "${DOCKER_REPO_CI}:${@:ci-build-%=%}" \
-f ci/Dockerfile.${@:ci-build-%=%} \
ci
# Run the CI scripts on different distros
# This requires the docker images to be locally on the machine
# with the variable DOCKER_TECHNIQUE=(pull|build) you can define,
# if the images will get built or pulled before
ci-run: ${IMG_CI:%=ci-run-%}
ci-run-%: ci-${DOCKER_TECHNIQUE}-%
$(eval RAND := $(shell date +%s))
[ -e "${REPO}" ]
$(DOCKER) run \
--rm \
--hostname "${@:ci-run-%=%}" \
-v "$(shell readlink -f ${REPO}):/dunstrepo" \
-e DIR_REPO="/dunstrepo" \
-e DIR_BUILD="/srv/dunstrepo-${RAND}" \
-e PREFIX="/srv/${RAND}-install" \
-e TARGETS="${DOCKER_TARGETS}" \
-e CC="${CC}" \
-e CFLAGS="${CFLAGS}" \
"${DOCKER_REPO_CI}:${@:ci-run-%=%}"
# Remove the images from your local docker machine
ci-clean: ${IMG_CI:%=ci-clean-%}
ci-clean-%:
-$(DOCKER) image rm "${DOCKER_REPO_CI}:${@:ci-clean-%=%}"